LyoKICogIGFzdXNfYWNwaS5jIC0gQXN1cyBMYXB0b3AgQUNQSSBFeHRyYXMKICoKICoKICogIENvcHlyaWdodCAoQykgMjAwMi0yMDA1IEp1bGllbiBMZXJvdWdlLCAyMDAzLTIwMDYgS2Fyb2wgS296aW1vcgogKgogKiAgVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vciBtb2RpZnkKICogIGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5CiAqICB0aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uOyBlaXRoZXIgdmVyc2lvbiAyIG9mIHRoZSBMaWNlbnNlLCBvcgogKiAgKGF0IHlvdXIgb3B0aW9uKSBhbnkgbGF0ZXIgdmVyc2lvbi4KICoKICogIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLAogKiAgYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKICogIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gIFNlZSB0aGUKICogIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvciBtb3JlIGRldGFpbHMuCiAqCiAqICBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZQogKiAgYWxvbmcgd2l0aCB0aGlzIHByb2dyYW07IGlmIG5vdCwgd3JpdGUgdG8gdGhlIEZyZWUgU29mdHdhcmUKICogIEZvdW5kYXRpb24sIEluYy4sIDU5IFRlbXBsZSBQbGFjZSwgU3VpdGUgMzMwLCBCb3N0b24sIE1BICAwMjExMS0xMzA3ICBVU0EKICoKICoKICogIFRoZSBkZXZlbG9wbWVudCBwYWdlIGZvciB0aGlzIGRyaXZlciBpcyBsb2NhdGVkIGF0CiAqICBodHRwOi8vc291cmNlZm9yZ2UubmV0L3Byb2plY3RzL2FjcGk0YXN1cy8KICoKICogIENyZWRpdHM6CiAqICBQb250dXMgRnVjaHMgICAtIEhlbHBlciBmdW5jdGlvbnMsIGNsZWFudXAKICogIEpvaGFubiBXaWVzbmVyIC0gU21hbGwgY29tcGlsZSBmaXhlcwogKiAgSm9obiBCZWxtb250ZSAgLSBBQ1BJIGNvZGUgZm9yIFRvc2hpYmEgbGFwdG9wIHdhcyBhIGdvb2Qgc3RhcnRpbmcgcG9pbnQuCiAqICDJcmljIEJ1cmdoYXJkICAtIExFRCBkaXNwbGF5IHN1cHBvcnQgZm9yIFcxTgogKgogKi8KCiNpbmNsdWRlIDxsaW51eC9rZXJuZWwuaD4KI2luY2x1ZGUgPGxpbnV4L21vZHVsZS5oPgojaW5jbHVkZSA8bGludXgvaW5pdC5oPgojaW5jbHVkZSA8bGludXgvdHlwZXMuaD4KI2luY2x1ZGUgPGxpbnV4L3Byb2NfZnMuaD4KI2luY2x1ZGUgPGFjcGkvYWNwaV9kcml2ZXJzLmg+CiNpbmNsdWRlIDxhY3BpL2FjcGlfYnVzLmg+CiNpbmNsdWRlIDxhc20vdWFjY2Vzcy5oPgoKI2RlZmluZSBBU1VTX0FDUElfVkVSU0lPTiAiMC4zMCIKCiNkZWZpbmUgUFJPQ19BU1VTICAgICAgICJhc3VzIgkvL3RoZSBkaXJlY3RvcnkKI2RlZmluZSBQUk9DX01MRUQgICAgICAgIm1sZWQiCiNkZWZpbmUgUFJPQ19XTEVEICAgICAgICJ3bGVkIgojZGVmaW5lIFBST0NfVExFRCAgICAgICAidGxlZCIKI2RlZmluZSBQUk9DX0JUICAgICAgICAgImJsdWV0b290aCIKI2RlZmluZSBQUk9DX0xFREQgICAgICAgImxlZGQiCiNkZWZpbmUgUFJPQ19JTkZPICAgICAgICJpbmZvIgojZGVmaW5lIFBST0NfTENEICAgICAgICAibGNkIgojZGVmaW5lIFBST0NfQlJOICAgICAgICAiYnJuIgojZGVmaW5lIFBST0NfRElTUCAgICAgICAiZGlzcCIKCiNkZWZpbmUgQUNQSV9IT1RLX05BTUUgICAgICAgICAgIkFzdXMgTGFwdG9wIEFDUEkgRXh0cmFzIERyaXZlciIKI2RlZmluZSBBQ1BJX0hPVEtfQ0xBU1MgICAgICAgICAiaG90a2V5IgojZGVmaW5lIEFDUElfSE9US19ERVZJQ0VfTkFNRSAgICJIb3RrZXkiCiNkZWZpbmUgQUNQSV9IT1RLX0hJRCAgICAgICAgICAgIkFUSzAxMDAiCgovKgogKiBTb21lIGV2ZW50cyB3ZSB1c2UsIHNhbWUgZm9yIGFsbCBBc3VzCiAqLwojZGVmaW5lIEJSX1VQICAgICAgIDB4MTAKI2RlZmluZSBCUl9ET1dOICAgICAweDIwCgovKgogKiBGbGFncyBmb3IgaG90ayBzdGF0dXMKICovCiNkZWZpbmUgTUxFRF9PTiAgICAgMHgwMQkvL21haWwgTEVECiNkZWZpbmUgV0xFRF9PTiAgICAgMHgwMgkvL3dpcmVsZXNzIExFRAojZGVmaW5lIFRMRURfT04gICAgIDB4MDQJLy90b3VjaHBhZCBMRUQKI2RlZmluZSBCVF9PTiAgICAgICAweDA4CS8vaW50ZXJuYWwgQmx1ZXRvb3RoCgpNT0RVTEVfQVVUSE9SKCJKdWxpZW4gTGVyb3VnZSwgS2Fyb2wgS296aW1vciIpOwpNT0RVTEVfREVTQ1JJUFRJT04oQUNQSV9IT1RLX05BTUUpOwpNT0RVTEVfTElDRU5TRSgiR1BMIik7CgpzdGF0aWMgdWlkX3QgYXN1c191aWQ7CnN0YXRpYyBnaWRfdCBhc3VzX2dpZDsKbW9kdWxlX3BhcmFtKGFzdXNfdWlkLCB1aW50LCAwKTsKTU9EVUxFX1BBUk1fREVTQyhhc3VzX3VpZCwgIlVJRCBmb3IgZW50cmllcyBpbiAvcHJvYy9hY3BpL2FzdXMuXG4iKTsKbW9kdWxlX3BhcmFtKGFzdXNfZ2lkLCB1aW50LCAwKTsKTU9EVUxFX1BBUk1fREVTQyhhc3VzX2dpZCwgIkdJRCBmb3IgZW50cmllcyBpbiAvcHJvYy9hY3BpL2FzdXMuXG4iKTsKCi8qIEZvciBlYWNoIG1vZGVsLCBhbGwgZmVhdHVyZXMgaW1wbGVtZW50ZWQsIAogKiB0aG9zZSBtYXJrZWQgd2l0aCBSIGFyZSByZWxhdGl2ZSB0byBIT1RLLCBBIGZvciBhYnNvbHV0ZSAqLwpzdHJ1Y3QgbW9kZWxfZGF0YSB7CgljaGFyICpuYW1lOwkJLy9uYW1lIG9mIHRoZSBsYXB0b3BfX19fX19fX19fX19fX19fQQoJY2hhciAqbXRfbWxlZDsJCS8vbWV0aG9kIHRvIGhhbmRsZSBtbGVkX19fX19fX19fX19fX1IKCWNoYXIgKm1sZWRfc3RhdHVzOwkvL25vZGUgdG8gaGFuZGxlIG1sZWQgcmVhZGluZ19fX19fX19BCgljaGFyICptdF93bGVkOwkJLy9tZXRob2QgdG8gaGFuZGxlIHdsZWRfX19fX19fX19fX19fUgoJY2hhciAqd2xlZF9zdGF0dXM7CS8vbm9kZSB0byBoYW5kbGUgd2xlZCByZWFkaW5nX19fX19fX0EKCWNoYXIgKm10X3RsZWQ7CQkvL21ldGhvZCB0byBoYW5kbGUgdGxlZF9fX19fX19fX19fX19SCgljaGFyICp0bGVkX3N0YXR1czsJLy9ub2RlIHRvIGhhbmRsZSB0bGVkIHJlYWRpbmdfX19fX19fQQoJY2hhciAqbXRfbGVkZDsJCS8vbWV0aG9kIHRvIGhhbmRsZSBMRUQgZGlzcGxheV9fX19fX1IKCWNoYXIgKm10X2J0X3N3aXRjaDsJLy9tZXRob2QgdG8gc3dpdGNoIEJsdWV0b290aCBvbi9vZmZfUgoJY2hhciAqYnRfc3RhdHVzOwkvL25vIG1vZGVsIGN1cnJlbnRseSBzdXBwb3J0cyB0aGlzX18/CgljaGFyICptdF9sY2Rfc3dpdGNoOwkvL21ldGhvZCB0byB0dXJuIExDRCBvbi9vZmZfX19fX19fX19BCgljaGFyICpsY2Rfc3RhdHVzOwkvL25vZGUgdG8gcmVhZCBMQ0QgcGFuZWwgc3RhdGVfX19fX19BCgljaGFyICpicmlnaHRuZXNzX3VwOwkvL21ldGhvZCB0byBzZXQgYnJpZ2h0bmVzcyB1cF9fX19fX19BCgljaGFyICpicmlnaHRuZXNzX2Rvd247CS8vZ3Vlc3Mgd2hhdCA/X19fX19fX19fX19fX19fX19fX19fX0EKCWNoYXIgKmJyaWdodG5lc3Nfc2V0OwkvL21ldGhvZCB0byBzZXQgYWJzb2x1dGUgYnJpZ2h0bmVzc19SCgljaGFyICpicmlnaHRuZXNzX2dldDsJLy9tZXRob2QgdG8gZ2V0IGFic29sdXRlIGJyaWdodG5lc3NfUgoJY2hhciAqYnJpZ2h0bmVzc19zdGF0dXM7CS8vbm9kZSB0byBnZXQgYnJpZ2h0bmVzc19fX19fX19fX19fX0EKCWNoYXIgKmRpc3BsYXlfc2V0OwkvL21ldGhvZCB0byBzZXQgdmlkZW8gb3V0cHV0X19fX19fX19SCgljaGFyICpkaXNwbGF5X2dldDsJLy9tZXRob2QgdG8gZ2V0IHZpZGVvIG91dHB1dF9fX19fX19fUgp9OwoKLyoKICogVGhpcyBpcyB0aGUgbWFpbiBzdHJ1Y3R1cmUsIHdlIGNhbiB1c2UgaXQgdG8gc3RvcmUgYW55dGhpbmcgaW50ZXJlc3RpbmcKICogYWJvdXQgdGhlIGhvdGsgZGV2aWNlCiAqLwpzdHJ1Y3QgYXN1c19ob3RrIHsKCXN0cnVjdCBhY3BpX2RldmljZSAqZGV2aWNlOwkvL3RoZSBkZXZpY2Ugd2UgYXJlIGluCglhY3BpX2hhbmRsZSBoYW5kbGU7CS8vdGhlIGhhbmRsZSBvZiB0aGUgaG90ayBkZXZpY2UKCWNoYXIgc3RhdHVzOwkJLy9zdGF0dXMgb2YgdGhlIGhvdGssIGZvciBMRURzLCAuLi4KCXUzMiBsZWRkX3N0YXR1czsJLy9zdGF0dXMgb2YgdGhlIExFRCBkaXNwbGF5CglzdHJ1Y3QgbW9kZWxfZGF0YSAqbWV0aG9kczsJLy9tZXRob2RzIGF2YWlsYWJsZSBvbiB0aGUgbGFwdG9wCgl1OCBicmlnaHRuZXNzOwkJLy9icmlnaHRuZXNzIGxldmVsCgllbnVtIHsKCQlBMXggPSAwLAkvL0ExMzQwRCwgQTEzMDBGCgkJQTJ4LAkJLy9BMjUwMEgKCQlBNEcsCQkvL0E0NzAwRwoJCUQxeCwJCS8vRDEKCQlMMkQsCQkvL0wyMDAwRAoJCUwzQywJCS8vTDM4MDBDCgkJTDNELAkJLy9MMzQwMEQKCQlMM0gsCQkvL0wzSCwgTDIwMDBFLCBMNUQKCQlMNFIsCQkvL0w0NTAwUgoJCUw1eCwJCS8vTDU4MDBDIAoJCUw4TCwJCS8vTDg0MDBMCgkJTTFBLAkJLy9NMTMwMEEKCQlNMkUsCQkvL00yNDAwRSwgTDQ0MDBMCgkJTTZOLAkJLy9NNjgwME4sIFczNDAwTgoJCU02UiwJCS8vTTY3MDBSLCBBMzAwMEcKCQlQMzAsCQkvL1NhbXN1bmcgUDMwCgkJUzF4LAkJLy9TMTMwMEEsIGJ1dCBhbHNvIEwxNDAwQiBhbmQgTTI0MDBBIChMODRGKQoJCVMyeCwJCS8vUzIwMCAoSjEgcmVwb3J0ZWQpLCBWaWN0b3IgTVAtWFA3MjEwCgkJVzFOLAkJLy9XMTAwME4KCQlXNUEsCQkvL1c1QQoJCVczViwgICAgICAgICAgICAvL1czMDMwVgoJCXh4TiwJCS8vTTI0MDBOLCBNMzcwME4sIE01MjAwTiwgTTY4MDBOLCBTMTMwME4sIFM1MjAwTgoJCS8vKENlbnRyaW5vKQoJCUVORF9NT0RFTAoJfSBtb2RlbDsJCS8vTW9kZWxzIGN1cnJlbnRseSBzdXBwb3J0ZWQKCXUxNiBldmVudF9jb3VudFsxMjhdOwkvL2NvdW50IGZvciBlYWNoIGV2ZW50IFRPRE8gbWFrZSB0aGlzIGJldHRlcgp9OwoKLyogSGVyZSB3ZSBnbyAqLwojZGVmaW5lIEExeF9QUkVGSVggIlxcX1NCLlBDSTAuSVNBLkVDMC4iCiNkZWZpbmUgTDNDX1BSRUZJWCAiXFxfU0IuUENJMC5QWDQwLkVDRDAuIgojZGVmaW5lIE0xQV9QUkVGSVggIlxcX1NCLlBDSTAuUFg0MC5FQzAuIgojZGVmaW5lIFAzMF9QUkVGSVggIlxcX1NCLlBDSTAuTFBDQi5FQzAuIgojZGVmaW5lIFMxeF9QUkVGSVggIlxcX1NCLlBDSTAuUFg0MC4iCiNkZWZpbmUgUzJ4X1BSRUZJWCBBMXhfUFJFRklYCiNkZWZpbmUgeHhOX1BSRUZJWCAiXFxfU0IuUENJMC5TQlJHLkVDMC4iCgpzdGF0aWMgc3RydWN0IG1vZGVsX2RhdGEgbW9kZWxfY29uZltFTkRfTU9ERUxdID0gewoJLyoKCSAqIFRPRE8gSSBoYXZlIHNlZW4gYSBTV0JYIGFuZCBBSUJYIG1ldGhvZCBvbiBzb21lIG1vZGVscywgbGlrZSBMMTQwMEIsCgkgKiBpdCBzZWVtcyB0byBiZSBhIGtpbmQgb2Ygc3dpdGNoLCBidXQgd2hhdCBmb3IgPwoJICovCgoJewoJIC5uYW1lID0gIkExeCIsCgkgLm10X21sZWQgPSAiTUxFRCIsCgkgLm1sZWRfc3RhdHVzID0gIlxcTUFJTCIsCgkgLm10X2xjZF9zd2l0Y2ggPSBBMXhfUFJFRklYICJfUTEwIiwKCSAubGNkX3N0YXR1cyA9ICJcXEJLTEkiLAoJIC5icmlnaHRuZXNzX3VwID0gQTF4X1BSRUZJWCAiX1EwRSIsCgkgLmJyaWdodG5lc3NfZG93biA9IEExeF9QUkVGSVggIl9RMEYifSwKCgl7CgkgLm5hbWUgPSAiQTJ4IiwKCSAubXRfbWxlZCA9ICJNTEVEIiwKCSAubXRfd2xlZCA9ICJXTEVEIiwKCSAud2xlZF9zdGF0dXMgPSAiXFxTRzY2IiwKCSAubXRfbGNkX3N3aXRjaCA9ICJcXFExMCIsCgkgLmxjZF9zdGF0dXMgPSAiXFxCQU9GIiwKCSAuYnJpZ2h0bmVzc19zZXQgPSAiU1BMViIsCgkgLmJyaWdodG5lc3NfZ2V0ID0gIkdQTFYiLAoJIC5kaXNwbGF5X3NldCA9ICJTRFNQIiwKCSAuZGlzcGxheV9nZXQgPSAiXFxJTkZCIn0sCgoJewoJIC5uYW1lID0gIkE0RyIsCgkgLm10X21sZWQgPSAiTUxFRCIsCi8qIFdMRUQgcHJlc2VudCwgYnV0IG5vdCBjb250cm9sbGVkIGJ5IEFDUEkgKi8KCSAubXRfbGNkX3N3aXRjaCA9IHh4Tl9QUkVGSVggIl9RMTAiLAoJIC5icmlnaHRuZXNzX3NldCA9ICJTUExWIiwKCSAuYnJpZ2h0bmVzc19nZXQgPSAiR1BMViIsCgkgLmRpc3BsYXlfc2V0ID0gIlNEU1AiLAoJIC5kaXNwbGF5X2dldCA9ICJcXEFEVkcifSwKCgl7CgkgLm5hbWUgPSAiRDF4IiwKCSAubXRfbWxlZCA9ICJNTEVEIiwKCSAubXRfbGNkX3N3aXRjaCA9ICJcXFEwRCIsCgkgLmxjZF9zdGF0dXMgPSAiXFxHUDExIiwKCSAuYnJpZ2h0bmVzc191cCA9ICJcXFEwQyIsCgkgLmJyaWdodG5lc3NfZG93biA9ICJcXFEwQiIsCgkgLmJyaWdodG5lc3Nfc3RhdHVzID0gIlxcQkxWTCIsCgkgLmRpc3BsYXlfc2V0ID0gIlNEU1AiLAoJIC5kaXNwbGF5X2dldCA9ICJcXElORkIifSwKCgl7CgkgLm5hbWUgPSAiTDJEIiwKCSAubXRfbWxlZCA9ICJNTEVEIiwKCSAubWxlZF9zdGF0dXMgPSAiXFxTR1A2IiwKCSAubXRfd2xlZCA9ICJXTEVEIiwKCSAud2xlZF9zdGF0dXMgPSAiXFxSQ1AzIiwKCSAubXRfbGNkX3N3aXRjaCA9ICJcXFExMCIsCgkgLmxjZF9zdGF0dXMgPSAiXFxTR1AwIiwKCSAuYnJpZ2h0bmVzc191cCA9ICJcXFEwRSIsCgkgLmJyaWdodG5lc3NfZG93biA9ICJcXFEwRiIsCgkgLmRpc3BsYXlfc2V0ID0gIlNEU1AiLAoJIC5kaXNwbGF5X2dldCA9ICJcXElORkIifSwKCgl7CgkgLm5hbWUgPSAiTDNDIiwKCSAubXRfbWxlZCA9ICJNTEVEIiwKCSAubXRfd2xlZCA9ICJXTEVEIiwKCSAubXRfbGNkX3N3aXRjaCA9IEwzQ19QUkVGSVggIl9RMTAiLAoJIC5sY2Rfc3RhdHVzID0gIlxcR0wzMiIsCgkgLmJyaWdodG5lc3Nfc2V0ID0gIlNQTFYiLAoJIC5icmlnaHRuZXNzX2dldCA9ICJHUExWIiwKCSAuZGlzcGxheV9zZXQgPSAiU0RTUCIsCgkgLmRpc3BsYXlfZ2V0ID0gIlxcX1NCLlBDSTAuUENJMS5WR0FDLk5NQVAifSwKCgl7CgkgLm5hbWUgPSAiTDNEIiwKCSAubXRfbWxlZCA9ICJNTEVEIiwKCSAubWxlZF9zdGF0dXMgPSAiXFxNQUxEIiwKCSAubXRfd2xlZCA9ICJXTEVEIiwKCSAubXRfbGNkX3N3aXRjaCA9ICJcXFExMCIsCgkgLmxjZF9zdGF0dXMgPSAiXFxCS0xHIiwKCSAuYnJpZ2h0bmVzc19zZXQgPSAiU1BMViIsCgkgLmJyaWdodG5lc3NfZ2V0ID0gIkdQTFYiLAoJIC5kaXNwbGF5X3NldCA9ICJTRFNQIiwKCSAuZGlzcGxheV9nZXQgPSAiXFxJTkZCIn0sCgoJewoJIC5uYW1lID0gIkwzSCIsCgkgLm10X21sZWQgPSAiTUxFRCIsCgkgLm10X3dsZWQgPSAiV0xFRCIsCgkgLm10X2xjZF9zd2l0Y2ggPSAiRUhLIiwKCSAubGNkX3N0YXR1cyA9ICJcXF9TQi5QQ0kwLlBNLlBCQyIsCgkgLmJyaWdodG5lc3Nfc2V0ID0gIlNQTFYiLAoJIC5icmlnaHRuZXNzX2dldCA9ICJHUExWIiwKCSAuZGlzcGxheV9zZXQgPSAiU0RTUCIsCgkgLmRpc3BsYXlfZ2V0ID0gIlxcSU5GQiJ9LAoKCXsKCSAubmFtZSA9ICJMNFIiLAoJIC5tdF9tbGVkID0gIk1MRUQiLAoJIC5tdF93bGVkID0gIldMRUQiLAoJIC53bGVkX3N0YXR1cyA9ICJcXF9TQi5QQ0kwLlNCUkcuU0cxMyIsCgkgLm10X2xjZF9zd2l0Y2ggPSB4eE5fUFJFRklYICJfUTEwIiwKCSAubGNkX3N0YXR1cyA9ICJcXF9TQi5QQ0kwLlNCU00uU0VPNCIsCgkgLmJyaWdodG5lc3Nfc2V0ID0gIlNQTFYiLAoJIC5icmlnaHRuZXNzX2dldCA9ICJHUExWIiwKCSAuZGlzcGxheV9zZXQgPSAiU0RTUCIsCgkgLmRpc3BsYXlfZ2V0ID0gIlxcX1NCLlBDSTAuUDBQMS5WR0EuR0VURCJ9LAoKCXsKCSAubmFtZSA9ICJMNXgiLAoJIC5tdF9tbGVkID0gIk1MRUQiLAovKiBXTEVEIHByZXNlbnQsIGJ1dCBub3QgY29udHJvbGxlZCBieSBBQ1BJICovCgkgLm10X3RsZWQgPSAiVExFRCIsCgkgLm10X2xjZF9zd2l0Y2ggPSAiXFxRMEQiLAoJIC5sY2Rfc3RhdHVzID0gIlxcQkFPRiIsCgkgLmJyaWdodG5lc3Nfc2V0ID0gIlNQTFYiLAoJIC5icmlnaHRuZXNzX2dldCA9ICJHUExWIiwKCSAuZGlzcGxheV9zZXQgPSAiU0RTUCIsCgkgLmRpc3BsYXlfZ2V0ID0gIlxcSU5GQiJ9LAoKCXsKCSAubmFtZSA9ICJMOEwiCi8qIE5vIGZlYXR1cmVzLCBidXQgYXQgbGVhc3Qgc3VwcG9ydCB0aGUgaG90a2V5cyAqLwoJIH0sCgoJewoJIC5uYW1lID0gIk0xQSIsCgkgLm10X21sZWQgPSAiTUxFRCIsCgkgLm10X2xjZF9zd2l0Y2ggPSBNMUFfUFJFRklYICJRMTAiLAoJIC5sY2Rfc3RhdHVzID0gIlxcUE5PRiIsCgkgLmJyaWdodG5lc3NfdXAgPSBNMUFfUFJFRklYICJRMEUiLAoJIC5icmlnaHRuZXNzX2Rvd24gPSBNMUFfUFJFRklYICJRMEYiLAoJIC5icmlnaHRuZXNzX3N0YXR1cyA9ICJcXEJSSVQiLAoJIC5kaXNwbGF5X3NldCA9ICJTRFNQIiwKCSAuZGlzcGxheV9nZXQgPSAiXFxJTkZCIn0sCgoJewoJIC5uYW1lID0gIk0yRSIsCgkgLm10X21sZWQgPSAiTUxFRCIsCgkgLm10X3dsZWQgPSAiV0xFRCIsCgkgLm10X2xjZF9zd2l0Y2ggPSAiXFxRMTAiLAoJIC5sY2Rfc3RhdHVzID0gIlxcR1AwNiIsCgkgLmJyaWdodG5lc3Nfc2V0ID0gIlNQTFYiLAoJIC5icmlnaHRuZXNzX2dldCA9ICJHUExWIiwKCSAuZGlzcGxheV9zZXQgPSAiU0RTUCIsCgkgLmRpc3BsYXlfZ2V0ID0gIlxcSU5GQiJ9LAoKCXsKCSAubmFtZSA9ICJNNk4iLAoJIC5tdF9tbGVkID0gIk1MRUQiLAoJIC5tdF93bGVkID0gIldMRUQiLAoJIC53bGVkX3N0YXR1cyA9ICJcXF9TQi5QQ0kwLlNCUkcuU0cxMyIsCgkgLm10X2xjZF9zd2l0Y2ggPSB4eE5fUFJFRklYICJfUTEwIiwKCSAubGNkX3N0YXR1cyA9ICJcXF9TQi5CS0xUIiwKCSAuYnJpZ2h0bmVzc19zZXQgPSAiU1BMViIsCgkgLmJyaWdodG5lc3NfZ2V0ID0gIkdQTFYiLAoJIC5kaXNwbGF5X3NldCA9ICJTRFNQIiwKCSAuZGlzcGxheV9nZXQgPSAiXFxTU1RFIn0sCgoJewoJIC5uYW1lID0gIk02UiIsCgkgLm10X21sZWQgPSAiTUxFRCIsCgkgLm10X3dsZWQgPSAiV0xFRCIsCgkgLm10X2xjZF9zd2l0Y2ggPSB4eE5fUFJFRklYICJfUTEwIiwKCSAubGNkX3N0YXR1cyA9ICJcXF9TQi5QQ0kwLlNCU00uU0VPNCIsCgkgLmJyaWdodG5lc3Nfc2V0ID0gIlNQTFYiLAoJIC5icmlnaHRuZXNzX2dldCA9ICJHUExWIiwKCSAuZGlzcGxheV9zZXQgPSAiU0RTUCIsCgkgLmRpc3BsYXlfZ2V0ID0gIlxcX1NCLlBDSTAuUDBQMS5WR0EuR0VURCJ9LAoKCXsKCSAubmFtZSA9ICJQMzAiLAoJIC5tdF93bGVkID0gIldMRUQiLAoJIC5tdF9sY2Rfc3dpdGNoID0gUDMwX1BSRUZJWCAiX1EwRSIsCgkgLmxjZF9zdGF0dXMgPSAiXFxCS0xUIiwKCSAuYnJpZ2h0bmVzc191cCA9IFAzMF9QUkVGSVggIl9RNjgiLAoJIC5icmlnaHRuZXNzX2Rvd24gPSBQMzBfUFJFRklYICJfUTY5IiwKCSAuYnJpZ2h0bmVzc19nZXQgPSAiR1BMViIsCgkgLmRpc3BsYXlfc2V0ID0gIlNEU1AiLAoJIC5kaXNwbGF5X2dldCA9ICJcXEROWFQifSwKCgl7CgkgLm5hbWUgPSAiUzF4IiwKCSAubXRfbWxlZCA9ICJNTEVEIiwKCSAubWxlZF9zdGF0dXMgPSAiXFxFTUxFIiwKCSAubXRfd2xlZCA9ICJXTEVEIiwKCSAubXRfbGNkX3N3aXRjaCA9IFMxeF9QUkVGSVggIlExMCIsCgkgLmxjZF9zdGF0dXMgPSAiXFxQTk9GIiwKCSAuYnJpZ2h0bmVzc19zZXQgPSAiU1BMViIsCgkgLmJyaWdodG5lc3NfZ2V0ID0gIkdQTFYifSwKCgl7CgkgLm5hbWUgPSAiUzJ4IiwKCSAubXRfbWxlZCA9ICJNTEVEIiwKCSAubWxlZF9zdGF0dXMgPSAiXFxNQUlMIiwKCSAubXRfbGNkX3N3aXRjaCA9IFMyeF9QUkVGSVggIl9RMTAiLAoJIC5sY2Rfc3RhdHVzID0gIlxcQktMSSIsCgkgLmJyaWdodG5lc3NfdXAgPSBTMnhfUFJFRklYICJfUTBCIiwKCSAuYnJpZ2h0bmVzc19kb3duID0gUzJ4X1BSRUZJWCAiX1EwQSJ9LAoKCXsKCSAubmFtZSA9ICJXMU4iLAoJIC5tdF9tbGVkID0gIk1MRUQiLAoJIC5tdF93bGVkID0gIldMRUQiLAoJIC5tdF9sZWRkID0gIlNMQ00iLAoJIC5tdF9sY2Rfc3dpdGNoID0geHhOX1BSRUZJWCAiX1ExMCIsCgkgLmxjZF9zdGF0dXMgPSAiXFxCS0xUIiwKCSAuYnJpZ2h0bmVzc19zZXQgPSAiU1BMViIsCgkgLmJyaWdodG5lc3NfZ2V0ID0gIkdQTFYiLAoJIC5kaXNwbGF5X3NldCA9ICJTRFNQIiwKCSAuZGlzcGxheV9nZXQgPSAiXFxBRFZHIn0sCgoJewoJIC5uYW1lID0gIlc1QSIsCgkgLm10X2J0X3N3aXRjaCA9ICJCTEVEIiwKCSAubXRfd2xlZCA9ICJXTEVEIiwKCSAubXRfbGNkX3N3aXRjaCA9IHh4Tl9QUkVGSVggIl9RMTAiLAoJIC5icmlnaHRuZXNzX3NldCA9ICJTUExWIiwKCSAuYnJpZ2h0bmVzc19nZXQgPSAiR1BMViIsCgkgLmRpc3BsYXlfc2V0ID0gIlNEU1AiLAoJIC5kaXNwbGF5X2dldCA9ICJcXEFEVkcifSwKCgl7CgkgLm5hbWUgPSAiVzNWIiwKCSAubXRfbWxlZCA9ICJNTEVEIiwKCSAubXRfd2xlZCA9ICJXTEVEIiwKCSAubXRfbGNkX3N3aXRjaCA9IHh4Tl9QUkVGSVggIl9RMTAiLAoJIC5sY2Rfc3RhdHVzID0gIlxcQktMVCIsCgkgLmJyaWdodG5lc3Nfc2V0ID0gIlNQTFYiLAoJIC5icmlnaHRuZXNzX2dldCA9ICJHUExWIiwKCSAuZGlzcGxheV9zZXQgPSAiU0RTUCIsCgkgLmRpc3BsYXlfZ2V0ID0gIlxcSU5GQiJ9LAoKICAgICAgIHsKCSAubmFtZSA9ICJ4eE4iLAoJIC5tdF9tbGVkID0gIk1MRUQiLAovKiBXTEVEIHByZXNlbnQsIGJ1dCBub3QgY29udHJvbGxlZCBieSBBQ1BJICovCgkgLm10X2xjZF9zd2l0Y2ggPSB4eE5fUFJFRklYICJfUTEwIiwKCSAubGNkX3N0YXR1cyA9ICJcXEJLTFQiLAoJIC5icmlnaHRuZXNzX3NldCA9ICJTUExWIiwKCSAuYnJpZ2h0bmVzc19nZXQgPSAiR1BMViIsCgkgLmRpc3BsYXlfc2V0ID0gIlNEU1AiLAoJIC5kaXNwbGF5X2dldCA9ICJcXEFEVkcifQp9OwoKLyogcHJvY2RpciB3ZSB1c2UgKi8Kc3RhdGljIHN0cnVjdCBwcm9jX2Rpcl9lbnRyeSAqYXN1c19wcm9jX2RpcjsKCi8qCiAqIFRoaXMgaGVhZGVyIGlzIG1hZGUgYXZhaWxhYmxlIHRvIGFsbG93IHByb3BlciBjb25maWd1cmF0aW9uIGdpdmVuIG1vZGVsLAogKiByZXZpc2lvbiBudW1iZXIgLCAuLi4gdGhpcyBpbmZvIGNhbm5vdCBnbyBpbiBzdHJ1Y3QgYXN1c19ob3RrIGJlY2F1c2UgaXQgaXMKICogYXZhaWxhYmxlIGJlZm9yZSB0aGUgaG90awogKi8Kc3RhdGljIHN0cnVjdCBhY3BpX3RhYmxlX2hlYWRlciAqYXN1c19pbmZvOwoKLyogVGhlIGFjdHVhbCBkZXZpY2UgdGhlIGRyaXZlciBiaW5kcyB0byAqLwpzdGF0aWMgc3RydWN0IGFzdXNfaG90ayAqaG90azsKCi8qCiAqIFRoZSBob3RrZXkgZHJpdmVyIGRlY2xhcmF0aW9uCiAqLwpzdGF0aWMgaW50IGFzdXNfaG90a19hZGQoc3RydWN0IGFjcGlfZGV2aWNlICpkZXZpY2UpOwpzdGF0aWMgaW50IGFzdXNfaG90a19yZW1vdmUoc3RydWN0IGFjcGlfZGV2aWNlICpkZXZpY2UsIGludCB0eXBlKTsKc3RhdGljIHN0cnVjdCBhY3BpX2RyaXZlciBhc3VzX2hvdGtfZHJpdmVyID0gewoJLm5hbWUgPSBBQ1BJX0hPVEtfTkFNRSwKCS5jbGFzcyA9IEFDUElfSE9US19DTEFTUywKCS5pZHMgPSBBQ1BJX0hPVEtfSElELAoJLm9wcyA9IHsKCQkuYWRkID0gYXN1c19ob3RrX2FkZCwKCQkucmVtb3ZlID0gYXN1c19ob3RrX3JlbW92ZSwKCQl9LAp9OwoKLyogCiAqIFRoaXMgZnVuY3Rpb24gZXZhbHVhdGVzIGFuIEFDUEkgbWV0aG9kLCBnaXZlbiBhbiBpbnQgYXMgcGFyYW1ldGVyLCB0aGUKICogbWV0aG9kIGlzIHNlYXJjaGVkIHdpdGhpbiB0aGUgc2NvcGUgb2YgdGhlIGhhbmRsZSwgY2FuIGJlIE5VTEwuIFRoZSBvdXRwdXQKICogb2YgdGhlIG1ldGhvZCBpcyB3cml0dGVuIGlzIG91dHB1dCwgd2hpY2ggY2FuIGFsc28gYmUgTlVMTAogKgogKiByZXR1cm5zIDEgaWYgd3JpdGUgaXMgc3VjY2Vzc2Z1bCwgMCBlbHNlLiAKICovCnN0YXRpYyBpbnQgd3JpdGVfYWNwaV9pbnQoYWNwaV9oYW5kbGUgaGFuZGxlLCBjb25zdCBjaGFyICptZXRob2QsIGludCB2YWwsCgkJCSAgc3RydWN0IGFjcGlfYnVmZmVyICpvdXRwdXQpCnsKCXN0cnVjdCBhY3BpX29iamVjdF9saXN0IHBhcmFtczsJLy9saXN0IG9mIGlucHV0IHBhcmFtZXRlcnMgKGFuIGludCBoZXJlKQoJdW5pb24gYWNwaV9vYmplY3QgaW5fb2JqOwkvL3RoZSBvbmx5IHBhcmFtIHdlIHVzZQoJYWNwaV9zdGF0dXMgc3RhdHVzOwoKCXBhcmFtcy5jb3VudCA9IDE7CglwYXJhbXMucG9pbnRlciA9ICZpbl9vYmo7Cglpbl9vYmoudHlwZSA9IEFDUElfVFlQRV9JTlRFR0VSOwoJaW5fb2JqLmludGVnZXIudmFsdWUgPSB2YWw7CgoJc3RhdHVzID0gYWNwaV9ldmFsdWF0ZV9vYmplY3QoaGFuZGxlLCAoY2hhciAqKW1ldGhvZCwgJnBhcmFtcywgb3V0cHV0KTsKCXJldHVybiAoc3RhdHVzID09IEFFX09LKTsKfQoKc3RhdGljIGludCByZWFkX2FjcGlfaW50KGFjcGlfaGFuZGxlIGhhbmRsZSwgY29uc3QgY2hhciAqbWV0aG9kLCBpbnQgKnZhbCkKewoJc3RydWN0IGFjcGlfYnVmZmVyIG91dHB1dDsKCXVuaW9uIGFjcGlfb2JqZWN0IG91dF9vYmo7CglhY3BpX3N0YXR1cyBzdGF0dXM7CgoJb3V0cHV0Lmxlbmd0aCA9IHNpemVvZihvdXRfb2JqKTsKCW91dHB1dC5wb2ludGVyID0gJm91dF9vYmo7CgoJc3RhdHVzID0gYWNwaV9ldmFsdWF0ZV9vYmplY3QoaGFuZGxlLCAoY2hhciAqKW1ldGhvZCwgTlVMTCwgJm91dHB1dCk7CgkqdmFsID0gb3V0X29iai5pbnRlZ2VyLnZhbHVlOwoJcmV0dXJuIChzdGF0dXMgPT0gQUVfT0spICYmIChvdXRfb2JqLnR5cGUgPT0gQUNQSV9UWVBFX0lOVEVHRVIpOwp9CgovKgogKiBXZSB3cml0ZSBvdXIgaW5mbyBpbiBwYWdlLCB3ZSBiZWdpbiBhdCBvZmZzZXQgb2ZmIGFuZCBjYW5ub3Qgd3JpdGUgbW9yZQogKiB0aGFuIGNvdW50IGJ5dGVzLiBXZSBzZXQgZW9mIHRvIDEgaWYgd2UgaGFuZGxlIHRob3NlIDIgdmFsdWVzLiBXZSByZXR1cm4gdGhlCiAqIG51bWJlciBvZiBieXRlcyB3cml0dGVuIGluIHBhZ2UKICovCnN0YXRpYyBpbnQKcHJvY19yZWFkX2luZm8oY2hhciAqcGFnZSwgY2hhciAqKnN0YXJ0LCBvZmZfdCBvZmYsIGludCBjb3VudCwgaW50ICplb2YsCgkgICAgICAgdm9pZCAqZGF0YSkKewoJaW50IGxlbiA9IDA7CglpbnQgdGVtcDsKCWNoYXIgYnVmWzE2XTsJCS8vZW5vdWdoIGZvciBhbGwgaW5mbwoJLyoKCSAqIFdlIHVzZSB0aGUgZWFzeSB3YXksIHdlIGRvbid0IGNhcmUgb2Ygb2ZmIGFuZCBjb3VudCwgc28gd2UgZG9uJ3Qgc2V0IGVvZgoJICogdG8gMQoJICovCgoJbGVuICs9IHNwcmludGYocGFnZSwgQUNQSV9IT1RLX05BTUUgIiAiIEFTVVNfQUNQSV9WRVJTSU9OICJcbiIpOwoJbGVuICs9IHNwcmludGYocGFnZSArIGxlbiwgIk1vZGVsIHJlZmVyZW5jZSAgICA6ICVzXG4iLAoJCSAgICAgICBob3RrLT5tZXRob2RzLT5uYW1lKTsKCS8qIAoJICogVGhlIFNGVU4gbWV0aG9kIHByb2JhYmx5IGFsbG93cyB0aGUgb3JpZ2luYWwgZHJpdmVyIHRvIGdldCB0aGUgbGlzdCAKCSAqIG9mIGZlYXR1cmVzIHN1cHBvcnRlZCBieSBhIGdpdmVuIG1vZGVsLiBGb3Igbm93LCAweDAxMDAgb3IgMHgwODAwIAoJICogYml0IHNpZ25pZmllcyB0aGF0IHRoZSBsYXB0b3AgaXMgZXF1aXBwZWQgd2l0aCBhIFdpLUZpIE1pbmlQQ0kgY2FyZC4KCSAqIFRoZSBzaWduaWZpY2FuY2Ugb2Ygb3RoZXJzIGlzIHlldCB0byBiZSBmb3VuZC4KCSAqLwoJaWYgKHJlYWRfYWNwaV9pbnQoaG90ay0+aGFuZGxlLCAiU0ZVTiIsICZ0ZW1wKSkKCQlsZW4gKz0KCQkgICAgc3ByaW50ZihwYWdlICsgbGVuLCAiU0ZVTiB2YWx1ZSAgICAgICAgIDogMHglMDR4XG4iLCB0ZW1wKTsKCS8qCgkgKiBBbm90aGVyIHZhbHVlIGZvciB1c2Vyc3BhY2U6IHRoZSBBU1lNIG1ldGhvZCByZXR1cm5zIDB4MDIgZm9yCgkgKiBiYXR0ZXJ5IGxvdyBhbmQgMHgwNCBmb3IgYmF0dGVyeSBjcml0aWNhbCwgaXRzIHJlYWRpbmdzIHRlbmQgdG8gYmUKCSAqIG1vcmUgYWNjdXJhdGUgdGhhbiB0aG9zZSBwcm92aWRlZCBieSBfQlNULiAKCSAqIE5vdGU6IHNpbmNlIG5vdCBhbGwgdGhlIGxhcHRvcHMgcHJvdmlkZSB0aGlzIG1ldGhvZCwgZXJyb3JzIGFyZQoJICogc2lsZW50bHkgaWdub3JlZC4KCSAqLwoJaWYgKHJlYWRfYWNwaV9pbnQoaG90ay0+aGFuZGxlLCAiQVNZTSIsICZ0ZW1wKSkKCQlsZW4gKz0KCQkgICAgc3ByaW50ZihwYWdlICsgbGVuLCAiQVNZTSB2YWx1ZSAgICAgICAgIDogMHglMDR4XG4iLCB0ZW1wKTsKCWlmIChhc3VzX2luZm8pIHsKCQlzbnByaW50ZihidWYsIDE2LCAiJWQiLCBhc3VzX2luZm8tPmxlbmd0aCk7CgkJbGVuICs9IHNwcmludGYocGFnZSArIGxlbiwgIkRTRFQgbGVuZ3RoICAgICAgICA6ICVzXG4iLCBidWYpOwoJCXNucHJpbnRmKGJ1ZiwgMTYsICIlZCIsIGFzdXNfaW5mby0+Y2hlY2tzdW0pOwoJCWxlbiArPSBzcHJpbnRmKHBhZ2UgKyBsZW4sICJEU0RUIGNoZWNrc3VtICAgICAgOiAlc1xuIiwgYnVmKTsKCQlzbnByaW50ZihidWYsIDE2LCAiJWQiLCBhc3VzX2luZm8tPnJldmlzaW9uKTsKCQlsZW4gKz0gc3ByaW50ZihwYWdlICsgbGVuLCAiRFNEVCByZXZpc2lvbiAgICAgIDogJXNcbiIsIGJ1Zik7CgkJc25wcmludGYoYnVmLCA3LCAiJXMiLCBhc3VzX2luZm8tPm9lbV9pZCk7CgkJbGVuICs9IHNwcmludGYocGFnZSArIGxlbiwgIk9FTSBpZCAgICAgICAgICAgICA6ICVzXG4iLCBidWYpOwoJCXNucHJpbnRmKGJ1ZiwgOSwgIiVzIiwgYXN1c19pbmZvLT5vZW1fdGFibGVfaWQpOwoJCWxlbiArPSBzcHJpbnRmKHBhZ2UgKyBsZW4sICJPRU0gdGFibGUgaWQgICAgICAgOiAlc1xuIiwgYnVmKTsKCQlzbnByaW50ZihidWYsIDE2LCAiJXgiLCBhc3VzX2luZm8tPm9lbV9yZXZpc2lvbik7CgkJbGVuICs9IHNwcmludGYocGFnZSArIGxlbiwgIk9FTSByZXZpc2lvbiAgICAgICA6IDB4JXNcbiIsIGJ1Zik7CgkJc25wcmludGYoYnVmLCA1LCAiJXMiLCBhc3VzX2luZm8tPmFzbF9jb21waWxlcl9pZCk7CgkJbGVuICs9IHNwcmludGYocGFnZSArIGxlbiwgIkFTTCBjb21wIHZlbmRvciBpZCA6ICVzXG4iLCBidWYpOwoJCXNucHJpbnRmKGJ1ZiwgMTYsICIleCIsIGFzdXNfaW5mby0+YXNsX2NvbXBpbGVyX3JldmlzaW9uKTsKCQlsZW4gKz0gc3ByaW50ZihwYWdlICsgbGVuLCAiQVNMIGNvbXAgcmV2aXNpb24gIDogMHglc1xuIiwgYnVmKTsKCX0KCglyZXR1cm4gbGVuOwp9CgovKgogKiAvcHJvYyBoYW5kbGVycwogKiBXZSB3cml0ZSBvdXIgaW5mbyBpbiBwYWdlLCB3ZSBiZWdpbiBhdCBvZmZzZXQgb2ZmIGFuZCBjYW5ub3Qgd3JpdGUgbW9yZQogKiB0aGFuIGNvdW50IGJ5dGVzLiBXZSBzZXQgZW9mIHRvIDEgaWYgd2UgaGFuZGxlIHRob3NlIDIgdmFsdWVzLiBXZSByZXR1cm4gdGhlCiAqIG51bWJlciBvZiBieXRlcyB3cml0dGVuIGluIHBhZ2UKICovCgovKiBHZW5lcmljIExFRCBmdW5jdGlvbnMgKi8Kc3RhdGljIGludCByZWFkX2xlZChjb25zdCBjaGFyICpsZWRuYW1lLCBpbnQgbGVkbWFzaykKewoJaWYgKGxlZG5hbWUpIHsKCQlpbnQgbGVkX3N0YXR1czsKCgkJaWYgKHJlYWRfYWNwaV9pbnQoTlVMTCwgbGVkbmFtZSwgJmxlZF9zdGF0dXMpKQoJCQlyZXR1cm4gbGVkX3N0YXR1czsKCQllbHNlCgkJCXByaW50ayhLRVJOX1dBUk5JTkcgIkFzdXMgQUNQSTogRXJyb3IgcmVhZGluZyBMRUQgIgoJCQkgICAgICAgInN0YXR1c1xuIik7Cgl9CglyZXR1cm4gKGhvdGstPnN0YXR1cyAmIGxlZG1hc2spID8gMSA6IDA7Cn0KCnN0YXRpYyBpbnQgcGFyc2VfYXJnKGNvbnN0IGNoYXIgX191c2VyICogYnVmLCB1bnNpZ25lZCBsb25nIGNvdW50LCBpbnQgKnZhbCkKewoJY2hhciBzWzMyXTsKCWlmICghY291bnQpCgkJcmV0dXJuIDA7CglpZiAoY291bnQgPiAzMSkKCQlyZXR1cm4gLUVJTlZBTDsKCWlmIChjb3B5X2Zyb21fdXNlcihzLCBidWYsIGNvdW50KSkKCQlyZXR1cm4gLUVGQVVMVDsKCXNbY291bnRdID0gMDsKCWlmIChzc2NhbmYocywgIiVpIiwgdmFsKSAhPSAxKQoJCXJldHVybiAtRUlOVkFMOwoJcmV0dXJuIGNvdW50Owp9CgovKiBGSVhNRToga2lsbCBleHRyYW5lb3VzIGFyZ3Mgc28gaXQgY2FuIGJlIGNhbGxlZCBpbmRlcGVuZGVudGx5ICovCnN0YXRpYyBpbnQKd3JpdGVfbGVkKGNvbnN0IGNoYXIgX191c2VyICogYnVmZmVyLCB1bnNpZ25lZCBsb25nIGNvdW50LAoJICBjaGFyICpsZWRuYW1lLCBpbnQgbGVkbWFzaywgaW50IGludmVydCkKewoJaW50IHJ2LCB2YWx1ZTsKCWludCBsZWRfb3V0ID0gMDsKCglydiA9IHBhcnNlX2FyZyhidWZmZXIsIGNvdW50LCAmdmFsdWUpOwoJaWYgKHJ2ID4gMCkKCQlsZWRfb3V0ID0gdmFsdWUgPyAxIDogMDsKCglob3RrLT5zdGF0dXMgPQoJICAgIChsZWRfb3V0KSA/IChob3RrLT5zdGF0dXMgfCBsZWRtYXNrKSA6IChob3RrLT5zdGF0dXMgJiB+bGVkbWFzayk7CgoJaWYgKGludmVydCkJCS8qIGludmVydCB0YXJnZXQgdmFsdWUgKi8KCQlsZWRfb3V0ID0gIWxlZF9vdXQgJiAweDE7CgoJaWYgKCF3cml0ZV9hY3BpX2ludChob3RrLT5oYW5kbGUsIGxlZG5hbWUsIGxlZF9vdXQsIE5VTEwpKQoJCXByaW50ayhLRVJOX1dBUk5JTkcgIkFzdXMgQUNQSTogTEVEICglcykgd3JpdGUgZmFpbGVkXG4iLAoJCSAgICAgICBsZWRuYW1lKTsKCglyZXR1cm4gcnY7Cn0KCi8qCiAqIFByb2MgaGFuZGxlcnMgZm9yIE1MRUQKICovCnN0YXRpYyBpbnQKcHJvY19yZWFkX21sZWQoY2hhciAqcGFnZSwgY2hhciAqKnN0YXJ0LCBvZmZfdCBvZmYsIGludCBjb3VudCwgaW50ICplb2YsCgkgICAgICAgdm9pZCAqZGF0YSkKewoJcmV0dXJuIHNwcmludGYocGFnZSwgIiVkXG4iLAoJCSAgICAgICByZWFkX2xlZChob3RrLT5tZXRob2RzLT5tbGVkX3N0YXR1cywgTUxFRF9PTikpOwp9CgpzdGF0aWMgaW50CnByb2Nfd3JpdGVfbWxlZChzdHJ1Y3QgZmlsZSAqZmlsZSwgY29uc3QgY2hhciBfX3VzZXIgKiBidWZmZXIsCgkJdW5zaWduZWQgbG9uZyBjb3VudCwgdm9pZCAqZGF0YSkKewoJcmV0dXJuIHdyaXRlX2xlZChidWZmZXIsIGNvdW50LCBob3RrLT5tZXRob2RzLT5tdF9tbGVkLCBNTEVEX09OLCAxKTsKfQoKLyoKICogUHJvYyBoYW5kbGVycyBmb3IgTEVEIGRpc3BsYXkKICovCnN0YXRpYyBpbnQKcHJvY19yZWFkX2xlZGQoY2hhciAqcGFnZSwgY2hhciAqKnN0YXJ0LCBvZmZfdCBvZmYsIGludCBjb3VudCwgaW50ICplb2YsCgkgICAgICAgdm9pZCAqZGF0YSkKewoJcmV0dXJuIHNwcmludGYocGFnZSwgIjB4JTA4eFxuIiwgaG90ay0+bGVkZF9zdGF0dXMpOwp9CgpzdGF0aWMgaW50CnByb2Nfd3JpdGVfbGVkZChzdHJ1Y3QgZmlsZSAqZmlsZSwgY29uc3QgY2hhciBfX3VzZXIgKiBidWZmZXIsCgkJdW5zaWduZWQgbG9uZyBjb3VudCwgdm9pZCAqZGF0YSkKewoJaW50IHJ2LCB2YWx1ZTsKCglydiA9IHBhcnNlX2FyZyhidWZmZXIsIGNvdW50LCAmdmFsdWUpOwoJaWYgKHJ2ID4gMCkgewoJCWlmICghd3JpdGVfYWNwaV9pbnQKCQkgICAgKGhvdGstPmhhbmRsZSwgaG90ay0+bWV0aG9kcy0+bXRfbGVkZCwgdmFsdWUsIE5VTEwpKQoJCQlwcmludGsoS0VSTl9XQVJOSU5HCgkJCSAgICAgICAiQXN1cyBBQ1BJOiBMRUQgZGlzcGxheSB3cml0ZSBmYWlsZWRcbiIpOwoJCWVsc2UKCQkJaG90ay0+bGVkZF9zdGF0dXMgPSAodTMyKSB2YWx1ZTsKCX0KCXJldHVybiBydjsKfQoKLyoKICogUHJvYyBoYW5kbGVycyBmb3IgV0xFRAogKi8Kc3RhdGljIGludApwcm9jX3JlYWRfd2xlZChjaGFyICpwYWdlLCBjaGFyICoqc3RhcnQsIG9mZl90IG9mZiwgaW50IGNvdW50LCBpbnQgKmVvZiwKCSAgICAgICB2b2lkICpkYXRhKQp7CglyZXR1cm4gc3ByaW50ZihwYWdlLCAiJWRcbiIsCgkJICAgICAgIHJlYWRfbGVkKGhvdGstPm1ldGhvZHMtPndsZWRfc3RhdHVzLCBXTEVEX09OKSk7Cn0KCnN0YXRpYyBpbnQKcHJvY193cml0ZV93bGVkKHN0cnVjdCBmaWxlICpmaWxlLCBjb25zdCBjaGFyIF9fdXNlciAqIGJ1ZmZlciwKCQl1bnNpZ25lZCBsb25nIGNvdW50LCB2b2lkICpkYXRhKQp7CglyZXR1cm4gd3JpdGVfbGVkKGJ1ZmZlciwgY291bnQsIGhvdGstPm1ldGhvZHMtPm10X3dsZWQsIFdMRURfT04sIDApOwp9CgovKgogKiBQcm9jIGhhbmRsZXJzIGZvciBCbHVldG9vdGgKICovCnN0YXRpYyBpbnQKcHJvY19yZWFkX2JsdWV0b290aChjaGFyICpwYWdlLCBjaGFyICoqc3RhcnQsIG9mZl90IG9mZiwgaW50IGNvdW50LCBpbnQgKmVvZiwKCQkgICAgdm9pZCAqZGF0YSkKewoJcmV0dXJuIHNwcmludGYocGFnZSwgIiVkXG4iLCByZWFkX2xlZChob3RrLT5tZXRob2RzLT5idF9zdGF0dXMsIEJUX09OKSk7Cn0KCnN0YXRpYyBpbnQKcHJvY193cml0ZV9ibHVldG9vdGgoc3RydWN0IGZpbGUgKmZpbGUsIGNvbnN0IGNoYXIgX191c2VyICogYnVmZmVyLAoJCSAgICAgdW5zaWduZWQgbG9uZyBjb3VudCwgdm9pZCAqZGF0YSkKewoJLyogTm90ZTogbXRfYnRfc3dpdGNoIGNvbnRyb2xzIGJvdGggaW50ZXJuYWwgQmx1ZXRvb3RoIGFkYXB0ZXIncyAKCSAgIHByZXNlbmNlIGFuZCBpdHMgTEVEICovCglyZXR1cm4gd3JpdGVfbGVkKGJ1ZmZlciwgY291bnQsIGhvdGstPm1ldGhvZHMtPm10X2J0X3N3aXRjaCwgQlRfT04sIDApOwp9CgovKgogKiBQcm9jIGhhbmRsZXJzIGZvciBUTEVECiAqLwpzdGF0aWMgaW50CnByb2NfcmVhZF90bGVkKGNoYXIgKnBhZ2UsIGNoYXIgKipzdGFydCwgb2ZmX3Qgb2ZmLCBpbnQgY291bnQsIGludCAqZW9mLAoJICAgICAgIHZvaWQgKmRhdGEpCnsKCXJldHVybiBzcHJpbnRmKHBhZ2UsICIlZFxuIiwKCQkgICAgICAgcmVhZF9sZWQoaG90ay0+bWV0aG9kcy0+dGxlZF9zdGF0dXMsIFRMRURfT04pKTsKfQoKc3RhdGljIGludApwcm9jX3dyaXRlX3RsZWQoc3RydWN0IGZpbGUgKmZpbGUsIGNvbnN0IGNoYXIgX191c2VyICogYnVmZmVyLAoJCXVuc2lnbmVkIGxvbmcgY291bnQsIHZvaWQgKmRhdGEpCnsKCXJldHVybiB3cml0ZV9sZWQoYnVmZmVyLCBjb3VudCwgaG90ay0+bWV0aG9kcy0+bXRfdGxlZCwgVExFRF9PTiwgMCk7Cn0KCnN0YXRpYyBpbnQgZ2V0X2xjZF9zdGF0ZSh2b2lkKQp7CglpbnQgbGNkID0gMDsKCglpZiAoaG90ay0+bW9kZWwgIT0gTDNIKSB7CgkJLyogV2UgZG9uJ3QgaGF2ZSB0byBjaGVjayBhbnl0aGluZyBpZiB3ZSBhcmUgaGVyZSAqLwoJCWlmICghcmVhZF9hY3BpX2ludChOVUxMLCBob3RrLT5tZXRob2RzLT5sY2Rfc3RhdHVzLCAmbGNkKSkKCQkJcHJpbnRrKEtFUk5fV0FSTklORwoJCQkgICAgICAgIkFzdXMgQUNQSTogRXJyb3IgcmVhZGluZyBMQ0Qgc3RhdHVzXG4iKTsKCgkJaWYgKGhvdGstPm1vZGVsID09IEwyRCkKCQkJbGNkID0gfmxjZDsKCX0gZWxzZSB7CQkvKiBMM0ggYW5kIHRoZSBsaWtlIGhhdmUgdG8gYmUgaGFuZGxlZCBkaWZmZXJlbnRseSAqLwoJCWFjcGlfc3RhdHVzIHN0YXR1cyA9IDA7CgkJc3RydWN0IGFjcGlfb2JqZWN0X2xpc3QgaW5wdXQ7CgkJdW5pb24gYWNwaV9vYmplY3QgbXRfcGFyYW1zWzJdOwoJCXN0cnVjdCBhY3BpX2J1ZmZlciBvdXRwdXQ7CgkJdW5pb24gYWNwaV9vYmplY3Qgb3V0X29iajsKCgkJaW5wdXQuY291bnQgPSAyOwoJCWlucHV0LnBvaW50ZXIgPSBtdF9wYXJhbXM7CgkJLyogTm90ZTogdGhlIGZvbGxvd2luZyB2YWx1ZXMgYXJlIHBhcnRseSBndWVzc2VkIHVwLCBidXQgCgkJICAgb3RoZXJ3aXNlIHRoZXkgc2VlbSB0byB3b3JrICovCgkJbXRfcGFyYW1zWzBdLnR5cGUgPSBBQ1BJX1RZUEVfSU5URUdFUjsKCQltdF9wYXJhbXNbMF0uaW50ZWdlci52YWx1ZSA9IDB4MDI7CgkJbXRfcGFyYW1zWzFdLnR5cGUgPSBBQ1BJX1RZUEVfSU5URUdFUjsKCQltdF9wYXJhbXNbMV0uaW50ZWdlci52YWx1ZSA9IDB4MDI7CgoJCW91dHB1dC5sZW5ndGggPSBzaXplb2Yob3V0X29iaik7CgkJb3V0cHV0LnBvaW50ZXIgPSAmb3V0X29iajsKCgkJc3RhdHVzID0KCQkgICAgYWNwaV9ldmFsdWF0ZV9vYmplY3QoTlVMTCwgaG90ay0+bWV0aG9kcy0+bGNkX3N0YXR1cywKCQkJCQkgJmlucHV0LCAmb3V0cHV0KTsKCQlpZiAoc3RhdHVzICE9IEFFX09LKQoJCQlyZXR1cm4gLTE7CgkJaWYgKG91dF9vYmoudHlwZSA9PSBBQ1BJX1RZUEVfSU5URUdFUikKCQkJLyogVGhhdCdzIHdoYXQgdGhlIEFNTCBjb2RlIGRvZXMgKi8KCQkJbGNkID0gb3V0X29iai5pbnRlZ2VyLnZhbHVlID4+IDg7Cgl9CgoJcmV0dXJuIChsY2QgJiAxKTsKfQoKc3RhdGljIGludCBzZXRfbGNkX3N0YXRlKGludCB2YWx1ZSkKewoJaW50IGxjZCA9IDA7CglhY3BpX3N0YXR1cyBzdGF0dXMgPSAwOwoKCWxjZCA9IHZhbHVlID8gMSA6IDA7CglpZiAobGNkICE9IGdldF9sY2Rfc3RhdGUoKSkgewoJCS8qIHN3aXRjaCAqLwoJCWlmIChob3RrLT5tb2RlbCAhPSBMM0gpIHsKCQkJc3RhdHVzID0KCQkJICAgIGFjcGlfZXZhbHVhdGVfb2JqZWN0KE5VTEwsCgkJCQkJCSBob3RrLT5tZXRob2RzLT5tdF9sY2Rfc3dpdGNoLAoJCQkJCQkgTlVMTCwgTlVMTCk7CgkJfSBlbHNlIHsJLyogTDNIIGFuZCB0aGUgbGlrZSBoYXZlIHRvIGJlIGhhbmRsZWQgZGlmZmVyZW50bHkgKi8KCQkJaWYgKCF3cml0ZV9hY3BpX2ludAoJCQkgICAgKGhvdGstPmhhbmRsZSwgaG90ay0+bWV0aG9kcy0+bXRfbGNkX3N3aXRjaCwgMHgwNywKCQkJICAgICBOVUxMKSkKCQkJCXN0YXR1cyA9IEFFX0VSUk9SOwoJCQkvKiBMM0gncyBBTUwgZXhlY3V0ZXMgRUhLICgweDA3KSB1cG9uIEZuK0Y3IGtleXByZXNzLCAKCQkJICAgdGhlIGV4YWN0IGJlaGF2aW91ciBpcyBzaW11bGF0ZWQgaGVyZSAqLwoJCX0KCQlpZiAoQUNQSV9GQUlMVVJFKHN0YXR1cykpCgkJCXByaW50ayhLRVJOX1dBUk5JTkcgIkFzdXMgQUNQSTogRXJyb3Igc3dpdGNoaW5nIExDRFxuIik7Cgl9CglyZXR1cm4gMDsKCn0KCnN0YXRpYyBpbnQKcHJvY19yZWFkX2xjZChjaGFyICpwYWdlLCBjaGFyICoqc3RhcnQsIG9mZl90IG9mZiwgaW50IGNvdW50LCBpbnQgKmVvZiwKCSAgICAgIHZvaWQgKmRhdGEpCnsKCXJldHVybiBzcHJpbnRmKHBhZ2UsICIlZFxuIiwgZ2V0X2xjZF9zdGF0ZSgpKTsKfQoKc3RhdGljIGludApwcm9jX3dyaXRlX2xjZChzdHJ1Y3QgZmlsZSAqZmlsZSwgY29uc3QgY2hhciBfX3VzZXIgKiBidWZmZXIsCgkgICAgICAgdW5zaWduZWQgbG9uZyBjb3VudCwgdm9pZCAqZGF0YSkKewoJaW50IHJ2LCB2YWx1ZTsKCglydiA9IHBhcnNlX2FyZyhidWZmZXIsIGNvdW50LCAmdmFsdWUpOwoJaWYgKHJ2ID4gMCkKCQlzZXRfbGNkX3N0YXRlKHZhbHVlKTsKCXJldHVybiBydjsKfQoKc3RhdGljIGludCByZWFkX2JyaWdodG5lc3Modm9pZCkKewoJaW50IHZhbHVlOwoKCWlmIChob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX2dldCkgewkvKiBTUExWL0dQTFYgbGFwdG9wICovCgkJaWYgKCFyZWFkX2FjcGlfaW50KGhvdGstPmhhbmRsZSwgaG90ay0+bWV0aG9kcy0+YnJpZ2h0bmVzc19nZXQsCgkJCQkgICAmdmFsdWUpKQoJCQlwcmludGsoS0VSTl9XQVJOSU5HCgkJCSAgICAgICAiQXN1cyBBQ1BJOiBFcnJvciByZWFkaW5nIGJyaWdodG5lc3NcbiIpOwoJfSBlbHNlIGlmIChob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX3N0YXR1cykgewkvKiBGb3IgRDEgZm9yIGV4YW1wbGUgKi8KCQlpZiAoIXJlYWRfYWNwaV9pbnQoTlVMTCwgaG90ay0+bWV0aG9kcy0+YnJpZ2h0bmVzc19zdGF0dXMsCgkJCQkgICAmdmFsdWUpKQoJCQlwcmludGsoS0VSTl9XQVJOSU5HCgkJCSAgICAgICAiQXN1cyBBQ1BJOiBFcnJvciByZWFkaW5nIGJyaWdodG5lc3NcbiIpOwoJfSBlbHNlCQkJLyogTm8gR1BMViBtZXRob2QgKi8KCQl2YWx1ZSA9IGhvdGstPmJyaWdodG5lc3M7CglyZXR1cm4gdmFsdWU7Cn0KCi8qCiAqIENoYW5nZSB0aGUgYnJpZ2h0bmVzcyBsZXZlbAogKi8Kc3RhdGljIHZvaWQgc2V0X2JyaWdodG5lc3MoaW50IHZhbHVlKQp7CglhY3BpX3N0YXR1cyBzdGF0dXMgPSAwOwoKCS8qIFNQTFYgbGFwdG9wICovCglpZiAoaG90ay0+bWV0aG9kcy0+YnJpZ2h0bmVzc19zZXQpIHsKCQlpZiAoIXdyaXRlX2FjcGlfaW50KGhvdGstPmhhbmRsZSwgaG90ay0+bWV0aG9kcy0+YnJpZ2h0bmVzc19zZXQsCgkJCQkgICAgdmFsdWUsIE5VTEwpKQoJCQlwcmludGsoS0VSTl9XQVJOSU5HCgkJCSAgICAgICAiQXN1cyBBQ1BJOiBFcnJvciBjaGFuZ2luZyBicmlnaHRuZXNzXG4iKTsKCQlyZXR1cm47Cgl9CgoJLyogTm8gU1BMViBtZXRob2QgaWYgd2UgYXJlIGhlcmUsIGFjdCBhcyBhcHByb3ByaWF0ZSAqLwoJdmFsdWUgLT0gcmVhZF9icmlnaHRuZXNzKCk7Cgl3aGlsZSAodmFsdWUgIT0gMCkgewoJCXN0YXR1cyA9IGFjcGlfZXZhbHVhdGVfb2JqZWN0KE5VTEwsICh2YWx1ZSA+IDApID8KCQkJCQkgICAgICBob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX3VwIDoKCQkJCQkgICAgICBob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX2Rvd24sCgkJCQkJICAgICAgTlVMTCwgTlVMTCk7CgkJKHZhbHVlID4gMCkgPyB2YWx1ZS0tIDogdmFsdWUrKzsKCQlpZiAoQUNQSV9GQUlMVVJFKHN0YXR1cykpCgkJCXByaW50ayhLRVJOX1dBUk5JTkcKCQkJICAgICAgICJBc3VzIEFDUEk6IEVycm9yIGNoYW5naW5nIGJyaWdodG5lc3NcbiIpOwoJfQoJcmV0dXJuOwp9CgpzdGF0aWMgaW50CnByb2NfcmVhZF9icm4oY2hhciAqcGFnZSwgY2hhciAqKnN0YXJ0LCBvZmZfdCBvZmYsIGludCBjb3VudCwgaW50ICplb2YsCgkgICAgICB2b2lkICpkYXRhKQp7CglyZXR1cm4gc3ByaW50ZihwYWdlLCAiJWRcbiIsIHJlYWRfYnJpZ2h0bmVzcygpKTsKfQoKc3RhdGljIGludApwcm9jX3dyaXRlX2JybihzdHJ1Y3QgZmlsZSAqZmlsZSwgY29uc3QgY2hhciBfX3VzZXIgKiBidWZmZXIsCgkgICAgICAgdW5zaWduZWQgbG9uZyBjb3VudCwgdm9pZCAqZGF0YSkKewoJaW50IHJ2LCB2YWx1ZTsKCglydiA9IHBhcnNlX2FyZyhidWZmZXIsIGNvdW50LCAmdmFsdWUpOwoJaWYgKHJ2ID4gMCkgewoJCXZhbHVlID0gKDAgPCB2YWx1ZSkgPyAoKDE1IDwgdmFsdWUpID8gMTUgOiB2YWx1ZSkgOiAwOwoJCS8qIDAgPD0gdmFsdWUgPD0gMTUgKi8KCQlzZXRfYnJpZ2h0bmVzcyh2YWx1ZSk7Cgl9CglyZXR1cm4gcnY7Cn0KCnN0YXRpYyB2b2lkIHNldF9kaXNwbGF5KGludCB2YWx1ZSkKewoJLyogbm8gc2FuaXR5IGNoZWNrIG5lZWRlZCBmb3Igbm93ICovCglpZiAoIXdyaXRlX2FjcGlfaW50KGhvdGstPmhhbmRsZSwgaG90ay0+bWV0aG9kcy0+ZGlzcGxheV9zZXQsCgkJCSAgICB2YWx1ZSwgTlVMTCkpCgkJcHJpbnRrKEtFUk5fV0FSTklORyAiQXN1cyBBQ1BJOiBFcnJvciBzZXR0aW5nIGRpc3BsYXlcbiIpOwoJcmV0dXJuOwp9CgovKgogKiBOb3csICp0aGlzKiBvbmUgY291bGQgYmUgbW9yZSB1c2VyLWZyaWVuZGx5LCBidXQgc28gZmFyLCBuby1vbmUgaGFzIAogKiBjb21wbGFpbmVkLiBUaGUgc2lnbmlmaWNhbmNlIG9mIGJpdHMgaXMgdGhlIHNhbWUgYXMgaW4gcHJvY193cml0ZV9kaXNwKCkKICovCnN0YXRpYyBpbnQKcHJvY19yZWFkX2Rpc3AoY2hhciAqcGFnZSwgY2hhciAqKnN0YXJ0LCBvZmZfdCBvZmYsIGludCBjb3VudCwgaW50ICplb2YsCgkgICAgICAgdm9pZCAqZGF0YSkKewoJaW50IHZhbHVlID0gMDsKCglpZiAoIXJlYWRfYWNwaV9pbnQoaG90ay0+aGFuZGxlLCBob3RrLT5tZXRob2RzLT5kaXNwbGF5X2dldCwgJnZhbHVlKSkKCQlwcmludGsoS0VSTl9XQVJOSU5HCgkJICAgICAgICJBc3VzIEFDUEk6IEVycm9yIHJlYWRpbmcgZGlzcGxheSBzdGF0dXNcbiIpOwoJdmFsdWUgJj0gMHgwNzsJCS8qIG5lZWRlZCBmb3Igc29tZSBtb2RlbHMsIHNob3VsZG4ndCBodXJ0IG90aGVycyAqLwoJcmV0dXJuIHNwcmludGYocGFnZSwgIiVkXG4iLCB2YWx1ZSk7Cn0KCi8qCiAqIEV4cGVyaW1lbnRhbCBzdXBwb3J0IGZvciBkaXNwbGF5IHN3aXRjaGluZy4gQXMgb2Ygbm93OiAxIHNob3VsZCBhY3RpdmF0ZSAKICogdGhlIExDRCBvdXRwdXQsIDIgc2hvdWxkIGRvIGZvciBDUlQsIGFuZCA0IGZvciBUVi1PdXQuIEFueSBjb21iaW5hdGlvbiAKICogKGJpdHdpc2UpIG9mIHRoZXNlIHdpbGwgc3VmZmljZS4gSSBuZXZlciBhY3R1YWxseSB0ZXN0ZWQgMyBkaXNwbGF5cyBob29rZWQgdXAgCiAqIHNpbXVsdGFuZW91c2x5LCBzbyBiZSB3YXJuZWQuIFNlZSB0aGUgYWNwaTRhc3VzIFJFQURNRSBmb3IgbW9yZSBpbmZvLgogKi8Kc3RhdGljIGludApwcm9jX3dyaXRlX2Rpc3Aoc3RydWN0IGZpbGUgKmZpbGUsIGNvbnN0IGNoYXIgX191c2VyICogYnVmZmVyLAoJCXVuc2lnbmVkIGxvbmcgY291bnQsIHZvaWQgKmRhdGEpCnsKCWludCBydiwgdmFsdWU7CgoJcnYgPSBwYXJzZV9hcmcoYnVmZmVyLCBjb3VudCwgJnZhbHVlKTsKCWlmIChydiA+IDApCgkJc2V0X2Rpc3BsYXkodmFsdWUpOwoJcmV0dXJuIHJ2Owp9Cgp0eXBlZGVmIGludCAocHJvY19yZWFkZnVuYykgKGNoYXIgKnBhZ2UsIGNoYXIgKipzdGFydCwgb2ZmX3Qgb2ZmLCBpbnQgY291bnQsCgkJCSAgICAgaW50ICplb2YsIHZvaWQgKmRhdGEpOwp0eXBlZGVmIGludCAocHJvY193cml0ZWZ1bmMpIChzdHJ1Y3QgZmlsZSAqIGZpbGUsIGNvbnN0IGNoYXIgX191c2VyICogYnVmZmVyLAoJCQkgICAgICB1bnNpZ25lZCBsb25nIGNvdW50LCB2b2lkICpkYXRhKTsKCnN0YXRpYyBpbnQKYXN1c19wcm9jX2FkZChjaGFyICpuYW1lLCBwcm9jX3dyaXRlZnVuYyAqIHdyaXRlZnVuYywKCQkgICAgIHByb2NfcmVhZGZ1bmMgKiByZWFkZnVuYywgbW9kZV90IG1vZGUsCgkJICAgICBzdHJ1Y3QgYWNwaV9kZXZpY2UgKmRldmljZSkKewoJc3RydWN0IHByb2NfZGlyX2VudHJ5ICpwcm9jID0KCSAgICBjcmVhdGVfcHJvY19lbnRyeShuYW1lLCBtb2RlLCBhY3BpX2RldmljZV9kaXIoZGV2aWNlKSk7CglpZiAoIXByb2MpIHsKCQlwcmludGsoS0VSTl9XQVJOSU5HICIgIFVuYWJsZSB0byBjcmVhdGUgJXMgZnMgZW50cnlcbiIsIG5hbWUpOwoJCXJldHVybiAtMTsKCX0KCXByb2MtPndyaXRlX3Byb2MgPSB3cml0ZWZ1bmM7Cglwcm9jLT5yZWFkX3Byb2MgPSByZWFkZnVuYzsKCXByb2MtPmRhdGEgPSBhY3BpX2RyaXZlcl9kYXRhKGRldmljZSk7Cglwcm9jLT5vd25lciA9IFRISVNfTU9EVUxFOwoJcHJvYy0+dWlkID0gYXN1c191aWQ7Cglwcm9jLT5naWQgPSBhc3VzX2dpZDsKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IGFzdXNfaG90a19hZGRfZnMoc3RydWN0IGFjcGlfZGV2aWNlICpkZXZpY2UpCnsKCXN0cnVjdCBwcm9jX2Rpcl9lbnRyeSAqcHJvYzsKCW1vZGVfdCBtb2RlOwoKCS8qCgkgKiBJZiBwYXJhbWV0ZXIgdWlkIG9yIGdpZCBpcyBub3QgY2hhbmdlZCwga2VlcCB0aGUgZGVmYXVsdCBzZXR0aW5nIGZvcgoJICogb3VyIHByb2MgZW50cmllcyAoLXJ3LXJ3LXJ3LSkgZWxzZSwgaXQgbWVhbnMgd2UgY2FyZSBhYm91dCBzZWN1cml0eSwKCSAqIGFuZCB0aGVuIHNldCB0byAtcnctcnctLS0tCgkgKi8KCglpZiAoKGFzdXNfdWlkID09IDApICYmIChhc3VzX2dpZCA9PSAwKSkgewoJCW1vZGUgPSBTX0lGUkVHIHwgU19JUlVHTyB8IFNfSVdVR087Cgl9IGVsc2UgewoJCW1vZGUgPSBTX0lGUkVHIHwgU19JUlVTUiB8IFNfSVJHUlAgfCBTX0lXVVNSIHwgU19JV0dSUDsKCQlwcmludGsoS0VSTl9XQVJOSU5HICIgIGFzdXNfdWlkIGFuZCBhc3VzX2dpZCBwYXJhbWV0ZXJzIGFyZSAiCgkJICAgICAgICJkZXByZWNhdGVkLCB1c2UgY2hvd24gYW5kIGNobW9kIGluc3RlYWQhXG4iKTsKCX0KCglhY3BpX2RldmljZV9kaXIoZGV2aWNlKSA9IGFzdXNfcHJvY19kaXI7CglpZiAoIWFjcGlfZGV2aWNlX2RpcihkZXZpY2UpKQoJCXJldHVybiAtRU5PREVWOwoKCXByb2MgPSBjcmVhdGVfcHJvY19lbnRyeShQUk9DX0lORk8sIG1vZGUsIGFjcGlfZGV2aWNlX2RpcihkZXZpY2UpKTsKCWlmIChwcm9jKSB7CgkJcHJvYy0+cmVhZF9wcm9jID0gcHJvY19yZWFkX2luZm87CgkJcHJvYy0+ZGF0YSA9IGFjcGlfZHJpdmVyX2RhdGEoZGV2aWNlKTsKCQlwcm9jLT5vd25lciA9IFRISVNfTU9EVUxFOwoJCXByb2MtPnVpZCA9IGFzdXNfdWlkOwoJCXByb2MtPmdpZCA9IGFzdXNfZ2lkOwoJfSBlbHNlIHsKCQlwcmludGsoS0VSTl9XQVJOSU5HICIgIFVuYWJsZSB0byBjcmVhdGUgIiBQUk9DX0lORk8KCQkgICAgICAgIiBmcyBlbnRyeVxuIik7Cgl9CgoJaWYgKGhvdGstPm1ldGhvZHMtPm10X3dsZWQpIHsKCQlhc3VzX3Byb2NfYWRkKFBST0NfV0xFRCwgJnByb2Nfd3JpdGVfd2xlZCwgJnByb2NfcmVhZF93bGVkLAoJCQkgICAgICBtb2RlLCBkZXZpY2UpOwoJfQoKCWlmIChob3RrLT5tZXRob2RzLT5tdF9sZWRkKSB7CgkJYXN1c19wcm9jX2FkZChQUk9DX0xFREQsICZwcm9jX3dyaXRlX2xlZGQsICZwcm9jX3JlYWRfbGVkZCwKCQkJICAgICAgbW9kZSwgZGV2aWNlKTsKCX0KCglpZiAoaG90ay0+bWV0aG9kcy0+bXRfbWxlZCkgewoJCWFzdXNfcHJvY19hZGQoUFJPQ19NTEVELCAmcHJvY193cml0ZV9tbGVkLCAmcHJvY19yZWFkX21sZWQsCgkJCSAgICAgIG1vZGUsIGRldmljZSk7Cgl9CgoJaWYgKGhvdGstPm1ldGhvZHMtPm10X3RsZWQpIHsKCQlhc3VzX3Byb2NfYWRkKFBST0NfVExFRCwgJnByb2Nfd3JpdGVfdGxlZCwgJnByb2NfcmVhZF90bGVkLAoJCQkgICAgICBtb2RlLCBkZXZpY2UpOwoJfQoKCWlmIChob3RrLT5tZXRob2RzLT5tdF9idF9zd2l0Y2gpIHsKCQlhc3VzX3Byb2NfYWRkKFBST0NfQlQsICZwcm9jX3dyaXRlX2JsdWV0b290aCwKCQkJICAgICAgJnByb2NfcmVhZF9ibHVldG9vdGgsIG1vZGUsIGRldmljZSk7Cgl9CgoJLyogCgkgKiBXZSBuZWVkIGJvdGggcmVhZCBub2RlIGFuZCB3cml0ZSBtZXRob2QgYXMgTENEIHN3aXRjaCBpcyBhbHNvIGFjY2Vzc2libGUKCSAqIGZyb20ga2V5Ym9hcmQgCgkgKi8KCWlmIChob3RrLT5tZXRob2RzLT5tdF9sY2Rfc3dpdGNoICYmIGhvdGstPm1ldGhvZHMtPmxjZF9zdGF0dXMpIHsKCQlhc3VzX3Byb2NfYWRkKFBST0NfTENELCAmcHJvY193cml0ZV9sY2QsICZwcm9jX3JlYWRfbGNkLCBtb2RlLAoJCQkgICAgICBkZXZpY2UpOwoJfQoKCWlmICgoaG90ay0+bWV0aG9kcy0+YnJpZ2h0bmVzc191cCAmJiBob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX2Rvd24pIHx8CgkgICAgKGhvdGstPm1ldGhvZHMtPmJyaWdodG5lc3NfZ2V0ICYmIGhvdGstPm1ldGhvZHMtPmJyaWdodG5lc3Nfc2V0KSkgewoJCWFzdXNfcHJvY19hZGQoUFJPQ19CUk4sICZwcm9jX3dyaXRlX2JybiwgJnByb2NfcmVhZF9icm4sIG1vZGUsCgkJCSAgICAgIGRldmljZSk7Cgl9CgoJaWYgKGhvdGstPm1ldGhvZHMtPmRpc3BsYXlfc2V0KSB7CgkJYXN1c19wcm9jX2FkZChQUk9DX0RJU1AsICZwcm9jX3dyaXRlX2Rpc3AsICZwcm9jX3JlYWRfZGlzcCwKCQkJICAgICAgbW9kZSwgZGV2aWNlKTsKCX0KCglyZXR1cm4gMDsKfQoKc3RhdGljIGludCBhc3VzX2hvdGtfcmVtb3ZlX2ZzKHN0cnVjdCBhY3BpX2RldmljZSAqZGV2aWNlKQp7CglpZiAoYWNwaV9kZXZpY2VfZGlyKGRldmljZSkpIHsKCQlyZW1vdmVfcHJvY19lbnRyeShQUk9DX0lORk8sIGFjcGlfZGV2aWNlX2RpcihkZXZpY2UpKTsKCQlpZiAoaG90ay0+bWV0aG9kcy0+bXRfd2xlZCkKCQkJcmVtb3ZlX3Byb2NfZW50cnkoUFJPQ19XTEVELCBhY3BpX2RldmljZV9kaXIoZGV2aWNlKSk7CgkJaWYgKGhvdGstPm1ldGhvZHMtPm10X21sZWQpCgkJCXJlbW92ZV9wcm9jX2VudHJ5KFBST0NfTUxFRCwgYWNwaV9kZXZpY2VfZGlyKGRldmljZSkpOwoJCWlmIChob3RrLT5tZXRob2RzLT5tdF90bGVkKQoJCQlyZW1vdmVfcHJvY19lbnRyeShQUk9DX1RMRUQsIGFjcGlfZGV2aWNlX2RpcihkZXZpY2UpKTsKCQlpZiAoaG90ay0+bWV0aG9kcy0+bXRfbGVkZCkKCQkJcmVtb3ZlX3Byb2NfZW50cnkoUFJPQ19MRURELCBhY3BpX2RldmljZV9kaXIoZGV2aWNlKSk7CgkJaWYgKGhvdGstPm1ldGhvZHMtPm10X2J0X3N3aXRjaCkKCQkJcmVtb3ZlX3Byb2NfZW50cnkoUFJPQ19CVCwgYWNwaV9kZXZpY2VfZGlyKGRldmljZSkpOwoJCWlmIChob3RrLT5tZXRob2RzLT5tdF9sY2Rfc3dpdGNoICYmIGhvdGstPm1ldGhvZHMtPmxjZF9zdGF0dXMpCgkJCXJlbW92ZV9wcm9jX2VudHJ5KFBST0NfTENELCBhY3BpX2RldmljZV9kaXIoZGV2aWNlKSk7CgkJaWYgKChob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX3VwCgkJICAgICAmJiBob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX2Rvd24pCgkJICAgIHx8IChob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX2dldAoJCQkmJiBob3RrLT5tZXRob2RzLT5icmlnaHRuZXNzX3NldCkpCgkJCXJlbW92ZV9wcm9jX2VudHJ5KFBST0NfQlJOLCBhY3BpX2RldmljZV9kaXIoZGV2aWNlKSk7CgkJaWYgKGhvdGstPm1ldGhvZHMtPmRpc3BsYXlfc2V0KQoJCQlyZW1vdmVfcHJvY19lbnRyeShQUk9DX0RJU1AsIGFjcGlfZGV2aWNlX2RpcihkZXZpY2UpKTsKCX0KCXJldHVybiAwOwp9CgpzdGF0aWMgdm9pZCBhc3VzX2hvdGtfbm90aWZ5KGFjcGlfaGFuZGxlIGhhbmRsZSwgdTMyIGV2ZW50LCB2b2lkICpkYXRhKQp7CgkvKiBUT0RPIEZpbmQgYSBiZXR0ZXIgd2F5IHRvIGhhbmRsZSBldmVudHMgY291bnQuICovCglpZiAoIWhvdGspCgkJcmV0dXJuOwoKCWlmICgoZXZlbnQgJiB+KCh1MzIpIEJSX1VQKSkgPCAxNikgewoJCWhvdGstPmJyaWdodG5lc3MgPSAoZXZlbnQgJiB+KCh1MzIpIEJSX1VQKSk7Cgl9IGVsc2UgaWYgKChldmVudCAmIH4oKHUzMikgQlJfRE9XTikpIDwgMTYpIHsKCQlob3RrLT5icmlnaHRuZXNzID0gKGV2ZW50ICYgfigodTMyKSBCUl9ET1dOKSk7Cgl9CgoJYWNwaV9idXNfZ2VuZXJhdGVfZXZlbnQoaG90ay0+ZGV2aWNlLCBldmVudCwKCQkJCWhvdGstPmV2ZW50X2NvdW50W2V2ZW50ICUgMTI4XSsrKTsKCglyZXR1cm47Cn0KCi8qCiAqIE1hdGNoIHRoZSBtb2RlbCBzdHJpbmcgdG8gdGhlIGxpc3Qgb2Ygc3VwcG9ydGVkIG1vZGVscy4gUmV0dXJuIEVORF9NT0RFTCBpZgogKiBubyBtYXRjaCBvciBtb2RlbCBpcyBOVUxMLgogKi8Kc3RhdGljIGludCBhc3VzX21vZGVsX21hdGNoKGNoYXIgKm1vZGVsKQp7CglpZiAobW9kZWwgPT0gTlVMTCkKCQlyZXR1cm4gRU5EX01PREVMOwoKCWlmIChzdHJuY21wKG1vZGVsLCAiTDNEIiwgMykgPT0gMCkKCQlyZXR1cm4gTDNEOwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkwyRSIsIDMpID09IDAgfHwKCQkgc3RybmNtcChtb2RlbCwgIkwzSCIsIDMpID09IDAgfHwgc3RybmNtcChtb2RlbCwgIkw1RCIsIDMpID09IDApCgkJcmV0dXJuIEwzSDsKCWVsc2UgaWYgKHN0cm5jbXAobW9kZWwsICJMMyIsIDIpID09IDAgfHwgc3RybmNtcChtb2RlbCwgIkwyQiIsIDMpID09IDApCgkJcmV0dXJuIEwzQzsKCWVsc2UgaWYgKHN0cm5jbXAobW9kZWwsICJMOEwiLCAzKSA9PSAwKQoJCXJldHVybiBMOEw7CgllbHNlIGlmIChzdHJuY21wKG1vZGVsLCAiTDRSIiwgMykgPT0gMCkKCQlyZXR1cm4gTDRSOwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIk02TiIsIDMpID09IDAgfHwgc3RybmNtcChtb2RlbCwgIlczTiIsIDMpID09IDApCgkJcmV0dXJuIE02TjsKCWVsc2UgaWYgKHN0cm5jbXAobW9kZWwsICJNNlIiLCAzKSA9PSAwIHx8IHN0cm5jbXAobW9kZWwsICJBM0ciLCAzKSA9PSAwKQoJCXJldHVybiBNNlI7CgllbHNlIGlmIChzdHJuY21wKG1vZGVsLCAiTTJOIiwgMykgPT0gMCB8fAoJCSBzdHJuY21wKG1vZGVsLCAiTTNOIiwgMykgPT0gMCB8fAoJCSBzdHJuY21wKG1vZGVsLCAiTTVOIiwgMykgPT0gMCB8fAoJCSBzdHJuY21wKG1vZGVsLCAiTTZOIiwgMykgPT0gMCB8fAoJCSBzdHJuY21wKG1vZGVsLCAiUzFOIiwgMykgPT0gMCB8fAoJCSBzdHJuY21wKG1vZGVsLCAiUzVOIiwgMykgPT0gMCB8fCBzdHJuY21wKG1vZGVsLCAiVzFOIiwgMykgPT0gMCkKCQlyZXR1cm4geHhOOwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIk0xIiwgMikgPT0gMCkKCQlyZXR1cm4gTTFBOwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIk0yIiwgMikgPT0gMCB8fCBzdHJuY21wKG1vZGVsLCAiTDRFIiwgMykgPT0gMCkKCQlyZXR1cm4gTTJFOwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkwyIiwgMikgPT0gMCkKCQlyZXR1cm4gTDJEOwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkw4IiwgMikgPT0gMCkKCQlyZXR1cm4gUzF4OwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkQxIiwgMikgPT0gMCkKCQlyZXR1cm4gRDF4OwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkExIiwgMikgPT0gMCkKCQlyZXR1cm4gQTF4OwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkEyIiwgMikgPT0gMCkKCQlyZXR1cm4gQTJ4OwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkoxIiwgMikgPT0gMCkKCQlyZXR1cm4gUzJ4OwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkw1IiwgMikgPT0gMCkKCQlyZXR1cm4gTDV4OwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIkE0RyIsIDMpID09IDApCgkJcmV0dXJuIEE0RzsKCWVsc2UgaWYgKHN0cm5jbXAobW9kZWwsICJXMU4iLCAzKSA9PSAwKQoJCXJldHVybiBXMU47CgllbHNlIGlmIChzdHJuY21wKG1vZGVsLCAiVzNWIiwgMykgPT0gMCkKCQlyZXR1cm4gVzNWOwoJZWxzZSBpZiAoc3RybmNtcChtb2RlbCwgIlc1QSIsIDMpID09IDApCgkJcmV0dXJuIFc1QTsKCWVsc2UKCQlyZXR1cm4gRU5EX01PREVMOwp9CgovKgogKiBUaGlzIGZ1bmN0aW9uIGlzIHVzZWQgdG8gaW5pdGlhbGl6ZSB0aGUgaG90ayB3aXRoIHJpZ2h0IHZhbHVlcy4gSW4gdGhpcwogKiBtZXRob2QsIHdlIGNhbiBtYWtlIGFsbCB0aGUgZGV0ZWN0aW9uIHdlIHdhbnQsIGFuZCBtb2RpZnkgdGhlIGhvdGsgc3RydWN0CiAqLwpzdGF0aWMgaW50IGFzdXNfaG90a19nZXRfaW5mbyh2b2lkKQp7CglzdHJ1Y3QgYWNwaV9idWZmZXIgYnVmZmVyID0geyBBQ1BJX0FMTE9DQVRFX0JVRkZFUiwgTlVMTCB9OwoJc3RydWN0IGFjcGlfYnVmZmVyIGRzZHQgPSB7IEFDUElfQUxMT0NBVEVfQlVGRkVSLCBOVUxMIH07Cgl1bmlvbiBhY3BpX29iamVjdCAqbW9kZWwgPSBOVUxMOwoJaW50IGJzdHNfcmVzdWx0OwoJY2hhciAqc3RyaW5nID0gTlVMTDsKCWFjcGlfc3RhdHVzIHN0YXR1czsKCgkvKgoJICogR2V0IERTRFQgaGVhZGVycyBlYXJseSBlbm91Z2ggdG8gYWxsb3cgZm9yIGRpZmZlcmVudGlhdGluZyBiZXR3ZWVuIAoJICogbW9kZWxzLCBidXQgbGF0ZSBlbm91Z2ggdG8gYWxsb3cgYWNwaV9idXNfcmVnaXN0ZXJfZHJpdmVyKCkgdG8gZmFpbCAKCSAqIGJlZm9yZSBkb2luZyBhbnl0aGluZyBBQ1BJLXNwZWNpZmljLiBTaG91bGQgd2UgZW5jb3VudGVyIGEgbWFjaGluZSwKCSAqIHdoaWNoIG5lZWRzIHNwZWNpYWwgaGFuZGxpbmcgKGkuZS4gaXRzIGhvdGtleSBkZXZpY2UgaGFzIGEgZGlmZmVyZW50CgkgKiBISUQpLCB0aGlzIGJpdCB3aWxsIGJlIG1vdmVkLiBBIGdsb2JhbCB2YXJpYWJsZSBhc3VzX2luZm8gY29udGFpbnMKCSAqIHRoZSBEU0RUIGhlYWRlci4KCSAqLwoJc3RhdHVzID0gYWNwaV9nZXRfdGFibGUoQUNQSV9UQUJMRV9JRF9EU0RULCAxLCAmZHNkdCk7CglpZiAoQUNQSV9GQUlMVVJFKHN0YXR1cykpCgkJcHJpbnRrKEtFUk5fV0FSTklORyAiICBDb3VsZG4ndCBnZXQgdGhlIERTRFQgdGFibGUgaGVhZGVyXG4iKTsKCWVsc2UKCQlhc3VzX2luZm8gPSAoc3RydWN0IGFjcGlfdGFibGVfaGVhZGVyICopZHNkdC5wb2ludGVyOwoKCS8qIFdlIGhhdmUgdG8gd3JpdGUgMCBvbiBpbml0IHRoaXMgZmFyIGZvciBhbGwgQVNVUyBtb2RlbHMgKi8KCWlmICghd3JpdGVfYWNwaV9pbnQoaG90ay0+aGFuZGxlLCAiSU5JVCIsIDAsICZidWZmZXIpKSB7CgkJcHJpbnRrKEtFUk5fRVJSICIgIEhvdGtleSBpbml0aWFsaXphdGlvbiBmYWlsZWRcbiIpOwoJCXJldHVybiAtRU5PREVWOwoJfQoKCS8qIFRoaXMgbmVlZHMgdG8gYmUgY2FsbGVkIGZvciBzb21lIGxhcHRvcHMgdG8gaW5pdCBwcm9wZXJseSAqLwoJaWYgKCFyZWFkX2FjcGlfaW50KGhvdGstPmhhbmRsZSwgIkJTVFMiLCAmYnN0c19yZXN1bHQpKQoJCXByaW50ayhLRVJOX1dBUk5JTkcgIiAgRXJyb3IgY2FsbGluZyBCU1RTXG4iKTsKCWVsc2UgaWYgKGJzdHNfcmVzdWx0KQoJCXByaW50ayhLRVJOX05PVElDRSAiICBCU1RTIGNhbGxlZCwgMHglMDJ4IHJldHVybmVkXG4iLAoJCSAgICAgICBic3RzX3Jlc3VsdCk7CgoJLyoKCSAqIFRyeSB0byBtYXRjaCB0aGUgb2JqZWN0IHJldHVybmVkIGJ5IElOSVQgdG8gdGhlIHNwZWNpZmljIG1vZGVsLgoJICogSGFuZGxlIGV2ZXJ5IHBvc3NpYmxlIG9iamVjdCAob3IgdGhlIGxhY2sgb2YgdGhlcmVvZikgdGhlIERTRFQgCgkgKiB3cml0ZXJzIG1pZ2h0IHRocm93IGF0IHVzLiBXaGVuIGluIHRyb3VibGUsIHdlIHBhc3MgTlVMTCB0byAKCSAqIGFzdXNfbW9kZWxfbWF0Y2goKSBhbmQgdHJ5IHNvbWV0aGluZyBjb21wbGV0ZWx5IGRpZmZlcmVudC4KCSAqLwoJaWYgKGJ1ZmZlci5wb2ludGVyKSB7CgkJbW9kZWwgPSAodW5pb24gYWNwaV9vYmplY3QgKilidWZmZXIucG9pbnRlcjsKCQlzd2l0Y2ggKG1vZGVsLT50eXBlKSB7CgkJY2FzZSBBQ1BJX1RZUEVfU1RSSU5HOgoJCQlzdHJpbmcgPSBtb2RlbC0+c3RyaW5nLnBvaW50ZXI7CgkJCWJyZWFrOwoJCWNhc2UgQUNQSV9UWVBFX0JVRkZFUjoKCQkJc3RyaW5nID0gbW9kZWwtPmJ1ZmZlci5wb2ludGVyOwoJCQlicmVhazsKCQlkZWZhdWx0OgoJCQlrZnJlZShtb2RlbCk7CgkJCWJyZWFrOwoJCX0KCX0KCWhvdGstPm1vZGVsID0gYXN1c19tb2RlbF9tYXRjaChzdHJpbmcpOwoJaWYgKGhvdGstPm1vZGVsID09IEVORF9NT0RFTCkgewkvKiBtYXRjaCBmYWlsZWQgKi8KCQlpZiAoYXN1c19pbmZvICYmCgkJICAgIHN0cm5jbXAoYXN1c19pbmZvLT5vZW1fdGFibGVfaWQsICJPREVNIiwgNCkgPT0gMCkgewoJCQlob3RrLT5tb2RlbCA9IFAzMDsKCQkJcHJpbnRrKEtFUk5fTk9USUNFCgkJCSAgICAgICAiICBTYW1zdW5nIFAzMCBkZXRlY3RlZCwgc3VwcG9ydGVkXG4iKTsKCQl9IGVsc2UgewoJCQlob3RrLT5tb2RlbCA9IE0yRTsKCQkJcHJpbnRrKEtFUk5fTk9USUNFICIgIHVuc3VwcG9ydGVkIG1vZGVsICVzLCB0cnlpbmcgIgoJCQkgICAgICAgImRlZmF1bHQgdmFsdWVzXG4iLCBzdHJpbmcpOwoJCQlwcmludGsoS0VSTl9OT1RJQ0UKCQkJICAgICAgICIgIHNlbmQgL3Byb2MvYWNwaS9kc2R0IHRvIHRoZSBkZXZlbG9wZXJzXG4iKTsKCQl9CgkJaG90ay0+bWV0aG9kcyA9ICZtb2RlbF9jb25mW2hvdGstPm1vZGVsXTsKCQlyZXR1cm4gQUVfT0s7Cgl9Cglob3RrLT5tZXRob2RzID0gJm1vZGVsX2NvbmZbaG90ay0+bW9kZWxdOwoJcHJpbnRrKEtFUk5fTk9USUNFICIgICVzIG1vZGVsIGRldGVjdGVkLCBzdXBwb3J0ZWRcbiIsIHN0cmluZyk7CgoJLyogU29ydCBvZiBwZXItbW9kZWwgYmxhY2tsaXN0ICovCglpZiAoc3RybmNtcChzdHJpbmcsICJMMkIiLCAzKSA9PSAwKQoJCWhvdGstPm1ldGhvZHMtPmxjZF9zdGF0dXMgPSBOVUxMOwoJLyogTDJCIGlzIHNpbWlsYXIgZW5vdWdoIHRvIEwzQyB0byB1c2UgaXRzIHNldHRpbmdzLCB3aXRoIHRoaXMgb25seSAKCSAgIGV4Y2VwdGlvbiAqLwoJZWxzZSBpZiAoc3RybmNtcChzdHJpbmcsICJBM0ciLCAzKSA9PSAwKQoJCWhvdGstPm1ldGhvZHMtPmxjZF9zdGF0dXMgPSAiXFxCTEZHIjsKCS8qIEEzRyBpcyBsaWtlIE02UiAqLwoJZWxzZSBpZiAoc3RybmNtcChzdHJpbmcsICJTNU4iLCAzKSA9PSAwIHx8CgkJIHN0cm5jbXAoc3RyaW5nLCAiTTVOIiwgMykgPT0gMCB8fAoJCSBzdHJuY21wKHN0cmluZywgIlczTiIsIDMpID09IDApCgkJaG90ay0+bWV0aG9kcy0+bXRfbWxlZCA9IE5VTEw7CgkvKiBTNU4sIE01TiBhbmQgVzNOIGhhdmUgbm8gTUxFRCAqLwoJZWxzZSBpZiAoc3RybmNtcChzdHJpbmcsICJMNUQiLCAzKSA9PSAwKQoJCWhvdGstPm1ldGhvZHMtPm10X3dsZWQgPSBOVUxMOwoJLyogTDVEJ3MgV0xFRCBpcyBub3QgY29udHJvbGxlZCBieSBBQ1BJICovCgllbHNlIGlmIChzdHJuY21wKHN0cmluZywgIk0yTiIsIDMpID09IDAgfHwKCQkgc3RybmNtcChzdHJpbmcsICJXM1YiLCAzKSA9PSAwIHx8CgkJIHN0cm5jbXAoc3RyaW5nLCAiUzFOIiwgMykgPT0gMCkKCQlob3RrLT5tZXRob2RzLT5tdF93bGVkID0gIldMRUQiOwoJLyogTTJOLCBTMU4gYW5kIFczViBoYXZlIGEgdXNhYmxlIFdMRUQgKi8KCWVsc2UgaWYgKGFzdXNfaW5mbykgewoJCWlmIChzdHJuY21wKGFzdXNfaW5mby0+b2VtX3RhYmxlX2lkLCAiTDEiLCAyKSA9PSAwKQoJCQlob3RrLT5tZXRob2RzLT5tbGVkX3N0YXR1cyA9IE5VTEw7CgkJLyogUzEzMDBBIHJlcG9ydHMgTDg0RiwgYnV0IEwxNDAwQiB0b28sIGFjY291bnQgZm9yIHRoYXQgKi8KCX0KCglrZnJlZShtb2RlbCk7CgoJcmV0dXJuIEFFX09LOwp9CgpzdGF0aWMgaW50IGFzdXNfaG90a19jaGVjayh2b2lkKQp7CglpbnQgcmVzdWx0ID0gMDsKCglyZXN1bHQgPSBhY3BpX2J1c19nZXRfc3RhdHVzKGhvdGstPmRldmljZSk7CglpZiAocmVzdWx0KQoJCXJldHVybiByZXN1bHQ7CgoJaWYgKGhvdGstPmRldmljZS0+c3RhdHVzLnByZXNlbnQpIHsKCQlyZXN1bHQgPSBhc3VzX2hvdGtfZ2V0X2luZm8oKTsKCX0gZWxzZSB7CgkJcHJpbnRrKEtFUk5fRVJSICIgIEhvdGtleSBkZXZpY2Ugbm90IHByZXNlbnQsIGFib3J0aW5nXG4iKTsKCQlyZXR1cm4gLUVJTlZBTDsKCX0KCglyZXR1cm4gcmVzdWx0Owp9CgpzdGF0aWMgaW50IGFzdXNfaG90a19mb3VuZDsKCnN0YXRpYyBpbnQgYXN1c19ob3RrX2FkZChzdHJ1Y3QgYWNwaV9kZXZpY2UgKmRldmljZSkKewoJYWNwaV9zdGF0dXMgc3RhdHVzID0gQUVfT0s7CglpbnQgcmVzdWx0OwoKCWlmICghZGV2aWNlKQoJCXJldHVybiAtRUlOVkFMOwoKCXByaW50ayhLRVJOX05PVElDRSAiQXN1cyBMYXB0b3AgQUNQSSBFeHRyYXMgdmVyc2lvbiAlc1xuIiwKCSAgICAgICBBU1VTX0FDUElfVkVSU0lPTik7CgoJaG90ayA9CgkgICAgKHN0cnVjdCBhc3VzX2hvdGsgKilrbWFsbG9jKHNpemVvZihzdHJ1Y3QgYXN1c19ob3RrKSwgR0ZQX0tFUk5FTCk7CglpZiAoIWhvdGspCgkJcmV0dXJuIC1FTk9NRU07CgltZW1zZXQoaG90aywgMCwgc2l6ZW9mKHN0cnVjdCBhc3VzX2hvdGspKTsKCglob3RrLT5oYW5kbGUgPSBkZXZpY2UtPmhhbmRsZTsKCXN0cmNweShhY3BpX2RldmljZV9uYW1lKGRldmljZSksIEFDUElfSE9US19ERVZJQ0VfTkFNRSk7CglzdHJjcHkoYWNwaV9kZXZpY2VfY2xhc3MoZGV2aWNlKSwgQUNQSV9IT1RLX0NMQVNTKTsKCWFjcGlfZHJpdmVyX2RhdGEoZGV2aWNlKSA9IGhvdGs7Cglob3RrLT5kZXZpY2UgPSBkZXZpY2U7CgoJcmVzdWx0ID0gYXN1c19ob3RrX2NoZWNrKCk7CglpZiAocmVzdWx0KQoJCWdvdG8gZW5kOwoKCXJlc3VsdCA9IGFzdXNfaG90a19hZGRfZnMoZGV2aWNlKTsKCWlmIChyZXN1bHQpCgkJZ290byBlbmQ7CgoJLyoKCSAqIFdlIGluc3RhbGwgdGhlIGhhbmRsZXIsIGl0IHdpbGwgcmVjZWl2ZSB0aGUgaG90ayBpbiBwYXJhbWV0ZXIsIHNvLCB3ZQoJICogY291bGQgYWRkIG90aGVyIGRhdGEgdG8gdGhlIGhvdGsgc3RydWN0CgkgKi8KCXN0YXR1cyA9IGFjcGlfaW5zdGFsbF9ub3RpZnlfaGFuZGxlcihob3RrLT5oYW5kbGUsIEFDUElfU1lTVEVNX05PVElGWSwKCQkJCQkgICAgIGFzdXNfaG90a19ub3RpZnksIGhvdGspOwoJaWYgKEFDUElfRkFJTFVSRShzdGF0dXMpKQoJCXByaW50ayhLRVJOX0VSUiAiICBFcnJvciBpbnN0YWxsaW5nIG5vdGlmeSBoYW5kbGVyXG4iKTsKCgkvKiBGb3IgbGFwdG9wcyB3aXRob3V0IEdQTFY6IGluaXQgdGhlIGhvdGstPmJyaWdodG5lc3MgdmFsdWUgKi8KCWlmICgoIWhvdGstPm1ldGhvZHMtPmJyaWdodG5lc3NfZ2V0KQoJICAgICYmICghaG90ay0+bWV0aG9kcy0+YnJpZ2h0bmVzc19zdGF0dXMpCgkgICAgJiYgKGhvdGstPm1ldGhvZHMtPmJyaWdodG5lc3NfdXAgJiYgaG90ay0+bWV0aG9kcy0+YnJpZ2h0bmVzc19kb3duKSkgewoJCXN0YXR1cyA9CgkJICAgIGFjcGlfZXZhbHVhdGVfb2JqZWN0KE5VTEwsIGhvdGstPm1ldGhvZHMtPmJyaWdodG5lc3NfZG93biwKCQkJCQkgTlVMTCwgTlVMTCk7CgkJaWYgKEFDUElfRkFJTFVSRShzdGF0dXMpKQoJCQlwcmludGsoS0VSTl9XQVJOSU5HICIgIEVycm9yIGNoYW5naW5nIGJyaWdodG5lc3NcbiIpOwoJCWVsc2UgewoJCQlzdGF0dXMgPQoJCQkgICAgYWNwaV9ldmFsdWF0ZV9vYmplY3QoTlVMTCwKCQkJCQkJIGhvdGstPm1ldGhvZHMtPmJyaWdodG5lc3NfdXAsCgkJCQkJCSBOVUxMLCBOVUxMKTsKCQkJaWYgKEFDUElfRkFJTFVSRShzdGF0dXMpKQoJCQkJcHJpbnRrKEtFUk5fV0FSTklORyAiICBTdHJhbmdlLCBlcnJvciBjaGFuZ2luZyIKCQkJCSAgICAgICAiIGJyaWdodG5lc3NcbiIpOwoJCX0KCX0KCglhc3VzX2hvdGtfZm91bmQgPSAxOwoKCS8qIExFRCBkaXNwbGF5IGlzIG9mZiBieSBkZWZhdWx0ICovCglob3RrLT5sZWRkX3N0YXR1cyA9IDB4RkZGOwoKICAgICAgZW5kOgoJaWYgKHJlc3VsdCkgewoJCWtmcmVlKGhvdGspOwoJfQoKCXJldHVybiByZXN1bHQ7Cn0KCnN0YXRpYyBpbnQgYXN1c19ob3RrX3JlbW92ZShzdHJ1Y3QgYWNwaV9kZXZpY2UgKmRldmljZSwgaW50IHR5cGUpCnsKCWFjcGlfc3RhdHVzIHN0YXR1cyA9IDA7CgoJaWYgKCFkZXZpY2UgfHwgIWFjcGlfZHJpdmVyX2RhdGEoZGV2aWNlKSkKCQlyZXR1cm4gLUVJTlZBTDsKCglzdGF0dXMgPSBhY3BpX3JlbW92ZV9ub3RpZnlfaGFuZGxlcihob3RrLT5oYW5kbGUsIEFDUElfU1lTVEVNX05PVElGWSwKCQkJCQkgICAgYXN1c19ob3RrX25vdGlmeSk7CglpZiAoQUNQSV9GQUlMVVJFKHN0YXR1cykpCgkJcHJpbnRrKEtFUk5fRVJSICJBc3VzIEFDUEk6IEVycm9yIHJlbW92aW5nIG5vdGlmeSBoYW5kbGVyXG4iKTsKCglhc3VzX2hvdGtfcmVtb3ZlX2ZzKGRldmljZSk7CgoJa2ZyZWUoaG90ayk7CgoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgX19pbml0IGFzdXNfYWNwaV9pbml0KHZvaWQpCnsKCWludCByZXN1bHQ7CgoJaWYgKGFjcGlfZGlzYWJsZWQpCgkJcmV0dXJuIC1FTk9ERVY7CgoJaWYgKCFhY3BpX3NwZWNpZmljX2hvdGtleV9lbmFibGVkKSB7CgkJcHJpbnRrKEtFUk5fRVJSICJVc2luZyBnZW5lcmljIGhvdGtleSBkcml2ZXJcbiIpOwoJCXJldHVybiAtRU5PREVWOwoJfQoJYXN1c19wcm9jX2RpciA9IHByb2NfbWtkaXIoUFJPQ19BU1VTLCBhY3BpX3Jvb3RfZGlyKTsKCWlmICghYXN1c19wcm9jX2RpcikgewoJCXByaW50ayhLRVJOX0VSUiAiQXN1cyBBQ1BJOiBVbmFibGUgdG8gY3JlYXRlIC9wcm9jIGVudHJ5XG4iKTsKCQlyZXR1cm4gLUVOT0RFVjsKCX0KCWFzdXNfcHJvY19kaXItPm93bmVyID0gVEhJU19NT0RVTEU7CgoJcmVzdWx0ID0gYWNwaV9idXNfcmVnaXN0ZXJfZHJpdmVyKCZhc3VzX2hvdGtfZHJpdmVyKTsKCWlmIChyZXN1bHQgPCAwKSB7CgkJcmVtb3ZlX3Byb2NfZW50cnkoUFJPQ19BU1VTLCBhY3BpX3Jvb3RfZGlyKTsKCQlyZXR1cm4gcmVzdWx0OwoJfQoKCS8qCgkgKiBUaGlzIGlzIGEgYml0IG9mIGEga2x1ZGdlLiAgV2Ugb25seSB3YW50IHRoaXMgbW9kdWxlIGxvYWRlZAoJICogZm9yIEFTVVMgc3lzdGVtcywgYnV0IHRoZXJlJ3MgY3VycmVudGx5IG5vIHdheSB0byBwcm9iZSB0aGUKCSAqIEFDUEkgbmFtZXNwYWNlIGZvciBBU1VTIEhJRHMuICBTbyB3ZSBqdXN0IHJldHVybiBmYWlsdXJlIGlmCgkgKiB3ZSBkaWRuJ3QgZmluZCBvbmUsIHdoaWNoIHdpbGwgY2F1c2UgdGhlIG1vZHVsZSB0byBiZQoJICogdW5sb2FkZWQuCgkgKi8KCWlmICghYXN1c19ob3RrX2ZvdW5kKSB7CgkJYWNwaV9idXNfdW5yZWdpc3Rlcl9kcml2ZXIoJmFzdXNfaG90a19kcml2ZXIpOwoJCXJlbW92ZV9wcm9jX2VudHJ5KFBST0NfQVNVUywgYWNwaV9yb290X2Rpcik7CgkJcmV0dXJuIHJlc3VsdDsKCX0KCglyZXR1cm4gMDsKfQoKc3RhdGljIHZvaWQgX19leGl0IGFzdXNfYWNwaV9leGl0KHZvaWQpCnsKCWFjcGlfYnVzX3VucmVnaXN0ZXJfZHJpdmVyKCZhc3VzX2hvdGtfZHJpdmVyKTsKCXJlbW92ZV9wcm9jX2VudHJ5KFBST0NfQVNVUywgYWNwaV9yb290X2Rpcik7CgoJa2ZyZWUoYXN1c19pbmZvKTsKCglyZXR1cm47Cn0KCm1vZHVsZV9pbml0KGFzdXNfYWNwaV9pbml0KTsKbW9kdWxlX2V4aXQoYXN1c19hY3BpX2V4aXQpOwo=