LyoKICogQ29weXJpZ2h0IKkgMjAwNiBJbnRlbCBDb3Jwb3JhdGlvbgogKgogKiBQZXJtaXNzaW9uIGlzIGhlcmVieSBncmFudGVkLCBmcmVlIG9mIGNoYXJnZSwgdG8gYW55IHBlcnNvbiBvYnRhaW5pbmcgYQogKiBjb3B5IG9mIHRoaXMgc29mdHdhcmUgYW5kIGFzc29jaWF0ZWQgZG9jdW1lbnRhdGlvbiBmaWxlcyAodGhlICJTb2Z0d2FyZSIpLAogKiB0byBkZWFsIGluIHRoZSBTb2Z0d2FyZSB3aXRob3V0IHJlc3RyaWN0aW9uLCBpbmNsdWRpbmcgd2l0aG91dCBsaW1pdGF0aW9uCiAqIHRoZSByaWdodHMgdG8gdXNlLCBjb3B5LCBtb2RpZnksIG1lcmdlLCBwdWJsaXNoLCBkaXN0cmlidXRlLCBzdWJsaWNlbnNlLAogKiBhbmQvb3Igc2VsbCBjb3BpZXMgb2YgdGhlIFNvZnR3YXJlLCBhbmQgdG8gcGVybWl0IHBlcnNvbnMgdG8gd2hvbSB0aGUKICogU29mdHdhcmUgaXMgZnVybmlzaGVkIHRvIGRvIHNvLCBzdWJqZWN0IHRvIHRoZSBmb2xsb3dpbmcgY29uZGl0aW9uczoKICoKICogVGhlIGFib3ZlIGNvcHlyaWdodCBub3RpY2UgYW5kIHRoaXMgcGVybWlzc2lvbiBub3RpY2UgKGluY2x1ZGluZyB0aGUgbmV4dAogKiBwYXJhZ3JhcGgpIHNoYWxsIGJlIGluY2x1ZGVkIGluIGFsbCBjb3BpZXMgb3Igc3Vic3RhbnRpYWwgcG9ydGlvbnMgb2YgdGhlCiAqIFNvZnR3YXJlLgogKgogKiBUSEUgU09GVFdBUkUgSVMgUFJPVklERUQgIkFTIElTIiwgV0lUSE9VVCBXQVJSQU5UWSBPRiBBTlkgS0lORCwgRVhQUkVTUyBPUgogKiBJTVBMSUVELCBJTkNMVURJTkcgQlVUIE5PVCBMSU1JVEVEIFRPIFRIRSBXQVJSQU5USUVTIE9GIE1FUkNIQU5UQUJJTElUWSwKICogRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UgQU5EIE5PTklORlJJTkdFTUVOVC4gIElOIE5PIEVWRU5UIFNIQUxMCiAqIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSCiAqIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sCiAqIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4gVEhFCiAqIFNPRlRXQVJFLgogKgogKiBBdXRob3JzOgogKiAgICBFcmljIEFuaG9sdCA8ZXJpY0BhbmhvbHQubmV0PgogKgogKi8KCiNpZm5kZWYgX0k4MzBfQklPU19IXwojZGVmaW5lIF9JODMwX0JJT1NfSF8KCiNpbmNsdWRlICJkcm1QLmgiCgpzdHJ1Y3QgdmJ0X2hlYWRlciB7Cgl1OCBzaWduYXR1cmVbMjBdOwkJLyoqPCBBbHdheXMgc3RhcnRzIHdpdGggJ1ZCVCQnICovCgl1MTYgdmVyc2lvbjsJCQkvKio8IGRlY2ltYWwgKi8KCXUxNiBoZWFkZXJfc2l6ZTsJCS8qKjwgaW4gYnl0ZXMgKi8KCXUxNiB2YnRfc2l6ZTsJCQkvKio8IGluIGJ5dGVzICovCgl1OCB2YnRfY2hlY2tzdW07Cgl1OCByZXNlcnZlZDA7Cgl1MzIgYmRiX29mZnNldDsJCQkvKio8IGZyb20gYmVnaW5uaW5nIG9mIFZCVCAqLwoJdTMyIGFpbV9vZmZzZXRbNF07CQkvKio8IGZyb20gYmVnaW5uaW5nIG9mIFZCVCAqLwp9IF9fYXR0cmlidXRlX18oKHBhY2tlZCkpOwoKc3RydWN0IGJkYl9oZWFkZXIgewoJdTggc2lnbmF0dXJlWzE2XTsJCS8qKjwgQWx3YXlzICdCSU9TX0RBVEFfQkxPQ0snICovCgl1MTYgdmVyc2lvbjsJCQkvKio8IGRlY2ltYWwgKi8KCXUxNiBoZWFkZXJfc2l6ZTsJCS8qKjwgaW4gYnl0ZXMgKi8KCXUxNiBiZGJfc2l6ZTsJCQkvKio8IGluIGJ5dGVzICovCn07CgovKiBzdHJpY3RseSBzcGVha2luZywgdGhpcyBpcyBhICJza2lwIiBibG9jaywgYnV0IGl0IGhhcyBpbnRlcmVzdGluZyBpbmZvICovCnN0cnVjdCB2Ymlvc19kYXRhIHsKCXU4IHR5cGU7IC8qIDAgPT0gZGVza3RvcCwgMSA9PSBtb2JpbGUgKi8KCXU4IHJlbHN0YWdlOwoJdTggY2hpcHNldDsKCXU4IGx2ZHNfcHJlc2VudDoxOwoJdTggdHZfcHJlc2VudDoxOwoJdTggcnN2ZDI6NjsgLyogZmluaXNoIGJ5dGUgKi8KCXU4IHJzdmQzWzRdOwoJdTggc2lnbm9uWzE1NV07Cgl1OCBjb3B5cmlnaHRbNjFdOwoJdTE2IGNvZGVfc2VnbWVudDsKCXU4IGRvc19ib290X21vZGU7Cgl1OCBiYW5kd2lkdGhfcGVyY2VudDsKCXU4IHJzdmQ0OyAvKiBwb3B1cCBtZW1vcnkgc2l6ZSAqLwoJdTggcmVzaXplX3BjaV9iaW9zOwoJdTggcnN2ZDU7IC8qIGlzIGNydCBhbHJlYWR5IG9uIGRkYzIgKi8KfSBfX2F0dHJpYnV0ZV9fKChwYWNrZWQpKTsKCi8qCiAqIFRoZXJlIGFyZSBzZXZlcmFsIHR5cGVzIG9mIEJJT1MgZGF0YSBibG9ja3MgKEJEQnMpLCBlYWNoIGJsb2NrIGhhcwogKiBhbiBJRCBhbmQgc2l6ZSBpbiB0aGUgZmlyc3QgMyBieXRlcyAoSUQgaW4gZmlyc3QsIHNpemUgaW4gbmV4dCAyKS4KICogS25vd24gdHlwZXMgYXJlIGxpc3RlZCBiZWxvdy4KICovCiNkZWZpbmUgQkRCX0dFTkVSQUxfRkVBVFVSRVMJICAxCiNkZWZpbmUgQkRCX0dFTkVSQUxfREVGSU5JVElPTlMJICAyCiNkZWZpbmUgQkRCX09MRF9UT0dHTEVfTElTVAkgIDMKI2RlZmluZSBCREJfTU9ERV9TVVBQT1JUX0xJU1QJICA0CiNkZWZpbmUgQkRCX0dFTkVSSUNfTU9ERV9UQUJMRQkgIDUKI2RlZmluZSBCREJfRVhUX01NSU9fUkVHUwkgIDYKI2RlZmluZSBCREJfU1dGX0lPCQkgIDcKI2RlZmluZSBCREJfU1dGX01NSU8JCSAgOAojZGVmaW5lIEJEQl9ET1RfQ0xPQ0tfVEFCTEUJICA5CiNkZWZpbmUgQkRCX01PREVfUkVNT1ZBTF9UQUJMRQkgMTAKI2RlZmluZSBCREJfQ0hJTERfREVWSUNFX1RBQkxFCSAxMQojZGVmaW5lIEJEQl9EUklWRVJfRkVBVFVSRVMJIDEyCiNkZWZpbmUgQkRCX0RSSVZFUl9QRVJTSVNURU5DRQkgMTMKI2RlZmluZSBCREJfRVhUX1RBQkxFX1BUUlMJIDE0CiNkZWZpbmUgQkRCX0RPVF9DTE9DS19PVkVSUklERQkgMTUKI2RlZmluZSBCREJfRElTUExBWV9TRUxFQ1QJIDE2Ci8qIDE3IHJzdmQgKi8KI2RlZmluZSBCREJfRFJJVkVSX1JPVEFUSU9OCSAxOAojZGVmaW5lIEJEQl9ESVNQTEFZX1JFTU9WRQkgMTkKI2RlZmluZSBCREJfT0VNX0NVU1RPTQkJIDIwCiNkZWZpbmUgQkRCX0VGUF9MSVNUCQkgMjEgLyogd29ya2Fyb3VuZHMgZm9yIFZHQSBoc3luYy92c3luYyAqLwojZGVmaW5lIEJEQl9TRFZPX0xWRFNfT1BUSU9OUwkgMjIKI2RlZmluZSBCREJfU0RWT19QQU5FTF9EVERTCSAyMwojZGVmaW5lIEJEQl9TRFZPX0xWRFNfUE5QX0lEUwkgMjQKI2RlZmluZSBCREJfU0RWT19MVkRTX1BPV0VSX1NFUQkgMjUKI2RlZmluZSBCREJfVFZfT1BUSU9OUwkJIDI2CiNkZWZpbmUgQkRCX0VEUAkJCSAyNwojZGVmaW5lIEJEQl9MVkRTX09QVElPTlMJIDQwCiNkZWZpbmUgQkRCX0xWRFNfTEZQX0RBVEFfUFRSUwkgNDEKI2RlZmluZSBCREJfTFZEU19MRlBfREFUQQkgNDIKI2RlZmluZSBCREJfTFZEU19CQUNLTElHSFQJIDQzCiNkZWZpbmUgQkRCX0xWRFNfUE9XRVIJCSA0NAojZGVmaW5lIEJEQl9TS0lQCQkyNTQgLyogVkJJT1MgcHJpdmF0ZSBibG9jaywgaWdub3JlICovCgpzdHJ1Y3QgYmRiX2dlbmVyYWxfZmVhdHVyZXMgewogICAgICAgIC8qIGJpdHMgMSAqLwoJdTggcGFuZWxfZml0dGluZzoyOwoJdTggZmxleGFpbToxOwoJdTggbXNnX2VuYWJsZToxOwoJdTggY2xlYXJfc2NyZWVuOjM7Cgl1OCBjb2xvcl9mbGlwOjE7CgogICAgICAgIC8qIGJpdHMgMiAqLwoJdTggZG93bmxvYWRfZXh0X3ZidDoxOwoJdTggZW5hYmxlX3NzYzoxOwoJdTggc3NjX2ZyZXE6MTsKCXU4IGVuYWJsZV9sZnBfb25fb3ZlcnJpZGU6MTsKCXU4IGRpc2FibGVfc3NjX2RkdDoxOwoJdTggcnN2ZDg6MzsgLyogZmluaXNoIGJ5dGUgKi8KCiAgICAgICAgLyogYml0cyAzICovCgl1OCBkaXNhYmxlX3Ntb290aF92aXNpb246MTsKCXU4IHNpbmdsZV9kdmk6MTsKCXU4IHJzdmQ5OjY7IC8qIGZpbmlzaCBieXRlICovCgogICAgICAgIC8qIGJpdHMgNCAqLwoJdTggbGVnYWN5X21vbml0b3JfZGV0ZWN0OwoKICAgICAgICAvKiBiaXRzIDUgKi8KCXU4IGludF9jcnRfc3VwcG9ydDoxOwoJdTggaW50X3R2X3N1cHBvcnQ6MTsKCXU4IHJzdmQxMTo2OyAvKiBmaW5pc2ggYnl0ZSAqLwp9IF9fYXR0cmlidXRlX18oKHBhY2tlZCkpOwoKLyogcHJlLTkxNSAqLwojZGVmaW5lIEdQSU9fUElOX0RWSV9MVkRTCTB4MDMgLyogIkRWSS9MVkRTIEREQyBHUElPIHBpbnMiICovCiNkZWZpbmUgR1BJT19QSU5fQUREX0kyQwkweDA1IC8qICJBRERDQVJEIEkyQyBHUElPIHBpbnMiICovCiNkZWZpbmUgR1BJT19QSU5fQUREX0REQwkweDA0IC8qICJBRERDQVJEIEREQyBHUElPIHBpbnMiICovCiNkZWZpbmUgR1BJT19QSU5fQUREX0REQ19JMkMJMHgwNiAvKiAiQUREQ0FSRCBEREMvSTJDIEdQSU8gcGlucyIgKi8KCi8qIFByZSA5MTUgKi8KI2RlZmluZSBERVZJQ0VfVFlQRV9OT05FCTB4MDAKI2RlZmluZSBERVZJQ0VfVFlQRV9DUlQJCTB4MDEKI2RlZmluZSBERVZJQ0VfVFlQRV9UVgkJMHgwOQojZGVmaW5lIERFVklDRV9UWVBFX0VGUAkJMHgxMgojZGVmaW5lIERFVklDRV9UWVBFX0xGUAkJMHgyMgovKiBPbiA5MTUrICovCiNkZWZpbmUgREVWSUNFX1RZUEVfQ1JUX0RQTVMJCTB4NjAwMQojZGVmaW5lIERFVklDRV9UWVBFX0NSVF9EUE1TX0hPVFBMVUcJMHg0MDAxCiNkZWZpbmUgREVWSUNFX1RZUEVfVFZfQ09NUE9TSVRFCTB4MDIwOQojZGVmaW5lIERFVklDRV9UWVBFX1RWX01BQ1JPVklTSU9OCTB4MDI4OQojZGVmaW5lIERFVklDRV9UWVBFX1RWX1JGX0NPTVBPU0lURQkweDAyMGMKI2RlZmluZSBERVZJQ0VfVFlQRV9UVl9TVklERU9fQ09NUE9TSVRFCTB4MDYwOQojZGVmaW5lIERFVklDRV9UWVBFX1RWX1NDQVJUCQkweDAyMDkKI2RlZmluZSBERVZJQ0VfVFlQRV9UVl9DT0RFQ19IT1RQTFVHX1BXUiAweDYwMDkKI2RlZmluZSBERVZJQ0VfVFlQRV9FRlBfSE9UUExVR19QV1IJMHg2MDEyCiNkZWZpbmUgREVWSUNFX1RZUEVfRUZQX0RWSV9IT1RQTFVHX1BXUgkweDYwNTIKI2RlZmluZSBERVZJQ0VfVFlQRV9FRlBfRFZJX0kJCTB4NjA1MwojZGVmaW5lIERFVklDRV9UWVBFX0VGUF9EVklfRF9EVUFMCTB4NjE1MgojZGVmaW5lIERFVklDRV9UWVBFX0VGUF9EVklfRF9IRENQCTB4NjBkMgojZGVmaW5lIERFVklDRV9UWVBFX09QRU5MRElfSE9UUExVR19QV1IJMHg2MDYyCiNkZWZpbmUgREVWSUNFX1RZUEVfT1BFTkxESV9EVUFMUElYCTB4NjE2MgojZGVmaW5lIERFVklDRV9UWVBFX0xGUF9QQU5FTExJTksJMHg1MDEyCiNkZWZpbmUgREVWSUNFX1RZUEVfTEZQX0NNT1NfUFdSCTB4NTA0MgojZGVmaW5lIERFVklDRV9UWVBFX0xGUF9MVkRTX1BXUgkweDUwNjIKI2RlZmluZSBERVZJQ0VfVFlQRV9MRlBfTFZEU19EVUFMCTB4NTE2MgojZGVmaW5lIERFVklDRV9UWVBFX0xGUF9MVkRTX0RVQUxfSERDUAkweDUxZTIKCiNkZWZpbmUgREVWSUNFX0NGR19OT05FCQkweDAwCiNkZWZpbmUgREVWSUNFX0NGR18xMkJJVF9EVk9CCTB4MDEKI2RlZmluZSBERVZJQ0VfQ0ZHXzEyQklUX0RWT0MJMHgwMgojZGVmaW5lIERFVklDRV9DRkdfMjRCSVRfRFZPQkMJMHgwOQojZGVmaW5lIERFVklDRV9DRkdfMjRCSVRfRFZPQ0IJMHgwYQojZGVmaW5lIERFVklDRV9DRkdfRFVBTF9EVk9CCTB4MTEKI2RlZmluZSBERVZJQ0VfQ0ZHX0RVQUxfRFZPQwkweDEyCiNkZWZpbmUgREVWSUNFX0NGR19EVUFMX0RWT0JDCTB4MTMKI2RlZmluZSBERVZJQ0VfQ0ZHX0RVQUxfTElOS19EVk9CQwkweDE5CiNkZWZpbmUgREVWSUNFX0NGR19EVUFMX0xJTktfRFZPQ0IJMHgxYQoKI2RlZmluZSBERVZJQ0VfV0lSRV9OT05FCTB4MDAKI2RlZmluZSBERVZJQ0VfV0lSRV9EVk9CCTB4MDEKI2RlZmluZSBERVZJQ0VfV0lSRV9EVk9DCTB4MDIKI2RlZmluZSBERVZJQ0VfV0lSRV9EVk9CQwkweDAzCiNkZWZpbmUgREVWSUNFX1dJUkVfRFZPQkIJMHgwNQojZGVmaW5lIERFVklDRV9XSVJFX0RWT0NDCTB4MDYKI2RlZmluZSBERVZJQ0VfV0lSRV9EVk9CX01BU1RFUiAweDBkCiNkZWZpbmUgREVWSUNFX1dJUkVfRFZPQ19NQVNURVIgMHgwZQoKI2RlZmluZSBERVZJQ0VfUE9SVF9EVk9BCTB4MDAgLyogbm9uZSBvbiA4NDUrICovCiNkZWZpbmUgREVWSUNFX1BPUlRfRFZPQgkweDAxCiNkZWZpbmUgREVWSUNFX1BPUlRfRFZPQwkweDAyCgpzdHJ1Y3QgY2hpbGRfZGV2aWNlX2NvbmZpZyB7Cgl1MTYgaGFuZGxlOwoJdTE2IGRldmljZV90eXBlOwoJdTggIGkyY19zcGVlZDsKCXU4ICByc3ZkWzldOwoJdTE2IGFkZGluX29mZnNldDsKCXU4ICBkdm9fcG9ydDsgLyogU2VlIERldmljZV9QT1JUXyogYWJvdmUgKi8KCXU4ICBpMmNfcGluOwoJdTggIHNsYXZlX2FkZHI7Cgl1OCAgZGRjX3BpbjsKCXUxNiBlZGlkX3B0cjsKCXU4ICBkdm9fY2ZnOyAvKiBTZWUgREVWSUNFX0NGR18qIGFib3ZlICovCgl1OCAgZHZvMl9wb3J0OwoJdTggIGkyYzJfcGluOwoJdTggIHNsYXZlMl9hZGRyOwoJdTggIGRkYzJfcGluOwoJdTggIGNhcGFiaWxpdGllczsKCXU4ICBkdm9fd2lyaW5nOy8qIFNlZSBERVZJQ0VfV0lSRV8qIGFib3ZlICovCgl1OCAgZHZvMl93aXJpbmc7Cgl1MTYgZXh0ZW5kZWRfdHlwZTsKCXU4ICBkdm9fZnVuY3Rpb247Cn0gX19hdHRyaWJ1dGVfXygocGFja2VkKSk7CgpzdHJ1Y3QgYmRiX2dlbmVyYWxfZGVmaW5pdGlvbnMgewoJLyogRERDIEdQSU8gKi8KCXU4IGNydF9kZGNfZ21idXNfcGluOwoKCS8qIERQTVMgYml0cyAqLwoJdTggZHBtc19hY3BpOjE7Cgl1OCBza2lwX2Jvb3RfY3J0X2RldGVjdDoxOwoJdTggZHBtc19haW06MTsKCXU4IHJzdmQxOjU7IC8qIGZpbmlzaCBieXRlICovCgoJLyogYm9vdCBkZXZpY2UgYml0cyAqLwoJdTggYm9vdF9kaXNwbGF5WzJdOwoJdTggY2hpbGRfZGV2X3NpemU7CgoJLyoKCSAqIERldmljZSBpbmZvOgoJICogSWYgVFYgaXMgcHJlc2VudCwgaXQnbGwgYmUgYXQgZGV2aWNlc1swXS4KCSAqIExWRFMgd2lsbCBiZSBuZXh0LCBlaXRoZXIgZGV2aWNlc1swXSBvciBbMV0sIGlmIHByZXNlbnQuCgkgKiBPbiBzb21lIHBsYXRmb3JtcyB0aGUgbnVtYmVyIG9mIGRldmljZSBpcyA2LiBCdXQgY291bGQgYmUgYXMgZmV3IGFzCgkgKiA0IGlmIGJvdGggVFYgYW5kIExWRFMgYXJlIG1pc3NpbmcuCgkgKiBBbmQgdGhlIGRldmljZSBudW0gaXMgcmVsYXRlZCB3aXRoIHRoZSBzaXplIG9mIGdlbmVyYWwgZGVmaW5pdGlvbgoJICogYmxvY2suIEl0IGlzIG9idGFpbmVkIGJ5IHVzaW5nIHRoZSBmb2xsb3dpbmcgZm9ybXVsYToKCSAqIG51bWJlciA9IChibG9ja19zaXplIC0gc2l6ZW9mKGJkYl9nZW5lcmFsX2RlZmluaXRpb25zKSkvCgkgKiAJCXNpemVvZihjaGlsZF9kZXZpY2VfY29uZmlnKTsKCSAqLwoJc3RydWN0IGNoaWxkX2RldmljZV9jb25maWcgZGV2aWNlc1swXTsKfSBfX2F0dHJpYnV0ZV9fKChwYWNrZWQpKTsKCnN0cnVjdCBiZGJfbHZkc19vcHRpb25zIHsKCXU4IHBhbmVsX3R5cGU7Cgl1OCByc3ZkMTsKCS8qIExWRFMgY2FwYWJpbGl0aWVzLCBzdG9yZWQgaW4gYSBkd29yZCAqLwoJdTggcGZpdF9tb2RlOjI7Cgl1OCBwZml0X3RleHRfbW9kZV9lbmhhbmNlZDoxOwoJdTggcGZpdF9nZnhfbW9kZV9lbmhhbmNlZDoxOwoJdTggcGZpdF9yYXRpb19hdXRvOjE7Cgl1OCBwaXhlbF9kaXRoZXI6MTsKCXU4IGx2ZHNfZWRpZDoxOwoJdTggcnN2ZDI6MTsKCXU4IHJzdmQ0Owp9IF9fYXR0cmlidXRlX18oKHBhY2tlZCkpOwoKLyogTEZQIHBvaW50ZXIgdGFibGUgY29udGFpbnMgZW50cmllcyB0byB0aGUgc3RydWN0IGJlbG93ICovCnN0cnVjdCBiZGJfbHZkc19sZnBfZGF0YV9wdHIgewoJdTE2IGZwX3RpbWluZ19vZmZzZXQ7IC8qIG9mZnNldHMgYXJlIGZyb20gc3RhcnQgb2YgYmRiICovCgl1OCBmcF90YWJsZV9zaXplOwoJdTE2IGR2b190aW1pbmdfb2Zmc2V0OwoJdTggZHZvX3RhYmxlX3NpemU7Cgl1MTYgcGFuZWxfcG5wX2lkX29mZnNldDsKCXU4IHBucF90YWJsZV9zaXplOwp9IF9fYXR0cmlidXRlX18oKHBhY2tlZCkpOwoKc3RydWN0IGJkYl9sdmRzX2xmcF9kYXRhX3B0cnMgewoJdTggbHZkc19lbnRyaWVzOyAvKiBmb2xsb3dlZCBieSBvbmUgb3IgbW9yZSBsdmRzX2RhdGFfcHRyIHN0cnVjdHMgKi8KCXN0cnVjdCBiZGJfbHZkc19sZnBfZGF0YV9wdHIgcHRyWzE2XTsKfSBfX2F0dHJpYnV0ZV9fKChwYWNrZWQpKTsKCi8qIExGUCBkYXRhIGhhcyAzIGJsb2NrcyBwZXIgZW50cnkgKi8Kc3RydWN0IGx2ZHNfZnBfdGltaW5nIHsKCXUxNiB4X3JlczsKCXUxNiB5X3JlczsKCXUzMiBsdmRzX3JlZzsKCXUzMiBsdmRzX3JlZ192YWw7Cgl1MzIgcHBfb25fcmVnOwoJdTMyIHBwX29uX3JlZ192YWw7Cgl1MzIgcHBfb2ZmX3JlZzsKCXUzMiBwcF9vZmZfcmVnX3ZhbDsKCXUzMiBwcF9jeWNsZV9yZWc7Cgl1MzIgcHBfY3ljbGVfcmVnX3ZhbDsKCXUzMiBwZml0X3JlZzsKCXUzMiBwZml0X3JlZ192YWw7Cgl1MTYgdGVybWluYXRvcjsKfSBfX2F0dHJpYnV0ZV9fKChwYWNrZWQpKTsKCnN0cnVjdCBsdmRzX2R2b190aW1pbmcgewoJdTE2IGNsb2NrOwkJLyoqPCBJbiAxMGtoeiAqLwoJdTggaGFjdGl2ZV9sbzsKCXU4IGhibGFua19sbzsKCXU4IGhibGFua19oaTo0OwoJdTggaGFjdGl2ZV9oaTo0OwoJdTggdmFjdGl2ZV9sbzsKCXU4IHZibGFua19sbzsKCXU4IHZibGFua19oaTo0OwoJdTggdmFjdGl2ZV9oaTo0OwoJdTggaHN5bmNfb2ZmX2xvOwoJdTggaHN5bmNfcHVsc2Vfd2lkdGg7Cgl1OCB2c3luY19wdWxzZV93aWR0aDo0OwoJdTggdnN5bmNfb2ZmOjQ7Cgl1OCByc3ZkMDo2OwoJdTggaHN5bmNfb2ZmX2hpOjI7Cgl1OCBoX2ltYWdlOwoJdTggdl9pbWFnZTsKCXU4IG1heF9odjsKCXU4IGhfYm9yZGVyOwoJdTggdl9ib3JkZXI7Cgl1OCByc3ZkMTozOwoJdTggZGlnaXRhbDoyOwoJdTggdnN5bmNfcG9zaXRpdmU6MTsKCXU4IGhzeW5jX3Bvc2l0aXZlOjE7Cgl1OCByc3ZkMjoxOwp9IF9fYXR0cmlidXRlX18oKHBhY2tlZCkpOwoKc3RydWN0IGx2ZHNfcG5wX2lkIHsKCXUxNiBtZmdfbmFtZTsKCXUxNiBwcm9kdWN0X2NvZGU7Cgl1MzIgc2VyaWFsOwoJdTggbWZnX3dlZWs7Cgl1OCBtZmdfeWVhcjsKfSBfX2F0dHJpYnV0ZV9fKChwYWNrZWQpKTsKCnN0cnVjdCBiZGJfbHZkc19sZnBfZGF0YV9lbnRyeSB7CglzdHJ1Y3QgbHZkc19mcF90aW1pbmcgZnBfdGltaW5nOwoJc3RydWN0IGx2ZHNfZHZvX3RpbWluZyBkdm9fdGltaW5nOwoJc3RydWN0IGx2ZHNfcG5wX2lkIHBucF9pZDsKfSBfX2F0dHJpYnV0ZV9fKChwYWNrZWQpKTsKCnN0cnVjdCBiZGJfbHZkc19sZnBfZGF0YSB7CglzdHJ1Y3QgYmRiX2x2ZHNfbGZwX2RhdGFfZW50cnkgZGF0YVsxNl07Cn0gX19hdHRyaWJ1dGVfXygocGFja2VkKSk7CgpzdHJ1Y3QgYWltZGJfaGVhZGVyIHsKCWNoYXIgc2lnbmF0dXJlWzE2XTsKCWNoYXIgb2VtX2RldmljZVsyMF07Cgl1MTYgYWltZGJfdmVyc2lvbjsKCXUxNiBhaW1kYl9oZWFkZXJfc2l6ZTsKCXUxNiBhaW1kYl9zaXplOwp9IF9fYXR0cmlidXRlX18oKHBhY2tlZCkpOwoKc3RydWN0IGFpbWRiX2Jsb2NrIHsKCXU4IGFpbWRiX2lkOwoJdTE2IGFpbWRiX3NpemU7Cn0gX19hdHRyaWJ1dGVfXygocGFja2VkKSk7CgpzdHJ1Y3QgdmNoX3BhbmVsX2RhdGEgewoJdTE2IGZwX3RpbWluZ19vZmZzZXQ7Cgl1OCBmcF90aW1pbmdfc2l6ZTsKCXUxNiBkdm9fdGltaW5nX29mZnNldDsKCXU4IGR2b190aW1pbmdfc2l6ZTsKCXUxNiB0ZXh0X2ZpdHRpbmdfb2Zmc2V0OwoJdTggdGV4dF9maXR0aW5nX3NpemU7Cgl1MTYgZ3JhcGhpY3NfZml0dGluZ19vZmZzZXQ7Cgl1OCBncmFwaGljc19maXR0aW5nX3NpemU7Cn0gX19hdHRyaWJ1dGVfXygocGFja2VkKSk7CgpzdHJ1Y3QgdmNoX2JkYl8yMiB7CglzdHJ1Y3QgYWltZGJfYmxvY2sgYWltZGJfYmxvY2s7CglzdHJ1Y3QgdmNoX3BhbmVsX2RhdGEgcGFuZWxzWzE2XTsKfSBfX2F0dHJpYnV0ZV9fKChwYWNrZWQpKTsKCnN0cnVjdCBiZGJfc2R2b19sdmRzX29wdGlvbnMgewoJdTggcGFuZWxfYmFja2xpZ2h0OwoJdTggaDQwX3NldF9wYW5lbF90eXBlOwoJdTggcGFuZWxfdHlwZTsKCXU4IHNzY19jbGtfZnJlcTsKCXUxNiBhbHNfbG93X3RyaXA7Cgl1MTYgYWxzX2hpZ2hfdHJpcDsKCXU4IHNjbGFsYXJjb2VmZl90YWJfcm93X251bTsKCXU4IHNjbGFsYXJjb2VmZl90YWJfcm93X3NpemU7Cgl1OCBjb2VmZmljaWVudFs4XTsKCXU4IHBhbmVsX21pc2NfYml0c18xOwoJdTggcGFuZWxfbWlzY19iaXRzXzI7Cgl1OCBwYW5lbF9taXNjX2JpdHNfMzsKCXU4IHBhbmVsX21pc2NfYml0c180Owp9IF9fYXR0cmlidXRlX18oKHBhY2tlZCkpOwoKCiNkZWZpbmUgQkRCX0RSSVZFUl9GRUFUVVJFX05PX0xWRFMJCTAKI2RlZmluZSBCREJfRFJJVkVSX0ZFQVRVUkVfSU5UX0xWRFMJCTEKI2RlZmluZSBCREJfRFJJVkVSX0ZFQVRVUkVfU0RWT19MVkRTCQkyCiNkZWZpbmUgQkRCX0RSSVZFUl9GRUFUVVJFX0VEUAkJCTMKCnN0cnVjdCBiZGJfZHJpdmVyX2ZlYXR1cmVzIHsKCXU4IGJvb3RfZGV2X2FsZ29yaXRobToxOwoJdTggYmxvY2tfZGlzcGxheV9zd2l0Y2g6MTsKCXU4IGFsbG93X2Rpc3BsYXlfc3dpdGNoOjE7Cgl1OCBob3RwbHVnX2R2bzoxOwoJdTggZHVhbF92aWV3X3pvb206MTsKCXU4IGludDE1aF9ob29rOjE7Cgl1OCBzcHJpdGVfaW5fY2xvbmU6MTsKCXU4IHByaW1hcnlfbGZwX2lkOjE7CgoJdTE2IGJvb3RfbW9kZV94OwoJdTE2IGJvb3RfbW9kZV95OwoJdTggYm9vdF9tb2RlX2JwcDsKCXU4IGJvb3RfbW9kZV9yZWZyZXNoOwoKCXUxNiBlbmFibGVfbGZwX3ByaW1hcnk6MTsKCXUxNiBzZWxlY3RpdmVfbW9kZV9wcnVuaW5nOjE7Cgl1MTYgZHVhbF9mcmVxdWVuY3k6MTsKCXUxNiByZW5kZXJfY2xvY2tfZnJlcToxOyAvKiAwOiBoaWdoIGZyZXE7IDE6IGxvdyBmcmVxICovCgl1MTYgbnRfY2xvbmVfc3VwcG9ydDoxOwoJdTE2IHBvd2VyX3NjaGVtZV91aToxOyAvKiAwOiBDVUk7IDE6IDNyZCBwYXJ0eSAqLwoJdTE2IHNwcml0ZV9kaXNwbGF5X2Fzc2lnbjoxOyAvKiAwOiBzZWNvbmRhcnk7IDE6IHByaW1hcnkgKi8KCXUxNiBjdWlfYXNwZWN0X3NjYWxpbmc6MTsKCXUxNiBwcmVzZXJ2ZV9hc3BlY3RfcmF0aW86MTsKCXUxNiBzZHZvX2RldmljZV9wb3dlcl9kb3duOjE7Cgl1MTYgY3J0X2hvdHBsdWc6MTsKCXUxNiBsdmRzX2NvbmZpZzoyOwoJdTE2IHR2X2hvdHBsdWc6MTsKCXUxNiBoZG1pX2NvbmZpZzoyOwoKCXU4IHN0YXRpY19kaXNwbGF5OjE7Cgl1OCByZXNlcnZlZDI6NzsKCXUxNiBsZWdhY3lfY3J0X21heF94OwoJdTE2IGxlZ2FjeV9jcnRfbWF4X3k7Cgl1OCBsZWdhY3lfY3J0X21heF9yZWZyZXNoOwoKCXU4IGhkbWlfdGVybWluYXRpb247Cgl1OCBjdXN0b21fdmJ0X3ZlcnNpb247Cn0gX19hdHRyaWJ1dGVfXygocGFja2VkKSk7CgojZGVmaW5lIEVEUF8xOEJQUAkwCiNkZWZpbmUgRURQXzI0QlBQCTEKI2RlZmluZSBFRFBfMzBCUFAJMgojZGVmaW5lIEVEUF9SQVRFXzFfNjIJMAojZGVmaW5lIEVEUF9SQVRFXzJfNwkxCiNkZWZpbmUgRURQX0xBTkVfMQkwCiNkZWZpbmUgRURQX0xBTkVfMgkxCiNkZWZpbmUgRURQX0xBTkVfNAkzCiNkZWZpbmUgRURQX1BSRUVNUEhBU0lTX05PTkUJMAojZGVmaW5lIEVEUF9QUkVFTVBIQVNJU18zXzVkQgkxCiNkZWZpbmUgRURQX1BSRUVNUEhBU0lTXzZkQgkyCiNkZWZpbmUgRURQX1BSRUVNUEhBU0lTXzlfNWRCCTMKI2RlZmluZSBFRFBfVlNXSU5HXzBfNFYJCTAKI2RlZmluZSBFRFBfVlNXSU5HXzBfNlYJCTEKI2RlZmluZSBFRFBfVlNXSU5HXzBfOFYJCTIKI2RlZmluZSBFRFBfVlNXSU5HXzFfMlYJCTMKCnN0cnVjdCBlZHBfcG93ZXJfc2VxIHsKCXUxNiB0MzsKCXUxNiB0NzsKCXUxNiB0OTsKCXUxNiB0MTA7Cgl1MTYgdDEyOwp9IF9fYXR0cmlidXRlX18gKChwYWNrZWQpKTsKCnN0cnVjdCBlZHBfbGlua19wYXJhbXMgewoJdTggcmF0ZTo0OwoJdTggbGFuZXM6NDsKCXU4IHByZWVtcGhhc2lzOjQ7Cgl1OCB2c3dpbmc6NDsKfSBfX2F0dHJpYnV0ZV9fICgocGFja2VkKSk7CgpzdHJ1Y3QgYmRiX2VkcCB7CglzdHJ1Y3QgZWRwX3Bvd2VyX3NlcSBwb3dlcl9zZXFzWzE2XTsKCXUzMiBjb2xvcl9kZXB0aDsKCXUzMiBzZHJyc19tc2FfdGltaW5nX2RlbGF5OwoJc3RydWN0IGVkcF9saW5rX3BhcmFtcyBsaW5rX3BhcmFtc1sxNl07Cn0gX19hdHRyaWJ1dGVfXyAoKHBhY2tlZCkpOwoKdm9pZCBpbnRlbF9zZXR1cF9iaW9zKHN0cnVjdCBkcm1fZGV2aWNlICpkZXYpOwpib29sIGludGVsX3BhcnNlX2Jpb3Moc3RydWN0IGRybV9kZXZpY2UgKmRldik7CgovKgogKiBEcml2ZXI8LT5WQklPUyBpbnRlcmFjdGlvbiBvY2N1cnMgdGhyb3VnaCBzY3JhdGNoIGJpdHMgaW4KICogR1IxOCAmIFNXRiouCiAqLwoKLyogR1IxOCBiaXRzIGFyZSBzZXQgb24gZGlzcGxheSBzd2l0Y2ggYW5kIGhvdGtleSBldmVudHMgKi8KI2RlZmluZSBHUjE4X0RSSVZFUl9TV0lUQ0hfRU4JKDE8PDcpIC8qIDA6IFZCSU9TIGNvbnRyb2wsIDE6IGRyaXZlciBjb250cm9sICovCiNkZWZpbmUgR1IxOF9IT1RLRVlfTUFTSwkweDc4IC8qIFNlZSBhbHNvIFNXRjQgMTU6MCAqLwojZGVmaW5lICAgR1IxOF9IS19OT05FCQkoMHgwPDwzKQojZGVmaW5lICAgR1IxOF9IS19MRlBfU1RSRVRDSAkoMHgxPDwzKQojZGVmaW5lICAgR1IxOF9IS19UT0dHTEVfRElTUAkoMHgyPDwzKQojZGVmaW5lICAgR1IxOF9IS19ESVNQX1NXSVRDSAkoMHg0PDwzKSAvKiBzZWUgU1dGMTQgMTU6MCBmb3Igd2hhdCB0byBlbmFibGUgKi8KI2RlZmluZSAgIEdSMThfSEtfUE9QVVBfRElTQUJMRUQgKDB4Njw8MykKI2RlZmluZSAgIEdSMThfSEtfUE9QVVBfRU5BQkxFRAkoMHg3PDwzKQojZGVmaW5lICAgR1IxOF9IS19QRklUCQkoMHg4PDwzKQojZGVmaW5lICAgR1IxOF9IS19BUE1fQ0hBTkdFCSgweGE8PDMpCiNkZWZpbmUgICBHUjE4X0hLX01VTFRJUExFCSgweGM8PDMpCiNkZWZpbmUgR1IxOF9VU0VSX0lOVF9FTgkoMTw8MikKI2RlZmluZSBHUjE4X0EwMDAwX0ZMVVNIX0VOCSgxPDwxKQojZGVmaW5lIEdSMThfU01NX0VOCQkoMTw8MCkKCi8qIFNldCBieSBkcml2ZXIsIGNsZWFyZWQgYnkgVkJJT1MgKi8KI2RlZmluZSBTV0YwMF9ZUkVTX1NISUZUCTE2CiNkZWZpbmUgU1dGMDBfWFJFU19TSElGVAkwCiNkZWZpbmUgU1dGMDBfUkVTX01BU0sJCTB4ZmZmZgoKLyogU2V0IGJ5IFZCSU9TIGF0IGJvb3QgdGltZSBhbmQgZHJpdmVyIGF0IHJ1bnRpbWUgKi8KI2RlZmluZSBTV0YwMV9UVjJfRk9STUFUX1NISUZUCTgKI2RlZmluZSBTV0YwMV9UVjFfRk9STUFUX1NISUZUCTAKI2RlZmluZSBTV0YwMV9UVl9GT1JNQVRfTUFTSwkweGZmZmYKCiNkZWZpbmUgU1dGMTBfVkJJT1NfQkxDX0kyQ19FTgkoMTw8MjkpCiNkZWZpbmUgU1dGMTBfR1RUX09WRVJSSURFX0VOCSgxPDwyOCkKI2RlZmluZSBTV0YxMF9MRlBfRFBNU19PVlIJKDE8PDI3KSAvKiBvdmVycmlkZSBEUE1TIG9uIGRpc3BsYXkgc3dpdGNoICovCiNkZWZpbmUgU1dGMTBfQUNUSVZFX1RPR0dMRV9MSVNUX01BU0sgKDc8PDI0KQojZGVmaW5lICAgU1dGMTBfT0xEX1RPR0dMRQkweDAKI2RlZmluZSAgIFNXRjEwX1RPR0dMRV9MSVNUXzEJMHgxCiNkZWZpbmUgICBTV0YxMF9UT0dHTEVfTElTVF8yCTB4MgojZGVmaW5lICAgU1dGMTBfVE9HR0xFX0xJU1RfMwkweDMKI2RlZmluZSAgIFNXRjEwX1RPR0dMRV9MSVNUXzQJMHg0CiNkZWZpbmUgU1dGMTBfUEFOTklOR19FTgkoMTw8MjMpCiNkZWZpbmUgU1dGMTBfRFJJVkVSX0xPQURFRAkoMTw8MjIpCiNkZWZpbmUgU1dGMTBfRVhURU5ERURfREVTS1RPUAkoMTw8MjEpCiNkZWZpbmUgU1dGMTBfRVhDTFVTSVZFX01PREUJKDE8PDIwKQojZGVmaW5lIFNXRjEwX09WRVJMQVlfRU4JKDE8PDE5KQojZGVmaW5lIFNXRjEwX1BMQU5FQl9IT0xET0ZGCSgxPDwxOCkKI2RlZmluZSBTV0YxMF9QTEFORUFfSE9MRE9GRgkoMTw8MTcpCiNkZWZpbmUgU1dGMTBfVkdBX0hPTERPRkYJKDE8PDE2KQojZGVmaW5lIFNXRjEwX0FDVElWRV9ESVNQX01BU0sJMHhmZmZmCiNkZWZpbmUgICBTV0YxMF9QSVBFQl9MRlAyCSgxPDwxNSkKI2RlZmluZSAgIFNXRjEwX1BJUEVCX0VGUDIJKDE8PDE0KQojZGVmaW5lICAgU1dGMTBfUElQRUJfVFYyCSgxPDwxMykKI2RlZmluZSAgIFNXRjEwX1BJUEVCX0NSVDIJKDE8PDEyKQojZGVmaW5lICAgU1dGMTBfUElQRUJfTEZQCSgxPDwxMSkKI2RlZmluZSAgIFNXRjEwX1BJUEVCX0VGUAkoMTw8MTApCiNkZWZpbmUgICBTV0YxMF9QSVBFQl9UVgkoMTw8OSkKI2RlZmluZSAgIFNXRjEwX1BJUEVCX0NSVAkoMTw8OCkKI2RlZmluZSAgIFNXRjEwX1BJUEVBX0xGUDIJKDE8PDcpCiNkZWZpbmUgICBTV0YxMF9QSVBFQV9FRlAyCSgxPDw2KQojZGVmaW5lICAgU1dGMTBfUElQRUFfVFYyCSgxPDw1KQojZGVmaW5lICAgU1dGMTBfUElQRUFfQ1JUMgkoMTw8NCkKI2RlZmluZSAgIFNXRjEwX1BJUEVBX0xGUAkoMTw8MykKI2RlZmluZSAgIFNXRjEwX1BJUEVBX0VGUAkoMTw8MikKI2RlZmluZSAgIFNXRjEwX1BJUEVBX1RWCSgxPDwxKQojZGVmaW5lICAgU1dGMTBfUElQRUFfQ1JUCSgxPDwwKQoKI2RlZmluZSBTV0YxMV9NRU1PUllfU0laRV9TSElGVAkxNgojZGVmaW5lIFNXRjExX1NWX1RFU1RfRU4JKDE8PDE1KQojZGVmaW5lIFNXRjExX0lTX0FHUAkJKDE8PDE0KQojZGVmaW5lIFNXRjExX0RJU1BMQVlfSE9MRE9GRgkoMTw8MTMpCiNkZWZpbmUgU1dGMTFfRFBNU19SRURVQ0VECSgxPDwxMikKI2RlZmluZSBTV0YxMV9JU19WQkVfTU9ERQkoMTw8MTEpCiNkZWZpbmUgU1dGMTFfUElQRUJfQUNDRVNTCSgxPDwxMCkgLyogMCBoZXJlIG1lYW5zIHBpcGUgYSAqLwojZGVmaW5lIFNXRjExX0RQTVNfTUFTSwkJMHgwNwojZGVmaW5lICAgU1dGMTFfRFBNU19PRkYJKDE8PDIpCiNkZWZpbmUgICBTV0YxMV9EUE1TX1NVU1BFTkQJKDE8PDEpCiNkZWZpbmUgICBTV0YxMV9EUE1TX1NUQU5EQlkJKDE8PDApCiNkZWZpbmUgICBTV0YxMV9EUE1TX09OCQkwCgojZGVmaW5lIFNXRjE0X0dGWF9QRklUX0VOCSgxPDwzMSkKI2RlZmluZSBTV0YxNF9URVhUX1BGSVRfRU4JKDE8PDMwKQojZGVmaW5lIFNXRjE0X0xJRF9TVEFUVVNfQ0xPU0VECSgxPDwyOSkgLyogMCBoZXJlIG1lYW5zIG9wZW4gKi8KI2RlZmluZSBTV0YxNF9QT1BVUF9FTgkJKDE8PDI4KQojZGVmaW5lIFNXRjE0X0RJU1BMQVlfSE9MRE9GRgkoMTw8MjcpCiNkZWZpbmUgU1dGMTRfRElTUF9ERVRFQ1RfRU4JKDE8PDI2KQojZGVmaW5lIFNXRjE0X0RPQ0tJTkdfU1RBVFVTX0RPQ0tFRCAoMTw8MjUpIC8qIDAgaGVyZSBtZWFucyB1bmRvY2tlZCAqLwojZGVmaW5lIFNXRjE0X0RSSVZFUl9TVEFUVVMJKDE8PDI0KQojZGVmaW5lIFNXRjE0X09TX1RZUEVfV0lOOVgJKDE8PDIzKQojZGVmaW5lIFNXRjE0X09TX1RZUEVfV0lOTlQJKDE8PDIyKQovKiAyMToxOSByc3ZkICovCiNkZWZpbmUgU1dGMTRfUE1fVFlQRV9NQVNLCTB4MDAwNzAwMDAKI2RlZmluZSAgIFNXRjE0X1BNX0FDUElfVklERU8JKDB4NCA8PCAxNikKI2RlZmluZSAgIFNXRjE0X1BNX0FDUEkJCSgweDMgPDwgMTYpCiNkZWZpbmUgICBTV0YxNF9QTV9BUE1fMTIJKDB4MiA8PCAxNikKI2RlZmluZSAgIFNXRjE0X1BNX0FQTV8xMQkoMHgxIDw8IDE2KQojZGVmaW5lIFNXRjE0X0hLX1JFUVVFU1RfTUFTSwkweDAwMDBmZmZmIC8qIHNlZSBHUjE4IDY6MyBmb3IgZXZlbnQgdHlwZSAqLwogICAgICAgICAgLyogaWYgR1IxOCBpbmRpY2F0ZXMgYSBkaXNwbGF5IHN3aXRjaCAqLwojZGVmaW5lICAgU1dGMTRfRFNfUElQRUJfTEZQMl9FTiAoMTw8MTUpCiNkZWZpbmUgICBTV0YxNF9EU19QSVBFQl9FRlAyX0VOICgxPDwxNCkKI2RlZmluZSAgIFNXRjE0X0RTX1BJUEVCX1RWMl9FTiAgKDE8PDEzKQojZGVmaW5lICAgU1dGMTRfRFNfUElQRUJfQ1JUMl9FTiAoMTw8MTIpCiNkZWZpbmUgICBTV0YxNF9EU19QSVBFQl9MRlBfRU4gICgxPDwxMSkKI2RlZmluZSAgIFNXRjE0X0RTX1BJUEVCX0VGUF9FTiAgKDE8PDEwKQojZGVmaW5lICAgU1dGMTRfRFNfUElQRUJfVFZfRU4gICAoMTw8OSkKI2RlZmluZSAgIFNXRjE0X0RTX1BJUEVCX0NSVF9FTiAgKDE8PDgpCiNkZWZpbmUgICBTV0YxNF9EU19QSVBFQV9MRlAyX0VOICgxPDw3KQojZGVmaW5lICAgU1dGMTRfRFNfUElQRUFfRUZQMl9FTiAoMTw8NikKI2RlZmluZSAgIFNXRjE0X0RTX1BJUEVBX1RWMl9FTiAgKDE8PDUpCiNkZWZpbmUgICBTV0YxNF9EU19QSVBFQV9DUlQyX0VOICgxPDw0KQojZGVmaW5lICAgU1dGMTRfRFNfUElQRUFfTEZQX0VOICAoMTw8MykKI2RlZmluZSAgIFNXRjE0X0RTX1BJUEVBX0VGUF9FTiAgKDE8PDIpCiNkZWZpbmUgICBTV0YxNF9EU19QSVBFQV9UVl9FTiAgICgxPDwxKQojZGVmaW5lICAgU1dGMTRfRFNfUElQRUFfQ1JUX0VOICAoMTw8MCkKICAgICAgICAgIC8qIGlmIEdSMTggaW5kaWNhdGVzIGEgcGFuZWwgZml0dGluZyByZXF1ZXN0ICovCiNkZWZpbmUgICBTV0YxNF9QRklUX0VOCQkoMTw8MCkgLyogMCBtZWFucyBkaXNhYmxlICovCiAgICAgICAgICAvKiBpZiBHUjE4IGluZGljYXRlcyBhbiBBUE0gY2hhbmdlIHJlcXVlc3QgKi8KI2RlZmluZSAgIFNXRjE0X0FQTV9ISUJFUk5BVEUJMHg0CiNkZWZpbmUgICBTV0YxNF9BUE1fU1VTUEVORAkweDMKI2RlZmluZSAgIFNXRjE0X0FQTV9TVEFOREJZCTB4MQojZGVmaW5lICAgU1dGMTRfQVBNX1JFU1RPUkUJMHgwCgovKiBBZGQgdGhlIGRldmljZSBjbGFzcyBmb3IgTEZQLCBUViwgSERNSSAqLwojZGVmaW5lCSBERVZJQ0VfVFlQRV9JTlRfTEZQCTB4MTAyMgojZGVmaW5lCSBERVZJQ0VfVFlQRV9JTlRfVFYJMHgxMDA5CiNkZWZpbmUJIERFVklDRV9UWVBFX0hETUkJMHg2MEQyCiNkZWZpbmUJIERFVklDRV9UWVBFX0RQCQkweDY4QzYKI2RlZmluZQkgREVWSUNFX1RZUEVfZURQCTB4NzhDNgoKLyogZGVmaW5lIHRoZSBEVk8gcG9ydCBmb3IgSERNSSBvdXRwdXQgdHlwZSAqLwojZGVmaW5lCQlEVk9fQgkJMQojZGVmaW5lCQlEVk9fQwkJMgojZGVmaW5lCQlEVk9fRAkJMwoKLyogZGVmaW5lIHRoZSBQT1JUIGZvciBEUCBvdXRwdXQgdHlwZSAqLwojZGVmaW5lCQlQT1JUX0lEUEIJNwojZGVmaW5lCQlQT1JUX0lEUEMJOAojZGVmaW5lCQlQT1JUX0lEUEQJOQoKI2VuZGlmIC8qIF9JODMwX0JJT1NfSF8gKi8K