Ci8qIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tClNvZnR3YXJlIExpY2Vuc2UgZm9yIFRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZAoKqSBDb3B5cmlnaHQgIDE5OTUgLSAyMDEzIEZyYXVuaG9mZXItR2VzZWxsc2NoYWZ0IHp1ciBG9nJkZXJ1bmcgZGVyIGFuZ2V3YW5kdGVuIEZvcnNjaHVuZyBlLlYuCiAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAxLiAgICBJTlRST0RVQ1RJT04KVGhlIEZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkICgiRkRLIEFBQyBDb2RlYyIpIGlzIHNvZnR3YXJlIHRoYXQgaW1wbGVtZW50cwp0aGUgTVBFRyBBZHZhbmNlZCBBdWRpbyBDb2RpbmcgKCJBQUMiKSBlbmNvZGluZyBhbmQgZGVjb2Rpbmcgc2NoZW1lIGZvciBkaWdpdGFsIGF1ZGlvLgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgaW50ZW5kZWQgdG8gYmUgdXNlZCBvbiBhIHdpZGUgdmFyaWV0eSBvZiBBbmRyb2lkIGRldmljZXMuCgpBQUMncyBIRS1BQUMgYW5kIEhFLUFBQyB2MiB2ZXJzaW9ucyBhcmUgcmVnYXJkZWQgYXMgdG9kYXkncyBtb3N0IGVmZmljaWVudCBnZW5lcmFsIHBlcmNlcHR1YWwKYXVkaW8gY29kZWNzLiBBQUMtRUxEIGlzIGNvbnNpZGVyZWQgdGhlIGJlc3QtcGVyZm9ybWluZyBmdWxsLWJhbmR3aWR0aCBjb21tdW5pY2F0aW9ucyBjb2RlYyBieQppbmRlcGVuZGVudCBzdHVkaWVzIGFuZCBpcyB3aWRlbHkgZGVwbG95ZWQuIEFBQyBoYXMgYmVlbiBzdGFuZGFyZGl6ZWQgYnkgSVNPIGFuZCBJRUMgYXMgcGFydApvZiB0aGUgTVBFRyBzcGVjaWZpY2F0aW9ucy4KClBhdGVudCBsaWNlbnNlcyBmb3IgbmVjZXNzYXJ5IHBhdGVudCBjbGFpbXMgZm9yIHRoZSBGREsgQUFDIENvZGVjIChpbmNsdWRpbmcgdGhvc2Ugb2YgRnJhdW5ob2ZlcikKbWF5IGJlIG9idGFpbmVkIHRocm91Z2ggVmlhIExpY2Vuc2luZyAod3d3LnZpYWxpY2Vuc2luZy5jb20pIG9yIHRocm91Z2ggdGhlIHJlc3BlY3RpdmUgcGF0ZW50IG93bmVycwppbmRpdmlkdWFsbHkgZm9yIHRoZSBwdXJwb3NlIG9mIGVuY29kaW5nIG9yIGRlY29kaW5nIGJpdCBzdHJlYW1zIGluIHByb2R1Y3RzIHRoYXQgYXJlIGNvbXBsaWFudCB3aXRoCnRoZSBJU08vSUVDIE1QRUcgYXVkaW8gc3RhbmRhcmRzLiBQbGVhc2Ugbm90ZSB0aGF0IG1vc3QgbWFudWZhY3R1cmVycyBvZiBBbmRyb2lkIGRldmljZXMgYWxyZWFkeSBsaWNlbnNlCnRoZXNlIHBhdGVudCBjbGFpbXMgdGhyb3VnaCBWaWEgTGljZW5zaW5nIG9yIGRpcmVjdGx5IGZyb20gdGhlIHBhdGVudCBvd25lcnMsIGFuZCB0aGVyZWZvcmUgRkRLIEFBQyBDb2RlYwpzb2Z0d2FyZSBtYXkgYWxyZWFkeSBiZSBjb3ZlcmVkIHVuZGVyIHRob3NlIHBhdGVudCBsaWNlbnNlcyB3aGVuIGl0IGlzIHVzZWQgZm9yIHRob3NlIGxpY2Vuc2VkIHB1cnBvc2VzIG9ubHkuCgpDb21tZXJjaWFsbHktbGljZW5zZWQgQUFDIHNvZnR3YXJlIGxpYnJhcmllcywgaW5jbHVkaW5nIGZsb2F0aW5nLXBvaW50IHZlcnNpb25zIHdpdGggZW5oYW5jZWQgc291bmQgcXVhbGl0eSwKYXJlIGFsc28gYXZhaWxhYmxlIGZyb20gRnJhdW5ob2Zlci4gVXNlcnMgYXJlIGVuY291cmFnZWQgdG8gY2hlY2sgdGhlIEZyYXVuaG9mZXIgd2Vic2l0ZSBmb3IgYWRkaXRpb25hbAphcHBsaWNhdGlvbnMgaW5mb3JtYXRpb24gYW5kIGRvY3VtZW50YXRpb24uCgoyLiAgICBDT1BZUklHSFQgTElDRU5TRQoKUmVkaXN0cmlidXRpb24gYW5kIHVzZSBpbiBzb3VyY2UgYW5kIGJpbmFyeSBmb3Jtcywgd2l0aCBvciB3aXRob3V0IG1vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCB3aXRob3V0CnBheW1lbnQgb2YgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBwcm92aWRlZCB0aGF0IHlvdSBzYXRpc2Z5IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoKCllvdSBtdXN0IHJldGFpbiB0aGUgY29tcGxldGUgdGV4dCBvZiB0aGlzIHNvZnR3YXJlIGxpY2Vuc2UgaW4gcmVkaXN0cmlidXRpb25zIG9mIHRoZSBGREsgQUFDIENvZGVjIG9yCnlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvIGluIHNvdXJjZSBjb2RlIGZvcm0uCgpZb3UgbXVzdCByZXRhaW4gdGhlIGNvbXBsZXRlIHRleHQgb2YgdGhpcyBzb2Z0d2FyZSBsaWNlbnNlIGluIHRoZSBkb2N1bWVudGF0aW9uIGFuZC9vciBvdGhlciBtYXRlcmlhbHMKcHJvdmlkZWQgd2l0aCByZWRpc3RyaWJ1dGlvbnMgb2YgdGhlIEZESyBBQUMgQ29kZWMgb3IgeW91ciBtb2RpZmljYXRpb25zIHRoZXJldG8gaW4gYmluYXJ5IGZvcm0uCllvdSBtdXN0IG1ha2UgYXZhaWxhYmxlIGZyZWUgb2YgY2hhcmdlIGNvcGllcyBvZiB0aGUgY29tcGxldGUgc291cmNlIGNvZGUgb2YgdGhlIEZESyBBQUMgQ29kZWMgYW5kIHlvdXIKbW9kaWZpY2F0aW9ucyB0aGVyZXRvIHRvIHJlY2lwaWVudHMgb2YgY29waWVzIGluIGJpbmFyeSBmb3JtLgoKVGhlIG5hbWUgb2YgRnJhdW5ob2ZlciBtYXkgbm90IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIGxpYnJhcnkgd2l0aG91dApwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgpZb3UgbWF5IG5vdCBjaGFyZ2UgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBmb3IgYW55b25lIHRvIHVzZSwgY29weSBvciBkaXN0cmlidXRlIHRoZSBGREsgQUFDIENvZGVjCnNvZnR3YXJlIG9yIHlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvLgoKWW91ciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYyBtdXN0IGNhcnJ5IHByb21pbmVudCBub3RpY2VzIHN0YXRpbmcgdGhhdCB5b3UgY2hhbmdlZCB0aGUgc29mdHdhcmUKYW5kIHRoZSBkYXRlIG9mIGFueSBjaGFuZ2UuIEZvciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYywgdGhlIHRlcm0KIkZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkIiBtdXN0IGJlIHJlcGxhY2VkIGJ5IHRoZSB0ZXJtCiJUaGlyZC1QYXJ0eSBNb2RpZmllZCBWZXJzaW9uIG9mIHRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZC4iCgozLiAgICBOTyBQQVRFTlQgTElDRU5TRQoKTk8gRVhQUkVTUyBPUiBJTVBMSUVEIExJQ0VOU0VTIFRPIEFOWSBQQVRFTlQgQ0xBSU1TLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSBwYXRlbnRzIG9mIEZyYXVuaG9mZXIsCkFSRSBHUkFOVEVEIEJZIFRISVMgU09GVFdBUkUgTElDRU5TRS4gRnJhdW5ob2ZlciBwcm92aWRlcyBubyB3YXJyYW50eSBvZiBwYXRlbnQgbm9uLWluZnJpbmdlbWVudCB3aXRoCnJlc3BlY3QgdG8gdGhpcyBzb2Z0d2FyZS4KCllvdSBtYXkgdXNlIHRoaXMgRkRLIEFBQyBDb2RlYyBzb2Z0d2FyZSBvciBtb2RpZmljYXRpb25zIHRoZXJldG8gb25seSBmb3IgcHVycG9zZXMgdGhhdCBhcmUgYXV0aG9yaXplZApieSBhcHByb3ByaWF0ZSBwYXRlbnQgbGljZW5zZXMuCgo0LiAgICBESVNDTEFJTUVSCgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgcHJvdmlkZWQgYnkgRnJhdW5ob2ZlciBvbiBiZWhhbGYgb2YgdGhlIGNvcHlyaWdodCBob2xkZXJzIGFuZCBjb250cmlidXRvcnMKIkFTIElTIiBhbmQgV0lUSE9VVCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIGluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gdGhlIGltcGxpZWQgd2FycmFudGllcwpvZiBtZXJjaGFudGFiaWxpdHkgYW5kIGZpdG5lc3MgZm9yIGEgcGFydGljdWxhciBwdXJwb3NlLiBJTiBOTyBFVkVOVCBTSEFMTCBUSEUgQ09QWVJJR0hUIEhPTERFUiBPUgpDT05UUklCVVRPUlMgQkUgTElBQkxFIGZvciBhbnkgZGlyZWN0LCBpbmRpcmVjdCwgaW5jaWRlbnRhbCwgc3BlY2lhbCwgZXhlbXBsYXJ5LCBvciBjb25zZXF1ZW50aWFsIGRhbWFnZXMsCmluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gcHJvY3VyZW1lbnQgb2Ygc3Vic3RpdHV0ZSBnb29kcyBvciBzZXJ2aWNlczsgbG9zcyBvZiB1c2UsIGRhdGEsIG9yIHByb2ZpdHMsCm9yIGJ1c2luZXNzIGludGVycnVwdGlvbiwgaG93ZXZlciBjYXVzZWQgYW5kIG9uIGFueSB0aGVvcnkgb2YgbGlhYmlsaXR5LCB3aGV0aGVyIGluIGNvbnRyYWN0LCBzdHJpY3QKbGlhYmlsaXR5LCBvciB0b3J0IChpbmNsdWRpbmcgbmVnbGlnZW5jZSksIGFyaXNpbmcgaW4gYW55IHdheSBvdXQgb2YgdGhlIHVzZSBvZiB0aGlzIHNvZnR3YXJlLCBldmVuIGlmCmFkdmlzZWQgb2YgdGhlIHBvc3NpYmlsaXR5IG9mIHN1Y2ggZGFtYWdlLgoKNS4gICAgQ09OVEFDVCBJTkZPUk1BVElPTgoKRnJhdW5ob2ZlciBJbnN0aXR1dGUgZm9yIEludGVncmF0ZWQgQ2lyY3VpdHMgSUlTCkF0dGVudGlvbjogQXVkaW8gYW5kIE11bHRpbWVkaWEgRGVwYXJ0bWVudHMgLSBGREsgQUFDIExMCkFtIFdvbGZzbWFudGVsIDMzCjkxMDU4IEVybGFuZ2VuLCBHZXJtYW55Cgp3d3cuaWlzLmZyYXVuaG9mZXIuZGUvYW1tCmFtbS1pbmZvQGlpcy5mcmF1bmhvZmVyLmRlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqICBGcmF1bmhvZmVyIElJUyBGREsgVG9vbHMgICoqKioqKioqKioqKioqKioqKioqKioKCiAgIEF1dGhvcihzKTogICBKb3NlZiBIb2VwZmwsIE1hbnVlbCBKYW5kZXIKICAgRGVzY3JpcHRpb246IE1EQ1Qgcm91dGluZXMKCioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCiNpbmNsdWRlICJtZGN0LmgiCgoKI2luY2x1ZGUgIkZES190b29sc19yb20uaCIKI2luY2x1ZGUgImRjdC5oIgojaW5jbHVkZSAiZml4cG9pbnRfbWF0aC5oIgoKCnZvaWQgbWRjdF9pbml0KCBIX01EQ1QgaE1kY3QsCiAgICAgICAgICAgICAgICBGSVhQX0RCTCAqb3ZlcmxhcCwKICAgICAgICAgICAgICAgIElOVCBvdmVybGFwQnVmZmVyU2l6ZSApCnsKICBoTWRjdC0+b3ZlcmxhcC5mcmVxID0gb3ZlcmxhcDsKICAvL0ZES21lbWNsZWFyKG92ZXJsYXAsIG92ZXJsYXBCdWZmZXJTaXplKnNpemVvZihGSVhQX0RCTCkpOwogIGhNZGN0LT5wcmV2X2ZyID0gMDsKICBoTWRjdC0+cHJldl9uciA9IDA7CiAgaE1kY3QtPnByZXZfdGwgPSAwOwogIGhNZGN0LT5vdl9zaXplID0gb3ZlcmxhcEJ1ZmZlclNpemU7Cn0KCgp2b2lkIGltZGN0X2dhaW4oRklYUF9EQkwgKnBHYWluX20sIGludCAqcEdhaW5fZSwgaW50IHRsKQp7CiAgRklYUF9EQkwgZ2Fpbl9tID0gKnBHYWluX207CiAgaW50IGdhaW5fZSA9ICpwR2Fpbl9lOwogIGludCBsb2cyX3RsOwoKICBsb2cyX3RsID0gREZSQUNUX0JJVFMtMS1mTm9ybXooKEZJWFBfREJMKXRsKTsKCiAgZ2Fpbl9lICs9IC1NRENUX09VVFBVVF9HQUlOIC0gbG9nMl90bCAtIE1EQ1RfT1VUX0hFQURST09NICsgMTsKCiAgLyogRGV0ZWN0IG5vbi1yYWRpeCAyIHRyYW5zZm9ybSBsZW5ndGggYW5kIGFkZCBhbXBsaXR1ZGUgY29tcGVuc2F0aW9uIGZhY3RvcgogICAgIHdoaWNoIGNhbm5vdCBiZSBpbmNsdWRlZCBpbnRvIHRoZSBleHBvbmVudCBhYm92ZSAqLwogIHN3aXRjaCAoICh0bCkgPj4gKGxvZzJfdGwgLSAyKSApIHsKICAgIGNhc2UgMHg3OiAvKiAxMCBtcywgMS90bCA9IDEuMC8oRkRLcG93KDIuMCwgLWxvZzJfdGwpICogMC41MzMzMzMzMzMzMzMzMzMzMzMzMykgKi8KICAgICAgaWYgKGdhaW5fbSA9PSAoRklYUF9EQkwpMCkgewogICAgICAgIGdhaW5fbSA9IEZMMkZYQ09OU1RfREJMKDAuNTMzMzMzMzMzMzMzMzMzMzMzMzNmKTsKICAgICAgfSBlbHNlIHsKICAgICAgICBnYWluX20gPSBmTXVsdChnYWluX20sIEZMMkZYQ09OU1RfREJMKDAuNTMzMzMzMzMzMzMzMzMzMzMzMzNmKSk7CiAgICAgIH0KICAgICAgYnJlYWs7CiAgICBjYXNlIDB4NjogLyogMy80IG9mIHJhZGl4IDIsIDEvdGwgPSAxLjAvKEZES3BvdygyLjAsIC1sb2cyX3RsKSAqIDIuMC8zLjApICovCiAgICAgIGlmIChnYWluX20gPT0gKEZJWFBfREJMKTApIHsKICAgICAgICBnYWluX20gPSBGTDJGWENPTlNUX0RCTCgyLjAvMy4wZik7CiAgICAgIH0gZWxzZSB7CiAgICAgICAgZ2Fpbl9tID0gZk11bHQoZ2Fpbl9tLCBGTDJGWENPTlNUX0RCTCgyLjAvMy4wZikpOwogICAgICB9CiAgICAgIGJyZWFrOwogICAgY2FzZSAweDQ6CiAgICAgIC8qIHJhZGl4IDIsIG5vdGhpbmcgdG8gZG8uICovCiAgICAgIGJyZWFrOwogICAgZGVmYXVsdDoKICAgICAgLyogdW5zdXBwb3J0ZWQgKi8KICAgICAgRkRLX0FTU0VSVCgwKTsKICAgICAgYnJlYWs7CiAgfQoKICAqcEdhaW5fbSA9IGdhaW5fbTsKICAqcEdhaW5fZSA9IGdhaW5fZTsKfQoKSU5UIGltZGN0X2RyYWluKAogICAgICAgIEhfTURDVCBoTWRjdCwKICAgICAgICBGSVhQX0RCTCAqb3V0cHV0LAogICAgICAgIElOVCBuclNhbXBsZXNSb29tCiAgICAgICAgKQp7CiAgaW50IGJ1ZmZlcmVkX3NhbXBsZXMgPSAwOwoKICBpZiAobnJTYW1wbGVzUm9vbSA+IDApIHsKICAgIGJ1ZmZlcmVkX3NhbXBsZXMgPSBoTWRjdC0+b3Zfb2Zmc2V0OwoKICAgIEZES19BU1NFUlQoYnVmZmVyZWRfc2FtcGxlcyA8PSBuclNhbXBsZXNSb29tKTsKCiAgICBpZiAoYnVmZmVyZWRfc2FtcGxlcyA+IDApICB7CiAgICAgIEZES21lbWNweShvdXRwdXQsIGhNZGN0LT5vdmVybGFwLnRpbWUsIGJ1ZmZlcmVkX3NhbXBsZXMqc2l6ZW9mKEZJWFBfREJMKSk7CiAgICAgIGhNZGN0LT5vdl9vZmZzZXQgPSAwOwogICAgfQogIH0KICByZXR1cm4gYnVmZmVyZWRfc2FtcGxlczsKfQoKSU5UIGltZGN0X2NvcHlfb3ZfYW5kX25yKAogICAgICAgIEhfTURDVCBoTWRjdCwKICAgICAgICBGSVhQX0RCTCAqIHBUaW1lRGF0YSwKICAgICAgICBJTlQgbnJTYW1wbGVzCiAgICAgICAgKQp7CiAgRklYUF9EQkwgKnBPdmw7CiAgaW50IG50LCBuZiwgaTsKCiAgbnQgPSBmTWluKGhNZGN0LT5vdl9vZmZzZXQsIG5yU2FtcGxlcyk7CiAgbnJTYW1wbGVzIC09IG50OwogIG5mID0gZk1pbihoTWRjdC0+cHJldl9uciwgbnJTYW1wbGVzKTsKICBuclNhbXBsZXMgLT0gbmY7CiAgRkRLbWVtY3B5KHBUaW1lRGF0YSwgaE1kY3QtPm92ZXJsYXAudGltZSwgbnQqc2l6ZW9mKEZJWFBfREJMKSk7CiAgcFRpbWVEYXRhICs9IG50OwoKICBwT3ZsID0gaE1kY3QtPm92ZXJsYXAuZnJlcSArIGhNZGN0LT5vdl9zaXplIC0gMTsKICBmb3IgKGk9MDsgaTxuZjsgaSsrKSB7CiAgICBGSVhQX0RCTCB4ID0gLSAoKnBPdmwtLSk7CiAgICAqcFRpbWVEYXRhID0gSU1EQ1RfU0NBTEVfREJMKHgpOwogICAgcFRpbWVEYXRhICsrOwogIH0KCiAgcmV0dXJuIChudCtuZik7Cn0KCnZvaWQgaW1kY3RfYWRhcHRfcGFyYW1ldGVycyhIX01EQ1QgaE1kY3QsIGludCAqcGZsLCBpbnQgKnBubCwgaW50IHRsLCBjb25zdCBGSVhQX1dUUCAqd2xzLCBpbnQgbm9PdXRTYW1wbGVzKQp7CiAgaW50IGZsID0gKnBmbCwgbmwgPSAqcG5sOwogIGludCB3aW5kb3dfZGlmZiwgdXNlX2N1cnJlbnQgPSAwLCB1c2VfcHJldmlvdXMgPSAwOwogIGlmIChoTWRjdC0+cHJldl90bCA9PSAwKSB7CiAgICBoTWRjdC0+cHJldl93cnMgICAgPSB3bHM7CiAgICBoTWRjdC0+cHJldl9mciAgICAgPSBmbDsKICAgIGhNZGN0LT5wcmV2X25yICAgICA9IChub091dFNhbXBsZXMtZmwpPj4xOwogICAgaE1kY3QtPnByZXZfdGwgICAgID0gbm9PdXRTYW1wbGVzOwogICAgaE1kY3QtPm92X29mZnNldCAgID0gMDsKICAgIHVzZV9jdXJyZW50ID0gMTsKICB9CgogIHdpbmRvd19kaWZmID0gKGhNZGN0LT5wcmV2X2ZyIC0gZmwpPj4xOwoKICAvKiBjaGVjayBpZiB0aGUgcHJldmlvdXMgd2luZG93IHNsb3BlIGNhbiBiZSBhZGp1c3RlZCB0byBtYXRjaCB0aGUgY3VycmVudCB3aW5kb3cgc2xvcGUgKi8KICBpZiAoaE1kY3QtPnByZXZfbnIgKyB3aW5kb3dfZGlmZiA+IDApIHsKICAgIHVzZV9jdXJyZW50ID0gMTsKICB9CiAgLyogY2hlY2sgaWYgdGhlIGN1cnJlbnQgd2luZG93IHNsb3BlIGNhbiBiZSBhZGp1c3RlZCB0byBtYXRjaCB0aGUgcHJldmlvdXMgd2luZG93IHNsb3BlICovCiAgaWYgKG5sIC0gd2luZG93X2RpZmYgPiAwICkgewogICAgdXNlX3ByZXZpb3VzID0gMTsKICB9CgogIC8qIGlmIGJvdGggaXMgcG9zc2libGUgY2hvb3NlIHRoZSBsYXJnZXIgb2YgYm90aCB3aW5kb3cgc2xvcGUgbGVuZ3RocyAqLwogIGlmICh1c2VfY3VycmVudCAmJiB1c2VfcHJldmlvdXMpIHsKICAgIGlmIChmbCA8IGhNZGN0LT5wcmV2X2ZyKSB7CiAgICAgIHVzZV9jdXJyZW50ID0gMDsKICAgIH0gZWxzZSB7CiAgICAgIHVzZV9wcmV2aW91cyA9IDA7CiAgICB9CiAgfQogIC8qCiAgICogSWYgdGhlIHByZXZpb3VzIHRyYW5zZm9ybSBibG9jayBpcyBiaWcgZW5vdWdoLCBlbmxhcmdlIHByZXZpb3VzIHdpbmRvdyBvdmVybGFwLAogICAqIGlmIG5vdCwgdGhlbiBzaHJpbmsgY3VycmVudCB3aW5kb3cgb3ZlcmxhcC4KICAgKi8KICBpZiAodXNlX2N1cnJlbnQpIHsKICAgIGhNZGN0LT5wcmV2X25yICs9IHdpbmRvd19kaWZmOwogICAgaE1kY3QtPnByZXZfZnIgPSBmbDsKICAgIGhNZGN0LT5wcmV2X3dycyA9IHdsczsKICB9IGVsc2UgewogICAgbmwgLT0gd2luZG93X2RpZmY7CiAgICBmbCA9IGhNZGN0LT5wcmV2X2ZyOwogIH0KCiAgKnBmbCA9IGZsOwogICpwbmwgPSBubDsKfQoKSU5UICBpbWRjdF9ibG9jaygKICAgICAgICBIX01EQ1QgaE1kY3QsCiAgICAgICAgRklYUF9EQkwgKm91dHB1dCwKICAgICAgICBGSVhQX0RCTCAqc3BlY3RydW0sCiAgICAgICAgY29uc3QgU0hPUlQgc2NhbGVmYWN0b3JbXSwKICAgICAgICBjb25zdCBJTlQgblNwZWMsCiAgICAgICAgY29uc3QgSU5UIG5vT3V0U2FtcGxlcywKICAgICAgICBjb25zdCBJTlQgdGwsCiAgICAgICAgY29uc3QgRklYUF9XVFAgKndscywKICAgICAgICBJTlQgZmwsCiAgICAgICAgY29uc3QgRklYUF9XVFAgKndycywKICAgICAgICBjb25zdCBJTlQgZnIsCiAgICAgICAgRklYUF9EQkwgZ2FpbgogICAgICAgICkKewogIEZJWFBfREJMICpwT3ZsOwogIEZJWFBfREJMICpwT3V0MCA9IG91dHB1dCwgKnBPdXQxOwogIElOVCBubCwgbnI7CiAgaW50IHcsIGksIG5yU2FtcGxlcyA9IDAsIHNwZWNTaGlmdFNjYWxlLCB0cmFuc2Zvcm1fZ2Fpbl9lID0gMDsKCiAgLyogRGVyaXZlIE5SIGFuZCBOTCAqLwogIG5yID0gKHRsIC0gZnIpPj4xOwogIG5sID0gKHRsIC0gZmwpPj4xOwoKICAvKiBJbmNsdWRlIDIvTiBJTURDVCBnYWluIGludG8gZ2FpbiBmYWN0b3IgYW5kIGV4cG9uZW50LiAqLwogIGltZGN0X2dhaW4oJmdhaW4sICZ0cmFuc2Zvcm1fZ2Fpbl9lLCB0bCk7CgogIC8qIERldGVjdCBGUnByZXZpb3VzIC8gRkwgbWlzbWF0Y2hlcyBhbmQgb3ZlcnJpZGUgcGFyYW1ldGVycyBhY2NvcmRpbmdseSAqLwogIGlmIChoTWRjdC0+cHJldl9mciAhPSBmbCkgewogICAgaW1kY3RfYWRhcHRfcGFyYW1ldGVycyhoTWRjdCwgJmZsLCAmbmwsIHRsLCB3bHMsIG5vT3V0U2FtcGxlcyk7CiAgfQoKICBwT3ZsID0gaE1kY3QtPm92ZXJsYXAuZnJlcSArIGhNZGN0LT5vdl9zaXplIC0gMTsKCiAgaWYgKCBub091dFNhbXBsZXMgPiBuclNhbXBsZXMgKSB7CiAgICAvKiBQdXJnZSBidWZmZXJlZCBvdXRwdXQuICovCiAgICBmb3IgKGk9MDsgaTxoTWRjdC0+b3Zfb2Zmc2V0OyBpKyspIHsKICAgICAgKnBPdXQwID0gaE1kY3QtPm92ZXJsYXAudGltZVtpXTsKICAgICAgcE91dDAgKys7CiAgICB9CiAgICBuclNhbXBsZXMgPSBoTWRjdC0+b3Zfb2Zmc2V0OwogICAgaE1kY3QtPm92X29mZnNldCA9IDA7CiAgfQoKICBmb3IgKHc9MDsgdzxuU3BlYzsgdysrKQogIHsKICAgIEZJWFBfREJMICpwU3BlYywgKnBDdXJyOwogICAgY29uc3QgRklYUF9XVFAgKnBXaW5kb3c7CgogICAgc3BlY1NoaWZ0U2NhbGUgPSB0cmFuc2Zvcm1fZ2Fpbl9lOwoKICAgIC8qIFNldHVwIHdpbmRvdyBwb2ludGVycyAqLwogICAgcFdpbmRvdyA9IGhNZGN0LT5wcmV2X3dyczsKCiAgICAvKiBDdXJyZW50IHNwZWN0cnVtICovCiAgICBwU3BlYyA9IHNwZWN0cnVtK3cqdGw7CgogICAgLyogRENUIElWIG9mIGN1cnJlbnQgc3BlY3RydW0uICovCiAgICBkY3RfSVYocFNwZWMsIHRsLCAmc3BlY1NoaWZ0U2NhbGUpOwoKICAgIC8qIE9wdGlvbmFsIHNjYWxpbmcgb2YgdGltZSBkb21haW4gLSBubyB5ZXQgd2luZG93ZWQgLSBvZiBjdXJyZW50IHNwZWN0cnVtICovCiAgICAvKiBhbmQgZGUtc2NhbGUgY3VycmVudCBzcGVjdHJ1bSBzaWduYWwgKHRpbWUgZG9tYWluLCBubyB5ZXQgd2luZG93ZWQpICovCQogICAgaWYgKGdhaW4gIT0gKEZJWFBfREJMKTApIHsKICAgICAgc2NhbGVWYWx1ZXNXaXRoRmFjdG9yKHBTcGVjLCBnYWluLCB0bCwgc2NhbGVmYWN0b3Jbd10gKyBzcGVjU2hpZnRTY2FsZSk7CiAgICB9IGVsc2UgewogICAgICBzY2FsZVZhbHVlcyhwU3BlYywgdGwsIHNjYWxlZmFjdG9yW3ddICsgc3BlY1NoaWZ0U2NhbGUpOwogICAgfQoKICAgIGlmICggbm9PdXRTYW1wbGVzIDw9IG5yU2FtcGxlcyApIHsKICAgICAgLyogRGl2ZXJ0IG91dHB1dCBmaXJzdCBoYWxmIHRvIG92ZXJsYXAgYnVmZmVyIGlmIHdlIGFscmVhZHkgZ290IGVub3VnaCBvdXRwdXQgc2FtcGxlcy4gKi8KICAgICAgcE91dDAgPSBoTWRjdC0+b3ZlcmxhcC50aW1lICsgaE1kY3QtPm92X29mZnNldDsKICAgICAgaE1kY3QtPm92X29mZnNldCArPSBoTWRjdC0+cHJldl9uciArIGZsLzI7CiAgICB9IGVsc2UgewogICAgICAvKiBBY2NvdW50IG91dHB1dCBzYW1wbGVzICovCiAgICAgIG5yU2FtcGxlcyArPSBoTWRjdC0+cHJldl9uciArIGZsLzI7CiAgICB9CgogICAgLyogTlIgb3V0cHV0IHNhbXBsZXMgMCAuLiBOUi4gLW92ZXJsYXBbVEwvMi4uVEwvMi1OUl0gKi8KICAgIGZvciAoaT0wOyBpPGhNZGN0LT5wcmV2X25yOyBpKyspIHsKICAgICAgRklYUF9EQkwgeCA9IC0gKCpwT3ZsLS0pOwogICAgICAqcE91dDAgPSBJTURDVF9TQ0FMRV9EQkwoeCk7CiAgICAgIHBPdXQwICsrOwogICAgfQoKICAgIGlmICggbm9PdXRTYW1wbGVzIDw9IG5yU2FtcGxlcyApIHsKICAgICAgLyogRGl2ZXJ0IG91dHB1dCBzZWNvbmQgaGFsZiB0byBvdmVybGFwIGJ1ZmZlciBpZiB3ZSBhbHJlYWR5IGdvdCBlbm91Z2ggb3V0cHV0IHNhbXBsZXMuICovCiAgICAgIHBPdXQxID0gaE1kY3QtPm92ZXJsYXAudGltZSArIGhNZGN0LT5vdl9vZmZzZXQgKyBmbC8yIC0gMTsKICAgICAgaE1kY3QtPm92X29mZnNldCArPSBmbC8yICsgbmw7CiAgICB9IGVsc2UgewogICAgICBwT3V0MSA9IHBPdXQwICsgKGZsIC0gMSk7CiAgICAgIG5yU2FtcGxlcyArPSBmbC8yICsgbmw7CiAgICB9CgogICAgLyogb3V0cHV0IHNhbXBsZXMgYmVmb3JlIHdpbmRvdyBjcm9zc2luZyBwb2ludCBOUiAuLiBUTC8yLiAtb3ZlcmxhcFtUTC8yLU5SLi5UTC8yLU5SLUZMLzJdICsgY3VycmVudFtOUi4uVEwvMl0gKi8KICAgIC8qIG91dHB1dCBzYW1wbGVzIGFmdGVyIHdpbmRvdyBjcm9zc2luZyBwb2ludCBUTC8yIC4uIFRMLzIrRkwvMi4gLW92ZXJsYXBbMC4uRkwvMl0gLSBjdXJyZW50W1RMLzIuLkZMLzJdICovCiAgICBwQ3VyciA9IHBTcGVjICsgdGwgLSBmbC8yOwogICAgZm9yIChpPTA7IGk8ZmwvMjsgaSsrKSB7CiAgICAgIEZJWFBfREJMIHgwLCB4MTsKCiAgICAgIGNwbHhNdWx0KCZ4MSwgJngwLCAqcEN1cnIrKywgLSAqcE92bC0tLCBwV2luZG93W2ldKTsKICAgICAgKnBPdXQwID0gSU1EQ1RfU0NBTEVfREJMKHgwKTsKICAgICAgKnBPdXQxID0gSU1EQ1RfU0NBTEVfREJMKC14MSk7CiAgICAgIHBPdXQwICsrOwogICAgICBwT3V0MSAtLTsKICAgIH0KICAgIHBPdXQwICs9IChmbC8yKTsKCiAgICAvKiBOTCBvdXRwdXQgc2FtcGxlcyBUTC8yK0ZMLzIuLlRMLiAtIGN1cnJlbnRbRkwvMi4uMF0gKi8KICAgIHBPdXQxICs9IChmbC8yKSArIDE7CiAgICBwQ3VyciA9IHBTcGVjICsgdGwgLSBmbC8yIC0gMTsKICAgIGZvciAoaT0wOyBpPG5sOyBpKyspIHsKICAgICAgRklYUF9EQkwgeCA9IC0gKCpwQ3Vyci0tKTsKICAgICAgKnBPdXQxID0gSU1EQ1RfU0NBTEVfREJMKHgpOwogICAgICBwT3V0MSArKzsKICAgIH0KCiAgICAvKiBTZXQgb3ZlcmxhcCBzb3VyY2UgcG9pbnRlciBmb3IgbmV4dCB3aW5kb3cgcE92bCA9IHBTcGVjICsgdGwvMiAtIDE7ICovCiAgICBwT3ZsID0gcFNwZWMgKyB0bC8yIC0gMTsKCiAgICAvKiBQcmV2aW91cyB3aW5kb3cgdmFsdWVzLiAqLwogICAgaE1kY3QtPnByZXZfbnIgPSBucjsKICAgIGhNZGN0LT5wcmV2X2ZyID0gZnI7CiAgICBoTWRjdC0+cHJldl90bCA9IHRsOwogICAgaE1kY3QtPnByZXZfd3JzID0gd3JzOwogIH0KCiAgLyogU2F2ZSBvdmVybGFwICovCiAgCiAgcE92bCA9IGhNZGN0LT5vdmVybGFwLmZyZXEgKyBoTWRjdC0+b3Zfc2l6ZSAtIHRsLzI7CiAgRkRLX0FTU0VSVChwT3ZsID49IGhNZGN0LT5vdmVybGFwLnRpbWUgKyBoTWRjdC0+b3Zfb2Zmc2V0KTsKICBGREtfQVNTRVJUKHRsLzIgPD0gaE1kY3QtPm92X3NpemUpOwogIGZvciAoaT0wOyBpPHRsLzI7IGkrKykgewogICAgcE92bFtpXSA9IHNwZWN0cnVtW2krKG5TcGVjLTEpKnRsXTsKICB9CgogIHJldHVybiBuclNhbXBsZXM7Cn0KCg==