Ci8qIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tClNvZnR3YXJlIExpY2Vuc2UgZm9yIFRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZAoKqSBDb3B5cmlnaHQgIDE5OTUgLSAyMDEzIEZyYXVuaG9mZXItR2VzZWxsc2NoYWZ0IHp1ciBG9nJkZXJ1bmcgZGVyIGFuZ2V3YW5kdGVuIEZvcnNjaHVuZyBlLlYuCiAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAxLiAgICBJTlRST0RVQ1RJT04KVGhlIEZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkICgiRkRLIEFBQyBDb2RlYyIpIGlzIHNvZnR3YXJlIHRoYXQgaW1wbGVtZW50cwp0aGUgTVBFRyBBZHZhbmNlZCBBdWRpbyBDb2RpbmcgKCJBQUMiKSBlbmNvZGluZyBhbmQgZGVjb2Rpbmcgc2NoZW1lIGZvciBkaWdpdGFsIGF1ZGlvLgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgaW50ZW5kZWQgdG8gYmUgdXNlZCBvbiBhIHdpZGUgdmFyaWV0eSBvZiBBbmRyb2lkIGRldmljZXMuCgpBQUMncyBIRS1BQUMgYW5kIEhFLUFBQyB2MiB2ZXJzaW9ucyBhcmUgcmVnYXJkZWQgYXMgdG9kYXkncyBtb3N0IGVmZmljaWVudCBnZW5lcmFsIHBlcmNlcHR1YWwKYXVkaW8gY29kZWNzLiBBQUMtRUxEIGlzIGNvbnNpZGVyZWQgdGhlIGJlc3QtcGVyZm9ybWluZyBmdWxsLWJhbmR3aWR0aCBjb21tdW5pY2F0aW9ucyBjb2RlYyBieQppbmRlcGVuZGVudCBzdHVkaWVzIGFuZCBpcyB3aWRlbHkgZGVwbG95ZWQuIEFBQyBoYXMgYmVlbiBzdGFuZGFyZGl6ZWQgYnkgSVNPIGFuZCBJRUMgYXMgcGFydApvZiB0aGUgTVBFRyBzcGVjaWZpY2F0aW9ucy4KClBhdGVudCBsaWNlbnNlcyBmb3IgbmVjZXNzYXJ5IHBhdGVudCBjbGFpbXMgZm9yIHRoZSBGREsgQUFDIENvZGVjIChpbmNsdWRpbmcgdGhvc2Ugb2YgRnJhdW5ob2ZlcikKbWF5IGJlIG9idGFpbmVkIHRocm91Z2ggVmlhIExpY2Vuc2luZyAod3d3LnZpYWxpY2Vuc2luZy5jb20pIG9yIHRocm91Z2ggdGhlIHJlc3BlY3RpdmUgcGF0ZW50IG93bmVycwppbmRpdmlkdWFsbHkgZm9yIHRoZSBwdXJwb3NlIG9mIGVuY29kaW5nIG9yIGRlY29kaW5nIGJpdCBzdHJlYW1zIGluIHByb2R1Y3RzIHRoYXQgYXJlIGNvbXBsaWFudCB3aXRoCnRoZSBJU08vSUVDIE1QRUcgYXVkaW8gc3RhbmRhcmRzLiBQbGVhc2Ugbm90ZSB0aGF0IG1vc3QgbWFudWZhY3R1cmVycyBvZiBBbmRyb2lkIGRldmljZXMgYWxyZWFkeSBsaWNlbnNlCnRoZXNlIHBhdGVudCBjbGFpbXMgdGhyb3VnaCBWaWEgTGljZW5zaW5nIG9yIGRpcmVjdGx5IGZyb20gdGhlIHBhdGVudCBvd25lcnMsIGFuZCB0aGVyZWZvcmUgRkRLIEFBQyBDb2RlYwpzb2Z0d2FyZSBtYXkgYWxyZWFkeSBiZSBjb3ZlcmVkIHVuZGVyIHRob3NlIHBhdGVudCBsaWNlbnNlcyB3aGVuIGl0IGlzIHVzZWQgZm9yIHRob3NlIGxpY2Vuc2VkIHB1cnBvc2VzIG9ubHkuCgpDb21tZXJjaWFsbHktbGljZW5zZWQgQUFDIHNvZnR3YXJlIGxpYnJhcmllcywgaW5jbHVkaW5nIGZsb2F0aW5nLXBvaW50IHZlcnNpb25zIHdpdGggZW5oYW5jZWQgc291bmQgcXVhbGl0eSwKYXJlIGFsc28gYXZhaWxhYmxlIGZyb20gRnJhdW5ob2Zlci4gVXNlcnMgYXJlIGVuY291cmFnZWQgdG8gY2hlY2sgdGhlIEZyYXVuaG9mZXIgd2Vic2l0ZSBmb3IgYWRkaXRpb25hbAphcHBsaWNhdGlvbnMgaW5mb3JtYXRpb24gYW5kIGRvY3VtZW50YXRpb24uCgoyLiAgICBDT1BZUklHSFQgTElDRU5TRQoKUmVkaXN0cmlidXRpb24gYW5kIHVzZSBpbiBzb3VyY2UgYW5kIGJpbmFyeSBmb3Jtcywgd2l0aCBvciB3aXRob3V0IG1vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCB3aXRob3V0CnBheW1lbnQgb2YgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBwcm92aWRlZCB0aGF0IHlvdSBzYXRpc2Z5IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoKCllvdSBtdXN0IHJldGFpbiB0aGUgY29tcGxldGUgdGV4dCBvZiB0aGlzIHNvZnR3YXJlIGxpY2Vuc2UgaW4gcmVkaXN0cmlidXRpb25zIG9mIHRoZSBGREsgQUFDIENvZGVjIG9yCnlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvIGluIHNvdXJjZSBjb2RlIGZvcm0uCgpZb3UgbXVzdCByZXRhaW4gdGhlIGNvbXBsZXRlIHRleHQgb2YgdGhpcyBzb2Z0d2FyZSBsaWNlbnNlIGluIHRoZSBkb2N1bWVudGF0aW9uIGFuZC9vciBvdGhlciBtYXRlcmlhbHMKcHJvdmlkZWQgd2l0aCByZWRpc3RyaWJ1dGlvbnMgb2YgdGhlIEZESyBBQUMgQ29kZWMgb3IgeW91ciBtb2RpZmljYXRpb25zIHRoZXJldG8gaW4gYmluYXJ5IGZvcm0uCllvdSBtdXN0IG1ha2UgYXZhaWxhYmxlIGZyZWUgb2YgY2hhcmdlIGNvcGllcyBvZiB0aGUgY29tcGxldGUgc291cmNlIGNvZGUgb2YgdGhlIEZESyBBQUMgQ29kZWMgYW5kIHlvdXIKbW9kaWZpY2F0aW9ucyB0aGVyZXRvIHRvIHJlY2lwaWVudHMgb2YgY29waWVzIGluIGJpbmFyeSBmb3JtLgoKVGhlIG5hbWUgb2YgRnJhdW5ob2ZlciBtYXkgbm90IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIGxpYnJhcnkgd2l0aG91dApwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgpZb3UgbWF5IG5vdCBjaGFyZ2UgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBmb3IgYW55b25lIHRvIHVzZSwgY29weSBvciBkaXN0cmlidXRlIHRoZSBGREsgQUFDIENvZGVjCnNvZnR3YXJlIG9yIHlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvLgoKWW91ciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYyBtdXN0IGNhcnJ5IHByb21pbmVudCBub3RpY2VzIHN0YXRpbmcgdGhhdCB5b3UgY2hhbmdlZCB0aGUgc29mdHdhcmUKYW5kIHRoZSBkYXRlIG9mIGFueSBjaGFuZ2UuIEZvciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYywgdGhlIHRlcm0KIkZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkIiBtdXN0IGJlIHJlcGxhY2VkIGJ5IHRoZSB0ZXJtCiJUaGlyZC1QYXJ0eSBNb2RpZmllZCBWZXJzaW9uIG9mIHRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZC4iCgozLiAgICBOTyBQQVRFTlQgTElDRU5TRQoKTk8gRVhQUkVTUyBPUiBJTVBMSUVEIExJQ0VOU0VTIFRPIEFOWSBQQVRFTlQgQ0xBSU1TLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSBwYXRlbnRzIG9mIEZyYXVuaG9mZXIsCkFSRSBHUkFOVEVEIEJZIFRISVMgU09GVFdBUkUgTElDRU5TRS4gRnJhdW5ob2ZlciBwcm92aWRlcyBubyB3YXJyYW50eSBvZiBwYXRlbnQgbm9uLWluZnJpbmdlbWVudCB3aXRoCnJlc3BlY3QgdG8gdGhpcyBzb2Z0d2FyZS4KCllvdSBtYXkgdXNlIHRoaXMgRkRLIEFBQyBDb2RlYyBzb2Z0d2FyZSBvciBtb2RpZmljYXRpb25zIHRoZXJldG8gb25seSBmb3IgcHVycG9zZXMgdGhhdCBhcmUgYXV0aG9yaXplZApieSBhcHByb3ByaWF0ZSBwYXRlbnQgbGljZW5zZXMuCgo0LiAgICBESVNDTEFJTUVSCgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgcHJvdmlkZWQgYnkgRnJhdW5ob2ZlciBvbiBiZWhhbGYgb2YgdGhlIGNvcHlyaWdodCBob2xkZXJzIGFuZCBjb250cmlidXRvcnMKIkFTIElTIiBhbmQgV0lUSE9VVCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIGluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gdGhlIGltcGxpZWQgd2FycmFudGllcwpvZiBtZXJjaGFudGFiaWxpdHkgYW5kIGZpdG5lc3MgZm9yIGEgcGFydGljdWxhciBwdXJwb3NlLiBJTiBOTyBFVkVOVCBTSEFMTCBUSEUgQ09QWVJJR0hUIEhPTERFUiBPUgpDT05UUklCVVRPUlMgQkUgTElBQkxFIGZvciBhbnkgZGlyZWN0LCBpbmRpcmVjdCwgaW5jaWRlbnRhbCwgc3BlY2lhbCwgZXhlbXBsYXJ5LCBvciBjb25zZXF1ZW50aWFsIGRhbWFnZXMsCmluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gcHJvY3VyZW1lbnQgb2Ygc3Vic3RpdHV0ZSBnb29kcyBvciBzZXJ2aWNlczsgbG9zcyBvZiB1c2UsIGRhdGEsIG9yIHByb2ZpdHMsCm9yIGJ1c2luZXNzIGludGVycnVwdGlvbiwgaG93ZXZlciBjYXVzZWQgYW5kIG9uIGFueSB0aGVvcnkgb2YgbGlhYmlsaXR5LCB3aGV0aGVyIGluIGNvbnRyYWN0LCBzdHJpY3QKbGlhYmlsaXR5LCBvciB0b3J0IChpbmNsdWRpbmcgbmVnbGlnZW5jZSksIGFyaXNpbmcgaW4gYW55IHdheSBvdXQgb2YgdGhlIHVzZSBvZiB0aGlzIHNvZnR3YXJlLCBldmVuIGlmCmFkdmlzZWQgb2YgdGhlIHBvc3NpYmlsaXR5IG9mIHN1Y2ggZGFtYWdlLgoKNS4gICAgQ09OVEFDVCBJTkZPUk1BVElPTgoKRnJhdW5ob2ZlciBJbnN0aXR1dGUgZm9yIEludGVncmF0ZWQgQ2lyY3VpdHMgSUlTCkF0dGVudGlvbjogQXVkaW8gYW5kIE11bHRpbWVkaWEgRGVwYXJ0bWVudHMgLSBGREsgQUFDIExMCkFtIFdvbGZzbWFudGVsIDMzCjkxMDU4IEVybGFuZ2VuLCBHZXJtYW55Cgp3d3cuaWlzLmZyYXVuaG9mZXIuZGUvYW1tCmFtbS1pbmZvQGlpcy5mcmF1bmhvZmVyLmRlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiogTVBFRyBBdWRpbyBFbmNvZGVyICoqKioqKioqKioqKioqKioqKioqKioqKioqCgogICBJbml0aWFsIGF1dGhvcjogICAgICAgTS5XZXJuZXIKICAgY29udGVudHMvZGVzY3JpcHRpb246IFByZSBlY2hvIGNvbnRyb2wKCioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCiNpbmNsdWRlICJwcmVfZWNob19jb250cm9sLmgiCiNpbmNsdWRlICJwc3lfY29uZmlndXJhdGlvbi5oIgoKdm9pZCBGREthYWNFbmNfSW5pdFByZUVjaG9Db250cm9sKEZJWFBfREJMICAgICpSRVNUUklDVCBwYlRocmVzaG9sZE5tMSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIElOVCAgICAgICAgICpjYWxjUHJlRWNobywKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIElOVCAgICAgICAgICBudW1QYiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZJWFBfREJMICAgICpSRVNUUklDVCBzZmJQY21RdWFudFRocmVzaG9sZCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIElOVCAgICAgICAgICptZGN0U2NhbGVubTEpCnsKICAqbWRjdFNjYWxlbm0xID0gUENNX1FVQU5UX1RIUl9TQ0FMRT4+MTsKCiAgRkRLbWVtY3B5KHBiVGhyZXNob2xkTm0xLCBzZmJQY21RdWFudFRocmVzaG9sZCwgbnVtUGIqc2l6ZW9mKEZJWFBfREJMKSk7CgogICpjYWxjUHJlRWNobyA9IDE7Cn0KCgp2b2lkIEZES2FhY0VuY19QcmVFY2hvQ29udHJvbChGSVhQX0RCTCAgICpSRVNUUklDVCBwYlRocmVzaG9sZE5tMSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSU5UICAgICAgICAgY2FsY1ByZUVjaG8sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIElOVCAgICAgICAgIG51bVBiLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICBJTlQgICAgICAgICBtYXhBbGxvd2VkSW5jcmVhc2VGYWN0b3IsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZJWFBfU0dMICAgIG1pblJlbWFpbmluZ1RocmVzaG9sZEZhY3RvciwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgRklYUF9EQkwgICAqUkVTVFJJQ1QgcGJUaHJlc2hvbGQsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIElOVCAgICAgICAgIG1kY3RTY2FsZSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgSU5UICAgICAgICAqbWRjdFNjYWxlbm0xKQp7CiAgICBpbnQgaTsKICAgIEZJWFBfREJMIHRtcFRocmVzaG9sZDEsIHRtcFRocmVzaG9sZDI7CiAgICBpbnQgc2NhbGluZzsKCgkvKiBJZiBsYXN0V2luZG93U2VxdWVuY2UgaW4gcHJldmlvdXMgZnJhbWUgd2FzIHN0YXJ0LSBvciBzdG9wLXdpbmRvdywKCSAgIHNraXAgcHJlZWNob2NvbnRyb2wgY2FsY3VsYXRpb24gKi8KICAgIGlmIChjYWxjUHJlRWNobz09MCkgewogICAgICAvKiBjb3B5IHRocmVzaG9sZHMgdG8gaW50ZXJuYWwgbWVtb3J5ICovCiAgICAgIEZES21lbWNweShwYlRocmVzaG9sZE5tMSwgcGJUaHJlc2hvbGQsIG51bVBiKnNpemVvZihGSVhQX0RCTCkpOwogICAgICAqbWRjdFNjYWxlbm0xID0gbWRjdFNjYWxlOwogICAgICByZXR1cm47CiAgICB9CgogICAgaWYgKCBtZGN0U2NhbGUgPiAqbWRjdFNjYWxlbm0xICkgewogICAgICAgIC8qIGlmIGN1cnJlbnQgdGhyZXNob2xkcyBhcmUgZG93bnNjYWxlZCBtb3JlIHRoYW4gdGhlIG9uZXMgZnJvbSB0aGUgbGFzdCBibG9jayAqLwogICAgICAgIHNjYWxpbmcgPSAyKihtZGN0U2NhbGUtKm1kY3RTY2FsZW5tMSk7CiAgICAgICAgZm9yKGkgPSAwOyBpIDwgbnVtUGI7IGkrKykgewoKICAgICAgICAgICAgLyogbXVsdGlwbGljYXRpb24gd2l0aCByZXR1cm4gZGF0YSB0eXBlIGZyYWN0IGlzdCBlcXVpdmFsZW50IHRvIGludCBtdWx0aXBsaWNhdGlvbiAqLwogICAgICAgICAgICBGREtfQVNTRVJUKHNjYWxpbmc+PTApOwogICAgICAgICAgICB0bXBUaHJlc2hvbGQxID0gbWF4QWxsb3dlZEluY3JlYXNlRmFjdG9yICogKHBiVGhyZXNob2xkTm0xW2ldPj5zY2FsaW5nKTsKICAgICAgICAgICAgdG1wVGhyZXNob2xkMiA9IGZNdWx0KG1pblJlbWFpbmluZ1RocmVzaG9sZEZhY3RvciwgcGJUaHJlc2hvbGRbaV0pOwoKCQkJRklYUF9EQkwgdG1wID0gcGJUaHJlc2hvbGRbaV07CgogICAgICAgICAgICAvKiBjb3B5IHRocmVzaG9sZHMgdG8gaW50ZXJuYWwgbWVtb3J5ICovCiAgICAgICAgICAgIHBiVGhyZXNob2xkTm0xW2ldID0gdG1wOwoKICAgICAgICAgICAgdG1wID0gZml4TWluKHRtcCwgdG1wVGhyZXNob2xkMSk7CiAgICAgICAgICAgIHBiVGhyZXNob2xkW2ldID0gZml4TWF4KHRtcCwgdG1wVGhyZXNob2xkMik7CiAgICAgICAgfQogICAgfQogICAgZWxzZSB7CiAgICAgICAgLyogaWYgdGhyZXNob2xkcyBvZiBsYXN0IGJsb2NrIGFyZSBtb3JlIGRvd25zY2FsZWQgdGhhbiB0aGUgY3VycmVudCBvbmVzICovCiAgICAgICAgc2NhbGluZyA9IDIqKCptZGN0U2NhbGVubTEtbWRjdFNjYWxlKTsKICAgICAgICBmb3IoaSA9IDA7IGkgPCBudW1QYjsgaSsrKSB7CgogICAgICAgICAgICAvKiBtdWx0aXBsaWNhdGlvbiB3aXRoIHJldHVybiBkYXRhIHR5cGUgZnJhY3QgaXN0IGVxdWl2YWxlbnQgdG8gaW50IG11bHRpcGxpY2F0aW9uICovCiAgICAgICAgICAgIHRtcFRocmVzaG9sZDEgPSAobWF4QWxsb3dlZEluY3JlYXNlRmFjdG9yPj4xKSAqIHBiVGhyZXNob2xkTm0xW2ldOwogICAgICAgICAgICB0bXBUaHJlc2hvbGQyID0gZk11bHQobWluUmVtYWluaW5nVGhyZXNob2xkRmFjdG9yLCBwYlRocmVzaG9sZFtpXSk7CgogICAgICAgICAgICAvKiBjb3B5IHRocmVzaG9sZHMgdG8gaW50ZXJuYWwgbWVtb3J5ICovCiAgICAgICAgICAgIHBiVGhyZXNob2xkTm0xW2ldID0gcGJUaHJlc2hvbGRbaV07CgogICAgICAgICAgICBGREtfQVNTRVJUKHNjYWxpbmc+PTApOwogICAgICAgICAgICBpZigocGJUaHJlc2hvbGRbaV0+PihzY2FsaW5nKzEpKSA+IHRtcFRocmVzaG9sZDEpIHsKICAgICAgICAgICAgICAgIHBiVGhyZXNob2xkW2ldID0gdG1wVGhyZXNob2xkMTw8KHNjYWxpbmcrMSk7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgcGJUaHJlc2hvbGRbaV0gPSBmaXhNYXgocGJUaHJlc2hvbGRbaV0sIHRtcFRocmVzaG9sZDIpOwogICAgICAgIH0KICAgIH0KCiAgICAqbWRjdFNjYWxlbm0xID0gbWRjdFNjYWxlOwp9Cg==