LyogR2VtVGVrIHJhZGlvIGNhcmQgZHJpdmVyIGZvciBMaW51eCAoQykgMTk5OCBKb25hcyBNdW5zaW4gPGptdW5zaW5AaWtpLmZpPgogKgogKiBHZW1UZWsgaGFzbid0IHJlbGVhc2VkIGFueSBzcGVjcyBvbiB0aGUgY2FyZCwgc28gdGhlIHByb3RvY29sIGhhZCB0bwogKiBiZSByZXZlcnNlIGVuZ2luZWVyZWQgd2l0aCBkb3NlbXUuCiAqCiAqIEJlc2lkZXMgdGhlIHByb3RvY29sIGNoYW5nZXMsIHRoaXMgaXMgbW9zdGx5IGEgY29weSBvZjoKICoKICogICAgUmFkaW9UcmFjayBJSSBkcml2ZXIgZm9yIExpbnV4IHJhZGlvIHN1cHBvcnQgKEMpIDE5OTggQmVuIFBmYWZmCiAqCiAqICAgIEJhc2VkIG9uIFJhZGlvVHJhY2sgSS9SYWRpb1JldmVhbCAoQykgMTk5NyBNLiBLaXJrd29vZAogKiAgICBDb252ZXJ0ZWQgdG8gbmV3IEFQSSBieSBBbGFuIENveCA8QWxhbi5Db3hAbGludXgub3JnPgogKiAgICBWYXJpb3VzIGJ1Z2ZpeGVzIGFuZCBlbmhhbmNlbWVudHMgYnkgUnVzc2VsbCBLcm9sbCA8cmtyb2xsQGV4cGxvaXRzLm9yZz4KICoKICogVE9ETzogQWxsb3cgZm9yIG1vcmUgdGhhbiBvbmUgb2YgdGhlc2UgZm9vbGlzaCBlbnRpdGllcyA6LSkKICoKICogQ29udmVydGVkIHRvIFY0TDIgQVBJIGJ5IE1hdXJvIENhcnZhbGhvIENoZWhhYiA8bWNoZWhhYkBpbmZyYWRlYWQub3JnPgogKi8KCiNpbmNsdWRlIDxsaW51eC9tb2R1bGUuaD4JLyogTW9kdWxlcyAJCQkqLwojaW5jbHVkZSA8bGludXgvaW5pdC5oPgkJLyogSW5pdGRhdGEJCQkqLwojaW5jbHVkZSA8bGludXgvaW9wb3J0Lmg+CS8qIHJlcXVlc3RfcmVnaW9uCQkqLwojaW5jbHVkZSA8bGludXgvZGVsYXkuaD4JLyogdWRlbGF5CQkJKi8KI2luY2x1ZGUgPGFzbS9pby5oPgkJLyogb3V0Yiwgb3V0Yl9wCQkJKi8KI2luY2x1ZGUgPGFzbS91YWNjZXNzLmg+CS8qIGNvcHkgdG8vZnJvbSB1c2VyCQkqLwojaW5jbHVkZSA8bGludXgvdmlkZW9kZXYyLmg+CS8qIGtlcm5lbCByYWRpbyBzdHJ1Y3RzCQkqLwojaW5jbHVkZSA8bWVkaWEvdjRsMi1jb21tb24uaD4KI2luY2x1ZGUgPGxpbnV4L3NwaW5sb2NrLmg+CgojaW5jbHVkZSA8bGludXgvdmVyc2lvbi5oPgkvKiBmb3IgS0VSTkVMX1ZFUlNJT04gTUFDUk8JKi8KI2RlZmluZSBSQURJT19WRVJTSU9OIEtFUk5FTF9WRVJTSU9OKDAsMCwzKQojZGVmaW5lIFJBRElPX0JBTk5FUiAiR2VtVGVrIFJhZGlvIGNhcmQgZHJpdmVyOiB2MC4wLjMiCgovKgogKiBNb2R1bGUgaW5mby4KICovCgpNT0RVTEVfQVVUSE9SKCJKb25hcyBNdW5zaW4sIFBla2thIFNlcHDkbmVuIDxwZXh1QGthcHNpLmZpPiIpOwpNT0RVTEVfREVTQ1JJUFRJT04oIkEgZHJpdmVyIGZvciB0aGUgR2VtVGVrIFJhZGlvIGNhcmQuIik7Ck1PRFVMRV9MSUNFTlNFKCJHUEwiKTsKCi8qCiAqIE1vZHVsZSBwYXJhbXMuCiAqLwoKI2lmbmRlZiBDT05GSUdfUkFESU9fR0VNVEVLX1BPUlQKI2RlZmluZSBDT05GSUdfUkFESU9fR0VNVEVLX1BPUlQgLTEKI2VuZGlmCiNpZm5kZWYgQ09ORklHX1JBRElPX0dFTVRFS19QUk9CRQojZGVmaW5lIENPTkZJR19SQURJT19HRU1URUtfUFJPQkUgMQojZW5kaWYKCnN0YXRpYyBpbnQgaW8JCT0gQ09ORklHX1JBRElPX0dFTVRFS19QT1JUOwpzdGF0aWMgaW50IHByb2JlCT0gQ09ORklHX1JBRElPX0dFTVRFS19QUk9CRTsKc3RhdGljIGludCBoYXJkbXV0ZTsKc3RhdGljIGludCBzaHV0ZG93bgk9IDE7CnN0YXRpYyBpbnQga2VlcG11dGVkCT0gMTsKc3RhdGljIGludCBpbml0bXV0ZQk9IDE7CnN0YXRpYyBpbnQgcmFkaW9fbnIJPSAtMTsKCm1vZHVsZV9wYXJhbShpbywgaW50LCAwNDQ0KTsKTU9EVUxFX1BBUk1fREVTQyhpbywgIkZvcmNlIEkvTyBwb3J0IGZvciB0aGUgR2VtVGVrIFJhZGlvIGNhcmQgaWYgYXV0b21hdGljIgoJICJwcm9iaW5nIGlzIGRpc2FibGVkIG9yIGZhaWxzLiBUaGUgbW9zdCBjb21tb24gSS9PIHBvcnRzIGFyZTogMHgyMGMgIgoJICIweDMwYywgMHgyNGMgb3IgMHgzNGMgKDB4MjBjLCAweDI0OCBhbmQgMHgyOGMgaGF2ZSBiZWVuIHJlcG9ydGVkIHRvICIKCSAiIHdvcmsgZm9yIHRoZSBjb21iaW5lZCBzb3VuZC9yYWRpb2NhcmQpLiIpOwoKbW9kdWxlX3BhcmFtKHByb2JlLCBib29sLCAwNDQ0KTsKTU9EVUxFX1BBUk1fREVTQyhwcm9iZSwgIkVuYWJsZSBhdXRvbWF0aWMgZGV2aWNlIHByb2JpbmcuIE5vdGU6IG9ubHkgdGhlIG1vc3QgIgoJImNvbW1vbiBJL08gcG9ydHMgdXNlZCBieSB0aGUgY2FyZCBhcmUgcHJvYmVkLiIpOwoKbW9kdWxlX3BhcmFtKGhhcmRtdXRlLCBib29sLCAwNjQ0KTsKTU9EVUxFX1BBUk1fREVTQyhoYXJkbXV0ZSwgIkVuYWJsZSBgaGFyZCBtdXRpbmcnIGJ5IHNodXR0aW5nIGRvd24gUExMLCBtYXkgIgoJICJyZWR1Y2Ugc3RhdGljIG5vaXNlLiIpOwoKbW9kdWxlX3BhcmFtKHNodXRkb3duLCBib29sLCAwNjQ0KTsKTU9EVUxFX1BBUk1fREVTQyhzaHV0ZG93biwgIkVuYWJsZSBzaHV0dGluZyBkb3duIFBMTCBhbmQgbXV0aW5nIGxpbmUgd2hlbiAiCgkgIm1vZHVsZSBpcyB1bmxvYWRlZC4iKTsKCm1vZHVsZV9wYXJhbShrZWVwbXV0ZWQsIGJvb2wsIDA2NDQpOwpNT0RVTEVfUEFSTV9ERVNDKGtlZXBtdXRlZCwgIktlZXAgY2FyZCBtdXRlZCBldmVuIHdoZW4gZnJlcXVlbmN5IGlzIGNoYW5nZWQuIik7Cgptb2R1bGVfcGFyYW0oaW5pdG11dGUsIGJvb2wsIDA0NDQpOwpNT0RVTEVfUEFSTV9ERVNDKGluaXRtdXRlLCAiTXV0ZSBjYXJkIHdoZW4gbW9kdWxlIGlzIGxvYWRlZC4iKTsKCm1vZHVsZV9wYXJhbShyYWRpb19uciwgaW50LCAwNDQ0KTsKCi8qCiAqIEZ1bmN0aW9ucyBmb3IgY29udHJvbGxpbmcgdGhlIGNhcmQuCiAqLwojZGVmaW5lIEdFTVRFS19MT1dGUkVRCSg4NyoxNjAwMCkKI2RlZmluZSBHRU1URUtfSElHSEZSRVEJKDEwOCoxNjAwMCkKCi8qCiAqIEZyZXF1ZW5jeSBjYWxjdWxhdGlvbiBjb25zdGFudHMuICBJbnRlcm1lZGlhdGUgZnJlcXVlbmN5IDEwLjUyIE1IeiAobm9taW5hbAogKiB2YWx1ZSAxMC43IE1IeiksIHJlZmVyZW5jZSBkaXZpc29yIDYuMzkga0h6IChub21pbmFsIDYuMjUga0h6KS4KICovCiNkZWZpbmUgRlNDQUxFCQk4CiNkZWZpbmUgSUZfT0ZGU0VUCSgodW5zaWduZWQgaW50KSgxMC41MiAqIDE2MDAwICogKDE8PEZTQ0FMRSkpKQojZGVmaW5lIFJFRl9GUkVRCSgodW5zaWduZWQgaW50KSg2LjM5ICogMTYgKiAoMTw8RlNDQUxFKSkpCgojZGVmaW5lIEdFTVRFS19DSwkJMHgwMQkvKiBDbG9jayBzaWduYWwJCQkqLwojZGVmaW5lIEdFTVRFS19EQQkJMHgwMgkvKiBTZXJpYWwgZGF0YQkJCSovCiNkZWZpbmUgR0VNVEVLX0NFCQkweDA0CS8qIENoaXAgZW5hYmxlCQkJKi8KI2RlZmluZSBHRU1URUtfTlMJCTB4MDgJLyogTm8gc2lnbmFsCQkJKi8KI2RlZmluZSBHRU1URUtfTVQJCTB4MTAJLyogTGluZSBtdXRlCQkJKi8KI2RlZmluZSBHRU1URUtfU1RERl8zXzEyNV9LSFoJMHgwMQkvKiBTdGFuZGFyZCBmcmVxdWVuY3kgMy4xMjUga0h6CSovCiNkZWZpbmUgR0VNVEVLX1BMTF9PRkYJCTB4MDcJLyogUExMIG9mZgkJCSovCgojZGVmaW5lIEJVMjYxNF9CVVNfU0laRQkzMgkvKiBCVTI2MTQgLyBCVTI2MTRGUyBidXMgc2l6ZQkJKi8KCiNkZWZpbmUgU0hPUlRfREVMQVkgNQkJLyogdXNlYyAqLwojZGVmaW5lIExPTkdfREVMQVkgNzUJCS8qIHVzZWMgKi8KCnN0cnVjdCBnZW10ZWtfZGV2aWNlIHsKCXVuc2lnbmVkIGxvbmcgbGFzdGZyZXE7CglpbnQgbXV0ZWQ7Cgl1MzIgYnUyNjE0ZGF0YTsKfTsKCiNkZWZpbmUgQlUyNjE0X0ZSRVFfQklUUyAJMTYgLyogRDAuLkQxNSwgRnJlcXVlbmN5IGRhdGEJCSovCiNkZWZpbmUgQlUyNjE0X1BPUlRfQklUUwkzIC8qIFAwLi5QMiwgT3V0cHV0IHBvcnQgY29udHJvbCBkYXRhCSovCiNkZWZpbmUgQlUyNjE0X1ZPSURfQklUUwk0IC8qIHVudXNlZCAJCQkJKi8KI2RlZmluZSBCVTI2MTRfRk1FU19CSVRTCTEgLyogQ1QsIEZyZXF1ZW5jeSBtZWFzdXJlbWVudCBiZWdpbm5pbmcgZGF0YSAqLwojZGVmaW5lIEJVMjYxNF9TVERGX0JJVFMJMyAvKiBSMC4uUjIsIFN0YW5kYXJkIGZyZXF1ZW5jeSBkYXRhCSovCiNkZWZpbmUgQlUyNjE0X1NXSU5fQklUUwkxIC8qIFMsIFN3aXRjaCBiZXR3ZWVuIEZNSU4gLyBBTUlOCSovCiNkZWZpbmUgQlUyNjE0X1NXQUxfQklUUyAgICAgICAgMSAvKiBQUywgU3dhbGxvdyBjb3VudGVyIGRpdmlzaW9uIChBTUlOIG9ubHkpKi8KI2RlZmluZSBCVTI2MTRfVk9JRDJfQklUUwkxIC8qIHVudXNlZAkJCQkqLwojZGVmaW5lIEJVMjYxNF9GTVVOX0JJVFMJMSAvKiBHVCwgRnJlcXVlbmN5IG1lYXN1cmVtZW50IHRpbWUgJiB1bmxvY2sgKi8KI2RlZmluZSBCVTI2MTRfVEVTVF9CSVRTCTEgLyogVFMsIFRlc3QgZGF0YSBpcyBpbnB1dAkJKi8KCiNkZWZpbmUgQlUyNjE0X0ZSRVFfU0hJRlQgCTAKI2RlZmluZSBCVTI2MTRfUE9SVF9TSElGVAkoQlUyNjE0X0ZSRVFfQklUUyArIEJVMjYxNF9GUkVRX1NISUZUKQojZGVmaW5lIEJVMjYxNF9WT0lEX1NISUZUCShCVTI2MTRfUE9SVF9CSVRTICsgQlUyNjE0X1BPUlRfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X0ZNRVNfU0hJRlQJKEJVMjYxNF9WT0lEX0JJVFMgKyBCVTI2MTRfVk9JRF9TSElGVCkKI2RlZmluZSBCVTI2MTRfU1RERl9TSElGVAkoQlUyNjE0X0ZNRVNfQklUUyArIEJVMjYxNF9GTUVTX1NISUZUKQojZGVmaW5lIEJVMjYxNF9TV0lOX1NISUZUCShCVTI2MTRfU1RERl9CSVRTICsgQlUyNjE0X1NUREZfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X1NXQUxfU0hJRlQJKEJVMjYxNF9TV0lOX0JJVFMgKyBCVTI2MTRfU1dJTl9TSElGVCkKI2RlZmluZSBCVTI2MTRfVk9JRDJfU0hJRlQJKEJVMjYxNF9TV0FMX0JJVFMgKyBCVTI2MTRfU1dBTF9TSElGVCkKI2RlZmluZSBCVTI2MTRfRk1VTl9TSElGVAkoQlUyNjE0X1ZPSUQyX0JJVFMgKyBCVTI2MTRfVk9JRDJfU0hJRlQpCiNkZWZpbmUgQlUyNjE0X1RFU1RfU0hJRlQJKEJVMjYxNF9GTVVOX0JJVFMgKyBCVTI2MTRfRk1VTl9TSElGVCkKCiNkZWZpbmUgTUtNQVNLKGZpZWxkKQkoKCgxPDxCVTI2MTRfIyNmaWVsZCMjX0JJVFMpIC0gMSkgPDwgXAoJCQlCVTI2MTRfIyNmaWVsZCMjX1NISUZUKQojZGVmaW5lIEJVMjYxNF9QT1JUX01BU0sJTUtNQVNLKFBPUlQpCiNkZWZpbmUgQlUyNjE0X0ZSRVFfTUFTSwlNS01BU0soRlJFUSkKI2RlZmluZSBCVTI2MTRfVk9JRF9NQVNLCU1LTUFTSyhWT0lEKQojZGVmaW5lIEJVMjYxNF9GTUVTX01BU0sJTUtNQVNLKEZNRVMpCiNkZWZpbmUgQlUyNjE0X1NUREZfTUFTSwlNS01BU0soU1RERikKI2RlZmluZSBCVTI2MTRfU1dJTl9NQVNLCU1LTUFTSyhTV0lOKQojZGVmaW5lIEJVMjYxNF9TV0FMX01BU0sJTUtNQVNLKFNXQUwpCiNkZWZpbmUgQlUyNjE0X1ZPSUQyX01BU0sJTUtNQVNLKFZPSUQyKQojZGVmaW5lIEJVMjYxNF9GTVVOX01BU0sJTUtNQVNLKEZNVU4pCiNkZWZpbmUgQlUyNjE0X1RFU1RfTUFTSwlNS01BU0soVEVTVCkKCnN0YXRpYyBzdHJ1Y3QgZ2VtdGVrX2RldmljZSBnZW10ZWtfdW5pdDsKCnN0YXRpYyBzcGlubG9ja190IGxvY2s7CgovKgogKiBTZXQgZGF0YSB3aGljaCB3aWxsIGJlIHNlbnQgdG8gQlUyNjE0RlMuCiAqLwojZGVmaW5lIGdlbXRla19idTI2MTRfc2V0KGRldiwgZmllbGQsIGRhdGEpICgoZGV2KS0+YnUyNjE0ZGF0YSA9IFwKCSgoZGV2KS0+YnUyNjE0ZGF0YSAmIH5maWVsZCMjX01BU0spIHwgKChkYXRhKSA8PCBmaWVsZCMjX1NISUZUKSkKCi8qCiAqIFRyYW5zbWl0IHNldHRpbmdzIHRvIEJVMjYxNEZTIG92ZXIgR2VtVGVrIElDLgogKi8Kc3RhdGljIHZvaWQgZ2VtdGVrX2J1MjYxNF90cmFuc21pdChzdHJ1Y3QgZ2VtdGVrX2RldmljZSAqZGV2KQp7CglpbnQgaSwgYml0LCBxLCBtdXRlOwoKCXNwaW5fbG9jaygmbG9jayk7CgoJbXV0ZSA9IGRldi0+bXV0ZWQgPyBHRU1URUtfTVQgOiAweDAwOwoKCW91dGJfcChtdXRlIHwgR0VNVEVLX0RBIHwgR0VNVEVLX0NLLCBpbyk7Cgl1ZGVsYXkoU0hPUlRfREVMQVkpOwoJb3V0Yl9wKG11dGUgfCBHRU1URUtfQ0UgfCBHRU1URUtfREEgfCBHRU1URUtfQ0ssIGlvKTsKCXVkZWxheShMT05HX0RFTEFZKTsKCglmb3IgKGkgPSAwLCBxID0gZGV2LT5idTI2MTRkYXRhOyBpIDwgMzI7IGkrKywgcSA+Pj0gMSkgewoJICAgIGJpdCA9IChxICYgMSkgPyBHRU1URUtfREEgOiAwOwoJICAgIG91dGJfcChtdXRlIHwgR0VNVEVLX0NFIHwgYml0LCBpbyk7CgkgICAgdWRlbGF5KFNIT1JUX0RFTEFZKTsKCSAgICBvdXRiX3AobXV0ZSB8IEdFTVRFS19DRSB8IGJpdCB8IEdFTVRFS19DSywgaW8pOwoJICAgIHVkZWxheShTSE9SVF9ERUxBWSk7Cgl9CgoJb3V0Yl9wKG11dGUgfCBHRU1URUtfREEgfCBHRU1URUtfQ0ssIGlvKTsKCXVkZWxheShTSE9SVF9ERUxBWSk7CglvdXRiX3AobXV0ZSB8IEdFTVRFS19DRSB8IEdFTVRFS19EQSB8IEdFTVRFS19DSywgaW8pOwoJdWRlbGF5KExPTkdfREVMQVkpOwoKCXNwaW5fdW5sb2NrKCZsb2NrKTsKfQoKLyoKICogQ2FsY3VsYXRlIGRpdmlzb3IgZnJvbSBGTS1mcmVxdWVuY3kgZm9yIEJVMjYxNEZTICgzLjEyNSBLSHogU1RERiBleHBlY3RlZCkuCiAqLwpzdGF0aWMgdW5zaWduZWQgbG9uZyBnZW10ZWtfY29udmZyZXEodW5zaWduZWQgbG9uZyBmcmVxKQp7CglyZXR1cm4gKChmcmVxPDxGU0NBTEUpICsgSUZfT0ZGU0VUICsgUkVGX0ZSRVEvMikgLyBSRUZfRlJFUTsKfQoKLyoKICogU2V0IEZNLWZyZXF1ZW5jeS4KICovCnN0YXRpYyB2b2lkIGdlbXRla19zZXRmcmVxKHN0cnVjdCBnZW10ZWtfZGV2aWNlICpkZXYsIHVuc2lnbmVkIGxvbmcgZnJlcSkKewoKCWlmIChrZWVwbXV0ZWQgJiYgaGFyZG11dGUgJiYgZGV2LT5tdXRlZCkKCQlyZXR1cm47CgoJaWYgKGZyZXEgPCBHRU1URUtfTE9XRlJFUSkKCQlmcmVxID0gR0VNVEVLX0xPV0ZSRVE7CgllbHNlIGlmIChmcmVxID4gR0VNVEVLX0hJR0hGUkVRKQoJCWZyZXEgPSBHRU1URUtfSElHSEZSRVE7CgoJZGV2LT5sYXN0ZnJlcSA9IGZyZXE7CglkZXYtPm11dGVkID0gMDsKCglnZW10ZWtfYnUyNjE0X3NldChkZXYsIEJVMjYxNF9QT1JULCAwKTsKCWdlbXRla19idTI2MTRfc2V0KGRldiwgQlUyNjE0X0ZNRVMsIDApOwoJZ2VtdGVrX2J1MjYxNF9zZXQoZGV2LCBCVTI2MTRfU1dJTiwgMCk7CS8qIEZNLW1vZGUJKi8KCWdlbXRla19idTI2MTRfc2V0KGRldiwgQlUyNjE0X1NXQUwsIDApOwoJZ2VtdGVrX2J1MjYxNF9zZXQoZGV2LCBCVTI2MTRfRk1VTiwgMSk7CS8qIEdUIGJpdCBzZXQJKi8KCWdlbXRla19idTI2MTRfc2V0KGRldiwgQlUyNjE0X1RFU1QsIDApOwoKCWdlbXRla19idTI2MTRfc2V0KGRldiwgQlUyNjE0X1NUREYsIEdFTVRFS19TVERGXzNfMTI1X0tIWik7CglnZW10ZWtfYnUyNjE0X3NldChkZXYsIEJVMjYxNF9GUkVRLCBnZW10ZWtfY29udmZyZXEoZnJlcSkpOwoKCWdlbXRla19idTI2MTRfdHJhbnNtaXQoZGV2KTsKfQoKLyoKICogU2V0IG11dGUgZmxhZy4KICovCnN0YXRpYyB2b2lkIGdlbXRla19tdXRlKHN0cnVjdCBnZW10ZWtfZGV2aWNlICpkZXYpCnsKCWludCBpOwoJZGV2LT5tdXRlZCA9IDE7CgoJaWYgKGhhcmRtdXRlKSB7CgkJLyogVHVybiBvZmYgUExMLCBkaXNhYmxlIGRhdGEgb3V0cHV0ICovCgkJZ2VtdGVrX2J1MjYxNF9zZXQoZGV2LCBCVTI2MTRfUE9SVCwgMCk7CgkJZ2VtdGVrX2J1MjYxNF9zZXQoZGV2LCBCVTI2MTRfRk1FUywgMCk7CS8qIENUIGJpdCBvZmYJKi8KCQlnZW10ZWtfYnUyNjE0X3NldChkZXYsIEJVMjYxNF9TV0lOLCAwKTsJLyogRk0tbW9kZQkqLwoJCWdlbXRla19idTI2MTRfc2V0KGRldiwgQlUyNjE0X1NXQUwsIDApOwoJCWdlbXRla19idTI2MTRfc2V0KGRldiwgQlUyNjE0X0ZNVU4sIDApOwkvKiBHVCBiaXQgb2ZmCSovCgkJZ2VtdGVrX2J1MjYxNF9zZXQoZGV2LCBCVTI2MTRfVEVTVCwgMCk7CgkJZ2VtdGVrX2J1MjYxNF9zZXQoZGV2LCBCVTI2MTRfU1RERiwgR0VNVEVLX1BMTF9PRkYpOwoJCWdlbXRla19idTI2MTRfc2V0KGRldiwgQlUyNjE0X0ZSRVEsIDApOwoJCWdlbXRla19idTI2MTRfdHJhbnNtaXQoZGV2KTsKCX0gZWxzZSB7CgkJc3Bpbl9sb2NrKCZsb2NrKTsKCgkJLyogUmVhZCBidXMgY29udGVudHMgKENFLCBDSyBhbmQgREEpLiAqLwoJCWkgPSBpbmJfcChpbyk7CgkJLyogV3JpdGUgaXQgYmFjayB3aXRoIG11dGUgZmxhZyBzZXQuICovCgkJb3V0Yl9wKChpID4+IDUpIHwgR0VNVEVLX01ULCBpbyk7CgkJdWRlbGF5KFNIT1JUX0RFTEFZKTsKCgkJc3Bpbl91bmxvY2soJmxvY2spOwoJfQp9CgovKgogKiBVbnNldCBtdXRlIGZsYWcuCiAqLwpzdGF0aWMgdm9pZCBnZW10ZWtfdW5tdXRlKHN0cnVjdCBnZW10ZWtfZGV2aWNlICpkZXYpCnsKCWludCBpOwoJZGV2LT5tdXRlZCA9IDA7CgoJaWYgKGhhcmRtdXRlKSB7CgkJLyogVHVybiBQTEwgYmFjayBvbi4gKi8KCQlnZW10ZWtfc2V0ZnJlcShkZXYsIGRldi0+bGFzdGZyZXEpOwoJfSBlbHNlIHsKCQlzcGluX2xvY2soJmxvY2spOwoKCQlpID0gaW5iX3AoaW8pOwoJCW91dGJfcChpID4+IDUsIGlvKTsKCQl1ZGVsYXkoU0hPUlRfREVMQVkpOwoKCQlzcGluX3VubG9jaygmbG9jayk7Cgl9Cn0KCi8qCiAqIEdldCBzaWduYWwgc3RyZW5ndGggKD0gc3RlcmVvIHN0YXR1cykuCiAqLwpzdGF0aWMgaW5saW5lIGludCBnZW10ZWtfZ2V0c2lnc3RyKHZvaWQpCnsKCXJldHVybiBpbmJfcChpbykgJiBHRU1URUtfTlMgPyAwIDogMTsKfQoKLyoKICogQ2hlY2sgaWYgcmVxdWVzdGVkIGNhcmQgYWN0cyBsaWtlIEdlbVRlayBSYWRpbyBjYXJkLgogKi8Kc3RhdGljIGludCBnZW10ZWtfdmVyaWZ5KGludCBwb3J0KQp7CglzdGF0aWMgaW50IHZlcmlmaWVkID0gLTE7CglpbnQgaSwgcTsKCglpZiAodmVyaWZpZWQgPT0gcG9ydCkKCQlyZXR1cm4gMTsKCglzcGluX2xvY2soJmxvY2spOwoKCXEgPSBpbmJfcChwb3J0KTsJLyogUmVhZCBidXMgY29udGVudHMgYmVmb3JlIHByb2JpbmcuICovCgkvKiBUcnkgdG8gdHVybiBvbiBDRSwgQ0sgYW5kIERBIHJlc3BlY3RpdmVseSBhbmQgY2hlY2sgaWYgY2FyZCByZXNwb25kcwoJICAgcHJvcGVybHkuICovCglmb3IgKGkgPSAwOyBpIDwgMzsgKytpKSB7CgkJb3V0Yl9wKDEgPDwgaSwgcG9ydCk7CgkJdWRlbGF5KFNIT1JUX0RFTEFZKTsKCgkJaWYgKChpbmJfcChwb3J0KSAmICh+R0VNVEVLX05TKSkgIT0gKDB4MTcgfCAoMSA8PCAoaSArIDUpKSkpIHsKCQkJc3Bpbl91bmxvY2soJmxvY2spOwoJCQlyZXR1cm4gMDsKCQl9Cgl9CglvdXRiX3AocSA+PiA1LCBwb3J0KTsJLyogV3JpdGUgYnVzIGNvbnRlbnRzIGJhY2suICovCgl1ZGVsYXkoU0hPUlRfREVMQVkpOwoKCXNwaW5fdW5sb2NrKCZsb2NrKTsKCXZlcmlmaWVkID0gcG9ydDsKCglyZXR1cm4gMTsKfQoKLyoKICogQXV0b21hdGljIHByb2JpbmcgZm9yIGNhcmQuCiAqLwpzdGF0aWMgaW50IGdlbXRla19wcm9iZSh2b2lkKQp7CglpbnQgaW9wb3J0c1tdID0geyAweDIwYywgMHgzMGMsIDB4MjRjLCAweDM0YywgMHgyNDgsIDB4MjhjIH07CglpbnQgaTsKCglpZiAoIXByb2JlKSB7CgkJcHJpbnRrKEtFUk5fSU5GTyAiQXV0b21hdGljIGRldmljZSBwcm9iaW5nIGRpc2FibGVkLlxuIik7CgkJcmV0dXJuIC0xOwoJfQoKCXByaW50ayhLRVJOX0lORk8gIkF1dG9tYXRpYyBkZXZpY2UgcHJvYmluZyBlbmFibGVkLlxuIik7CgoJZm9yIChpID0gMDsgaSA8IEFSUkFZX1NJWkUoaW9wb3J0cyk7ICsraSkgewoJCXByaW50ayhLRVJOX0lORk8gIlRyeWluZyBJL08gcG9ydCAweCV4Li4uXG4iLCBpb3BvcnRzW2ldKTsKCgkJaWYgKCFyZXF1ZXN0X3JlZ2lvbihpb3BvcnRzW2ldLCAxLCAiZ2VtdGVrLXByb2JlIikpIHsKCQkJcHJpbnRrKEtFUk5fV0FSTklORyAiSS9PIHBvcnQgMHgleCBidXN5IVxuIiwKCQkJICAgICAgIGlvcG9ydHNbaV0pOwoJCQljb250aW51ZTsKCQl9CgoJCWlmIChnZW10ZWtfdmVyaWZ5KGlvcG9ydHNbaV0pKSB7CgkJCXByaW50ayhLRVJOX0lORk8gIkNhcmQgZm91bmQgZnJvbSBJL08gcG9ydCAiCgkJCSAgICAgICAiMHgleCFcbiIsIGlvcG9ydHNbaV0pOwoKCQkJcmVsZWFzZV9yZWdpb24oaW9wb3J0c1tpXSwgMSk7CgoJCQlpbyA9IGlvcG9ydHNbaV07CgkJCXJldHVybiBpbzsKCQl9CgoJCXJlbGVhc2VfcmVnaW9uKGlvcG9ydHNbaV0sIDEpOwoJfQoKCXByaW50ayhLRVJOX0VSUiAiQXV0b21hdGljIHByb2JpbmcgZmFpbGVkIVxuIik7CgoJcmV0dXJuIC0xOwp9CgovKgogKiBWaWRlbyA0IExpbnV4IHN0dWZmLgogKi8KCnN0YXRpYyBzdHJ1Y3QgdjRsMl9xdWVyeWN0cmwgcmFkaW9fcWN0cmxbXSA9IHsKCXsKCQkuaWQgPSBWNEwyX0NJRF9BVURJT19NVVRFLAoJCS5uYW1lID0gIk11dGUiLAoJCS5taW5pbXVtID0gMCwKCQkubWF4aW11bSA9IDEsCgkJLmRlZmF1bHRfdmFsdWUgPSAxLAoJCS50eXBlID0gVjRMMl9DVFJMX1RZUEVfQk9PTEVBTiwKCX0sIHsKCQkuaWQgPSBWNEwyX0NJRF9BVURJT19WT0xVTUUsCgkJLm5hbWUgPSAiVm9sdW1lIiwKCQkubWluaW11bSA9IDAsCgkJLm1heGltdW0gPSA2NTUzNSwKCQkuc3RlcCA9IDY1NTM1LAoJCS5kZWZhdWx0X3ZhbHVlID0gMHhmZiwKCQkudHlwZSA9IFY0TDJfQ1RSTF9UWVBFX0lOVEVHRVIsCgl9Cn07CgpzdGF0aWMgc3RydWN0IGZpbGVfb3BlcmF0aW9ucyBnZW10ZWtfZm9wcyA9IHsKCS5vd25lcgkJPSBUSElTX01PRFVMRSwKCS5vcGVuCQk9IHZpZGVvX2V4Y2x1c2l2ZV9vcGVuLAoJLnJlbGVhc2UJPSB2aWRlb19leGNsdXNpdmVfcmVsZWFzZSwKCS5pb2N0bAkJPSB2aWRlb19pb2N0bDIsCgkuY29tcGF0X2lvY3RsCT0gdjRsX2NvbXBhdF9pb2N0bDMyLAoJLmxsc2VlawkJPSBub19sbHNlZWsKfTsKCnN0YXRpYyBpbnQgdmlkaW9jX3F1ZXJ5Y2FwKHN0cnVjdCBmaWxlICpmaWxlLCB2b2lkICpwcml2LAoJCQkgICBzdHJ1Y3QgdjRsMl9jYXBhYmlsaXR5ICp2KQp7CglzdHJsY3B5KHYtPmRyaXZlciwgInJhZGlvLWdlbXRlayIsIHNpemVvZih2LT5kcml2ZXIpKTsKCXN0cmxjcHkodi0+Y2FyZCwgIkdlbVRlayIsIHNpemVvZih2LT5jYXJkKSk7CglzcHJpbnRmKHYtPmJ1c19pbmZvLCAiSVNBIik7Cgl2LT52ZXJzaW9uID0gUkFESU9fVkVSU0lPTjsKCXYtPmNhcGFiaWxpdGllcyA9IFY0TDJfQ0FQX1RVTkVSOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX2dfdHVuZXIoc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsIHN0cnVjdCB2NGwyX3R1bmVyICp2KQp7CglpZiAodi0+aW5kZXggPiAwKQoJCXJldHVybiAtRUlOVkFMOwoKCXN0cmNweSh2LT5uYW1lLCAiRk0iKTsKCXYtPnR5cGUgPSBWNEwyX1RVTkVSX1JBRElPOwoJdi0+cmFuZ2Vsb3cgPSBHRU1URUtfTE9XRlJFUTsKCXYtPnJhbmdlaGlnaCA9IEdFTVRFS19ISUdIRlJFUTsKCXYtPmNhcGFiaWxpdHkgPSBWNEwyX1RVTkVSX0NBUF9MT1cgfCBWNEwyX1RVTkVSX0NBUF9TVEVSRU87Cgl2LT5zaWduYWwgPSAweGZmZmYgKiBnZW10ZWtfZ2V0c2lnc3RyKCk7CglpZiAodi0+c2lnbmFsKSB7CgkJdi0+YXVkbW9kZSA9IFY0TDJfVFVORVJfTU9ERV9TVEVSRU87CgkJdi0+cnhzdWJjaGFucyA9IFY0TDJfVFVORVJfU1VCX1NURVJFTzsKCX0gZWxzZSB7CgkJdi0+YXVkbW9kZSA9IFY0TDJfVFVORVJfTU9ERV9NT05POwoJCXYtPnJ4c3ViY2hhbnMgPSBWNEwyX1RVTkVSX1NVQl9NT05POwoJfQoKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IHZpZGlvY19zX3R1bmVyKHN0cnVjdCBmaWxlICpmaWxlLCB2b2lkICpwcml2LCBzdHJ1Y3QgdjRsMl90dW5lciAqdikKewoJaWYgKHYtPmluZGV4ID4gMCkKCQlyZXR1cm4gLUVJTlZBTDsKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IHZpZGlvY19zX2ZyZXF1ZW5jeShzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwKCQkJICAgICAgc3RydWN0IHY0bDJfZnJlcXVlbmN5ICpmKQp7CglzdHJ1Y3QgdmlkZW9fZGV2aWNlICpkZXYgPSB2aWRlb19kZXZkYXRhKGZpbGUpOwoJc3RydWN0IGdlbXRla19kZXZpY2UgKnJ0ID0gZGV2LT5wcml2OwoKCWdlbXRla19zZXRmcmVxKHJ0LCBmLT5mcmVxdWVuY3kpOwoKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IHZpZGlvY19nX2ZyZXF1ZW5jeShzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwKCQkJICAgICAgc3RydWN0IHY0bDJfZnJlcXVlbmN5ICpmKQp7CglzdHJ1Y3QgdmlkZW9fZGV2aWNlICpkZXYgPSB2aWRlb19kZXZkYXRhKGZpbGUpOwoJc3RydWN0IGdlbXRla19kZXZpY2UgKnJ0ID0gZGV2LT5wcml2OwoKCWYtPnR5cGUgPSBWNEwyX1RVTkVSX1JBRElPOwoJZi0+ZnJlcXVlbmN5ID0gcnQtPmxhc3RmcmVxOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX3F1ZXJ5Y3RybChzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwKCQkJICAgIHN0cnVjdCB2NGwyX3F1ZXJ5Y3RybCAqcWMpCnsKCWludCBpOwoKCWZvciAoaSA9IDA7IGkgPCBBUlJBWV9TSVpFKHJhZGlvX3FjdHJsKTsgKytpKSB7CgkJaWYgKHFjLT5pZCAmJiBxYy0+aWQgPT0gcmFkaW9fcWN0cmxbaV0uaWQpIHsKCQkJbWVtY3B5KHFjLCAmKHJhZGlvX3FjdHJsW2ldKSwgc2l6ZW9mKCpxYykpOwoJCQlyZXR1cm4gMDsKCQl9Cgl9CglyZXR1cm4gLUVJTlZBTDsKfQoKc3RhdGljIGludCB2aWRpb2NfZ19jdHJsKHN0cnVjdCBmaWxlICpmaWxlLCB2b2lkICpwcml2LAoJCQkgc3RydWN0IHY0bDJfY29udHJvbCAqY3RybCkKewoJc3RydWN0IHZpZGVvX2RldmljZSAqZGV2ID0gdmlkZW9fZGV2ZGF0YShmaWxlKTsKCXN0cnVjdCBnZW10ZWtfZGV2aWNlICpydCA9IGRldi0+cHJpdjsKCglzd2l0Y2ggKGN0cmwtPmlkKSB7CgljYXNlIFY0TDJfQ0lEX0FVRElPX01VVEU6CgkJY3RybC0+dmFsdWUgPSBydC0+bXV0ZWQ7CgkJcmV0dXJuIDA7CgljYXNlIFY0TDJfQ0lEX0FVRElPX1ZPTFVNRToKCQlpZiAocnQtPm11dGVkKQoJCQljdHJsLT52YWx1ZSA9IDA7CgkJZWxzZQoJCQljdHJsLT52YWx1ZSA9IDY1NTM1OwoJCXJldHVybiAwOwoJfQoJcmV0dXJuIC1FSU5WQUw7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX3NfY3RybChzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwKCQkJIHN0cnVjdCB2NGwyX2NvbnRyb2wgKmN0cmwpCnsKCXN0cnVjdCB2aWRlb19kZXZpY2UgKmRldiA9IHZpZGVvX2RldmRhdGEoZmlsZSk7CglzdHJ1Y3QgZ2VtdGVrX2RldmljZSAqcnQgPSBkZXYtPnByaXY7CgoJc3dpdGNoIChjdHJsLT5pZCkgewoJY2FzZSBWNEwyX0NJRF9BVURJT19NVVRFOgoJCWlmIChjdHJsLT52YWx1ZSkKCQkJZ2VtdGVrX211dGUocnQpOwoJCWVsc2UKCQkJZ2VtdGVrX3VubXV0ZShydCk7CgkJcmV0dXJuIDA7CgljYXNlIFY0TDJfQ0lEX0FVRElPX1ZPTFVNRToKCQlpZiAoY3RybC0+dmFsdWUpCgkJCWdlbXRla191bm11dGUocnQpOwoJCWVsc2UKCQkJZ2VtdGVrX211dGUocnQpOwoJCXJldHVybiAwOwoJfQoJcmV0dXJuIC1FSU5WQUw7Cn0KCnN0YXRpYyBpbnQgdmlkaW9jX2dfYXVkaW8oc3RydWN0IGZpbGUgKmZpbGUsIHZvaWQgKnByaXYsIHN0cnVjdCB2NGwyX2F1ZGlvICphKQp7CglpZiAoYS0+aW5kZXggPiAxKQoJCXJldHVybiAtRUlOVkFMOwoKCXN0cmNweShhLT5uYW1lLCAiUmFkaW8iKTsKCWEtPmNhcGFiaWxpdHkgPSBWNEwyX0FVRENBUF9TVEVSRU87CglyZXR1cm4gMDsKfQoKc3RhdGljIGludCB2aWRpb2NfZ19pbnB1dChzdHJ1Y3QgZmlsZSAqZmlscCwgdm9pZCAqcHJpdiwgdW5zaWduZWQgaW50ICppKQp7CgkqaSA9IDA7CglyZXR1cm4gMDsKfQoKc3RhdGljIGludCB2aWRpb2Nfc19pbnB1dChzdHJ1Y3QgZmlsZSAqZmlscCwgdm9pZCAqcHJpdiwgdW5zaWduZWQgaW50IGkpCnsKCWlmIChpICE9IDApCgkJcmV0dXJuIC1FSU5WQUw7CglyZXR1cm4gMDsKfQoKc3RhdGljIGludCB2aWRpb2Nfc19hdWRpbyhzdHJ1Y3QgZmlsZSAqZmlsZSwgdm9pZCAqcHJpdiwgc3RydWN0IHY0bDJfYXVkaW8gKmEpCnsKCWlmIChhLT5pbmRleCAhPSAwKQoJCXJldHVybiAtRUlOVkFMOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBzdHJ1Y3QgdmlkZW9fZGV2aWNlIGdlbXRla19yYWRpbyA9IHsKCS5vd25lcgkJCT0gVEhJU19NT0RVTEUsCgkubmFtZQkJCT0gIkdlbVRlayBSYWRpbyBjYXJkIiwKCS50eXBlCQkJPSBWSURfVFlQRV9UVU5FUiwKCS5oYXJkd2FyZQkJPSBWSURfSEFSRFdBUkVfR0VNVEVLLAoJLmZvcHMJCQk9ICZnZW10ZWtfZm9wcywKCS52aWRpb2NfcXVlcnljYXAJPSB2aWRpb2NfcXVlcnljYXAsCgkudmlkaW9jX2dfdHVuZXIJCT0gdmlkaW9jX2dfdHVuZXIsCgkudmlkaW9jX3NfdHVuZXIJCT0gdmlkaW9jX3NfdHVuZXIsCgkudmlkaW9jX2dfYXVkaW8JCT0gdmlkaW9jX2dfYXVkaW8sCgkudmlkaW9jX3NfYXVkaW8JCT0gdmlkaW9jX3NfYXVkaW8sCgkudmlkaW9jX2dfaW5wdXQJCT0gdmlkaW9jX2dfaW5wdXQsCgkudmlkaW9jX3NfaW5wdXQJCT0gdmlkaW9jX3NfaW5wdXQsCgkudmlkaW9jX2dfZnJlcXVlbmN5CT0gdmlkaW9jX2dfZnJlcXVlbmN5LAoJLnZpZGlvY19zX2ZyZXF1ZW5jeQk9IHZpZGlvY19zX2ZyZXF1ZW5jeSwKCS52aWRpb2NfcXVlcnljdHJsCT0gdmlkaW9jX3F1ZXJ5Y3RybCwKCS52aWRpb2NfZ19jdHJsCQk9IHZpZGlvY19nX2N0cmwsCgkudmlkaW9jX3NfY3RybAkJPSB2aWRpb2Nfc19jdHJsCn07CgovKgogKiBJbml0aWFsaXphdGlvbiAvIGNsZWFudXAgcmVsYXRlZCBzdHVmZi4KICovCgovKgogKiBJbml0aWxpemUgY2FyZC4KICovCnN0YXRpYyBpbnQgX19pbml0IGdlbXRla19pbml0KHZvaWQpCnsKCXByaW50ayhLRVJOX0lORk8gUkFESU9fQkFOTkVSICJcbiIpOwoKCXNwaW5fbG9ja19pbml0KCZsb2NrKTsKCglnZW10ZWtfcHJvYmUoKTsKCWlmIChpbykgewoJCWlmICghcmVxdWVzdF9yZWdpb24oaW8sIDEsICJnZW10ZWsiKSkgewoJCQlwcmludGsoS0VSTl9FUlIgIkkvTyBwb3J0IDB4JXggYWxyZWFkeSBpbiB1c2UuXG4iLCBpbyk7CgkJCXJldHVybiAtRUJVU1k7CgkJfQoKCQlpZiAoIWdlbXRla192ZXJpZnkoaW8pKQoJCQlwcmludGsoS0VSTl9XQVJOSU5HICJDYXJkIGF0IEkvTyBwb3J0IDB4JXggZG9lcyBub3QgIgoJCQkgICAgICAgInJlc3BvbmQgcHJvcGVybHksIGNoZWNrIHlvdXIgIgoJCQkgICAgICAgImNvbmZpZ3VyYXRpb24uXG4iLCBpbyk7CgkJZWxzZQoJCQlwcmludGsoS0VSTl9JTkZPICJVc2luZyBJL08gcG9ydCAweCV4LlxuIiwgaW8pOwoJfSBlbHNlIGlmIChwcm9iZSkgewoJCXByaW50ayhLRVJOX0VSUiAiQXV0b21hdGljIHByb2JpbmcgZmFpbGVkIGFuZCBubyAiCgkJICAgICAgICJmaXhlZCBJL08gcG9ydCBkZWZpbmVkLlxuIik7CgkJcmV0dXJuIC1FTk9ERVY7Cgl9IGVsc2UgewoJCXByaW50ayhLRVJOX0VSUiAiQXV0b21hdGljIHByb2JpbmcgZGlzYWJsZWQgYnV0IG5vIGZpeGVkICIKCQkgICAgICAgIkkvTyBwb3J0IGRlZmluZWQuIik7CgkJcmV0dXJuIC1FSU5WQUw7Cgl9CgoJZ2VtdGVrX3JhZGlvLnByaXYgPSAmZ2VtdGVrX3VuaXQ7CgoJaWYgKHZpZGVvX3JlZ2lzdGVyX2RldmljZSgmZ2VtdGVrX3JhZGlvLCBWRkxfVFlQRV9SQURJTywKCQlyYWRpb19ucikgPT0gLTEpIHsKCQlyZWxlYXNlX3JlZ2lvbihpbywgMSk7CgkJcmV0dXJuIC1FQlVTWTsKCX0KCgkvKiBTZXQgZGVmYXVsdHMgKi8KCWdlbXRla191bml0Lmxhc3RmcmVxID0gR0VNVEVLX0xPV0ZSRVE7CglnZW10ZWtfdW5pdC5idTI2MTRkYXRhID0gMDsKCglpZiAoaW5pdG11dGUpCgkJZ2VtdGVrX211dGUoJmdlbXRla191bml0KTsKCglyZXR1cm4gMDsKfQoKLyoKICogTW9kdWxlIGNsZWFudXAKICovCnN0YXRpYyB2b2lkIF9fZXhpdCBnZW10ZWtfZXhpdCh2b2lkKQp7CglpZiAoc2h1dGRvd24pIHsKCQloYXJkbXV0ZSA9IDE7CS8qIFR1cm4gb2ZmIFBMTCAqLwoJCWdlbXRla19tdXRlKCZnZW10ZWtfdW5pdCk7Cgl9IGVsc2UgewoJCXByaW50ayhLRVJOX0lORk8gIk1vZHVsZSB1bmxvYWRlZCBidXQgY2FyZCBub3QgbXV0ZWQhXG4iKTsKCX0KCgl2aWRlb191bnJlZ2lzdGVyX2RldmljZSgmZ2VtdGVrX3JhZGlvKTsKCXJlbGVhc2VfcmVnaW9uKGlvLCAxKTsKfQoKbW9kdWxlX2luaXQoZ2VtdGVrX2luaXQpOwptb2R1bGVfZXhpdChnZW10ZWtfZXhpdCk7Cg==