LyogR2VtVGVrIHJhZGlvIGNhcmQgZHJpdmVyIGZvciBMaW51eCAoQykgMTk5OCBKb25hcyBNdW5zaW4gPGptdW5zaW5AaWtpLmZpPgogKgogKiBHZW1UZWsgaGFzbid0IHJlbGVhc2VkIGFueSBzcGVjcyBvbiB0aGUgY2FyZCwgc28gdGhlIHByb3RvY29sIGhhZCB0bwogKiBiZSByZXZlcnNlIGVuZ2luZWVyZWQgd2l0aCBkb3NlbXUuCiAqCiAqIEJlc2lkZXMgdGhlIHByb3RvY29sIGNoYW5nZXMsIHRoaXMgaXMgbW9zdGx5IGEgY29weSBvZjoKICoKICogICAgUmFkaW9UcmFjayBJSSBkcml2ZXIgZm9yIExpbnV4IHJhZGlvIHN1cHBvcnQgKEMpIDE5OTggQmVuIFBmYWZmCiAqCiAqICAgIEJhc2VkIG9uIFJhZGlvVHJhY2sgSS9SYWRpb1JldmVhbCAoQykgMTk5NyBNLiBLaXJrd29vZAogKiAgICBDb252ZXJ0ZWQgdG8gbmV3IEFQSSBieSBBbGFuIENveCA8YWxhbkBseG9yZ3VrLnVrdXUub3JnLnVrPgogKiAgICBWYXJpb3VzIGJ1Z2ZpeGVzIGFuZCBlbmhhbmNlbWVudHMgYnkgUnVzc2VsbCBLcm9sbCA8cmtyb2xsQGV4cGxvaXRzLm9yZz4KICoKICogVE9ETzogQWxsb3cgZm9yIG1vcmUgdGhhbiBvbmUgb2YgdGhlc2UgZm9vbGlzaCBlbnRpdGllcyA6LSkKICoKICogQ29udmVydGVkIHRvIFY0TDIgQVBJIGJ5IE1hdXJvIENhcnZhbGhvIENoZWhhYiA8bWNoZWhhYkBpbmZyYWRlYWQub3JnPgogKi8KCiNpbmNsdWRlIDxsaW51eC9tb2R1bGUuaD4JLyogTW9kdWxlcyAJCQkqLwojaW5jbHVkZSA8bGludXgvaW5pdC5oPgkJLyogSW5pdGRhdGEJCQkqLwojaW5jbHVkZSA8bGludXgvaW9wb3J0Lmg+CS8qIHJlcXVlc3RfcmVnaW9uCQkqLwojaW5jbHVkZSA8bGludXgvZGVsYXkuaD4JLyogdWRlbGF5CQkJKi8KI2luY2x1ZGUgPGxpbnV4L3ZpZGVvZGV2Mi5oPgkvKiBrZXJuZWwgcmFkaW8gc3RydWN0cwkJKi8KI2luY2x1ZGUgPGxpbnV4L3ZlcnNpb24uaD4JLyogZm9yIEtFUk5FTF9WRVJTSU9OIE1BQ1JPCSovCiNpbmNsdWRlIDxsaW51eC9tdXRleC5oPgojaW5jbHVkZSA8bGludXgvaW8uaD4JCS8qIG91dGIsIG91dGJfcAkJCSovCiNpbmNsdWRlIDxtZWRpYS92NGwyLWlvY3RsLmg+CiNpbmNsdWRlIDxtZWRpYS92NGwyLWRldmljZS5oPgoKI2RlZmluZSBSQURJT19WRVJTSU9OIEtFUk5FTF9WRVJTSU9OKDAsIDAsIDMpCgovKgogKiBNb2R1bGUgaW5mby4KICovCgpNT0RVTEVfQVVUSE9SKCJKb25hcyBNdW5zaW4sIFBla2thIFNlcHDkbmVuIDxwZXh1QGthcHNpLmZpPiIpOwpNT0RVTEVfREVTQ1JJUFRJT04oIkEgZHJpdmVyIGZvciB0aGUgR2VtVGVrIFJhZGlvIGNhcmQuIik7Ck1PRFVMRV9MSUNFTlNFKCJHUEwiKTsKCi8qCiAqIE1vZHVsZSBwYXJhbXMuCiAqLwoKI2lmbmRlZiBDT05GSUdfUkFESU9fR0VNVEVLX1BPUlQKI2RlZmluZSBDT05GSUdfUkFESU9fR0VNVEVLX1BPUlQgLTEKI2VuZGlmCiNpZm5kZWYgQ09ORklHX1JBRElPX0dFTVRFS19QUk9CRQojZGVmaW5lIENPTkZJR19SQURJT19HRU1URUtfUFJPQkUgMQojZW5kaWYKCnN0YXRpYyBpbnQgaW8JCT0gQ09ORklHX1JBRElPX0dFTVRFS19QT1JUOwpzdGF0aWMgaW50IHByb2JlCT0gQ09ORklHX1JBRElPX0dFTVRFS19QUk9CRTsKc3RhdGljIGludCBoYXJkbXV0ZTsKc3RhdGljIGludCBzaHV0ZG93bgk9IDE7CnN0YXRpYyBpbnQga2VlcG11dGVkCT0gMTsKc3RhdGljIGludCBpbml0bXV0ZQk9IDE7CnN0YXRpYyBpbnQgcmFkaW9fbnIJPSAtMTsKCm1vZHVsZV9wYXJhbShpbywgaW50LCAwNDQ0KTsKTU9EVUxFX1BBUk1fREVTQyhpbywgIkZvcmNlIEkvTyBwb3J0IGZvciB0aGUgR2VtVGVrIFJhZGlvIGNhcmQgaWYgYXV0b21hdGljICIKCSAicHJvYmluZyBpcyBkaXNhYmxlZCBvciBmYWlscy4gVGhlIG1vc3QgY29tbW9uIEkvTyBwb3J0cyBhcmU6IDB4MjBjICIKCSAiMHgzMGMsIDB4MjRjIG9yIDB4MzRjICgweDIwYywgMHgyNDggYW5kIDB4MjhjIGhhdmUgYmVlbiByZXBvcnRlZCB0byAiCgkgIndvcmsgZm9yIHRoZSBjb21iaW5lZCBzb3VuZC9yYWRpb2NhcmQpLiIpOwoKbW9kdWxlX3BhcmFtKHByb2JlLCBib29sLCAwNDQ0KTsKTU9EVUxFX1BBUk1fREVTQyhwcm9iZSwgIkVuYWJsZSBhdXRvbWF0aWMgZGV2aWNlIHByb2JpbmcuIE5vdGU6IG9ubHkgdGhlIG1vc3QgIgoJImNvbW1vbiBJL08gcG9ydHMgdXNlZCBieSB0aGUgY2FyZCBhcmUgcHJvYmVkLiIpOwoKbW9kdWxlX3BhcmFtKGhhcmRtdXRlLCBib29sLCAwNjQ0KTsKTU9EVUxFX1BBUk1fREVTQyhoYXJkbXV0ZSwgIkVuYWJsZSBgaGFyZCBtdXRpbmcnIGJ5IHNodXR0aW5nIGRvd24gUExMLCBtYXkgIgoJICJyZWR1Y2Ugc3RhdGljIG5vaXNlLiIpOwoKbW9kdWxlX3BhcmFtKHNodXRkb3duLCBib29sLCAwNjQ0KTsKTU9EVUxFX1BBUk1fREVTQyhzaHV0ZG93biwgIkVuYWJsZSBzaHV0dGluZyBkb3duIFBMTCBhbmQgbXV0aW5nIGxpbmUgd2hlbiAiCgkgIm1vZHVsZSBpcyB1bmxvYWRlZC4iKTsKCm1vZHVsZV9wYXJhbShrZWVwbXV0ZWQsIGJvb2wsIDA2NDQpOwpNT0RVTEVfUEFSTV9ERVNDKGtlZXBtdXRlZCwgIktlZXAgY2FyZCBtdXRlZCBldmVuIHdoZW4gZnJlcXVlbmN5IGlzIGNoYW5nZWQuIik7Cgptb2R1bGVfcGFyYW0oaW5pdG11dGUsIGJvb2wsIDA0NDQpOwpNT0RVTEVfUEFSTV9ERVNDKGluaXRtdXRlLCAiTXV0ZSBjYXJkIHdoZW4gbW9kdWxlIGlzIGxvYWRlZC4iKTsKCm1vZHVsZV9wYXJhbShyYWRpb19uciwgaW50LCAwNDQ0KTsKCi8qCiAqIEZ1bmN0aW9ucyBmb3IgY29udHJvbGxpbmcgdGhlIGNhcmQuCiAqLwojZGVmaW5lIEdFTVRFS19MT1dGUkVRCSg4NyoxNjAwMCkKI2RlZmluZSBHRU1URUtfSElHSEZSRVEJKDEwOCoxNjAwMCkKCi8qCiAqIEZyZXF1ZW5jeSBjYWxjdWxhdGlvbiBjb25zdGFudHMuICBJbnRlcm1lZGlhdGUgZnJlcXVlbmN5IDEwLjUyIE1IeiAobm9taW5hbAogKiB2YWx1ZSAxMC43IE1IeiksIHJlZmVyZW5jZSBkaXZpc29yIDYuMzkga0h6IChub21pbmFsIDYuMjUga0h6KS4KICovCiNkZWZpbmUgRlNDQUxFCQk4CiNkZWZpbmUgSUZfT0ZGU0VUCSgodW5zaWduZWQgaW50KSgxMC41MiAqIDE2MDAwICogKDE8PEZTQ0FMRSkpKQojZGVmaW5lIFJFRl9GUkVRCSgodW5zaWduZWQgaW50KSg2LjM5ICogMTYgKiAoMTw8RlNDQUxFKSkpCgojZGVmaW5lIEdFTVRFS19DSwkJMHgwMQkvKiBDbG9jayBzaWduYWwJCQkqLwojZGVmaW5lIEdFTVRFS19EQQkJMHgwMgkvKiBTZXJpYWwgZGF0YQkJCSovCiNkZWZpbmUgR0VNVEVLX0NFCQkweDA0CS8qIENoaXAgZW5hYmxlCQkJKi8KI2RlZmluZSBHRU1URUtfTlMJCTB4MDgJLyogTm8gc2lnbmFsCQkJKi8KI2RlZmluZSBHRU1URUtfTVQJCTB4MTAJLyogTGluZSBtdXRlCQkJKi8KI2RlZmluZSBHRU1URUtfU1RERl8zXzEyNV9LSFoJMHgwMQkvKiBTdGFuZGFyZCBmcmVxdWVuY3kgMy4xMjUga0h6CSovCiNkZWZpbmUgR0VNVEVLX1BMTF9PRkYJCTB4MDcJLyogUExMIG9mZgkJCSovCgojZGVmaW5lIEJVMjYxNF9CVVNfU0laRQkzMgkvKiBCVTI2MTQgLyBCVTI2MTRGUyBidXMgc2l6ZQkJKi8KCiNkZWZpbmUgU0hPUlRfREVMQVkgNQkJLyogdXNlYyAqLwojZGVmaW5lIExPTkdfREVMQVkgNzUJCS8qIHVzZWMgKi8KCnN0cnVjdCBnZW10ZWsgewoJc3RydWN0IHY0bDJfZGV2aWNlIHY0bDJfZGV2OwoJc3RydWN0IHZpZGVvX2RldmljZSB2ZGV2OwoJc3RydWN0IG11dGV4IGxvY2s7Cgl1bnNpZ25lZCBsb25nIGxhc3RmcmVxOwoJaW50IG11dGVkOwoJaW50IHZlcmlmaWVkOwoJaW50IGlvOwoJdTMyIGJ1MjYxNGRhdGE7Cn07CgpzdGF0aWMgc3RydWN0IGdlbXRlayBnZW10ZWtfY2FyZDsKCiNkZWZpbmUgQlUyNjE0X0ZSRVFfQklUUyAJMTYgLyogRDAuLkQxNSwgRnJlcXVlbmN5IGRhdGEJCSovCiNkZWZpbmUgQlUyNjE0X1BPUlRfQklUUwkzIC8qIFAwLi5QMiwgT3V0cHV0IHBvcnQgY29udHJvbCBkYXRhCSovCiNkZWZpbmUgQlUyNjE0X1ZPSURfQklUUwk0IC8qIHVudXNlZCAJCQkJKi8KI2RlZmluZSBCVTI2MTRfRk1FU19CSVRTCTEgLyogQ1QsIEZyZXF1ZW5jeSBtZWFzdXJlbWVudCBiZWdpbm5pbmcgZGF0YSAqLwojZGVmaW5lIEJVMjYxNF9TVERGX0JJVFMJMyAvKiBSMC4uUjIsIFN0YW5kYXJkIGZyZXF1ZW5jeSBkYXRhCSovCiNkZWZpbmUgQlUyNjE0X1NXSU5fQklUUwkxIC8qIFMsIFN3aXRjaCBiZXR3ZWVuIEZNSU4gLyBBTUlOCSovCiNkZWZpbmUgQlUyNjE0X1NXQUxfQklUUyAgICAgICAgMSAvKiBQUywgU3dhbGxvdyBjb3VudGVyIGRpdmlzaW9uIChBTUlOIG9ubHkpKi8KI2RlZmluZSBCVTI2MTRfVk9JRDJfQklUUwkxIC8qIHVudXNlZAkJCQkqLwojZGVmaW5lIEJVMjYxNF9GTVVOX0JJVFMJMSAvKiBHVCwgRnJlcXVlbmN5IG1lYXN1cmVtZW50IHRpbWUgJiB1bmxvY2sgKi8KI2RlZmluZSBCVTI2MTRfVEVTVF9CSVRTCTEgLyogVFMsIFRlc3QgZGF0YSBpcyBpbnB1dAkJKi8KCiNkZWZpbmUgQlUyNjE0X0ZSRVFfU0hJRlQgCTAKI2RlZmluZSBCVTI2MTRfUE9SVF9TSElGVAkoQlUyNjE0X0ZSRVFfQklUUyArIEJVMjYxNF9GUkVRX1NISUZUKQojZGVmaW5lIEJVMjYxNF9WT0lEX1NISUZUCShCVTI2MTRfUE9SVF9CSVRTICsgQlUyNjE0X1BPUlRfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X0ZNRVNfU0hJRlQJKEJVMjYxNF9WT0lEX0JJVFMgKyBCVTI2MTRfVk9JRF9TSElGVCkKI2RlZmluZSBCVTI2MTRfU1RERl9TSElGVAkoQlUyNjE0X0ZNRVNfQklUUyArIEJVMjYxNF9GTUVTX1NISUZUKQojZGVmaW5lIEJVMjYxNF9TV0lOX1NISUZUCShCVTI2MTRfU1RERl9CSVRTICsgQlUyNjE0X1NUREZfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X1NXQUxfU0hJRlQJKEJVMjYxNF9TV0lOX0JJVFMgKyBCVTI2MTRfU1dJTl9TSElGVCkKI2RlZmluZSBCVTI2MTRfVk9JRDJfU0hJRlQJKEJVMjYxNF9TV0FMX0JJVFMgKyBCVTI2MTRfU1dBTF9TSElGVCkKI2RlZmluZSBCVTI2MTRfRk1VTl9TSElGVAkoQlUyNjE0X1ZPSUQyX0JJVFMgKyBCVTI2MTRfVk9JRDJfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X1RFU1RfU0hJRlQJKEJVMjYxNF9GTVVOX0JJVFMgKyBCVTI2MTRfRk1VTl9TSElGVCkKCiNkZWZpbmUgTUtNQVNLKGZpZWxkKQkoKCgxPDxCVTI2MTRfIyNmaWVsZCMjX0JJVFMpIC0gMSkgPDwgXAoJCQlCVTI2MTRfIyNmaWVsZCMjX1NISUZUKQojZGVmaW5lIEJVMjYxNF9QT1JUX01BU0sJTUtNQVNLKFBPUlQpCiNkZWZpbmUgQlUyNjE0X0ZSRVFfTUFTSwlNS01BU0soRlJFUSkKI2RlZmluZSBCVTI2MTRfVk9JRF9NQVNLCU1LTUFTSyhWT0lEKQojZGVmaW5lIEJVMjYxNF9GTUVTX01BU0sJTUtNQVNLKEZNRVMpCiNkZWZpbmUgQlUyNjE0X1NUREZfTUFTSwlNS01BU0soU1RERikKI2RlZmluZSBCVTI2MTRfU1dJTl9NQVNLCU1LTUFTSyhTV0lOKQojZGVmaW5lIEJVMjYxNF9TV0FMX01BU0sJTUtNQVNLKFNXQUwpCiNkZWZpbmUgQlUyNjE0X1ZPSUQyX01BU0sJTUtNQVNLKFZPSUQyKQojZGVmaW5lIEJVMjYxNF9GTVVOX01BU0sJTUtNQVNLKEZNVU4pCiNkZWZpbmUgQlUyNjE0X1RFU1RfTUFTSwlNS01BU0soVEVTVCkKCi8qCiAqIFNldCBkYXRhIHdoaWNoIHdpbGwgYmUgc2VudCB0byBCVTI2MTRGUy4KICovCiNkZWZpbmUgZ2VtdGVrX2J1MjYxNF9zZXQoZGV2LCBmaWVsZCwgZGF0YSkgKChkZXYpLT5idTI2MTRkYXRhID0gXAoJKChkZXYpLT5idTI2MTRkYXRhICYgfmZpZWxkIyNfTUFTSykgfCAoKGRhdGEpIDw8IGZpZWxkIyNfU0hJRlQpKQoKLyoKICogVHJhbnNtaXQgc2V0dGluZ3MgdG8gQlUyNjE0RlMgb3ZlciBHZW1UZWsgSUMuCiAqLwpzdGF0aWMgdm9pZCBnZW10ZWtfYnUyNjE0X3RyYW5zbWl0KHN0cnVjdCBnZW10ZWsgKmd0KQp7CglpbnQgaSwgYml0LCBxLCBtdXRlOwoKCW11dGV4X2xvY2soJmd0LT5sb2NrKTsKCgltdXRlID0gZ3QtPm11dGVkID8gR0VNVEVLX01UIDogMHgwMDsKCglvdXRiX3AobXV0ZSB8IEdFTVRFS19EQSB8IEdFTVRFS19DSywgZ3QtPmlvKTsKCXVkZWxheShTSE9SVF9ERUxBWSk7CglvdXRiX3AobXV0ZSB8IEdFTVRFS19DRSB8IEdFTVRFS19EQSB8IEdFTVRFS19DSywgZ3QtPmlvKTsKCXVkZWxheShMT05HX0RFTEFZKTsKCglmb3IgKGkgPSAwLCBxID0gZ3QtPmJ1MjYxNGRhdGE7IGkgPCAzMjsgaSsrLCBxID4+PSAxKSB7CgkJYml0ID0gKHEgJiAxKSA/IEdFTVRFS19EQSA6IDA7CgkJb3V0Yl9wKG11dGUgfCBHRU1URUtfQ0UgfCBiaXQsIGd0LT5pbyk7CgkJdWRlbGF5KFNIT1JUX0RFTEFZKTsKCQlvdXRiX3AobXV0ZSB8IEdFTVRFS19DRSB8IGJpdCB8IEdFTVRFS19DSywgZ3QtPmlvKTsKCQl1ZGVsYXkoU0hPUlRfREVMQVkpOwoJfQoKCW91dGJfcChtdXRlIHwgR0VNVEVLX0RBIHwgR0VNVEVLX0NLLCBndC0+aW8pOwoJdWRlbGF5KFNIT1JUX0RFTEFZKTsKCW91dGJfcChtdXRlIHwgR0VNVEVLX0NFIHwgR0VNVEVLX0RBIHwgR0VNVEVLX0NLLCBndC0+aW8pOwoJdWRlbGF5KExPTkdfREVMQVkpOwoKCW11dGV4X3VubG9jaygmZ3QtPmxvY2spOwp9CgovKgogKiBDYWxjdWxhdGUgZGl2aXNvciBmcm9tIEZNLWZyZXF1ZW5jeSBmb3IgQlUyNjE0RlMgKDMuMTI1IEtIeiBTVERGIGV4cGVjdGVkKS4KICovCnN0YXRpYyB1bnNpZ25lZCBsb25nIGdlbXRla19jb252ZnJlcSh1bnNpZ25lZCBsb25nIGZyZXEpCnsKCXJldHVybiAoKGZyZXE8PEZTQ0FMRSkgKyBJRl9PRkZTRVQgKyBSRUZfRlJFUS8yKSAvIFJFRl9GUkVROwp9CgovKgogKiBTZXQgRk0tZnJlcXVlbmN5LgogKi8Kc3RhdGljIHZvaWQgZ2VtdGVrX3NldGZyZXEoc3RydWN0IGdlbXRlayAqZ3QsIHVuc2lnbmVkIGxvbmcgZnJlcSkKewoJaWYgKGtlZXBtdXRlZCAmJiBoYXJkbXV0ZSAmJiBndC0+bXV0ZWQpCgkJcmV0dXJuOwoKCWZyZXEgPSBjbGFtcF92YWwoZnJlcSwgR0VNVEVLX0xPV0ZSRVEsIEdFTVRFS19ISUdIRlJFUSk7CgoJZ3QtPmxhc3RmcmVxID0gZnJlcTsKCWd0LT5tdXRlZCA9IDA7CgoJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9QT1JULCAwKTsKCWdlbXRla19idTI2MTRfc2V0KGd0LCBCVTI2MTRfRk1FUywgMCk7CglnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NXSU4sIDApOwkvKiBGTS1tb2RlCSovCglnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NXQUwsIDApOwoJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9GTVVOLCAxKTsJLyogR1QgYml0IHNldAkqLwoJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9URVNULCAwKTsKCglnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NUREYsIEdFTVRFS19TVERGXzNfMTI1X0tIWik7CglnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X0ZSRVEsIGdlbXRla19jb252ZnJlcShmcmVxKSk7CgoJZ2VtdGVrX2J1MjYxNF90cmFuc21pdChndCk7Cn0KCi8qCiAqIFNldCBtdXRlIGZsYWcuCiAqLwpzdGF0aWMgdm9pZCBnZW10ZWtfbXV0ZShzdHJ1Y3QgZ2VtdGVrICpndCkKewoJaW50IGk7CgoJZ3QtPm11dGVkID0gMTsKCglpZiAoaGFyZG11dGUpIHsKCQkvKiBUdXJuIG9mZiBQTEwsIGRpc2FibGUgZGF0YSBvdXRwdXQgKi8KCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1BPUlQsIDApOwoJCWdlbXRla19idTI2MTRfc2V0KGd0LCBCVTI2MTRfRk1FUywgMCk7CS8qIENUIGJpdCBvZmYJKi8KCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NXSU4sIDApOwkvKiBGTS1tb2RlCSovCgkJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9TV0FMLCAwKTsKCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X0ZNVU4sIDApOwkvKiBHVCBiaXQgb2ZmCSovCgkJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9URVNULCAwKTsKCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NUREYsIEdFTVRFS19QTExfT0ZGKTsKCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X0ZSRVEsIDApOwoJCWdlbXRla19idTI2MTRfdHJhbnNtaXQoZ3QpOwoJCXJldHVybjsKCX0KCgltdXRleF9sb2NrKCZndC0+bG9jayk7CgoJLyogUmVhZCBidXMgY29udGVudHMgKENFLCBDSyBhbmQgREEpLiAqLwoJaSA9IGluYl9wKGd0LT5pbyk7CgkvKiBXcml0ZSBpdCBiYWNrIHdpdGggbXV0ZSBmbGFnIHNldC4gKi8KCW91dGJfcCgoaSA+PiA1KSB8IEdFTVRFS19NVCwgZ3QtPmlvKTsKCXVkZWxheShTSE9SVF9ERUxBWSk7CgoJbXV0ZXhfdW5sb2NrKCZndC0+bG9jayk7Cn0KCi8qCiAqIFVuc2V0IG11dGUgZmxhZy4KICovCnN0YXRpYyB2b2lkIGdlbXRla191bm11dGUoc3RydWN0IGdlbXRlayAqZ3QpCnsKCWludCBpOwoKCWd0LT5tdXRlZCA9IDA7CglpZiAoaGFyZG11dGUpIHsKCQkvKiBUdXJuIFBMTCBiYWNrIG9uLiAqLwoJCWdlbXRla19zZXRmcmVxKGd0LCBndC0+bGFzdGZyZXEpOwoJCXJldHVybjsKCX0KCW11dGV4X2xvY2soJmd0LT5sb2NrKTsKCglpID0gaW5iX3AoZ3QtPmlvKTsKCW91dGJfcChpID4+IDUsIGd0LT5pbyk7Cgl1ZGVsYXkoU0hPUlRfREVMQVkpOwoKCW11dGV4X3VubG9jaygmZ3QtPmxvY2spOwp9CgovKgogKiBHZXQgc2lnbmFsIHN0cmVuZ3RoICg9IHN0ZXJlbyBzdGF0dXMpLgogKi8Kc3RhdGljIGlubGluZSBpbnQgZ2VtdGVrX2dldHNpZ3N0cihzdHJ1Y3QgZ2VtdGVrICpndCkKewoJaW50IHNpZzsKCgltdXRleF9sb2NrKCZndC0+bG9jayk7CglzaWcgPSBpbmJfcChndC0+aW8pICYgR0VNVEVLX05TID8gMCA6IDE7CgltdXRleF91bmxvY2soJmd0LT5sb2NrKTsKCXJldHVybiBzaWc7Cn0KCi8qCiAqIENoZWNrIGlmIHJlcXVlc3RlZCBjYXJkIGFjdHMgbGlrZSBHZW1UZWsgUmFkaW8gY2FyZC4KICovCnN0YXRpYyBpbnQgZ2VtdGVrX3ZlcmlmeShzdHJ1Y3QgZ2VtdGVrICpndCwgaW50IHBvcnQpCnsKCWludCBpLCBxOwoKCWlmIChndC0+dmVyaWZpZWQgPT0gcG9ydCkKCQlyZXR1cm4gMTsKCgltdXRleF9sb2NrKCZndC0+bG9jayk7CgoJcSA9IGluYl9wKHBvcnQpOwkvKiBSZWFkIGJ1cyBjb250ZW50cyBiZWZvcmUgcHJvYmluZy4gKi8KCS8qIFRyeSB0byB0dXJuIG9uIENFLCBDSyBhbmQgREEgcmVzcGVjdGl2ZWx5IGFuZCBjaGVjayBpZiBjYXJkIHJlc3BvbmRzCgkgICBwcm9wZXJseS4gKi8KCWZvciAoaSA9IDA7IGkgPCAzOyArK2kpIHsKCQlvdXRiX3AoMSA8PCBpLCBwb3J0KTsKCQl1ZGVsYXkoU0hPUlRfREVMQVkpOwoKCQlpZiAoKGluYl9wKHBvcnQpICYgKH5HRU1URUtfTlMpKSAhPSAoMHgxNyB8ICgxIDw8IChpICsgNSkpKSkgewoJCQltdXRleF91bmxvY2soJmd0LT5sb2NrKTsKCQkJcmV0dXJuIDA7CgkJfQoJfQoJb3V0Yl9wKHEgPj4gNSwgcG9ydCk7CS8qIFdyaXRlIGJ1cyBjb250ZW50cyBiYWNrLiAqLwoJdWRlbGF5KFNIT1JUX0RFTEFZKTsKCgltdXRleF91bmxvY2soJmd0LT5sb2NrKTsKCWd0LT52ZXJpZmllZCA9IHBvcnQ7CgoJcmV0dXJuIDE7Cn0KCi8qCiAqIEF1dG9tYXRpYyBwcm9iaW5nIGZvciBjYXJkLgogKi8Kc3RhdGljIGludCBnZW10ZWtfcHJvYmUoc3RydWN0IGdlbXRlayAqZ3QpCnsKCXN0cnVjdCB2NGwyX2RldmljZSAqdjRsMl9kZXYgPSAmZ3QtPnY0bDJfZGV2OwoJaW50IGlvcG9ydHNbXSA9IHsgMHgyMGMsIDB4MzBjLCAweDI0YywgMHgzNGMsIDB4MjQ4LCAweDI4YyB9OwoJaW50IGk7CgoJaWYgKCFwcm9iZSkgewoJCXY0bDJfaW5mbyh2NGwyX2RldiwgIkF1dG9tYXRpYyBkZXZpY2UgcHJvYmluZyBkaXNhYmxlZC5cbiIpOwoJCXJldHVybiAtMTsKCX0KCgl2NGwyX2luZm8odjRsMl9kZXYsICJBdXRvbWF0aWMgZGV2aWNlIHByb2JpbmcgZW5hYmxlZC5cbiIpOwoKCWZvciAoaSA9IDA7IGkgPCBBUlJBWV9TSVpFKGlvcG9ydHMpOyArK2kpIHsKCQl2NGwyX2luZm8odjRsMl9kZXYsICJUcnlpbmcgSS9PIHBvcnQgMHgleC4uLlxuIiwgaW9wb3J0c1tpXSk7CgoJCWlmICghcmVxdWVzdF9yZWdpb24oaW9wb3J0c1tpXSwgMSwgImdlbXRlay1wcm9iZSIpKSB7CgkJCXY0bDJfd2Fybih2NGwyX2RldiwgIkkvTyBwb3J0IDB4JXggYnVzeSFcbiIsCgkJCSAgICAgICBpb3BvcnRzW2ldKTsKCQkJY29udGludWU7CgkJfQoKCQlpZiAoZ2VtdGVrX3ZlcmlmeShndCwgaW9wb3J0c1tpXSkpIHsKCQkJdjRsMl9pbmZvKHY0bDJfZGV2LCAiQ2FyZCBmb3VuZCBmcm9tIEkvTyBwb3J0ICIKCQkJICAgICAgICIweCV4IVxuIiwgaW9wb3J0c1tpXSk7CgoJCQlyZWxlYXNlX3JlZ2lvbihpb3BvcnRzW2ldLCAxKTsKCQkJZ3QtPmlvID0gaW9wb3J0c1tpXTsKCQkJcmV0dXJuIGd0LT5pbzsKCQl9CgoJCXJlbGVhc2VfcmVnaW9uKGlvcG9ydHNbaV0sIDEpOwoJfQoKCXY0bDJfZXJyKHY0bDJfZGV2LCAiQXV0b21hdGljIHByb2JpbmcgZmFpbGVkIVxuIik7CglyZXR1cm4gLTE7Cn0KCi8qCiAqIFZpZGVvIDQgTGludXggc3R1ZmYuCiAqLwoKc3RhdGljIGNvbnN0IHN0cnVjdCB2NGwyX2ZpbGVfb3BlcmF0aW9ucyBnZW10ZWtfZm9wcyA9IHsKCS5vd25lcgkJPSBUSElTX01PRFVMRSwKCS5pb2N0bAkJPSB2aWRlb19pb2N0bDIsCn07CgpzdGF0aWMgaW50IHZpZGlvY19xdWVyeWNhcChzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwKCQkJICAgc3RydWN0IHY0bDJfY2FwYWJpbGl0eSAqdikKewoJc3RybGNweSh2LT5kcml2ZXIsICJyYWRpby1nZW10ZWsiLCBzaXplb2Yodi0+ZHJpdmVyKSk7CglzdHJsY3B5KHYtPmNhcmQsICJHZW1UZWsiLCBzaXplb2Yodi0+Y2FyZCkpOwoJc3RybGNweSh2LT5idXNfaW5mbywgIklTQSIsIHNpemVvZih2LT5idXNfaW5mbykpOwoJdi0+dmVyc2lvbiA9IFJBRElPX1ZFUlNJT047Cgl2LT5jYXBhYmlsaXRpZXMgPSBWNEwyX0NBUF9UVU5FUiB8IFY0TDJfQ0FQX1JBRElPOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX2dfdHVuZXIoc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsIHN0cnVjdCB2NGwyX3R1bmVyICp2KQp7CglzdHJ1Y3QgZ2VtdGVrICpndCA9IHZpZGVvX2RydmRhdGEoZmlsZSk7CgoJaWYgKHYtPmluZGV4ID4gMCkKCQlyZXR1cm4gLUVJTlZBTDsKCglzdHJsY3B5KHYtPm5hbWUsICJGTSIsIHNpemVvZih2LT5uYW1lKSk7Cgl2LT50eXBlID0gVjRMMl9UVU5FUl9SQURJTzsKCXYtPnJhbmdlbG93ID0gR0VNVEVLX0xPV0ZSRVE7Cgl2LT5yYW5nZWhpZ2ggPSBHRU1URUtfSElHSEZSRVE7Cgl2LT5jYXBhYmlsaXR5ID0gVjRMMl9UVU5FUl9DQVBfTE9XIHwgVjRMMl9UVU5FUl9DQVBfU1RFUkVPOwoJdi0+c2lnbmFsID0gMHhmZmZmICogZ2VtdGVrX2dldHNpZ3N0cihndCk7CglpZiAodi0+c2lnbmFsKSB7CgkJdi0+YXVkbW9kZSA9IFY0TDJfVFVORVJfTU9ERV9TVEVSRU87CgkJdi0+cnhzdWJjaGFucyA9IFY0TDJfVFVORVJfU1VCX1NURVJFTzsKCX0gZWxzZSB7CgkJdi0+YXVkbW9kZSA9IFY0TDJfVFVORVJfTU9ERV9NT05POwoJCXYtPnJ4c3ViY2hhbnMgPSBWNEwyX1RVTkVSX1NVQl9NT05POwoJfQoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX3NfdHVuZXIoc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsIHN0cnVjdCB2NGwyX3R1bmVyICp2KQp7CglyZXR1cm4gKHYtPmluZGV4ICE9IDApID8gLUVJTlZBTCA6IDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX2dfZnJlcXVlbmN5KHN0cnVjdCBmaWxlICpmaWxlLCB2b2lkICpwcml2LAoJCQkgICAgICBzdHJ1Y3QgdjRsMl9mcmVxdWVuY3kgKmYpCnsKCXN0cnVjdCBnZW10ZWsgKmd0ID0gdmlkZW9fZHJ2ZGF0YShmaWxlKTsKCglpZiAoZi0+dHVuZXIgIT0gMCkKCQlyZXR1cm4gLUVJTlZBTDsKCWYtPnR5cGUgPSBWNEwyX1RVTkVSX1JBRElPOwoJZi0+ZnJlcXVlbmN5ID0gZ3QtPmxhc3RmcmVxOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX3NfZnJlcXVlbmN5KHN0cnVjdCBmaWxlICpmaWxlLCB2b2lkICpwcml2LAoJCQkgICAgICBzdHJ1Y3QgdjRsMl9mcmVxdWVuY3kgKmYpCnsKCXN0cnVjdCBnZW10ZWsgKmd0ID0gdmlkZW9fZHJ2ZGF0YShmaWxlKTsKCglpZiAoZi0+dHVuZXIgIT0gMCB8fCBmLT50eXBlICE9IFY0TDJfVFVORVJfUkFESU8pCgkJcmV0dXJuIC1FSU5WQUw7CglnZW10ZWtfc2V0ZnJlcShndCwgZi0+ZnJlcXVlbmN5KTsKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IHZpZGlvY19xdWVyeWN0cmwoc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsCgkJCSAgICBzdHJ1Y3QgdjRsMl9xdWVyeWN0cmwgKnFjKQp7Cglzd2l0Y2ggKHFjLT5pZCkgewoJY2FzZSBWNEwyX0NJRF9BVURJT19NVVRFOgoJCXJldHVybiB2NGwyX2N0cmxfcXVlcnlfZmlsbChxYywgMCwgMSwgMSwgMCk7CglkZWZhdWx0OgoJCXJldHVybiAtRUlOVkFMOwoJfQp9CgpzdGF0aWMgaW50IHZpZGlvY19nX2N0cmwoc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsCgkJCSBzdHJ1Y3QgdjRsMl9jb250cm9sICpjdHJsKQp7CglzdHJ1Y3QgZ2VtdGVrICpndCA9IHZpZGVvX2RydmRhdGEoZmlsZSk7CgoJc3dpdGNoIChjdHJsLT5pZCkgewoJY2FzZSBWNEwyX0NJRF9BVURJT19NVVRFOgoJCWN0cmwtPnZhbHVlID0gZ3QtPm11dGVkOwoJCXJldHVybiAwOwoJfQoJcmV0dXJuIC1FSU5WQUw7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX3NfY3RybChzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwKCQkJIHN0cnVjdCB2NGwyX2NvbnRyb2wgKmN0cmwpCnsKCXN0cnVjdCBnZW10ZWsgKmd0ID0gdmlkZW9fZHJ2ZGF0YShmaWxlKTsKCglzd2l0Y2ggKGN0cmwtPmlkKSB7CgljYXNlIFY0TDJfQ0lEX0FVRElPX01VVEU6CgkJaWYgKGN0cmwtPnZhbHVlKQoJCQlnZW10ZWtfbXV0ZShndCk7CgkJZWxzZQoJCQlnZW10ZWtfdW5tdXRlKGd0KTsKCQlyZXR1cm4gMDsKCX0KCXJldHVybiAtRUlOVkFMOwp9CgpzdGF0aWMgaW50IHZpZGlvY19nX2lucHV0KHN0cnVjdCBmaWxlICpmaWxwLCB2b2lkICpwcml2LCB1bnNpZ25lZCBpbnQgKmkpCnsKCSppID0gMDsKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IHZpZGlvY19zX2lucHV0KHN0cnVjdCBmaWxlICpmaWxwLCB2b2lkICpwcml2LCB1bnNpZ25lZCBpbnQgaSkKewoJcmV0dXJuIChpICE9IDApID8gLUVJTlZBTCA6IDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX2dfYXVkaW8oc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsIHN0cnVjdCB2NGwyX2F1ZGlvICphKQp7CglhLT5pbmRleCA9IDA7CglzdHJsY3B5KGEtPm5hbWUsICJSYWRpbyIsIHNpemVvZihhLT5uYW1lKSk7CglhLT5jYXBhYmlsaXR5ID0gVjRMMl9BVURDQVBfU1RFUkVPOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX3NfYXVkaW8oc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsIHN0cnVjdCB2NGwyX2F1ZGlvICphKQp7CglyZXR1cm4gKGEtPmluZGV4ICE9IDApID8gLUVJTlZBTCA6IDA7Cn0KCnN0YXRpYyBjb25zdCBzdHJ1Y3QgdjRsMl9pb2N0bF9vcHMgZ2VtdGVrX2lvY3RsX29wcyA9IHsKCS52aWRpb2NfcXVlcnljYXAJPSB2aWRpb2NfcXVlcnljYXAsCgkudmlkaW9jX2dfdHVuZXIJCT0gdmlkaW9jX2dfdHVuZXIsCgkudmlkaW9jX3NfdHVuZXIJCT0gdmlkaW9jX3NfdHVuZXIsCgkudmlkaW9jX2dfYXVkaW8JCT0gdmlkaW9jX2dfYXVkaW8sCgkudmlkaW9jX3NfYXVkaW8JCT0gdmlkaW9jX3NfYXVkaW8sCgkudmlkaW9jX2dfaW5wdXQJCT0gdmlkaW9jX2dfaW5wdXQsCgkudmlkaW9jX3NfaW5wdXQJCT0gdmlkaW9jX3NfaW5wdXQsCgkudmlkaW9jX2dfZnJlcXVlbmN5CT0gdmlkaW9jX2dfZnJlcXVlbmN5LAoJLnZpZGlvY19zX2ZyZXF1ZW5jeQk9IHZpZGlvY19zX2ZyZXF1ZW5jeSwKCS52aWRpb2NfcXVlcnljdHJsCT0gdmlkaW9jX3F1ZXJ5Y3RybCwKCS52aWRpb2NfZ19jdHJsCQk9IHZpZGlvY19nX2N0cmwsCgkudmlkaW9jX3NfY3RybAkJPSB2aWRpb2Nfc19jdHJsCn07CgovKgogKiBJbml0aWFsaXphdGlvbiAvIGNsZWFudXAgcmVsYXRlZCBzdHVmZi4KICovCgpzdGF0aWMgaW50IF9faW5pdCBnZW10ZWtfaW5pdCh2b2lkKQp7CglzdHJ1Y3QgZ2VtdGVrICpndCA9ICZnZW10ZWtfY2FyZDsKCXN0cnVjdCB2NGwyX2RldmljZSAqdjRsMl9kZXYgPSAmZ3QtPnY0bDJfZGV2OwoJaW50IHJlczsKCglzdHJsY3B5KHY0bDJfZGV2LT5uYW1lLCAiZ2VtdGVrIiwgc2l6ZW9mKHY0bDJfZGV2LT5uYW1lKSk7CgoJdjRsMl9pbmZvKHY0bDJfZGV2LCAiR2VtVGVrIFJhZGlvIGNhcmQgZHJpdmVyOiB2MC4wLjNcbiIpOwoKCW11dGV4X2luaXQoJmd0LT5sb2NrKTsKCglndC0+dmVyaWZpZWQgPSAtMTsKCWd0LT5pbyA9IGlvOwoJZ2VtdGVrX3Byb2JlKGd0KTsKCWlmIChndC0+aW8pIHsKCQlpZiAoIXJlcXVlc3RfcmVnaW9uKGd0LT5pbywgMSwgImdlbXRlayIpKSB7CgkJCXY0bDJfZXJyKHY0bDJfZGV2LCAiSS9PIHBvcnQgMHgleCBhbHJlYWR5IGluIHVzZS5cbiIsIGd0LT5pbyk7CgkJCXJldHVybiAtRUJVU1k7CgkJfQoKCQlpZiAoIWdlbXRla192ZXJpZnkoZ3QsIGd0LT5pbykpCgkJCXY0bDJfd2Fybih2NGwyX2RldiwgIkNhcmQgYXQgSS9PIHBvcnQgMHgleCBkb2VzIG5vdCAiCgkJCSAgICAgICAicmVzcG9uZCBwcm9wZXJseSwgY2hlY2sgeW91ciAiCgkJCSAgICAgICAiY29uZmlndXJhdGlvbi5cbiIsIGd0LT5pbyk7CgkJZWxzZQoJCQl2NGwyX2luZm8odjRsMl9kZXYsICJVc2luZyBJL08gcG9ydCAweCV4LlxuIiwgZ3QtPmlvKTsKCX0gZWxzZSBpZiAocHJvYmUpIHsKCQl2NGwyX2Vycih2NGwyX2RldiwgIkF1dG9tYXRpYyBwcm9iaW5nIGZhaWxlZCBhbmQgbm8gIgoJCSAgICAgICAiZml4ZWQgSS9PIHBvcnQgZGVmaW5lZC5cbiIpOwoJCXJldHVybiAtRU5PREVWOwoJfSBlbHNlIHsKCQl2NGwyX2Vycih2NGwyX2RldiwgIkF1dG9tYXRpYyBwcm9iaW5nIGRpc2FibGVkIGJ1dCBubyBmaXhlZCAiCgkJICAgICAgICJJL08gcG9ydCBkZWZpbmVkLiIpOwoJCXJldHVybiAtRUlOVkFMOwoJfQoKCXJlcyA9IHY0bDJfZGV2aWNlX3JlZ2lzdGVyKE5VTEwsIHY0bDJfZGV2KTsKCWlmIChyZXMgPCAwKSB7CgkJdjRsMl9lcnIodjRsMl9kZXYsICJDb3VsZCBub3QgcmVnaXN0ZXIgdjRsMl9kZXZpY2VcbiIpOwoJCXJlbGVhc2VfcmVnaW9uKGd0LT5pbywgMSk7CgkJcmV0dXJuIHJlczsKCX0KCglzdHJsY3B5KGd0LT52ZGV2Lm5hbWUsIHY0bDJfZGV2LT5uYW1lLCBzaXplb2YoZ3QtPnZkZXYubmFtZSkpOwoJZ3QtPnZkZXYudjRsMl9kZXYgPSB2NGwyX2RldjsKCWd0LT52ZGV2LmZvcHMgPSAmZ2VtdGVrX2ZvcHM7CglndC0+dmRldi5pb2N0bF9vcHMgPSAmZ2VtdGVrX2lvY3RsX29wczsKCWd0LT52ZGV2LnJlbGVhc2UgPSB2aWRlb19kZXZpY2VfcmVsZWFzZV9lbXB0eTsKCXZpZGVvX3NldF9kcnZkYXRhKCZndC0+dmRldiwgZ3QpOwoKCWlmICh2aWRlb19yZWdpc3Rlcl9kZXZpY2UoJmd0LT52ZGV2LCBWRkxfVFlQRV9SQURJTywgcmFkaW9fbnIpIDwgMCkgewoJCXY0bDJfZGV2aWNlX3VucmVnaXN0ZXIodjRsMl9kZXYpOwoJCXJlbGVhc2VfcmVnaW9uKGd0LT5pbywgMSk7CgkJcmV0dXJuIC1FQlVTWTsKCX0KCgkvKiBTZXQgZGVmYXVsdHMgKi8KCWd0LT5sYXN0ZnJlcSA9IEdFTVRFS19MT1dGUkVROwoJZ3QtPmJ1MjYxNGRhdGEgPSAwOwoKCWlmIChpbml0bXV0ZSkKCQlnZW10ZWtfbXV0ZShndCk7CgoJcmV0dXJuIDA7Cn0KCi8qCiAqIE1vZHVsZSBjbGVhbnVwCiAqLwpzdGF0aWMgdm9pZCBfX2V4aXQgZ2VtdGVrX2V4aXQodm9pZCkKewoJc3RydWN0IGdlbXRlayAqZ3QgPSAmZ2VtdGVrX2NhcmQ7CglzdHJ1Y3QgdjRsMl9kZXZpY2UgKnY0bDJfZGV2ID0gJmd0LT52NGwyX2RldjsKCglpZiAoc2h1dGRvd24pIHsKCQloYXJkbXV0ZSA9IDE7CS8qIFR1cm4gb2ZmIFBMTCAqLwoJCWdlbXRla19tdXRlKGd0KTsKCX0gZWxzZSB7CgkJdjRsMl9pbmZvKHY0bDJfZGV2LCAiTW9kdWxlIHVubG9hZGVkIGJ1dCBjYXJkIG5vdCBtdXRlZCFcbiIpOwoJfQoKCXZpZGVvX3VucmVnaXN0ZXJfZGV2aWNlKCZndC0+dmRldik7Cgl2NGwyX2RldmljZV91bnJlZ2lzdGVyKCZndC0+djRsMl9kZXYpOwoJcmVsZWFzZV9yZWdpb24oZ3QtPmlvLCAxKTsKfQoKbW9kdWxlX2luaXQoZ2VtdGVrX2luaXQpOwptb2R1bGVfZXhpdChnZW10ZWtfZXhpdCk7Cg==