Ci8qIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tClNvZnR3YXJlIExpY2Vuc2UgZm9yIFRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZAoKqSBDb3B5cmlnaHQgIDE5OTUgLSAyMDEzIEZyYXVuaG9mZXItR2VzZWxsc2NoYWZ0IHp1ciBG9nJkZXJ1bmcgZGVyIGFuZ2V3YW5kdGVuIEZvcnNjaHVuZyBlLlYuCiAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAxLiAgICBJTlRST0RVQ1RJT04KVGhlIEZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkICgiRkRLIEFBQyBDb2RlYyIpIGlzIHNvZnR3YXJlIHRoYXQgaW1wbGVtZW50cwp0aGUgTVBFRyBBZHZhbmNlZCBBdWRpbyBDb2RpbmcgKCJBQUMiKSBlbmNvZGluZyBhbmQgZGVjb2Rpbmcgc2NoZW1lIGZvciBkaWdpdGFsIGF1ZGlvLgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgaW50ZW5kZWQgdG8gYmUgdXNlZCBvbiBhIHdpZGUgdmFyaWV0eSBvZiBBbmRyb2lkIGRldmljZXMuCgpBQUMncyBIRS1BQUMgYW5kIEhFLUFBQyB2MiB2ZXJzaW9ucyBhcmUgcmVnYXJkZWQgYXMgdG9kYXkncyBtb3N0IGVmZmljaWVudCBnZW5lcmFsIHBlcmNlcHR1YWwKYXVkaW8gY29kZWNzLiBBQUMtRUxEIGlzIGNvbnNpZGVyZWQgdGhlIGJlc3QtcGVyZm9ybWluZyBmdWxsLWJhbmR3aWR0aCBjb21tdW5pY2F0aW9ucyBjb2RlYyBieQppbmRlcGVuZGVudCBzdHVkaWVzIGFuZCBpcyB3aWRlbHkgZGVwbG95ZWQuIEFBQyBoYXMgYmVlbiBzdGFuZGFyZGl6ZWQgYnkgSVNPIGFuZCBJRUMgYXMgcGFydApvZiB0aGUgTVBFRyBzcGVjaWZpY2F0aW9ucy4KClBhdGVudCBsaWNlbnNlcyBmb3IgbmVjZXNzYXJ5IHBhdGVudCBjbGFpbXMgZm9yIHRoZSBGREsgQUFDIENvZGVjIChpbmNsdWRpbmcgdGhvc2Ugb2YgRnJhdW5ob2ZlcikKbWF5IGJlIG9idGFpbmVkIHRocm91Z2ggVmlhIExpY2Vuc2luZyAod3d3LnZpYWxpY2Vuc2luZy5jb20pIG9yIHRocm91Z2ggdGhlIHJlc3BlY3RpdmUgcGF0ZW50IG93bmVycwppbmRpdmlkdWFsbHkgZm9yIHRoZSBwdXJwb3NlIG9mIGVuY29kaW5nIG9yIGRlY29kaW5nIGJpdCBzdHJlYW1zIGluIHByb2R1Y3RzIHRoYXQgYXJlIGNvbXBsaWFudCB3aXRoCnRoZSBJU08vSUVDIE1QRUcgYXVkaW8gc3RhbmRhcmRzLiBQbGVhc2Ugbm90ZSB0aGF0IG1vc3QgbWFudWZhY3R1cmVycyBvZiBBbmRyb2lkIGRldmljZXMgYWxyZWFkeSBsaWNlbnNlCnRoZXNlIHBhdGVudCBjbGFpbXMgdGhyb3VnaCBWaWEgTGljZW5zaW5nIG9yIGRpcmVjdGx5IGZyb20gdGhlIHBhdGVudCBvd25lcnMsIGFuZCB0aGVyZWZvcmUgRkRLIEFBQyBDb2RlYwpzb2Z0d2FyZSBtYXkgYWxyZWFkeSBiZSBjb3ZlcmVkIHVuZGVyIHRob3NlIHBhdGVudCBsaWNlbnNlcyB3aGVuIGl0IGlzIHVzZWQgZm9yIHRob3NlIGxpY2Vuc2VkIHB1cnBvc2VzIG9ubHkuCgpDb21tZXJjaWFsbHktbGljZW5zZWQgQUFDIHNvZnR3YXJlIGxpYnJhcmllcywgaW5jbHVkaW5nIGZsb2F0aW5nLXBvaW50IHZlcnNpb25zIHdpdGggZW5oYW5jZWQgc291bmQgcXVhbGl0eSwKYXJlIGFsc28gYXZhaWxhYmxlIGZyb20gRnJhdW5ob2Zlci4gVXNlcnMgYXJlIGVuY291cmFnZWQgdG8gY2hlY2sgdGhlIEZyYXVuaG9mZXIgd2Vic2l0ZSBmb3IgYWRkaXRpb25hbAphcHBsaWNhdGlvbnMgaW5mb3JtYXRpb24gYW5kIGRvY3VtZW50YXRpb24uCgoyLiAgICBDT1BZUklHSFQgTElDRU5TRQoKUmVkaXN0cmlidXRpb24gYW5kIHVzZSBpbiBzb3VyY2UgYW5kIGJpbmFyeSBmb3Jtcywgd2l0aCBvciB3aXRob3V0IG1vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCB3aXRob3V0CnBheW1lbnQgb2YgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBwcm92aWRlZCB0aGF0IHlvdSBzYXRpc2Z5IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoKCllvdSBtdXN0IHJldGFpbiB0aGUgY29tcGxldGUgdGV4dCBvZiB0aGlzIHNvZnR3YXJlIGxpY2Vuc2UgaW4gcmVkaXN0cmlidXRpb25zIG9mIHRoZSBGREsgQUFDIENvZGVjIG9yCnlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvIGluIHNvdXJjZSBjb2RlIGZvcm0uCgpZb3UgbXVzdCByZXRhaW4gdGhlIGNvbXBsZXRlIHRleHQgb2YgdGhpcyBzb2Z0d2FyZSBsaWNlbnNlIGluIHRoZSBkb2N1bWVudGF0aW9uIGFuZC9vciBvdGhlciBtYXRlcmlhbHMKcHJvdmlkZWQgd2l0aCByZWRpc3RyaWJ1dGlvbnMgb2YgdGhlIEZESyBBQUMgQ29kZWMgb3IgeW91ciBtb2RpZmljYXRpb25zIHRoZXJldG8gaW4gYmluYXJ5IGZvcm0uCllvdSBtdXN0IG1ha2UgYXZhaWxhYmxlIGZyZWUgb2YgY2hhcmdlIGNvcGllcyBvZiB0aGUgY29tcGxldGUgc291cmNlIGNvZGUgb2YgdGhlIEZESyBBQUMgQ29kZWMgYW5kIHlvdXIKbW9kaWZpY2F0aW9ucyB0aGVyZXRvIHRvIHJlY2lwaWVudHMgb2YgY29waWVzIGluIGJpbmFyeSBmb3JtLgoKVGhlIG5hbWUgb2YgRnJhdW5ob2ZlciBtYXkgbm90IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIGxpYnJhcnkgd2l0aG91dApwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgpZb3UgbWF5IG5vdCBjaGFyZ2UgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBmb3IgYW55b25lIHRvIHVzZSwgY29weSBvciBkaXN0cmlidXRlIHRoZSBGREsgQUFDIENvZGVjCnNvZnR3YXJlIG9yIHlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvLgoKWW91ciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYyBtdXN0IGNhcnJ5IHByb21pbmVudCBub3RpY2VzIHN0YXRpbmcgdGhhdCB5b3UgY2hhbmdlZCB0aGUgc29mdHdhcmUKYW5kIHRoZSBkYXRlIG9mIGFueSBjaGFuZ2UuIEZvciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYywgdGhlIHRlcm0KIkZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkIiBtdXN0IGJlIHJlcGxhY2VkIGJ5IHRoZSB0ZXJtCiJUaGlyZC1QYXJ0eSBNb2RpZmllZCBWZXJzaW9uIG9mIHRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZC4iCgozLiAgICBOTyBQQVRFTlQgTElDRU5TRQoKTk8gRVhQUkVTUyBPUiBJTVBMSUVEIExJQ0VOU0VTIFRPIEFOWSBQQVRFTlQgQ0xBSU1TLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSBwYXRlbnRzIG9mIEZyYXVuaG9mZXIsCkFSRSBHUkFOVEVEIEJZIFRISVMgU09GVFdBUkUgTElDRU5TRS4gRnJhdW5ob2ZlciBwcm92aWRlcyBubyB3YXJyYW50eSBvZiBwYXRlbnQgbm9uLWluZnJpbmdlbWVudCB3aXRoCnJlc3BlY3QgdG8gdGhpcyBzb2Z0d2FyZS4KCllvdSBtYXkgdXNlIHRoaXMgRkRLIEFBQyBDb2RlYyBzb2Z0d2FyZSBvciBtb2RpZmljYXRpb25zIHRoZXJldG8gb25seSBmb3IgcHVycG9zZXMgdGhhdCBhcmUgYXV0aG9yaXplZApieSBhcHByb3ByaWF0ZSBwYXRlbnQgbGljZW5zZXMuCgo0LiAgICBESVNDTEFJTUVSCgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgcHJvdmlkZWQgYnkgRnJhdW5ob2ZlciBvbiBiZWhhbGYgb2YgdGhlIGNvcHlyaWdodCBob2xkZXJzIGFuZCBjb250cmlidXRvcnMKIkFTIElTIiBhbmQgV0lUSE9VVCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIGluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gdGhlIGltcGxpZWQgd2FycmFudGllcwpvZiBtZXJjaGFudGFiaWxpdHkgYW5kIGZpdG5lc3MgZm9yIGEgcGFydGljdWxhciBwdXJwb3NlLiBJTiBOTyBFVkVOVCBTSEFMTCBUSEUgQ09QWVJJR0hUIEhPTERFUiBPUgpDT05UUklCVVRPUlMgQkUgTElBQkxFIGZvciBhbnkgZGlyZWN0LCBpbmRpcmVjdCwgaW5jaWRlbnRhbCwgc3BlY2lhbCwgZXhlbXBsYXJ5LCBvciBjb25zZXF1ZW50aWFsIGRhbWFnZXMsCmluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gcHJvY3VyZW1lbnQgb2Ygc3Vic3RpdHV0ZSBnb29kcyBvciBzZXJ2aWNlczsgbG9zcyBvZiB1c2UsIGRhdGEsIG9yIHByb2ZpdHMsCm9yIGJ1c2luZXNzIGludGVycnVwdGlvbiwgaG93ZXZlciBjYXVzZWQgYW5kIG9uIGFueSB0aGVvcnkgb2YgbGlhYmlsaXR5LCB3aGV0aGVyIGluIGNvbnRyYWN0LCBzdHJpY3QKbGlhYmlsaXR5LCBvciB0b3J0IChpbmNsdWRpbmcgbmVnbGlnZW5jZSksIGFyaXNpbmcgaW4gYW55IHdheSBvdXQgb2YgdGhlIHVzZSBvZiB0aGlzIHNvZnR3YXJlLCBldmVuIGlmCmFkdmlzZWQgb2YgdGhlIHBvc3NpYmlsaXR5IG9mIHN1Y2ggZGFtYWdlLgoKNS4gICAgQ09OVEFDVCBJTkZPUk1BVElPTgoKRnJhdW5ob2ZlciBJbnN0aXR1dGUgZm9yIEludGVncmF0ZWQgQ2lyY3VpdHMgSUlTCkF0dGVudGlvbjogQXVkaW8gYW5kIE11bHRpbWVkaWEgRGVwYXJ0bWVudHMgLSBGREsgQUFDIExMCkFtIFdvbGZzbWFudGVsIDMzCjkxMDU4IEVybGFuZ2VuLCBHZXJtYW55Cgp3d3cuaWlzLmZyYXVuaG9mZXIuZGUvYW1tCmFtbS1pbmZvQGlpcy5mcmF1bmhvZmVyLmRlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqICBGcmF1bmhvZmVyIElJUyBGREsgVG9vbHMgICoqKioqKioqKioqKioqKioqKioqKioKCiAgIEF1dGhvcihzKTogICBIYXJpY2hhcmFuIExha3NobWFuLCBNYW51ZWwgSmFuZGVyCiAgIERlc2NyaXB0aW9uOiBUcmlnb25vbWV0cmljIGZ1bmN0aW9ucyBmaXhlZCBwb2ludCBmcmFjdGlvbmFsIGltcGxlbWVudGF0aW9uLgoKKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKI2luY2x1ZGUgIkZES190cmlnRmN0cy5oIgoKI2luY2x1ZGUgImZpeHBvaW50X21hdGguaCIKCgoKCiNkZWZpbmUgSU1QUk9WRV9BVEFOMl9BQ0NVUkFDWSAgMSAgLy8gMCAtLT4gNTkgZEIgU05SICAgICAxIC0tPiA2NSBkQiBTTlIKI2RlZmluZSBNSU5TRlRBQiAgNwojZGVmaW5lIE1BWFNGVEFCIDI1CgojaWYgSU1QUk9WRV9BVEFOMl9BQ0NVUkFDWQpzdGF0aWMgY29uc3QgRklYUF9EQkwgZl9hdGFuX2V4cGFuZF9yYW5nZVtNQVhTRlRBQi0oTUlOU0ZUQUItMSldICA9CnsKICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICAgKgogICAqICBUYWJsZSBob2xkcyBmaXhwX2F0YW4oKSBvdXRwdXQgdmFsdWVzIHdoaWNoIGFyZSBvdXRzaWRlIG9mIGlucHV0IHJhbmdlCiAgICogIG9mIGZpeHBfYXRhbigpIHRvIGltcHJvdmUgU05SIG9mIGZpeHBfYXRhbjIoKS4KICAgKgogICAqICBUaGlzIFRhYmxlIG1pZ2h0IGFsc28gYmUgdXNlZCBpbiBmaXhwX2F0YW4oKSBbdG9kb10gc28gdGhlcmUgYSB3aWRlciBpbnB1dAogICAqICByYW5nZSBjYW4gYmUgY292ZXJlZCwgdG9vLgogICAqCiAgICogIE1hdGxhYiAoZ2VuZXJhdGUgdGFibGUpOgogICAqICAgIGZvciBzY2wgPSA3OjI1ICAgICAgICAgICAgJSBNSU5TRlRBQiAuLiBNQVhTRlRBQgogICAqICAgICAgYXQ9YXRhbigwLjUgKigyXnNjbCkpOyAgJSAwLjUgYmVjYXVzZSBnZXQgaW4gJ21pZGRsZScgYXJlYSBvZiBjdXJyZW50IHNjYWxlIGxldmVsICdzY2wnCiAgICogICAgICBhdC8yICAgICAgICAgICAgICAgICAgICAlIGRpdiBhdCBieSBBVE9fU0NBTEUKICAgKiAgICBlbmQKICAgKgogICAqICBUYWJsZSBkaXZpZGVkIGJ5IDI9QVRPX1NDQUxFICA8LS0gIFNGPUFUT19TRgogICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KICAgRkwyRlhDT05TVF9EQkwoNy43NzU4NjI5OTA4NzIwOTllLTAwMSksIEZMMkZYQ09OU1RfREJMKDcuODE0OTE5OTI4NjczOTc4ZS0wMDEpLCBGTDJGWENPTlNUX0RCTCg3LjgzNDQ1MDQ4MzMxNDY0OGUtMDAxKSwKICAgRkwyRlhDT05TVF9EQkwoNy44NDQyMTYwMjEzOTIwODllLTAwMSksIEZMMkZYQ09OU1RfREJMKDcuODQ5MDk4ODIzMDI2Njg3ZS0wMDEpLCBGTDJGWENPTlNUX0RCTCg3Ljg1MTU0MDIyNzkxODUwOWUtMDAxKSwKICAgRkwyRlhDT05TVF9EQkwoNy44NTI3NjA5MzA4NzM3MzdlLTAwMSksIEZMMkZYQ09OU1RfREJMKDcuODUzMzcxMjgyNDE1MDE1ZS0wMDEpLCBGTDJGWENPTlNUX0RCTCg3Ljg1MzY3NjQ1ODE5MzYxMmUtMDAxKSwKICAgRkwyRlhDT05TVF9EQkwoNy44NTM4MjkwNDYwODM5MDZlLTAwMSksIEZMMkZYQ09OU1RfREJMKDcuODUzOTA1MzQwMDI5MTc3ZS0wMDEpLCBGTDJGWENPTlNUX0RCTCg3Ljg1Mzk0MzQ4NzAwMTgyOGUtMDAxKSwKICAgRkwyRlhDT05TVF9EQkwoNy44NTM5NjI1NjA0ODgxNTVlLTAwMSksIEZMMkZYQ09OU1RfREJMKDcuODUzOTcyMDk3MjMxMzE5ZS0wMDEpLCBGTDJGWENPTlNUX0RCTCg3Ljg1Mzk3Njg2NTYwMjkwMWUtMDAxKSwKICAgRkwyRlhDT05TVF9EQkwoNy44NTM5NzkyNDk3ODg2OTJlLTAwMSksIEZMMkZYQ09OU1RfREJMKDcuODUzOTgwNDQxODgxNTg3ZS0wMDEpLCBGTDJGWENPTlNUX0RCTCg3Ljg1Mzk4MTAzNzkyODAzNWUtMDAxKSwKICAgRkwyRlhDT05TVF9EQkwoNy44NTM5ODEzMzU5NTEyNTllLTAwMSkKICAgLy8gICAgIHBpLzQgPSAwLjc4NTM5ODE2MzM5NzQ0OCA9IHBpLzIvQVRPX1NDQUxFCn07CiNlbmRpZgoKRklYUF9EQkwgZml4cF9hdGFuMihGSVhQX0RCTCB5LCBGSVhQX0RCTCB4KQp7CiAgICBGSVhQX0RCTCBxOwogICAgRklYUF9EQkwgYXQ7ICAvLyBhdGFuICBvdXQKICAgIEZJWFBfREJMIGF0MjsgLy8gYXRhbjIgb3V0CiAgICBGSVhQX0RCTCByZXQgPSBGTDJGWENPTlNUX0RCTCgtMS4wZik7CiAgICBJTlQgc2Ysc2ZvLHN0ZjsKCiAgICAvLyAtLS0gZGl2aXNpb24KCiAgICBpZiAgICAgICh5ID4gRkwyRlhDT05TVF9EQkwoMC4wZikpCiAgICB7CiAgICAgICAgaWYgICAgICAoeCA+IEZMMkZYQ09OU1RfREJMKDAuMGYpKSB7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBxID0gIGZEaXZOb3JtSGlnaFByZWMoIHksIHgsICZzZik7IC8vIGJvdGggcG9zLgogICAgICAgIH0KICAgICAgICBlbHNlIGlmICh4IDwgRkwyRlhDT05TVF9EQkwoMC4wZikpIHsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHEgPSAtZkRpdk5vcm1IaWdoUHJlYyggeSwteCwgJnNmKTsgLy8geCBuZWcuCiAgICAgICAgfQogICAgICAgIGVsc2Ugey8vKHggPT1GTDJGWENPTlNUX0RCTCgwLjBmKSkKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHEgPSAgRkwyRlhDT05TVF9EQkwoKzEuMGYpOyAgLy8geS94ID0gcG9zL3plcm8gPSArSW5mCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZiA9IDA7CiAgICAgICAgfQogICAgfQogICAgZWxzZSBpZiAoeSA8IEZMMkZYQ09OU1RfREJMKDAuMGYpKQogICAgewogICAgICAgIGlmICAgICAgKHggPiBGTDJGWENPTlNUX0RCTCgwLjBmKSkgewogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgcSA9IC1mRGl2Tm9ybUhpZ2hQcmVjKC15LCB4LCAmc2YpOyAvLyB5IG5lZy4KICAgICAgICB9CiAgICAgICAgZWxzZSBpZiAoeCA8IEZMMkZYQ09OU1RfREJMKDAuMGYpKSB7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBxID0gIGZEaXZOb3JtSGlnaFByZWMoLXksLXgsICZzZik7IC8vIGJvdGggbmVnLgogICAgICAgIH0KICAgICAgICBlbHNlIHsvLyh4ID09RkwyRlhDT05TVF9EQkwoMC4wZikpCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBxID0gIEZMMkZYQ09OU1RfREJMKC0xLjBmKTsgIC8vIHkveCA9IG5lZy96ZXJvID0gLUluZgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgc2YgPSAwOwogICAgICAgIH0KICAgIH0KICAgIGVsc2UgeyAvLyAoeSA9PUZMMkZYQ09OU1RfREJMKDAuMGYpKQogICAgICAgIHEgPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKICAgICAgICBzZiA9IDA7CiAgICB9CiAgICBzZm8gPSBzZjsKCiAgICAvLyAtLS0gYXRhbigpCgogICAgaWYgICggc2ZvID4gQVRJX1NGICkgewogICAgICAgIC8vIC0tLSBjb3VsZCBub3QgY2FsYyBmaXhwX2F0YW4oKSBoZXJlIGJlYyBvZiBpbnB1dCBkYXRhIG91dCBvZiByYW5nZQogICAgICAgIC8vICAgICA9PT4gdGhlcmVmb3JlIGdpdmUgYmFjayBib3VuZGFyeSB2YWx1ZXMKCiAgICAgICAgI2lmIElNUFJPVkVfQVRBTjJfQUNDVVJBQ1kKICAgICAgICBpZiAoc2ZvID4gTUFYU0ZUQUIpIHNmbyA9IE1BWFNGVEFCOwogICAgICAgICNlbmRpZgoKICAgICAgICBpZiAgICAgICggIHEgPiBGTDJGWENPTlNUX0RCTCgwLjBmKSApIHsKICAgICAgICAgICAjaWYgSU1QUk9WRV9BVEFOMl9BQ0NVUkFDWQogICAgICAgICAgICBhdCA9ICtmX2F0YW5fZXhwYW5kX3JhbmdlW3Nmby1BVElfU0YtMV07CiAgICAgICAgICAgI2Vsc2UKICAgICAgICAgICAgYXQgPSBGTDJGWENPTlNUX0RCTCggK01fUEkvMiAvIEFUT19TQ0FMRSk7CiAgICAgICAgICAgI2VuZGlmCiAgICAgICAgfQogICAgICAgIGVsc2UgaWYgKCAgcSA8IEZMMkZYQ09OU1RfREJMKDAuMGYpICkgewogICAgICAgICAgICNpZiBJTVBST1ZFX0FUQU4yX0FDQ1VSQUNZCiAgICAgICAgICAgIGF0ID0gLWZfYXRhbl9leHBhbmRfcmFuZ2Vbc2ZvLUFUSV9TRi0xXTsKICAgICAgICAgICAjZWxzZQogICAgICAgICAgICBhdCA9IEZMMkZYQ09OU1RfREJMKCAtTV9QSS8yIC8gQVRPX1NDQUxFKTsKICAgICAgICAgICAjZW5kaWYKICAgICAgICB9CiAgICAgICAgZWxzZSB7ICAvLyBxPT0gRkwyRlhDT05TVF9EQkwoMC4wZikKICAgICAgICAgICAgYXQgPSBGTDJGWENPTlNUX0RCTCggMC4wZiApOwogICAgICAgIH0KICAgIH1lbHNlewogICAgICAgIC8vIC0tLSBjYWxjIG9mIGZpeHBfYXRhbigpIGlzIHBvc3NpYmxlOyBpbnB1dCBkYXRhIHdpdGhpbiByYW5nZQogICAgICAgIC8vICAgICA9PT4gc2V0IHEgb24gZml4ZWQgc2NhbGUgbGV2ZWwgYXMgZGVzaXJlZCBmcm9tIGZpeHBfYXRhbigpCiAgICAgICAgc3RmID0gc2ZvIC0gQVRJX1NGOwogICAgICAgIGlmIChzdGYgPiAwKSAgcSA9IHEgPDwgKElOVClmTWluKCBzdGYsREZSQUNUX0JJVFMtMSk7CiAgICAgICAgZWxzZSAgICAgICAgICBxID0gcSA+PiAoSU5UKWZNaW4oLXN0ZixERlJBQ1RfQklUUy0xKTsKICAgICAgICBhdCA9IGZpeHBfYXRhbihxKTsgIC8vIEFUT19TRgogICAgfQoKICAgIC8vIC0tLSBhdGFuMigpCgogICAgYXQyID0gYXQgPj4gKEFUMk9fU0YgLSBBVE9fU0YpOyAvLyBub3cgQVQyT19TRiBmb3IgYXRhbjIKICAgIGlmICAgICAgKCAgeCA+IEZMMkZYQ09OU1RfREJMKDAuMGYpICkgewogICAgICAgIHJldCA9IGF0MjsKICAgIH0KICAgIGVsc2UgaWYgKCAgeCA8IEZMMkZYQ09OU1RfREJMKDAuMGYpICkgewogICAgICAgIGlmICggIHkgPj0gRkwyRlhDT05TVF9EQkwoMC4wZikgKSB7CiAgICAgICAgICAgIHJldCA9IGF0MiArIEZMMkZYQ09OU1RfREJMKCBNX1BJIC8gQVQyT19TQ0FMRSk7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgcmV0ID0gYXQyIC0gRkwyRlhDT05TVF9EQkwoIE1fUEkgLyBBVDJPX1NDQUxFKTsKICAgICAgICB9CiAgICB9CiAgICBlbHNlIHsKICAgICAgICAvLyB4ID09IDAKICAgICAgICBpZiAgICAgICggeSA+ICBGTDJGWENPTlNUX0RCTCgwLjBmKSApIHsKICAgICAgICAgICAgcmV0ID0gRkwyRlhDT05TVF9EQkwoICtNX1BJLzIgLyBBVDJPX1NDQUxFKTsKICAgICAgICB9CiAgICAgICAgZWxzZSBpZiAoIHkgPCAgRkwyRlhDT05TVF9EQkwoMC4wZikgKSB7CiAgICAgICAgICAgIHJldCA9IEZMMkZYQ09OU1RfREJMKCAtTV9QSS8yIC8gQVQyT19TQ0FMRSk7CiAgICAgICAgfQogICAgICAgIGVsc2UgaWYgKCB5ID09IEZMMkZYQ09OU1RfREJMKDAuMGYpICkgewogICAgICAgICAgICByZXQgPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKICAgICAgICB9CiAgICB9CiAgICByZXR1cm4gcmV0Owp9CgoKRklYUF9EQkwgZml4cF9hdGFuKEZJWFBfREJMIHgpCnsKICAgIElOVCBzaWduOwogICAgRklYUF9EQkwgcmVzdWx0LCB0ZW1wOwoKICAgIC8vIFNOUiBvZiBmaXhwX2F0YW4oKSA9IDU2IGRCCiAgICBGSVhQX0RCTCBPTkVCWTNQNTYgID0gKEZJWFBfREJMKTB4MjY4MDAwMDA7IC8vIDEuMC8zLjU2IGluIHEzMQogICAgRklYUF9EQkwgUDI4MSAgICAgICA9IChGSVhQX0RCTCkweDAwMDEzMDAwOyAvLyAwLjI4MSBpbiBxMTgKICAgIEZJWFBfREJMIE9ORVA1NzEgICAgPSAoRklYUF9EQkwpMHg2NDg3ZWYwMDsgLy8gMS41NzEgaW4gcTMwCgogICAgaWYgKHggPCBGSVhQX0RCTCgwKSkgewogICAgICBzaWduID0gMTsKICAgICAgeCA9IC0geCA7CiAgICB9IGVsc2UgewogICAgICBzaWduID0gMDsKICAgIH0KCiAgICAvKiBjYWxjIG9mIGFyY3RhbiAqLwogICAgaWYoeCA8ICggUShRX0FUQU5JTlApLUZMMkZYQ09OU1RfREJMKDAuMDAzOTUpKSApCiAgICB7CiAgICAgICAgSU5UIHJlc19lOwoKICAgICAgICB0ZW1wID0gZlBvdzIoeCk7ICAgICAgICAgICAgLy8gcTI1ICogcTI1IC0gKERGUkFDVF9CSVRTLTEpID0gcTE5CiAgICAgICAgdGVtcCA9IGZNdWx0KHRlbXAsIE9ORUJZM1A1Nik7ICAgICAgLy8gcTE5ICogcTMxIC0gKERGUkFDVF9CSVRTLTEpID0gcTE5CiAgICAgICAgdGVtcCA9IHRlbXAgKyBRKDE5KTsgICAgICAgICAgICAgICAgLy8gcTE5ICsgcTE5ID0gcTE5CiAgICAgICAgcmVzdWx0ID0gZkRpdk5vcm0oeCwgdGVtcCwgJnJlc19lKTsKICAgICAgICByZXN1bHQgPSBzY2FsZVZhbHVlKHJlc3VsdCwgKFFfQVRBTk9VVC1RX0FUQU5JTlArMTktREZSQUNUX0JJVFMrMSkgKyByZXNfZSAgKTsKICAgIH0KICAgIGVsc2UgaWYoIHggPCBGTDJGWENPTlNUX0RCTCgxLjI4LzY0LjApICkKICAgIHsKICAgICAgICBGSVhQX0RCTCBkZWx0YV9maXg7CiAgICAgICAgRklYUF9EQkwgUElfQllfNCA9IEZMMkZYQ09OU1RfREJMKDMuMTQxNTkyNi80LjApID4+IDE7IC8qIHBpLzQgaW4gcTMwICovCgogICAgICAgIGRlbHRhX2ZpeCA9ICh4IC0gRkwyRlhDT05TVF9EQkwoMS4wLzY0LjApKSA8PCA1OyAvKiBxMzAgKi8KICAgICAgICByZXN1bHQgPSBQSV9CWV80ICsgKGRlbHRhX2ZpeCA+PiAxKSAtIChmUG93MkRpdjIoZGVsdGFfZml4KSk7CiAgICB9CiAgICBlbHNlCiAgICB7CiAgICAgICAgSU5UIHJlc19lOwoKICAgICAgICB0ZW1wID0gZlBvdzJEaXYyKHgpOyAgICAgICAgLy8gcTI1ICogcTI1IC0gKERGUkFDVF9CSVRTLTEpIC0gMSA9IHExOAogICAgICAgIHRlbXAgPSB0ZW1wICsgUDI4MTsgICAgICAgICAgICAgICAgIC8vIHExOCArIHExOCA9IHExOAogICAgICAgIHJlc3VsdCA9IGZEaXZOb3JtKHgsIHRlbXAsICZyZXNfZSk7CiAgICAgICAgcmVzdWx0ID0gc2NhbGVWYWx1ZShyZXN1bHQsIChRX0FUQU5PVVQtUV9BVEFOSU5QKzE4LURGUkFDVF9CSVRTKzEpICsgcmVzX2UgKTsKICAgICAgICByZXN1bHQgPSBPTkVQNTcxIC0gcmVzdWx0OyAgICAgICAgICAvLyBxMzAgKyBxMzAgPSBxMzAKICAgIH0KICAgIGlmIChzaWduKSB7CiAgICAgIHJlc3VsdCA9IC1yZXN1bHQ7CiAgICB9CgogICAgcmV0dXJuKHJlc3VsdCk7Cn0KCgoKI2luY2x1ZGUgIkZES190b29sc19yb20uaCIKCkZJWFBfREJMIGZpeHBfY29zKEZJWFBfREJMIHgsIGludCBzY2FsZSkKewogICAgRklYUF9EQkwgcmVzaWR1YWwsIGVycm9yLCBzaW5lLCBjb3NpbmU7CiAgICAKICAgIHJlc2lkdWFsID0gZml4cF9zaW5fY29zX3Jlc2lkdWFsX2lubGluZSh4LCBzY2FsZSwgJnNpbmUsICZjb3NpbmUpOwogICAgZXJyb3IgPSBmTXVsdChzaW5lLCByZXNpZHVhbCk7CgogICAgcmV0dXJuIGNvc2luZSAtIGVycm9yOwp9CgpGSVhQX0RCTCBmaXhwX3NpbihGSVhQX0RCTCB4LCBpbnQgc2NhbGUpCnsKICAgIEZJWFBfREJMIHJlc2lkdWFsLCBlcnJvciwgc2luZSwgY29zaW5lOwogICAgCiAgICByZXNpZHVhbCA9IGZpeHBfc2luX2Nvc19yZXNpZHVhbF9pbmxpbmUoeCwgc2NhbGUsICZzaW5lLCAmY29zaW5lKTsKICAgIGVycm9yID0gZk11bHQoY29zaW5lLCByZXNpZHVhbCk7CgogICAgcmV0dXJuIHNpbmUgKyBlcnJvcjsKfQoKdm9pZCBmaXhwX2Nvc19zaW4gKEZJWFBfREJMIHgsIGludCBzY2FsZSwgRklYUF9EQkwgKmNvcywgRklYUF9EQkwgKnNpbikKewogICAgRklYUF9EQkwgcmVzaWR1YWwsIGVycm9yMCwgZXJyb3IxLCBzaW5lLCBjb3NpbmU7CiAgICAKICAgIHJlc2lkdWFsID0gZml4cF9zaW5fY29zX3Jlc2lkdWFsX2lubGluZSh4LCBzY2FsZSwgJnNpbmUsICZjb3NpbmUpOwogICAgZXJyb3IwID0gZk11bHQoc2luZSwgcmVzaWR1YWwpOwogICAgZXJyb3IxID0gZk11bHQoY29zaW5lLCByZXNpZHVhbCk7CiAgICAqY29zICA9IGNvc2luZSAtIGVycm9yMDsKICAgICpzaW4gID0gc2luZSArIGVycm9yMTsKfQoKCgoKCg==