LyoKICogIGFybWJvb3QgLSBTdGFydHVwIENvZGUgZm9yIEFSTTcyMCBDUFUtY29yZQogKgogKiAgQ29weXJpZ2h0IChjKSAyMDAxCU1hcml1cyBHcvZnZXIgPG1hZ0BzeXNnby5kZT4KICogIENvcHlyaWdodCAoYykgMjAwMglBbGV4IFr8cGtlIDxhenVAc3lzZ28uZGU+CiAqCiAqIFNlZSBmaWxlIENSRURJVFMgZm9yIGxpc3Qgb2YgcGVvcGxlIHdobyBjb250cmlidXRlZCB0byB0aGlzCiAqIHByb2plY3QuCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IKICogbW9kaWZ5IGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMKICogcHVibGlzaGVkIGJ5IHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVpdGhlciB2ZXJzaW9uIDIgb2YKICogdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLAogKiBidXQgV0lUSE9VVCBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZgogKiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuCSBTZWUgdGhlCiAqIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvciBtb3JlIGRldGFpbHMuCiAqCiAqIFlvdSBzaG91bGQgaGF2ZSByZWNlaXZlZCBhIGNvcHkgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlCiAqIGFsb25nIHdpdGggdGhpcyBwcm9ncmFtOyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDU5IFRlbXBsZSBQbGFjZSwgU3VpdGUgMzMwLCBCb3N0b24sCiAqIE1BIDAyMTExLTEzMDcgVVNBCiAqLwoKI2luY2x1ZGUgPGFzbS1vZmZzZXRzLmg+CiNpbmNsdWRlIDxjb25maWcuaD4KI2luY2x1ZGUgPHZlcnNpb24uaD4KI2luY2x1ZGUgPGFzbS9oYXJkd2FyZS5oPgoKLyoKICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoKICogSnVtcCB2ZWN0b3IgdGFibGUgYXMgaW4gdGFibGUgMy4xIGluIFsxXQogKgogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKi8KCgouZ2xvYmwgX3N0YXJ0Cl9zdGFydDogYglyZXNldAoJbGRyCXBjLCBfdW5kZWZpbmVkX2luc3RydWN0aW9uCglsZHIJcGMsIF9zb2Z0d2FyZV9pbnRlcnJ1cHQKCWxkcglwYywgX3ByZWZldGNoX2Fib3J0CglsZHIJcGMsIF9kYXRhX2Fib3J0CiNpZmRlZiBDT05GSUdfTFBDMjI5MgoJLndvcmQJMHhCNDQwNUY3NiAvKiAyJ3MgY29tcGxlbWVudCBvZiB0aGUgY2hlY2tzdW0gb2YgdGhlIHZlY3RvcnMgKi8KI2Vsc2UKCWxkcglwYywgX25vdF91c2VkCiNlbmRpZgoJbGRyCXBjLCBfaXJxCglsZHIJcGMsIF9maXEKCl91bmRlZmluZWRfaW5zdHJ1Y3Rpb246IC53b3JkIHVuZGVmaW5lZF9pbnN0cnVjdGlvbgpfc29mdHdhcmVfaW50ZXJydXB0Ogkud29yZCBzb2Z0d2FyZV9pbnRlcnJ1cHQKX3ByZWZldGNoX2Fib3J0Ogkud29yZCBwcmVmZXRjaF9hYm9ydApfZGF0YV9hYm9ydDoJCS53b3JkIGRhdGFfYWJvcnQKX25vdF91c2VkOgkJLndvcmQgbm90X3VzZWQKX2lycToJCQkud29yZCBpcnEKX2ZpcToJCQkud29yZCBmaXEKCgkuYmFsaWdubCAxNiwweGRlYWRiZWVmCgoKLyoKICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoKICogU3RhcnR1cCBDb2RlIChyZXNldCB2ZWN0b3IpCiAqCiAqIGRvIGltcG9ydGFudCBpbml0IG9ubHkgaWYgd2UgZG9uJ3Qgc3RhcnQgZnJvbSBSQU0hCiAqIHJlbG9jYXRlIGFybWJvb3QgdG8gcmFtCiAqIHNldHVwIHN0YWNrCiAqIGp1bXAgdG8gc2Vjb25kIHN0YWdlCiAqCiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqLwoKLmdsb2JsIF9URVhUX0JBU0UKX1RFWFRfQkFTRToKCS53b3JkCUNPTkZJR19TWVNfVEVYVF9CQVNFCgovKgogKiBUaGVzZSBhcmUgZGVmaW5lZCBpbiB0aGUgYm9hcmQtc3BlY2lmaWMgbGlua2VyIHNjcmlwdC4KICogU3VidHJhY3RpbmcgX3N0YXJ0IGZyb20gdGhlbSBsZXRzIHRoZSBsaW5rZXIgcHV0IHRoZWlyCiAqIHJlbGF0aXZlIHBvc2l0aW9uIGluIHRoZSBleGVjdXRhYmxlIGluc3RlYWQgb2YgbGVhdmluZwogKiB0aGVtIG51bGwuCiAqLwouZ2xvYmwgX2Jzc19zdGFydF9vZnMKX2Jzc19zdGFydF9vZnM6Cgkud29yZCBfX2Jzc19zdGFydCAtIF9zdGFydAoKLmdsb2JsIF9ic3NfZW5kX29mcwpfYnNzX2VuZF9vZnM6Cgkud29yZCBfX2Jzc19lbmRfXyAtIF9zdGFydAoKLmdsb2JsIF9lbmRfb2ZzCl9lbmRfb2ZzOgoJLndvcmQgX2VuZCAtIF9zdGFydAoKI2lmZGVmIENPTkZJR19VU0VfSVJRCi8qIElSUSBzdGFjayBtZW1vcnkgKGNhbGN1bGF0ZWQgYXQgcnVuLXRpbWUpICovCi5nbG9ibCBJUlFfU1RBQ0tfU1RBUlQKSVJRX1NUQUNLX1NUQVJUOgoJLndvcmQJMHgwYmFkYzBkZQoKLyogSVJRIHN0YWNrIG1lbW9yeSAoY2FsY3VsYXRlZCBhdCBydW4tdGltZSkgKi8KLmdsb2JsIEZJUV9TVEFDS19TVEFSVApGSVFfU1RBQ0tfU1RBUlQ6Cgkud29yZCAweDBiYWRjMGRlCiNlbmRpZgoKLyogSVJRIHN0YWNrIG1lbW9yeSAoY2FsY3VsYXRlZCBhdCBydW4tdGltZSkgKyA4IGJ5dGVzICovCi5nbG9ibCBJUlFfU1RBQ0tfU1RBUlRfSU4KSVJRX1NUQUNLX1NUQVJUX0lOOgoJLndvcmQJMHgwYmFkYzBkZQoKLyoKICogdGhlIGFjdHVhbCByZXNldCBjb2RlCiAqLwoKcmVzZXQ6CgkvKgoJICogc2V0IHRoZSBjcHUgdG8gU1ZDMzIgbW9kZQoJICovCgltcnMJcjAsY3BzcgoJYmljCXIwLHIwLCMweDFmCglvcnIJcjAscjAsIzB4ZDMKCW1zcgljcHNyLHIwCgoJLyoKCSAqIHdlIGRvIHN5cy1jcml0aWNhbCBpbml0cyBvbmx5IGF0IHJlYm9vdCwKCSAqIG5vdCB3aGVuIGJvb3RpbmcgZnJvbSByYW0hCgkgKi8KI2lmbmRlZiBDT05GSUdfU0tJUF9MT1dMRVZFTF9JTklUCglibAljcHVfaW5pdF9jcml0CiNlbmRpZgoKI2lmZGVmIENPTkZJR19MUEMyMjkyCglibAlsb3dsZXZlbF9pbml0CiNlbmRpZgoKLyogU2V0IHN0YWNrcG9pbnRlciBpbiBpbnRlcm5hbCBSQU0gdG8gY2FsbCBib2FyZF9pbml0X2YgKi8KY2FsbF9ib2FyZF9pbml0X2Y6CglsZHIJc3AsID0oQ09ORklHX1NZU19JTklUX1NQX0FERFIpCgliaWMJc3AsIHNwLCAjNyAvKiA4LWJ5dGUgYWxpZ25tZW50IGZvciBBQkkgY29tcGxpYW5jZSAqLwoJbGRyCXIwLD0weDAwMDAwMDAwCglibAlib2FyZF9pbml0X2YKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKi8KCi8qCiAqIHZvaWQgcmVsb2NhdGVfY29kZSAoYWRkcl9zcCwgZ2QsIGFkZHJfbW9uaSkKICoKICogVGhpcyAiZnVuY3Rpb24iIGRvZXMgbm90IHJldHVybiwgaW5zdGVhZCBpdCBjb250aW51ZXMgaW4gUkFNCiAqIGFmdGVyIHJlbG9jYXRpbmcgdGhlIG1vbml0b3IgY29kZS4KICoKICovCgkuZ2xvYmwJcmVsb2NhdGVfY29kZQpyZWxvY2F0ZV9jb2RlOgoJbW92CXI0LCByMAkvKiBzYXZlIGFkZHJfc3AgKi8KCW1vdglyNSwgcjEJLyogc2F2ZSBhZGRyIG9mIGdkICovCgltb3YJcjYsIHIyCS8qIHNhdmUgYWRkciBvZiBkZXN0aW5hdGlvbiAqLwoKCS8qIFNldCB1cCB0aGUgc3RhY2sJCQkJCQkgICAgKi8Kc3RhY2tfc2V0dXA6Cgltb3YJc3AsIHI0CgoJYWRyCXIwLCBfc3RhcnQKCWNtcAlyMCwgcjYKCWJlcQljbGVhcl9ic3MJCS8qIHNraXAgcmVsb2NhdGlvbiAqLwoJbW92CXIxLCByNgkJCS8qIHIxIDwtIHNjcmF0Y2ggZm9yIGNvcHlfbG9vcCAqLwoJbGRyCXIzLCBfYnNzX3N0YXJ0X29mcwoJYWRkCXIyLCByMCwgcjMJCS8qIHIyIDwtIHNvdXJjZSBlbmQgYWRkcmVzcwkgICAgKi8KCmNvcHlfbG9vcDoKCWxkbWlhCXIwISwge3I5LXIxMH0JCS8qIGNvcHkgZnJvbSBzb3VyY2UgYWRkcmVzcyBbcjBdICAgICovCglzdG1pYQlyMSEsIHtyOS1yMTB9CQkvKiBjb3B5IHRvICAgdGFyZ2V0IGFkZHJlc3MgW3IxXSAgICAqLwoJY21wCXIwLCByMgkJCS8qIHVudGlsIHNvdXJjZSBlbmQgYWRkcmVzcyBbcjJdICAgICovCglibG8JY29weV9sb29wCgojaWZuZGVmIENPTkZJR19QUkVMT0FERVIKCS8qCgkgKiBmaXggLnJlbC5keW4gcmVsb2NhdGlvbnMKCSAqLwoJbGRyCXIwLCBfVEVYVF9CQVNFCQkvKiByMCA8LSBUZXh0IGJhc2UgKi8KCXN1YglyOSwgcjYsIHIwCQkvKiByOSA8LSByZWxvY2F0aW9uIG9mZnNldCAqLwoJbGRyCXIxMCwgX2R5bnN5bV9zdGFydF9vZnMJLyogcjEwIDwtIHN5bSB0YWJsZSBvZnMgKi8KCWFkZAlyMTAsIHIxMCwgcjAJCS8qIHIxMCA8LSBzeW0gdGFibGUgaW4gRkxBU0ggKi8KCWxkcglyMiwgX3JlbF9keW5fc3RhcnRfb2ZzCS8qIHIyIDwtIHJlbCBkeW4gc3RhcnQgb2ZzICovCglhZGQJcjIsIHIyLCByMAkJLyogcjIgPC0gcmVsIGR5biBzdGFydCBpbiBGTEFTSCAqLwoJbGRyCXIzLCBfcmVsX2R5bl9lbmRfb2ZzCS8qIHIzIDwtIHJlbCBkeW4gZW5kIG9mcyAqLwoJYWRkCXIzLCByMywgcjAJCS8qIHIzIDwtIHJlbCBkeW4gZW5kIGluIEZMQVNIICovCmZpeGxvb3A6CglsZHIJcjAsIFtyMl0JCS8qIHIwIDwtIGxvY2F0aW9uIHRvIGZpeCB1cCwgSU4gRkxBU0ghICovCglhZGQJcjAsIHIwLCByOQkJLyogcjAgPC0gbG9jYXRpb24gdG8gZml4IHVwIGluIFJBTSAqLwoJbGRyCXIxLCBbcjIsICM0XQoJYW5kCXI3LCByMSwgIzB4ZmYKCWNtcAlyNywgIzIzCQkJLyogcmVsYXRpdmUgZml4dXA/ICovCgliZXEJZml4cmVsCgljbXAJcjcsICMyCQkJLyogYWJzb2x1dGUgZml4dXA/ICovCgliZXEJZml4YWJzCgkvKiBpZ25vcmUgdW5rbm93biB0eXBlIG9mIGZpeHVwICovCgliCWZpeG5leHQKZml4YWJzOgoJLyogYWJzb2x1dGUgZml4OiBzZXQgbG9jYXRpb24gdG8gKG9mZnNldCkgc3ltYm9sIHZhbHVlICovCgltb3YJcjEsIHIxLCBMU1IgIzQJCS8qIHIxIDwtIHN5bWJvbCBpbmRleCBpbiAuZHluc3ltICovCglhZGQJcjEsIHIxMCwgcjEJCS8qIHIxIDwtIGFkZHJlc3Mgb2Ygc3ltYm9sIGluIHRhYmxlICovCglsZHIJcjEsIFtyMSwgIzRdCQkvKiByMSA8LSBzeW1ib2wgdmFsdWUgKi8KCWFkZAlyMSwgcjEsIHI5CQkvKiByMSA8LSByZWxvY2F0ZWQgc3ltIGFkZHIgKi8KCWIJZml4bmV4dApmaXhyZWw6CgkvKiByZWxhdGl2ZSBmaXg6IGluY3JlYXNlIGxvY2F0aW9uIGJ5IG9mZnNldCAqLwoJbGRyCXIxLCBbcjBdCglhZGQJcjEsIHIxLCByOQpmaXhuZXh0OgoJc3RyCXIxLCBbcjBdCglhZGQJcjIsIHIyLCAjOAkJLyogZWFjaCByZWwuZHluIGVudHJ5IGlzIDggYnl0ZXMgKi8KCWNtcAlyMiwgcjMKCWJsbwlmaXhsb29wCiNlbmRpZgoKY2xlYXJfYnNzOgojaWZuZGVmIENPTkZJR19QUkVMT0FERVIKCWxkcglyMCwgX2Jzc19zdGFydF9vZnMKCWxkcglyMSwgX2Jzc19lbmRfb2ZzCgltb3YJcjQsIHI2CQkJLyogcmVsb2MgYWRkciAqLwoJYWRkCXIwLCByMCwgcjQKCWFkZAlyMSwgcjEsIHI0Cgltb3YJcjIsICMweDAwMDAwMDAwCQkvKiBjbGVhcgkJCSAgICAqLwoKY2xic3NfbDpzdHIJcjIsIFtyMF0JCS8qIGNsZWFyIGxvb3AuLi4JCSAgICAqLwoJYWRkCXIwLCByMCwgIzQKCWNtcAlyMCwgcjEKCWJuZQljbGJzc19sCgoJYmwgY29sb3VyZWRfTEVEX2luaXQKCWJsIHJlZF9MRURfb24KI2VuZGlmCgovKgogKiBXZSBhcmUgZG9uZS4gRG8gbm90IHJldHVybiwgaW5zdGVhZCBicmFuY2ggdG8gc2Vjb25kIHBhcnQgb2YgYm9hcmQKICogaW5pdGlhbGl6YXRpb24sIG5vdyBydW5uaW5nIGZyb20gUkFNLgogKi8KCWxkcglyMCwgX2JvYXJkX2luaXRfcl9vZnMKCWFkcglyMSwgX3N0YXJ0CglhZGQJbHIsIHIwLCByMQoJYWRkCWxyLCBsciwgcjkKCS8qIHNldHVwIHBhcmFtZXRlcnMgZm9yIGJvYXJkX2luaXRfciAqLwoJbW92CXIwLCByNQkJLyogZ2RfdCAqLwoJbW92CXIxLCByNgkJLyogZGVzdF9hZGRyICovCgkvKiBqdW1wIHRvIGl0IC4uLiAqLwoJbW92CXBjLCBscgoKX2JvYXJkX2luaXRfcl9vZnM6Cgkud29yZCBib2FyZF9pbml0X3IgLSBfc3RhcnQKCl9yZWxfZHluX3N0YXJ0X29mczoKCS53b3JkIF9fcmVsX2R5bl9zdGFydCAtIF9zdGFydApfcmVsX2R5bl9lbmRfb2ZzOgoJLndvcmQgX19yZWxfZHluX2VuZCAtIF9zdGFydApfZHluc3ltX3N0YXJ0X29mczoKCS53b3JkIF9fZHluc3ltX3N0YXJ0IC0gX3N0YXJ0CgovKgogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgogKiBDUFVfaW5pdF9jcml0aWNhbCByZWdpc3RlcnMKICoKICogc2V0dXAgaW1wb3J0YW50IHJlZ2lzdGVycwogKiBzZXR1cCBtZW1vcnkgdGltaW5nCiAqCiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqLwoKI2lmIGRlZmluZWQoQ09ORklHX0lNUEE3KSB8fCBkZWZpbmVkKENPTkZJR19FUDczMTIpIHx8IGRlZmluZWQoQ09ORklHX0FSTUFESUxMTykKCi8qIEludGVydXB0LUNvbnRyb2xsZXIgYmFzZSBhZGRyZXNzZXMgKi8KSU5UTVIxOgkJLndvcmQJMHg4MDAwMDI4MCBAIDMyIGJpdCBzaXplCklOVE1SMjoJCS53b3JkCTB4ODAwMDEyODAgQCAxNiBiaXQgc2l6ZQpJTlRNUjM6CQkud29yZAkweDgwMDAyMjgwIEAgIDggYml0IHNpemUKCi8qIFNZU0NPTnMgKi8KU1lTQ09OMToJLndvcmQJMHg4MDAwMDEwMApTWVNDT04yOgkud29yZAkweDgwMDAxMTAwClNZU0NPTjM6CS53b3JkCTB4ODAwMDIyMDAKCiNkZWZpbmUgQ0xLQ1RMCSAgICAgICAweDYgIC8qIG1hc2sgKi8KI2RlZmluZSBDTEtDVExfMTggICAgICAweDAgIC8qIDE4LjQzMiBNSHogKi8KI2RlZmluZSBDTEtDVExfMzYgICAgICAweDIgIC8qIDM2Ljg2NCBNSHogKi8KI2RlZmluZSBDTEtDVExfNDkgICAgICAweDQgIC8qIDQ5LjE1MiBNSHogKi8KI2RlZmluZSBDTEtDVExfNzMgICAgICAweDYgIC8qIDczLjcyOCBNSHogKi8KCiNlbGlmIGRlZmluZWQoQ09ORklHX0xQQzIyOTIpClBMTENGR19BRFI6CS53b3JkCVBMTENGRwpQTExGRUVEX0FEUjoJLndvcmQJUExMRkVFRApQTExDT05fQURSOgkud29yZAlQTExDT04KUExMU1RBVF9BRFI6CS53b3JkCVBMTFNUQVQKVlBCRElWX0FEUjoJLndvcmQJVlBCRElWCk1FTU1BUF9BRFI6CS53b3JkCU1FTU1BUAoKI2VuZGlmCgpjcHVfaW5pdF9jcml0OgojaWYgZGVmaW5lZChDT05GSUdfSU1QQTcpIHx8IGRlZmluZWQoQ09ORklHX0VQNzMxMikgfHwgZGVmaW5lZChDT05GSUdfQVJNQURJTExPKQoKCS8qCgkgKiBtYXNrIGFsbCBJUlFzIGJ5IGNsZWFyaW5nIGFsbCBiaXRzIGluIHRoZSBJTlRNUnMKCSAqLwoJbW92CXIxLCAjMHgwMAoJbGRyCXIwLCBJTlRNUjEKCXN0cglyMSwgW3IwXQoJbGRyCXIwLCBJTlRNUjIKCXN0cglyMSwgW3IwXQoJbGRyCXIwLCBJTlRNUjMKCXN0cglyMSwgW3IwXQoKCS8qCgkgKiBmbHVzaCB2NCBJL0QgY2FjaGVzCgkgKi8KCW1vdglyMCwgIzAKCW1jcglwMTUsIDAsIHIwLCBjNywgYzcsIDAJLyogZmx1c2ggdjMvdjQgY2FjaGUgKi8KCW1jcglwMTUsIDAsIHIwLCBjOCwgYzcsIDAJLyogZmx1c2ggdjQgVExCICovCgoJLyoKCSAqIGRpc2FibGUgTU1VIHN0dWZmIGFuZCBjYWNoZXMKCSAqLwoJbXJjCXAxNSwwLHIwLGMxLGMwCgliaWMJcjAsIHIwLCAjMHgwMDAwMjMwMAlAIGNsZWFyIGJpdHMgMTMsIDk6OCAoLS1WLSAtLVJTKQoJYmljCXIwLCByMCwgIzB4MDAwMDAwOGYJQCBjbGVhciBiaXRzIDcsIDM6MCAoQi0tLSBXQ0FNKQoJb3JyCXIwLCByMCwgIzB4MDAwMDAwMDIJQCBzZXQgYml0IDIgKEEpIEFsaWduCgltY3IJcDE1LDAscjAsYzEsYzAKI2VsaWYgZGVmaW5lZChDT05GSUdfTkVUQVJNKQoJLyoKCSAqIHByaW9yIHRvIHNvZnR3YXJlIHJlc2V0IDogbmVlZCB0byBzZXQgcGluIFBPUlRDNCB0byBiZSAqSFJFU0VUCgkgKi8KCWxkcglyMCwgPU5FVEFSTV9HRU5fTU9EVUxFX0JBU0UKCWxkcglyMSwgPShORVRBUk1fR0VOX1BPUlRfTU9ERSgweDEwKSB8IFwKCQkJTkVUQVJNX0dFTl9QT1JUX0RJUigweDEwKSkKCXN0cglyMSwgW3IwLCAjK05FVEFSTV9HRU5fUE9SVENdCgkvKgoJICogc29mdHdhcmUgcmVzZXQgOiBzZWUgSFcgUmVmLiBHdWlkZSA4LjIuNCA6IFNvZnR3YXJlIFNlcnZpY2UgcmVnaXN0ZXIKCSAqCQkgICAgZm9yIGFuIGV4cGxhbmF0aW9uIG9mIHRoaXMgcHJvY2VzcwoJICovCglsZHIJcjAsID1ORVRBUk1fR0VOX01PRFVMRV9CQVNFCglsZHIJcjEsID1ORVRBUk1fR0VOX1NXX1NWQ19SRVNFVEEKCXN0cglyMSwgW3IwLCAjK05FVEFSTV9HRU5fU09GVFdBUkVfU0VSVklDRV0KCWxkcglyMSwgPU5FVEFSTV9HRU5fU1dfU1ZDX1JFU0VUQgoJc3RyCXIxLCBbcjAsICMrTkVUQVJNX0dFTl9TT0ZUV0FSRV9TRVJWSUNFXQoJbGRyCXIxLCA9TkVUQVJNX0dFTl9TV19TVkNfUkVTRVRBCglzdHIJcjEsIFtyMCwgIytORVRBUk1fR0VOX1NPRlRXQVJFX1NFUlZJQ0VdCglsZHIJcjEsID1ORVRBUk1fR0VOX1NXX1NWQ19SRVNFVEIKCXN0cglyMSwgW3IwLCAjK05FVEFSTV9HRU5fU09GVFdBUkVfU0VSVklDRV0KCS8qCgkgKiBzZXR1cCBQTEwgYW5kIFN5c3RlbSBDb25maWcKCSAqLwoJbGRyCXIwLCA9TkVUQVJNX0dFTl9NT0RVTEVfQkFTRQoKCWxkcglyMSwgPSgJTkVUQVJNX0dFTl9TWVNfQ0ZHX0xFTkRJQU4gfCBcCgkJCU5FVEFSTV9HRU5fU1lTX0NGR19CVVNGVUxMIHwgXAoJCQlORVRBUk1fR0VOX1NZU19DRkdfVVNFUl9FTiB8IFwKCQkJTkVUQVJNX0dFTl9TWVNfQ0ZHX0FMSUdOX0FCT1JUIHwgXAoJCQlORVRBUk1fR0VOX1NZU19DRkdfQlVTQVJCX0lOVCB8IFwKCQkJTkVUQVJNX0dFTl9TWVNfQ0ZHX0JVU01PTl9FTiApCgoJc3RyCXIxLCBbcjAsICMrTkVUQVJNX0dFTl9TWVNURU1fQ09OVFJPTF0KCiNpZm5kZWYgQ09ORklHX05FVEFSTV9QTExfQllQQVNTCglsZHIJcjEsID0oCU5FVEFSTV9HRU5fUExMX0NUTF9QTExDTlQoTkVUQVJNX1BMTF9DT1VOVF9WQUwpIHwgXAoJCQlORVRBUk1fR0VOX1BMTF9DVExfUE9MVFNUX0RFRiB8IFwKCQkJTkVUQVJNX0dFTl9QTExfQ1RMX0lORElWKDEpIHwgXAoJCQlORVRBUk1fR0VOX1BMTF9DVExfSUNQX0RFRiB8IFwKCQkJTkVUQVJNX0dFTl9QTExfQ1RMX09VVERJVigyKSApCglzdHIJcjEsIFtyMCwgIytORVRBUk1fR0VOX1BMTF9DT05UUk9MXQojZW5kaWYKCgkvKgoJICogbWFzayBhbGwgSVJRcyBieSBjbGVhcmluZyBhbGwgYml0cyBpbiB0aGUgSU5UTVJzCgkgKi8KCW1vdglyMSwgIzAKCWxkcglyMCwgPU5FVEFSTV9HRU5fTU9EVUxFX0JBU0UKCXN0cglyMSwgW3IwLCAjK05FVEFSTV9HRU5fSU5UUl9FTkFCTEVdCgojZWxpZiBkZWZpbmVkKENPTkZJR19TM0M0NTEwQikKCgkvKgoJICogTWFzayBvZmYgYWxsIElSUSBzb3VyY2VzCgkgKi8KCWxkcglyMSwgPVJFR19JTlRNQVNLCglsZHIJcjAsID0weDNGRkZGRgoJc3RyCXIwLCBbcjFdCgoJLyoKCSAqIERpc2FibGUgQ2FjaGUKCSAqLwoJbGRyIHIwLCA9UkVHX1NZU0NGRwoJbGRyIHIxLCA9MHg4M2ZmZmZhMAkvKiBjYWNoZS1kaXNhYmxlZCAgKi8KCXN0ciByMSwgW3IwXQoKI2VsaWYgZGVmaW5lZChDT05GSUdfSU5URUdSQVRPUikgJiYgZGVmaW5lZChDT05GSUdfQVJDSF9JTlRFR1JBVE9SKQoJLyogTm8gc3BlY2lmaWMgaW5pdGlhbGlzYXRpb24gZm9yIEludGVncmF0b3JBUC9DTTcyMFQgYXMgeWV0ICovCiNlbGlmIGRlZmluZWQoQ09ORklHX0xQQzIyOTIpCgkvKiBTZXQtdXAgUExMICovCgltb3YJcjMsICMweEFBCgltb3YJcjQsICMweDU1CgkvKiBGaXJzdCBkaXNjb25uZWN0IGFuZCBkaXNhYmxlIHRoZSBQTEwgKi8KCWxkcglyMCwgUExMQ09OX0FEUgoJbW92CXIxLCAjMHgwMAoJc3RyCXIxLCBbcjBdCglsZHIJcjAsIFBMTEZFRURfQURSIC8qIHN0YXJ0IGZlZWQgc2VxdWVuY2UgKi8KCXN0cglyMywgW3IwXQoJc3RyCXI0LCBbcjBdCS8qIGZlZWQgc2VxdWVuY2UgZG9uZSAqLwoJLyogU2V0IG5ldyBNIGFuZCBQIHZhbHVlcyAqLwoJbGRyCXIwLCBQTExDRkdfQURSCgltb3YJcjEsICMweDIzCS8qIE09NCBhbmQgUD0yICovCglzdHIJcjEsIFtyMF0KCWxkcglyMCwgUExMRkVFRF9BRFIgLyogc3RhcnQgZmVlZCBzZXF1ZW5jZSAqLwoJc3RyCXIzLCBbcjBdCglzdHIJcjQsIFtyMF0JLyogZmVlZCBzZXF1ZW5jZSBkb25lICovCgkvKiBUaGVuIGVuYWJsZSB0aGUgUExMICovCglsZHIJcjAsIFBMTENPTl9BRFIKCW1vdglyMSwgIzB4MDEJLyogUExMIGVuYWJsZSBiaXQgKi8KCXN0cglyMSwgW3IwXQoJbGRyCXIwLCBQTExGRUVEX0FEUiAvKiBzdGFydCBmZWVkIHNlcXVlbmNlICovCglzdHIJcjMsIFtyMF0KCXN0cglyNCwgW3IwXQkvKiBmZWVkIHNlcXVlbmNlIGRvbmUgKi8KCS8qIFdhaXQgZm9yIHRoZSBsb2NrICovCglsZHIJcjAsIFBMTFNUQVRfQURSCgltb3YJcjEsICMweDQwMAkvKiBsb2NrIGJpdCAqLwpsb2NrX2xvb3A6CglsZHIJcjIsIFtyMF0KCWFuZAlyMiwgcjEsIHIyCgljbXAJcjIsICMwCgliZXEJbG9ja19sb29wCgkvKiBBbmQgZmluYWxseSBjb25uZWN0IHRoZSBQTEwgKi8KCWxkcglyMCwgUExMQ09OX0FEUgoJbW92CXIxLCAjMHgwMwkvKiBQTEwgZW5hYmxlIGJpdCBhbmQgY29ubmVjdCBiaXQgKi8KCXN0cglyMSwgW3IwXQoJbGRyCXIwLCBQTExGRUVEX0FEUiAvKiBzdGFydCBmZWVkIHNlcXVlbmNlICovCglzdHIJcjMsIFtyMF0KCXN0cglyNCwgW3IwXQkvKiBmZWVkIHNlcXVlbmNlIGRvbmUgKi8KCS8qIFNldC11cCBWUEJESVYgcmVnaXN0ZXIgKi8KCWxkcglyMCwgVlBCRElWX0FEUgoJbW92CXIxLCAjMHgwMQkvKiBWUEIgY2xvY2sgaXMgc2FtZSBhcyBwcm9jZXNzIGNsb2NrICovCglzdHIJcjEsIFtyMF0KI2Vsc2UKI2Vycm9yIE5vIGNwdV9pbml0X2NyaXQoKSBkZWZpbmVkIGZvciBjdXJyZW50IENQVSB0eXBlCiNlbmRpZgoKI2lmZGVmIENPTkZJR19BUk03X1JFVkQKCS8qIHNldCBjbG9jayBzcGVlZCAqLwoJLyogISEhIHdlIHJ1biBAIDM2IE1IeiBkdWUgdG8gYSBoYXJkd2FyZSBmbGF3IGluIFJldi4gRCBwcm9jZXNzb3JzICovCgkvKiAhISEgbm90IGRvaW5nIERSQU0gcmVmcmVzaCBwcm9wZXJseSEgKi8KCWxkcglyMCwgU1lTQ09OMwoJbGRyCXIxLCBbcjBdCgliaWMJcjEsIHIxLCAjQ0xLQ1RMCglvcnIJcjEsIHIxLCAjQ0xLQ1RMXzM2CglzdHIJcjEsIFtyMF0KI2VuZGlmCgojaWZuZGVmIENPTkZJR19MUEMyMjkyCgltb3YJaXAsIGxyCgkvKgoJICogYmVmb3JlIHJlbG9jYXRpbmcsIHdlIGhhdmUgdG8gc2V0dXAgUkFNIHRpbWluZwoJICogYmVjYXVzZSBtZW1vcnkgdGltaW5nIGlzIGJvYXJkLWRlcGVuZGVudCwgeW91IHdpbGwKCSAqIGZpbmQgYSBsb3dsZXZlbF9pbml0LlMgaW4geW91ciBib2FyZCBkaXJlY3RvcnkuCgkgKi8KCWJsCWxvd2xldmVsX2luaXQKCW1vdglsciwgaXAKI2VuZGlmCgoJbW92CXBjLCBscgoKCi8qCiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCiAqIEludGVycnVwdCBoYW5kbGluZwogKgogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKi8KCkAKQCBJUlEgc3RhY2sgZnJhbWUuCkAKI2RlZmluZSBTX0ZSQU1FX1NJWkUJNzIKCiNkZWZpbmUgU19PTERfUjAJNjgKI2RlZmluZSBTX1BTUgkJNjQKI2RlZmluZSBTX1BDCQk2MAojZGVmaW5lIFNfTFIJCTU2CiNkZWZpbmUgU19TUAkJNTIKCiNkZWZpbmUgU19JUAkJNDgKI2RlZmluZSBTX0ZQCQk0NAojZGVmaW5lIFNfUjEwCQk0MAojZGVmaW5lIFNfUjkJCTM2CiNkZWZpbmUgU19SOAkJMzIKI2RlZmluZSBTX1I3CQkyOAojZGVmaW5lIFNfUjYJCTI0CiNkZWZpbmUgU19SNQkJMjAKI2RlZmluZSBTX1I0CQkxNgojZGVmaW5lIFNfUjMJCTEyCiNkZWZpbmUgU19SMgkJOAojZGVmaW5lIFNfUjEJCTQKI2RlZmluZSBTX1IwCQkwCgojZGVmaW5lIE1PREVfU1ZDIDB4MTMKI2RlZmluZSBJX0JJVAkgMHg4MAoKLyoKICogdXNlIGJhZF9zYXZlX3VzZXJfcmVncyBmb3IgYWJvcnQvcHJlZmV0Y2gvdW5kZWYvc3dpIC4uLgogKiB1c2UgaXJxX3NhdmVfdXNlcl9yZWdzIC8gaXJxX3Jlc3RvcmVfdXNlcl9yZWdzIGZvciBJUlEvRklRIGhhbmRsaW5nCiAqLwoKCS5tYWNybwliYWRfc2F2ZV91c2VyX3JlZ3MKCXN1YglzcCwgc3AsICNTX0ZSQU1FX1NJWkUKCXN0bWlhCXNwLCB7cjAgLSByMTJ9CQkJQCBDYWxsaW5nIHIwLXIxMgoJYWRkCXI4LCBzcCwgI1NfUEMKCglsZHIJcjIsIElSUV9TVEFDS19TVEFSVF9JTgoJbGRtaWEJcjIsIHtyMiAtIHI0fQkJCUAgZ2V0IHBjLCBjcHNyLCBvbGRfcjAKCWFkZAlyMCwgc3AsICNTX0ZSQU1FX1NJWkUJCUAgcmVzdG9yZSBzcF9TVkMKCglhZGQJcjUsIHNwLCAjU19TUAoJbW92CXIxLCBscgoJc3RtaWEJcjUsIHtyMCAtIHI0fQkJCUAgc2F2ZSBzcF9TVkMsIGxyX1NWQywgcGMsIGNwc3IsIG9sZF9yCgltb3YJcjAsIHNwCgkuZW5kbQoKCS5tYWNybwlpcnFfc2F2ZV91c2VyX3JlZ3MKCXN1YglzcCwgc3AsICNTX0ZSQU1FX1NJWkUKCXN0bWlhCXNwLCB7cjAgLSByMTJ9CQkJQCBDYWxsaW5nIHIwLXIxMgoJYWRkCXI4LCBzcCwgI1NfUEMKCXN0bWRiCXI4LCB7c3AsIGxyfV4JCQlAIENhbGxpbmcgU1AsIExSCglzdHIJbHIsIFtyOCwgIzBdCQkJQCBTYXZlIGNhbGxpbmcgUEMKCW1ycwlyNiwgc3BzcgoJc3RyCXI2LCBbcjgsICM0XQkJCUAgU2F2ZSBDUFNSCglzdHIJcjAsIFtyOCwgIzhdCQkJQCBTYXZlIE9MRF9SMAoJbW92CXIwLCBzcAoJLmVuZG0KCgkubWFjcm8JaXJxX3Jlc3RvcmVfdXNlcl9yZWdzCglsZG1pYQlzcCwge3IwIC0gbHJ9XgkJCUAgQ2FsbGluZyByMCAtIGxyCgltb3YJcjAsIHIwCglsZHIJbHIsIFtzcCwgI1NfUENdCQkJQCBHZXQgUEMKCWFkZAlzcCwgc3AsICNTX0ZSQU1FX1NJWkUKCXN1YnMJcGMsIGxyLCAjNAkJCUAgcmV0dXJuICYgbW92ZSBzcHNyX3N2YyBpbnRvIGNwc3IKCS5lbmRtCgoJLm1hY3JvIGdldF9iYWRfc3RhY2sKCWxkcglyMTMsIElSUV9TVEFDS19TVEFSVF9JTgkJQCBzZXR1cCBvdXIgbW9kZSBzdGFjawoKCXN0cglsciwgW3IxM10JCQlAIHNhdmUgY2FsbGVyIGxyIC8gc3BzcgoJbXJzCWxyLCBzcHNyCglzdHIJbHIsIFtyMTMsICM0XQoKCW1vdglyMTMsICNNT0RFX1NWQwkJCUAgcHJlcGFyZSBTVkMtTW9kZQoJbXNyCXNwc3JfYywgcjEzCgltb3YJbHIsIHBjCgltb3ZzCXBjLCBscgoJLmVuZG0KCgkubWFjcm8gZ2V0X2lycV9zdGFjawkJCUAgc2V0dXAgSVJRIHN0YWNrCglsZHIJc3AsIElSUV9TVEFDS19TVEFSVAoJLmVuZG0KCgkubWFjcm8gZ2V0X2ZpcV9zdGFjawkJCUAgc2V0dXAgRklRIHN0YWNrCglsZHIJc3AsIEZJUV9TVEFDS19TVEFSVAoJLmVuZG0KCi8qCiAqIGV4Y2VwdGlvbiBoYW5kbGVycwogKi8KCS5hbGlnbgk1CnVuZGVmaW5lZF9pbnN0cnVjdGlvbjoKCWdldF9iYWRfc3RhY2sKCWJhZF9zYXZlX3VzZXJfcmVncwoJYmwJZG9fdW5kZWZpbmVkX2luc3RydWN0aW9uCgoJLmFsaWduCTUKc29mdHdhcmVfaW50ZXJydXB0OgoJZ2V0X2JhZF9zdGFjawoJYmFkX3NhdmVfdXNlcl9yZWdzCglibAlkb19zb2Z0d2FyZV9pbnRlcnJ1cHQKCgkuYWxpZ24JNQpwcmVmZXRjaF9hYm9ydDoKCWdldF9iYWRfc3RhY2sKCWJhZF9zYXZlX3VzZXJfcmVncwoJYmwJZG9fcHJlZmV0Y2hfYWJvcnQKCgkuYWxpZ24JNQpkYXRhX2Fib3J0OgoJZ2V0X2JhZF9zdGFjawoJYmFkX3NhdmVfdXNlcl9yZWdzCglibAlkb19kYXRhX2Fib3J0CgoJLmFsaWduCTUKbm90X3VzZWQ6CglnZXRfYmFkX3N0YWNrCgliYWRfc2F2ZV91c2VyX3JlZ3MKCWJsCWRvX25vdF91c2VkCgojaWZkZWYgQ09ORklHX1VTRV9JUlEKCgkuYWxpZ24JNQppcnE6CglnZXRfaXJxX3N0YWNrCglpcnFfc2F2ZV91c2VyX3JlZ3MKCWJsCWRvX2lycQoJaXJxX3Jlc3RvcmVfdXNlcl9yZWdzCgoJLmFsaWduCTUKZmlxOgoJZ2V0X2ZpcV9zdGFjawoJLyogc29tZW9uZSBvdWdodCB0byB3cml0ZSBhIG1vcmUgZWZmaWN0aW9uIGZpcV9zYXZlX3VzZXJfcmVncyAqLwoJaXJxX3NhdmVfdXNlcl9yZWdzCglibAlkb19maXEKCWlycV9yZXN0b3JlX3VzZXJfcmVncwoKI2Vsc2UKCgkuYWxpZ24JNQppcnE6CglnZXRfYmFkX3N0YWNrCgliYWRfc2F2ZV91c2VyX3JlZ3MKCWJsCWRvX2lycQoKCS5hbGlnbgk1CmZpcToKCWdldF9iYWRfc3RhY2sKCWJhZF9zYXZlX3VzZXJfcmVncwoJYmwJZG9fZmlxCgojZW5kaWYKCiNpZiBkZWZpbmVkKENPTkZJR19JTVBBNykgfHwgZGVmaW5lZChDT05GSUdfRVA3MzEyKSB8fCBkZWZpbmVkKENPTkZJR19BUk1BRElMTE8pCgkuYWxpZ24JNQouZ2xvYmwgcmVzZXRfY3B1CnJlc2V0X2NwdToKCW1vdglpcCwgIzAKCW1jcglwMTUsIDAsIGlwLCBjNywgYzcsIDAJCUAgaW52YWxpZGF0ZSBjYWNoZQoJbWNyCXAxNSwgMCwgaXAsIGM4LCBjNywgMAkJQCBmbHVzaCBUTEIgKHY0KQoJbXJjCXAxNSwgMCwgaXAsIGMxLCBjMCwgMAkJQCBnZXQgY3RybCByZWdpc3RlcgoJYmljCWlwLCBpcCwgIzB4MDAwZgkJCUAgLi4uLi4uLi4uLi4ud2NhbQoJYmljCWlwLCBpcCwgIzB4MjEwMAkJCUAgLi52Li4uLnMuLi4uLi4uLgoJbWNyCXAxNSwgMCwgaXAsIGMxLCBjMCwgMAkJQCBjdHJsIHJlZ2lzdGVyCgltb3YJcGMsIHIwCiNlbGlmIGRlZmluZWQoQ09ORklHX05FVEFSTSkKCS5hbGlnbgk1Ci5nbG9ibCByZXNldF9jcHUKcmVzZXRfY3B1OgoJbGRyCXIxLCA9TkVUQVJNX01FTV9NT0RVTEVfQkFTRQoJbGRyCXIwLCBbcjEsICMrTkVUQVJNX01FTV9DUzBfQkFTRV9BRERSXQoJbGRyCXIxLCA9MHhGRkZGRjAwMAoJYW5kCXIwLCByMSwgcjAKCWxkcglyMSwgPShyZWxvY2F0ZS1DT05GSUdfU1lTX1RFWFRfQkFTRSkKCWFkZAlyMCwgcjEsIHIwCglsZHIJcjQsID1ORVRBUk1fR0VOX01PRFVMRV9CQVNFCglsZHIJcjEsID1ORVRBUk1fR0VOX1NXX1NWQ19SRVNFVEEKCXN0cglyMSwgW3I0LCAjK05FVEFSTV9HRU5fU09GVFdBUkVfU0VSVklDRV0KCWxkcglyMSwgPU5FVEFSTV9HRU5fU1dfU1ZDX1JFU0VUQgoJc3RyCXIxLCBbcjQsICMrTkVUQVJNX0dFTl9TT0ZUV0FSRV9TRVJWSUNFXQoJbGRyCXIxLCA9TkVUQVJNX0dFTl9TV19TVkNfUkVTRVRBCglzdHIJcjEsIFtyNCwgIytORVRBUk1fR0VOX1NPRlRXQVJFX1NFUlZJQ0VdCglsZHIJcjEsID1ORVRBUk1fR0VOX1NXX1NWQ19SRVNFVEIKCXN0cglyMSwgW3I0LCAjK05FVEFSTV9HRU5fU09GVFdBUkVfU0VSVklDRV0KCW1vdglwYywgcjAKI2VsaWYgZGVmaW5lZChDT05GSUdfUzNDNDUxMEIpCi8qIE5vdGhpbmcgZG9uZSBoZXJlIGFzIHJlc2V0aW5nIHRoZSBDUFUgaXMgYm9hcmQgc3BlY2lmaWMsIGRlcGVuZGluZwogKiBvbiBleHRlcm5hbCBwZXJpcGhlcmFscyBzdWNoIGFzIHdhdGNoZG9nIHRpbWVycywgZXRjLiAqLwojZWxpZiBkZWZpbmVkKENPTkZJR19JTlRFR1JBVE9SKSAmJiBkZWZpbmVkKENPTkZJR19BUkNIX0lOVEVHUkFUT1IpCgkvKiBObyBzcGVjaWZpYyByZXNldCBhY3Rpb25zIGZvciBJbnRlZ3JhdG9yQVAvQ003MjBUIGFzIHlldCAqLwojZWxpZiBkZWZpbmVkKENPTkZJR19MUEMyMjkyKQoJLmFsaWduCTUKLmdsb2JsIHJlc2V0X2NwdQpyZXNldF9jcHU6Cgltb3YJcGMsIHIwCiNlbHNlCiNlcnJvciBObyByZXNldF9jcHUoKSBkZWZpbmVkIGZvciBjdXJyZW50IENQVSB0eXBlCiNlbmRpZgo=