LyogR2VtVGVrIHJhZGlvIGNhcmQgZHJpdmVyIGZvciBMaW51eCAoQykgMTk5OCBKb25hcyBNdW5zaW4gPGptdW5zaW5AaWtpLmZpPgogKgogKiBHZW1UZWsgaGFzbid0IHJlbGVhc2VkIGFueSBzcGVjcyBvbiB0aGUgY2FyZCwgc28gdGhlIHByb3RvY29sIGhhZCB0bwogKiBiZSByZXZlcnNlIGVuZ2luZWVyZWQgd2l0aCBkb3NlbXUuCiAqCiAqIEJlc2lkZXMgdGhlIHByb3RvY29sIGNoYW5nZXMsIHRoaXMgaXMgbW9zdGx5IGEgY29weSBvZjoKICoKICogICAgUmFkaW9UcmFjayBJSSBkcml2ZXIgZm9yIExpbnV4IHJhZGlvIHN1cHBvcnQgKEMpIDE5OTggQmVuIFBmYWZmCiAqCiAqICAgIEJhc2VkIG9uIFJhZGlvVHJhY2sgSS9SYWRpb1JldmVhbCAoQykgMTk5NyBNLiBLaXJrd29vZAogKiAgICBDb252ZXJ0ZWQgdG8gbmV3IEFQSSBieSBBbGFuIENveCA8YWxhbkBseG9yZ3VrLnVrdXUub3JnLnVrPgogKiAgICBWYXJpb3VzIGJ1Z2ZpeGVzIGFuZCBlbmhhbmNlbWVudHMgYnkgUnVzc2VsbCBLcm9sbCA8cmtyb2xsQGV4cGxvaXRzLm9yZz4KICoKICogVE9ETzogQWxsb3cgZm9yIG1vcmUgdGhhbiBvbmUgb2YgdGhlc2UgZm9vbGlzaCBlbnRpdGllcyA6LSkKICoKICogQ29udmVydGVkIHRvIFY0TDIgQVBJIGJ5IE1hdXJvIENhcnZhbGhvIENoZWhhYiA8bWNoZWhhYkBpbmZyYWRlYWQub3JnPgogKi8KCiNpbmNsdWRlIDxsaW51eC9tb2R1bGUuaD4JLyogTW9kdWxlcyAJCQkqLwojaW5jbHVkZSA8bGludXgvaW5pdC5oPgkJLyogSW5pdGRhdGEJCQkqLwojaW5jbHVkZSA8bGludXgvaW9wb3J0Lmg+CS8qIHJlcXVlc3RfcmVnaW9uCQkqLwojaW5jbHVkZSA8bGludXgvZGVsYXkuaD4JLyogdWRlbGF5CQkJKi8KI2luY2x1ZGUgPGxpbnV4L3ZpZGVvZGV2Mi5oPgkvKiBrZXJuZWwgcmFkaW8gc3RydWN0cwkJKi8KI2luY2x1ZGUgPGxpbnV4L3ZlcnNpb24uaD4JLyogZm9yIEtFUk5FTF9WRVJTSU9OIE1BQ1JPCSovCiNpbmNsdWRlIDxsaW51eC9tdXRleC5oPgojaW5jbHVkZSA8bGludXgvaW8uaD4JCS8qIG91dGIsIG91dGJfcAkJCSovCiNpbmNsdWRlIDxtZWRpYS92NGwyLWlvY3RsLmg+CiNpbmNsdWRlIDxtZWRpYS92NGwyLWRldmljZS5oPgoKI2RlZmluZSBSQURJT19WRVJTSU9OIEtFUk5FTF9WRVJTSU9OKDAsIDAsIDMpCgovKgogKiBNb2R1bGUgaW5mby4KICovCgpNT0RVTEVfQVVUSE9SKCJKb25hcyBNdW5zaW4sIFBla2thIFNlcHDkbmVuIDxwZXh1QGthcHNpLmZpPiIpOwpNT0RVTEVfREVTQ1JJUFRJT04oIkEgZHJpdmVyIGZvciB0aGUgR2VtVGVrIFJhZGlvIGNhcmQuIik7Ck1PRFVMRV9MSUNFTlNFKCJHUEwiKTsKCi8qCiAqIE1vZHVsZSBwYXJhbXMuCiAqLwoKI2lmbmRlZiBDT05GSUdfUkFESU9fR0VNVEVLX1BPUlQKI2RlZmluZSBDT05GSUdfUkFESU9fR0VNVEVLX1BPUlQgLTEKI2VuZGlmCiNpZm5kZWYgQ09ORklHX1JBRElPX0dFTVRFS19QUk9CRQojZGVmaW5lIENPTkZJR19SQURJT19HRU1URUtfUFJPQkUgMQojZW5kaWYKCnN0YXRpYyBpbnQgaW8JCT0gQ09ORklHX1JBRElPX0dFTVRFS19QT1JUOwpzdGF0aWMgaW50IHByb2JlCT0gQ09ORklHX1JBRElPX0dFTVRFS19QUk9CRTsKc3RhdGljIGludCBoYXJkbXV0ZTsKc3RhdGljIGludCBzaHV0ZG93bgk9IDE7CnN0YXRpYyBpbnQga2VlcG11dGVkCT0gMTsKc3RhdGljIGludCBpbml0bXV0ZQk9IDE7CnN0YXRpYyBpbnQgcmFkaW9fbnIJPSAtMTsKCm1vZHVsZV9wYXJhbShpbywgaW50LCAwNDQ0KTsKTU9EVUxFX1BBUk1fREVTQyhpbywgIkZvcmNlIEkvTyBwb3J0IGZvciB0aGUgR2VtVGVrIFJhZGlvIGNhcmQgaWYgYXV0b21hdGljICIKCSAicHJvYmluZyBpcyBkaXNhYmxlZCBvciBmYWlscy4gVGhlIG1vc3QgY29tbW9uIEkvTyBwb3J0cyBhcmU6IDB4MjBjICIKCSAiMHgzMGMsIDB4MjRjIG9yIDB4MzRjICgweDIwYywgMHgyNDggYW5kIDB4MjhjIGhhdmUgYmVlbiByZXBvcnRlZCB0byAiCgkgIndvcmsgZm9yIHRoZSBjb21iaW5lZCBzb3VuZC9yYWRpb2NhcmQpLiIpOwoKbW9kdWxlX3BhcmFtKHByb2JlLCBib29sLCAwNDQ0KTsKTU9EVUxFX1BBUk1fREVTQyhwcm9iZSwgIkVuYWJsZSBhdXRvbWF0aWMgZGV2aWNlIHByb2JpbmcuIE5vdGU6IG9ubHkgdGhlIG1vc3QgIgoJImNvbW1vbiBJL08gcG9ydHMgdXNlZCBieSB0aGUgY2FyZCBhcmUgcHJvYmVkLiIpOwoKbW9kdWxlX3BhcmFtKGhhcmRtdXRlLCBib29sLCAwNjQ0KTsKTU9EVUxFX1BBUk1fREVTQyhoYXJkbXV0ZSwgIkVuYWJsZSBgaGFyZCBtdXRpbmcnIGJ5IHNodXR0aW5nIGRvd24gUExMLCBtYXkgIgoJICJyZWR1Y2Ugc3RhdGljIG5vaXNlLiIpOwoKbW9kdWxlX3BhcmFtKHNodXRkb3duLCBib29sLCAwNjQ0KTsKTU9EVUxFX1BBUk1fREVTQyhzaHV0ZG93biwgIkVuYWJsZSBzaHV0dGluZyBkb3duIFBMTCBhbmQgbXV0aW5nIGxpbmUgd2hlbiAiCgkgIm1vZHVsZSBpcyB1bmxvYWRlZC4iKTsKCm1vZHVsZV9wYXJhbShrZWVwbXV0ZWQsIGJvb2wsIDA2NDQpOwpNT0RVTEVfUEFSTV9ERVNDKGtlZXBtdXRlZCwgIktlZXAgY2FyZCBtdXRlZCBldmVuIHdoZW4gZnJlcXVlbmN5IGlzIGNoYW5nZWQuIik7Cgptb2R1bGVfcGFyYW0oaW5pdG11dGUsIGJvb2wsIDA0NDQpOwpNT0RVTEVfUEFSTV9ERVNDKGluaXRtdXRlLCAiTXV0ZSBjYXJkIHdoZW4gbW9kdWxlIGlzIGxvYWRlZC4iKTsKCm1vZHVsZV9wYXJhbShyYWRpb19uciwgaW50LCAwNDQ0KTsKCi8qCiAqIEZ1bmN0aW9ucyBmb3IgY29udHJvbGxpbmcgdGhlIGNhcmQuCiAqLwojZGVmaW5lIEdFTVRFS19MT1dGUkVRCSg4NyoxNjAwMCkKI2RlZmluZSBHRU1URUtfSElHSEZSRVEJKDEwOCoxNjAwMCkKCi8qCiAqIEZyZXF1ZW5jeSBjYWxjdWxhdGlvbiBjb25zdGFudHMuICBJbnRlcm1lZGlhdGUgZnJlcXVlbmN5IDEwLjUyIE1IeiAobm9taW5hbAogKiB2YWx1ZSAxMC43IE1IeiksIHJlZmVyZW5jZSBkaXZpc29yIDYuMzkga0h6IChub21pbmFsIDYuMjUga0h6KS4KICovCiNkZWZpbmUgRlNDQUxFCQk4CiNkZWZpbmUgSUZfT0ZGU0VUCSgodW5zaWduZWQgaW50KSgxMC41MiAqIDE2MDAwICogKDE8PEZTQ0FMRSkpKQojZGVmaW5lIFJFRl9GUkVRCSgodW5zaWduZWQgaW50KSg2LjM5ICogMTYgKiAoMTw8RlNDQUxFKSkpCgojZGVmaW5lIEdFTVRFS19DSwkJMHgwMQkvKiBDbG9jayBzaWduYWwJCQkqLwojZGVmaW5lIEdFTVRFS19EQQkJMHgwMgkvKiBTZXJpYWwgZGF0YQkJCSovCiNkZWZpbmUgR0VNVEVLX0NFCQkweDA0CS8qIENoaXAgZW5hYmxlCQkJKi8KI2RlZmluZSBHRU1URUtfTlMJCTB4MDgJLyogTm8gc2lnbmFsCQkJKi8KI2RlZmluZSBHRU1URUtfTVQJCTB4MTAJLyogTGluZSBtdXRlCQkJKi8KI2RlZmluZSBHRU1URUtfU1RERl8zXzEyNV9LSFoJMHgwMQkvKiBTdGFuZGFyZCBmcmVxdWVuY3kgMy4xMjUga0h6CSovCiNkZWZpbmUgR0VNVEVLX1BMTF9PRkYJCTB4MDcJLyogUExMIG9mZgkJCSovCgojZGVmaW5lIEJVMjYxNF9CVVNfU0laRQkzMgkvKiBCVTI2MTQgLyBCVTI2MTRGUyBidXMgc2l6ZQkJKi8KCiNkZWZpbmUgU0hPUlRfREVMQVkgNQkJLyogdXNlYyAqLwojZGVmaW5lIExPTkdfREVMQVkgNzUJCS8qIHVzZWMgKi8KCnN0cnVjdCBnZW10ZWsgewoJc3RydWN0IHY0bDJfZGV2aWNlIHY0bDJfZGV2OwoJc3RydWN0IHZpZGVvX2RldmljZSB2ZGV2OwoJc3RydWN0IG11dGV4IGxvY2s7Cgl1bnNpZ25lZCBsb25nIGxhc3RmcmVxOwoJaW50IG11dGVkOwoJaW50IHZlcmlmaWVkOwoJaW50IGlvOwoJdTMyIGJ1MjYxNGRhdGE7Cn07CgpzdGF0aWMgc3RydWN0IGdlbXRlayBnZW10ZWtfY2FyZDsKCiNkZWZpbmUgQlUyNjE0X0ZSRVFfQklUUyAJMTYgLyogRDAuLkQxNSwgRnJlcXVlbmN5IGRhdGEJCSovCiNkZWZpbmUgQlUyNjE0X1BPUlRfQklUUwkzIC8qIFAwLi5QMiwgT3V0cHV0IHBvcnQgY29udHJvbCBkYXRhCSovCiNkZWZpbmUgQlUyNjE0X1ZPSURfQklUUwk0IC8qIHVudXNlZCAJCQkJKi8KI2RlZmluZSBCVTI2MTRfRk1FU19CSVRTCTEgLyogQ1QsIEZyZXF1ZW5jeSBtZWFzdXJlbWVudCBiZWdpbm5pbmcgZGF0YSAqLwojZGVmaW5lIEJVMjYxNF9TVERGX0JJVFMJMyAvKiBSMC4uUjIsIFN0YW5kYXJkIGZyZXF1ZW5jeSBkYXRhCSovCiNkZWZpbmUgQlUyNjE0X1NXSU5fQklUUwkxIC8qIFMsIFN3aXRjaCBiZXR3ZWVuIEZNSU4gLyBBTUlOCSovCiNkZWZpbmUgQlUyNjE0X1NXQUxfQklUUyAgICAgICAgMSAvKiBQUywgU3dhbGxvdyBjb3VudGVyIGRpdmlzaW9uIChBTUlOIG9ubHkpKi8KI2RlZmluZSBCVTI2MTRfVk9JRDJfQklUUwkxIC8qIHVudXNlZAkJCQkqLwojZGVmaW5lIEJVMjYxNF9GTVVOX0JJVFMJMSAvKiBHVCwgRnJlcXVlbmN5IG1lYXN1cmVtZW50IHRpbWUgJiB1bmxvY2sgKi8KI2RlZmluZSBCVTI2MTRfVEVTVF9CSVRTCTEgLyogVFMsIFRlc3QgZGF0YSBpcyBpbnB1dAkJKi8KCiNkZWZpbmUgQlUyNjE0X0ZSRVFfU0hJRlQgCTAKI2RlZmluZSBCVTI2MTRfUE9SVF9TSElGVAkoQlUyNjE0X0ZSRVFfQklUUyArIEJVMjYxNF9GUkVRX1NISUZUKQojZGVmaW5lIEJVMjYxNF9WT0lEX1NISUZUCShCVTI2MTRfUE9SVF9CSVRTICsgQlUyNjE0X1BPUlRfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X0ZNRVNfU0hJRlQJKEJVMjYxNF9WT0lEX0JJVFMgKyBCVTI2MTRfVk9JRF9TSElGVCkKI2RlZmluZSBCVTI2MTRfU1RERl9TSElGVAkoQlUyNjE0X0ZNRVNfQklUUyArIEJVMjYxNF9GTUVTX1NISUZUKQojZGVmaW5lIEJVMjYxNF9TV0lOX1NISUZUCShCVTI2MTRfU1RERl9CSVRTICsgQlUyNjE0X1NUREZfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X1NXQUxfU0hJRlQJKEJVMjYxNF9TV0lOX0JJVFMgKyBCVTI2MTRfU1dJTl9TSElGVCkKI2RlZmluZSBCVTI2MTRfVk9JRDJfU0hJRlQJKEJVMjYxNF9TV0FMX0JJVFMgKyBCVTI2MTRfU1dBTF9TSElGVCkKI2RlZmluZSBCVTI2MTRfRk1VTl9TSElGVAkoQlUyNjE0X1ZPSUQyX0JJVFMgKyBCVTI2MTRfVk9JRDJfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X1RFU1RfU0hJRlQJKEJVMjYxNF9GTVVOX0JJVFMgKyBCVTI2MTRfRk1VTl9TSElGVCkKCiNkZWZpbmUgTUtNQVNLKGZpZWxkKQkoKCgxPDxCVTI2MTRfIyNmaWVsZCMjX0JJVFMpIC0gMSkgPDwgXAoJCQlCVTI2MTRfIyNmaWVsZCMjX1NISUZUKQojZGVmaW5lIEJVMjYxNF9QT1JUX01BU0sJTUtNQVNLKFBPUlQpCiNkZWZpbmUgQlUyNjE0X0ZSRVFfTUFTSwlNS01BU0soRlJFUSkKI2RlZmluZSBCVTI2MTRfVk9JRF9NQVNLCU1LTUFTSyhWT0lEKQojZGVmaW5lIEJVMjYxNF9GTUVTX01BU0sJTUtNQVNLKEZNRVMpCiNkZWZpbmUgQlUyNjE0X1NUREZfTUFTSwlNS01BU0soU1RERikKI2RlZmluZSBCVTI2MTRfU1dJTl9NQVNLCU1LTUFTSyhTV0lOKQojZGVmaW5lIEJVMjYxNF9TV0FMX01BU0sJTUtNQVNLKFNXQUwpCiNkZWZpbmUgQlUyNjE0X1ZPSUQyX01BU0sJTUtNQVNLKFZPSUQyKQojZGVmaW5lIEJVMjYxNF9GTVVOX01BU0sJTUtNQVNLKEZNVU4pCiNkZWZpbmUgQlUyNjE0X1RFU1RfTUFTSwlNS01BU0soVEVTVCkKCi8qCiAqIFNldCBkYXRhIHdoaWNoIHdpbGwgYmUgc2VudCB0byBCVTI2MTRGUy4KICovCiNkZWZpbmUgZ2VtdGVrX2J1MjYxNF9zZXQoZGV2LCBmaWVsZCwgZGF0YSkgKChkZXYpLT5idTI2MTRkYXRhID0gXAoJKChkZXYpLT5idTI2MTRkYXRhICYgfmZpZWxkIyNfTUFTSykgfCAoKGRhdGEpIDw8IGZpZWxkIyNfU0hJRlQpKQoKLyoKICogVHJhbnNtaXQgc2V0dGluZ3MgdG8gQlUyNjE0RlMgb3ZlciBHZW1UZWsgSUMuCiAqLwpzdGF0aWMgdm9pZCBnZW10ZWtfYnUyNjE0X3RyYW5zbWl0KHN0cnVjdCBnZW10ZWsgKmd0KQp7CglpbnQgaSwgYml0LCBxLCBtdXRlOwoKCW11dGV4X2xvY2soJmd0LT5sb2NrKTsKCgltdXRlID0gZ3QtPm11dGVkID8gR0VNVEVLX01UIDogMHgwMDsKCglvdXRiX3AobXV0ZSB8IEdFTVRFS19EQSB8IEdFTVRFS19DSywgZ3QtPmlvKTsKCXVkZWxheShTSE9SVF9ERUxBWSk7CglvdXRiX3AobXV0ZSB8IEdFTVRFS19DRSB8IEdFTVRFS19EQSB8IEdFTVRFS19DSywgZ3QtPmlvKTsKCXVkZWxheShMT05HX0RFTEFZKTsKCglmb3IgKGkgPSAwLCBxID0gZ3QtPmJ1MjYxNGRhdGE7IGkgPCAzMjsgaSsrLCBxID4+PSAxKSB7CgkJYml0ID0gKHEgJiAxKSA/IEdFTVRFS19EQSA6IDA7CgkJb3V0Yl9wKG11dGUgfCBHRU1URUtfQ0UgfCBiaXQsIGd0LT5pbyk7CgkJdWRlbGF5KFNIT1JUX0RFTEFZKTsKCQlvdXRiX3AobXV0ZSB8IEdFTVRFS19DRSB8IGJpdCB8IEdFTVRFS19DSywgZ3QtPmlvKTsKCQl1ZGVsYXkoU0hPUlRfREVMQVkpOwoJfQoKCW91dGJfcChtdXRlIHwgR0VNVEVLX0RBIHwgR0VNVEVLX0NLLCBndC0+aW8pOwoJdWRlbGF5KFNIT1JUX0RFTEFZKTsKCW91dGJfcChtdXRlIHwgR0VNVEVLX0NFIHwgR0VNVEVLX0RBIHwgR0VNVEVLX0NLLCBndC0+aW8pOwoJdWRlbGF5KExPTkdfREVMQVkpOwoKCW11dGV4X3VubG9jaygmZ3QtPmxvY2spOwp9CgovKgogKiBDYWxjdWxhdGUgZGl2aXNvciBmcm9tIEZNLWZyZXF1ZW5jeSBmb3IgQlUyNjE0RlMgKDMuMTI1IEtIeiBTVERGIGV4cGVjdGVkKS4KICovCnN0YXRpYyB1bnNpZ25lZCBsb25nIGdlbXRla19jb252ZnJlcSh1bnNpZ25lZCBsb25nIGZyZXEpCnsKCXJldHVybiAoKGZyZXE8PEZTQ0FMRSkgKyBJRl9PRkZTRVQgKyBSRUZfRlJFUS8yKSAvIFJFRl9GUkVROwp9CgovKgogKiBTZXQgRk0tZnJlcXVlbmN5LgogKi8Kc3RhdGljIHZvaWQgZ2VtdGVrX3NldGZyZXEoc3RydWN0IGdlbXRlayAqZ3QsIHVuc2lnbmVkIGxvbmcgZnJlcSkKewoJaWYgKGtlZXBtdXRlZCAmJiBoYXJkbXV0ZSAmJiBndC0+bXV0ZWQpCgkJcmV0dXJuOwoKCWZyZXEgPSBjbGFtcF92YWwoZnJlcSwgR0VNVEVLX0xPV0ZSRVEsIEdFTVRFS19ISUdIRlJFUSk7CgoJZ3QtPmxhc3RmcmVxID0gZnJlcTsKCWd0LT5tdXRlZCA9IDA7CgoJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9QT1JULCAwKTsKCWdlbXRla19idTI2MTRfc2V0KGd0LCBCVTI2MTRfRk1FUywgMCk7CglnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NXSU4sIDApOwkvKiBGTS1tb2RlCSovCglnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NXQUwsIDApOwoJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9GTVVOLCAxKTsJLyogR1QgYml0IHNldAkqLwoJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9URVNULCAwKTsKCglnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NUREYsIEdFTVRFS19TVERGXzNfMTI1X0tIWik7CglnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X0ZSRVEsIGdlbXRla19jb252ZnJlcShmcmVxKSk7CgoJZ2VtdGVrX2J1MjYxNF90cmFuc21pdChndCk7Cn0KCi8qCiAqIFNldCBtdXRlIGZsYWcuCiAqLwpzdGF0aWMgdm9pZCBnZW10ZWtfbXV0ZShzdHJ1Y3QgZ2VtdGVrICpndCkKewoJaW50IGk7CgoJZ3QtPm11dGVkID0gMTsKCglpZiAoaGFyZG11dGUpIHsKCQkvKiBUdXJuIG9mZiBQTEwsIGRpc2FibGUgZGF0YSBvdXRwdXQgKi8KCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1BPUlQsIDApOwoJCWdlbXRla19idTI2MTRfc2V0KGd0LCBCVTI2MTRfRk1FUywgMCk7CS8qIENUIGJpdCBvZmYJKi8KCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NXSU4sIDApOwkvKiBGTS1tb2RlCSovCgkJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9TV0FMLCAwKTsKCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X0ZNVU4sIDApOwkvKiBHVCBiaXQgb2ZmCSovCgkJZ2VtdGVrX2J1MjYxNF9zZXQoZ3QsIEJVMjYxNF9URVNULCAwKTsKCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X1NUREYsIEdFTVRFS19QTExfT0ZGKTsKCQlnZW10ZWtfYnUyNjE0X3NldChndCwgQlUyNjE0X0ZSRVEsIDApOwoJCWdlbXRla19idTI2MTRfdHJhbnNtaXQoZ3QpOwoJCXJldHVybjsKCX0KCgltdXRleF9sb2NrKCZndC0+bG9jayk7CgoJLyogUmVhZCBidXMgY29udGVudHMgKENFLCBDSyBhbmQgREEpLiAqLwoJaSA9IGluYl9wKGd0LT5pbyk7CgkvKiBXcml0ZSBpdCBiYWNrIHdpdGggbXV0ZSBmbGFnIHNldC4gKi8KCW91dGJfcCgoaSA+PiA1KSB8IEdFTVRFS19NVCwgZ3QtPmlvKTsKCXVkZWxheShTSE9SVF9ERUxBWSk7CgoJbXV0ZXhfdW5sb2NrKCZndC0+bG9jayk7Cn0KCi8qCiAqIFVuc2V0IG11dGUgZmxhZy4KICovCnN0YXRpYyB2b2lkIGdlbXRla191bm11dGUoc3RydWN0IGdlbXRlayAqZ3QpCnsKCWludCBpOwoKCWd0LT5tdXRlZCA9IDA7CglpZiAoaGFyZG11dGUpIHsKCQkvKiBUdXJuIFBMTCBiYWNrIG9uLiAqLwoJCWdlbXRla19zZXRmcmVxKGd0LCBndC0+bGFzdGZyZXEpOwoJCXJldHVybjsKCX0KCW11dGV4X2xvY2soJmd0LT5sb2NrKTsKCglpID0gaW5iX3AoZ3QtPmlvKTsKCW91dGJfcChpID4+IDUsIGd0LT5pbyk7Cgl1ZGVsYXkoU0hPUlRfREVMQVkpOwoKCW11dGV4X3VubG9jaygmZ3QtPmxvY2spOwp9CgovKgogKiBHZXQgc2lnbmFsIHN0cmVuZ3RoICg9IHN0ZXJlbyBzdGF0dXMpLgogKi8Kc3RhdGljIGlubGluZSBpbnQgZ2VtdGVrX2dldHNpZ3N0cihzdHJ1Y3QgZ2VtdGVrICpndCkKewoJaW50IHNpZzsKCgltdXRleF9sb2NrKCZndC0+bG9jayk7CglzaWcgPSBpbmJfcChndC0+aW8pICYgR0VNVEVLX05TID8gMCA6IDE7CgltdXRleF91bmxvY2soJmd0LT5sb2NrKTsKCXJldHVybiBzaWc7Cn0KCi8qCiAqIENoZWNrIGlmIHJlcXVlc3RlZCBjYXJkIGFjdHMgbGlrZSBHZW1UZWsgUmFkaW8gY2FyZC4KICovCnN0YXRpYyBpbnQgZ2VtdGVrX3ZlcmlmeShzdHJ1Y3QgZ2VtdGVrICpndCwgaW50IHBvcnQpCnsKCWludCBpLCBxOwoKCWlmIChndC0+dmVyaWZpZWQgPT0gcG9ydCkKCQlyZXR1cm4gMTsKCgltdXRleF9sb2NrKCZndC0+bG9jayk7CgoJcSA9IGluYl9wKHBvcnQpOwkvKiBSZWFkIGJ1cyBjb250ZW50cyBiZWZvcmUgcHJvYmluZy4gKi8KCS8qIFRyeSB0byB0dXJuIG9uIENFLCBDSyBhbmQgREEgcmVzcGVjdGl2ZWx5IGFuZCBjaGVjayBpZiBjYXJkIHJlc3BvbmRzCgkgICBwcm9wZXJseS4gKi8KCWZvciAoaSA9IDA7IGkgPCAzOyArK2kpIHsKCQlvdXRiX3AoMSA8PCBpLCBwb3J0KTsKCQl1ZGVsYXkoU0hPUlRfREVMQVkpOwoKCQlpZiAoKGluYl9wKHBvcnQpICYgKH5HRU1URUtfTlMpKSAhPSAoMHgxNyB8ICgxIDw8IChpICsgNSkpKSkgewoJCQltdXRleF91bmxvY2soJmd0LT5sb2NrKTsKCQkJcmV0dXJuIDA7CgkJfQoJfQoJb3V0Yl9wKHEgPj4gNSwgcG9ydCk7CS8qIFdyaXRlIGJ1cyBjb250ZW50cyBiYWNrLiAqLwoJdWRlbGF5KFNIT1JUX0RFTEFZKTsKCgltdXRleF91bmxvY2soJmd0LT5sb2NrKTsKCWd0LT52ZXJpZmllZCA9IHBvcnQ7CgoJcmV0dXJuIDE7Cn0KCi8qCiAqIEF1dG9tYXRpYyBwcm9iaW5nIGZvciBjYXJkLgogKi8Kc3RhdGljIGludCBnZW10ZWtfcHJvYmUoc3RydWN0IGdlbXRlayAqZ3QpCnsKCXN0cnVjdCB2NGwyX2RldmljZSAqdjRsMl9kZXYgPSAmZ3QtPnY0bDJfZGV2OwoJaW50IGlvcG9ydHNbXSA9IHsgMHgyMGMsIDB4MzBjLCAweDI0YywgMHgzNGMsIDB4MjQ4LCAweDI4YyB9OwoJaW50IGk7CgoJaWYgKCFwcm9iZSkgewoJCXY0bDJfaW5mbyh2NGwyX2RldiwgIkF1dG9tYXRpYyBkZXZpY2UgcHJvYmluZyBkaXNhYmxlZC5cbiIpOwoJCXJldHVybiAtMTsKCX0KCgl2NGwyX2luZm8odjRsMl9kZXYsICJBdXRvbWF0aWMgZGV2aWNlIHByb2JpbmcgZW5hYmxlZC5cbiIpOwoKCWZvciAoaSA9IDA7IGkgPCBBUlJBWV9TSVpFKGlvcG9ydHMpOyArK2kpIHsKCQl2NGwyX2luZm8odjRsMl9kZXYsICJUcnlpbmcgSS9PIHBvcnQgMHgleC4uLlxuIiwgaW9wb3J0c1tpXSk7CgoJCWlmICghcmVxdWVzdF9yZWdpb24oaW9wb3J0c1tpXSwgMSwgImdlbXRlay1wcm9iZSIpKSB7CgkJCXY0bDJfd2Fybih2NGwyX2RldiwgIkkvTyBwb3J0IDB4JXggYnVzeSFcbiIsCgkJCSAgICAgICBpb3BvcnRzW2ldKTsKCQkJY29udGludWU7CgkJfQoKCQlpZiAoZ2VtdGVrX3ZlcmlmeShndCwgaW9wb3J0c1tpXSkpIHsKCQkJdjRsMl9pbmZvKHY0bDJfZGV2LCAiQ2FyZCBmb3VuZCBmcm9tIEkvTyBwb3J0ICIKCQkJICAgICAgICIweCV4IVxuIiwgaW9wb3J0c1tpXSk7CgoJCQlyZWxlYXNlX3JlZ2lvbihpb3BvcnRzW2ldLCAxKTsKCQkJZ3QtPmlvID0gaW9wb3J0c1tpXTsKCQkJcmV0dXJuIGd0LT5pbzsKCQl9CgoJCXJlbGVhc2VfcmVnaW9uKGlvcG9ydHNbaV0sIDEpOwoJfQoKCXY0bDJfZXJyKHY0bDJfZGV2LCAiQXV0b21hdGljIHByb2JpbmcgZmFpbGVkIVxuIik7CglyZXR1cm4gLTE7Cn0KCi8qCiAqIFZpZGVvIDQgTGludXggc3R1ZmYuCiAqLwoKc3RhdGljIGNvbnN0IHN0cnVjdCB2NGwyX2ZpbGVfb3BlcmF0aW9ucyBnZW10ZWtfZm9wcyA9IHsKCS5vd25lcgkJPSBUSElTX01PRFVMRSwKCS51bmxvY2tlZF9pb2N0bAk9IHZpZGVvX2lvY3RsMiwKfTsKCnN0YXRpYyBpbnQgdmlkaW9jX3F1ZXJ5Y2FwKHN0cnVjdCBmaWxlICpmaWxlLCB2b2lkICpwcml2LAoJCQkgICBzdHJ1Y3QgdjRsMl9jYXBhYmlsaXR5ICp2KQp7CglzdHJsY3B5KHYtPmRyaXZlciwgInJhZGlvLWdlbXRlayIsIHNpemVvZih2LT5kcml2ZXIpKTsKCXN0cmxjcHkodi0+Y2FyZCwgIkdlbVRlayIsIHNpemVvZih2LT5jYXJkKSk7CglzdHJsY3B5KHYtPmJ1c19pbmZvLCAiSVNBIiwgc2l6ZW9mKHYtPmJ1c19pbmZvKSk7Cgl2LT52ZXJzaW9uID0gUkFESU9fVkVSU0lPTjsKCXYtPmNhcGFiaWxpdGllcyA9IFY0TDJfQ0FQX1RVTkVSIHwgVjRMMl9DQVBfUkFESU87CglyZXR1cm4gMDsKfQoKc3RhdGljIGludCB2aWRpb2NfZ190dW5lcihzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwgc3RydWN0IHY0bDJfdHVuZXIgKnYpCnsKCXN0cnVjdCBnZW10ZWsgKmd0ID0gdmlkZW9fZHJ2ZGF0YShmaWxlKTsKCglpZiAodi0+aW5kZXggPiAwKQoJCXJldHVybiAtRUlOVkFMOwoKCXN0cmxjcHkodi0+bmFtZSwgIkZNIiwgc2l6ZW9mKHYtPm5hbWUpKTsKCXYtPnR5cGUgPSBWNEwyX1RVTkVSX1JBRElPOwoJdi0+cmFuZ2Vsb3cgPSBHRU1URUtfTE9XRlJFUTsKCXYtPnJhbmdlaGlnaCA9IEdFTVRFS19ISUdIRlJFUTsKCXYtPmNhcGFiaWxpdHkgPSBWNEwyX1RVTkVSX0NBUF9MT1cgfCBWNEwyX1RVTkVSX0NBUF9TVEVSRU87Cgl2LT5zaWduYWwgPSAweGZmZmYgKiBnZW10ZWtfZ2V0c2lnc3RyKGd0KTsKCWlmICh2LT5zaWduYWwpIHsKCQl2LT5hdWRtb2RlID0gVjRMMl9UVU5FUl9NT0RFX1NURVJFTzsKCQl2LT5yeHN1YmNoYW5zID0gVjRMMl9UVU5FUl9TVUJfU1RFUkVPOwoJfSBlbHNlIHsKCQl2LT5hdWRtb2RlID0gVjRMMl9UVU5FUl9NT0RFX01PTk87CgkJdi0+cnhzdWJjaGFucyA9IFY0TDJfVFVORVJfU1VCX01PTk87Cgl9CglyZXR1cm4gMDsKfQoKc3RhdGljIGludCB2aWRpb2Nfc190dW5lcihzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwgc3RydWN0IHY0bDJfdHVuZXIgKnYpCnsKCXJldHVybiAodi0+aW5kZXggIT0gMCkgPyAtRUlOVkFMIDogMDsKfQoKc3RhdGljIGludCB2aWRpb2NfZ19mcmVxdWVuY3koc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsCgkJCSAgICAgIHN0cnVjdCB2NGwyX2ZyZXF1ZW5jeSAqZikKewoJc3RydWN0IGdlbXRlayAqZ3QgPSB2aWRlb19kcnZkYXRhKGZpbGUpOwoKCWlmIChmLT50dW5lciAhPSAwKQoJCXJldHVybiAtRUlOVkFMOwoJZi0+dHlwZSA9IFY0TDJfVFVORVJfUkFESU87CglmLT5mcmVxdWVuY3kgPSBndC0+bGFzdGZyZXE7CglyZXR1cm4gMDsKfQoKc3RhdGljIGludCB2aWRpb2Nfc19mcmVxdWVuY3koc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsCgkJCSAgICAgIHN0cnVjdCB2NGwyX2ZyZXF1ZW5jeSAqZikKewoJc3RydWN0IGdlbXRlayAqZ3QgPSB2aWRlb19kcnZkYXRhKGZpbGUpOwoKCWlmIChmLT50dW5lciAhPSAwIHx8IGYtPnR5cGUgIT0gVjRMMl9UVU5FUl9SQURJTykKCQlyZXR1cm4gLUVJTlZBTDsKCWdlbXRla19zZXRmcmVxKGd0LCBmLT5mcmVxdWVuY3kpOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX3F1ZXJ5Y3RybChzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwKCQkJICAgIHN0cnVjdCB2NGwyX3F1ZXJ5Y3RybCAqcWMpCnsKCXN3aXRjaCAocWMtPmlkKSB7CgljYXNlIFY0TDJfQ0lEX0FVRElPX01VVEU6CgkJcmV0dXJuIHY0bDJfY3RybF9xdWVyeV9maWxsKHFjLCAwLCAxLCAxLCAwKTsKCWRlZmF1bHQ6CgkJcmV0dXJuIC1FSU5WQUw7Cgl9Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX2dfY3RybChzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwKCQkJIHN0cnVjdCB2NGwyX2NvbnRyb2wgKmN0cmwpCnsKCXN0cnVjdCBnZW10ZWsgKmd0ID0gdmlkZW9fZHJ2ZGF0YShmaWxlKTsKCglzd2l0Y2ggKGN0cmwtPmlkKSB7CgljYXNlIFY0TDJfQ0lEX0FVRElPX01VVEU6CgkJY3RybC0+dmFsdWUgPSBndC0+bXV0ZWQ7CgkJcmV0dXJuIDA7Cgl9CglyZXR1cm4gLUVJTlZBTDsKfQoKc3RhdGljIGludCB2aWRpb2Nfc19jdHJsKHN0cnVjdCBmaWxlICpmaWxlLCB2b2lkICpwcml2LAoJCQkgc3RydWN0IHY0bDJfY29udHJvbCAqY3RybCkKewoJc3RydWN0IGdlbXRlayAqZ3QgPSB2aWRlb19kcnZkYXRhKGZpbGUpOwoKCXN3aXRjaCAoY3RybC0+aWQpIHsKCWNhc2UgVjRMMl9DSURfQVVESU9fTVVURToKCQlpZiAoY3RybC0+dmFsdWUpCgkJCWdlbXRla19tdXRlKGd0KTsKCQllbHNlCgkJCWdlbXRla191bm11dGUoZ3QpOwoJCXJldHVybiAwOwoJfQoJcmV0dXJuIC1FSU5WQUw7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX2dfaW5wdXQoc3RydWN0IGZpbGUgKmZpbHAsIHZvaWQgKnByaXYsIHVuc2lnbmVkIGludCAqaSkKewoJKmkgPSAwOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX3NfaW5wdXQoc3RydWN0IGZpbGUgKmZpbHAsIHZvaWQgKnByaXYsIHVuc2lnbmVkIGludCBpKQp7CglyZXR1cm4gKGkgIT0gMCkgPyAtRUlOVkFMIDogMDsKfQoKc3RhdGljIGludCB2aWRpb2NfZ19hdWRpbyhzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwgc3RydWN0IHY0bDJfYXVkaW8gKmEpCnsKCWEtPmluZGV4ID0gMDsKCXN0cmxjcHkoYS0+bmFtZSwgIlJhZGlvIiwgc2l6ZW9mKGEtPm5hbWUpKTsKCWEtPmNhcGFiaWxpdHkgPSBWNEwyX0FVRENBUF9TVEVSRU87CglyZXR1cm4gMDsKfQoKc3RhdGljIGludCB2aWRpb2Nfc19hdWRpbyhzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwgc3RydWN0IHY0bDJfYXVkaW8gKmEpCnsKCXJldHVybiAoYS0+aW5kZXggIT0gMCkgPyAtRUlOVkFMIDogMDsKfQoKc3RhdGljIGNvbnN0IHN0cnVjdCB2NGwyX2lvY3RsX29wcyBnZW10ZWtfaW9jdGxfb3BzID0gewoJLnZpZGlvY19xdWVyeWNhcAk9IHZpZGlvY19xdWVyeWNhcCwKCS52aWRpb2NfZ190dW5lcgkJPSB2aWRpb2NfZ190dW5lciwKCS52aWRpb2Nfc190dW5lcgkJPSB2aWRpb2Nfc190dW5lciwKCS52aWRpb2NfZ19hdWRpbwkJPSB2aWRpb2NfZ19hdWRpbywKCS52aWRpb2Nfc19hdWRpbwkJPSB2aWRpb2Nfc19hdWRpbywKCS52aWRpb2NfZ19pbnB1dAkJPSB2aWRpb2NfZ19pbnB1dCwKCS52aWRpb2Nfc19pbnB1dAkJPSB2aWRpb2Nfc19pbnB1dCwKCS52aWRpb2NfZ19mcmVxdWVuY3kJPSB2aWRpb2NfZ19mcmVxdWVuY3ksCgkudmlkaW9jX3NfZnJlcXVlbmN5CT0gdmlkaW9jX3NfZnJlcXVlbmN5LAoJLnZpZGlvY19xdWVyeWN0cmwJPSB2aWRpb2NfcXVlcnljdHJsLAoJLnZpZGlvY19nX2N0cmwJCT0gdmlkaW9jX2dfY3RybCwKCS52aWRpb2Nfc19jdHJsCQk9IHZpZGlvY19zX2N0cmwKfTsKCi8qCiAqIEluaXRpYWxpemF0aW9uIC8gY2xlYW51cCByZWxhdGVkIHN0dWZmLgogKi8KCnN0YXRpYyBpbnQgX19pbml0IGdlbXRla19pbml0KHZvaWQpCnsKCXN0cnVjdCBnZW10ZWsgKmd0ID0gJmdlbXRla19jYXJkOwoJc3RydWN0IHY0bDJfZGV2aWNlICp2NGwyX2RldiA9ICZndC0+djRsMl9kZXY7CglpbnQgcmVzOwoKCXN0cmxjcHkodjRsMl9kZXYtPm5hbWUsICJnZW10ZWsiLCBzaXplb2YodjRsMl9kZXYtPm5hbWUpKTsKCgl2NGwyX2luZm8odjRsMl9kZXYsICJHZW1UZWsgUmFkaW8gY2FyZCBkcml2ZXI6IHYwLjAuM1xuIik7CgoJbXV0ZXhfaW5pdCgmZ3QtPmxvY2spOwoKCWd0LT52ZXJpZmllZCA9IC0xOwoJZ3QtPmlvID0gaW87CglnZW10ZWtfcHJvYmUoZ3QpOwoJaWYgKGd0LT5pbykgewoJCWlmICghcmVxdWVzdF9yZWdpb24oZ3QtPmlvLCAxLCAiZ2VtdGVrIikpIHsKCQkJdjRsMl9lcnIodjRsMl9kZXYsICJJL08gcG9ydCAweCV4IGFscmVhZHkgaW4gdXNlLlxuIiwgZ3QtPmlvKTsKCQkJcmV0dXJuIC1FQlVTWTsKCQl9CgoJCWlmICghZ2VtdGVrX3ZlcmlmeShndCwgZ3QtPmlvKSkKCQkJdjRsMl93YXJuKHY0bDJfZGV2LCAiQ2FyZCBhdCBJL08gcG9ydCAweCV4IGRvZXMgbm90ICIKCQkJICAgICAgICJyZXNwb25kIHByb3Blcmx5LCBjaGVjayB5b3VyICIKCQkJICAgICAgICJjb25maWd1cmF0aW9uLlxuIiwgZ3QtPmlvKTsKCQllbHNlCgkJCXY0bDJfaW5mbyh2NGwyX2RldiwgIlVzaW5nIEkvTyBwb3J0IDB4JXguXG4iLCBndC0+aW8pOwoJfSBlbHNlIGlmIChwcm9iZSkgewoJCXY0bDJfZXJyKHY0bDJfZGV2LCAiQXV0b21hdGljIHByb2JpbmcgZmFpbGVkIGFuZCBubyAiCgkJICAgICAgICJmaXhlZCBJL08gcG9ydCBkZWZpbmVkLlxuIik7CgkJcmV0dXJuIC1FTk9ERVY7Cgl9IGVsc2UgewoJCXY0bDJfZXJyKHY0bDJfZGV2LCAiQXV0b21hdGljIHByb2JpbmcgZGlzYWJsZWQgYnV0IG5vIGZpeGVkICIKCQkgICAgICAgIkkvTyBwb3J0IGRlZmluZWQuIik7CgkJcmV0dXJuIC1FSU5WQUw7Cgl9CgoJcmVzID0gdjRsMl9kZXZpY2VfcmVnaXN0ZXIoTlVMTCwgdjRsMl9kZXYpOwoJaWYgKHJlcyA8IDApIHsKCQl2NGwyX2Vycih2NGwyX2RldiwgIkNvdWxkIG5vdCByZWdpc3RlciB2NGwyX2RldmljZVxuIik7CgkJcmVsZWFzZV9yZWdpb24oZ3QtPmlvLCAxKTsKCQlyZXR1cm4gcmVzOwoJfQoKCXN0cmxjcHkoZ3QtPnZkZXYubmFtZSwgdjRsMl9kZXYtPm5hbWUsIHNpemVvZihndC0+dmRldi5uYW1lKSk7CglndC0+dmRldi52NGwyX2RldiA9IHY0bDJfZGV2OwoJZ3QtPnZkZXYuZm9wcyA9ICZnZW10ZWtfZm9wczsKCWd0LT52ZGV2LmlvY3RsX29wcyA9ICZnZW10ZWtfaW9jdGxfb3BzOwoJZ3QtPnZkZXYucmVsZWFzZSA9IHZpZGVvX2RldmljZV9yZWxlYXNlX2VtcHR5OwoJdmlkZW9fc2V0X2RydmRhdGEoJmd0LT52ZGV2LCBndCk7CgoJLyogU2V0IGRlZmF1bHRzICovCglndC0+bGFzdGZyZXEgPSBHRU1URUtfTE9XRlJFUTsKCWd0LT5idTI2MTRkYXRhID0gMDsKCglpZiAoaW5pdG11dGUpCgkJZ2VtdGVrX211dGUoZ3QpOwoKCWlmICh2aWRlb19yZWdpc3Rlcl9kZXZpY2UoJmd0LT52ZGV2LCBWRkxfVFlQRV9SQURJTywgcmFkaW9fbnIpIDwgMCkgewoJCXY0bDJfZGV2aWNlX3VucmVnaXN0ZXIodjRsMl9kZXYpOwoJCXJlbGVhc2VfcmVnaW9uKGd0LT5pbywgMSk7CgkJcmV0dXJuIC1FQlVTWTsKCX0KCglyZXR1cm4gMDsKfQoKLyoKICogTW9kdWxlIGNsZWFudXAKICovCnN0YXRpYyB2b2lkIF9fZXhpdCBnZW10ZWtfZXhpdCh2b2lkKQp7CglzdHJ1Y3QgZ2VtdGVrICpndCA9ICZnZW10ZWtfY2FyZDsKCXN0cnVjdCB2NGwyX2RldmljZSAqdjRsMl9kZXYgPSAmZ3QtPnY0bDJfZGV2OwoKCWlmIChzaHV0ZG93bikgewoJCWhhcmRtdXRlID0gMTsJLyogVHVybiBvZmYgUExMICovCgkJZ2VtdGVrX211dGUoZ3QpOwoJfSBlbHNlIHsKCQl2NGwyX2luZm8odjRsMl9kZXYsICJNb2R1bGUgdW5sb2FkZWQgYnV0IGNhcmQgbm90IG11dGVkIVxuIik7Cgl9CgoJdmlkZW9fdW5yZWdpc3Rlcl9kZXZpY2UoJmd0LT52ZGV2KTsKCXY0bDJfZGV2aWNlX3VucmVnaXN0ZXIoJmd0LT52NGwyX2Rldik7CglyZWxlYXNlX3JlZ2lvbihndC0+aW8sIDEpOwp9Cgptb2R1bGVfaW5pdChnZW10ZWtfaW5pdCk7Cm1vZHVsZV9leGl0KGdlbXRla19leGl0KTsK