Ci8qIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tClNvZnR3YXJlIExpY2Vuc2UgZm9yIFRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZAoKqSBDb3B5cmlnaHQgIDE5OTUgLSAyMDE1IEZyYXVuaG9mZXItR2VzZWxsc2NoYWZ0IHp1ciBG9nJkZXJ1bmcgZGVyIGFuZ2V3YW5kdGVuIEZvcnNjaHVuZyBlLlYuCiAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAxLiAgICBJTlRST0RVQ1RJT04KVGhlIEZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkICgiRkRLIEFBQyBDb2RlYyIpIGlzIHNvZnR3YXJlIHRoYXQgaW1wbGVtZW50cwp0aGUgTVBFRyBBZHZhbmNlZCBBdWRpbyBDb2RpbmcgKCJBQUMiKSBlbmNvZGluZyBhbmQgZGVjb2Rpbmcgc2NoZW1lIGZvciBkaWdpdGFsIGF1ZGlvLgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgaW50ZW5kZWQgdG8gYmUgdXNlZCBvbiBhIHdpZGUgdmFyaWV0eSBvZiBBbmRyb2lkIGRldmljZXMuCgpBQUMncyBIRS1BQUMgYW5kIEhFLUFBQyB2MiB2ZXJzaW9ucyBhcmUgcmVnYXJkZWQgYXMgdG9kYXkncyBtb3N0IGVmZmljaWVudCBnZW5lcmFsIHBlcmNlcHR1YWwKYXVkaW8gY29kZWNzLiBBQUMtRUxEIGlzIGNvbnNpZGVyZWQgdGhlIGJlc3QtcGVyZm9ybWluZyBmdWxsLWJhbmR3aWR0aCBjb21tdW5pY2F0aW9ucyBjb2RlYyBieQppbmRlcGVuZGVudCBzdHVkaWVzIGFuZCBpcyB3aWRlbHkgZGVwbG95ZWQuIEFBQyBoYXMgYmVlbiBzdGFuZGFyZGl6ZWQgYnkgSVNPIGFuZCBJRUMgYXMgcGFydApvZiB0aGUgTVBFRyBzcGVjaWZpY2F0aW9ucy4KClBhdGVudCBsaWNlbnNlcyBmb3IgbmVjZXNzYXJ5IHBhdGVudCBjbGFpbXMgZm9yIHRoZSBGREsgQUFDIENvZGVjIChpbmNsdWRpbmcgdGhvc2Ugb2YgRnJhdW5ob2ZlcikKbWF5IGJlIG9idGFpbmVkIHRocm91Z2ggVmlhIExpY2Vuc2luZyAod3d3LnZpYWxpY2Vuc2luZy5jb20pIG9yIHRocm91Z2ggdGhlIHJlc3BlY3RpdmUgcGF0ZW50IG93bmVycwppbmRpdmlkdWFsbHkgZm9yIHRoZSBwdXJwb3NlIG9mIGVuY29kaW5nIG9yIGRlY29kaW5nIGJpdCBzdHJlYW1zIGluIHByb2R1Y3RzIHRoYXQgYXJlIGNvbXBsaWFudCB3aXRoCnRoZSBJU08vSUVDIE1QRUcgYXVkaW8gc3RhbmRhcmRzLiBQbGVhc2Ugbm90ZSB0aGF0IG1vc3QgbWFudWZhY3R1cmVycyBvZiBBbmRyb2lkIGRldmljZXMgYWxyZWFkeSBsaWNlbnNlCnRoZXNlIHBhdGVudCBjbGFpbXMgdGhyb3VnaCBWaWEgTGljZW5zaW5nIG9yIGRpcmVjdGx5IGZyb20gdGhlIHBhdGVudCBvd25lcnMsIGFuZCB0aGVyZWZvcmUgRkRLIEFBQyBDb2RlYwpzb2Z0d2FyZSBtYXkgYWxyZWFkeSBiZSBjb3ZlcmVkIHVuZGVyIHRob3NlIHBhdGVudCBsaWNlbnNlcyB3aGVuIGl0IGlzIHVzZWQgZm9yIHRob3NlIGxpY2Vuc2VkIHB1cnBvc2VzIG9ubHkuCgpDb21tZXJjaWFsbHktbGljZW5zZWQgQUFDIHNvZnR3YXJlIGxpYnJhcmllcywgaW5jbHVkaW5nIGZsb2F0aW5nLXBvaW50IHZlcnNpb25zIHdpdGggZW5oYW5jZWQgc291bmQgcXVhbGl0eSwKYXJlIGFsc28gYXZhaWxhYmxlIGZyb20gRnJhdW5ob2Zlci4gVXNlcnMgYXJlIGVuY291cmFnZWQgdG8gY2hlY2sgdGhlIEZyYXVuaG9mZXIgd2Vic2l0ZSBmb3IgYWRkaXRpb25hbAphcHBsaWNhdGlvbnMgaW5mb3JtYXRpb24gYW5kIGRvY3VtZW50YXRpb24uCgoyLiAgICBDT1BZUklHSFQgTElDRU5TRQoKUmVkaXN0cmlidXRpb24gYW5kIHVzZSBpbiBzb3VyY2UgYW5kIGJpbmFyeSBmb3Jtcywgd2l0aCBvciB3aXRob3V0IG1vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCB3aXRob3V0CnBheW1lbnQgb2YgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBwcm92aWRlZCB0aGF0IHlvdSBzYXRpc2Z5IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoKCllvdSBtdXN0IHJldGFpbiB0aGUgY29tcGxldGUgdGV4dCBvZiB0aGlzIHNvZnR3YXJlIGxpY2Vuc2UgaW4gcmVkaXN0cmlidXRpb25zIG9mIHRoZSBGREsgQUFDIENvZGVjIG9yCnlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvIGluIHNvdXJjZSBjb2RlIGZvcm0uCgpZb3UgbXVzdCByZXRhaW4gdGhlIGNvbXBsZXRlIHRleHQgb2YgdGhpcyBzb2Z0d2FyZSBsaWNlbnNlIGluIHRoZSBkb2N1bWVudGF0aW9uIGFuZC9vciBvdGhlciBtYXRlcmlhbHMKcHJvdmlkZWQgd2l0aCByZWRpc3RyaWJ1dGlvbnMgb2YgdGhlIEZESyBBQUMgQ29kZWMgb3IgeW91ciBtb2RpZmljYXRpb25zIHRoZXJldG8gaW4gYmluYXJ5IGZvcm0uCllvdSBtdXN0IG1ha2UgYXZhaWxhYmxlIGZyZWUgb2YgY2hhcmdlIGNvcGllcyBvZiB0aGUgY29tcGxldGUgc291cmNlIGNvZGUgb2YgdGhlIEZESyBBQUMgQ29kZWMgYW5kIHlvdXIKbW9kaWZpY2F0aW9ucyB0aGVyZXRvIHRvIHJlY2lwaWVudHMgb2YgY29waWVzIGluIGJpbmFyeSBmb3JtLgoKVGhlIG5hbWUgb2YgRnJhdW5ob2ZlciBtYXkgbm90IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIGxpYnJhcnkgd2l0aG91dApwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgpZb3UgbWF5IG5vdCBjaGFyZ2UgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBmb3IgYW55b25lIHRvIHVzZSwgY29weSBvciBkaXN0cmlidXRlIHRoZSBGREsgQUFDIENvZGVjCnNvZnR3YXJlIG9yIHlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvLgoKWW91ciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYyBtdXN0IGNhcnJ5IHByb21pbmVudCBub3RpY2VzIHN0YXRpbmcgdGhhdCB5b3UgY2hhbmdlZCB0aGUgc29mdHdhcmUKYW5kIHRoZSBkYXRlIG9mIGFueSBjaGFuZ2UuIEZvciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYywgdGhlIHRlcm0KIkZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkIiBtdXN0IGJlIHJlcGxhY2VkIGJ5IHRoZSB0ZXJtCiJUaGlyZC1QYXJ0eSBNb2RpZmllZCBWZXJzaW9uIG9mIHRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZC4iCgozLiAgICBOTyBQQVRFTlQgTElDRU5TRQoKTk8gRVhQUkVTUyBPUiBJTVBMSUVEIExJQ0VOU0VTIFRPIEFOWSBQQVRFTlQgQ0xBSU1TLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSBwYXRlbnRzIG9mIEZyYXVuaG9mZXIsCkFSRSBHUkFOVEVEIEJZIFRISVMgU09GVFdBUkUgTElDRU5TRS4gRnJhdW5ob2ZlciBwcm92aWRlcyBubyB3YXJyYW50eSBvZiBwYXRlbnQgbm9uLWluZnJpbmdlbWVudCB3aXRoCnJlc3BlY3QgdG8gdGhpcyBzb2Z0d2FyZS4KCllvdSBtYXkgdXNlIHRoaXMgRkRLIEFBQyBDb2RlYyBzb2Z0d2FyZSBvciBtb2RpZmljYXRpb25zIHRoZXJldG8gb25seSBmb3IgcHVycG9zZXMgdGhhdCBhcmUgYXV0aG9yaXplZApieSBhcHByb3ByaWF0ZSBwYXRlbnQgbGljZW5zZXMuCgo0LiAgICBESVNDTEFJTUVSCgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgcHJvdmlkZWQgYnkgRnJhdW5ob2ZlciBvbiBiZWhhbGYgb2YgdGhlIGNvcHlyaWdodCBob2xkZXJzIGFuZCBjb250cmlidXRvcnMKIkFTIElTIiBhbmQgV0lUSE9VVCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIGluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gdGhlIGltcGxpZWQgd2FycmFudGllcwpvZiBtZXJjaGFudGFiaWxpdHkgYW5kIGZpdG5lc3MgZm9yIGEgcGFydGljdWxhciBwdXJwb3NlLiBJTiBOTyBFVkVOVCBTSEFMTCBUSEUgQ09QWVJJR0hUIEhPTERFUiBPUgpDT05UUklCVVRPUlMgQkUgTElBQkxFIGZvciBhbnkgZGlyZWN0LCBpbmRpcmVjdCwgaW5jaWRlbnRhbCwgc3BlY2lhbCwgZXhlbXBsYXJ5LCBvciBjb25zZXF1ZW50aWFsIGRhbWFnZXMsCmluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gcHJvY3VyZW1lbnQgb2Ygc3Vic3RpdHV0ZSBnb29kcyBvciBzZXJ2aWNlczsgbG9zcyBvZiB1c2UsIGRhdGEsIG9yIHByb2ZpdHMsCm9yIGJ1c2luZXNzIGludGVycnVwdGlvbiwgaG93ZXZlciBjYXVzZWQgYW5kIG9uIGFueSB0aGVvcnkgb2YgbGlhYmlsaXR5LCB3aGV0aGVyIGluIGNvbnRyYWN0LCBzdHJpY3QKbGlhYmlsaXR5LCBvciB0b3J0IChpbmNsdWRpbmcgbmVnbGlnZW5jZSksIGFyaXNpbmcgaW4gYW55IHdheSBvdXQgb2YgdGhlIHVzZSBvZiB0aGlzIHNvZnR3YXJlLCBldmVuIGlmCmFkdmlzZWQgb2YgdGhlIHBvc3NpYmlsaXR5IG9mIHN1Y2ggZGFtYWdlLgoKNS4gICAgQ09OVEFDVCBJTkZPUk1BVElPTgoKRnJhdW5ob2ZlciBJbnN0aXR1dGUgZm9yIEludGVncmF0ZWQgQ2lyY3VpdHMgSUlTCkF0dGVudGlvbjogQXVkaW8gYW5kIE11bHRpbWVkaWEgRGVwYXJ0bWVudHMgLSBGREsgQUFDIExMCkFtIFdvbGZzbWFudGVsIDMzCjkxMDU4IEVybGFuZ2VuLCBHZXJtYW55Cgp3d3cuaWlzLmZyYXVuaG9mZXIuZGUvYW1tCmFtbS1pbmZvQGlpcy5mcmF1bmhvZmVyLmRlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiogTVBFRyBBdWRpbyBFbmNvZGVyICoqKioqKioqKioqKioqKioqKioqKioqKioqCgogICBJbml0aWFsIGF1dGhvcjogICAgICAgTS5XZXJuZXIKICAgY29udGVudHMvZGVzY3JpcHRpb246IFF1YW50aXphdGlvbgoKKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKI2luY2x1ZGUgInF1YW50aXplLmgiCgojaW5jbHVkZSAiYWFjRW5jX3JvbS5oIgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgogICAgZnVuY3Rpb25uYW1lOiBGREthYWNFbmNfcXVhbnRpemVMaW5lcwogICAgZGVzY3JpcHRpb246IHF1YW50aXplcyBzcGVjdHJ1bSBsaW5lcwogICAgcmV0dXJuczoKICAgIGlucHV0OiBnbG9iYWwgZ2FpbiwgbnVtYmVyIG9mIGxpbmVzIHRvIHByb2Nlc3MsIHNwZWN0cmFsIGRhdGEKICAgIG91dHB1dDogcXVhbnRpemVkIHNwZWN0cnVtCgoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQgRkRLYWFjRW5jX3F1YW50aXplTGluZXMoSU5UICAgICAgZ2FpbiwKICAgICAgICAgICAgICAgICAgICAgICAgICBJTlQgICAgICBub09mTGluZXMsCiAgICAgICAgICAgICAgICAgICAgICAgICAgRklYUF9EQkwgKm1kY3RTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgICAgICBTSE9SVCAgICAqcXVhU3BlY3RydW0sCiAgICAgICAgICAgICAgICAgICAgICAgICAgSU5UICAgICAgZFpvbmVRdWFudEVuYWJsZSkKewogIGludCAgIGxpbmU7CiAgRklYUF9EQkwgayA9IEZMMkZYQ09OU1RfREJMKDAuMGYpOwogIEZJWFBfUVREIHF1YW50aXplciA9IEZES2FhY0VuY19xdWFudFRhYmxlUVsoLWdhaW4pJjNdOwogIElOVCAgICAgIHF1YW50aXplcnNoaWZ0ID0gKCgtZ2Fpbik+PjIpKzE7CiAgY29uc3QgSU5UIGtTaGlmdD0xNjsKCiAgaWYgKGRab25lUXVhbnRFbmFibGUpCiAgICBrID0gRkwyRlhDT05TVF9EQkwoMC4yM2YpPj5rU2hpZnQ7CiAgZWxzZQogICAgayA9IEZMMkZYQ09OU1RfREJMKC0wLjA5NDZmICsgMC41Zik+PmtTaGlmdDsKCiAgZm9yIChsaW5lID0gMDsgbGluZSA8IG5vT2ZMaW5lczsgbGluZSsrKQogIHsKICAgIEZJWFBfREJMIGFjY3UgPSBmTXVsdERpdjIobWRjdFNwZWN0cnVtW2xpbmVdLHF1YW50aXplcik7CgogICAgaWYgKGFjY3UgPCBGTDJGWENPTlNUX0RCTCgwLjBmKSkKICAgIHsKICAgICAgYWNjdT0tYWNjdTsKICAgICAgLyogbm9ybWFsaXplICovCiAgICAgIElOVCAgIGFjY3VTaGlmdCA9IENudExlYWRpbmdaZXJvcyhhY2N1KSAtIDE7ICAvKiBDb3VudExlYWRpbmdCaXRzKCkgaXMgbm90IG5lY2Vzc2FyeSBoZXJlIHNpbmNlIHRlc3QgdmFsdWUgaXMgYWx3YXlzID4gMCAqLwogICAgICBhY2N1IDw8PSBhY2N1U2hpZnQ7CiAgICAgIElOVCB0YWJJbmRleCA9IChJTlQpKGFjY3U+PihERlJBQ1RfQklUUy0yLU1BTlRfRElHSVRTKSkmKH5NQU5UX1NJWkUpOwogICAgICBJTlQgdG90YWxTaGlmdCA9IHF1YW50aXplcnNoaWZ0LWFjY3VTaGlmdCsxOwogICAgICBhY2N1ID0gZk11bHREaXYyKEZES2FhY0VuY19tVGFiXzNfNFt0YWJJbmRleF0sRkRLYWFjRW5jX3F1YW50VGFibGVFW3RvdGFsU2hpZnQmM10pOwogICAgICB0b3RhbFNoaWZ0ID0gKDE2LTQpLSgzKih0b3RhbFNoaWZ0Pj4yKSk7CiAgICAgIEZES19BU1NFUlQodG90YWxTaGlmdCA+PTApOyAvKiBNQVhfUVVBTlRfVklPTEFUSU9OICovCiAgICAgIGFjY3UgPj49IGZpeE1pbih0b3RhbFNoaWZ0LERGUkFDVF9CSVRTLTEpOwogICAgICBxdWFTcGVjdHJ1bVtsaW5lXSA9IChTSE9SVCkoLSgoTE9ORykoayArIGFjY3UpID4+IChERlJBQ1RfQklUUy0xLTE2KSkpOwogICAgfQogICAgZWxzZSBpZihhY2N1ID4gRkwyRlhDT05TVF9EQkwoMC4wZikpCiAgICB7CiAgICAgIC8qIG5vcm1hbGl6ZSAqLwogICAgICBJTlQgICBhY2N1U2hpZnQgPSBDbnRMZWFkaW5nWmVyb3MoYWNjdSkgLSAxOyAgLyogQ291bnRMZWFkaW5nQml0cygpIGlzIG5vdCBuZWNlc3NhcnkgaGVyZSBzaW5jZSB0ZXN0IHZhbHVlIGlzIGFsd2F5cyA+IDAgKi8KICAgICAgYWNjdSA8PD0gYWNjdVNoaWZ0OwogICAgICBJTlQgdGFiSW5kZXggPSAoSU5UKShhY2N1Pj4oREZSQUNUX0JJVFMtMi1NQU5UX0RJR0lUUykpJih+TUFOVF9TSVpFKTsKICAgICAgSU5UIHRvdGFsU2hpZnQgPSBxdWFudGl6ZXJzaGlmdC1hY2N1U2hpZnQrMTsKICAgICAgYWNjdSA9IGZNdWx0RGl2MihGREthYWNFbmNfbVRhYl8zXzRbdGFiSW5kZXhdLEZES2FhY0VuY19xdWFudFRhYmxlRVt0b3RhbFNoaWZ0JjNdKTsKICAgICAgdG90YWxTaGlmdCA9ICgxNi00KS0oMyoodG90YWxTaGlmdD4+MikpOwogICAgICBGREtfQVNTRVJUKHRvdGFsU2hpZnQgPj0wKTsgLyogTUFYX1FVQU5UX1ZJT0xBVElPTiAqLwogICAgICBhY2N1ID4+PSBmaXhNaW4odG90YWxTaGlmdCxERlJBQ1RfQklUUy0xKTsKICAgICAgcXVhU3BlY3RydW1bbGluZV0gPSAoU0hPUlQpKChMT05HKShrICsgYWNjdSkgPj4gKERGUkFDVF9CSVRTLTEtMTYpKTsKICAgIH0KICAgIGVsc2UKICAgICAgcXVhU3BlY3RydW1bbGluZV09MDsKICB9Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCiAgICBmdW5jdGlvbm5hbWU6aUZES2FhY0VuY19xdWFudGl6ZUxpbmVzCiAgICBkZXNjcmlwdGlvbjogaXF1YW50aXplcyBzcGVjdHJ1bSBsaW5lcwogICAgICAgICAgICAgICAgIG1kY3RTcGVjdHJ1bSA9IGlxdWFTcGVjdHJ1bV40LzMgKjJeKDAuMjUqZ2FpbikKICAgIGlucHV0OiBnbG9iYWwgZ2FpbiwgbnVtYmVyIG9mIGxpbmVzIHRvIHByb2Nlc3MscXVhbnRpemVkIHNwZWN0cnVtCiAgICBvdXRwdXQ6IHNwZWN0cmFsIGRhdGEKCioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZCBGREthYWNFbmNfaW52UXVhbnRpemVMaW5lcyhJTlQgIGdhaW4sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSU5UICBub09mTGluZXMsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgU0hPUlQgKnF1YW50U3BlY3RydW0sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgRklYUF9EQkwgKm1kY3RTcGVjdHJ1bSkKCnsKICBJTlQgaXF1YW50aXplcm1vZDsKICBJTlQgaXF1YW50aXplcnNoaWZ0OwogIElOVCBsaW5lOwoKICBpcXVhbnRpemVybW9kID0gZ2FpbiYzOwogIGlxdWFudGl6ZXJzaGlmdCA9IGdhaW4+PjI7CgogIGZvciAobGluZSA9IDA7IGxpbmUgPCBub09mTGluZXM7IGxpbmUrKykgewoKICAgIGlmKHF1YW50U3BlY3RydW1bbGluZV0gPCAwKSB7CiAgICAgIEZJWFBfREJMIGFjY3U7CiAgICAgIElOVCBleCxzcGVjRXhwLHRhYkluZGV4OwogICAgICBGSVhQX0RCTCBzLHQ7CgogICAgICBhY2N1ID0gKEZJWFBfREJMKSAtcXVhbnRTcGVjdHJ1bVtsaW5lXTsKCiAgICAgIGV4ID0gQ291bnRMZWFkaW5nQml0cyhhY2N1KTsKICAgICAgYWNjdSA8PD0gZXg7CiAgICAgIHNwZWNFeHAgPSAoREZSQUNUX0JJVFMtMSkgLSBleDsKCiAgICAgIEZES19BU1NFUlQoc3BlY0V4cCA8IDE0KTsgICAgICAgLyogdGhpcyBmYWlscyBpZiBhYnModmFsdWUpID4gODE5MSAqLwoKICAgICAgdGFiSW5kZXggPSAoSU5UKShhY2N1Pj4oREZSQUNUX0JJVFMtMi1NQU5UX0RJR0lUUykpJih+TUFOVF9TSVpFKTsKCiAgICAgIC8qIGNhbGN1bGF0ZSAibWFudGlzc2EiIF40LzMgKi8KICAgICAgcyA9IEZES2FhY0VuY19tVGFiXzRfM0VsY1t0YWJJbmRleF07CgogICAgICAvKiBnZXQgYXBwcm9wZXJpYXRlIGV4cG9uZW50IG11bHRpcGxpZXIgZm9yIHNwZWNFeHBeMy80IGNvbWJpbmVkIHdpdGggc2NmTW9kICovCiAgICAgIHQgPSBGREthYWNFbmNfc3BlY0V4cE1hbnRUYWJsZUNvbWJFbGNbaXF1YW50aXplcm1vZF1bc3BlY0V4cF07CgogICAgICAvKiBtdWx0aXBseSAibWFudGlzc2EiIF40LzMgd2l0aCBleHBvbmVudCBtdWx0aXBsaWVyICovCiAgICAgIGFjY3UgPSBmTXVsdChzLHQpOwoKICAgICAgLyogZ2V0IGFwcHJvcGVyaWF0ZSBleHBvbmVudCBzaGlmdGVyICovCiAgICAgIHNwZWNFeHAgPSBGREthYWNFbmNfc3BlY0V4cFRhYmxlQ29tYltpcXVhbnRpemVybW9kXVtzcGVjRXhwXS0xOyAvKiAtMSB0byBhdm9pZCBvdmVyZmxvd3MgaW4gYWNjdSAqLwoKICAgICAgaWYgKCgtaXF1YW50aXplcnNoaWZ0LXNwZWNFeHApIDwgMCkKICAgICAgICBhY2N1IDw8PSAtKC1pcXVhbnRpemVyc2hpZnQtc3BlY0V4cCk7CiAgICAgIGVsc2UKICAgICAgICBhY2N1ID4+PSAtaXF1YW50aXplcnNoaWZ0LXNwZWNFeHA7CgogICAgICBtZGN0U3BlY3RydW1bbGluZV0gPSAtYWNjdTsKICAgIH0KICAgIGVsc2UgaWYgKHF1YW50U3BlY3RydW1bbGluZV0gPiAwKSB7CiAgICAgIEZJWFBfREJMIGFjY3U7CiAgICAgIElOVCBleCxzcGVjRXhwLHRhYkluZGV4OwogICAgICBGSVhQX0RCTCBzLHQ7CgogICAgICBhY2N1ID0gKEZJWFBfREJMKShJTlQpcXVhbnRTcGVjdHJ1bVtsaW5lXTsKCiAgICAgIGV4ID0gQ291bnRMZWFkaW5nQml0cyhhY2N1KTsKICAgICAgYWNjdSA8PD0gZXg7CiAgICAgIHNwZWNFeHAgPSAoREZSQUNUX0JJVFMtMSkgLSBleDsKCiAgICAgIEZES19BU1NFUlQoc3BlY0V4cCA8IDE0KTsgICAgICAgLyogdGhpcyBmYWlscyBpZiBhYnModmFsdWUpID4gODE5MSAqLwoKICAgICAgdGFiSW5kZXggPSAoSU5UKShhY2N1Pj4oREZSQUNUX0JJVFMtMi1NQU5UX0RJR0lUUykpJih+TUFOVF9TSVpFKTsKCiAgICAgIC8qIGNhbGN1bGF0ZSAibWFudGlzc2EiIF40LzMgKi8KICAgICAgcyA9IEZES2FhY0VuY19tVGFiXzRfM0VsY1t0YWJJbmRleF07CgogICAgICAvKiBnZXQgYXBwcm9wZXJpYXRlIGV4cG9uZW50IG11bHRpcGxpZXIgZm9yIHNwZWNFeHBeMy80IGNvbWJpbmVkIHdpdGggc2NmTW9kICovCiAgICAgIHQgPSBGREthYWNFbmNfc3BlY0V4cE1hbnRUYWJsZUNvbWJFbGNbaXF1YW50aXplcm1vZF1bc3BlY0V4cF07CgogICAgICAvKiBtdWx0aXBseSAibWFudGlzc2EiIF40LzMgd2l0aCBleHBvbmVudCBtdWx0aXBsaWVyICovCiAgICAgIGFjY3UgPSBmTXVsdChzLHQpOwoKICAgICAgLyogZ2V0IGFwcHJvcGVyaWF0ZSBleHBvbmVudCBzaGlmdGVyICovCiAgICAgIHNwZWNFeHAgPSBGREthYWNFbmNfc3BlY0V4cFRhYmxlQ29tYltpcXVhbnRpemVybW9kXVtzcGVjRXhwXS0xOyAvKiAtMSB0byBhdm9pZCBvdmVyZmxvd3MgaW4gYWNjdSAqLwoKICAgICAgaWYgKCggLWlxdWFudGl6ZXJzaGlmdC1zcGVjRXhwKSA8IDApCiAgICAgICAgYWNjdSA8PD0gLSgtaXF1YW50aXplcnNoaWZ0LXNwZWNFeHApOwogICAgICBlbHNlCiAgICAgICAgYWNjdSA+Pj0gLWlxdWFudGl6ZXJzaGlmdC1zcGVjRXhwOwoKICAgICAgbWRjdFNwZWN0cnVtW2xpbmVdID0gYWNjdTsKICAgIH0KICAgIGVsc2UgewogICAgICBtZGN0U3BlY3RydW1bbGluZV0gPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKICAgIH0KICB9Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgoKICAgIGZ1bmN0aW9ubmFtZTogRkRLYWFjRW5jX1F1YW50aXplU3BlY3RydW0KICAgIGRlc2NyaXB0aW9uOiBxdWFudGl6ZXMgdGhlIGVudGlyZSBzcGVjdHJ1bQogICAgcmV0dXJuczoKICAgIGlucHV0OiBudW1iZXIgb2Ygc2NhbGVmYWN0b3IgYmFuZHMgdG8gYmUgcXVhbnRpemVkLCAuLi4KICAgIG91dHB1dDogcXVhbnRpemVkIHNwZWN0cnVtCgoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kdm9pZCBGREthYWNFbmNfUXVhbnRpemVTcGVjdHJ1bShJTlQgc2ZiQ250LAogICAgICAgICAgICAgICAgICAgICAgSU5UIG1heFNmYlBlckdyb3VwLAogICAgICAgICAgICAgICAgICAgICAgSU5UIHNmYlBlckdyb3VwLAogICAgICAgICAgICAgICAgICAgICAgSU5UICpzZmJPZmZzZXQsCiAgICAgICAgICAgICAgICAgICAgICBGSVhQX0RCTCAqbWRjdFNwZWN0cnVtLAogICAgICAgICAgICAgICAgICAgICAgSU5UIGdsb2JhbEdhaW4sCiAgICAgICAgICAgICAgICAgICAgICBJTlQgKnNjYWxlZmFjdG9ycywKICAgICAgICAgICAgICAgICAgICAgIFNIT1JUICpxdWFudGl6ZWRTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgIElOVCBkWm9uZVF1YW50RW5hYmxlKQp7CiAgSU5UIHNmYk9mZnMsc2ZiOwoKICAvKiBpbiBGREthYWNFbmNfcXVhbnRpemVMaW5lcyBxdWFTcGVjdHJ1bSBpcyBjYWxjdWxhdGVkIHdpdGg6CiAgICAgICAgc3BlY14oMy80KSAqIDJeKC0zLzE2KlFTUykgKiAyXigzLzQqc2NhbGUpICsgawogICAgIHNpbXBsaWZ5IHNjYWxpbmcgY2FsY3VsYXRpb24gYW5kIHJlZHVjZSBRU1MgYmVmb3JlOgogICAgICAgIHNwZWNeKDMvNCkgKiAyXigtMy8xNiooUVNTIC0gNCpzY2FsZSkpICovCgogIGZvcihzZmJPZmZzPTA7c2ZiT2ZmczxzZmJDbnQ7c2ZiT2Zmcys9c2ZiUGVyR3JvdXApCiAgZm9yIChzZmIgPSAwOyBzZmIgPCBtYXhTZmJQZXJHcm91cDsgc2ZiKyspCiAgewogICAgSU5UIHNjYWxlZmFjdG9yID0gc2NhbGVmYWN0b3JzW3NmYk9mZnMrc2ZiXSA7CgogICAgRkRLYWFjRW5jX3F1YW50aXplTGluZXMoZ2xvYmFsR2FpbiAtIHNjYWxlZmFjdG9yLCAvKiBRU1MgKi8KICAgICAgICAgICAgICAgICAgc2ZiT2Zmc2V0W3NmYk9mZnMrc2ZiKzFdIC0gc2ZiT2Zmc2V0W3NmYk9mZnMrc2ZiXSwKICAgICAgICAgICAgICAgICAgbWRjdFNwZWN0cnVtICsgc2ZiT2Zmc2V0W3NmYk9mZnMrc2ZiXSwKICAgICAgICAgICAgICAgICAgcXVhbnRpemVkU3BlY3RydW0gKyBzZmJPZmZzZXRbc2ZiT2ZmcytzZmJdLAogICAgICAgICAgICAgICAgICBkWm9uZVF1YW50RW5hYmxlKTsKICB9Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgoKICAgIGZ1bmN0aW9ubmFtZTogRkRLYWFjRW5jX2NhbGNTZmJEaXN0CiAgICBkZXNjcmlwdGlvbjogY2FsY3VsYXRlcyBkaXN0b3J0aW9uIG9mIHF1YW50aXplZCB2YWx1ZXMKICAgIHJldHVybnM6IGRpc3RvcnRpb24KICAgIGlucHV0OiBnYWluLCBudW1iZXIgb2YgbGluZXMgdG8gcHJvY2Vzcywgc3BlY3RyYWwgZGF0YQogICAgb3V0cHV0OgoKKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCkZJWFBfREJMIEZES2FhY0VuY19jYWxjU2ZiRGlzdChGSVhQX0RCTCAqbWRjdFNwZWN0cnVtLAogICAgICAgICAgICAgICAgICAgICBTSE9SVCAqcXVhbnRTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgSU5UIG5vT2ZMaW5lcywKICAgICAgICAgICAgICAgICAgICAgSU5UIGdhaW4sCiAgICAgICAgICAgICAgICAgICAgIElOVCBkWm9uZVF1YW50RW5hYmxlCiAgICAgICAgICAgICAgICAgICAgICkKewogIElOVCBpLHNjYWxlOwogIEZJWFBfREJMIHhmc2Y7CiAgRklYUF9EQkwgZGlmZjsKICBGSVhQX0RCTCBpbnZRdWFudFNwZWM7CgogIHhmc2YgPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKCiAgZm9yIChpPTA7IGk8bm9PZkxpbmVzOyBpKyspIHsKICAgIC8qIHF1YW50aXphdGlvbiAqLwogICAgRkRLYWFjRW5jX3F1YW50aXplTGluZXMoZ2FpbiwKICAgICAgICAgICAgICAgICAgMSwKICAgICAgICAgICAgICAgICAmbWRjdFNwZWN0cnVtW2ldLAogICAgICAgICAgICAgICAgICZxdWFudFNwZWN0cnVtW2ldLAogICAgICAgICAgICAgICAgICBkWm9uZVF1YW50RW5hYmxlKTsKCiAgICBpZiAoZkFicyhxdWFudFNwZWN0cnVtW2ldKT5NQVhfUVVBTlQpIHsKICAgICAgcmV0dXJuIEZMMkZYQ09OU1RfREJMKDAuMGYpOwogICAgfQogICAgLyogaW52ZXJzZSBxdWFudGl6YXRpb24gKi8KICAgIEZES2FhY0VuY19pbnZRdWFudGl6ZUxpbmVzKGdhaW4sMSwmcXVhbnRTcGVjdHJ1bVtpXSwmaW52UXVhbnRTcGVjKTsKCiAgICAvKiBkaXN0ICovCiAgICBkaWZmID0gZml4cF9hYnMoZml4cF9hYnMoaW52UXVhbnRTcGVjKSAtIGZpeHBfYWJzKG1kY3RTcGVjdHJ1bVtpXT4+MSkpOwoKICAgIHNjYWxlID0gQ291bnRMZWFkaW5nQml0cyhkaWZmKTsKICAgIGRpZmYgPSBzY2FsZVZhbHVlKGRpZmYsIHNjYWxlKTsKICAgIGRpZmYgPSBmUG93MihkaWZmKTsKICAgIHNjYWxlID0gZml4TWluKDIqKHNjYWxlLTEpLCBERlJBQ1RfQklUUy0xKTsKCiAgICBkaWZmID0gc2NhbGVWYWx1ZShkaWZmLCAtc2NhbGUpOwoKICAgIHhmc2YgPSB4ZnNmICsgZGlmZjsKICB9CgogIHhmc2YgPSBDYWxjTGREYXRhKHhmc2YpOwoKICByZXR1cm4geGZzZjsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgogICAgZnVuY3Rpb25uYW1lOiBGREthYWNFbmNfY2FsY1NmYlF1YW50RW5lcmd5QW5kRGlzdAogICAgZGVzY3JpcHRpb246IGNhbGN1bGF0ZXMgZW5lcmd5IGFuZCBkaXN0b3J0aW9uIG9mIHF1YW50aXplZCB2YWx1ZXMKICAgIHJldHVybnM6CiAgICBpbnB1dDogZ2FpbiwgbnVtYmVyIG9mIGxpbmVzIHRvIHByb2Nlc3MsIHF1YW50aXplZCBzcGVjdHJhbCBkYXRhLAogICAgICAgICAgIHNwZWN0cmFsIGRhdGEKICAgIG91dHB1dDogZW5lcmd5LCBkaXN0b3J0aW9uCgoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kdm9pZCBGREthYWNFbmNfY2FsY1NmYlF1YW50RW5lcmd5QW5kRGlzdChGSVhQX0RCTCAqbWRjdFNwZWN0cnVtLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgU0hPUlQgKnF1YW50U3BlY3RydW0sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBJTlQgbm9PZkxpbmVzLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSU5UIGdhaW4sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGSVhQX0RCTCAqZW4sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGSVhQX0RCTCAqZGlzdCkKewogIElOVCBpLHNjYWxlOwogIEZJWFBfREJMIGludlF1YW50U3BlYzsKICBGSVhQX0RCTCBkaWZmOwoKICBGSVhQX0RCTCBlbmVyZ3kgPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKICBGSVhQX0RCTCBkaXN0b3J0aW9uID0gRkwyRlhDT05TVF9EQkwoMC4wZik7CgogIGZvciAoaT0wOyBpPG5vT2ZMaW5lczsgaSsrKSB7CgogICAgaWYgKGZBYnMocXVhbnRTcGVjdHJ1bVtpXSk+TUFYX1FVQU5UKSB7CiAgICAgICplbiAgID0gRkwyRlhDT05TVF9EQkwoMC4wZik7CiAgICAgICpkaXN0ID0gRkwyRlhDT05TVF9EQkwoMC4wZik7CiAgICAgIHJldHVybjsKICAgIH0KCiAgICAvKiBpbnZlcnNlIHF1YW50aXphdGlvbiAqLwogICAgRkRLYWFjRW5jX2ludlF1YW50aXplTGluZXMoZ2FpbiwxLCZxdWFudFNwZWN0cnVtW2ldLCZpbnZRdWFudFNwZWMpOwoKICAgIC8qIGVuZXJneSAqLwogICAgZW5lcmd5ICs9IGZQb3cyKGludlF1YW50U3BlYyk7CgogICAgLyogZGlzdCAqLwogICAgZGlmZiA9IGZpeHBfYWJzKGZpeHBfYWJzKGludlF1YW50U3BlYykgLSBmaXhwX2FicyhtZGN0U3BlY3RydW1baV0+PjEpKTsKCiAgICBzY2FsZSA9IENvdW50TGVhZGluZ0JpdHMoZGlmZik7CiAgICBkaWZmID0gc2NhbGVWYWx1ZShkaWZmLCBzY2FsZSk7CiAgICBkaWZmID0gZlBvdzIoZGlmZik7CgogICAgc2NhbGUgPSBmaXhNaW4oMiooc2NhbGUtMSksIERGUkFDVF9CSVRTLTEpOwoKICAgIGRpZmYgPSBzY2FsZVZhbHVlKGRpZmYsIC1zY2FsZSk7CgogICAgZGlzdG9ydGlvbiArPSBkaWZmOwogIH0KCiAgKmVuICAgPSBDYWxjTGREYXRhKGVuZXJneSkrRkwyRlhDT05TVF9EQkwoMC4wMzEyNWYpOwogICpkaXN0ID0gQ2FsY0xkRGF0YShkaXN0b3J0aW9uKTsKfQoK