LyogJElkOiBoZmNfcGNpLmMsdiAxLjQ4LjIuNCAyMDA0LzAyLzExIDEzOjIxOjMzIGtlaWwgRXhwICQKICoKICogbG93IGxldmVsIGRyaXZlciBmb3IgQ0NEtHMgaGZjLXBjaSBiYXNlZCBjYXJkcwogKgogKiBBdXRob3IgICAgICAgV2VybmVyIENvcm5lbGl1cwogKiAgICAgICAgICAgICAgYmFzZWQgb24gZXhpc3RpbmcgZHJpdmVyIGZvciBDQ0QgaGZjIElTQSBjYXJkcwogKiBDb3B5cmlnaHQgICAgYnkgV2VybmVyIENvcm5lbGl1cyAgPHdlcm5lckBpc2RuNGxpbnV4LmRlPgogKiAgICAgICAgICAgICAgYnkgS2Fyc3RlbiBLZWlsICAgICAgPGtlaWxAaXNkbjRsaW51eC5kZT4KICoKICogVGhpcyBzb2Z0d2FyZSBtYXkgYmUgdXNlZCBhbmQgZGlzdHJpYnV0ZWQgYWNjb3JkaW5nIHRvIHRoZSB0ZXJtcwogKiBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UsIGluY29ycG9yYXRlZCBoZXJlaW4gYnkgcmVmZXJlbmNlLgogKgogKiBGb3IgY2hhbmdlcyBhbmQgbW9kaWZpY2F0aW9ucyBwbGVhc2UgcmVhZAogKiBEb2N1bWVudGF0aW9uL2lzZG4vSGlTYXguY2VydAogKgogKi8KCiNpbmNsdWRlIDxsaW51eC9pbml0Lmg+CiNpbmNsdWRlICJoaXNheC5oIgojaW5jbHVkZSAiaGZjX3BjaS5oIgojaW5jbHVkZSAiaXNkbmwxLmgiCiNpbmNsdWRlIDxsaW51eC9wY2kuaD4KI2luY2x1ZGUgPGxpbnV4L2ludGVycnVwdC5oPgoKZXh0ZXJuIGNvbnN0IGNoYXIgKkNhcmRUeXBlW107CgpzdGF0aWMgY29uc3QgY2hhciAqaGZjcGNpX3JldmlzaW9uID0gIiRSZXZpc2lvbjogMS40OC4yLjQgJCI7CgovKiB0YWJsZSBlbnRyeSBpbiB0aGUgUENJIGRldmljZXMgbGlzdCAqLwp0eXBlZGVmIHN0cnVjdCB7CglpbnQgdmVuZG9yX2lkOwoJaW50IGRldmljZV9pZDsKCWNoYXIgKnZlbmRvcl9uYW1lOwoJY2hhciAqY2FyZF9uYW1lOwp9IFBDSV9FTlRSWTsKCiNkZWZpbmUgTlRfVDFfQ09VTlQJMjAJLyogbnVtYmVyIG9mIDMuMTI1bXMgaW50ZXJydXB0cyBmb3IgRzIgdGltZW91dCAqLwojZGVmaW5lIENMS0RFTF9URQkweDBlCS8qIENMS0RFTCBpbiBURSBtb2RlICovCiNkZWZpbmUgQ0xLREVMX05UCTB4NmMJLyogQ0xLREVMIGluIE5UIG1vZGUgKi8KCnN0YXRpYyBjb25zdCBQQ0lfRU5UUlkgaWRfbGlzdFtdID0KewoJe1BDSV9WRU5ET1JfSURfQ0NELCBQQ0lfREVWSUNFX0lEX0NDRF8yQkQwLCAiQ0NEL0JpbGxpb24vQXN1c2NvbSIsICIyQkQwIn0sCgl7UENJX1ZFTkRPUl9JRF9DQ0QsIFBDSV9ERVZJQ0VfSURfQ0NEX0IwMDAsICJCaWxsaW9uIiwgIkIwMDAifSwKCXtQQ0lfVkVORE9SX0lEX0NDRCwgUENJX0RFVklDRV9JRF9DQ0RfQjAwNiwgIkJpbGxpb24iLCAiQjAwNiJ9LAoJe1BDSV9WRU5ET1JfSURfQ0NELCBQQ0lfREVWSUNFX0lEX0NDRF9CMDA3LCAiQmlsbGlvbiIsICJCMDA3In0sCgl7UENJX1ZFTkRPUl9JRF9DQ0QsIFBDSV9ERVZJQ0VfSURfQ0NEX0IwMDgsICJCaWxsaW9uIiwgIkIwMDgifSwKCXtQQ0lfVkVORE9SX0lEX0NDRCwgUENJX0RFVklDRV9JRF9DQ0RfQjAwOSwgIkJpbGxpb24iLCAiQjAwOSJ9LAoJe1BDSV9WRU5ET1JfSURfQ0NELCBQQ0lfREVWSUNFX0lEX0NDRF9CMDBBLCAiQmlsbGlvbiIsICJCMDBBIn0sCgl7UENJX1ZFTkRPUl9JRF9DQ0QsIFBDSV9ERVZJQ0VfSURfQ0NEX0IwMEIsICJCaWxsaW9uIiwgIkIwMEIifSwKCXtQQ0lfVkVORE9SX0lEX0NDRCwgUENJX0RFVklDRV9JRF9DQ0RfQjAwQywgIkJpbGxpb24iLCAiQjAwQyJ9LAoJe1BDSV9WRU5ET1JfSURfQ0NELCBQQ0lfREVWSUNFX0lEX0NDRF9CMTAwLCAiU2V5ZW9uIiwgIkIxMDAifSwKCXtQQ0lfVkVORE9SX0lEX0NDRCwgUENJX0RFVklDRV9JRF9DQ0RfQjcwMCwgIlByaW11eCBJSSBTMCIsICJCNzAwIn0sCgl7UENJX1ZFTkRPUl9JRF9DQ0QsIFBDSV9ERVZJQ0VfSURfQ0NEX0I3MDEsICJQcmltdXggSUkgUzAgTlQiLCAiQjcwMSJ9LAoJe1BDSV9WRU5ET1JfSURfQUJPQ09NLCBQQ0lfREVWSUNFX0lEX0FCT0NPTV8yQkQxLCAiQWJvY29tL01hZ2l0ZWsiLCAiMkJEMSJ9LAoJe1BDSV9WRU5ET1JfSURfQVNVU1RFSywgUENJX0RFVklDRV9JRF9BU1VTVEVLXzA2NzUsICJBc3VzY29tL0Fza2V5IiwgIjY3NSJ9LAoJe1BDSV9WRU5ET1JfSURfQkVSS09NLCBQQ0lfREVWSUNFX0lEX0JFUktPTV9UX0NPTkNFUFQsICJHZXJtYW4gdGVsZWtvbSIsICJULUNvbmNlcHQifSwKCXtQQ0lfVkVORE9SX0lEX0JFUktPTSwgUENJX0RFVklDRV9JRF9CRVJLT01fQTFULCAiR2VybWFuIHRlbGVrb20iLCAiQTFUIn0sCgl7UENJX1ZFTkRPUl9JRF9BTklHTUEsIFBDSV9ERVZJQ0VfSURfQU5JR01BX01DMTQ1NTc1LCAiTW90b3JvbGEgTUMxNDU1NzUiLCAiTUMxNDU1NzUifSwKCXtQQ0lfVkVORE9SX0lEX1pPTFRSSVgsIFBDSV9ERVZJQ0VfSURfWk9MVFJJWF8yQkQwLCAiWm9sdHJpeCIsICIyQkQwIn0sCgl7UENJX1ZFTkRPUl9JRF9ESUdJLCBQQ0lfREVWSUNFX0lEX0RJR0lfREZfTV9JT00yX0UsIkRpZ2kgSW50ZXJuYXRpb25hbCIsICJEaWdpIERhdGFGaXJlIE1pY3JvIFYgSU9NMiAoRXVyb3BlKSJ9LAoJe1BDSV9WRU5ET1JfSURfRElHSSwgUENJX0RFVklDRV9JRF9ESUdJX0RGX01fRSwiRGlnaSBJbnRlcm5hdGlvbmFsIiwgIkRpZ2kgRGF0YUZpcmUgTWljcm8gViAoRXVyb3BlKSJ9LAoJe1BDSV9WRU5ET1JfSURfRElHSSwgUENJX0RFVklDRV9JRF9ESUdJX0RGX01fSU9NMl9BLCJEaWdpIEludGVybmF0aW9uYWwiLCAiRGlnaSBEYXRhRmlyZSBNaWNybyBWIElPTTIgKE5vcnRoIEFtZXJpY2EpIn0sCgl7UENJX1ZFTkRPUl9JRF9ESUdJLCBQQ0lfREVWSUNFX0lEX0RJR0lfREZfTV9BLCJEaWdpIEludGVybmF0aW9uYWwiLCAiRGlnaSBEYXRhRmlyZSBNaWNybyBWIChOb3J0aCBBbWVyaWNhKSJ9LAoJe1BDSV9WRU5ET1JfSURfU0lURUNPTSwgUENJX0RFVklDRV9JRF9TSVRFQ09NX0RDMTA1VjIsICJTaXRlY29tIEV1cm9wZSIsICJEQy0xMDUgSVNETiBQQ0kifSwKCXswLCAwLCBOVUxMLCBOVUxMfSwKfTsKCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBmcmVlIGhhcmR3YXJlIHJlc291cmNlcyB1c2VkIGJ5IGRyaXZlciAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZApyZWxlYXNlX2lvX2hmY3BjaShzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSAqY3MpCnsKCXByaW50ayhLRVJOX0lORk8gIkhpU2F4OiByZWxlYXNlIGhmY3BjaSBhdCAlcFxuIiwKCQljcy0+aHcuaGZjcGNpLnBjaV9pbyk7Cgljcy0+aHcuaGZjcGNpLmludF9tMiA9IDA7CQkJCQkvKiBpbnRlcnJ1cHQgb3V0cHV0IG9mZiAhICovCglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9JTlRfTTIsIGNzLT5ody5oZmNwY2kuaW50X20yKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0NJUk0sIEhGQ1BDSV9SRVNFVCk7CQkJLyogUmVzZXQgT24gKi8KCW1kZWxheSgxMCk7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9DSVJNLCAwKTsJCQkJCS8qIFJlc2V0IE9mZiAqLwoJbWRlbGF5KDEwKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0lOVF9NMiwgY3MtPmh3LmhmY3BjaS5pbnRfbTIpOwoJcGNpX3dyaXRlX2NvbmZpZ193b3JkKGNzLT5ody5oZmNwY2kuZGV2LCBQQ0lfQ09NTUFORCwgMCk7CS8qIGRpc2FibGUgbWVtb3J5IG1hcHBlZCBwb3J0cyArIGJ1c21hc3RlciAqLwoJZGVsX3RpbWVyKCZjcy0+aHcuaGZjcGNpLnRpbWVyKTsKCWtmcmVlKGNzLT5ody5oZmNwY2kuc2hhcmVfc3RhcnQpOwoJY3MtPmh3LmhmY3BjaS5zaGFyZV9zdGFydCA9IE5VTEw7Cglpb3VubWFwKCh2b2lkICopY3MtPmh3LmhmY3BjaS5wY2lfaW8pOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qIGZ1bmN0aW9uIGNhbGxlZCB0byByZXNldCB0aGUgSEZDIFBDSSBjaGlwLiBBIGNvbXBsZXRlIHNvZnR3YXJlIHJlc2V0IG9mIGNoaXAgKi8KLyogYW5kIGZpZm9zIGlzIGRvbmUuICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyB2b2lkCnJlc2V0X2hmY3BjaShzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSAqY3MpCnsKCXBjaV93cml0ZV9jb25maWdfd29yZChjcy0+aHcuaGZjcGNpLmRldiwgUENJX0NPTU1BTkQsIFBDSV9FTkFfTUVNSU8pOwkvKiBlbmFibGUgbWVtb3J5IG1hcHBlZCBwb3J0cywgZGlzYWJsZSBidXNtYXN0ZXIgKi8KCWNzLT5ody5oZmNwY2kuaW50X20yID0gMDsJLyogaW50ZXJydXB0IG91dHB1dCBvZmYgISAqLwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfSU5UX00yLCBjcy0+aHcuaGZjcGNpLmludF9tMik7CgoJcHJpbnRrKEtFUk5fSU5GTyAiSEZDX1BDSTogcmVzZXR0aW5nIGNhcmRcbiIpOwoJcGNpX3dyaXRlX2NvbmZpZ193b3JkKGNzLT5ody5oZmNwY2kuZGV2LCBQQ0lfQ09NTUFORCwgUENJX0VOQV9NRU1JTyArIFBDSV9FTkFfTUFTVEVSKTsJLyogZW5hYmxlIG1lbW9yeSBwb3J0cyArIGJ1c21hc3RlciAqLwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQ0lSTSwgSEZDUENJX1JFU0VUKTsJLyogUmVzZXQgT24gKi8KCW1kZWxheSgxMCk7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9DSVJNLCAwKTsJLyogUmVzZXQgT2ZmICovCgltZGVsYXkoMTApOwoJaWYgKFJlYWRfaGZjKGNzLCBIRkNQQ0lfU1RBVFVTKSAmIDIpCgkJcHJpbnRrKEtFUk5fV0FSTklORyAiSEZDLVBDSSBpbml0IGJpdCBidXN5XG4iKTsKCgljcy0+aHcuaGZjcGNpLmZpZm9fZW4gPSAweDMwOwkvKiBvbmx5IEQgZmlmb3MgZW5hYmxlZCAqLwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfRklGT19FTiwgY3MtPmh3LmhmY3BjaS5maWZvX2VuKTsKCgljcy0+aHcuaGZjcGNpLnRybSA9IDAgKyBIRkNQQ0lfQlRSQU5TX1RIUkVTTUFTSzsJLyogbm8gZWNobyBjb25uZWN0ICwgdGhyZXNob2xkICovCglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9UUk0sIGNzLT5ody5oZmNwY2kudHJtKTsKCglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9DTEtERUwsIENMS0RFTF9URSk7IC8qIFNULUJpdCBkZWxheSBmb3IgVEUtTW9kZSAqLwoJY3MtPmh3LmhmY3BjaS5zY3RybF9lID0gSEZDUENJX0FVVE9fQVdBS0U7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9TQ1RSTF9FLCBjcy0+aHcuaGZjcGNpLnNjdHJsX2UpOwkvKiBTL1QgQXV0byBhd2FrZSAqLwoJY3MtPmh3LmhmY3BjaS5ic3dhcHBlZCA9IDA7CS8qIG5vIGV4Y2hhbmdlICovCgljcy0+aHcuaGZjcGNpLm50X21vZGUgPSAwOwkvKiB3ZSBhcmUgaW4gVEUgbW9kZSAqLwoJY3MtPmh3LmhmY3BjaS5jdG10ID0gSEZDUENJX1RJTTNfMTI1IHwgSEZDUENJX0FVVE9fVElNRVI7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9DVE1ULCBjcy0+aHcuaGZjcGNpLmN0bXQpOwoKCWNzLT5ody5oZmNwY2kuaW50X20xID0gSEZDUENJX0lOVFNfRFRSQU5TIHwgSEZDUENJX0lOVFNfRFJFQyB8CgkgICAgSEZDUENJX0lOVFNfTDFTVEFURSB8IEhGQ1BDSV9JTlRTX1RJTUVSOwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfSU5UX00xLCBjcy0+aHcuaGZjcGNpLmludF9tMSk7CgoJLyogQ2xlYXIgYWxyZWFkeSBwZW5kaW5nIGludHMgKi8KCWlmIChSZWFkX2hmYyhjcywgSEZDUENJX0lOVF9TMSkpOwoKCVdyaXRlX2hmYyhjcywgSEZDUENJX1NUQVRFUywgSEZDUENJX0xPQURfU1RBVEUgfCAyKTsJLyogSEZDIFNUIDIgKi8KCXVkZWxheSgxMCk7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9TVEFURVMsIDIpOwkvKiBIRkMgU1QgMiAqLwoJY3MtPmh3LmhmY3BjaS5tc3RfbSA9IEhGQ1BDSV9NQVNURVI7CS8qIEhGQyBNYXN0ZXIgTW9kZSAqLwoKCVdyaXRlX2hmYyhjcywgSEZDUENJX01TVF9NT0RFLCBjcy0+aHcuaGZjcGNpLm1zdF9tKTsKCWNzLT5ody5oZmNwY2kuc2N0cmwgPSAweDQwOwkvKiBzZXQgdHhfbG8gbW9kZSwgZXJyb3IgaW4gZGF0YXNoZWV0ICEgKi8KCVdyaXRlX2hmYyhjcywgSEZDUENJX1NDVFJMLCBjcy0+aHcuaGZjcGNpLnNjdHJsKTsKCWNzLT5ody5oZmNwY2kuc2N0cmxfciA9IDA7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9TQ1RSTF9SLCBjcy0+aHcuaGZjcGNpLnNjdHJsX3IpOwoKCS8qIEluaXQgR0NJL0lPTTIgaW4gbWFzdGVyIG1vZGUgKi8KCS8qIFNsb3RzIDAgYW5kIDEgYXJlIHNldCBmb3IgQi1jaGFuIDEgYW5kIDIgKi8KCS8qIEQtIGFuZCBtb25pdG9yL0NJIGNoYW5uZWwgYXJlIG5vdCBlbmFibGVkICovCgkvKiBTVElPMSBpcyB1c2VkIGFzIG91dHB1dCBmb3IgZGF0YSwgQjErQjIgZnJvbSBTVC0+SU9NK0hGQyAqLwoJLyogU1RJTzIgaXMgdXNlZCBhcyBkYXRhIGlucHV0LCBCMStCMiBmcm9tIElPTS0+U1QgKi8KCS8qIFNUIEItY2hhbm5lbCBzZW5kIGRpc2FibGVkIC0+IGNvbnRpbm91cyAxcyAqLwoJLyogVGhlIElPTSBzbG90cyBhcmUgYWx3YXlzIGVuYWJsZWQgKi8KCWNzLT5ody5oZmNwY2kuY29ubiA9IDB4MzY7CS8qIHNldCBkYXRhIGZsb3cgZGlyZWN0aW9ucyAqLwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQ09OTkVDVCwgY3MtPmh3LmhmY3BjaS5jb25uKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0IxX1NTTCwgMHg4MCk7CS8qIEIxLVNsb3QgMCBTVElPMSBvdXQgZW5hYmxlZCAqLwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQjJfU1NMLCAweDgxKTsJLyogQjItU2xvdCAxIFNUSU8xIG91dCBlbmFibGVkICovCglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9CMV9SU0wsIDB4ODApOwkvKiBCMS1TbG90IDAgU1RJTzIgaW4gZW5hYmxlZCAqLwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQjJfUlNMLCAweDgxKTsJLyogQjItU2xvdCAxIFNUSU8yIGluIGVuYWJsZWQgKi8KCgkvKiBGaW5hbGx5IGVuYWJsZSBJUlEgb3V0cHV0ICovCgljcy0+aHcuaGZjcGNpLmludF9tMiA9IEhGQ1BDSV9JUlFfRU5BQkxFOwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfSU5UX00yLCBjcy0+aHcuaGZjcGNpLmludF9tMik7CglpZiAoUmVhZF9oZmMoY3MsIEhGQ1BDSV9JTlRfUzEpKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogVGltZXIgZnVuY3Rpb24gY2FsbGVkIHdoZW4ga2VybmVsIHRpbWVyIGV4cGlyZXMgKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQKaGZjcGNpX1RpbWVyKHN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcykKewoJY3MtPmh3LmhmY3BjaS50aW1lci5leHBpcmVzID0gamlmZmllcyArIDc1OwoJLyogV0QgUkVTRVQgKi8KLyogICAgICBXcml0ZVJlZyhjcywgSEZDRF9EQVRBLCBIRkNEX0NUTVQsIGNzLT5ody5oZmNwY2kuY3RtdCB8IDB4ODApOwogICBhZGRfdGltZXIoJmNzLT5ody5oZmNwY2kudGltZXIpOwogKi8KfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qIHNjaGVkdWxlIGEgbmV3IEQtY2hhbm5lbCB0YXNrICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyB2b2lkCnNjaGVkX2V2ZW50X0RfcGNpKHN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcywgaW50IGV2ZW50KQp7Cgl0ZXN0X2FuZF9zZXRfYml0KGV2ZW50LCAmY3MtPmV2ZW50KTsKCXNjaGVkdWxlX3dvcmsoJmNzLT50cXVldWUpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBzY2hlZHVsZSBhIG5ldyBiX2NoYW5uZWwgdGFzayAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZApoZmNwY2lfc2NoZWRfZXZlbnQoc3RydWN0IEJDU3RhdGUgKmJjcywgaW50IGV2ZW50KQp7Cgl0ZXN0X2FuZF9zZXRfYml0KGV2ZW50LCAmYmNzLT5ldmVudCk7CglzY2hlZHVsZV93b3JrKCZiY3MtPnRxdWV1ZSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qIHNlbGVjdCBhIGItY2hhbm5lbCBlbnRyeSBtYXRjaGluZyBhbmQgYWN0aXZlICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYwpzdHJ1Y3QgQkNTdGF0ZSAqClNlbF9CQ1Moc3RydWN0IElzZG5DYXJkU3RhdGUgKmNzLCBpbnQgY2hhbm5lbCkKewoJaWYgKGNzLT5iY3NbMF0ubW9kZSAmJiAoY3MtPmJjc1swXS5jaGFubmVsID09IGNoYW5uZWwpKQoJCXJldHVybiAoJmNzLT5iY3NbMF0pOwoJZWxzZSBpZiAoY3MtPmJjc1sxXS5tb2RlICYmIChjcy0+YmNzWzFdLmNoYW5uZWwgPT0gY2hhbm5lbCkpCgkJcmV0dXJuICgmY3MtPmJjc1sxXSk7CgllbHNlCgkJcmV0dXJuIChOVUxMKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogY2xlYXIgdGhlIGRlc2lyZWQgQi1jaGFubmVsIHJ4IGZpZm8gKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQgaGZjcGNpX2NsZWFyX2ZpZm9fcngoc3RydWN0IElzZG5DYXJkU3RhdGUgKmNzLCBpbnQgZmlmbykKeyAgICAgICB1X2NoYXIgZmlmb19zdGF0ZTsKICAgICAgICBiemZpZm9fdHlwZSAqYnpyOwoKCWlmIChmaWZvKSB7CgkgICAgICAgIGJ6ciA9ICYoKGZpZm9fYXJlYSAqKSAoY3MtPmh3LmhmY3BjaS5maWZvcykpLT5iX2NoYW5zLnJ4YnpfYjI7CgkJZmlmb19zdGF0ZSA9IGNzLT5ody5oZmNwY2kuZmlmb19lbiAmIEhGQ1BDSV9GSUZPRU5fQjJSWDsKCX0gZWxzZSB7CgkgICAgICAgIGJ6ciA9ICYoKGZpZm9fYXJlYSAqKSAoY3MtPmh3LmhmY3BjaS5maWZvcykpLT5iX2NoYW5zLnJ4YnpfYjE7CgkJZmlmb19zdGF0ZSA9IGNzLT5ody5oZmNwY2kuZmlmb19lbiAmIEhGQ1BDSV9GSUZPRU5fQjFSWDsKCX0KCWlmIChmaWZvX3N0YXRlKQoJICAgICAgICBjcy0+aHcuaGZjcGNpLmZpZm9fZW4gXj0gZmlmb19zdGF0ZTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0ZJRk9fRU4sIGNzLT5ody5oZmNwY2kuZmlmb19lbik7Cgljcy0+aHcuaGZjcGNpLmxhc3RfYmZpZm9fY250W2ZpZm9dID0gMDsKCWJ6ci0+emFbTUFYX0JfRlJBTUVTXS56MSA9IEJfRklGT19TSVpFICsgQl9TVUJfVkFMIC0gMTsKCWJ6ci0+emFbTUFYX0JfRlJBTUVTXS56MiA9IGJ6ci0+emFbTUFYX0JfRlJBTUVTXS56MTsKCWJ6ci0+ZjEgPSBNQVhfQl9GUkFNRVM7CglienItPmYyID0gYnpyLT5mMTsJLyogaW5pdCBGIHBvaW50ZXJzIHRvIHJlbWFpbiBjb25zdGFudCAqLwoJaWYgKGZpZm9fc3RhdGUpCgkgICAgICAgIGNzLT5ody5oZmNwY2kuZmlmb19lbiB8PSBmaWZvX3N0YXRlOwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfRklGT19FTiwgY3MtPmh3LmhmY3BjaS5maWZvX2VuKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogY2xlYXIgdGhlIGRlc2lyZWQgQi1jaGFubmVsIHR4IGZpZm8gKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQgaGZjcGNpX2NsZWFyX2ZpZm9fdHgoc3RydWN0IElzZG5DYXJkU3RhdGUgKmNzLCBpbnQgZmlmbykKeyAgICAgICB1X2NoYXIgZmlmb19zdGF0ZTsKICAgICAgICBiemZpZm9fdHlwZSAqYnp0OwoKCWlmIChmaWZvKSB7CgkgICAgICAgIGJ6dCA9ICYoKGZpZm9fYXJlYSAqKSAoY3MtPmh3LmhmY3BjaS5maWZvcykpLT5iX2NoYW5zLnR4YnpfYjI7CgkJZmlmb19zdGF0ZSA9IGNzLT5ody5oZmNwY2kuZmlmb19lbiAmIEhGQ1BDSV9GSUZPRU5fQjJUWDsKCX0gZWxzZSB7CgkgICAgICAgIGJ6dCA9ICYoKGZpZm9fYXJlYSAqKSAoY3MtPmh3LmhmY3BjaS5maWZvcykpLT5iX2NoYW5zLnR4YnpfYjE7CgkJZmlmb19zdGF0ZSA9IGNzLT5ody5oZmNwY2kuZmlmb19lbiAmIEhGQ1BDSV9GSUZPRU5fQjFUWDsKCX0KCWlmIChmaWZvX3N0YXRlKQoJICAgICAgICBjcy0+aHcuaGZjcGNpLmZpZm9fZW4gXj0gZmlmb19zdGF0ZTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0ZJRk9fRU4sIGNzLT5ody5oZmNwY2kuZmlmb19lbik7CglienQtPnphW01BWF9CX0ZSQU1FU10uejEgPSBCX0ZJRk9fU0laRSArIEJfU1VCX1ZBTCAtIDE7CglienQtPnphW01BWF9CX0ZSQU1FU10uejIgPSBienQtPnphW01BWF9CX0ZSQU1FU10uejE7CglienQtPmYxID0gTUFYX0JfRlJBTUVTOwoJYnp0LT5mMiA9IGJ6dC0+ZjE7CS8qIGluaXQgRiBwb2ludGVycyB0byByZW1haW4gY29uc3RhbnQgKi8KCWlmIChmaWZvX3N0YXRlKQoJICAgICAgICBjcy0+aHcuaGZjcGNpLmZpZm9fZW4gfD0gZmlmb19zdGF0ZTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0ZJRk9fRU4sIGNzLT5ody5oZmNwY2kuZmlmb19lbik7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qIHJlYWQgYSBjb21wbGV0ZSBCLWZyYW1lIG91dCBvZiB0aGUgYnVmZmVyICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyBzdHJ1Y3Qgc2tfYnVmZgoqCmhmY3BjaV9lbXB0eV9maWZvKHN0cnVjdCBCQ1N0YXRlICpiY3MsIGJ6Zmlmb190eXBlICogYnosIHVfY2hhciAqIGJkYXRhLCBpbnQgY291bnQpCnsKCXVfY2hhciAqcHRyLCAqcHRyMSwgbmV3X2YyOwoJc3RydWN0IHNrX2J1ZmYgKnNrYjsKCXN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcyA9IGJjcy0+Y3M7CglpbnQgdG90YWwsIG1heGxlbiwgbmV3X3oyOwoJel90eXBlICp6cDsKCglpZiAoKGNzLT5kZWJ1ZyAmIEwxX0RFQl9IU0NYKSAmJiAhKGNzLT5kZWJ1ZyAmIEwxX0RFQl9IU0NYX0ZJRk8pKQoJCWRlYnVnbDEoY3MsICJoZmNwY2lfZW1wdHlfZmlmbyIpOwoJenAgPSAmYnotPnphW2J6LT5mMl07CS8qIHBvaW50IHRvIFotUmVncyAqLwoJbmV3X3oyID0genAtPnoyICsgY291bnQ7CS8qIG5ldyBwb3NpdGlvbiBpbiBmaWZvICovCglpZiAobmV3X3oyID49IChCX0ZJRk9fU0laRSArIEJfU1VCX1ZBTCkpCgkJbmV3X3oyIC09IEJfRklGT19TSVpFOwkvKiBidWZmZXIgd3JhcCAqLwoJbmV3X2YyID0gKGJ6LT5mMiArIDEpICYgTUFYX0JfRlJBTUVTOwoJaWYgKChjb3VudCA+IEhTQ1hfQlVGTUFYICsgMykgfHwgKGNvdW50IDwgNCkgfHwKCSAgICAoKihiZGF0YSArICh6cC0+ejEgLSBCX1NVQl9WQUwpKSkpIHsKCQlpZiAoY3MtPmRlYnVnICYgTDFfREVCX1dBUk4pCgkJCWRlYnVnbDEoY3MsICJoZmNwY2lfZW1wdHlfZmlmbzogaW5jb21pbmcgcGFja2V0IGludmFsaWQgbGVuZ3RoICVkIG9yIGNyYyIsIGNvdW50KTsKI2lmZGVmIEVSUk9SX1NUQVRJU1RJQwoJCWJjcy0+ZXJyX2ludisrOwojZW5kaWYKCQliei0+emFbbmV3X2YyXS56MiA9IG5ld196MjsKCQliei0+ZjIgPSBuZXdfZjI7CS8qIG5leHQgYnVmZmVyICovCgkJc2tiID0gTlVMTDsKCX0gZWxzZSBpZiAoIShza2IgPSBkZXZfYWxsb2Nfc2tiKGNvdW50IC0gMykpKQoJCXByaW50ayhLRVJOX1dBUk5JTkcgIkhGQ1BDSTogcmVjZWl2ZSBvdXQgb2YgbWVtb3J5XG4iKTsKCWVsc2UgewoJCXRvdGFsID0gY291bnQ7CgkJY291bnQgLT0gMzsKCQlwdHIgPSBza2JfcHV0KHNrYiwgY291bnQpOwoKCQlpZiAoenAtPnoyICsgY291bnQgPD0gQl9GSUZPX1NJWkUgKyBCX1NVQl9WQUwpCgkJCW1heGxlbiA9IGNvdW50OwkJLyogY29tcGxldGUgdHJhbnNmZXIgKi8KCQllbHNlCgkJCW1heGxlbiA9IEJfRklGT19TSVpFICsgQl9TVUJfVkFMIC0genAtPnoyOwkvKiBtYXhpbXVtICovCgoJCXB0cjEgPSBiZGF0YSArICh6cC0+ejIgLSBCX1NVQl9WQUwpOwkvKiBzdGFydCBvZiBkYXRhICovCgkJbWVtY3B5KHB0ciwgcHRyMSwgbWF4bGVuKTsJLyogY29weSBkYXRhICovCgkJY291bnQgLT0gbWF4bGVuOwoKCQlpZiAoY291bnQpIHsJLyogcmVzdCByZW1haW5pbmcgKi8KCQkJcHRyICs9IG1heGxlbjsKCQkJcHRyMSA9IGJkYXRhOwkvKiBzdGFydCBvZiBidWZmZXIgKi8KCQkJbWVtY3B5KHB0ciwgcHRyMSwgY291bnQpOwkvKiByZXN0ICovCgkJfQoJCWJ6LT56YVtuZXdfZjJdLnoyID0gbmV3X3oyOwoJCWJ6LT5mMiA9IG5ld19mMjsJLyogbmV4dCBidWZmZXIgKi8KCgl9CglyZXR1cm4gKHNrYik7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBELWNoYW5uZWwgcmVjZWl2ZSBwcm9jZWR1cmUgKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYwppbnQKcmVjZWl2ZV9kbXNnKHN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcykKewoJc3RydWN0IHNrX2J1ZmYgKnNrYjsKCWludCBtYXhsZW47CglpbnQgcmNudCwgdG90YWw7CglpbnQgY291bnQgPSA1OwoJdV9jaGFyICpwdHIsICpwdHIxOwoJZGZpZm9fdHlwZSAqZGY7Cgl6X3R5cGUgKnpwOwoKCWRmID0gJigoZmlmb19hcmVhICopIChjcy0+aHcuaGZjcGNpLmZpZm9zKSktPmRfY2hhbi5kX3J4OwoJaWYgKHRlc3RfYW5kX3NldF9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKSkgewoJCWRlYnVnbDEoY3MsICJyZWNfZG1zZyBibG9ja2VkIik7CgkJcmV0dXJuICgxKTsKCX0KCXdoaWxlICgoKGRmLT5mMSAmIERfRlJFR19NQVNLKSAhPSAoZGYtPmYyICYgRF9GUkVHX01BU0spKSAmJiBjb3VudC0tKSB7CgkJenAgPSAmZGYtPnphW2RmLT5mMiAmIERfRlJFR19NQVNLXTsKCQlyY250ID0genAtPnoxIC0genAtPnoyOwoJCWlmIChyY250IDwgMCkKCQkJcmNudCArPSBEX0ZJRk9fU0laRTsKCQlyY250Kys7CgkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9JU0FDKQoJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpIHJlY2QgZjEoJWQpIGYyKCVkKSB6MSgleCkgejIoJXgpIGNudCglZCkiLAoJCQkJZGYtPmYxLCBkZi0+ZjIsIHpwLT56MSwgenAtPnoyLCByY250KTsKCgkJaWYgKChyY250ID4gTUFYX0RGUkFNRV9MRU4gKyAzKSB8fCAocmNudCA8IDQpIHx8CgkJICAgIChkZi0+ZGF0YVt6cC0+ejFdKSkgewoJCQlpZiAoY3MtPmRlYnVnICYgTDFfREVCX1dBUk4pCgkJCQlkZWJ1Z2wxKGNzLCAiZW1wdHlfZmlmbyBoZmNwY2kgcGFrZXQgaW52LiBsZW4gJWQgb3IgY3JjICVkIiwgcmNudCwgZGYtPmRhdGFbenAtPnoxXSk7CiNpZmRlZiBFUlJPUl9TVEFUSVNUSUMKCQkJY3MtPmVycl9yeCsrOwojZW5kaWYKCQkJZGYtPmYyID0gKChkZi0+ZjIgKyAxKSAmIE1BWF9EX0ZSQU1FUykgfCAoTUFYX0RfRlJBTUVTICsgMSk7CS8qIG5leHQgYnVmZmVyICovCgkJCWRmLT56YVtkZi0+ZjIgJiBEX0ZSRUdfTUFTS10uejIgPSAoenAtPnoyICsgcmNudCkgJiAoRF9GSUZPX1NJWkUgLSAxKTsKCQl9IGVsc2UgaWYgKChza2IgPSBkZXZfYWxsb2Nfc2tiKHJjbnQgLSAzKSkpIHsKCQkJdG90YWwgPSByY250OwoJCQlyY250IC09IDM7CgkJCXB0ciA9IHNrYl9wdXQoc2tiLCByY250KTsKCgkJCWlmICh6cC0+ejIgKyByY250IDw9IERfRklGT19TSVpFKQoJCQkJbWF4bGVuID0gcmNudDsJLyogY29tcGxldGUgdHJhbnNmZXIgKi8KCQkJZWxzZQoJCQkJbWF4bGVuID0gRF9GSUZPX1NJWkUgLSB6cC0+ejI7CS8qIG1heGltdW0gKi8KCgkJCXB0cjEgPSBkZi0+ZGF0YSArIHpwLT56MjsJLyogc3RhcnQgb2YgZGF0YSAqLwoJCQltZW1jcHkocHRyLCBwdHIxLCBtYXhsZW4pOwkvKiBjb3B5IGRhdGEgKi8KCQkJcmNudCAtPSBtYXhsZW47CgoJCQlpZiAocmNudCkgewkvKiByZXN0IHJlbWFpbmluZyAqLwoJCQkJcHRyICs9IG1heGxlbjsKCQkJCXB0cjEgPSBkZi0+ZGF0YTsJLyogc3RhcnQgb2YgYnVmZmVyICovCgkJCQltZW1jcHkocHRyLCBwdHIxLCByY250KTsJLyogcmVzdCAqLwoJCQl9CgkJCWRmLT5mMiA9ICgoZGYtPmYyICsgMSkgJiBNQVhfRF9GUkFNRVMpIHwgKE1BWF9EX0ZSQU1FUyArIDEpOwkvKiBuZXh0IGJ1ZmZlciAqLwoJCQlkZi0+emFbZGYtPmYyICYgRF9GUkVHX01BU0tdLnoyID0gKHpwLT56MiArIHRvdGFsKSAmIChEX0ZJRk9fU0laRSAtIDEpOwoKCQkJc2tiX3F1ZXVlX3RhaWwoJmNzLT5ycSwgc2tiKTsKCQkJc2NoZWRfZXZlbnRfRF9wY2koY3MsIERfUkNWQlVGUkVBRFkpOwoJCX0gZWxzZQoJCQlwcmludGsoS0VSTl9XQVJOSU5HICJIRkMtUENJOiBEIHJlY2VpdmUgb3V0IG9mIG1lbW9yeVxuIik7Cgl9Cgl0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKTsKCXJldHVybiAoMSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBjaGVjayBmb3IgdHJhbnNwYXJlbnQgcmVjZWl2ZSBkYXRhIGFuZCByZWFkIG1heCBvbmUgdGhyZXNob2xkIHNpemUgaWYgYXZhaWwgKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyBpbnQKaGZjcGNpX2VtcHR5X2ZpZm9fdHJhbnMoc3RydWN0IEJDU3RhdGUgKmJjcywgYnpmaWZvX3R5cGUgKiBieiwgdV9jaGFyICogYmRhdGEpCnsKCXVuc2lnbmVkIHNob3J0ICp6MXIsICp6MnI7CglpbnQgbmV3X3oyLCBmY250LCBtYXhsZW47CglzdHJ1Y3Qgc2tfYnVmZiAqc2tiOwoJdV9jaGFyICpwdHIsICpwdHIxOwoKCXoxciA9ICZiei0+emFbTUFYX0JfRlJBTUVTXS56MTsJCS8qIHBvaW50ZXIgdG8geiByZWcgKi8KCXoyciA9IHoxciArIDE7CgoJaWYgKCEoZmNudCA9ICp6MXIgLSAqejJyKSkKCQlyZXR1cm4gKDApOwkvKiBubyBkYXRhIGF2YWlsICovCgoJaWYgKGZjbnQgPD0gMCkKCQlmY250ICs9IEJfRklGT19TSVpFOwkvKiBieXRlcyBhY3R1YWxseSBidWZmZXJlZCAqLwoJaWYgKGZjbnQgPiBIRkNQQ0lfQlRSQU5TX1RIUkVTSE9MRCkKCQlmY250ID0gSEZDUENJX0JUUkFOU19USFJFU0hPTEQ7CQkvKiBsaW1pdCBzaXplICovCgoJbmV3X3oyID0gKnoyciArIGZjbnQ7CS8qIG5ldyBwb3NpdGlvbiBpbiBmaWZvICovCglpZiAobmV3X3oyID49IChCX0ZJRk9fU0laRSArIEJfU1VCX1ZBTCkpCgkJbmV3X3oyIC09IEJfRklGT19TSVpFOwkvKiBidWZmZXIgd3JhcCAqLwoKCWlmICghKHNrYiA9IGRldl9hbGxvY19za2IoZmNudCkpKQoJCXByaW50ayhLRVJOX1dBUk5JTkcgIkhGQ1BDSTogcmVjZWl2ZSBvdXQgb2YgbWVtb3J5XG4iKTsKCWVsc2UgewoJCXB0ciA9IHNrYl9wdXQoc2tiLCBmY250KTsKCQlpZiAoKnoyciArIGZjbnQgPD0gQl9GSUZPX1NJWkUgKyBCX1NVQl9WQUwpCgkJCW1heGxlbiA9IGZjbnQ7CS8qIGNvbXBsZXRlIHRyYW5zZmVyICovCgkJZWxzZQoJCQltYXhsZW4gPSBCX0ZJRk9fU0laRSArIEJfU1VCX1ZBTCAtICp6MnI7CS8qIG1heGltdW0gKi8KCgkJcHRyMSA9IGJkYXRhICsgKCp6MnIgLSBCX1NVQl9WQUwpOwkvKiBzdGFydCBvZiBkYXRhICovCgkJbWVtY3B5KHB0ciwgcHRyMSwgbWF4bGVuKTsJLyogY29weSBkYXRhICovCgkJZmNudCAtPSBtYXhsZW47CgoJCWlmIChmY250KSB7CS8qIHJlc3QgcmVtYWluaW5nICovCgkJCXB0ciArPSBtYXhsZW47CgkJCXB0cjEgPSBiZGF0YTsJLyogc3RhcnQgb2YgYnVmZmVyICovCgkJCW1lbWNweShwdHIsIHB0cjEsIGZjbnQpOwkvKiByZXN0ICovCgkJfQoJCXNrYl9xdWV1ZV90YWlsKCZiY3MtPnJxdWV1ZSwgc2tiKTsKCQloZmNwY2lfc2NoZWRfZXZlbnQoYmNzLCBCX1JDVkJVRlJFQURZKTsKCX0KCgkqejJyID0gbmV3X3oyOwkJLyogbmV3IHBvc2l0aW9uICovCglyZXR1cm4gKDEpOwp9CQkJCS8qIGhmY3BjaV9lbXB0eV9maWZvX3RyYW5zICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogQi1jaGFubmVsIG1haW4gcmVjZWl2ZSByb3V0aW5lICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZAptYWluX3JlY19oZmNwY2koc3RydWN0IEJDU3RhdGUgKmJjcykKewoJc3RydWN0IElzZG5DYXJkU3RhdGUgKmNzID0gYmNzLT5jczsKCWludCByY250LCByZWFsX2ZpZm87CglpbnQgcmVjZWl2ZSwgY291bnQgPSA1OwoJc3RydWN0IHNrX2J1ZmYgKnNrYjsKCWJ6Zmlmb190eXBlICpiejsKCXVfY2hhciAqYmRhdGE7Cgl6X3R5cGUgKnpwOwoKCglpZiAoKGJjcy0+Y2hhbm5lbCkgJiYgKCFjcy0+aHcuaGZjcGNpLmJzd2FwcGVkKSkgewoJCWJ6ID0gJigoZmlmb19hcmVhICopIChjcy0+aHcuaGZjcGNpLmZpZm9zKSktPmJfY2hhbnMucnhiel9iMjsKCQliZGF0YSA9ICgoZmlmb19hcmVhICopIChjcy0+aHcuaGZjcGNpLmZpZm9zKSktPmJfY2hhbnMucnhkYXRfYjI7CgkJcmVhbF9maWZvID0gMTsKCX0gZWxzZSB7CgkJYnogPSAmKChmaWZvX2FyZWEgKikgKGNzLT5ody5oZmNwY2kuZmlmb3MpKS0+Yl9jaGFucy5yeGJ6X2IxOwoJCWJkYXRhID0gKChmaWZvX2FyZWEgKikgKGNzLT5ody5oZmNwY2kuZmlmb3MpKS0+Yl9jaGFucy5yeGRhdF9iMTsKCQlyZWFsX2ZpZm8gPSAwOwoJfQogICAgICBCZWdpbjoKCWNvdW50LS07CglpZiAodGVzdF9hbmRfc2V0X2JpdChGTEdfTE9DS19BVE9NSUMsICZjcy0+SFdfRmxhZ3MpKSB7CgkJZGVidWdsMShjcywgInJlY19kYXRhICVkIGJsb2NrZWQiLCBiY3MtPmNoYW5uZWwpOwoJCXJldHVybjsKCX0KCWlmIChiei0+ZjEgIT0gYnotPmYyKSB7CgkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9IU0NYKQoJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpIHJlYyAlZCBmMSglZCkgZjIoJWQpIiwKCQkJCWJjcy0+Y2hhbm5lbCwgYnotPmYxLCBiei0+ZjIpOwoJCXpwID0gJmJ6LT56YVtiei0+ZjJdOwoKCQlyY250ID0genAtPnoxIC0genAtPnoyOwoJCWlmIChyY250IDwgMCkKCQkJcmNudCArPSBCX0ZJRk9fU0laRTsKCQlyY250Kys7CgkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9IU0NYKQoJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpIHJlYyAlZCB6MSgleCkgejIoJXgpIGNudCglZCkiLAoJCQkJYmNzLT5jaGFubmVsLCB6cC0+ejEsIHpwLT56MiwgcmNudCk7CgkJaWYgKChza2IgPSBoZmNwY2lfZW1wdHlfZmlmbyhiY3MsIGJ6LCBiZGF0YSwgcmNudCkpKSB7CgkJCXNrYl9xdWV1ZV90YWlsKCZiY3MtPnJxdWV1ZSwgc2tiKTsKCQkJaGZjcGNpX3NjaGVkX2V2ZW50KGJjcywgQl9SQ1ZCVUZSRUFEWSk7CgkJfQoJCXJjbnQgPSBiei0+ZjEgLSBiei0+ZjI7CgkJaWYgKHJjbnQgPCAwKQoJCQlyY250ICs9IE1BWF9CX0ZSQU1FUyArIDE7CgkJaWYgKGNzLT5ody5oZmNwY2kubGFzdF9iZmlmb19jbnRbcmVhbF9maWZvXSA+IHJjbnQgKyAxKSB7CgkJICAgICAgICByY250ID0gMDsKCQkJaGZjcGNpX2NsZWFyX2ZpZm9fcngoY3MsIHJlYWxfZmlmbyk7CgkJfQoJCWNzLT5ody5oZmNwY2kubGFzdF9iZmlmb19jbnRbcmVhbF9maWZvXSA9IHJjbnQ7CgkJaWYgKHJjbnQgPiAxKQoJCQlyZWNlaXZlID0gMTsKCQllbHNlCgkJCXJlY2VpdmUgPSAwOwoJfSBlbHNlIGlmIChiY3MtPm1vZGUgPT0gTDFfTU9ERV9UUkFOUykKCQlyZWNlaXZlID0gaGZjcGNpX2VtcHR5X2ZpZm9fdHJhbnMoYmNzLCBieiwgYmRhdGEpOwoJZWxzZQoJCXJlY2VpdmUgPSAwOwoJdGVzdF9hbmRfY2xlYXJfYml0KEZMR19MT0NLX0FUT01JQywgJmNzLT5IV19GbGFncyk7CglpZiAoY291bnQgJiYgcmVjZWl2ZSkKCQlnb3RvIEJlZ2luOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qIEQtY2hhbm5lbCBzZW5kIHJvdXRpbmUgKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZApoZmNwY2lfZmlsbF9kZmlmbyhzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSAqY3MpCnsKCWludCBmY250OwoJaW50IGNvdW50LCBuZXdfejEsIG1heGxlbjsKCWRmaWZvX3R5cGUgKmRmOwoJdV9jaGFyICpzcmMsICpkc3QsIG5ld19mMTsKCglpZiAoIWNzLT50eF9za2IpCgkJcmV0dXJuOwoJaWYgKGNzLT50eF9za2ItPmxlbiA8PSAwKQoJCXJldHVybjsKCglkZiA9ICYoKGZpZm9fYXJlYSAqKSAoY3MtPmh3LmhmY3BjaS5maWZvcykpLT5kX2NoYW4uZF90eDsKCglpZiAoY3MtPmRlYnVnICYgTDFfREVCX0lTQUMpCgkJZGVidWdsMShjcywgImhmY3BjaV9maWxsX0RmaWZvIGYxKCVkKSBmMiglZCkgejEoZjEpKCV4KSIsCgkJCWRmLT5mMSwgZGYtPmYyLAoJCQlkZi0+emFbZGYtPmYxICYgRF9GUkVHX01BU0tdLnoxKTsKCWZjbnQgPSBkZi0+ZjEgLSBkZi0+ZjI7CS8qIGZyYW1lIGNvdW50IGFjdHVhbGx5IGJ1ZmZlcmVkICovCglpZiAoZmNudCA8IDApCgkJZmNudCArPSAoTUFYX0RfRlJBTUVTICsgMSk7CS8qIGlmIHdyYXAgYXJvdW5kICovCglpZiAoZmNudCA+IChNQVhfRF9GUkFNRVMgLSAxKSkgewoJCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfSVNBQykKCQkJZGVidWdsMShjcywgImhmY3BjaV9maWxsX0RmaWZvIG1vcmUgYXMgMTQgZnJhbWVzIik7CiNpZmRlZiBFUlJPUl9TVEFUSVNUSUMKCQljcy0+ZXJyX3R4Kys7CiNlbmRpZgoJCXJldHVybjsKCX0KCS8qIG5vdyBkZXRlcm1pbmUgZnJlZSBieXRlcyBpbiBGSUZPIGJ1ZmZlciAqLwoJY291bnQgPSBkZi0+emFbZGYtPmYyICYgRF9GUkVHX01BU0tdLnoyIC0gZGYtPnphW2RmLT5mMSAmIERfRlJFR19NQVNLXS56MSAtIDE7CglpZiAoY291bnQgPD0gMCkKCQljb3VudCArPSBEX0ZJRk9fU0laRTsJLyogY291bnQgbm93IGNvbnRhaW5zIGF2YWlsYWJsZSBieXRlcyAqLwoKCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfSVNBQykKCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpX2ZpbGxfRGZpZm8gY291bnQoJWxkLyVkKSIsCgkJCWNzLT50eF9za2ItPmxlbiwgY291bnQpOwoJaWYgKGNvdW50IDwgY3MtPnR4X3NrYi0+bGVuKSB7CgkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9JU0FDKQoJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpX2ZpbGxfRGZpZm8gbm8gZmlmbyBtZW0iKTsKCQlyZXR1cm47Cgl9Cgljb3VudCA9IGNzLT50eF9za2ItPmxlbjsJLyogZ2V0IGZyYW1lIGxlbiAqLwoJbmV3X3oxID0gKGRmLT56YVtkZi0+ZjEgJiBEX0ZSRUdfTUFTS10uejEgKyBjb3VudCkgJiAoRF9GSUZPX1NJWkUgLSAxKTsKCW5ld19mMSA9ICgoZGYtPmYxICsgMSkgJiBEX0ZSRUdfTUFTSykgfCAoRF9GUkVHX01BU0sgKyAxKTsKCXNyYyA9IGNzLT50eF9za2ItPmRhdGE7CS8qIHNvdXJjZSBwb2ludGVyICovCglkc3QgPSBkZi0+ZGF0YSArIGRmLT56YVtkZi0+ZjEgJiBEX0ZSRUdfTUFTS10uejE7CgltYXhsZW4gPSBEX0ZJRk9fU0laRSAtIGRmLT56YVtkZi0+ZjEgJiBEX0ZSRUdfTUFTS10uejE7CQkvKiBlbmQgZmlmbyAqLwoJaWYgKG1heGxlbiA+IGNvdW50KQoJCW1heGxlbiA9IGNvdW50OwkvKiBsaW1pdCBzaXplICovCgltZW1jcHkoZHN0LCBzcmMsIG1heGxlbik7CS8qIGZpcnN0IGNvcHkgKi8KCgljb3VudCAtPSBtYXhsZW47CS8qIHJlbWFpbmluZyBieXRlcyAqLwoJaWYgKGNvdW50KSB7CgkJZHN0ID0gZGYtPmRhdGE7CS8qIHN0YXJ0IG9mIGJ1ZmZlciAqLwoJCXNyYyArPSBtYXhsZW47CS8qIG5ldyBwb3NpdGlvbiAqLwoJCW1lbWNweShkc3QsIHNyYywgY291bnQpOwoJfQoJZGYtPnphW25ld19mMSAmIERfRlJFR19NQVNLXS56MSA9IG5ld196MTsJLyogZm9yIG5leHQgYnVmZmVyICovCglkZi0+emFbZGYtPmYxICYgRF9GUkVHX01BU0tdLnoxID0gbmV3X3oxOwkvKiBuZXcgcG9zIGFjdHVhbCBidWZmZXIgKi8KCWRmLT5mMSA9IG5ld19mMTsJLyogbmV4dCBmcmFtZSAqLwoKCWRldl9rZnJlZV9za2JfYW55KGNzLT50eF9za2IpOwoJY3MtPnR4X3NrYiA9IE5VTEw7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogQi1jaGFubmVsIHNlbmQgcm91dGluZSAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyB2b2lkCmhmY3BjaV9maWxsX2ZpZm8oc3RydWN0IEJDU3RhdGUgKmJjcykKewoJc3RydWN0IElzZG5DYXJkU3RhdGUgKmNzID0gYmNzLT5jczsKCWludCBtYXhsZW4sIGZjbnQ7CglpbnQgY291bnQsIG5ld196MTsKCWJ6Zmlmb190eXBlICpiejsKCXVfY2hhciAqYmRhdGE7Cgl1X2NoYXIgbmV3X2YxLCAqc3JjLCAqZHN0OwoJdW5zaWduZWQgc2hvcnQgKnoxdCwgKnoydDsKCglpZiAoIWJjcy0+dHhfc2tiKQoJCXJldHVybjsKCWlmIChiY3MtPnR4X3NrYi0+bGVuIDw9IDApCgkJcmV0dXJuOwoKCWlmICgoYmNzLT5jaGFubmVsKSAmJiAoIWNzLT5ody5oZmNwY2kuYnN3YXBwZWQpKSB7CgkJYnogPSAmKChmaWZvX2FyZWEgKikgKGNzLT5ody5oZmNwY2kuZmlmb3MpKS0+Yl9jaGFucy50eGJ6X2IyOwoJCWJkYXRhID0gKChmaWZvX2FyZWEgKikgKGNzLT5ody5oZmNwY2kuZmlmb3MpKS0+Yl9jaGFucy50eGRhdF9iMjsKCX0gZWxzZSB7CgkJYnogPSAmKChmaWZvX2FyZWEgKikgKGNzLT5ody5oZmNwY2kuZmlmb3MpKS0+Yl9jaGFucy50eGJ6X2IxOwoJCWJkYXRhID0gKChmaWZvX2FyZWEgKikgKGNzLT5ody5oZmNwY2kuZmlmb3MpKS0+Yl9jaGFucy50eGRhdF9iMTsKCX0KCglpZiAoYmNzLT5tb2RlID09IEwxX01PREVfVFJBTlMpIHsKCQl6MXQgPSAmYnotPnphW01BWF9CX0ZSQU1FU10uejE7CgkJejJ0ID0gejF0ICsgMTsKCQlpZiAoY3MtPmRlYnVnICYgTDFfREVCX0hTQ1gpCgkJCWRlYnVnbDEoY3MsICJoZmNwY2lfZmlsbF9maWZvX3RyYW5zICVkIHoxKCV4KSB6MigleCkiLAoJCQkJYmNzLT5jaGFubmVsLCAqejF0LCAqejJ0KTsKCQlmY250ID0gKnoydCAtICp6MXQ7CgkJaWYgKGZjbnQgPD0gMCkKCQkJZmNudCArPSBCX0ZJRk9fU0laRTsJLyogZmNudCBjb250YWlucyBhdmFpbGFibGUgYnl0ZXMgaW4gZmlmbyAqLwoJCWZjbnQgPSBCX0ZJRk9fU0laRSAtIGZjbnQ7CS8qIHJlbWFpbmluZyBieXRlcyB0byBzZW5kICovCgoJCXdoaWxlICgoZmNudCA8IDIgKiBIRkNQQ0lfQlRSQU5TX1RIUkVTSE9MRCkgJiYgKGJjcy0+dHhfc2tiKSkgewoJCQlpZiAoYmNzLT50eF9za2ItPmxlbiA8IEJfRklGT19TSVpFIC0gZmNudCkgewoJCQkJLyogZGF0YSBpcyBzdWl0YWJsZSBmb3IgZmlmbyAqLwoJCQkJY291bnQgPSBiY3MtPnR4X3NrYi0+bGVuOwoKCQkJCW5ld196MSA9ICp6MXQgKyBjb3VudDsJLyogbmV3IGJ1ZmZlciBQb3NpdGlvbiAqLwoJCQkJaWYgKG5ld196MSA+PSAoQl9GSUZPX1NJWkUgKyBCX1NVQl9WQUwpKQoJCQkJCW5ld196MSAtPSBCX0ZJRk9fU0laRTsJLyogYnVmZmVyIHdyYXAgKi8KCQkJCXNyYyA9IGJjcy0+dHhfc2tiLT5kYXRhOwkvKiBzb3VyY2UgcG9pbnRlciAqLwoJCQkJZHN0ID0gYmRhdGEgKyAoKnoxdCAtIEJfU1VCX1ZBTCk7CgkJCQltYXhsZW4gPSAoQl9GSUZPX1NJWkUgKyBCX1NVQl9WQUwpIC0gKnoxdDsJLyogZW5kIG9mIGZpZm8gKi8KCQkJCWlmIChtYXhsZW4gPiBjb3VudCkKCQkJCQltYXhsZW4gPSBjb3VudDsJCS8qIGxpbWl0IHNpemUgKi8KCQkJCW1lbWNweShkc3QsIHNyYywgbWF4bGVuKTsJLyogZmlyc3QgY29weSAqLwoKCQkJCWNvdW50IC09IG1heGxlbjsJLyogcmVtYWluaW5nIGJ5dGVzICovCgkJCQlpZiAoY291bnQpIHsKCQkJCQlkc3QgPSBiZGF0YTsJLyogc3RhcnQgb2YgYnVmZmVyICovCgkJCQkJc3JjICs9IG1heGxlbjsJLyogbmV3IHBvc2l0aW9uICovCgkJCQkJbWVtY3B5KGRzdCwgc3JjLCBjb3VudCk7CgkJCQl9CgkJCQliY3MtPnR4X2NudCAtPSBiY3MtPnR4X3NrYi0+bGVuOwoJCQkJZmNudCArPSBiY3MtPnR4X3NrYi0+bGVuOwoJCQkJKnoxdCA9IG5ld196MTsJLyogbm93IHNlbmQgZGF0YSAqLwoJCQl9IGVsc2UgaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9IU0NYKQoJCQkJZGVidWdsMShjcywgImhmY3BjaV9maWxsX2ZpZm9fdHJhbnMgJWQgZnJhbWUgbGVuZ3RoICVkIGRpc2NhcmRlZCIsCgkJCQkJYmNzLT5jaGFubmVsLCBiY3MtPnR4X3NrYi0+bGVuKTsKCgkJCWlmICh0ZXN0X2JpdChGTEdfTExJX0wxV0FLRVVQLCZiY3MtPnN0LT5sbGkuZmxhZykgJiYKCQkJCShQQUNLRVRfTk9BQ0sgIT0gYmNzLT50eF9za2ItPnBrdF90eXBlKSkgewoJCQkJdV9sb25nCWZsYWdzOwoJCQkJc3Bpbl9sb2NrX2lycXNhdmUoJmJjcy0+YWNsb2NrLCBmbGFncyk7CgkJCQliY3MtPmFja2NudCArPSBiY3MtPnR4X3NrYi0+bGVuOwoJCQkJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmYmNzLT5hY2xvY2ssIGZsYWdzKTsKCQkJCXNjaGVkdWxlX2V2ZW50KGJjcywgQl9BQ0tQRU5ESU5HKTsKCQkJfQoKCQkJZGV2X2tmcmVlX3NrYl9hbnkoYmNzLT50eF9za2IpOwoJCQliY3MtPnR4X3NrYiA9IHNrYl9kZXF1ZXVlKCZiY3MtPnNxdWV1ZSk7CS8qIGZldGNoIG5leHQgZGF0YSAqLwoJCX0KCQl0ZXN0X2FuZF9jbGVhcl9iaXQoQkNfRkxHX0JVU1ksICZiY3MtPkZsYWcpOwoJCXJldHVybjsKCX0KCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfSFNDWCkKCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpX2ZpbGxfZmlmb19oZGxjICVkIGYxKCVkKSBmMiglZCkgejEoZjEpKCV4KSIsCgkJCWJjcy0+Y2hhbm5lbCwgYnotPmYxLCBiei0+ZjIsCgkJCWJ6LT56YVtiei0+ZjFdLnoxKTsKCglmY250ID0gYnotPmYxIC0gYnotPmYyOwkvKiBmcmFtZSBjb3VudCBhY3R1YWxseSBidWZmZXJlZCAqLwoJaWYgKGZjbnQgPCAwKQoJCWZjbnQgKz0gKE1BWF9CX0ZSQU1FUyArIDEpOwkvKiBpZiB3cmFwIGFyb3VuZCAqLwoJaWYgKGZjbnQgPiAoTUFYX0JfRlJBTUVTIC0gMSkpIHsKCQlpZiAoY3MtPmRlYnVnICYgTDFfREVCX0hTQ1gpCgkJCWRlYnVnbDEoY3MsICJoZmNwY2lfZmlsbF9CZmlmbyBtb3JlIGFzIDE0IGZyYW1lcyIpOwoJCXJldHVybjsKCX0KCS8qIG5vdyBkZXRlcm1pbmUgZnJlZSBieXRlcyBpbiBGSUZPIGJ1ZmZlciAqLwoJY291bnQgPSBiei0+emFbYnotPmYyXS56MiAtIGJ6LT56YVtiei0+ZjFdLnoxIC0gMTsKCWlmIChjb3VudCA8PSAwKQoJCWNvdW50ICs9IEJfRklGT19TSVpFOwkvKiBjb3VudCBub3cgY29udGFpbnMgYXZhaWxhYmxlIGJ5dGVzICovCgoJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9IU0NYKQoJCWRlYnVnbDEoY3MsICJoZmNwY2lfZmlsbF9maWZvICVkIGNvdW50KCVsZC8lZCksJWx4IiwKCQkJYmNzLT5jaGFubmVsLCBiY3MtPnR4X3NrYi0+bGVuLAoJCQljb3VudCwgY3VycmVudC0+c3RhdGUpOwoKCWlmIChjb3VudCA8IGJjcy0+dHhfc2tiLT5sZW4pIHsKCQlpZiAoY3MtPmRlYnVnICYgTDFfREVCX0hTQ1gpCgkJCWRlYnVnbDEoY3MsICJoZmNwY2lfZmlsbF9maWZvIG5vIGZpZm8gbWVtIik7CgkJcmV0dXJuOwoJfQoJY291bnQgPSBiY3MtPnR4X3NrYi0+bGVuOwkvKiBnZXQgZnJhbWUgbGVuICovCgluZXdfejEgPSBiei0+emFbYnotPmYxXS56MSArIGNvdW50OwkvKiBuZXcgYnVmZmVyIFBvc2l0aW9uICovCglpZiAobmV3X3oxID49IChCX0ZJRk9fU0laRSArIEJfU1VCX1ZBTCkpCgkJbmV3X3oxIC09IEJfRklGT19TSVpFOwkvKiBidWZmZXIgd3JhcCAqLwoKCW5ld19mMSA9ICgoYnotPmYxICsgMSkgJiBNQVhfQl9GUkFNRVMpOwoJc3JjID0gYmNzLT50eF9za2ItPmRhdGE7CS8qIHNvdXJjZSBwb2ludGVyICovCglkc3QgPSBiZGF0YSArIChiei0+emFbYnotPmYxXS56MSAtIEJfU1VCX1ZBTCk7CgltYXhsZW4gPSAoQl9GSUZPX1NJWkUgKyBCX1NVQl9WQUwpIC0gYnotPnphW2J6LT5mMV0uejE7CQkvKiBlbmQgZmlmbyAqLwoJaWYgKG1heGxlbiA+IGNvdW50KQoJCW1heGxlbiA9IGNvdW50OwkvKiBsaW1pdCBzaXplICovCgltZW1jcHkoZHN0LCBzcmMsIG1heGxlbik7CS8qIGZpcnN0IGNvcHkgKi8KCgljb3VudCAtPSBtYXhsZW47CS8qIHJlbWFpbmluZyBieXRlcyAqLwoJaWYgKGNvdW50KSB7CgkJZHN0ID0gYmRhdGE7CS8qIHN0YXJ0IG9mIGJ1ZmZlciAqLwoJCXNyYyArPSBtYXhsZW47CS8qIG5ldyBwb3NpdGlvbiAqLwoJCW1lbWNweShkc3QsIHNyYywgY291bnQpOwoJfQoJYmNzLT50eF9jbnQgLT0gYmNzLT50eF9za2ItPmxlbjsKCWlmICh0ZXN0X2JpdChGTEdfTExJX0wxV0FLRVVQLCZiY3MtPnN0LT5sbGkuZmxhZykgJiYKCQkoUEFDS0VUX05PQUNLICE9IGJjcy0+dHhfc2tiLT5wa3RfdHlwZSkpIHsKCQl1X2xvbmcJZmxhZ3M7CgkJc3Bpbl9sb2NrX2lycXNhdmUoJmJjcy0+YWNsb2NrLCBmbGFncyk7CgkJYmNzLT5hY2tjbnQgKz0gYmNzLT50eF9za2ItPmxlbjsKCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZiY3MtPmFjbG9jaywgZmxhZ3MpOwoJCXNjaGVkdWxlX2V2ZW50KGJjcywgQl9BQ0tQRU5ESU5HKTsKCX0KCgliei0+emFbbmV3X2YxXS56MSA9IG5ld196MTsJLyogZm9yIG5leHQgYnVmZmVyICovCgliei0+ZjEgPSBuZXdfZjE7CS8qIG5leHQgZnJhbWUgKi8KCglkZXZfa2ZyZWVfc2tiX2FueShiY3MtPnR4X3NrYik7CgliY3MtPnR4X3NrYiA9IE5VTEw7Cgl0ZXN0X2FuZF9jbGVhcl9iaXQoQkNfRkxHX0JVU1ksICZiY3MtPkZsYWcpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogRC1jaGFubmVsIGwxIHN0YXRlIGNhbGwgZm9yIGxlYXNlZCBOVC1tb2RlICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZApkY2hfbnRfbDJsMShzdHJ1Y3QgUFN0YWNrICpzdCwgaW50IHByLCB2b2lkICphcmcpCnsKCXN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcyA9IChzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSAqKSBzdC0+bDEuaGFyZHdhcmU7CgoJc3dpdGNoIChwcikgewoJCWNhc2UgKFBIX0RBVEEgfCBSRVFVRVNUKToKCQljYXNlIChQSF9QVUxMIHwgUkVRVUVTVCk6CgkJY2FzZSAoUEhfUFVMTCB8IElORElDQVRJT04pOgoJCQlzdC0+bDEubDFodyhzdCwgcHIsIGFyZyk7CgkJCWJyZWFrOwoJCWNhc2UgKFBIX0FDVElWQVRFIHwgUkVRVUVTVCk6CgkJCXN0LT5sMS5sMWwyKHN0LCBQSF9BQ1RJVkFURSB8IENPTkZJUk0sIE5VTEwpOwoJCQlicmVhazsKCQljYXNlIChQSF9URVNUTE9PUCB8IFJFUVVFU1QpOgoJCQlpZiAoMSAmIChsb25nKSBhcmcpCgkJCQlkZWJ1Z2wxKGNzLCAiUEhfVEVTVF9MT09QIEIxIik7CgkJCWlmICgyICYgKGxvbmcpIGFyZykKCQkJCWRlYnVnbDEoY3MsICJQSF9URVNUX0xPT1AgQjIiKTsKCQkJaWYgKCEoMyAmIChsb25nKSBhcmcpKQoJCQkJZGVidWdsMShjcywgIlBIX1RFU1RfTE9PUCBESVNBQkxFRCIpOwoJCQlzdC0+bDEubDFodyhzdCwgSFdfVEVTVExPT1AgfCBSRVFVRVNULCBhcmcpOwoJCQlicmVhazsKCQlkZWZhdWx0OgoJCQlpZiAoY3MtPmRlYnVnKQoJCQkJZGVidWdsMShjcywgImRjaF9udF9sMmwxIG1zZyAlMDRYIHVuaGFuZGxlZCIsIHByKTsKCQkJYnJlYWs7Cgl9Cn0KCgoKLyoqKioqKioqKioqKioqKioqKioqKioqLwovKiBzZXQvcmVzZXQgZWNobyBtb2RlICovCi8qKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIGludApoZmNwY2lfYXV4Y21kKHN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcywgaXNkbl9jdHJsICogaWMpCnsKCXVfbG9uZwlmbGFnczsKCWludAlpID0gKih1bnNpZ25lZCBpbnQgKikgaWMtPnBhcm0ubnVtOwoKCWlmICgoaWMtPmFyZyA9PSA5OCkgJiYKCSAgICAoIShjcy0+aHcuaGZjcGNpLmludF9tMSAmIChIRkNQQ0lfSU5UU19CMlRSQU5TICsgSEZDUENJX0lOVFNfQjJSRUMgKyBIRkNQQ0lfSU5UU19CMVRSQU5TICsgSEZDUENJX0lOVFNfQjFSRUMpKSkpIHsKCSAgICAJc3Bpbl9sb2NrX2lycXNhdmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQ0xLREVMLCBDTEtERUxfTlQpOyAvKiBTVC1CaXQgZGVsYXkgZm9yIE5ULU1vZGUgKi8KCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9TVEFURVMsIEhGQ1BDSV9MT0FEX1NUQVRFIHwgMCk7CS8qIEhGQyBTVCBHMCAqLwoJCXVkZWxheSgxMCk7CgkJY3MtPmh3LmhmY3BjaS5zY3RybCB8PSBTQ1RSTF9NT0RFX05UOwoJCVdyaXRlX2hmYyhjcywgSEZDUENJX1NDVFJMLCBjcy0+aHcuaGZjcGNpLnNjdHJsKTsJLyogc2V0IE5ULW1vZGUgKi8KCQl1ZGVsYXkoMTApOwoJCVdyaXRlX2hmYyhjcywgSEZDUENJX1NUQVRFUywgSEZDUENJX0xPQURfU1RBVEUgfCAxKTsJLyogSEZDIFNUIEcxICovCgkJdWRlbGF5KDEwKTsKCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9TVEFURVMsIDEgfCBIRkNQQ0lfQUNUSVZBVEUgfCBIRkNQQ0lfRE9fQUNUSU9OKTsKCQljcy0+ZGMuaGZjcGNpLnBoX3N0YXRlID0gMTsKCQljcy0+aHcuaGZjcGNpLm50X21vZGUgPSAxOwoJCWNzLT5ody5oZmNwY2kubnRfdGltZXIgPSAwOwoJCWNzLT5zdGxpc3QtPmwyLmwybDEgPSBkY2hfbnRfbDJsMTsKCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZjcy0+bG9jaywgZmxhZ3MpOwoJCWRlYnVnbDEoY3MsICJOVCBtb2RlIGFjdGl2YXRlZCIpOwoJCXJldHVybiAoMCk7Cgl9CglpZiAoKGNzLT5jaGFubGltaXQgPiAxKSB8fCAoY3MtPmh3LmhmY3BjaS5ic3dhcHBlZCkgfHwKCSAgICAoY3MtPmh3LmhmY3BjaS5udF9tb2RlKSB8fCAoaWMtPmFyZyAhPSAxMikpCgkJcmV0dXJuICgtRUlOVkFMKTsKCglzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCWlmIChpKSB7CgkJY3MtPmxvZ2VjaG8gPSAxOwoJCWNzLT5ody5oZmNwY2kudHJtIHw9IDB4MjA7CS8qIGVuYWJsZSBlY2hvIGNoYW4gKi8KCQljcy0+aHcuaGZjcGNpLmludF9tMSB8PSBIRkNQQ0lfSU5UU19CMlJFQzsKCQljcy0+aHcuaGZjcGNpLmZpZm9fZW4gfD0gSEZDUENJX0ZJRk9FTl9CMlJYOwoJfSBlbHNlIHsKCQljcy0+bG9nZWNobyA9IDA7CgkJY3MtPmh3LmhmY3BjaS50cm0gJj0gfjB4MjA7CS8qIGRpc2FibGUgZWNobyBjaGFuICovCgkJY3MtPmh3LmhmY3BjaS5pbnRfbTEgJj0gfkhGQ1BDSV9JTlRTX0IyUkVDOwoJCWNzLT5ody5oZmNwY2kuZmlmb19lbiAmPSB+SEZDUENJX0ZJRk9FTl9CMlJYOwoJfQoJY3MtPmh3LmhmY3BjaS5zY3RybF9yICY9IH5TQ1RSTF9CMl9FTkE7Cgljcy0+aHcuaGZjcGNpLnNjdHJsICY9IH5TQ1RSTF9CMl9FTkE7Cgljcy0+aHcuaGZjcGNpLmNvbm4gfD0gMHgxMDsJLyogQjItSU9NIC0+IEIyLVNUICovCgljcy0+aHcuaGZjcGNpLmN0bXQgJj0gfjI7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9DVE1ULCBjcy0+aHcuaGZjcGNpLmN0bXQpOwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfU0NUUkxfUiwgY3MtPmh3LmhmY3BjaS5zY3RybF9yKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX1NDVFJMLCBjcy0+aHcuaGZjcGNpLnNjdHJsKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0NPTk5FQ1QsIGNzLT5ody5oZmNwY2kuY29ubik7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9UUk0sIGNzLT5ody5oZmNwY2kudHJtKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0ZJRk9fRU4sIGNzLT5ody5oZmNwY2kuZmlmb19lbik7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9JTlRfTTEsIGNzLT5ody5oZmNwY2kuaW50X20xKTsKCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmNzLT5sb2NrLCBmbGFncyk7CglyZXR1cm4gKDApOwp9CQkJCS8qIGhmY3BjaV9hdXhjbWQgKi8KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogRS1jaGFubmVsIHJlY2VpdmUgcm91dGluZSAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyB2b2lkCnJlY2VpdmVfZW1zZyhzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSAqY3MpCnsKCWludCByY250OwoJaW50IHJlY2VpdmUsIGNvdW50ID0gNTsKCWJ6Zmlmb190eXBlICpiejsKCXVfY2hhciAqYmRhdGE7Cgl6X3R5cGUgKnpwOwoJdV9jaGFyICpwdHIsICpwdHIxLCBuZXdfZjI7CglpbnQgdG90YWwsIG1heGxlbiwgbmV3X3oyOwoJdV9jaGFyIGVfYnVmZmVyWzI1Nl07CgoJYnogPSAmKChmaWZvX2FyZWEgKikgKGNzLT5ody5oZmNwY2kuZmlmb3MpKS0+Yl9jaGFucy5yeGJ6X2IyOwoJYmRhdGEgPSAoKGZpZm9fYXJlYSAqKSAoY3MtPmh3LmhmY3BjaS5maWZvcykpLT5iX2NoYW5zLnJ4ZGF0X2IyOwogICAgICBCZWdpbjoKCWNvdW50LS07CglpZiAodGVzdF9hbmRfc2V0X2JpdChGTEdfTE9DS19BVE9NSUMsICZjcy0+SFdfRmxhZ3MpKSB7CgkJZGVidWdsMShjcywgImVjaG9fcmVjX2RhdGEgYmxvY2tlZCIpOwoJCXJldHVybjsKCX0KCWlmIChiei0+ZjEgIT0gYnotPmYyKSB7CgkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9JU0FDKQoJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpIGVfcmVjIGYxKCVkKSBmMiglZCkiLAoJCQkJYnotPmYxLCBiei0+ZjIpOwoJCXpwID0gJmJ6LT56YVtiei0+ZjJdOwoKCQlyY250ID0genAtPnoxIC0genAtPnoyOwoJCWlmIChyY250IDwgMCkKCQkJcmNudCArPSBCX0ZJRk9fU0laRTsKCQlyY250Kys7CgkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9JU0FDKQoJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpIGVfcmVjIHoxKCV4KSB6MigleCkgY250KCVkKSIsCgkJCQl6cC0+ejEsIHpwLT56MiwgcmNudCk7CgkJbmV3X3oyID0genAtPnoyICsgcmNudDsJCS8qIG5ldyBwb3NpdGlvbiBpbiBmaWZvICovCgkJaWYgKG5ld196MiA+PSAoQl9GSUZPX1NJWkUgKyBCX1NVQl9WQUwpKQoJCQluZXdfejIgLT0gQl9GSUZPX1NJWkU7CS8qIGJ1ZmZlciB3cmFwICovCgkJbmV3X2YyID0gKGJ6LT5mMiArIDEpICYgTUFYX0JfRlJBTUVTOwoJCWlmICgocmNudCA+IDI1NiArIDMpIHx8IChjb3VudCA8IDQpIHx8CgkJICAgICgqKGJkYXRhICsgKHpwLT56MSAtIEJfU1VCX1ZBTCkpKSkgewoJCQlpZiAoY3MtPmRlYnVnICYgTDFfREVCX1dBUk4pCgkJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpX2VtcHR5X2VjaGFuOiBpbmNvbWluZyBwYWNrZXQgaW52YWxpZCBsZW5ndGggJWQgb3IgY3JjIiwgcmNudCk7CgkJCWJ6LT56YVtuZXdfZjJdLnoyID0gbmV3X3oyOwoJCQliei0+ZjIgPSBuZXdfZjI7CS8qIG5leHQgYnVmZmVyICovCgkJfSBlbHNlIHsKCQkJdG90YWwgPSByY250OwoJCQlyY250IC09IDM7CgkJCXB0ciA9IGVfYnVmZmVyOwoKCQkJaWYgKHpwLT56MiA8PSBCX0ZJRk9fU0laRSArIEJfU1VCX1ZBTCkKCQkJCW1heGxlbiA9IHJjbnQ7CS8qIGNvbXBsZXRlIHRyYW5zZmVyICovCgkJCWVsc2UKCQkJCW1heGxlbiA9IEJfRklGT19TSVpFICsgQl9TVUJfVkFMIC0genAtPnoyOwkvKiBtYXhpbXVtICovCgoJCQlwdHIxID0gYmRhdGEgKyAoenAtPnoyIC0gQl9TVUJfVkFMKTsJLyogc3RhcnQgb2YgZGF0YSAqLwoJCQltZW1jcHkocHRyLCBwdHIxLCBtYXhsZW4pOwkvKiBjb3B5IGRhdGEgKi8KCQkJcmNudCAtPSBtYXhsZW47CgoJCQlpZiAocmNudCkgewkvKiByZXN0IHJlbWFpbmluZyAqLwoJCQkJcHRyICs9IG1heGxlbjsKCQkJCXB0cjEgPSBiZGF0YTsJLyogc3RhcnQgb2YgYnVmZmVyICovCgkJCQltZW1jcHkocHRyLCBwdHIxLCByY250KTsJLyogcmVzdCAqLwoJCQl9CgkJCWJ6LT56YVtuZXdfZjJdLnoyID0gbmV3X3oyOwoJCQliei0+ZjIgPSBuZXdfZjI7CS8qIG5leHQgYnVmZmVyICovCgkJCWlmIChjcy0+ZGVidWcgJiBERUJfRExPR19IRVgpIHsKCQkJCXB0ciA9IGNzLT5kbG9nOwoJCQkJaWYgKCh0b3RhbCAtIDMpIDwgTUFYX0RMT0dfU1BBQ0UgLyAzIC0gMTApIHsKCQkJCQkqcHRyKysgPSAnRSc7CgkJCQkJKnB0cisrID0gJ0MnOwoJCQkJCSpwdHIrKyA9ICdIJzsKCQkJCQkqcHRyKysgPSAnTyc7CgkJCQkJKnB0cisrID0gJzonOwoJCQkJCXB0ciArPSBRdWlja0hleChwdHIsIGVfYnVmZmVyLCB0b3RhbCAtIDMpOwoJCQkJCXB0ci0tOwoJCQkJCSpwdHIrKyA9ICdcbic7CgkJCQkJKnB0ciA9IDA7CgkJCQkJSGlTYXhfcHV0c3RhdHVzKGNzLCBOVUxMLCBjcy0+ZGxvZyk7CgkJCQl9IGVsc2UKCQkJCQlIaVNheF9wdXRzdGF0dXMoY3MsICJMb2dFY2hvOiAiLCAid2FybmluZyBGcmFtZSB0b28gYmlnICglZCkiLCB0b3RhbCAtIDMpOwoJCQl9CgkJfQoKCQlyY250ID0gYnotPmYxIC0gYnotPmYyOwoJCWlmIChyY250IDwgMCkKCQkJcmNudCArPSBNQVhfQl9GUkFNRVMgKyAxOwoJCWlmIChyY250ID4gMSkKCQkJcmVjZWl2ZSA9IDE7CgkJZWxzZQoJCQlyZWNlaXZlID0gMDsKCX0gZWxzZQoJCXJlY2VpdmUgPSAwOwoJdGVzdF9hbmRfY2xlYXJfYml0KEZMR19MT0NLX0FUT01JQywgJmNzLT5IV19GbGFncyk7CglpZiAoY291bnQgJiYgcmVjZWl2ZSkKCQlnb3RvIEJlZ2luOwp9CQkJCS8qIHJlY2VpdmVfZW1zZyAqLwoKLyoqKioqKioqKioqKioqKioqKioqKi8KLyogSW50ZXJydXB0IGhhbmRsZXIgKi8KLyoqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIGlycXJldHVybl90CmhmY3BjaV9pbnRlcnJ1cHQoaW50IGludG5vLCB2b2lkICpkZXZfaWQpCnsKCXVfbG9uZyBmbGFnczsKCXN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcyA9IGRldl9pZDsKCXVfY2hhciBleHZhbDsKCXN0cnVjdCBCQ1N0YXRlICpiY3M7CglpbnQgY291bnQgPSAxNTsKCXVfY2hhciB2YWwsIHN0YXQ7CgoJaWYgKCEoY3MtPmh3LmhmY3BjaS5pbnRfbTIgJiAweDA4KSkgewoJCWRlYnVnbDEoY3MsICJIRkMtUENJOiBpbnRfbTIgJXggbm90IGluaXRpYWxpc2VkIiwgY3MtPmh3LmhmY3BjaS5pbnRfbTIpOwoJCXJldHVybiBJUlFfTk9ORTsJLyogbm90IGluaXRpYWxpc2VkICovCgl9CglzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCWlmIChIRkNQQ0lfQU5ZSU5UICYgKHN0YXQgPSBSZWFkX2hmYyhjcywgSEZDUENJX1NUQVRVUykpKSB7CgkJdmFsID0gUmVhZF9oZmMoY3MsIEhGQ1BDSV9JTlRfUzEpOwoJCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfSVNBQykKCQkJZGVidWdsMShjcywgIkhGQy1QQ0k6IHN0YXQoJTAyeCkgczEoJTAyeCkiLCBzdGF0LCB2YWwpOwoJfSBlbHNlIHsKCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZjcy0+bG9jaywgZmxhZ3MpOwoJCXJldHVybiBJUlFfTk9ORTsKCX0KCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfSVNBQykKCQlkZWJ1Z2wxKGNzLCAiSEZDLVBDSSBpcnEgJXggJXMiLCB2YWwsCgkJCXRlc3RfYml0KEZMR19MT0NLX0FUT01JQywgJmNzLT5IV19GbGFncykgPwoJCQkibG9ja2VkIiA6ICJ1bmxvY2tlZCIpOwoJdmFsICY9IGNzLT5ody5oZmNwY2kuaW50X20xOwoJaWYgKHZhbCAmIDB4NDApIHsJLyogc3RhdGUgbWFjaGluZSBpcnEgKi8KCQlleHZhbCA9IFJlYWRfaGZjKGNzLCBIRkNQQ0lfU1RBVEVTKSAmIDB4ZjsKCQlpZiAoY3MtPmRlYnVnICYgTDFfREVCX0lTQUMpCgkJCWRlYnVnbDEoY3MsICJwaF9zdGF0ZSBjaGcgJWQtPiVkIiwgY3MtPmRjLmhmY3BjaS5waF9zdGF0ZSwKCQkJCWV4dmFsKTsKCQljcy0+ZGMuaGZjcGNpLnBoX3N0YXRlID0gZXh2YWw7CgkJc2NoZWRfZXZlbnRfRF9wY2koY3MsIERfTDFTVEFURUNIQU5HRSk7CgkJdmFsICY9IH4weDQwOwoJfQoJaWYgKHZhbCAmIDB4ODApIHsJLyogdGltZXIgaXJxICovCgkJaWYgKGNzLT5ody5oZmNwY2kubnRfbW9kZSkgewoJCQlpZiAoKC0tY3MtPmh3LmhmY3BjaS5udF90aW1lcikgPCAwKQoJCQkJc2NoZWRfZXZlbnRfRF9wY2koY3MsIERfTDFTVEFURUNIQU5HRSk7CgkJfQoJCXZhbCAmPSB+MHg4MDsKCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9DVE1ULCBjcy0+aHcuaGZjcGNpLmN0bXQgfCBIRkNQQ0lfQ0xUSU1FUik7Cgl9Cgl3aGlsZSAodmFsKSB7CgkJaWYgKHRlc3RfYml0KEZMR19MT0NLX0FUT01JQywgJmNzLT5IV19GbGFncykpIHsKCQkJY3MtPmh3LmhmY3BjaS5pbnRfczEgfD0gdmFsOwoJCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZjcy0+bG9jaywgZmxhZ3MpOwoJCQlyZXR1cm4gSVJRX0hBTkRMRUQ7CgkJfQoJCWlmIChjcy0+aHcuaGZjcGNpLmludF9zMSAmIDB4MTgpIHsKCQkJZXh2YWwgPSB2YWw7CgkJCXZhbCA9IGNzLT5ody5oZmNwY2kuaW50X3MxOwoJCQljcy0+aHcuaGZjcGNpLmludF9zMSA9IGV4dmFsOwoJCX0KCQlpZiAodmFsICYgMHgwOCkgewoJCQlpZiAoIShiY3MgPSBTZWxfQkNTKGNzLCBjcy0+aHcuaGZjcGNpLmJzd2FwcGVkID8gMSA6IDApKSkgewoJCQkJaWYgKGNzLT5kZWJ1ZykKCQkJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpIHNwdXJpb3VzIDB4MDggSVJRIik7CgkJCX0gZWxzZQoJCQkJbWFpbl9yZWNfaGZjcGNpKGJjcyk7CgkJfQoJCWlmICh2YWwgJiAweDEwKSB7CgkJCWlmIChjcy0+bG9nZWNobykKCQkJCXJlY2VpdmVfZW1zZyhjcyk7CgkJCWVsc2UgaWYgKCEoYmNzID0gU2VsX0JDUyhjcywgMSkpKSB7CgkJCQlpZiAoY3MtPmRlYnVnKQoJCQkJCWRlYnVnbDEoY3MsICJoZmNwY2kgc3B1cmlvdXMgMHgxMCBJUlEiKTsKCQkJfSBlbHNlCgkJCQltYWluX3JlY19oZmNwY2koYmNzKTsKCQl9CgkJaWYgKHZhbCAmIDB4MDEpIHsKCQkJaWYgKCEoYmNzID0gU2VsX0JDUyhjcywgY3MtPmh3LmhmY3BjaS5ic3dhcHBlZCA/IDEgOiAwKSkpIHsKCQkJCWlmIChjcy0+ZGVidWcpCgkJCQkJZGVidWdsMShjcywgImhmY3BjaSBzcHVyaW91cyAweDAxIElSUSIpOwoJCQl9IGVsc2UgewoJCQkJaWYgKGJjcy0+dHhfc2tiKSB7CgkJCQkJaWYgKCF0ZXN0X2FuZF9zZXRfYml0KEZMR19MT0NLX0FUT01JQywgJmNzLT5IV19GbGFncykpIHsKCQkJCQkJaGZjcGNpX2ZpbGxfZmlmbyhiY3MpOwoJCQkJCQl0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKTsKCQkJCQl9IGVsc2UKCQkJCQkJZGVidWdsMShjcywgImZpbGxfZGF0YSAlZCBibG9ja2VkIiwgYmNzLT5jaGFubmVsKTsKCQkJCX0gZWxzZSB7CgkJCQkJaWYgKChiY3MtPnR4X3NrYiA9IHNrYl9kZXF1ZXVlKCZiY3MtPnNxdWV1ZSkpKSB7CgkJCQkJCWlmICghdGVzdF9hbmRfc2V0X2JpdChGTEdfTE9DS19BVE9NSUMsICZjcy0+SFdfRmxhZ3MpKSB7CgkJCQkJCQloZmNwY2lfZmlsbF9maWZvKGJjcyk7CgkJCQkJCQl0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKTsKCQkJCQkJfSBlbHNlCgkJCQkJCQlkZWJ1Z2wxKGNzLCAiZmlsbF9kYXRhICVkIGJsb2NrZWQiLCBiY3MtPmNoYW5uZWwpOwoJCQkJCX0gZWxzZSB7CgkJCQkJCWhmY3BjaV9zY2hlZF9ldmVudChiY3MsIEJfWE1UQlVGUkVBRFkpOwoJCQkJCX0KCQkJCX0KCQkJfQoJCX0KCQlpZiAodmFsICYgMHgwMikgewoJCQlpZiAoIShiY3MgPSBTZWxfQkNTKGNzLCAxKSkpIHsKCQkJCWlmIChjcy0+ZGVidWcpCgkJCQkJZGVidWdsMShjcywgImhmY3BjaSBzcHVyaW91cyAweDAyIElSUSIpOwoJCQl9IGVsc2UgewoJCQkJaWYgKGJjcy0+dHhfc2tiKSB7CgkJCQkJaWYgKCF0ZXN0X2FuZF9zZXRfYml0KEZMR19MT0NLX0FUT01JQywgJmNzLT5IV19GbGFncykpIHsKCQkJCQkJaGZjcGNpX2ZpbGxfZmlmbyhiY3MpOwoJCQkJCQl0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKTsKCQkJCQl9IGVsc2UKCQkJCQkJZGVidWdsMShjcywgImZpbGxfZGF0YSAlZCBibG9ja2VkIiwgYmNzLT5jaGFubmVsKTsKCQkJCX0gZWxzZSB7CgkJCQkJaWYgKChiY3MtPnR4X3NrYiA9IHNrYl9kZXF1ZXVlKCZiY3MtPnNxdWV1ZSkpKSB7CgkJCQkJCWlmICghdGVzdF9hbmRfc2V0X2JpdChGTEdfTE9DS19BVE9NSUMsICZjcy0+SFdfRmxhZ3MpKSB7CgkJCQkJCQloZmNwY2lfZmlsbF9maWZvKGJjcyk7CgkJCQkJCQl0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKTsKCQkJCQkJfSBlbHNlCgkJCQkJCQlkZWJ1Z2wxKGNzLCAiZmlsbF9kYXRhICVkIGJsb2NrZWQiLCBiY3MtPmNoYW5uZWwpOwoJCQkJCX0gZWxzZSB7CgkJCQkJCWhmY3BjaV9zY2hlZF9ldmVudChiY3MsIEJfWE1UQlVGUkVBRFkpOwoJCQkJCX0KCQkJCX0KCQkJfQoJCX0KCQlpZiAodmFsICYgMHgyMCkgewkvKiByZWNlaXZlIGRmcmFtZSAqLwoJCQlyZWNlaXZlX2Rtc2coY3MpOwoJCX0KCQlpZiAodmFsICYgMHgwNCkgewkvKiBkZnJhbWUgdHJhbnNtaXR0ZWQgKi8KCQkJaWYgKHRlc3RfYW5kX2NsZWFyX2JpdChGTEdfREJVU1lfVElNRVIsICZjcy0+SFdfRmxhZ3MpKQoJCQkJZGVsX3RpbWVyKCZjcy0+ZGJ1c3l0aW1lcik7CgkJCWlmICh0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0wxX0RCVVNZLCAmY3MtPkhXX0ZsYWdzKSkKCQkJCXNjaGVkX2V2ZW50X0RfcGNpKGNzLCBEX0NMRUFSQlVTWSk7CgkJCWlmIChjcy0+dHhfc2tiKSB7CgkJCQlpZiAoY3MtPnR4X3NrYi0+bGVuKSB7CgkJCQkJaWYgKCF0ZXN0X2FuZF9zZXRfYml0KEZMR19MT0NLX0FUT01JQywgJmNzLT5IV19GbGFncykpIHsKCQkJCQkJaGZjcGNpX2ZpbGxfZGZpZm8oY3MpOwoJCQkJCQl0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKTsKCQkJCQl9IGVsc2UgewoJCQkJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpX2ZpbGxfZGZpZm8gaXJxIGJsb2NrZWQiKTsKCQkJCQl9CgkJCQkJZ290byBhZnRlclhQUjsKCQkJCX0gZWxzZSB7CgkJCQkJZGV2X2tmcmVlX3NrYl9pcnEoY3MtPnR4X3NrYik7CgkJCQkJY3MtPnR4X2NudCA9IDA7CgkJCQkJY3MtPnR4X3NrYiA9IE5VTEw7CgkJCQl9CgkJCX0KCQkJaWYgKChjcy0+dHhfc2tiID0gc2tiX2RlcXVldWUoJmNzLT5zcSkpKSB7CgkJCQljcy0+dHhfY250ID0gMDsKCQkJCWlmICghdGVzdF9hbmRfc2V0X2JpdChGTEdfTE9DS19BVE9NSUMsICZjcy0+SFdfRmxhZ3MpKSB7CgkJCQkJaGZjcGNpX2ZpbGxfZGZpZm8oY3MpOwoJCQkJCXRlc3RfYW5kX2NsZWFyX2JpdChGTEdfTE9DS19BVE9NSUMsICZjcy0+SFdfRmxhZ3MpOwoJCQkJfSBlbHNlIHsKCQkJCQlkZWJ1Z2wxKGNzLCAiaGZjcGNpX2ZpbGxfZGZpZm8gaXJxIGJsb2NrZWQiKTsKCQkJCX0KCQkJfSBlbHNlCgkJCQlzY2hlZF9ldmVudF9EX3BjaShjcywgRF9YTVRCVUZSRUFEWSk7CgkJfQoJICAgICAgYWZ0ZXJYUFI6CgkJaWYgKGNzLT5ody5oZmNwY2kuaW50X3MxICYmIGNvdW50LS0pIHsKCQkJdmFsID0gY3MtPmh3LmhmY3BjaS5pbnRfczE7CgkJCWNzLT5ody5oZmNwY2kuaW50X3MxID0gMDsKCQkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9JU0FDKQoJCQkJZGVidWdsMShjcywgIkhGQy1QQ0kgaXJxICV4IGxvb3AgJWQiLCB2YWwsIDE1IC0gY291bnQpOwoJCX0gZWxzZQoJCQl2YWwgPSAwOwoJfQoJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmY3MtPmxvY2ssIGZsYWdzKTsKCXJldHVybiBJUlFfSEFORExFRDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiB0aW1lciBjYWxsYmFjayBmb3IgRC1jaGFuIGJ1c3kgcmVzb2x1dGlvbi4gQ3VycmVudGx5IG5vIGZ1bmN0aW9uICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQKaGZjcGNpX2RidXN5X3RpbWVyKHN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcykKewp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogTGF5ZXIgMSBELWNoYW5uZWwgaGFyZHdhcmUgYWNjZXNzICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZApIRkNQQ0lfbDFodyhzdHJ1Y3QgUFN0YWNrICpzdCwgaW50IHByLCB2b2lkICphcmcpCnsKCXVfbG9uZyBmbGFnczsKCXN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcyA9IChzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSAqKSBzdC0+bDEuaGFyZHdhcmU7CglzdHJ1Y3Qgc2tfYnVmZiAqc2tiID0gYXJnOwoKCXN3aXRjaCAocHIpIHsKCQljYXNlIChQSF9EQVRBIHwgUkVRVUVTVCk6CgkJCWlmIChjcy0+ZGVidWcgJiBERUJfRExPR19IRVgpCgkJCQlMb2dGcmFtZShjcywgc2tiLT5kYXRhLCBza2ItPmxlbik7CgkJCWlmIChjcy0+ZGVidWcgJiBERUJfRExPR19WRVJCT1NFKQoJCQkJZGxvZ2ZyYW1lKGNzLCBza2IsIDApOwoJCQlzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJaWYgKGNzLT50eF9za2IpIHsKCQkJCXNrYl9xdWV1ZV90YWlsKCZjcy0+c3EsIHNrYik7CiNpZmRlZiBMMkZSQU1FX0RFQlVHCQkvKiBwc2EgKi8KCQkJCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfTEFQRCkKCQkJCQlMb2dsMkZyYW1lKGNzLCBza2IsICJQSF9EQVRBIFF1ZXVlZCIsIDApOwojZW5kaWYKCQkJfSBlbHNlIHsKCQkJCWNzLT50eF9za2IgPSBza2I7CgkJCQljcy0+dHhfY250ID0gMDsKI2lmZGVmIEwyRlJBTUVfREVCVUcJCS8qIHBzYSAqLwoJCQkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9MQVBEKQoJCQkJCUxvZ2wyRnJhbWUoY3MsIHNrYiwgIlBIX0RBVEEiLCAwKTsKI2VuZGlmCgkJCQlpZiAoIXRlc3RfYW5kX3NldF9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKSkgewoJCQkJCWhmY3BjaV9maWxsX2RmaWZvKGNzKTsKCQkJCQl0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKTsKCQkJCX0gZWxzZQoJCQkJCWRlYnVnbDEoY3MsICJoZmNwY2lfZmlsbF9kZmlmbyBibG9ja2VkIik7CgoJCQl9CgkJCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJCWJyZWFrOwoJCWNhc2UgKFBIX1BVTEwgfCBJTkRJQ0FUSU9OKToKCQkJc3Bpbl9sb2NrX2lycXNhdmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJCWlmIChjcy0+dHhfc2tiKSB7CgkJCQlpZiAoY3MtPmRlYnVnICYgTDFfREVCX1dBUk4pCgkJCQkJZGVidWdsMShjcywgIiBsMmwxIHR4X3NrYiBleGlzdCB0aGlzIHNob3VsZG4ndCBoYXBwZW4iKTsKCQkJCXNrYl9xdWV1ZV90YWlsKCZjcy0+c3EsIHNrYik7CgkJCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZjcy0+bG9jaywgZmxhZ3MpOwoJCQkJYnJlYWs7CgkJCX0KCQkJaWYgKGNzLT5kZWJ1ZyAmIERFQl9ETE9HX0hFWCkKCQkJCUxvZ0ZyYW1lKGNzLCBza2ItPmRhdGEsIHNrYi0+bGVuKTsKCQkJaWYgKGNzLT5kZWJ1ZyAmIERFQl9ETE9HX1ZFUkJPU0UpCgkJCQlkbG9nZnJhbWUoY3MsIHNrYiwgMCk7CgkJCWNzLT50eF9za2IgPSBza2I7CgkJCWNzLT50eF9jbnQgPSAwOwojaWZkZWYgTDJGUkFNRV9ERUJVRwkJLyogcHNhICovCgkJCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfTEFQRCkKCQkJCUxvZ2wyRnJhbWUoY3MsIHNrYiwgIlBIX0RBVEFfUFVMTEVEIiwgMCk7CiNlbmRpZgoJCQlpZiAoIXRlc3RfYW5kX3NldF9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKSkgewoJCQkJaGZjcGNpX2ZpbGxfZGZpZm8oY3MpOwoJCQkJdGVzdF9hbmRfY2xlYXJfYml0KEZMR19MT0NLX0FUT01JQywgJmNzLT5IV19GbGFncyk7CgkJCX0gZWxzZQoJCQkJZGVidWdsMShjcywgImhmY3BjaV9maWxsX2RmaWZvIGJsb2NrZWQiKTsKCQkJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJYnJlYWs7CgkJY2FzZSAoUEhfUFVMTCB8IFJFUVVFU1QpOgojaWZkZWYgTDJGUkFNRV9ERUJVRwkJLyogcHNhICovCgkJCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfTEFQRCkKCQkJCWRlYnVnbDEoY3MsICItPiBQSF9SRVFVRVNUX1BVTEwiKTsKI2VuZGlmCgkJCWlmICghY3MtPnR4X3NrYikgewoJCQkJdGVzdF9hbmRfY2xlYXJfYml0KEZMR19MMV9QVUxMX1JFUSwgJnN0LT5sMS5GbGFncyk7CgkJCQlzdC0+bDEubDFsMihzdCwgUEhfUFVMTCB8IENPTkZJUk0sIE5VTEwpOwoJCQl9IGVsc2UKCQkJCXRlc3RfYW5kX3NldF9iaXQoRkxHX0wxX1BVTExfUkVRLCAmc3QtPmwxLkZsYWdzKTsKCQkJYnJlYWs7CgkJY2FzZSAoSFdfUkVTRVQgfCBSRVFVRVNUKToKCQkJc3Bpbl9sb2NrX2lycXNhdmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJCVdyaXRlX2hmYyhjcywgSEZDUENJX1NUQVRFUywgSEZDUENJX0xPQURfU1RBVEUgfCAzKTsJLyogSEZDIFNUIDMgKi8KCQkJdWRlbGF5KDYpOwoJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9TVEFURVMsIDMpOwkvKiBIRkMgU1QgMiAqLwoJCQljcy0+aHcuaGZjcGNpLm1zdF9tIHw9IEhGQ1BDSV9NQVNURVI7CgkJCVdyaXRlX2hmYyhjcywgSEZDUENJX01TVF9NT0RFLCBjcy0+aHcuaGZjcGNpLm1zdF9tKTsKCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfU1RBVEVTLCBIRkNQQ0lfQUNUSVZBVEUgfCBIRkNQQ0lfRE9fQUNUSU9OKTsKCQkJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJbDFfbXNnKGNzLCBIV19QT1dFUlVQIHwgQ09ORklSTSwgTlVMTCk7CgkJCWJyZWFrOwoJCWNhc2UgKEhXX0VOQUJMRSB8IFJFUVVFU1QpOgoJCQlzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfU1RBVEVTLCBIRkNQQ0lfRE9fQUNUSU9OKTsKCQkJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJYnJlYWs7CgkJY2FzZSAoSFdfREVBQ1RJVkFURSB8IFJFUVVFU1QpOgoJCQlzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJY3MtPmh3LmhmY3BjaS5tc3RfbSAmPSB+SEZDUENJX01BU1RFUjsKCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfTVNUX01PREUsIGNzLT5ody5oZmNwY2kubXN0X20pOwoJCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZjcy0+bG9jaywgZmxhZ3MpOwoJCQlicmVhazsKCQljYXNlIChIV19JTkZPMyB8IFJFUVVFU1QpOgoJCQlzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJY3MtPmh3LmhmY3BjaS5tc3RfbSB8PSBIRkNQQ0lfTUFTVEVSOwoJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9NU1RfTU9ERSwgY3MtPmh3LmhmY3BjaS5tc3RfbSk7CgkJCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJCWJyZWFrOwoJCWNhc2UgKEhXX1RFU1RMT09QIHwgUkVRVUVTVCk6CgkJCXNwaW5fbG9ja19pcnFzYXZlKCZjcy0+bG9jaywgZmxhZ3MpOwoJCQlzd2l0Y2ggKChsb25nKSBhcmcpIHsKCQkJCWNhc2UgKDEpOgoJCQkJCVdyaXRlX2hmYyhjcywgSEZDUENJX0IxX1NTTCwgMHg4MCk7CS8qIHR4IHNsb3QgKi8KCQkJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9CMV9SU0wsIDB4ODApOwkvKiByeCBzbG90ICovCgkJCQkJY3MtPmh3LmhmY3BjaS5jb25uID0gKGNzLT5ody5oZmNwY2kuY29ubiAmIH43KSB8IDE7CgkJCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQ09OTkVDVCwgY3MtPmh3LmhmY3BjaS5jb25uKTsKCQkJCQlicmVhazsKCgkJCQljYXNlICgyKToKCQkJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9CMl9TU0wsIDB4ODEpOwkvKiB0eCBzbG90ICovCgkJCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQjJfUlNMLCAweDgxKTsJLyogcnggc2xvdCAqLwoJCQkJCWNzLT5ody5oZmNwY2kuY29ubiA9IChjcy0+aHcuaGZjcGNpLmNvbm4gJiB+MHgzOCkgfCAweDA4OwoJCQkJCVdyaXRlX2hmYyhjcywgSEZDUENJX0NPTk5FQ1QsIGNzLT5ody5oZmNwY2kuY29ubik7CgkJCQkJYnJlYWs7CgoJCQkJZGVmYXVsdDoKCQkJCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZjcy0+bG9jaywgZmxhZ3MpOwoJCQkJCWlmIChjcy0+ZGVidWcgJiBMMV9ERUJfV0FSTikKCQkJCQkJZGVidWdsMShjcywgImhmY3BjaV9sMWh3IGxvb3AgaW52YWxpZCAlNGx4IiwgKGxvbmcpIGFyZyk7CgkJCQkJcmV0dXJuOwoJCQl9CgkJCWNzLT5ody5oZmNwY2kudHJtIHw9IDB4ODA7CS8qIGVuYWJsZSBJT00tbG9vcCAqLwoJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9UUk0sIGNzLT5ody5oZmNwY2kudHJtKTsKCQkJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJYnJlYWs7CgkJZGVmYXVsdDoKCQkJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9XQVJOKQoJCQkJZGVidWdsMShjcywgImhmY3BjaV9sMWh3IHVua25vd24gcHIgJTR4IiwgcHIpOwoJCQlicmVhazsKCX0KfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBjYWxsZWQgZHVyaW5nIGluaXQgc2V0dGluZyBsMSBzdGFjayBwb2ludGVyICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQKc2V0c3RhY2tfaGZjcGNpKHN0cnVjdCBQU3RhY2sgKnN0LCBzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSAqY3MpCnsKCXN0LT5sMS5sMWh3ID0gSEZDUENJX2wxaHc7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogc2VuZCBCLWNoYW5uZWwgZGF0YSBpZiBub3QgYmxvY2tlZCAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyB2b2lkCmhmY3BjaV9zZW5kX2RhdGEoc3RydWN0IEJDU3RhdGUgKmJjcykKewoJc3RydWN0IElzZG5DYXJkU3RhdGUgKmNzID0gYmNzLT5jczsKCglpZiAoIXRlc3RfYW5kX3NldF9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKSkgewoJCWhmY3BjaV9maWxsX2ZpZm8oYmNzKTsKCQl0ZXN0X2FuZF9jbGVhcl9iaXQoRkxHX0xPQ0tfQVRPTUlDLCAmY3MtPkhXX0ZsYWdzKTsKCX0gZWxzZQoJCWRlYnVnbDEoY3MsICJzZW5kX2RhdGEgJWQgYmxvY2tlZCIsIGJjcy0+Y2hhbm5lbCk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qIGFjdGl2YXRlL2RlYWN0aXZhdGUgaGFyZHdhcmUgZm9yIHNlbGVjdGVkIGNoYW5uZWxzIGFuZCBtb2RlICovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyB2b2lkCm1vZGVfaGZjcGNpKHN0cnVjdCBCQ1N0YXRlICpiY3MsIGludCBtb2RlLCBpbnQgYmMpCnsKCXN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcyA9IGJjcy0+Y3M7CglpbnQgZmlmbzI7CgoJaWYgKGNzLT5kZWJ1ZyAmIEwxX0RFQl9IU0NYKQoJCWRlYnVnbDEoY3MsICJIRkNQQ0kgYmNoYW5uZWwgbW9kZSAlZCBiY2hhbiAlZC8lZCIsCgkJCW1vZGUsIGJjLCBiY3MtPmNoYW5uZWwpOwoJYmNzLT5tb2RlID0gbW9kZTsKCWJjcy0+Y2hhbm5lbCA9IGJjOwoJZmlmbzIgPSBiYzsKCWlmIChjcy0+Y2hhbmxpbWl0ID4gMSkgewoJCWNzLT5ody5oZmNwY2kuYnN3YXBwZWQgPSAwOwkvKiBCMSBhbmQgQjIgbm9ybWFsIG1vZGUgKi8KCQljcy0+aHcuaGZjcGNpLnNjdHJsX2UgJj0gfjB4ODA7Cgl9IGVsc2UgewoJCWlmIChiYykgewoJCQlpZiAobW9kZSAhPSBMMV9NT0RFX05VTEwpIHsKCQkJCWNzLT5ody5oZmNwY2kuYnN3YXBwZWQgPSAxOwkvKiBCMSBhbmQgQjIgZXhjaGFuZ2VkICovCgkJCQljcy0+aHcuaGZjcGNpLnNjdHJsX2UgfD0gMHg4MDsKCQkJfSBlbHNlIHsKCQkJCWNzLT5ody5oZmNwY2kuYnN3YXBwZWQgPSAwOwkvKiBCMSBhbmQgQjIgbm9ybWFsIG1vZGUgKi8KCQkJCWNzLT5ody5oZmNwY2kuc2N0cmxfZSAmPSB+MHg4MDsKCQkJfQoJCQlmaWZvMiA9IDA7CgkJfSBlbHNlIHsKCQkJY3MtPmh3LmhmY3BjaS5ic3dhcHBlZCA9IDA7CS8qIEIxIGFuZCBCMiBub3JtYWwgbW9kZSAqLwoJCQljcy0+aHcuaGZjcGNpLnNjdHJsX2UgJj0gfjB4ODA7CgkJfQoJfQoJc3dpdGNoIChtb2RlKSB7CgkJY2FzZSAoTDFfTU9ERV9OVUxMKToKCQkJaWYgKGJjKSB7CgkJCQljcy0+aHcuaGZjcGNpLnNjdHJsICY9IH5TQ1RSTF9CMl9FTkE7CgkJCQljcy0+aHcuaGZjcGNpLnNjdHJsX3IgJj0gflNDVFJMX0IyX0VOQTsKCQkJfSBlbHNlIHsKCQkJCWNzLT5ody5oZmNwY2kuc2N0cmwgJj0gflNDVFJMX0IxX0VOQTsKCQkJCWNzLT5ody5oZmNwY2kuc2N0cmxfciAmPSB+U0NUUkxfQjFfRU5BOwoJCQl9CgkJCWlmIChmaWZvMikgewoJCQkJY3MtPmh3LmhmY3BjaS5maWZvX2VuICY9IH5IRkNQQ0lfRklGT0VOX0IyOwoJCQkJY3MtPmh3LmhmY3BjaS5pbnRfbTEgJj0gfihIRkNQQ0lfSU5UU19CMlRSQU5TICsgSEZDUENJX0lOVFNfQjJSRUMpOwoJCQl9IGVsc2UgewoJCQkJY3MtPmh3LmhmY3BjaS5maWZvX2VuICY9IH5IRkNQQ0lfRklGT0VOX0IxOwoJCQkJY3MtPmh3LmhmY3BjaS5pbnRfbTEgJj0gfihIRkNQQ0lfSU5UU19CMVRSQU5TICsgSEZDUENJX0lOVFNfQjFSRUMpOwoJCQl9CgkJCWJyZWFrOwoJCWNhc2UgKEwxX01PREVfVFJBTlMpOgoJCSAgICAgICAgaGZjcGNpX2NsZWFyX2ZpZm9fcngoY3MsIGZpZm8yKTsKCQkgICAgICAgIGhmY3BjaV9jbGVhcl9maWZvX3R4KGNzLCBmaWZvMik7CgkJCWlmIChiYykgewoJCQkJY3MtPmh3LmhmY3BjaS5zY3RybCB8PSBTQ1RSTF9CMl9FTkE7CgkJCQljcy0+aHcuaGZjcGNpLnNjdHJsX3IgfD0gU0NUUkxfQjJfRU5BOwoJCQl9IGVsc2UgewoJCQkJY3MtPmh3LmhmY3BjaS5zY3RybCB8PSBTQ1RSTF9CMV9FTkE7CgkJCQljcy0+aHcuaGZjcGNpLnNjdHJsX3IgfD0gU0NUUkxfQjFfRU5BOwoJCQl9CgkJCWlmIChmaWZvMikgewoJCQkJY3MtPmh3LmhmY3BjaS5maWZvX2VuIHw9IEhGQ1BDSV9GSUZPRU5fQjI7CgkJCQljcy0+aHcuaGZjcGNpLmludF9tMSB8PSAoSEZDUENJX0lOVFNfQjJUUkFOUyArIEhGQ1BDSV9JTlRTX0IyUkVDKTsKCQkJCWNzLT5ody5oZmNwY2kuY3RtdCB8PSAyOwoJCQkJY3MtPmh3LmhmY3BjaS5jb25uICY9IH4weDE4OwoJCQl9IGVsc2UgewoJCQkJY3MtPmh3LmhmY3BjaS5maWZvX2VuIHw9IEhGQ1BDSV9GSUZPRU5fQjE7CgkJCQljcy0+aHcuaGZjcGNpLmludF9tMSB8PSAoSEZDUENJX0lOVFNfQjFUUkFOUyArIEhGQ1BDSV9JTlRTX0IxUkVDKTsKCQkJCWNzLT5ody5oZmNwY2kuY3RtdCB8PSAxOwoJCQkJY3MtPmh3LmhmY3BjaS5jb25uICY9IH4weDAzOwoJCQl9CgkJCWJyZWFrOwoJCWNhc2UgKEwxX01PREVfSERMQyk6CgkJICAgICAgICBoZmNwY2lfY2xlYXJfZmlmb19yeChjcywgZmlmbzIpOwoJCSAgICAgICAgaGZjcGNpX2NsZWFyX2ZpZm9fdHgoY3MsIGZpZm8yKTsKCQkJaWYgKGJjKSB7CgkJCQljcy0+aHcuaGZjcGNpLnNjdHJsIHw9IFNDVFJMX0IyX0VOQTsKCQkJCWNzLT5ody5oZmNwY2kuc2N0cmxfciB8PSBTQ1RSTF9CMl9FTkE7CgkJCX0gZWxzZSB7CgkJCQljcy0+aHcuaGZjcGNpLnNjdHJsIHw9IFNDVFJMX0IxX0VOQTsKCQkJCWNzLT5ody5oZmNwY2kuc2N0cmxfciB8PSBTQ1RSTF9CMV9FTkE7CgkJCX0KCQkJaWYgKGZpZm8yKSB7CgkJCSAgICAgICAgY3MtPmh3LmhmY3BjaS5sYXN0X2JmaWZvX2NudFsxXSA9IDA7CgkJCQljcy0+aHcuaGZjcGNpLmZpZm9fZW4gfD0gSEZDUENJX0ZJRk9FTl9CMjsKCQkJCWNzLT5ody5oZmNwY2kuaW50X20xIHw9IChIRkNQQ0lfSU5UU19CMlRSQU5TICsgSEZDUENJX0lOVFNfQjJSRUMpOwoJCQkJY3MtPmh3LmhmY3BjaS5jdG10ICY9IH4yOwoJCQkJY3MtPmh3LmhmY3BjaS5jb25uICY9IH4weDE4OwoJCQl9IGVsc2UgewoJCQkgICAgICAgIGNzLT5ody5oZmNwY2kubGFzdF9iZmlmb19jbnRbMF0gPSAwOwoJCQkJY3MtPmh3LmhmY3BjaS5maWZvX2VuIHw9IEhGQ1BDSV9GSUZPRU5fQjE7CgkJCQljcy0+aHcuaGZjcGNpLmludF9tMSB8PSAoSEZDUENJX0lOVFNfQjFUUkFOUyArIEhGQ1BDSV9JTlRTX0IxUkVDKTsKCQkJCWNzLT5ody5oZmNwY2kuY3RtdCAmPSB+MTsKCQkJCWNzLT5ody5oZmNwY2kuY29ubiAmPSB+MHgwMzsKCQkJfQoJCQlicmVhazsKCQljYXNlIChMMV9NT0RFX0VYVFJOKToKCQkJaWYgKGJjKSB7CgkJCQljcy0+aHcuaGZjcGNpLmNvbm4gfD0gMHgxMDsKCQkJCWNzLT5ody5oZmNwY2kuc2N0cmwgfD0gU0NUUkxfQjJfRU5BOwoJCQkJY3MtPmh3LmhmY3BjaS5zY3RybF9yIHw9IFNDVFJMX0IyX0VOQTsKCQkJCWNzLT5ody5oZmNwY2kuZmlmb19lbiAmPSB+SEZDUENJX0ZJRk9FTl9CMjsKCQkJCWNzLT5ody5oZmNwY2kuaW50X20xICY9IH4oSEZDUENJX0lOVFNfQjJUUkFOUyArIEhGQ1BDSV9JTlRTX0IyUkVDKTsKCQkJfSBlbHNlIHsKCQkJCWNzLT5ody5oZmNwY2kuY29ubiB8PSAweDAyOwoJCQkJY3MtPmh3LmhmY3BjaS5zY3RybCB8PSBTQ1RSTF9CMV9FTkE7CgkJCQljcy0+aHcuaGZjcGNpLnNjdHJsX3IgfD0gU0NUUkxfQjFfRU5BOwoJCQkJY3MtPmh3LmhmY3BjaS5maWZvX2VuICY9IH5IRkNQQ0lfRklGT0VOX0IxOwoJCQkJY3MtPmh3LmhmY3BjaS5pbnRfbTEgJj0gfihIRkNQQ0lfSU5UU19CMVRSQU5TICsgSEZDUENJX0lOVFNfQjFSRUMpOwoJCQl9CgkJCWJyZWFrOwoJfQoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfU0NUUkxfRSwgY3MtPmh3LmhmY3BjaS5zY3RybF9lKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0lOVF9NMSwgY3MtPmh3LmhmY3BjaS5pbnRfbTEpOwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfRklGT19FTiwgY3MtPmh3LmhmY3BjaS5maWZvX2VuKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX1NDVFJMLCBjcy0+aHcuaGZjcGNpLnNjdHJsKTsKCVdyaXRlX2hmYyhjcywgSEZDUENJX1NDVFJMX1IsIGNzLT5ody5oZmNwY2kuc2N0cmxfcik7CglXcml0ZV9oZmMoY3MsIEhGQ1BDSV9DVE1ULCBjcy0+aHcuaGZjcGNpLmN0bXQpOwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQ09OTkVDVCwgY3MtPmh3LmhmY3BjaS5jb25uKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogTGF5ZXIyIC0+IExheWVyIDEgVHJhbnNmZXIgKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQKaGZjcGNpX2wybDEoc3RydWN0IFBTdGFjayAqc3QsIGludCBwciwgdm9pZCAqYXJnKQp7CglzdHJ1Y3QgQkNTdGF0ZQkqYmNzID0gc3QtPmwxLmJjczsKCXVfbG9uZwkJZmxhZ3M7CglzdHJ1Y3Qgc2tfYnVmZgkqc2tiID0gYXJnOwoKCXN3aXRjaCAocHIpIHsKCQljYXNlIChQSF9EQVRBIHwgUkVRVUVTVCk6CgkJCXNwaW5fbG9ja19pcnFzYXZlKCZiY3MtPmNzLT5sb2NrLCBmbGFncyk7CgkJCWlmIChiY3MtPnR4X3NrYikgewoJCQkJc2tiX3F1ZXVlX3RhaWwoJmJjcy0+c3F1ZXVlLCBza2IpOwoJCQl9IGVsc2UgewoJCQkJYmNzLT50eF9za2IgPSBza2I7Ci8vCQkJCXRlc3RfYW5kX3NldF9iaXQoQkNfRkxHX0JVU1ksICZiY3MtPkZsYWcpOwogCQkJCWJjcy0+Y3MtPkJDX1NlbmRfRGF0YShiY3MpOwoJCQl9CgkJCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmJjcy0+Y3MtPmxvY2ssIGZsYWdzKTsKCQkJYnJlYWs7CgkJY2FzZSAoUEhfUFVMTCB8IElORElDQVRJT04pOgoJCQlzcGluX2xvY2tfaXJxc2F2ZSgmYmNzLT5jcy0+bG9jaywgZmxhZ3MpOwoJCQlpZiAoYmNzLT50eF9za2IpIHsKCQkJCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmJjcy0+Y3MtPmxvY2ssIGZsYWdzKTsKCQkJCXByaW50ayhLRVJOX1dBUk5JTkcgImhmY19sMmwxOiB0aGlzIHNob3VsZG4ndCBoYXBwZW5cbiIpOwoJCQkJYnJlYWs7CgkJCX0KLy8JCQl0ZXN0X2FuZF9zZXRfYml0KEJDX0ZMR19CVVNZLCAmYmNzLT5GbGFnKTsKCQkJYmNzLT50eF9za2IgPSBza2I7CgkJCWJjcy0+Y3MtPkJDX1NlbmRfRGF0YShiY3MpOwoJCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZiY3MtPmNzLT5sb2NrLCBmbGFncyk7CgkJCWJyZWFrOwoJCWNhc2UgKFBIX1BVTEwgfCBSRVFVRVNUKToKCQkJaWYgKCFiY3MtPnR4X3NrYikgewoJCQkJdGVzdF9hbmRfY2xlYXJfYml0KEZMR19MMV9QVUxMX1JFUSwgJnN0LT5sMS5GbGFncyk7CgkJCQlzdC0+bDEubDFsMihzdCwgUEhfUFVMTCB8IENPTkZJUk0sIE5VTEwpOwoJCQl9IGVsc2UKCQkJCXRlc3RfYW5kX3NldF9iaXQoRkxHX0wxX1BVTExfUkVRLCAmc3QtPmwxLkZsYWdzKTsKCQkJYnJlYWs7CgkJY2FzZSAoUEhfQUNUSVZBVEUgfCBSRVFVRVNUKToKCQkJc3Bpbl9sb2NrX2lycXNhdmUoJmJjcy0+Y3MtPmxvY2ssIGZsYWdzKTsKCQkJdGVzdF9hbmRfc2V0X2JpdChCQ19GTEdfQUNUSVYsICZiY3MtPkZsYWcpOwoJCQltb2RlX2hmY3BjaShiY3MsIHN0LT5sMS5tb2RlLCBzdC0+bDEuYmMpOwoJCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZiY3MtPmNzLT5sb2NrLCBmbGFncyk7CgkJCWwxX21zZ19iKHN0LCBwciwgYXJnKTsKCQkJYnJlYWs7CgkJY2FzZSAoUEhfREVBQ1RJVkFURSB8IFJFUVVFU1QpOgoJCQlsMV9tc2dfYihzdCwgcHIsIGFyZyk7CgkJCWJyZWFrOwoJCWNhc2UgKFBIX0RFQUNUSVZBVEUgfCBDT05GSVJNKToKCQkJc3Bpbl9sb2NrX2lycXNhdmUoJmJjcy0+Y3MtPmxvY2ssIGZsYWdzKTsKCQkJdGVzdF9hbmRfY2xlYXJfYml0KEJDX0ZMR19BQ1RJViwgJmJjcy0+RmxhZyk7CgkJCXRlc3RfYW5kX2NsZWFyX2JpdChCQ19GTEdfQlVTWSwgJmJjcy0+RmxhZyk7CgkJCW1vZGVfaGZjcGNpKGJjcywgMCwgc3QtPmwxLmJjKTsKCQkJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmYmNzLT5jcy0+bG9jaywgZmxhZ3MpOwoJCQlzdC0+bDEubDFsMihzdCwgUEhfREVBQ1RJVkFURSB8IENPTkZJUk0sIE5VTEwpOwoJCQlicmVhazsKCX0KfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogZGVhY3RpdmF0ZSBCLWNoYW5uZWwgYWNjZXNzIGFuZCBxdWV1ZXMgKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIHZvaWQKY2xvc2VfaGZjcGNpKHN0cnVjdCBCQ1N0YXRlICpiY3MpCnsKCW1vZGVfaGZjcGNpKGJjcywgMCwgYmNzLT5jaGFubmVsKTsKCWlmICh0ZXN0X2FuZF9jbGVhcl9iaXQoQkNfRkxHX0lOSVQsICZiY3MtPkZsYWcpKSB7CgkJc2tiX3F1ZXVlX3B1cmdlKCZiY3MtPnJxdWV1ZSk7CgkJc2tiX3F1ZXVlX3B1cmdlKCZiY3MtPnNxdWV1ZSk7CgkJaWYgKGJjcy0+dHhfc2tiKSB7CgkJCWRldl9rZnJlZV9za2JfYW55KGJjcy0+dHhfc2tiKTsKCQkJYmNzLT50eF9za2IgPSBOVUxMOwoJCQl0ZXN0X2FuZF9jbGVhcl9iaXQoQkNfRkxHX0JVU1ksICZiY3MtPkZsYWcpOwoJCX0KCX0KfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qIGluaXQgQi1jaGFubmVsIHF1ZXVlcyBhbmQgY29udHJvbCAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8Kc3RhdGljIGludApvcGVuX2hmY3BjaXN0YXRlKHN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcywgc3RydWN0IEJDU3RhdGUgKmJjcykKewoJaWYgKCF0ZXN0X2FuZF9zZXRfYml0KEJDX0ZMR19JTklULCAmYmNzLT5GbGFnKSkgewoJCXNrYl9xdWV1ZV9oZWFkX2luaXQoJmJjcy0+cnF1ZXVlKTsKCQlza2JfcXVldWVfaGVhZF9pbml0KCZiY3MtPnNxdWV1ZSk7Cgl9CgliY3MtPnR4X3NrYiA9IE5VTEw7Cgl0ZXN0X2FuZF9jbGVhcl9iaXQoQkNfRkxHX0JVU1ksICZiY3MtPkZsYWcpOwoJYmNzLT5ldmVudCA9IDA7CgliY3MtPnR4X2NudCA9IDA7CglyZXR1cm4gKDApOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBpbml0cyB0aGUgc3RhY2sgZm9yIEItY2hhbm5lbCAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgaW50CnNldHN0YWNrXzJiKHN0cnVjdCBQU3RhY2sgKnN0LCBzdHJ1Y3QgQkNTdGF0ZSAqYmNzKQp7CgliY3MtPmNoYW5uZWwgPSBzdC0+bDEuYmM7CglpZiAob3Blbl9oZmNwY2lzdGF0ZShzdC0+bDEuaGFyZHdhcmUsIGJjcykpCgkJcmV0dXJuICgtMSk7CglzdC0+bDEuYmNzID0gYmNzOwoJc3QtPmwyLmwybDEgPSBoZmNwY2lfbDJsMTsKCXNldHN0YWNrX21hbmFnZXIoc3QpOwoJYmNzLT5zdCA9IHN0OwoJc2V0c3RhY2tfbDFfQihzdCk7CglyZXR1cm4gKDApOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBoYW5kbGUgTDEgc3RhdGUgY2hhbmdlcyAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqLwpzdGF0aWMgdm9pZApoZmNwY2lfYmgoc3RydWN0IHdvcmtfc3RydWN0ICp3b3JrKQp7CglzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSAqY3MgPQoJCWNvbnRhaW5lcl9vZih3b3JrLCBzdHJ1Y3QgSXNkbkNhcmRTdGF0ZSwgdHF1ZXVlKTsKCXVfbG9uZwlmbGFnczsKLy8gICAgICBzdHJ1Y3QgUFN0YWNrICpzdHB0cjsKCglpZiAoIWNzKQoJCXJldHVybjsKCWlmICh0ZXN0X2FuZF9jbGVhcl9iaXQoRF9MMVNUQVRFQ0hBTkdFLCAmY3MtPmV2ZW50KSkgewoJCWlmICghY3MtPmh3LmhmY3BjaS5udF9tb2RlKQoJCQlzd2l0Y2ggKGNzLT5kYy5oZmNwY2kucGhfc3RhdGUpIHsKCQkJCWNhc2UgKDApOgoJCQkJCWwxX21zZyhjcywgSFdfUkVTRVQgfCBJTkRJQ0FUSU9OLCBOVUxMKTsKCQkJCQlicmVhazsKCQkJCWNhc2UgKDMpOgoJCQkJCWwxX21zZyhjcywgSFdfREVBQ1RJVkFURSB8IElORElDQVRJT04sIE5VTEwpOwoJCQkJCWJyZWFrOwoJCQkJY2FzZSAoOCk6CgkJCQkJbDFfbXNnKGNzLCBIV19SU1lOQyB8IElORElDQVRJT04sIE5VTEwpOwoJCQkJCWJyZWFrOwoJCQkJY2FzZSAoNik6CgkJCQkJbDFfbXNnKGNzLCBIV19JTkZPMiB8IElORElDQVRJT04sIE5VTEwpOwoJCQkJCWJyZWFrOwoJCQkJY2FzZSAoNyk6CgkJCQkJbDFfbXNnKGNzLCBIV19JTkZPNF9QOCB8IElORElDQVRJT04sIE5VTEwpOwoJCQkJCWJyZWFrOwoJCQkJZGVmYXVsdDoKCQkJCQlicmVhazsKCQl9IGVsc2UgewoJCQlzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJc3dpdGNoIChjcy0+ZGMuaGZjcGNpLnBoX3N0YXRlKSB7CgkJCQljYXNlICgyKToKCQkJCQlpZiAoY3MtPmh3LmhmY3BjaS5udF90aW1lciA8IDApIHsKCQkJCQkJY3MtPmh3LmhmY3BjaS5udF90aW1lciA9IDA7CgkJCQkJCWNzLT5ody5oZmNwY2kuaW50X20xICY9IH5IRkNQQ0lfSU5UU19USU1FUjsKCQkJCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfSU5UX00xLCBjcy0+aHcuaGZjcGNpLmludF9tMSk7CgkJCQkJCS8qIENsZWFyIGFscmVhZHkgcGVuZGluZyBpbnRzICovCgkJCQkJCWlmIChSZWFkX2hmYyhjcywgSEZDUENJX0lOVF9TMSkpOwoJCQkJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9TVEFURVMsIDQgfCBIRkNQQ0lfTE9BRF9TVEFURSk7CgkJCQkJCXVkZWxheSgxMCk7CgkJCQkJCVdyaXRlX2hmYyhjcywgSEZDUENJX1NUQVRFUywgNCk7CgkJCQkJCWNzLT5kYy5oZmNwY2kucGhfc3RhdGUgPSA0OwoJCQkJCX0gZWxzZSB7CgkJCQkJCWNzLT5ody5oZmNwY2kuaW50X20xIHw9IEhGQ1BDSV9JTlRTX1RJTUVSOwoJCQkJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9JTlRfTTEsIGNzLT5ody5oZmNwY2kuaW50X20xKTsKCQkJCQkJY3MtPmh3LmhmY3BjaS5jdG10ICY9IH5IRkNQQ0lfQVVUT19USU1FUjsKCQkJCQkJY3MtPmh3LmhmY3BjaS5jdG10IHw9IEhGQ1BDSV9USU0zXzEyNTsKCQkJCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfQ1RNVCwgY3MtPmh3LmhmY3BjaS5jdG10IHwgSEZDUENJX0NMVElNRVIpOwoJCQkJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9DVE1ULCBjcy0+aHcuaGZjcGNpLmN0bXQgfCBIRkNQQ0lfQ0xUSU1FUik7CgkJCQkJCWNzLT5ody5oZmNwY2kubnRfdGltZXIgPSBOVF9UMV9DT1VOVDsKCQkJCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfU1RBVEVTLCAyIHwgSEZDUENJX05UX0cyX0czKTsJLyogYWxsb3cgRzIgLT4gRzMgdHJhbnNpdGlvbiAqLwoJCQkJCX0KCQkJCQlicmVhazsKCQkJCWNhc2UgKDEpOgoJCQkJY2FzZSAoMyk6CgkJCQljYXNlICg0KToKCQkJCQljcy0+aHcuaGZjcGNpLm50X3RpbWVyID0gMDsKCQkJCQljcy0+aHcuaGZjcGNpLmludF9tMSAmPSB+SEZDUENJX0lOVFNfVElNRVI7CgkJCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfSU5UX00xLCBjcy0+aHcuaGZjcGNpLmludF9tMSk7CgkJCQkJYnJlYWs7CgkJCQlkZWZhdWx0OgoJCQkJCWJyZWFrOwoJCQl9CgkJCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJfQoJfQoJaWYgKHRlc3RfYW5kX2NsZWFyX2JpdChEX1JDVkJVRlJFQURZLCAmY3MtPmV2ZW50KSkKCQlEQ2hhbm5lbF9wcm9jX3Jjdihjcyk7CglpZiAodGVzdF9hbmRfY2xlYXJfYml0KERfWE1UQlVGUkVBRFksICZjcy0+ZXZlbnQpKQoJCURDaGFubmVsX3Byb2NfeG10KGNzKTsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KLyogY2FsbGVkIGZvciBjYXJkIGluaXQgbWVzc2FnZSAqLwovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyB2b2lkCmluaXRoZmNwY2koc3RydWN0IElzZG5DYXJkU3RhdGUgKmNzKQp7Cgljcy0+YmNzWzBdLkJDX1NldFN0YWNrID0gc2V0c3RhY2tfMmI7Cgljcy0+YmNzWzFdLkJDX1NldFN0YWNrID0gc2V0c3RhY2tfMmI7Cgljcy0+YmNzWzBdLkJDX0Nsb3NlID0gY2xvc2VfaGZjcGNpOwoJY3MtPmJjc1sxXS5CQ19DbG9zZSA9IGNsb3NlX2hmY3BjaTsKCWNzLT5kYnVzeXRpbWVyLmZ1bmN0aW9uID0gKHZvaWQgKikgaGZjcGNpX2RidXN5X3RpbWVyOwoJY3MtPmRidXN5dGltZXIuZGF0YSA9IChsb25nKSBjczsKCWluaXRfdGltZXIoJmNzLT5kYnVzeXRpbWVyKTsKCW1vZGVfaGZjcGNpKGNzLT5iY3MsIDAsIDApOwoJbW9kZV9oZmNwY2koY3MtPmJjcyArIDEsIDAsIDEpOwp9CgoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBoYW5kbGUgY2FyZCBtZXNzYWdlcyBmcm9tIGNvbnRyb2wgbGF5ZXIgKi8KLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCnN0YXRpYyBpbnQKaGZjcGNpX2NhcmRfbXNnKHN0cnVjdCBJc2RuQ2FyZFN0YXRlICpjcywgaW50IG10LCB2b2lkICphcmcpCnsKCXVfbG9uZyBmbGFnczsKCglpZiAoY3MtPmRlYnVnICYgTDFfREVCX0lTQUMpCgkJZGVidWdsMShjcywgIkhGQ1BDSTogY2FyZF9tc2cgJXgiLCBtdCk7Cglzd2l0Y2ggKG10KSB7CgkJY2FzZSBDQVJEX1JFU0VUOgoJCQlzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJcmVzZXRfaGZjcGNpKGNzKTsKCQkJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJcmV0dXJuICgwKTsKCQljYXNlIENBUkRfUkVMRUFTRToKCQkJcmVsZWFzZV9pb19oZmNwY2koY3MpOwoJCQlyZXR1cm4gKDApOwoJCWNhc2UgQ0FSRF9JTklUOgoJCQlzcGluX2xvY2tfaXJxc2F2ZSgmY3MtPmxvY2ssIGZsYWdzKTsKCQkJaW5pdGhmY3BjaShjcyk7CgkJCXJlc2V0X2hmY3BjaShjcyk7CgkJCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJCW1zbGVlcCg4MCk7CQkJCS8qIFRpbWVvdXQgODBtcyAqLwoJCQkvKiBub3cgc3dpdGNoIHRpbWVyIGludGVycnVwdCBvZmYgKi8KCQkJc3Bpbl9sb2NrX2lycXNhdmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJCWNzLT5ody5oZmNwY2kuaW50X20xICY9IH5IRkNQQ0lfSU5UU19USU1FUjsKCQkJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfSU5UX00xLCBjcy0+aHcuaGZjcGNpLmludF9tMSk7CgkJCS8qIHJlaW5pdCBtb2RlIHJlZyAqLwoJCQlXcml0ZV9oZmMoY3MsIEhGQ1BDSV9NU1RfTU9ERSwgY3MtPmh3LmhmY3BjaS5tc3RfbSk7CgkJCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmNzLT5sb2NrLCBmbGFncyk7CgkJCXJldHVybiAoMCk7CgkJY2FzZSBDQVJEX1RFU1Q6CgkJCXJldHVybiAoMCk7Cgl9CglyZXR1cm4gKDApOwp9CgoKLyogdGhpcyB2YXJpYWJsZSBpcyB1c2VkIGFzIGNhcmQgaW5kZXggd2hlbiBtb3JlIHRoYW4gb25lIGNhcmRzIGFyZSBwcmVzZW50ICovCnN0YXRpYyBzdHJ1Y3QgcGNpX2RldiAqZGV2X2hmY3BjaSBfX2RldmluaXRkYXRhID0gTlVMTDsKCmludCBfX2RldmluaXQKc2V0dXBfaGZjcGNpKHN0cnVjdCBJc2RuQ2FyZCAqY2FyZCkKewoJdV9sb25nIGZsYWdzOwoJc3RydWN0IElzZG5DYXJkU3RhdGUgKmNzID0gY2FyZC0+Y3M7CgljaGFyIHRtcFs2NF07CglpbnQgaTsKCXN0cnVjdCBwY2lfZGV2ICp0bXBfaGZjcGNpID0gTlVMTDsKCiNpZmRlZiBfX0JJR19FTkRJQU4KI2Vycm9yICJub3QgcnVubmluZyBvbiBiaWcgZW5kaWFuIG1hY2hpbmVzIG5vdyIKI2VuZGlmCgoJc3RyY3B5KHRtcCwgaGZjcGNpX3JldmlzaW9uKTsKCXByaW50ayhLRVJOX0lORk8gIkhpU2F4OiBIRkMtUENJIGRyaXZlciBSZXYuICVzXG4iLCBIaVNheF9nZXRyZXYodG1wKSk7CgoJY3MtPmh3LmhmY3BjaS5pbnRfczEgPSAwOwoJY3MtPmRjLmhmY3BjaS5waF9zdGF0ZSA9IDA7Cgljcy0+aHcuaGZjcGNpLmZpZm8gPSAyNTU7CglpZiAoY3MtPnR5cCAhPSBJU0ROX0NUWVBFX0hGQ19QQ0kpCgkJcmV0dXJuKDApOwoKCWkgPSAwOwoJd2hpbGUgKGlkX2xpc3RbaV0udmVuZG9yX2lkKSB7CgkJdG1wX2hmY3BjaSA9IHBjaV9maW5kX2RldmljZShpZF9saXN0W2ldLnZlbmRvcl9pZCwKCQkJCQkgICAgIGlkX2xpc3RbaV0uZGV2aWNlX2lkLAoJCQkJCSAgICAgZGV2X2hmY3BjaSk7CgkJaSsrOwoJCWlmICh0bXBfaGZjcGNpKSB7CgkJCWlmIChwY2lfZW5hYmxlX2RldmljZSh0bXBfaGZjcGNpKSkKCQkJCWNvbnRpbnVlOwoJCQlwY2lfc2V0X21hc3Rlcih0bXBfaGZjcGNpKTsKCQkJaWYgKChjYXJkLT5wYXJhWzBdKSAmJiAoY2FyZC0+cGFyYVswXSAhPSAodG1wX2hmY3BjaS0+cmVzb3VyY2VbIDBdLnN0YXJ0ICYgUENJX0JBU0VfQUREUkVTU19JT19NQVNLKSkpCgkJCQljb250aW51ZTsKCQkJZWxzZQoJCQkJYnJlYWs7CgkJfQoJfQoKCWlmICghdG1wX2hmY3BjaSkgewoJCXByaW50ayhLRVJOX1dBUk5JTkcgIkhGQy1QQ0k6IE5vIFBDSSBjYXJkIGZvdW5kXG4iKTsKCQlyZXR1cm4gKDApOwoJfQoKCWktLTsKCWRldl9oZmNwY2kgPSB0bXBfaGZjcGNpOwkvKiBvbGQgZGV2aWNlICovCgljcy0+aHcuaGZjcGNpLmRldiA9IGRldl9oZmNwY2k7Cgljcy0+aXJxID0gZGV2X2hmY3BjaS0+aXJxOwoJaWYgKCFjcy0+aXJxKSB7CgkJcHJpbnRrKEtFUk5fV0FSTklORyAiSEZDLVBDSTogTm8gSVJRIGZvciBQQ0kgY2FyZCBmb3VuZFxuIik7CgkJcmV0dXJuICgwKTsKCX0KCWNzLT5ody5oZmNwY2kucGNpX2lvID0gKGNoYXIgKikodW5zaWduZWQgbG9uZylkZXZfaGZjcGNpLT5yZXNvdXJjZVsxXS5zdGFydDsKCXByaW50ayhLRVJOX0lORk8gIkhpU2F4OiBIRkMtUENJIGNhcmQgbWFudWZhY3R1cmVyOiAlcyBjYXJkIG5hbWU6ICVzXG4iLCBpZF9saXN0W2ldLnZlbmRvcl9uYW1lLCBpZF9saXN0W2ldLmNhcmRfbmFtZSk7CgoJaWYgKCFjcy0+aHcuaGZjcGNpLnBjaV9pbykgewoJCXByaW50ayhLRVJOX1dBUk5JTkcgIkhGQy1QQ0k6IE5vIElPLU1lbSBmb3IgUENJIGNhcmQgZm91bmRcbiIpOwoJCXJldHVybiAoMCk7Cgl9CgkvKiBBbGxvY2F0ZSBtZW1vcnkgZm9yIEZJRk9TICovCgkvKiBCZWNhdXNlIHRoZSBIRkMtUENJIG5lZWRzIGEgMzJLIHBoeXNpY2FsIGFsaWdubWVudCwgd2UgKi8KCS8qIG5lZWQgdG8gYWxsb2NhdGUgdGhlIGRvdWJsZSBtZW0gYW5kIGFsaWduIHRoZSBhZGRyZXNzICovCglpZiAoIShjcy0+aHcuaGZjcGNpLnNoYXJlX3N0YXJ0ID0ga21hbGxvYyg2NTUzNiwgR0ZQX0tFUk5FTCkpKSB7CgkJcHJpbnRrKEtFUk5fV0FSTklORyAiSEZDLVBDSTogRXJyb3IgYWxsb2NhdGluZyBtZW1vcnkgZm9yIEZJRk8hXG4iKTsKCQlyZXR1cm4gMDsKCX0KCWNzLT5ody5oZmNwY2kuZmlmb3MgPSAodm9pZCAqKQoJICAgICgoKHVsb25nKSBjcy0+aHcuaGZjcGNpLnNoYXJlX3N0YXJ0KSAmIH4weDdGRkYpICsgMHg4MDAwOwoJcGNpX3dyaXRlX2NvbmZpZ19kd29yZChjcy0+aHcuaGZjcGNpLmRldiwgMHg4MCwgKHVfaW50KSB2aXJ0X3RvX2J1cyhjcy0+aHcuaGZjcGNpLmZpZm9zKSk7Cgljcy0+aHcuaGZjcGNpLnBjaV9pbyA9IGlvcmVtYXAoKHVsb25nKSBjcy0+aHcuaGZjcGNpLnBjaV9pbywgMjU2KTsKCXByaW50ayhLRVJOX0lORk8KCSAgICAgICAiSEZDLVBDSTogZGVmaW5lZCBhdCBtZW0gJXAgZmlmbyAlcCglI3gpIElSUSAlZCBIWiAlZFxuIiwKCSAgICAgICBjcy0+aHcuaGZjcGNpLnBjaV9pbywKCSAgICAgICBjcy0+aHcuaGZjcGNpLmZpZm9zLAoJICAgICAgICh1X2ludCkgdmlydF90b19idXMoY3MtPmh3LmhmY3BjaS5maWZvcyksCgkgICAgICAgY3MtPmlycSwgSFopOwoKCXNwaW5fbG9ja19pcnFzYXZlKCZjcy0+bG9jaywgZmxhZ3MpOwoKCXBjaV93cml0ZV9jb25maWdfd29yZChjcy0+aHcuaGZjcGNpLmRldiwgUENJX0NPTU1BTkQsIFBDSV9FTkFfTUVNSU8pOwkvKiBlbmFibGUgbWVtb3J5IG1hcHBlZCBwb3J0cywgZGlzYWJsZSBidXNtYXN0ZXIgKi8KCWNzLT5ody5oZmNwY2kuaW50X20yID0gMDsJLyogZGlzYWJsZSBhbGxlIGludGVycnVwdHMgKi8KCWNzLT5ody5oZmNwY2kuaW50X20xID0gMDsKCVdyaXRlX2hmYyhjcywgSEZDUENJX0lOVF9NMSwgY3MtPmh3LmhmY3BjaS5pbnRfbTEpOwoJV3JpdGVfaGZjKGNzLCBIRkNQQ0lfSU5UX00yLCBjcy0+aHcuaGZjcGNpLmludF9tMik7CgkvKiBBdCB0aGlzIHBvaW50IHRoZSBuZWVkZWQgUENJIGNvbmZpZyBpcyBkb25lICovCgkvKiBmaWZvcyBhcmUgc3RpbGwgbm90IGVuYWJsZWQgKi8KCglJTklUX1dPUksoJmNzLT50cXVldWUsICBoZmNwY2lfYmgpOwoJY3MtPnNldHN0YWNrX2QgPSBzZXRzdGFja19oZmNwY2k7Cgljcy0+QkNfU2VuZF9EYXRhID0gJmhmY3BjaV9zZW5kX2RhdGE7Cgljcy0+cmVhZGlzYWMgPSBOVUxMOwoJY3MtPndyaXRlaXNhYyA9IE5VTEw7Cgljcy0+cmVhZGlzYWNmaWZvID0gTlVMTDsKCWNzLT53cml0ZWlzYWNmaWZvID0gTlVMTDsKCWNzLT5CQ19SZWFkX1JlZyA9IE5VTEw7Cgljcy0+QkNfV3JpdGVfUmVnID0gTlVMTDsKCWNzLT5pcnFfZnVuYyA9ICZoZmNwY2lfaW50ZXJydXB0OwoJY3MtPmlycV9mbGFncyB8PSBJUlFGX1NIQVJFRDsKCWNzLT5ody5oZmNwY2kudGltZXIuZnVuY3Rpb24gPSAodm9pZCAqKSBoZmNwY2lfVGltZXI7Cgljcy0+aHcuaGZjcGNpLnRpbWVyLmRhdGEgPSAobG9uZykgY3M7Cglpbml0X3RpbWVyKCZjcy0+aHcuaGZjcGNpLnRpbWVyKTsKCWNzLT5jYXJkbXNnID0gJmhmY3BjaV9jYXJkX21zZzsKCWNzLT5hdXhjbWQgPSAmaGZjcGNpX2F1eGNtZDsKCglzcGluX3VubG9ja19pcnFyZXN0b3JlKCZjcy0+bG9jaywgZmxhZ3MpOwoKCXJldHVybiAoMSk7Cn0K