LyogR1NTQVBJL2tyYjUgc3VwcG9ydCBmb3IgRlRQIC0gbG9vc2VseSBiYXNlZCBvbiBvbGQga3JiNC5jCiAqCiAqIENvcHlyaWdodCAoYykgMTk5NSwgMTk5NiwgMTk5NywgMTk5OCwgMTk5OSBLdW5nbGlnYSBUZWtuaXNrYSBI9mdza29sYW4KICogKFJveWFsIEluc3RpdHV0ZSBvZiBUZWNobm9sb2d5LCBTdG9ja2hvbG0sIFN3ZWRlbikuCiAqIENvcHlyaWdodCAoYykgMjAwNCAtIDIwMTYgRGFuaWVsIFN0ZW5iZXJnCiAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuCiAqCiAqIFJlZGlzdHJpYnV0aW9uIGFuZCB1c2UgaW4gc291cmNlIGFuZCBiaW5hcnkgZm9ybXMsIHdpdGggb3Igd2l0aG91dAogKiBtb2RpZmljYXRpb24sIGFyZSBwZXJtaXR0ZWQgcHJvdmlkZWQgdGhhdCB0aGUgZm9sbG93aW5nIGNvbmRpdGlvbnMKICogYXJlIG1ldDoKICoKICogMS4gUmVkaXN0cmlidXRpb25zIG9mIHNvdXJjZSBjb2RlIG11c3QgcmV0YWluIHRoZSBhYm92ZSBjb3B5cmlnaHQKICogICAgbm90aWNlLCB0aGlzIGxpc3Qgb2YgY29uZGl0aW9ucyBhbmQgdGhlIGZvbGxvd2luZyBkaXNjbGFpbWVyLgogKgogKiAyLiBSZWRpc3RyaWJ1dGlvbnMgaW4gYmluYXJ5IGZvcm0gbXVzdCByZXByb2R1Y2UgdGhlIGFib3ZlIGNvcHlyaWdodAogKiAgICBub3RpY2UsIHRoaXMgbGlzdCBvZiBjb25kaXRpb25zIGFuZCB0aGUgZm9sbG93aW5nIGRpc2NsYWltZXIgaW4gdGhlCiAqICAgIGRvY3VtZW50YXRpb24gYW5kL29yIG90aGVyIG1hdGVyaWFscyBwcm92aWRlZCB3aXRoIHRoZSBkaXN0cmlidXRpb24uCiAqCiAqIDMuIE5laXRoZXIgdGhlIG5hbWUgb2YgdGhlIEluc3RpdHV0ZSBub3IgdGhlIG5hbWVzIG9mIGl0cyBjb250cmlidXRvcnMKICogICAgbWF5IGJlIHVzZWQgdG8gZW5kb3JzZSBvciBwcm9tb3RlIHByb2R1Y3RzIGRlcml2ZWQgZnJvbSB0aGlzIHNvZnR3YXJlCiAqICAgIHdpdGhvdXQgc3BlY2lmaWMgcHJpb3Igd3JpdHRlbiBwZXJtaXNzaW9uLgogKgogKiBUSElTIFNPRlRXQVJFIElTIFBST1ZJREVEIEJZIFRIRSBJTlNUSVRVVEUgQU5EIENPTlRSSUJVVE9SUyBgYEFTIElTJycgQU5ECiAqIEFOWSBFWFBSRVNTIE9SIElNUExJRUQgV0FSUkFOVElFUywgSU5DTFVESU5HLCBCVVQgTk9UIExJTUlURUQgVE8sIFRIRQogKiBJTVBMSUVEIFdBUlJBTlRJRVMgT0YgTUVSQ0hBTlRBQklMSVRZIEFORCBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRQogKiBBUkUgRElTQ0xBSU1FRC4gIElOIE5PIEVWRU5UIFNIQUxMIFRIRSBJTlNUSVRVVEUgT1IgQ09OVFJJQlVUT1JTIEJFIExJQUJMRQogKiBGT1IgQU5ZIERJUkVDVCwgSU5ESVJFQ1QsIElOQ0lERU5UQUwsIFNQRUNJQUwsIEVYRU1QTEFSWSwgT1IgQ09OU0VRVUVOVElBTAogKiBEQU1BR0VTIChJTkNMVURJTkcsIEJVVCBOT1QgTElNSVRFRCBUTywgUFJPQ1VSRU1FTlQgT0YgU1VCU1RJVFVURSBHT09EUwogKiBPUiBTRVJWSUNFUzsgTE9TUyBPRiBVU0UsIERBVEEsIE9SIFBST0ZJVFM7IE9SIEJVU0lORVNTIElOVEVSUlVQVElPTikKICogSE9XRVZFUiBDQVVTRUQgQU5EIE9OIEFOWSBUSEVPUlkgT0YgTElBQklMSVRZLCBXSEVUSEVSIElOIENPTlRSQUNULCBTVFJJQ1QKICogTElBQklMSVRZLCBPUiBUT1JUIChJTkNMVURJTkcgTkVHTElHRU5DRSBPUiBPVEhFUldJU0UpIEFSSVNJTkcgSU4gQU5ZIFdBWQogKiBPVVQgT0YgVEhFIFVTRSBPRiBUSElTIFNPRlRXQVJFLCBFVkVOIElGIEFEVklTRUQgT0YgVEhFIFBPU1NJQklMSVRZIE9GCiAqIFNVQ0ggREFNQUdFLiAgKi8KCiNpbmNsdWRlICJjdXJsX3NldHVwLmgiCgojaWYgZGVmaW5lZChIQVZFX0dTU0FQSSkgJiYgIWRlZmluZWQoQ1VSTF9ESVNBQkxFX0ZUUCkKCiNpZmRlZiBIQVZFX05FVERCX0gKI2luY2x1ZGUgPG5ldGRiLmg+CiNlbmRpZgoKI2luY2x1ZGUgInVybGRhdGEuaCIKI2luY2x1ZGUgImN1cmxfYmFzZTY0LmgiCiNpbmNsdWRlICJmdHAuaCIKI2luY2x1ZGUgImN1cmxfZ3NzYXBpLmgiCiNpbmNsdWRlICJzZW5kZi5oIgojaW5jbHVkZSAiY3VybF9zZWMuaCIKI2luY2x1ZGUgIndhcm5sZXNzLmgiCgovKiBUaGUgbGFzdCAzICNpbmNsdWRlIGZpbGVzIHNob3VsZCBiZSBpbiB0aGlzIG9yZGVyICovCiNpbmNsdWRlICJjdXJsX3ByaW50Zi5oIgojaW5jbHVkZSAiY3VybF9tZW1vcnkuaCIKI2luY2x1ZGUgIm1lbWRlYnVnLmgiCgpzdGF0aWMgaW50CmtyYjVfaW5pdCh2b2lkICphcHBfZGF0YSkKewogIGdzc19jdHhfaWRfdCAqY29udGV4dCA9IGFwcF9kYXRhOwogIC8qIE1ha2Ugc3VyZSBvdXIgY29udGV4dCBpcyBpbml0aWFsaXplZCBmb3Iga3JiNV9lbmQuICovCiAgKmNvbnRleHQgPSBHU1NfQ19OT19DT05URVhUOwogIHJldHVybiAwOwp9CgpzdGF0aWMgaW50CmtyYjVfY2hlY2tfcHJvdCh2b2lkICphcHBfZGF0YSwgaW50IGxldmVsKQp7CiAgKHZvaWQpYXBwX2RhdGE7IC8qIHVudXNlZCAqLwogIGlmKGxldmVsID09IFBST1RfQ09ORklERU5USUFMKQogICAgcmV0dXJuIC0xOwogIHJldHVybiAwOwp9CgpzdGF0aWMgaW50CmtyYjVfZGVjb2RlKHZvaWQgKmFwcF9kYXRhLCB2b2lkICpidWYsIGludCBsZW4sCiAgICAgICAgICAgIGludCBsZXZlbCBVTlVTRURfUEFSQU0sCiAgICAgICAgICAgIHN0cnVjdCBjb25uZWN0ZGF0YSAqY29ubiBVTlVTRURfUEFSQU0pCnsKICBnc3NfY3R4X2lkX3QgKmNvbnRleHQgPSBhcHBfZGF0YTsKICBPTV91aW50MzIgbWFqLCBtaW47CiAgZ3NzX2J1ZmZlcl9kZXNjIGVuYywgZGVjOwoKICAodm9pZClsZXZlbDsKICAodm9pZCljb25uOwoKICBlbmMudmFsdWUgPSBidWY7CiAgZW5jLmxlbmd0aCA9IGxlbjsKICBtYWogPSBnc3NfdW5zZWFsKCZtaW4sICpjb250ZXh0LCAmZW5jLCAmZGVjLCBOVUxMLCBOVUxMKTsKICBpZihtYWogIT0gR1NTX1NfQ09NUExFVEUpIHsKICAgIGlmKGxlbiA+PSA0KQogICAgICBzdHJjcHkoYnVmLCAiNTk5ICIpOwogICAgcmV0dXJuIC0xOwogIH0KCiAgbWVtY3B5KGJ1ZiwgZGVjLnZhbHVlLCBkZWMubGVuZ3RoKTsKICBsZW4gPSBjdXJseF91enRvc2koZGVjLmxlbmd0aCk7CiAgZ3NzX3JlbGVhc2VfYnVmZmVyKCZtaW4sICZkZWMpOwoKICByZXR1cm4gbGVuOwp9CgpzdGF0aWMgaW50CmtyYjVfb3ZlcmhlYWQodm9pZCAqYXBwX2RhdGEsIGludCBsZXZlbCwgaW50IGxlbikKewogIC8qIG5vIGFyZ3VtZW50cyBhcmUgdXNlZCAqLwogICh2b2lkKWFwcF9kYXRhOwogICh2b2lkKWxldmVsOwogICh2b2lkKWxlbjsKICByZXR1cm4gMDsKfQoKc3RhdGljIGludAprcmI1X2VuY29kZSh2b2lkICphcHBfZGF0YSwgY29uc3Qgdm9pZCAqZnJvbSwgaW50IGxlbmd0aCwgaW50IGxldmVsLCB2b2lkICoqdG8pCnsKICBnc3NfY3R4X2lkX3QgKmNvbnRleHQgPSBhcHBfZGF0YTsKICBnc3NfYnVmZmVyX2Rlc2MgZGVjLCBlbmM7CiAgT01fdWludDMyIG1haiwgbWluOwogIGludCBzdGF0ZTsKICBpbnQgbGVuOwoKICAvKiBOT1RFIHRoYXQgdGhlIGNhc3QgaXMgc2FmZSwgbmVpdGhlciBvZiB0aGUga3JiNSwgZ251IGdzcyBhbmQgaGVpbWRhbAogICAqIGxpYnJhcmllcyBtb2RpZnkgdGhlIGlucHV0IGJ1ZmZlciBpbiBnc3Nfc2VhbCgpCiAgICovCiAgZGVjLnZhbHVlID0gKHZvaWQqKWZyb207CiAgZGVjLmxlbmd0aCA9IGxlbmd0aDsKICBtYWogPSBnc3Nfc2VhbCgmbWluLCAqY29udGV4dCwKICAgICAgICAgICAgICAgICBsZXZlbCA9PSBQUk9UX1BSSVZBVEUsCiAgICAgICAgICAgICAgICAgR1NTX0NfUU9QX0RFRkFVTFQsCiAgICAgICAgICAgICAgICAgJmRlYywgJnN0YXRlLCAmZW5jKTsKCiAgaWYobWFqICE9IEdTU19TX0NPTVBMRVRFKQogICAgcmV0dXJuIC0xOwoKICAvKiBtYWxsb2MgYSBuZXcgYnVmZmVyLCBpbiBjYXNlIGdzc19yZWxlYXNlX2J1ZmZlciBkb2Vzbid0IHdvcmsgYXMKICAgICBleHBlY3RlZCAqLwogICp0byA9IG1hbGxvYyhlbmMubGVuZ3RoKTsKICBpZighKnRvKQogICAgcmV0dXJuIC0xOwogIG1lbWNweSgqdG8sIGVuYy52YWx1ZSwgZW5jLmxlbmd0aCk7CiAgbGVuID0gY3VybHhfdXp0b3NpKGVuYy5sZW5ndGgpOwogIGdzc19yZWxlYXNlX2J1ZmZlcigmbWluLCAmZW5jKTsKICByZXR1cm4gbGVuOwp9CgpzdGF0aWMgaW50CmtyYjVfYXV0aCh2b2lkICphcHBfZGF0YSwgc3RydWN0IGNvbm5lY3RkYXRhICpjb25uKQp7CiAgaW50IHJldCA9IEFVVEhfT0s7CiAgY2hhciAqcDsKICBjb25zdCBjaGFyICpob3N0ID0gY29ubi0+aG9zdC5uYW1lOwogIHNzaXplX3QgbnJlYWQ7CiAgY3VybF9zb2NrbGVuX3QgbCA9IHNpemVvZihjb25uLT5sb2NhbF9hZGRyKTsKICBzdHJ1Y3QgQ3VybF9lYXN5ICpkYXRhID0gY29ubi0+ZGF0YTsKICBDVVJMY29kZSByZXN1bHQ7CiAgY29uc3QgY2hhciAqc2VydmljZSA9IGRhdGEtPnNldC5zdHJbU1RSSU5HX1NFUlZJQ0VfTkFNRV0gPwogICAgICAgICAgICAgICAgICAgICAgICBkYXRhLT5zZXQuc3RyW1NUUklOR19TRVJWSUNFX05BTUVdIDoKICAgICAgICAgICAgICAgICAgICAgICAgImZ0cCI7CiAgY29uc3QgY2hhciAqc3J2X2hvc3QgPSAiaG9zdCI7CiAgZ3NzX2J1ZmZlcl9kZXNjIGlucHV0X2J1ZmZlciwgb3V0cHV0X2J1ZmZlciwgX2dzc3Jlc3AsICpnc3NyZXNwOwogIE9NX3VpbnQzMiBtYWosIG1pbjsKICBnc3NfbmFtZV90IGdzc25hbWU7CiAgZ3NzX2N0eF9pZF90ICpjb250ZXh0ID0gYXBwX2RhdGE7CiAgc3RydWN0IGdzc19jaGFubmVsX2JpbmRpbmdzX3N0cnVjdCBjaGFuOwogIHNpemVfdCBiYXNlNjRfc3ogPSAwOwogIHN0cnVjdCBzb2NrYWRkcl9pbiAqKnJlbW90ZV9hZGRyID0KICAgIChzdHJ1Y3Qgc29ja2FkZHJfaW4gKiopJmNvbm4tPmlwX2FkZHItPmFpX2FkZHI7CgogIGlmKGdldHNvY2tuYW1lKGNvbm4tPnNvY2tbRklSU1RTT0NLRVRdLAogICAgICAgICAgICAgICAgIChzdHJ1Y3Qgc29ja2FkZHIgKikmY29ubi0+bG9jYWxfYWRkciwgJmwpIDwgMCkKICAgIHBlcnJvcigiZ2V0c29ja25hbWUoKSIpOwoKICBjaGFuLmluaXRpYXRvcl9hZGRydHlwZSA9IEdTU19DX0FGX0lORVQ7CiAgY2hhbi5pbml0aWF0b3JfYWRkcmVzcy5sZW5ndGggPSBsIC0gNDsKICBjaGFuLmluaXRpYXRvcl9hZGRyZXNzLnZhbHVlID0gJmNvbm4tPmxvY2FsX2FkZHIuc2luX2FkZHIuc19hZGRyOwogIGNoYW4uYWNjZXB0b3JfYWRkcnR5cGUgPSBHU1NfQ19BRl9JTkVUOwogIGNoYW4uYWNjZXB0b3JfYWRkcmVzcy5sZW5ndGggPSBsIC0gNDsKICBjaGFuLmFjY2VwdG9yX2FkZHJlc3MudmFsdWUgPSAmKCpyZW1vdGVfYWRkciktPnNpbl9hZGRyLnNfYWRkcjsKICBjaGFuLmFwcGxpY2F0aW9uX2RhdGEubGVuZ3RoID0gMDsKICBjaGFuLmFwcGxpY2F0aW9uX2RhdGEudmFsdWUgPSBOVUxMOwoKICAvKiB0aGlzIGxvb3Agd2lsbCBleGVjdXRlIHR3aWNlIChvbmNlIGZvciBzZXJ2aWNlLCBvbmNlIGZvciBob3N0KSAqLwogIGZvcig7OykgewogICAgLyogdGhpcyByZWFsbHkgc2hvdWxkbid0IGJlIHJlcGVhdGVkIGhlcmUsIGJ1dCBjYW4ndCBoZWxwIGl0ICovCiAgICBpZihzZXJ2aWNlID09IHNydl9ob3N0KSB7CiAgICAgIHJlc3VsdCA9IEN1cmxfZnRwc2VuZGYoY29ubiwgIkFVVEggR1NTQVBJIik7CiAgICAgIGlmKHJlc3VsdCkKICAgICAgICByZXR1cm4gLTI7CgogICAgICBpZihDdXJsX0dldEZUUFJlc3BvbnNlKCZucmVhZCwgY29ubiwgTlVMTCkpCiAgICAgICAgcmV0dXJuIC0xOwoKICAgICAgaWYoZGF0YS0+c3RhdGUuYnVmZmVyWzBdICE9ICczJykKICAgICAgICByZXR1cm4gLTE7CiAgICB9CgogICAgaW5wdXRfYnVmZmVyLnZhbHVlID0gZGF0YS0+c3RhdGUuYnVmZmVyOwogICAgaW5wdXRfYnVmZmVyLmxlbmd0aCA9IHNucHJpbnRmKGlucHV0X2J1ZmZlci52YWx1ZSwgQlVGU0laRSwgIiVzQCVzIiwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBzZXJ2aWNlLCBob3N0KTsKICAgIG1haiA9IGdzc19pbXBvcnRfbmFtZSgmbWluLCAmaW5wdXRfYnVmZmVyLCBHU1NfQ19OVF9IT1NUQkFTRURfU0VSVklDRSwKICAgICAgICAgICAgICAgICAgICAgICAgICAmZ3NzbmFtZSk7CiAgICBpZihtYWogIT0gR1NTX1NfQ09NUExFVEUpIHsKICAgICAgZ3NzX3JlbGVhc2VfbmFtZSgmbWluLCAmZ3NzbmFtZSk7CiAgICAgIGlmKHNlcnZpY2UgPT0gc3J2X2hvc3QpIHsKICAgICAgICBDdXJsX2ZhaWxmKGRhdGEsICJFcnJvciBpbXBvcnRpbmcgc2VydmljZSBuYW1lICVzIiwKICAgICAgICAgICAgICAgICAgIGlucHV0X2J1ZmZlci52YWx1ZSk7CiAgICAgICAgcmV0dXJuIEFVVEhfRVJST1I7CiAgICAgIH0KICAgICAgc2VydmljZSA9IHNydl9ob3N0OwogICAgICBjb250aW51ZTsKICAgIH0KICAgIC8qIFdlIHBhc3MgTlVMTCBhcyB8b3V0cHV0X25hbWVfdHlwZXwgdG8gYXZvaWQgYSBsZWFrLiAqLwogICAgZ3NzX2Rpc3BsYXlfbmFtZSgmbWluLCBnc3NuYW1lLCAmb3V0cHV0X2J1ZmZlciwgTlVMTCk7CiAgICBDdXJsX2luZm9mKGRhdGEsICJUcnlpbmcgYWdhaW5zdCAlc1xuIiwgb3V0cHV0X2J1ZmZlci52YWx1ZSk7CiAgICBnc3NyZXNwID0gR1NTX0NfTk9fQlVGRkVSOwogICAgKmNvbnRleHQgPSBHU1NfQ19OT19DT05URVhUOwoKICAgIGRvIHsKICAgICAgLyogUmVsZWFzZSB0aGUgYnVmZmVyIGF0IGVhY2ggaXRlcmF0aW9uIHRvIGF2b2lkIGxlYWtpbmc6IHRoZSBmaXJzdCB0aW1lCiAgICAgICAgIHdlIGFyZSByZWxlYXNpbmcgdGhlIG1lbW9yeSBmcm9tIGdzc19kaXNwbGF5X25hbWUuIFRoZSBsYXN0IGl0ZW0gaXMKICAgICAgICAgdGFrZW4gY2FyZSBieSBhIGZpbmFsIGdzc19yZWxlYXNlX2J1ZmZlci4gKi8KICAgICAgZ3NzX3JlbGVhc2VfYnVmZmVyKCZtaW4sICZvdXRwdXRfYnVmZmVyKTsKICAgICAgcmV0ID0gQVVUSF9PSzsKICAgICAgbWFqID0gQ3VybF9nc3NfaW5pdF9zZWNfY29udGV4dChkYXRhLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICZtaW4sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgY29udGV4dCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBnc3NuYW1lLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICZDdXJsX2tyYjVfbWVjaF9vaWQsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJmNoYW4sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZ3NzcmVzcCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAmb3V0cHV0X2J1ZmZlciwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBUUlVFLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5VTEwpOwoKICAgICAgaWYoZ3NzcmVzcCkgewogICAgICAgIGZyZWUoX2dzc3Jlc3AudmFsdWUpOwogICAgICAgIGdzc3Jlc3AgPSBOVUxMOwogICAgICB9CgogICAgICBpZihHU1NfRVJST1IobWFqKSkgewogICAgICAgIEN1cmxfaW5mb2YoZGF0YSwgIkVycm9yIGNyZWF0aW5nIHNlY3VyaXR5IGNvbnRleHRcbiIpOwogICAgICAgIHJldCA9IEFVVEhfRVJST1I7CiAgICAgICAgYnJlYWs7CiAgICAgIH0KCiAgICAgIGlmKG91dHB1dF9idWZmZXIubGVuZ3RoICE9IDApIHsKICAgICAgICByZXN1bHQgPSBDdXJsX2Jhc2U2NF9lbmNvZGUoZGF0YSwgKGNoYXIgKilvdXRwdXRfYnVmZmVyLnZhbHVlLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBvdXRwdXRfYnVmZmVyLmxlbmd0aCwgJnAsICZiYXNlNjRfc3opOwogICAgICAgIGlmKHJlc3VsdCkgewogICAgICAgICAgQ3VybF9pbmZvZihkYXRhLCAiYmFzZTY0LWVuY29kaW5nOiAlc1xuIiwKICAgICAgICAgICAgICAgICAgICAgY3VybF9lYXN5X3N0cmVycm9yKHJlc3VsdCkpOwogICAgICAgICAgcmV0ID0gQVVUSF9DT05USU5VRTsKICAgICAgICAgIGJyZWFrOwogICAgICAgIH0KCiAgICAgICAgcmVzdWx0ID0gQ3VybF9mdHBzZW5kZihjb25uLCAiQURBVCAlcyIsIHApOwoKICAgICAgICBmcmVlKHApOwoKICAgICAgICBpZihyZXN1bHQpIHsKICAgICAgICAgIHJldCA9IC0yOwogICAgICAgICAgYnJlYWs7CiAgICAgICAgfQoKICAgICAgICBpZihDdXJsX0dldEZUUFJlc3BvbnNlKCZucmVhZCwgY29ubiwgTlVMTCkpIHsKICAgICAgICAgIHJldCA9IC0xOwogICAgICAgICAgYnJlYWs7CiAgICAgICAgfQoKICAgICAgICBpZihkYXRhLT5zdGF0ZS5idWZmZXJbMF0gIT0gJzInICYmIGRhdGEtPnN0YXRlLmJ1ZmZlclswXSAhPSAnMycpIHsKICAgICAgICAgIEN1cmxfaW5mb2YoZGF0YSwgIlNlcnZlciBkaWRuJ3QgYWNjZXB0IGF1dGggZGF0YVxuIik7CiAgICAgICAgICByZXQgPSBBVVRIX0VSUk9SOwogICAgICAgICAgYnJlYWs7CiAgICAgICAgfQoKICAgICAgICBwID0gZGF0YS0+c3RhdGUuYnVmZmVyICsgNDsKICAgICAgICBwID0gc3Ryc3RyKHAsICJBREFUPSIpOwogICAgICAgIGlmKHApIHsKICAgICAgICAgIHJlc3VsdCA9IEN1cmxfYmFzZTY0X2RlY29kZShwICsgNSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAodW5zaWduZWQgY2hhciAqKikmX2dzc3Jlc3AudmFsdWUsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgJl9nc3NyZXNwLmxlbmd0aCk7CiAgICAgICAgICBpZihyZXN1bHQpIHsKICAgICAgICAgICAgQ3VybF9mYWlsZihkYXRhLCAiYmFzZTY0LWRlY29kaW5nOiAlcyIsCiAgICAgICAgICAgICAgICAgICAgICAgY3VybF9lYXN5X3N0cmVycm9yKHJlc3VsdCkpOwogICAgICAgICAgICByZXQgPSBBVVRIX0NPTlRJTlVFOwogICAgICAgICAgICBicmVhazsKICAgICAgICAgIH0KICAgICAgICB9CgogICAgICAgIGdzc3Jlc3AgPSAmX2dzc3Jlc3A7CiAgICAgIH0KICAgIH0gd2hpbGUobWFqID09IEdTU19TX0NPTlRJTlVFX05FRURFRCk7CgogICAgZ3NzX3JlbGVhc2VfbmFtZSgmbWluLCAmZ3NzbmFtZSk7CiAgICBnc3NfcmVsZWFzZV9idWZmZXIoJm1pbiwgJm91dHB1dF9idWZmZXIpOwoKICAgIGlmKGdzc3Jlc3ApCiAgICAgIGZyZWUoX2dzc3Jlc3AudmFsdWUpOwoKICAgIGlmKHJldCA9PSBBVVRIX09LIHx8IHNlcnZpY2UgPT0gc3J2X2hvc3QpCiAgICAgIHJldHVybiByZXQ7CgogICAgc2VydmljZSA9IHNydl9ob3N0OwogIH0KICByZXR1cm4gcmV0Owp9CgpzdGF0aWMgdm9pZCBrcmI1X2VuZCh2b2lkICphcHBfZGF0YSkKewogICAgT01fdWludDMyIG1pbjsKICAgIGdzc19jdHhfaWRfdCAqY29udGV4dCA9IGFwcF9kYXRhOwogICAgaWYoKmNvbnRleHQgIT0gR1NTX0NfTk9fQ09OVEVYVCkgewojaWZkZWYgREVCVUdCVUlMRAogICAgICBPTV91aW50MzIgbWFqID0KI2VuZGlmCiAgICAgIGdzc19kZWxldGVfc2VjX2NvbnRleHQoJm1pbiwgY29udGV4dCwgR1NTX0NfTk9fQlVGRkVSKTsKICAgICAgREVCVUdBU1NFUlQobWFqID09IEdTU19TX0NPTVBMRVRFKTsKICAgIH0KfQoKc3RydWN0IEN1cmxfc2VjX2NsaWVudF9tZWNoIEN1cmxfa3JiNV9jbGllbnRfbWVjaCA9IHsKICAgICJHU1NBUEkiLAogICAgc2l6ZW9mKGdzc19jdHhfaWRfdCksCiAgICBrcmI1X2luaXQsCiAgICBrcmI1X2F1dGgsCiAgICBrcmI1X2VuZCwKICAgIGtyYjVfY2hlY2tfcHJvdCwKICAgIGtyYjVfb3ZlcmhlYWQsCiAgICBrcmI1X2VuY29kZSwKICAgIGtyYjVfZGVjb2RlCn07CgojZW5kaWYgLyogSEFWRV9HU1NBUEkgJiYgIUNVUkxfRElTQUJMRV9GVFAgKi8K