Ci8qIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tClNvZnR3YXJlIExpY2Vuc2UgZm9yIFRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZAoKqSBDb3B5cmlnaHQgIDE5OTUgLSAyMDEyIEZyYXVuaG9mZXItR2VzZWxsc2NoYWZ0IHp1ciBG9nJkZXJ1bmcgZGVyIGFuZ2V3YW5kdGVuIEZvcnNjaHVuZyBlLlYuCiAgQWxsIHJpZ2h0cyByZXNlcnZlZC4KCiAxLiAgICBJTlRST0RVQ1RJT04KVGhlIEZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkICgiRkRLIEFBQyBDb2RlYyIpIGlzIHNvZnR3YXJlIHRoYXQgaW1wbGVtZW50cwp0aGUgTVBFRyBBZHZhbmNlZCBBdWRpbyBDb2RpbmcgKCJBQUMiKSBlbmNvZGluZyBhbmQgZGVjb2Rpbmcgc2NoZW1lIGZvciBkaWdpdGFsIGF1ZGlvLgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgaW50ZW5kZWQgdG8gYmUgdXNlZCBvbiBhIHdpZGUgdmFyaWV0eSBvZiBBbmRyb2lkIGRldmljZXMuCgpBQUMncyBIRS1BQUMgYW5kIEhFLUFBQyB2MiB2ZXJzaW9ucyBhcmUgcmVnYXJkZWQgYXMgdG9kYXkncyBtb3N0IGVmZmljaWVudCBnZW5lcmFsIHBlcmNlcHR1YWwKYXVkaW8gY29kZWNzLiBBQUMtRUxEIGlzIGNvbnNpZGVyZWQgdGhlIGJlc3QtcGVyZm9ybWluZyBmdWxsLWJhbmR3aWR0aCBjb21tdW5pY2F0aW9ucyBjb2RlYyBieQppbmRlcGVuZGVudCBzdHVkaWVzIGFuZCBpcyB3aWRlbHkgZGVwbG95ZWQuIEFBQyBoYXMgYmVlbiBzdGFuZGFyZGl6ZWQgYnkgSVNPIGFuZCBJRUMgYXMgcGFydApvZiB0aGUgTVBFRyBzcGVjaWZpY2F0aW9ucy4KClBhdGVudCBsaWNlbnNlcyBmb3IgbmVjZXNzYXJ5IHBhdGVudCBjbGFpbXMgZm9yIHRoZSBGREsgQUFDIENvZGVjIChpbmNsdWRpbmcgdGhvc2Ugb2YgRnJhdW5ob2ZlcikKbWF5IGJlIG9idGFpbmVkIHRocm91Z2ggVmlhIExpY2Vuc2luZyAod3d3LnZpYWxpY2Vuc2luZy5jb20pIG9yIHRocm91Z2ggdGhlIHJlc3BlY3RpdmUgcGF0ZW50IG93bmVycwppbmRpdmlkdWFsbHkgZm9yIHRoZSBwdXJwb3NlIG9mIGVuY29kaW5nIG9yIGRlY29kaW5nIGJpdCBzdHJlYW1zIGluIHByb2R1Y3RzIHRoYXQgYXJlIGNvbXBsaWFudCB3aXRoCnRoZSBJU08vSUVDIE1QRUcgYXVkaW8gc3RhbmRhcmRzLiBQbGVhc2Ugbm90ZSB0aGF0IG1vc3QgbWFudWZhY3R1cmVycyBvZiBBbmRyb2lkIGRldmljZXMgYWxyZWFkeSBsaWNlbnNlCnRoZXNlIHBhdGVudCBjbGFpbXMgdGhyb3VnaCBWaWEgTGljZW5zaW5nIG9yIGRpcmVjdGx5IGZyb20gdGhlIHBhdGVudCBvd25lcnMsIGFuZCB0aGVyZWZvcmUgRkRLIEFBQyBDb2RlYwpzb2Z0d2FyZSBtYXkgYWxyZWFkeSBiZSBjb3ZlcmVkIHVuZGVyIHRob3NlIHBhdGVudCBsaWNlbnNlcyB3aGVuIGl0IGlzIHVzZWQgZm9yIHRob3NlIGxpY2Vuc2VkIHB1cnBvc2VzIG9ubHkuCgpDb21tZXJjaWFsbHktbGljZW5zZWQgQUFDIHNvZnR3YXJlIGxpYnJhcmllcywgaW5jbHVkaW5nIGZsb2F0aW5nLXBvaW50IHZlcnNpb25zIHdpdGggZW5oYW5jZWQgc291bmQgcXVhbGl0eSwKYXJlIGFsc28gYXZhaWxhYmxlIGZyb20gRnJhdW5ob2Zlci4gVXNlcnMgYXJlIGVuY291cmFnZWQgdG8gY2hlY2sgdGhlIEZyYXVuaG9mZXIgd2Vic2l0ZSBmb3IgYWRkaXRpb25hbAphcHBsaWNhdGlvbnMgaW5mb3JtYXRpb24gYW5kIGRvY3VtZW50YXRpb24uCgoyLiAgICBDT1BZUklHSFQgTElDRU5TRQoKUmVkaXN0cmlidXRpb24gYW5kIHVzZSBpbiBzb3VyY2UgYW5kIGJpbmFyeSBmb3Jtcywgd2l0aCBvciB3aXRob3V0IG1vZGlmaWNhdGlvbiwgYXJlIHBlcm1pdHRlZCB3aXRob3V0CnBheW1lbnQgb2YgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBwcm92aWRlZCB0aGF0IHlvdSBzYXRpc2Z5IHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoKCllvdSBtdXN0IHJldGFpbiB0aGUgY29tcGxldGUgdGV4dCBvZiB0aGlzIHNvZnR3YXJlIGxpY2Vuc2UgaW4gcmVkaXN0cmlidXRpb25zIG9mIHRoZSBGREsgQUFDIENvZGVjIG9yCnlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvIGluIHNvdXJjZSBjb2RlIGZvcm0uCgpZb3UgbXVzdCByZXRhaW4gdGhlIGNvbXBsZXRlIHRleHQgb2YgdGhpcyBzb2Z0d2FyZSBsaWNlbnNlIGluIHRoZSBkb2N1bWVudGF0aW9uIGFuZC9vciBvdGhlciBtYXRlcmlhbHMKcHJvdmlkZWQgd2l0aCByZWRpc3RyaWJ1dGlvbnMgb2YgdGhlIEZESyBBQUMgQ29kZWMgb3IgeW91ciBtb2RpZmljYXRpb25zIHRoZXJldG8gaW4gYmluYXJ5IGZvcm0uCllvdSBtdXN0IG1ha2UgYXZhaWxhYmxlIGZyZWUgb2YgY2hhcmdlIGNvcGllcyBvZiB0aGUgY29tcGxldGUgc291cmNlIGNvZGUgb2YgdGhlIEZESyBBQUMgQ29kZWMgYW5kIHlvdXIKbW9kaWZpY2F0aW9ucyB0aGVyZXRvIHRvIHJlY2lwaWVudHMgb2YgY29waWVzIGluIGJpbmFyeSBmb3JtLgoKVGhlIG5hbWUgb2YgRnJhdW5ob2ZlciBtYXkgbm90IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIGxpYnJhcnkgd2l0aG91dApwcmlvciB3cml0dGVuIHBlcm1pc3Npb24uCgpZb3UgbWF5IG5vdCBjaGFyZ2UgY29weXJpZ2h0IGxpY2Vuc2UgZmVlcyBmb3IgYW55b25lIHRvIHVzZSwgY29weSBvciBkaXN0cmlidXRlIHRoZSBGREsgQUFDIENvZGVjCnNvZnR3YXJlIG9yIHlvdXIgbW9kaWZpY2F0aW9ucyB0aGVyZXRvLgoKWW91ciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYyBtdXN0IGNhcnJ5IHByb21pbmVudCBub3RpY2VzIHN0YXRpbmcgdGhhdCB5b3UgY2hhbmdlZCB0aGUgc29mdHdhcmUKYW5kIHRoZSBkYXRlIG9mIGFueSBjaGFuZ2UuIEZvciBtb2RpZmllZCB2ZXJzaW9ucyBvZiB0aGUgRkRLIEFBQyBDb2RlYywgdGhlIHRlcm0KIkZyYXVuaG9mZXIgRkRLIEFBQyBDb2RlYyBMaWJyYXJ5IGZvciBBbmRyb2lkIiBtdXN0IGJlIHJlcGxhY2VkIGJ5IHRoZSB0ZXJtCiJUaGlyZC1QYXJ0eSBNb2RpZmllZCBWZXJzaW9uIG9mIHRoZSBGcmF1bmhvZmVyIEZESyBBQUMgQ29kZWMgTGlicmFyeSBmb3IgQW5kcm9pZC4iCgozLiAgICBOTyBQQVRFTlQgTElDRU5TRQoKTk8gRVhQUkVTUyBPUiBJTVBMSUVEIExJQ0VOU0VTIFRPIEFOWSBQQVRFTlQgQ0xBSU1TLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uIHRoZSBwYXRlbnRzIG9mIEZyYXVuaG9mZXIsCkFSRSBHUkFOVEVEIEJZIFRISVMgU09GVFdBUkUgTElDRU5TRS4gRnJhdW5ob2ZlciBwcm92aWRlcyBubyB3YXJyYW50eSBvZiBwYXRlbnQgbm9uLWluZnJpbmdlbWVudCB3aXRoCnJlc3BlY3QgdG8gdGhpcyBzb2Z0d2FyZS4KCllvdSBtYXkgdXNlIHRoaXMgRkRLIEFBQyBDb2RlYyBzb2Z0d2FyZSBvciBtb2RpZmljYXRpb25zIHRoZXJldG8gb25seSBmb3IgcHVycG9zZXMgdGhhdCBhcmUgYXV0aG9yaXplZApieSBhcHByb3ByaWF0ZSBwYXRlbnQgbGljZW5zZXMuCgo0LiAgICBESVNDTEFJTUVSCgpUaGlzIEZESyBBQUMgQ29kZWMgc29mdHdhcmUgaXMgcHJvdmlkZWQgYnkgRnJhdW5ob2ZlciBvbiBiZWhhbGYgb2YgdGhlIGNvcHlyaWdodCBob2xkZXJzIGFuZCBjb250cmlidXRvcnMKIkFTIElTIiBhbmQgV0lUSE9VVCBBTlkgRVhQUkVTUyBPUiBJTVBMSUVEIFdBUlJBTlRJRVMsIGluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gdGhlIGltcGxpZWQgd2FycmFudGllcwpvZiBtZXJjaGFudGFiaWxpdHkgYW5kIGZpdG5lc3MgZm9yIGEgcGFydGljdWxhciBwdXJwb3NlLiBJTiBOTyBFVkVOVCBTSEFMTCBUSEUgQ09QWVJJR0hUIEhPTERFUiBPUgpDT05UUklCVVRPUlMgQkUgTElBQkxFIGZvciBhbnkgZGlyZWN0LCBpbmRpcmVjdCwgaW5jaWRlbnRhbCwgc3BlY2lhbCwgZXhlbXBsYXJ5LCBvciBjb25zZXF1ZW50aWFsIGRhbWFnZXMsCmluY2x1ZGluZyBidXQgbm90IGxpbWl0ZWQgdG8gcHJvY3VyZW1lbnQgb2Ygc3Vic3RpdHV0ZSBnb29kcyBvciBzZXJ2aWNlczsgbG9zcyBvZiB1c2UsIGRhdGEsIG9yIHByb2ZpdHMsCm9yIGJ1c2luZXNzIGludGVycnVwdGlvbiwgaG93ZXZlciBjYXVzZWQgYW5kIG9uIGFueSB0aGVvcnkgb2YgbGlhYmlsaXR5LCB3aGV0aGVyIGluIGNvbnRyYWN0LCBzdHJpY3QKbGlhYmlsaXR5LCBvciB0b3J0IChpbmNsdWRpbmcgbmVnbGlnZW5jZSksIGFyaXNpbmcgaW4gYW55IHdheSBvdXQgb2YgdGhlIHVzZSBvZiB0aGlzIHNvZnR3YXJlLCBldmVuIGlmCmFkdmlzZWQgb2YgdGhlIHBvc3NpYmlsaXR5IG9mIHN1Y2ggZGFtYWdlLgoKNS4gICAgQ09OVEFDVCBJTkZPUk1BVElPTgoKRnJhdW5ob2ZlciBJbnN0aXR1dGUgZm9yIEludGVncmF0ZWQgQ2lyY3VpdHMgSUlTCkF0dGVudGlvbjogQXVkaW8gYW5kIE11bHRpbWVkaWEgRGVwYXJ0bWVudHMgLSBGREsgQUFDIExMCkFtIFdvbGZzbWFudGVsIDMzCjkxMDU4IEVybGFuZ2VuLCBHZXJtYW55Cgp3d3cuaWlzLmZyYXVuaG9mZXIuZGUvYW1tCmFtbS1pbmZvQGlpcy5mcmF1bmhvZmVyLmRlCi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiogTVBFRyBBdWRpbyBFbmNvZGVyICoqKioqKioqKioqKioqKioqKioqKioqKioqCgogICBJbml0aWFsIGF1dGhvcjogICAgICAgTS5XZXJuZXIKICAgY29udGVudHMvZGVzY3JpcHRpb246IFF1YW50aXphdGlvbgoKKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKI2luY2x1ZGUgInF1YW50aXplLmgiCgojaW5jbHVkZSAiYWFjRW5jX3JvbS5oIgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgogICAgZnVuY3Rpb25uYW1lOiBGREthYWNFbmNfcXVhbnRpemVMaW5lcwogICAgZGVzY3JpcHRpb246IHF1YW50aXplcyBzcGVjdHJ1bSBsaW5lcwogICAgcmV0dXJuczoKICAgIGlucHV0OiBnbG9iYWwgZ2FpbiwgbnVtYmVyIG9mIGxpbmVzIHRvIHByb2Nlc3MsIHNwZWN0cmFsIGRhdGEKICAgIG91dHB1dDogcXVhbnRpemVkIHNwZWN0cnVtCgoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQgRkRLYWFjRW5jX3F1YW50aXplTGluZXMoSU5UICAgICAgZ2FpbiwKICAgICAgICAgICAgICAgICAgICAgICAgICBJTlQgICAgICBub09mTGluZXMsCiAgICAgICAgICAgICAgICAgICAgICAgICAgRklYUF9EQkwgKm1kY3RTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgICAgICBTSE9SVCAgICAgICpxdWFTcGVjdHJ1bSkKewogIGludCAgIGxpbmU7CiAgRklYUF9EQkwgayA9IEZMMkZYQ09OU1RfREJMKC0wLjA5NDZmICsgMC41Zik+PjE2OwogIEZJWFBfUVREIHF1YW50aXplciA9IEZES2FhY0VuY19xdWFudFRhYmxlUVsoLWdhaW4pJjNdOwogIElOVCAgICAgIHF1YW50aXplcnNoaWZ0ID0gKCgtZ2Fpbik+PjIpKzE7CgoKICBmb3IgKGxpbmUgPSAwOyBsaW5lIDwgbm9PZkxpbmVzOyBsaW5lKyspCiAgewogICAgRklYUF9EQkwgYWNjdSA9IGZNdWx0RGl2MihtZGN0U3BlY3RydW1bbGluZV0scXVhbnRpemVyKTsKCiAgICBpZiAoYWNjdSA8IEZMMkZYQ09OU1RfREJMKDAuMGYpKQogICAgewogICAgICBhY2N1PS1hY2N1OwogICAgICAvKiBub3JtYWxpemUgKi8KICAgICAgSU5UICAgYWNjdVNoaWZ0ID0gQ250TGVhZGluZ1plcm9zKGFjY3UpIC0gMTsgIC8qIENvdW50TGVhZGluZ0JpdHMoKSBpcyBub3QgbmVjZXNzYXJ5IGhlcmUgc2luY2UgdGVzdCB2YWx1ZSBpcyBhbHdheXMgPiAwICovCiAgICAgIGFjY3UgPDw9IGFjY3VTaGlmdDsKICAgICAgSU5UIHRhYkluZGV4ID0gKElOVCkoYWNjdT4+KERGUkFDVF9CSVRTLTItTUFOVF9ESUdJVFMpKSYofk1BTlRfU0laRSk7CiAgICAgIElOVCB0b3RhbFNoaWZ0ID0gcXVhbnRpemVyc2hpZnQtYWNjdVNoaWZ0KzE7CiAgICAgIGFjY3UgPSBmTXVsdERpdjIoRkRLYWFjRW5jX21UYWJfM180W3RhYkluZGV4XSxGREthYWNFbmNfcXVhbnRUYWJsZUVbdG90YWxTaGlmdCYzXSk7CiAgICAgIHRvdGFsU2hpZnQgPSAoMTYtNCktKDMqKHRvdGFsU2hpZnQ+PjIpKTsKICAgICAgRkRLX0FTU0VSVCh0b3RhbFNoaWZ0ID49MCk7IC8qIE1BWF9RVUFOVF9WSU9MQVRJT04gKi8KICAgICAgYWNjdT4+PXRvdGFsU2hpZnQ7CiAgICAgIHF1YVNwZWN0cnVtW2xpbmVdID0gKFNIT1JUKSgtKChMT05HKShrICsgYWNjdSkgPj4gKERGUkFDVF9CSVRTLTEtMTYpKSk7CiAgICB9CiAgICBlbHNlIGlmKGFjY3UgPiBGTDJGWENPTlNUX0RCTCgwLjBmKSkKICAgIHsKICAgICAgLyogbm9ybWFsaXplICovCiAgICAgIElOVCAgIGFjY3VTaGlmdCA9IENudExlYWRpbmdaZXJvcyhhY2N1KSAtIDE7ICAvKiBDb3VudExlYWRpbmdCaXRzKCkgaXMgbm90IG5lY2Vzc2FyeSBoZXJlIHNpbmNlIHRlc3QgdmFsdWUgaXMgYWx3YXlzID4gMCAqLwogICAgICBhY2N1IDw8PSBhY2N1U2hpZnQ7CiAgICAgIElOVCB0YWJJbmRleCA9IChJTlQpKGFjY3U+PihERlJBQ1RfQklUUy0yLU1BTlRfRElHSVRTKSkmKH5NQU5UX1NJWkUpOwogICAgICBJTlQgdG90YWxTaGlmdCA9IHF1YW50aXplcnNoaWZ0LWFjY3VTaGlmdCsxOwogICAgICBhY2N1ID0gZk11bHREaXYyKEZES2FhY0VuY19tVGFiXzNfNFt0YWJJbmRleF0sRkRLYWFjRW5jX3F1YW50VGFibGVFW3RvdGFsU2hpZnQmM10pOwogICAgICB0b3RhbFNoaWZ0ID0gKDE2LTQpLSgzKih0b3RhbFNoaWZ0Pj4yKSk7CiAgICAgIEZES19BU1NFUlQodG90YWxTaGlmdCA+PTApOyAvKiBNQVhfUVVBTlRfVklPTEFUSU9OICovCiAgICAgIGFjY3U+Pj10b3RhbFNoaWZ0OwogICAgICBxdWFTcGVjdHJ1bVtsaW5lXSA9IChTSE9SVCkoKExPTkcpKGsgKyBhY2N1KSA+PiAoREZSQUNUX0JJVFMtMS0xNikpOwogICAgfQogICAgZWxzZQogICAgICBxdWFTcGVjdHJ1bVtsaW5lXT0wOwogIH0KfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgoKICAgIGZ1bmN0aW9ubmFtZTppRkRLYWFjRW5jX3F1YW50aXplTGluZXMKICAgIGRlc2NyaXB0aW9uOiBpcXVhbnRpemVzIHNwZWN0cnVtIGxpbmVzCiAgICAgICAgICAgICAgICAgbWRjdFNwZWN0cnVtID0gaXF1YVNwZWN0cnVtXjQvMyAqMl4oMC4yNSpnYWluKQogICAgaW5wdXQ6IGdsb2JhbCBnYWluLCBudW1iZXIgb2YgbGluZXMgdG8gcHJvY2VzcyxxdWFudGl6ZWQgc3BlY3RydW0KICAgIG91dHB1dDogc3BlY3RyYWwgZGF0YQoKKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyB2b2lkIEZES2FhY0VuY19pbnZRdWFudGl6ZUxpbmVzKElOVCAgZ2FpbiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBJTlQgIG5vT2ZMaW5lcywKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBTSE9SVCAqcXVhbnRTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICBGSVhQX0RCTCAqbWRjdFNwZWN0cnVtKQoKewogIElOVCBpcXVhbnRpemVybW9kOwogIElOVCBpcXVhbnRpemVyc2hpZnQ7CiAgSU5UIGxpbmU7CgogIGlxdWFudGl6ZXJtb2QgPSBnYWluJjM7CiAgaXF1YW50aXplcnNoaWZ0ID0gZ2Fpbj4+MjsKCiAgZm9yIChsaW5lID0gMDsgbGluZSA8IG5vT2ZMaW5lczsgbGluZSsrKSB7CgogICAgaWYocXVhbnRTcGVjdHJ1bVtsaW5lXSA8IDApIHsKICAgICAgRklYUF9EQkwgYWNjdTsKICAgICAgSU5UIGV4LHNwZWNFeHAsdGFiSW5kZXg7CiAgICAgIEZJWFBfREJMIHMsdDsKCiAgICAgIGFjY3UgPSAoRklYUF9EQkwpIC1xdWFudFNwZWN0cnVtW2xpbmVdOwoKICAgICAgZXggPSBDb3VudExlYWRpbmdCaXRzKGFjY3UpOwogICAgICBhY2N1IDw8PSBleDsKICAgICAgc3BlY0V4cCA9IChERlJBQ1RfQklUUy0xKSAtIGV4OwoKICAgICAgRkRLX0FTU0VSVChzcGVjRXhwIDwgMTQpOyAgICAgICAvKiB0aGlzIGZhaWxzIGlmIGFicyh2YWx1ZSkgPiA4MTkxICovCgogICAgICB0YWJJbmRleCA9IChJTlQpKGFjY3U+PihERlJBQ1RfQklUUy0yLU1BTlRfRElHSVRTKSkmKH5NQU5UX1NJWkUpOwoKICAgICAgLyogY2FsY3VsYXRlICJtYW50aXNzYSIgXjQvMyAqLwogICAgICBzID0gRkRLYWFjRW5jX21UYWJfNF8zRWxjW3RhYkluZGV4XTsKCiAgICAgIC8qIGdldCBhcHByb3BlcmlhdGUgZXhwb25lbnQgbXVsdGlwbGllciBmb3Igc3BlY0V4cF4zLzQgY29tYmluZWQgd2l0aCBzY2ZNb2QgKi8KICAgICAgdCA9IEZES2FhY0VuY19zcGVjRXhwTWFudFRhYmxlQ29tYkVsY1tpcXVhbnRpemVybW9kXVtzcGVjRXhwXTsKCiAgICAgIC8qIG11bHRpcGx5ICJtYW50aXNzYSIgXjQvMyB3aXRoIGV4cG9uZW50IG11bHRpcGxpZXIgKi8KICAgICAgYWNjdSA9IGZNdWx0KHMsdCk7CgogICAgICAvKiBnZXQgYXBwcm9wZXJpYXRlIGV4cG9uZW50IHNoaWZ0ZXIgKi8KICAgICAgc3BlY0V4cCA9IEZES2FhY0VuY19zcGVjRXhwVGFibGVDb21iW2lxdWFudGl6ZXJtb2RdW3NwZWNFeHBdLTE7IC8qIC0xIHRvIGF2b2lkIG92ZXJmbG93cyBpbiBhY2N1ICovCgogICAgICBpZiAoKC1pcXVhbnRpemVyc2hpZnQtc3BlY0V4cCkgPCAwKQogICAgICAgIGFjY3UgPDw9IC0oLWlxdWFudGl6ZXJzaGlmdC1zcGVjRXhwKTsKICAgICAgZWxzZQogICAgICAgIGFjY3UgPj49IC1pcXVhbnRpemVyc2hpZnQtc3BlY0V4cDsKCiAgICAgIG1kY3RTcGVjdHJ1bVtsaW5lXSA9IC1hY2N1OwogICAgfQogICAgZWxzZSBpZiAocXVhbnRTcGVjdHJ1bVtsaW5lXSA+IDApIHsKICAgICAgRklYUF9EQkwgYWNjdTsKICAgICAgSU5UIGV4LHNwZWNFeHAsdGFiSW5kZXg7CiAgICAgIEZJWFBfREJMIHMsdDsKCiAgICAgIGFjY3UgPSAoRklYUF9EQkwpKElOVClxdWFudFNwZWN0cnVtW2xpbmVdOwoKICAgICAgZXggPSBDb3VudExlYWRpbmdCaXRzKGFjY3UpOwogICAgICBhY2N1IDw8PSBleDsKICAgICAgc3BlY0V4cCA9IChERlJBQ1RfQklUUy0xKSAtIGV4OwoKICAgICAgRkRLX0FTU0VSVChzcGVjRXhwIDwgMTQpOyAgICAgICAvKiB0aGlzIGZhaWxzIGlmIGFicyh2YWx1ZSkgPiA4MTkxICovCgogICAgICB0YWJJbmRleCA9IChJTlQpKGFjY3U+PihERlJBQ1RfQklUUy0yLU1BTlRfRElHSVRTKSkmKH5NQU5UX1NJWkUpOwoKICAgICAgLyogY2FsY3VsYXRlICJtYW50aXNzYSIgXjQvMyAqLwogICAgICBzID0gRkRLYWFjRW5jX21UYWJfNF8zRWxjW3RhYkluZGV4XTsKCiAgICAgIC8qIGdldCBhcHByb3BlcmlhdGUgZXhwb25lbnQgbXVsdGlwbGllciBmb3Igc3BlY0V4cF4zLzQgY29tYmluZWQgd2l0aCBzY2ZNb2QgKi8KICAgICAgdCA9IEZES2FhY0VuY19zcGVjRXhwTWFudFRhYmxlQ29tYkVsY1tpcXVhbnRpemVybW9kXVtzcGVjRXhwXTsKCiAgICAgIC8qIG11bHRpcGx5ICJtYW50aXNzYSIgXjQvMyB3aXRoIGV4cG9uZW50IG11bHRpcGxpZXIgKi8KICAgICAgYWNjdSA9IGZNdWx0KHMsdCk7CgogICAgICAvKiBnZXQgYXBwcm9wZXJpYXRlIGV4cG9uZW50IHNoaWZ0ZXIgKi8KICAgICAgc3BlY0V4cCA9IEZES2FhY0VuY19zcGVjRXhwVGFibGVDb21iW2lxdWFudGl6ZXJtb2RdW3NwZWNFeHBdLTE7IC8qIC0xIHRvIGF2b2lkIG92ZXJmbG93cyBpbiBhY2N1ICovCgogICAgICBpZiAoKCAtaXF1YW50aXplcnNoaWZ0LXNwZWNFeHApIDwgMCkKICAgICAgICBhY2N1IDw8PSAtKC1pcXVhbnRpemVyc2hpZnQtc3BlY0V4cCk7CiAgICAgIGVsc2UKICAgICAgICBhY2N1ID4+PSAtaXF1YW50aXplcnNoaWZ0LXNwZWNFeHA7CgogICAgICBtZGN0U3BlY3RydW1bbGluZV0gPSBhY2N1OwogICAgfQogICAgZWxzZSB7CiAgICAgIG1kY3RTcGVjdHJ1bVtsaW5lXSA9IEZMMkZYQ09OU1RfREJMKDAuMGYpOwogICAgfQogIH0KfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCgogICAgZnVuY3Rpb25uYW1lOiBGREthYWNFbmNfUXVhbnRpemVTcGVjdHJ1bQogICAgZGVzY3JpcHRpb246IHF1YW50aXplcyB0aGUgZW50aXJlIHNwZWN0cnVtCiAgICByZXR1cm5zOgogICAgaW5wdXQ6IG51bWJlciBvZiBzY2FsZWZhY3RvciBiYW5kcyB0byBiZSBxdWFudGl6ZWQsIC4uLgogICAgb3V0cHV0OiBxdWFudGl6ZWQgc3BlY3RydW0KCioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwp2b2lkIEZES2FhY0VuY19RdWFudGl6ZVNwZWN0cnVtKElOVCBzZmJDbnQsCiAgICAgICAgICAgICAgICAgICAgICBJTlQgbWF4U2ZiUGVyR3JvdXAsCiAgICAgICAgICAgICAgICAgICAgICBJTlQgc2ZiUGVyR3JvdXAsCiAgICAgICAgICAgICAgICAgICAgICBJTlQgKnNmYk9mZnNldCwKICAgICAgICAgICAgICAgICAgICAgIEZJWFBfREJMICptZGN0U3BlY3RydW0sCiAgICAgICAgICAgICAgICAgICAgICBJTlQgZ2xvYmFsR2FpbiwKICAgICAgICAgICAgICAgICAgICAgIElOVCAqc2NhbGVmYWN0b3JzLAogICAgICAgICAgICAgICAgICAgICAgU0hPUlQgKnF1YW50aXplZFNwZWN0cnVtKQp7CiAgSU5UIHNmYk9mZnMsc2ZiOwoKICAvKiBpbiBGREthYWNFbmNfcXVhbnRpemVMaW5lcyBxdWFTcGVjdHJ1bSBpcyBjYWxjdWxhdGVkIHdpdGg6CiAgICAgICAgc3BlY14oMy80KSAqIDJeKC0zLzE2KlFTUykgKiAyXigzLzQqc2NhbGUpICsgawogICAgIHNpbXBsaWZ5IHNjYWxpbmcgY2FsY3VsYXRpb24gYW5kIHJlZHVjZSBRU1MgYmVmb3JlOgogICAgICAgIHNwZWNeKDMvNCkgKiAyXigtMy8xNiooUVNTIC0gNCpzY2FsZSkpICovCgogIGZvcihzZmJPZmZzPTA7c2ZiT2ZmczxzZmJDbnQ7c2ZiT2Zmcys9c2ZiUGVyR3JvdXApCiAgZm9yIChzZmIgPSAwOyBzZmIgPCBtYXhTZmJQZXJHcm91cDsgc2ZiKyspCiAgewogICAgSU5UIHNjYWxlZmFjdG9yID0gc2NhbGVmYWN0b3JzW3NmYk9mZnMrc2ZiXSA7CgogICAgRkRLYWFjRW5jX3F1YW50aXplTGluZXMoZ2xvYmFsR2FpbiAtIHNjYWxlZmFjdG9yLCAvKiBRU1MgKi8KICAgICAgICAgICAgICAgICAgc2ZiT2Zmc2V0W3NmYk9mZnMrc2ZiKzFdIC0gc2ZiT2Zmc2V0W3NmYk9mZnMrc2ZiXSwKICAgICAgICAgICAgICAgICAgbWRjdFNwZWN0cnVtICsgc2ZiT2Zmc2V0W3NmYk9mZnMrc2ZiXSwKICAgICAgICAgICAgICAgICAgcXVhbnRpemVkU3BlY3RydW0gKyBzZmJPZmZzZXRbc2ZiT2ZmcytzZmJdKTsKICB9Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgoKICAgIGZ1bmN0aW9ubmFtZTogRkRLYWFjRW5jX2NhbGNTZmJEaXN0CiAgICBkZXNjcmlwdGlvbjogY2FsY3VsYXRlcyBkaXN0b3J0aW9uIG9mIHF1YW50aXplZCB2YWx1ZXMKICAgIHJldHVybnM6IGRpc3RvcnRpb24KICAgIGlucHV0OiBnYWluLCBudW1iZXIgb2YgbGluZXMgdG8gcHJvY2Vzcywgc3BlY3RyYWwgZGF0YQogICAgb3V0cHV0OgoKKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCkZJWFBfREJMIEZES2FhY0VuY19jYWxjU2ZiRGlzdChGSVhQX0RCTCAqbWRjdFNwZWN0cnVtLAogICAgICAgICAgICAgICAgICAgICBTSE9SVCAqcXVhbnRTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgSU5UIG5vT2ZMaW5lcywKICAgICAgICAgICAgICAgICAgICAgSU5UIGdhaW4KICAgICAgICAgICAgICAgICAgICAgKQp7CiAgSU5UIGksc2NhbGU7CiAgRklYUF9EQkwgeGZzZjsKICBGSVhQX0RCTCBkaWZmOwogIEZJWFBfREJMIGludlF1YW50U3BlYzsKCiAgeGZzZiA9IEZMMkZYQ09OU1RfREJMKDAuMGYpOwoKICBmb3IgKGk9MDsgaTxub09mTGluZXM7IGkrKykgewogICAgLyogcXVhbnRpemF0aW9uICovCiAgICBGREthYWNFbmNfcXVhbnRpemVMaW5lcyhnYWluLAogICAgICAgICAgICAgICAgICAxLAogICAgICAgICAgICAgICAgICZtZGN0U3BlY3RydW1baV0sCiAgICAgICAgICAgICAgICAgJnF1YW50U3BlY3RydW1baV0pOwoKICAgIGlmIChmQWJzKHF1YW50U3BlY3RydW1baV0pPk1BWF9RVUFOVCkgewogICAgICByZXR1cm4gRkwyRlhDT05TVF9EQkwoMC4wZik7CiAgICB9CiAgICAvKiBpbnZlcnNlIHF1YW50aXphdGlvbiAqLwogICAgRkRLYWFjRW5jX2ludlF1YW50aXplTGluZXMoZ2FpbiwxLCZxdWFudFNwZWN0cnVtW2ldLCZpbnZRdWFudFNwZWMpOwoKICAgIC8qIGRpc3QgKi8KICAgIGRpZmYgPSBmaXhwX2FicyhmaXhwX2FicyhpbnZRdWFudFNwZWMpIC0gZml4cF9hYnMobWRjdFNwZWN0cnVtW2ldPj4xKSk7CgogICAgc2NhbGUgPSBDb3VudExlYWRpbmdCaXRzKGRpZmYpOwogICAgZGlmZiA9IHNjYWxlVmFsdWUoZGlmZiwgc2NhbGUpOwogICAgZGlmZiA9IGZQb3cyKGRpZmYpOwogICAgc2NhbGUgPSBmaXhNaW4oMiooc2NhbGUtMSksIERGUkFDVF9CSVRTLTEpOwoKICAgIGRpZmYgPSBzY2FsZVZhbHVlKGRpZmYsIC1zY2FsZSk7CgogICAgeGZzZiA9IHhmc2YgKyBkaWZmOwogIH0KCiAgeGZzZiA9IENhbGNMZERhdGEoeGZzZik7CgogIHJldHVybiB4ZnNmOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKCiAgICBmdW5jdGlvbm5hbWU6IEZES2FhY0VuY19jYWxjU2ZiUXVhbnRFbmVyZ3lBbmREaXN0CiAgICBkZXNjcmlwdGlvbjogY2FsY3VsYXRlcyBlbmVyZ3kgYW5kIGRpc3RvcnRpb24gb2YgcXVhbnRpemVkIHZhbHVlcwogICAgcmV0dXJuczoKICAgIGlucHV0OiBnYWluLCBudW1iZXIgb2YgbGluZXMgdG8gcHJvY2VzcywgcXVhbnRpemVkIHNwZWN0cmFsIGRhdGEsCiAgICAgICAgICAgc3BlY3RyYWwgZGF0YQogICAgb3V0cHV0OiBlbmVyZ3ksIGRpc3RvcnRpb24KCioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwp2b2lkIEZES2FhY0VuY19jYWxjU2ZiUXVhbnRFbmVyZ3lBbmREaXN0KEZJWFBfREJMICptZGN0U3BlY3RydW0sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBTSE9SVCAqcXVhbnRTcGVjdHJ1bSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIElOVCBub09mTGluZXMsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBJTlQgZ2FpbiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZJWFBfREJMICplbiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIEZJWFBfREJMICpkaXN0KQp7CiAgSU5UIGksc2NhbGU7CiAgRklYUF9EQkwgaW52UXVhbnRTcGVjOwogIEZJWFBfREJMIGRpZmY7CgogIEZJWFBfREJMIGVuZXJneSA9IEZMMkZYQ09OU1RfREJMKDAuMGYpOwogIEZJWFBfREJMIGRpc3RvcnRpb24gPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKCiAgZm9yIChpPTA7IGk8bm9PZkxpbmVzOyBpKyspIHsKCiAgICBpZiAoZkFicyhxdWFudFNwZWN0cnVtW2ldKT5NQVhfUVVBTlQpIHsKICAgICAgKmVuICAgPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKICAgICAgKmRpc3QgPSBGTDJGWENPTlNUX0RCTCgwLjBmKTsKICAgICAgcmV0dXJuOwogICAgfQoKICAgIC8qIGludmVyc2UgcXVhbnRpemF0aW9uICovCiAgICBGREthYWNFbmNfaW52UXVhbnRpemVMaW5lcyhnYWluLDEsJnF1YW50U3BlY3RydW1baV0sJmludlF1YW50U3BlYyk7CgogICAgLyogZW5lcmd5ICovCiAgICBlbmVyZ3kgKz0gZlBvdzIoaW52UXVhbnRTcGVjKTsKCiAgICAvKiBkaXN0ICovCiAgICBkaWZmID0gZml4cF9hYnMoZml4cF9hYnMoaW52UXVhbnRTcGVjKSAtIGZpeHBfYWJzKG1kY3RTcGVjdHJ1bVtpXT4+MSkpOwoKICAgIHNjYWxlID0gQ291bnRMZWFkaW5nQml0cyhkaWZmKTsKICAgIGRpZmYgPSBzY2FsZVZhbHVlKGRpZmYsIHNjYWxlKTsKICAgIGRpZmYgPSBmUG93MihkaWZmKTsKCiAgICBzY2FsZSA9IGZpeE1pbigyKihzY2FsZS0xKSwgREZSQUNUX0JJVFMtMSk7CgogICAgZGlmZiA9IHNjYWxlVmFsdWUoZGlmZiwgLXNjYWxlKTsKCiAgICBkaXN0b3J0aW9uICs9IGRpZmY7CiAgfQoKICAqZW4gICA9IENhbGNMZERhdGEoZW5lcmd5KStGTDJGWENPTlNUX0RCTCgwLjAzMTI1Zik7CiAgKmRpc3QgPSBDYWxjTGREYXRhKGRpc3RvcnRpb24pOwp9Cgo=