LyoKICogKEMpIENvcHlyaWdodCAyMDA3CiAqIEhlaWtvIFNjaG9jaGVyLCBERU5YIFNvZnR3YXJlIEVuZ2luZWVyaW5nLCA8aHNAZGVueC5kZT4uCiAqCiAqIEZyb206CiAqIChDKSBDb3B5cmlnaHQgMjAwMwogKiBKdWVyZ2VuIEJlaXNlcnQsIEV1cm9EZXNpZ24gZW1iZWRkZWQgdGVjaG5vbG9naWVzLCBqYmVpc2VydEBldXJvZHNuLmRlCiAqCiAqIFNlZSBmaWxlIENSRURJVFMgZm9yIGxpc3Qgb2YgcGVvcGxlIHdobyBjb250cmlidXRlZCB0byB0aGlzCiAqIHByb2plY3QuCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IKICogbW9kaWZ5IGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMKICogcHVibGlzaGVkIGJ5IHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVpdGhlciB2ZXJzaW9uIDIgb2YKICogdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLAogKiBidXQgV0lUSE9VVCBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZgogKiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuCSBTZWUgdGhlCiAqIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvciBtb3JlIGRldGFpbHMuCiAqCiAqIFlvdSBzaG91bGQgaGF2ZSByZWNlaXZlZCBhIGNvcHkgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlCiAqIGFsb25nIHdpdGggdGhpcyBwcm9ncmFtOyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDU5IFRlbXBsZSBQbGFjZSwgU3VpdGUgMzMwLCBCb3N0b24sCiAqIE1BIDAyMTExLTEzMDcgVVNBCiAqLwoKI2lmbmRlZiBfX0NPTkZJR19ICiNkZWZpbmUgX19DT05GSUdfSAoKI3VuZGVmIFVTRV9WR0FfR1JBUEhJQ1MKCi8qIE1lbW9yeSBNYXAKICogMHgwMDAwMDAwMCAuLi4uIDB4MDNGRkZGRkYgLT4gUkFNICh1cCB0byAxMjhNaUIpCiAqIDB4NzQwMDAwMDAgLi4uLiAweDc0MEZGRkZGIC0+IENTIzYKICogMHg3NDEwMDAwMCAuLi4uIDB4NzQxRkZGRkYgLT4gQ1MjNwogKiAweDc0MjAwMDAwIC4uLi4gMHg3NDJGRkZGRiAtPiBDUzQjIGlmIG5vIGludGVybmFsIFVTQgogKiAweDc0MzAwMDAwIC4uLi4gMHg3NDNGRkZGRiAtPiBDUzUjIGlmIG5vIGJvb3N0ZWQgSURFCiAqIDB4NzdDMDAwMDAgLi4uLiAweDc3Q0ZGRkZGIC0+IENTNCMgVVNCIEhDICgxIE1pQikKICogMHg3N0QwMDAwMCAuLi4uIDB4NzdERkZGRkYgLT4gQ1MxIyBOQU5ELUZsYXNoICgxIE1pQikKICogMHg3ODAwMDAwMCAuLi4uIDB4NzhGRkZGRkYgLT4gQ1MyIyBJU0EtQnVzIFNwZWljaGVyenVncmlmZiAoMTYgTWlCKQogKiAweDc5MDAwMDAwIC4uLi4gMHg3OTAwRkZGRiAtPiBDUzIjIElTQS1CdXMgSU8tWnVncmlmZiAoMTYgTWlCLCBtYXBwZWQ6IDY0a2lCKQogKiAweDc5MDEwMDAwIC4uLi4gMHg3OUZGRkZGRiAtPiBDUzIjIElTQS1CdXMgSU8tWnVncmlmZiAobWlycm9yZWQpCiAqIDB4N0EwMDAwMDAgLi4uLiAweDdBMEZGRkZGIC0+IENTNSMgSURFIGVtdWxhdGlvbiAoMU1pQikKICoKICogMHg4MDAwMDAwMCAuLi4uIDB4OUZGRkZGRkYgLT4gUENJLUJ1cyBTcGVpY2hlcnp1Z3JpZmYgKDUxMk1pQiwgbWFwcGVkOiAxOjEpCiAqIDB4QTAwMDAwMDAgLi4uLiAweEJGRkZGRkZGIC0+IFBDSS1CdXMgU3BlaWNoZXJ6dWdyaWZmICg1MTJNaUIsIG1hcHBlZDogMHgwMDAwMDAwMC4uLjB4MUZGRkZGRkYpCiAqIDB4RTgwMDAwMDAgLi4uLiAweEU4MDBGRkZGIC0+IFBDSS1CdXMgSU8tWnVncmlmZiAoNjRraUIsIHRyYW5zbGF0ZWQgdG8gUENJOiAweDAwMDAuLi4weEZGRkYpCiAqIDB4RTg4MDAwMDAgLi4uLiAweEVCRkZGRkZGIC0+IFBDSS1CdXMgSU8tWnVncmlmZiAoNTZNaUIsIHRyYW5zbGF0ZWQgdG8gUENJOiAweDAwODAwMDAwLi4uMHgzRkZGRkZGKQogKiAweEVFRDAwMDAwIC4uLi4gMHhFRUQwMDAwMyAtPiBQQ0ktQnVzCiAqIDB4RUY0MDAwMDAgLi4uLiAweEVGNDAwMDNGIC0+IFBDSS1CdXMgTG9jYWwgQ29uZmlndXJhdGlvbiBSZWdpc3RlcnMKICogMHhFRjQwMDAzRiAuLi4uIDB4RUY1RkZGRkYgLT4gcmVzZXJ2ZWQKICogMHhFRjYwMDAwMCAuLi4uIDB4RUZGRkZGRkYgLT4gNDA1R1AgaW50ZXJuYWwgRGV2aWNlcyAoMTAgTWlCKQogKiAweEYwMDAwMDAwIC4uLi4gMHhGMDFGRkZGRiAtPiBGbGFzaC1ST00gKDIgTWlCKQogKiAweEYwMjAwMDAwIC4uLi4gMHhGN0ZGRkZGRiAtPiBmcmVlIGZvciBmbGFzaCBkZXZpY2VzCiAqIDB4RjgwMDAwMDAgLi4uLiAweEY4MDAwRkZGIC0+IE9uQ2hpcE1lbW9yeSAoNGtpQikKICogMHhGODAwMTAwMCAuLi4uIDB4RkZERkZGRkYgLT4gZnJlZSBmb3IgZmxhc2ggZGV2aWNlcwogKiAweEZGRTAwMDAwIC4uLi4gMHhGRkZGRkZGRiAtPiBCT09ULVJPTSAoMiBNaUIpCiAqLwoKI2RlZmluZSBDT05GSUdfU0MzCTEKI2RlZmluZSBDT05GSUdfNHh4CTEKI2RlZmluZSBDT05GSUdfNDA1R1AJMQoKI2RlZmluZSBDT05GSUdfQk9BUkRfRUFSTFlfSU5JVF9GCTEKI2RlZmluZSBDT05GSUdfTUlTQ19JTklUX1IJCTEJLyogQ2FsbCBtaXNjX2luaXRfcigpICovCgovKgogKiBEZWZpbmUgSURFX1VTRVNfSVNBX0VNVUxBVElPTiBmb3Igc2xvd2VyIElERSBhY2Nlc3MgaW4gdGhlIElTQS1JTyBhZGRyZXNzIHJhbmdlCiAqIElmIHVuZGVmaW5lZCwgSURFIGFjY2VzcyB1c2VzIGEgc2VwZXJhdCBlbXVsYXRpb24gd2l0aCBoaWdoZXIgYWNjZXNzIHNwZWVkLgogKiBDb25zaWRlciB0byBpbmZvcm0geW91ciBMaW51eCBJREUgZHJpdmVyIGFib3V0IHRoZSBkaWZmZXJlbnQgYWRkcmVzc2VzIQogKiBJREVfVVNFU19JU0FfRU1VTEFUSU9OIGlzIG9ubHkgdXNlZCBpZiB5b3UgZGVmaW5lIENPTkZJR19DTURfSURFIQogKi8KI2RlZmluZSBJREVfVVNFU19JU0FfRU1VTEFUSU9OCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFNlcmlhbCBQb3J0CiAqLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCiNkZWZpbmUgQ09ORklHX1NFUklBTF9NVUxUSQojdW5kZWYgQ09ORklHX1NFUklBTF9TT0ZUV0FSRV9GSUZPCi8qCiAqIGRlZmluZSBDT05GSUdfUE9XRVJfRE9XTiBpZiB5b3VyIGNwdSBzaG91bGQgcG93ZXIgZG93biB3aGlsZSB3YWl0aW5nIGZvciB5b3VyIGlucHV0CiAqIFdvcmtzIG9ubHksIGlmIHlvdSBoYXZlIGVuYWJsZWQgdGhlIENPTkZJR19TRVJJQUxfU09GVFdBUkVfRklGTyBmZWF0dXJlCiAqLwojaWYgQ09ORklHX1NFUklBTF9TT0ZUV0FSRV9GSUZPCiAjZGVmaW5lIENPTkZJR19QT1dFUl9ET1dOCiNlbmRpZgoKLyoKICogZGVmaW5lIENPTkZJR19TWVNfQ0xLX0ZSRVEgdG8geW91ciBiYXNlIGNyeXN0YWwgY2xvY2sgaW4gSHoKICovCiNkZWZpbmUgQ09ORklHX1NZU19DTEtfRlJFUQkzMzMzMzMzMwoKLyoKICogZGVmaW5lIENPTkZJR19CQVVEUkFURSB0byB0aGUgYmF1ZHJhdGUgdmFsdWUgeW91IHdhbnQgdG8gdXNlIGFzIGRlZmF1bHQKICovCiNkZWZpbmUgQ09ORklHX0JBVURSQVRFCQkxMTUyMDAKI2RlZmluZSBDT05GSUdfQk9PVERFTEFZCTMgLyogYXV0b2Jvb3QgYWZ0ZXIgMyBzZWNvbmRzCSAgICAgICovCgojZGVmaW5lIENPTkZJR19QUkVCT09UCSJlY2hvOyIJXAoJImVjaG8gVHlwZSBcXFwicnVuIGZsYXNoX25mc1xcXCIgdG8gbW91bnQgcm9vdCBmaWxlc3lzdGVtIG92ZXIgTkZTOyIgXAoJImVjaG8iCgojdW5kZWYJQ09ORklHX0JPT1RBUkdTCgojZGVmaW5lCUNPTkZJR19FWFRSQV9FTlZfU0VUVElOR1MJCQkJCVwKCSJuZXRkZXY9ZXRoMFwwIgkJCQkJCQlcCgkibmZzYXJncz1zZXRlbnYgYm9vdGFyZ3Mgcm9vdD0vZGV2L25mcyBydyAiCQkJXAoJCSJuZnNyb290PSR7c2VydmVyaXB9OiR7cm9vdHBhdGh9XDAiCQkJXAoJInJhbWFyZ3M9c2V0ZW52IGJvb3RhcmdzIHJvb3Q9L2Rldi9yYW0gcndcMCIJCQlcCgkibmFuZF9hcmdzPXNldGVudiBib290YXJncyByb290PS9kZXYvbXRkYmxvY2s1IHJ3IgkJXAoJCSJyb290ZnN0eXBlPWpmZnMyXDAiCQkJCQlcCgkiYWRkaXA9c2V0ZW52IGJvb3RhcmdzICR7Ym9vdGFyZ3N9ICIJCQkJXAoJCSJpcD0ke2lwYWRkcn06JHtzZXJ2ZXJpcH06JHtnYXRld2F5aXB9OiR7bmV0bWFza30iCVwKCQkiOiR7aG9zdG5hbWV9OiR7bmV0ZGV2fTpvZmYgcGFuaWM9MVwwIgkJCVwKCSJhZGRjb25zPXNldGVudiBib290YXJncyAke2Jvb3RhcmdzfSAiCQkJCVwKCQkiY29uc29sZT10dHlTMCwke2JhdWRyYXRlfVwwIgkJCQlcCgkiZmxhc2hfbmZzPXJ1biBuZnNhcmdzIGFkZGlwIGFkZGNvbnM7IgkJCQlcCgkJImJvb3RtICR7a2VybmVsX2FkZHJ9XDAiCQkJCVwKCSJmbGFzaF9uYW5kPXJ1biBuYW5kX2FyZ3MgYWRkaXAgYWRkY29ucztib290bSAke2tlcm5lbF9hZGRyfVwwIglcCgkibmV0X25mcz10ZnRwIDIwMDAwMCAke2Jvb3RmaWxlfTtydW4gbmZzYXJncyBhZGRpcCBhZGRjb25zOyIJXAoJCSJib290bVwwIgkJCQkJCVwKCSJyb290cGF0aD0vb3B0L2VsZGsvcHBjXzR4eFwwIgkJCQkJXAoJImJvb3RmaWxlPS90ZnRwYm9vdC9zYzMvdUltYWdlXDAiCQkJCVwKCSJ1LWJvb3Q9L3RmdHBib290L3NjMy91LWJvb3QuYmluXDAiCQkJCVwKCSJzZXR1cD10ZnRwIDIwMDAwMCAvdGZ0cGJvb3Qvc2MzL3NldHVwLmltZztzb3VyY2UgMjAwMDAwXDAiCVwKCSJrZXJuZWxfYWRkcj1GRkUwODAwMFwwIgkJCQkJXAoJIiIKI3VuZGVmIENPTkZJR19CT09UQ09NTUFORAoKI2RlZmluZSBDT05GSUdfU0lMRU5UX0NPTlNPTEUJMQkvKiBlbmFibGUgc2lsZW50IHN0YXJ0dXAgKi8KI2RlZmluZSBDT05GSUdfU1lTX0RFVklDRV9OVUxMREVWCTEJLyogaW5jbHVkZSBudWxsZGV2IGRldmljZQkqLwoKI2lmIDEJLyogZmVlbCBmcmVlIHRvIGRpc2FibGUgZm9yIGRldmVsb3BtZW50ICovCiNkZWZpbmUgQ09ORklHX0FVVE9CT09UX0tFWUVECQkvKiBFbmFibGUgcGFzc3dvcmQgcHJvdGVjdGlvbgkqLwojZGVmaW5lIENPTkZJR19BVVRPQk9PVF9QUk9NUFQJCVwKCSJcblNDMyAtIGJvb3RpbmcuLi4gc3RvcCB3aXRoIEVOVEVSXG4iCiNkZWZpbmUgQ09ORklHX0FVVE9CT09UX0RFTEFZX1NUUgkiXHIiCS8qIDFzdCAicGFzc3dvcmQiCSovCiNkZWZpbmUgQ09ORklHX0FVVE9CT09UX0RFTEFZX1NUUjIJIlxuIgkvKiAxc3QgInBhc3N3b3JkIgkqLwojZW5kaWYKCi8qCiAqIGRlZmluZSBDT05GSUdfQk9PVENPTU1BTkQgdG8gdGhlIGF1dG9ib290IGNvbW1hbmRzLiBUaGV5IHdpbGwgcnVubmluZyBhZnRlcgogKiB0aGUgQ09ORklHX0JPT1RERUxBWSBkZWxheSB0byBib290IHlvdXIgbWFjaGluZQogKi8KI2RlZmluZSBDT05GSUdfQk9PVENPTU1BTkQJImJvb3RwO2RjYWNoZSBvbjtib290bSIKCi8qCiAqIGRlZmluZSBDT05GSUdfQk9PVEFSR1MgdG8gdGhlIGRlZmF1bHQga2VybmVsIHBhcmFtZXRlcnMuIFRoZXkgd2lsbCB1c2VkIGlmIHlvdSBkb24ndAogKiBzZXQgZGlmZmVyZW50IHZhbHVlcyBhdCB0aGUgdS1ib290IHByb21wdAogKi8KI2lmZGVmIFVTRV9WR0FfR1JBUEhJQ1MKICNkZWZpbmUgQ09ORklHX0JPT1RBUkdTCSJyb290PS9kZXYvbmZzIHJ3IGlwPWJvb3RwIG5mc3Jvb3Q9L3RmdHBib290L3NvbGlkY2FyZDNyZSIKI2Vsc2UKICNkZWZpbmUgQ09ORklHX0JPT1RBUkdTCSJjb25zb2xlPXR0eVMwLDExNTIwMCByb290PS9kZXYvbmZzIHJ3IGlwPWJvb3RwIgojZW5kaWYKLyoKICogSXMgdGhlIFVTQiBob3N0IGNvbnRyb2xsZXIgYXNzZW1ibGVkPyBJZiB5ZXMgZGVmaW5lIENPTkZJR19JU1AxMTYxX1BSRVNFTlQKICogVGhpcyByZXNlcnZlcyBtZW1vcnkgYmFuayAjNCBmb3IgdGhpcyBwdXJwb3NlCiAqLwojdW5kZWYgQ09ORklHX0lTUDExNjFfUFJFU0VOVAoKI3VuZGVmIENPTkZJR19MT0FEU19FQ0hPICAgLyogbm8gZWNobyBvbiBmb3Igc2VyaWFsIGRvd25sb2FkCSovCiNkZWZpbmUgQ09ORklHX1NZU19MT0FEU19CQVVEX0NIQU5HRQkxCS8qIGFsbG93IGJhdWRyYXRlIGNoYW5nZQkqLwoKI2RlZmluZSBDT05GSUdfTkVUX01VTFRJCi8qICNkZWZpbmUgQ09ORklHX0VFUFJPMTAwX1NST01fV1JJVEUgKi8KLyogI2RlZmluZSBDT05GSUdfU0hPV19NQUMgKi8KI2RlZmluZSBDT05GSUdfRUVQUk8xMDAKCiNkZWZpbmUgQ09ORklHX1BQQzR4eF9FTUFDCiNkZWZpbmUgQ09ORklHX01JSSAxCQkJLyogYWRkIDQwNUdQIE1JSSBQSFkgbWFuYWdlbWVudAkJKi8KI2RlZmluZSBDT05GSUdfUEhZX0FERFIgMQkvKiB0aGUgY29ubmVjdGVkIFBoeSBkZWZhdWx0cyB0byBhZGRyZXNzIDEgKi8KCi8qCiAqIEJPT1RQIG9wdGlvbnMKICovCiNkZWZpbmUgQ09ORklHX0JPT1RQX0JPT1RGSUxFU0laRQojZGVmaW5lIENPTkZJR19CT09UUF9CT09UUEFUSAojZGVmaW5lIENPTkZJR19CT09UUF9HQVRFV0FZCiNkZWZpbmUgQ09ORklHX0JPT1RQX0hPU1ROQU1FCgoKLyoKICogQ29tbWFuZCBsaW5lIGNvbmZpZ3VyYXRpb24uCiAqLwojaW5jbHVkZSA8Y29uZmlnX2NtZF9kZWZhdWx0Lmg+CgoKI2RlZmluZSBDT05GSUdfQ01EX0NBQ0hFCiNkZWZpbmUgQ09ORklHX0NNRF9EQVRFCiNkZWZpbmUgQ09ORklHX0NNRF9ESENQCiNkZWZpbmUgQ09ORklHX0NNRF9FTEYKI2RlZmluZSBDT05GSUdfQ01EX0kyQwojZGVmaW5lIENPTkZJR19DTURfSURFCiNkZWZpbmUgQ09ORklHX0NNRF9JUlEKI2RlZmluZSBDT05GSUdfQ01EX0pGRlMyCiNkZWZpbmUgQ09ORklHX0NNRF9NSUkKI2RlZmluZSBDT05GSUdfQ01EX05BTkQKI2RlZmluZSBDT05GSUdfQ01EX05FVAojZGVmaW5lIENPTkZJR19DTURfUENJCiNkZWZpbmUgQ09ORklHX0NNRF9QSU5HCiNkZWZpbmUgQ09ORklHX0NNRF9TT1VSQ0UKCgojdW5kZWYgQ09ORklHX1dBVENIRE9HCQkJLyogd2F0Y2hkb2cgZGlzYWJsZWQJCSovCgovKgogKiBNaXNjZWxsYW5lb3VzIGNvbmZpZ3VyYWJsZSBvcHRpb25zCiAqLwojZGVmaW5lIENPTkZJR19TWVNfTE9OR0hFTFAJMQkJLyogdW5kZWYgdG8gc2F2ZSBtZW1vcnkJCSovCiNkZWZpbmUgQ09ORklHX1NZU19QUk9NUFQJIlNDMz4gIgkvKiBNb25pdG9yIENvbW1hbmQgUHJvbXB0CSovCiNkZWZpbmUJQ09ORklHX1NZU19DQlNJWkUJMjU2CQkvKiBDb25zb2xlIEkvTyBCdWZmZXIgU2l6ZQkqLwoKI2RlZmluZSBDT05GSUdfU1lTX1BCU0laRSAoQ09ORklHX1NZU19DQlNJWkUrc2l6ZW9mKENPTkZJR19TWVNfUFJPTVBUKSsxNikgLyogUHJpbnQgQnVmZmVyIFNpemUgKi8KCiNkZWZpbmUgQ09ORklHX1NZU19NQVhBUkdTCTE2CQkvKiBtYXggbnVtYmVyIG9mIGNvbW1hbmQgYXJncwkqLwojZGVmaW5lIENPTkZJR19TWVNfQkFSR1NJWkUJQ09ORklHX1NZU19DQlNJWkUJLyogQm9vdCBBcmd1bWVudCBCdWZmZXIgU2l6ZQkqLwoKI2RlZmluZSBDT05GSUdfU1lTX01FTVRFU1RfU1RBUlQJMHgwNDAwMDAwCS8qIG1lbXRlc3Qgd29ya3Mgb24JKi8KI2RlZmluZSBDT05GSUdfU1lTX01FTVRFU1RfRU5ECQkweDBDMDAwMDAJLyogNCAuLi4gMTIgTUIgaW4gRFJBTQkqLwoKLyoKICogSWYgQ09ORklHX1NZU19FWFRfU0VSSUFMX0NMT0NLLCB0aGVuIHRoZSBVQVJUIGRpdmlzb3IgaXMgMS4KICogSWYgQ09ORklHX1NZU180MDVfVUFSVF9FUlJBVEFfNTksIHRoZW4gVUFSVCBkaXZpc29yIGlzIDMxLgogKiBPdGhlcndpc2UsIFVBUlQgZGl2aXNvciBpcyBkZXRlcm1pbmVkIGJ5IENQVSBDbG9jayBhbmQgQ09ORklHX1NZU19CQVNFX0JBVUQgdmFsdWUuCiAqIFRoZSBMaW51eCBCQVNFX0JBVUQgZGVmaW5lIHNob3VsZCBtYXRjaCB0aGlzIGNvbmZpZ3VyYXRpb24uCiAqICAgIGJhc2VCYXVkID0gY3B1Q2xvY2svKHVhcnREaXZpc29yKjE2KQogKiBJZiBDT05GSUdfU1lTXzQwNV9VQVJUX0VSUkFUQV81OSBhbmQgMjAwTUh6IENQVSBjbG9jaywKICogc2V0IExpbnV4IEJBU0VfQkFVRCB0byA0MDMyMDAuCiAqCiAqIENvbnNpZGVyIHRoZSBPUEIgY2xvY2shIElmIGl0IGdldCBsb3dlciB0aGUgQkFTRV9CQVVEIG11c3QgYmUgbG93ZXIgdG8KICogKHNlZSA0MDVHUCBkYXRhc2hlZXQgZm9yIGRlc2NyaXRwaW9uKQogKi8KI3VuZGVmCUNPTkZJR19TWVNfRVhUX1NFUklBTF9DTE9DSwkJLyogZXh0ZXJuYWwgc2VyaWFsIGNsb2NrICovCiN1bmRlZglDT05GSUdfU1lTXzQwNV9VQVJUX0VSUkFUQV81OQkJLyogNDA1R1AvQ1IgUmV2LiBEIHNpbGljb24gKi8KI2RlZmluZSBDT05GSUdfU1lTX0JBU0VfQkFVRAkJOTIxNjAwCS8qIGludGVybmFsIGNsb2NrICovCgovKiBUaGUgZm9sbG93aW5nIHRhYmxlIGluY2x1ZGVzIHRoZSBzdXBwb3J0ZWQgYmF1ZHJhdGVzICovCiNkZWZpbmUgQ09ORklHX1NZU19CQVVEUkFURV9UQUJMRSAgXAogICAgezMwMCwgNjAwLCAxMjAwLCAyNDAwLCA0ODAwLCA5NjAwLCAxOTIwMCwgMzg0MDAsIDU3NjAwLCAxMTUyMDAsIDIzMDQwMH0KCiNkZWZpbmUgQ09ORklHX1NZU19MT0FEX0FERFIJCTB4MTAwMDAwMAkvKiBkZWZhdWx0IGxvYWQgYWRkcmVzcyAqLwojZGVmaW5lIENPTkZJR19TWVNfRVhUQkRJTkZPCQkxCS8qIFRvIHVzZSBleHRlbmRlZCBib2FyZF9pbnRvIChiZF90KSAqLwoKI2RlZmluZQlDT05GSUdfU1lTX0haCQkJMTAwMAkvKiBkZWNyZW1lbnRlciBmcmVxOiAxIG1zIHRpY2tzCSovCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIElJQyBzdHVmZgogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqLwojZGVmaW5lICBDT05GSUdfSEFSRF9JMkMJCS8qIEkyQyB3aXRoIGhhcmR3YXJlIHN1cHBvcnQJKi8KI3VuZGVmCUNPTkZJR19TT0ZUX0kyQwkJCS8qIEkyQyBiaXQtYmFuZ2VkCQkqLwojZGVmaW5lIENPTkZJR19QUEM0WFhfSTJDCQkvKiB1c2UgUFBDNHh4IGRyaXZlcgkJKi8KCiNkZWZpbmUgSTJDX0lOSVQKI2RlZmluZSBJMkNfQUNUSVZFIDAKI2RlZmluZSBJMkNfVFJJU1RBVEUgMAoKI2RlZmluZSBDT05GSUdfU1lTX0kyQ19TUEVFRAkJMTAwMDAwCS8qIHVzZSB0aGUgc3RhbmRhcmQgMTAwa0h6IHNwZWVkICovCiNkZWZpbmUgQ09ORklHX1NZU19JMkNfU0xBVkUJCTB4N0YJCS8qIG1hc2sgdmFsaWQgYml0cyAqLwoKI2RlZmluZSBDT05GSUdfUlRDX0RTMTMzNwojZGVmaW5lIENPTkZJR19TWVNfSTJDX1JUQ19BRERSIDB4NjgKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogUENJIHN0dWZmCiAqLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICovCiNkZWZpbmUgUENJX0hPU1RfQURBUFRFUiAwCQkvKiBjb25maWd1cmUgYXIgcGNpIGFkYXB0ZXIJKi8KI2RlZmluZSBQQ0lfSE9TVF9GT1JDRQkxCQkvKiBjb25maWd1cmUgYXMgcGNpIGhvc3QJKi8KI2RlZmluZSBQQ0lfSE9TVF9BVVRPCTIJCS8qIGRldGVjdGVkIHZpYSBhcmJpdGVyIGVuYWJsZQkqLwoKI2RlZmluZSBDT05GSUdfUENJCQkJLyogaW5jbHVkZSBwY2kgc3VwcG9ydAkJKi8KI2RlZmluZSBDT05GSUdfUENJX0hPU1QJUENJX0hPU1RfRk9SQ0UJLyogc2VsZWN0IHBjaSBob3N0IGZ1bmN0aW9uCSovCiNkZWZpbmUgQ09ORklHX1BDSV9QTlAJCQkvKiBkbyBwY2kgcGx1Zy1hbmQtcGxheQkJKi8KCQkJCQkvKiByZXNvdXJjZSBjb25maWd1cmF0aW9uCSovCgovKiBJZiB5b3Ugd2FudCB0byBzZWUsIHdoYXRzIGNvbm5lY3RlZCB0byB5b3VyIFBDSSBidXMgKi8KLyogI2RlZmluZSBDT05GSUdfUENJX1NDQU5fU0hPVyAqLwoKI2RlZmluZSBDT05GSUdfU1lTX1BDSV9TVUJTWVNfVkVORE9SSUQgMHgwMDAwCS8qIFBDSSBWZW5kb3IgSUQ6IHRvLWRvISEhCSovCiNkZWZpbmUgQ09ORklHX1NZU19QQ0lfU1VCU1lTX0RFVklDRUlEIDB4MDAwMAkvKiBQQ0kgRGV2aWNlIElEOiB0by1kbyEhIQkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTFMQQkweDAwMDAwMDAwCS8qIHBvaW50IHRvIHNkcmFtCQkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTFNUwkweDgwMDAwMDAxCS8qIDJHQiwgZW5hYmxlIGhhcmQtd2lyZWQgdG8gMQkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTFQQ0kgMHgwMDAwMDAwMAkvKiBIb3N0OiB1c2UgdGhpcyBwY2kgYWRkcmVzcwkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTJMQQkweDAwMDAwMDAwCS8qIGRpc2FibGVkCQkJKi8KI2RlZmluZSBDT05GSUdfU1lTX1BDSV9QVE0yTVMJMHgwMDAwMDAwMAkvKiBkaXNhYmxlZAkJCSovCiNkZWZpbmUgQ09ORklHX1NZU19QQ0lfUFRNMlBDSSAweDA0MDAwMDAwCS8qIEhvc3Q6IHVzZSB0aGlzIHBjaSBhZGRyZXNzCSovCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIEV4dGVybmFsIHBlcmlwaGVyYWwgYmFzZSBhZGRyZXNzCiAqLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICovCiNpZiAhZGVmaW5lZChDT05GSUdfQ01EX0lERSkKCiN1bmRlZglDT05GSUdfSURFX0xFRAkJCS8qIG5vIGxlZCBmb3IgaWRlIHN1cHBvcnRlZAkqLwojdW5kZWYJQ09ORklHX0lERV9SRVNFVAkJLyogbm8gcmVzZXQgZm9yIGlkZSBzdXBwb3J0ZWQJKi8KCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogSURFL0FUQSBzdHVmZgogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqLwojZWxzZQojZGVmaW5lIENPTkZJR19TVEFSVF9JREUJMQkvKiBjaGVjaywgaWYgdXNlIElERSAqLwoKI3VuZGVmCUNPTkZJR19JREVfOHh4X0RJUkVDVAkJLyogbm8gcGNtY2lhIGludGVyZmFjZSByZXF1aXJlZCAqLwojdW5kZWYJQ09ORklHX0lERV9MRUQJCQkvKiBubyBsZWQgZm9yIGlkZSBzdXBwb3J0ZWQJKi8KI3VuZGVmCUNPTkZJR19JREVfUkVTRVQJCS8qIG5vIHJlc2V0IGZvciBpZGUgc3VwcG9ydGVkCSovCgojZGVmaW5lCUNPTkZJR19BVEFQSQojZGVmaW5lCUNPTkZJR19ET1NfUEFSVElUSU9OCiNkZWZpbmUJQ09ORklHX1NZU19JREVfTUFYREVWSUNFCShDT05GSUdfU1lTX0lERV9NQVhCVVMqMSkgLyogbWF4LiAxIGRyaXZlcyBwZXIgSURFIGJ1cyAqLwoKI2lmbmRlZiBJREVfVVNFU19JU0FfRU1VTEFUSU9OCgovKiBOZXcgYW5kIGZhc3RlciBhY2Nlc3MgKi8KI2RlZmluZQlDT05GSUdfU1lTX0FUQV9CQVNFX0FERFIJCTB4N0EwMDAwMDAJLyogc3RhcnQgb2YgSVNBIElPIGVtdWxhdGlvbiAqLwoKLyogSG93IG1hbnkgSURFIGJ1c3NlcyBhcmUgYXZhaWxhYmxlICovCiNkZWZpbmUJQ09ORklHX1NZU19JREVfTUFYQlVTCQkxCgovKiBXaGF0IElERSBwb3J0cyBhcmUgYXZhaWxhYmxlICovCiNkZWZpbmUJQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQJMHgwMDAJCS8qIGZpcnN0IGlzIGF2YWlsYWJsZSAqLwojdW5kZWYJQ09ORklHX1NZU19BVEFfSURFMV9PRkZTRVQJCQkvKiBzZWNvbmQgbm90IGF2YWlsYWJsZSAqLwoKLyogYWNjZXNzIHRvIHRoZSBkYXRhIHBvcnQgaXMgY2FsY3VsYXRlZDoKICAgQ09ORklHX1NZU19BVEFfQkFTRV9BRERSICsgQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQgKyBDT05GSUdfU1lTX0FUQV9EQVRBX09GRlNFVCArIDAgKi8KI2RlZmluZSBDT05GSUdfU1lTX0FUQV9EQVRBX09GRlNFVAkweDAwMDAJLyogT2Zmc2V0IGZvciBkYXRhIEkvTyAqLwoKLyogYWNjZXNzIHRvIHRoZSByZWdpc3RlcnMgaXMgY2FsY3VsYXRlZDoKICAgQ09ORklHX1NZU19BVEFfQkFTRV9BRERSICsgQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQgKyBDT05GSUdfU1lTX0FUQV9SRUdfT0ZGU0VUICsgWzEuLjddICovCiNkZWZpbmUJQ09ORklHX1NZU19BVEFfUkVHX09GRlNFVAkweDAwMDAJLyogT2Zmc2V0IGZvciBub3JtYWwgcmVnaXN0ZXIgYWNjZXNzZXMJKi8KCi8qIGFjY2VzcyB0byB0aGUgYWx0ZXJuYXRlIHJlZ2lzdGVyIGlzIGNhbGN1bGF0ZWQ6CiAgIENPTkZJR19TWVNfQVRBX0JBU0VfQUREUiArIENPTkZJR19TWVNfQVRBX0lERTBfT0ZGU0VUICsgQ09ORklHX1NZU19BVEFfQUxUX09GRlNFVCArIDYgKi8KI2RlZmluZSBDT05GSUdfU1lTX0FUQV9BTFRfT0ZGU0VUCTB4MDA4CQkvKiBPZmZzZXQgZm9yIGFsdGVybmF0ZSByZWdpc3RlcnMJKi8KCiNlbHNlIC8qIElERV9VU0VTX0lTQV9FTVVMQVRJT04gKi8KCiNkZWZpbmUJQ09ORklHX1NZU19BVEFfQkFTRV9BRERSCQkweDc5MDAwMDAwCS8qIHN0YXJ0IG9mIElTQSBJTyBlbXVsYXRpb24gKi8KCi8qIEhvdyBtYW55IElERSBidXNzZXMgYXJlIGF2YWlsYWJsZSAqLwojZGVmaW5lCUNPTkZJR19TWVNfSURFX01BWEJVUwkJMQoKLyogV2hhdCBJREUgcG9ydHMgYXJlIGF2YWlsYWJsZSAqLwojZGVmaW5lCUNPTkZJR19TWVNfQVRBX0lERTBfT0ZGU0VUCTB4MDFGMAkvKiBmaXJzdCBpcyBhdmFpbGFibGUgKi8KI3VuZGVmCUNPTkZJR19TWVNfQVRBX0lERTFfT0ZGU0VUCQkJCS8qIHNlY29uZCBub3QgYXZhaWxhYmxlICovCgovKiBhY2Nlc3MgdG8gdGhlIGRhdGEgcG9ydCBpcyBjYWxjdWxhdGVkOgogICBDT05GSUdfU1lTX0FUQV9CQVNFX0FERFIgKyBDT05GSUdfU1lTX0FUQV9JREUwX09GRlNFVCArIENPTkZJR19TWVNfQVRBX0RBVEFfT0ZGU0VUICsgMCAqLwojZGVmaW5lIENPTkZJR19TWVNfQVRBX0RBVEFfT0ZGU0VUCTB4MDAwMAkvKiBPZmZzZXQgZm9yIGRhdGEgSS9PICovCgovKiBhY2Nlc3MgdG8gdGhlIHJlZ2lzdGVycyBpcyBjYWxjdWxhdGVkOgogICBDT05GSUdfU1lTX0FUQV9CQVNFX0FERFIgKyBDT05GSUdfU1lTX0FUQV9JREUwX09GRlNFVCArIENPTkZJR19TWVNfQVRBX1JFR19PRkZTRVQgKyBbMS4uN10gKi8KI2RlZmluZQlDT05GSUdfU1lTX0FUQV9SRUdfT0ZGU0VUCTB4MDAwMAkvKiBPZmZzZXQgZm9yIG5vcm1hbCByZWdpc3RlciBhY2Nlc3NlcwkqLwoKLyogYWNjZXNzIHRvIHRoZSBhbHRlcm5hdGUgcmVnaXN0ZXIgaXMgY2FsY3VsYXRlZDoKICAgQ09ORklHX1NZU19BVEFfQkFTRV9BRERSICsgQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQgKyBDT05GSUdfU1lTX0FUQV9BTFRfT0ZGU0VUICsgNiAqLwojZGVmaW5lIENPTkZJR19TWVNfQVRBX0FMVF9PRkZTRVQJMHgwM0YwCQkvKiBPZmZzZXQgZm9yIGFsdGVybmF0ZSByZWdpc3RlcnMJKi8KCiNlbmRpZiAvKiBJREVfVVNFU19JU0FfRU1VTEFUSU9OICovCgojZW5kaWYKCi8qCiNkZWZpbmUJQ09ORklHX1NZU19LRVlfUkVHX0JBU0VfQUREUgkweEYwMTAwMDAwCiNkZWZpbmUJQ09ORklHX1NZU19JUl9SRUdfQkFTRV9BRERSCTB4RjAyMDAwMDAKI2RlZmluZQlDT05GSUdfU1lTX0ZQR0FfUkVHX0JBU0VfQUREUgkweEYwMzAwMDAwCiovCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFN0YXJ0IGFkZHJlc3NlcyBmb3IgdGhlIGZpbmFsIG1lbW9yeSBjb25maWd1cmF0aW9uCiAqIChTZXQgdXAgYnkgdGhlIHN0YXJ0dXAgY29kZSkKICogUGxlYXNlIG5vdGUgdGhhdCBDT05GSUdfU1lTX1NEUkFNX0JBU0UgX211c3RfIHN0YXJ0IGF0IDAKICoKICogQ09ORklHX1NZU19GTEFTSF9CQVNFICAgLT4gc3RhcnQgYWRkcmVzcyBvZiBpbnRlcm5hbCBmbGFzaAogKiBDT05GSUdfU1lTX01PTklUT1JfQkFTRSAtPiBzdGFydCBvZiB1LWJvb3QKICovCiNkZWZpbmUgQ09ORklHX1NZU19TRFJBTV9CQVNFCQkweDAwMDAwMDAwCiNkZWZpbmUgQ09ORklHX1NZU19GTEFTSF9CQVNFCQkweEZGRTAwMDAwCiNkZWZpbmUgQ09ORklHX1NZU19NT05JVE9SX0JBU0UJMHhGRkZDMDAwMCAgICAgLyogcGxhY2VkIGxhc3QgMjU2ayAqLwojZGVmaW5lIENPTkZJR19TWVNfTU9OSVRPUl9MRU4JCSgyMjQgKiAxMDI0KQkvKiBSZXNlcnZlIDIyNCBLaUIgZm9yIE1vbml0b3IJKi8KI2RlZmluZSBDT05GSUdfU1lTX01BTExPQ19MRU4JCSgxMjggKiAxMDI0KQkvKiBSZXNlcnZlIDEyOCBLaUIgZm9yIG1hbGxvYygpCSovCgovKgogKiBGb3IgYm9vdGluZyBMaW51eCwgdGhlIGJvYXJkIGluZm8gYW5kIGNvbW1hbmQgbGluZSBkYXRhCiAqIGhhdmUgdG8gYmUgaW4gdGhlIGZpcnN0IDggTWlCIG9mIG1lbW9yeSwgc2luY2UgdGhpcyBpcwogKiB0aGUgbWF4aW11bSBtYXBwZWQgYnkgdGhlIExpbnV4IGtlcm5lbCBkdXJpbmcgaW5pdGlhbGl6YXRpb24uCiAqLwojZGVmaW5lIENPTkZJR19TWVNfQk9PVE1BUFNaCQkoOCA8PCAyMCkJLyogSW5pdGlhbCBNZW1vcnkgbWFwIGZvciBMaW51eCAqLwovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIEZMQVNIIG9yZ2FuaXphdGlvbiAjIyBGSVhNRTogbG9va3VwIGluIGRhdGFzaGVldAogKi8KI2RlZmluZSBDT05GSUdfU1lTX01BWF9GTEFTSF9CQU5LUwkyCS8qIG1heCBudW1iZXIgb2YgbWVtb3J5IGJhbmtzCQkqLwojZGVmaW5lIENPTkZJR19TWVNfTUFYX0ZMQVNIX1NFQ1QJMjU2CS8qIG1heCBudW1iZXIgb2Ygc2VjdG9ycyBvbiBvbmUgY2hpcAkqLwoKI2RlZmluZSBDT05GSUdfU1lTX0ZMQVNIX0NGSQkJCS8qIGZsYXNoIGlzIENGSSBjb21wYXQuCSovCiNkZWZpbmUgQ09ORklHX0ZMQVNIX0NGSV9EUklWRVIJCS8qIFVzZSBjb21tb24gQ0ZJIGRyaXZlciovCiNkZWZpbmUgQ09ORklHX1NZU19GTEFTSF9FTVBUWV9JTkZPCQkvKiBwcmludCAnRScgZm9yIGVtcHR5IHNlY3RvcgkqLwojZGVmaW5lIENPTkZJR19TWVNfRkxBU0hfUVVJRVRfVEVTVAkxCS8qIGRvbid0IHdhcm4gdXBvbiB1bmtub3duIGZsYXNoKi8KI2RlZmluZSBDT05GSUdfU1lTX0ZMQVNIX0VSQVNFX1RPVVQJMTIwMDAwCS8qIFRpbWVvdXQgZm9yIEZsYXNoIEVyYXNlIChpbiBtcykJKi8KI2RlZmluZSBDT05GSUdfU1lTX0ZMQVNIX1dSSVRFX1RPVVQJNTAwCS8qIFRpbWVvdXQgZm9yIEZsYXNoIFdyaXRlIChpbiBtcykJKi8KI2RlZmluZSBDT05GSUdfU1lTX1dSSVRFX1NXQVBQRURfREFUQQkJLyogc3dhcCBEYXRhYnl0ZXMgYmV0d2VlbiByZWFkaW5nL3dyaXRpbmcgKi8KCiNkZWZpbmUgQ09ORklHX0VOVl9JU19JTl9GTEFTSAkxCiNpZmRlZiBDT05GSUdfRU5WX0lTX0lOX0ZMQVNICiNkZWZpbmUgQ09ORklHX0VOVl9PRkZTRVQJCTB4MDAwMDAwMDAgIC8qIE9mZnNldCBvZiBFbnZpcm9ubWVudCBTZWN0b3IgaW4gYm90dG9tIHR5cGUgKi8KI2RlZmluZSBDT05GSUdfRU5WX1NJWkUJCTB4NDAwMAkgICAgLyogVG90YWwgU2l6ZSBvZiBFbnZpcm9ubWVudCBTZWN0b3IJKi8KI2RlZmluZSBDT05GSUdfRU5WX1NFQ1RfU0laRQkweDQwMDAJICAgIC8qIHNlZSBSRUFETUUgLSBlbnYgc2VjdG9yIHRvdGFsIHNpemUJKi8KCi8qIEFkZHJlc3MgYW5kIHNpemUgb2YgUmVkdW5kYW50IEVudmlyb25tZW50IFNlY3RvcgkqLwojZGVmaW5lIENPTkZJR19FTlZfT0ZGU0VUX1JFRFVORAkoQ09ORklHX0VOVl9PRkZTRVQrQ09ORklHX0VOVl9TSVpFKQojZGVmaW5lIENPTkZJR19FTlZfU0laRV9SRURVTkQJKENPTkZJR19FTlZfU0laRSkKCiNlbmRpZgovKiBsZXQgdXMgY2hhbmdpbmcgYW55dGhpbmcgaW4gb3VyIGVudmlyb25tZW50ICovCiNkZWZpbmUgQ09ORklHX0VOVl9PVkVSV1JJVEUKCi8qCiAqIE5BTkQtRkxBU0ggc3R1ZmYKICovCiNkZWZpbmUgQ09ORklHX1NZU19NQVhfTkFORF9ERVZJQ0UJMQojZGVmaW5lIENPTkZJR19TWVNfTkFORF9CQVNFCQkweDc3RDAwMDAwCgojZGVmaW5lIENPTkZJR19KRkZTMl9OQU5EIDEJCQkvKiBqZmZzMiBvbiBuYW5kIHN1cHBvcnQgKi8KCi8qIE5vIGNvbW1hbmQgbGluZSwgb25lIHN0YXRpYyBwYXJ0aXRpb24gKi8KI3VuZGVmCUNPTkZJR19DTURfTVREUEFSVFMKI2RlZmluZSBDT05GSUdfSkZGUzJfREVWCQkibmFuZDAiCiNkZWZpbmUgQ09ORklHX0pGRlMyX1BBUlRfU0laRQkJMHgwMTAwMDAwMAojZGVmaW5lIENPTkZJR19KRkZTMl9QQVJUX09GRlNFVAkweDAwMDAwMDAwCgovKgogKiBJbml0IE1lbW9yeSBDb250cm9sbGVyOgogKgogKi8KCiNkZWZpbmUgRkxBU0hfQkFTRTBfUFJFTElNCUNPTkZJR19TWVNfRkxBU0hfQkFTRQojZGVmaW5lIEZMQVNIX0JBU0UxX1BSRUxJTQkwCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFNvbWUgaW5mb3JtYXRpb25zIGFib3V0IHRoZSBpbnRlcm5hbCBTUkFNIChPQ009T24gQ2hpcCBNZW1vcnkpCiAqCiAqIENPTkZJR19TWVNfT0NNX0RBVEFfQUREUiAtPiBsb2NhdGlvbgogKiBDT05GSUdfU1lTX09DTV9EQVRBX1NJWkUgLT4gc2l6ZQoqLwoKI2RlZmluZSBDT05GSUdfU1lTX1RFTVBfU1RBQ0tfT0NNCTEKI2RlZmluZSBDT05GSUdfU1lTX09DTV9EQVRBX0FERFIJMHhGODAwMDAwMAojZGVmaW5lIENPTkZJR19TWVNfT0NNX0RBVEFfU0laRQkweDEwMDAKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogRGVmaW5pdGlvbnMgZm9yIGluaXRpYWwgc3RhY2sgcG9pbnRlciBhbmQgZGF0YSBhcmVhIChpbiBEUFJBTSk6CiAqIC0gd2UgYXJlIHVzaW5nIHRoZSBpbnRlcm5hbCA0ayBTUkFNLCBzbyB3ZSBkb24ndCBuZWVkIGRhdGEgY2FjaGUgbWFwcGluZwogKiAtIGludGVybmFsIFNSQU0gKE9DTT1PbiBDaGlwIE1lbW9yeSkgaXMgcGxhY2VkIHRvIENPTkZJR19TWVNfT0NNX0RBVEFfQUREUgogKiAtIFN0YWNrcG9pbnRlciB3aWxsIGJlIGxvY2F0ZWQgdG8KICogICAoQ09ORklHX1NZU19JTklUX1JBTV9BRERSJjB4RkZGRjAwMDApIHwgKENPTkZJR19TWVNfSU5JVF9TUF9PRkZTRVQmMHgwMDAwRkZGRikKICogICBpbiBhcmNoL3BwYy9jcHUvcHBjNHh4L3N0YXJ0LlMKICovCgojdW5kZWYgQ09ORklHX1NZU19JTklUX0RDQUNIRV9DUwovKiBXaGVyZSB0aGUgaW50ZXJuYWwgU1JBTSBzdGFydHMgKi8KI2RlZmluZSBDT05GSUdfU1lTX0lOSVRfUkFNX0FERFIJQ09ORklHX1NZU19PQ01fREFUQV9BRERSCi8qIFdoZXJlIHRoZSBpbnRlcm5hbCBTUkFNIGVuZHMgKG9ubHkgb2Zmc2V0KSAqLwojZGVmaW5lIENPTkZJR19TWVNfSU5JVF9SQU1fRU5ECTB4MEYwMAoKLyoKCiBDT05GSUdfU1lTX0lOSVRfUkFNX0FERFIgLS0tLS0tPiAtLS0tLS0tLS0tLS0gbG93ZXIgYWRkcmVzcwoJCQkgICB8CSAgICAgIHwKCQkJICAgfCAgXiAgICAgICB8CgkJCSAgIHwgIHwgICAgICAgfAoJCQkgICB8ICB8IFN0YWNrIHwKIENPTkZJR19TWVNfR0JMX0RBVEFfT0ZGU0VUIC0tLS0+IC0tLS0tLS0tLS0tLQoJCQkgICB8CSAgICAgIHwKCQkJICAgfCA2NCBCeXRlcyB8CgkJCSAgIHwJICAgICAgfAogQ09ORklHX1NZU19JTklUX1JBTV9FTkQgIC0tLS0tLT4gLS0tLS0tLS0tLS0tIGhpZ2hlciBhZGRyZXNzCiAgKG9mZnNldCBvbmx5KQoKKi8KLyogc2l6ZSBpbiBieXRlcyByZXNlcnZlZCBmb3IgaW5pdGlhbCBkYXRhICovCiNkZWZpbmUgQ09ORklHX1NZU19HQkxfREFUQV9TSVpFICAgICA2NAojZGVmaW5lIENPTkZJR19TWVNfR0JMX0RBVEFfT0ZGU0VUICAgKENPTkZJR19TWVNfSU5JVF9SQU1fRU5EIC0gQ09ORklHX1NZU19HQkxfREFUQV9TSVpFKQovKiBJbml0aWFsIHZhbHVlIG9mIHRoZSBzdGFjayBwb2ludGVybiBpbiBpbnRlcm5hbCBTUkFNICovCiNkZWZpbmUgQ09ORklHX1NZU19JTklUX1NQX09GRlNFVCAgICBDT05GSUdfU1lTX0dCTF9EQVRBX09GRlNFVAoKLyoKICogSW50ZXJuYWwgRGVmaW5pdGlvbnMKICoKICogQm9vdCBGbGFncwogKi8KI2RlZmluZSBCT09URkxBR19DT0xECTB4MDEJCS8qIE5vcm1hbCBQb3dlci1PbjogQm9vdCBmcm9tIEZMQVNICSovCiNkZWZpbmUgQk9PVEZMQUdfV0FSTQkweDAyCQkvKiBTb2Z0d2FyZSByZWJvb3QJCQkqLwoKLyogIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMgKi8KLyogVGhlc2UgZGVmaW5lcyB3aWxsIGJlIHVzZWQgaW4gYXJjaC9wcGMvY3B1L3BwYzR4eC9jcHVfaW5pdC5jIHRvIHNldHVwIGV4dGVybmFsIGNoaXAgc2VsZWN0cyAgKi8KLyogVGhleSBhcmUgY3VycmVudGx5IHVuZGVmaW5lZCBjYXVzZSB0aGV5IGFyZSBpbml0aWFpemVkIGluIGJvYXJkL3NvbGlkY2FyZDMvaW5pdC5TICAgKi8KCi8qIFRoaXMgY2hpcCBzZWxlY3QgYWNjZXNzZXMgdGhlIGJvb3QgZGV2aWNlICovCi8qIEl0IGRlcGVuZHMgb24gYm9vdCBzZWxlY3Qgc3dpdGNoIGlmIHRoaXMgZGV2aWNlIGlzIDE2IG9yIDggYml0ICovCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIwQVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCMENSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIxQVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCMUNSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIyQVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCMkNSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIzQVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCM0NSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI0QVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCNENSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI1QVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCNUNSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI2QVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCNkNSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI3QVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCN0NSCgojZGVmaW5lIENPTkZJR19TWVNfRUJDX0NGRyAgICAweGI4NGVmMDAwCgojZGVmaW5lIENPTkZJR19TRFJBTV9CQU5LMAkvKiB1c2UgdGhlIHN0YW5kYXJkIFNEUkFNIGluaXRpYWxpemF0aW9uICovCiN1bmRlZiBDT05GSUdfU1BEX0VFUFJPTQoKLyoKICogRGVmaW5lIHRoaXMgdG8gZ2V0IG1vcmUgaW5mb3JtYXRpb24gYWJvdXQgc3lzdGVtIGNvbmZpZ3VyYXRpb24KICovCi8qICNkZWZpbmUgU0MzX0RFQlVHT1VUICovCiN1bmRlZiBTQzNfREVCVUdPVVQKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiBFeHRlcm5hbCBwZXJpcGhlcmFsIGJhc2UgYWRkcmVzcwogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCgojZGVmaW5lIENPTkZJR19TWVNfSVNBX01FTV9CQVNFX0FERFJFU1MgMHg3ODAwMDAwMAovKgogRGllIEdyYWZpay1UcmVpYmVyIGdyZWlmZW4g/GJlciBkaWUgQWRyZXNzZSBpbiBkaWVzZW0gTWFjcm8gYXVmIGRlbiBDaGlwIHp1LgogRGFzIGZ1bmt0aW9uaWVydCBiZWkgZGVyZW4gS2FydGVuLCB3ZWlsIHNpZSBlaW5lIFBDSS1CcmlkZ2UgYmVudXR6ZW4sIGRpZQogZGFzIGdsZWljaGUgTWFwcGluZyBkdXJjaGb8aHJlbiBrYW5uLCB3aWUgZGVyIFNDNTIwIChhbHNvIEF1ZnRlaWxlbiB2b24gSU8tWnVncmlmZmVuCiBhdWYgSVNBLSB1bmQgUENJLVp5a2xlbikKICovCiNkZWZpbmUgQ09ORklHX1NZU19JU0FfSU9fQkFTRV9BRERSRVNTICAweEU4MDAwMDAwCi8qI2RlZmluZSBDT05GSUdfU1lTX0lTQV9JT19CQVNFX0FERFJFU1MgIDB4NzkwMDAwMDAgKi8KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogVmlkZW8gc3VwcG9ydAogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKI2lmZGVmIFVTRV9WR0FfR1JBUEhJQ1MKI2RlZmluZSBDT05GSUdfVklERU8JCS8qIFRvIGVuYWJsZSB2aWRlbyBjb250cm9sbGVyIHN1cHBvcnQgKi8KI2RlZmluZSBDT05GSUdfVklERU9fQ1Q2OTAwMAojZGVmaW5lIENPTkZJR19DRkJfQ09OU09MRQovKiAjZGVmaW5lIENPTkZJR19WSURFT19MT0dPICovCiNkZWZpbmUgQ09ORklHX1ZHQV9BU19TSU5HTEVfREVWSUNFCiNkZWZpbmUgQ09ORklHX1ZJREVPX1NXX0NVUlNPUgovKiAjZGVmaW5lIENPTkZJR19WSURFT19IV19DVVJTT1IgKi8KI2RlZmluZSBDT05GSUdfVklERU9fT05CT0FSRAkvKiBWaWRlbyBjb250cm9sbGVyIGlzIG9uLWJvYXJkICovCgojZGVmaW5lIFZJREVPX0hXX1JFQ1RGSUxMCiNkZWZpbmUgVklERU9fSFdfQklUQkxUCgojZW5kaWYKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogSWRlbnQKICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KI2RlZmluZSBDT05GSUdfU0MzX1ZFUlNJT04gInIxLjQiCgojZGVmaW5lIFBPU1RfT1VUKHgpICgqKCh2b2xhdGlsZSB1bnNpZ25lZCBjaGFyKikoMHg3OTAwMDA4MCkpPXgpCgojZW5kaWYJLyogX19DT05GSUdfSCAqLwo=