LyoKICogKEMpIENvcHlyaWdodCAyMDA3CiAqIEhlaWtvIFNjaG9jaGVyLCBERU5YIFNvZnR3YXJlIEVuZ2luZWVyaW5nLCA8aHNAZGVueC5kZT4uCiAqCiAqIEZyb206CiAqIChDKSBDb3B5cmlnaHQgMjAwMwogKiBKdWVyZ2VuIEJlaXNlcnQsIEV1cm9EZXNpZ24gZW1iZWRkZWQgdGVjaG5vbG9naWVzLCBqYmVpc2VydEBldXJvZHNuLmRlCiAqCiAqIFNlZSBmaWxlIENSRURJVFMgZm9yIGxpc3Qgb2YgcGVvcGxlIHdobyBjb250cmlidXRlZCB0byB0aGlzCiAqIHByb2plY3QuCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IKICogbW9kaWZ5IGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMKICogcHVibGlzaGVkIGJ5IHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVpdGhlciB2ZXJzaW9uIDIgb2YKICogdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLAogKiBidXQgV0lUSE9VVCBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZgogKiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuCSBTZWUgdGhlCiAqIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvciBtb3JlIGRldGFpbHMuCiAqCiAqIFlvdSBzaG91bGQgaGF2ZSByZWNlaXZlZCBhIGNvcHkgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlCiAqIGFsb25nIHdpdGggdGhpcyBwcm9ncmFtOyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDU5IFRlbXBsZSBQbGFjZSwgU3VpdGUgMzMwLCBCb3N0b24sCiAqIE1BIDAyMTExLTEzMDcgVVNBCiAqLwoKI2lmbmRlZiBfX0NPTkZJR19ICiNkZWZpbmUgX19DT05GSUdfSAoKI3VuZGVmIFVTRV9WR0FfR1JBUEhJQ1MKCi8qIE1lbW9yeSBNYXAKICogMHgwMDAwMDAwMCAuLi4uIDB4MDNGRkZGRkYgLT4gUkFNICh1cCB0byAxMjhNaUIpCiAqIDB4NzQwMDAwMDAgLi4uLiAweDc0MEZGRkZGIC0+IENTIzYKICogMHg3NDEwMDAwMCAuLi4uIDB4NzQxRkZGRkYgLT4gQ1MjNwogKiAweDc0MjAwMDAwIC4uLi4gMHg3NDJGRkZGRiAtPiBDUzQjIGlmIG5vIGludGVybmFsIFVTQgogKiAweDc0MzAwMDAwIC4uLi4gMHg3NDNGRkZGRiAtPiBDUzUjIGlmIG5vIGJvb3N0ZWQgSURFCiAqIDB4NzdDMDAwMDAgLi4uLiAweDc3Q0ZGRkZGIC0+IENTNCMgVVNCIEhDICgxIE1pQikKICogMHg3N0QwMDAwMCAuLi4uIDB4NzdERkZGRkYgLT4gQ1MxIyBOQU5ELUZsYXNoICgxIE1pQikKICogMHg3ODAwMDAwMCAuLi4uIDB4NzhGRkZGRkYgLT4gQ1MyIyBJU0EtQnVzIFNwZWljaGVyenVncmlmZiAoMTYgTWlCKQogKiAweDc5MDAwMDAwIC4uLi4gMHg3OTAwRkZGRiAtPiBDUzIjIElTQS1CdXMgSU8tWnVncmlmZiAoMTYgTWlCLCBtYXBwZWQ6IDY0a2lCKQogKiAweDc5MDEwMDAwIC4uLi4gMHg3OUZGRkZGRiAtPiBDUzIjIElTQS1CdXMgSU8tWnVncmlmZiAobWlycm9yZWQpCiAqIDB4N0EwMDAwMDAgLi4uLiAweDdBMEZGRkZGIC0+IENTNSMgSURFIGVtdWxhdGlvbiAoMU1pQikKICoKICogMHg4MDAwMDAwMCAuLi4uIDB4OUZGRkZGRkYgLT4gUENJLUJ1cyBTcGVpY2hlcnp1Z3JpZmYgKDUxMk1pQiwgbWFwcGVkOiAxOjEpCiAqIDB4QTAwMDAwMDAgLi4uLiAweEJGRkZGRkZGIC0+IFBDSS1CdXMgU3BlaWNoZXJ6dWdyaWZmICg1MTJNaUIsIG1hcHBlZDogMHgwMDAwMDAwMC4uLjB4MUZGRkZGRkYpCiAqIDB4RTgwMDAwMDAgLi4uLiAweEU4MDBGRkZGIC0+IFBDSS1CdXMgSU8tWnVncmlmZiAoNjRraUIsIHRyYW5zbGF0ZWQgdG8gUENJOiAweDAwMDAuLi4weEZGRkYpCiAqIDB4RTg4MDAwMDAgLi4uLiAweEVCRkZGRkZGIC0+IFBDSS1CdXMgSU8tWnVncmlmZiAoNTZNaUIsIHRyYW5zbGF0ZWQgdG8gUENJOiAweDAwODAwMDAwLi4uMHgzRkZGRkZGKQogKiAweEVFRDAwMDAwIC4uLi4gMHhFRUQwMDAwMyAtPiBQQ0ktQnVzCiAqIDB4RUY0MDAwMDAgLi4uLiAweEVGNDAwMDNGIC0+IFBDSS1CdXMgTG9jYWwgQ29uZmlndXJhdGlvbiBSZWdpc3RlcnMKICogMHhFRjQwMDAzRiAuLi4uIDB4RUY1RkZGRkYgLT4gcmVzZXJ2ZWQKICogMHhFRjYwMDAwMCAuLi4uIDB4RUZGRkZGRkYgLT4gNDA1R1AgaW50ZXJuYWwgRGV2aWNlcyAoMTAgTWlCKQogKiAweEYwMDAwMDAwIC4uLi4gMHhGMDFGRkZGRiAtPiBGbGFzaC1ST00gKDIgTWlCKQogKiAweEYwMjAwMDAwIC4uLi4gMHhGN0ZGRkZGRiAtPiBmcmVlIGZvciBmbGFzaCBkZXZpY2VzCiAqIDB4RjgwMDAwMDAgLi4uLiAweEY4MDAwRkZGIC0+IE9uQ2hpcE1lbW9yeSAoNGtpQikKICogMHhGODAwMTAwMCAuLi4uIDB4RkZERkZGRkYgLT4gZnJlZSBmb3IgZmxhc2ggZGV2aWNlcwogKiAweEZGRTAwMDAwIC4uLi4gMHhGRkZGRkZGRiAtPiBCT09ULVJPTSAoMiBNaUIpCiAqLwoKI2RlZmluZSBDT05GSUdfU0MzCTEKI2RlZmluZSBDT05GSUdfNHh4CTEKI2RlZmluZSBDT05GSUdfNDA1R1AJMQoKI2RlZmluZSBDT05GSUdfQk9BUkRfRUFSTFlfSU5JVF9GCTEKCi8qCiAqIERlZmluZSBJREVfVVNFU19JU0FfRU1VTEFUSU9OIGZvciBzbG93ZXIgSURFIGFjY2VzcyBpbiB0aGUgSVNBLUlPIGFkZHJlc3MgcmFuZ2UKICogSWYgdW5kZWZpbmVkLCBJREUgYWNjZXNzIHVzZXMgYSBzZXBlcmF0IGVtdWxhdGlvbiB3aXRoIGhpZ2hlciBhY2Nlc3Mgc3BlZWQuCiAqIENvbnNpZGVyIHRvIGluZm9ybSB5b3VyIExpbnV4IElERSBkcml2ZXIgYWJvdXQgdGhlIGRpZmZlcmVudCBhZGRyZXNzZXMhCiAqIElERV9VU0VTX0lTQV9FTVVMQVRJT04gaXMgb25seSB1c2VkIGlmIHlvdSBkZWZpbmUgQ09ORklHX0NNRF9JREUhCiAqLwojZGVmaW5lIElERV9VU0VTX0lTQV9FTVVMQVRJT04KCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogU2VyaWFsIFBvcnQKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKi8KI2RlZmluZSBDT05GSUdfU0VSSUFMX01VTFRJCiN1bmRlZiBDT05GSUdfU0VSSUFMX1NPRlRXQVJFX0ZJRk8KLyoKICogZGVmaW5lIENPTkZJR19QT1dFUl9ET1dOIGlmIHlvdXIgY3B1IHNob3VsZCBwb3dlciBkb3duIHdoaWxlIHdhaXRpbmcgZm9yIHlvdXIgaW5wdXQKICogV29ya3Mgb25seSwgaWYgeW91IGhhdmUgZW5hYmxlZCB0aGUgQ09ORklHX1NFUklBTF9TT0ZUV0FSRV9GSUZPIGZlYXR1cmUKICovCiNpZiBDT05GSUdfU0VSSUFMX1NPRlRXQVJFX0ZJRk8KICNkZWZpbmUgQ09ORklHX1BPV0VSX0RPV04KI2VuZGlmCgovKgogKiBkZWZpbmUgQ09ORklHX1NZU19DTEtfRlJFUSB0byB5b3VyIGJhc2UgY3J5c3RhbCBjbG9jayBpbiBIegogKi8KI2RlZmluZSBDT05GSUdfU1lTX0NMS19GUkVRCTMzMzMzMzMzCgovKgogKiBkZWZpbmUgQ09ORklHX0JBVURSQVRFIHRvIHRoZSBiYXVkcmF0ZSB2YWx1ZSB5b3Ugd2FudCB0byB1c2UgYXMgZGVmYXVsdAogKi8KI2RlZmluZSBDT05GSUdfQkFVRFJBVEUJCTExNTIwMAojZGVmaW5lIENPTkZJR19CT09UREVMQVkJMyAvKiBhdXRvYm9vdCBhZnRlciAzIHNlY29uZHMJICAgICAgKi8KCiNkZWZpbmUgQ09ORklHX1BSRUJPT1QJImVjaG87IglcCgkiZWNobyBUeXBlIFxcXCJydW4gZmxhc2hfbmZzXFxcIiB0byBtb3VudCByb290IGZpbGVzeXN0ZW0gb3ZlciBORlM7IiBcCgkiZWNobyIKCiN1bmRlZglDT05GSUdfQk9PVEFSR1MKCiNkZWZpbmUJQ09ORklHX0VYVFJBX0VOVl9TRVRUSU5HUwkJCQkJXAoJIm5ldGRldj1ldGgwXDAiCQkJCQkJCVwKCSJuZnNhcmdzPXNldGVudiBib290YXJncyByb290PS9kZXYvbmZzIHJ3ICIJCQlcCgkJIm5mc3Jvb3Q9JHtzZXJ2ZXJpcH06JHtyb290cGF0aH1cMCIJCQlcCgkicmFtYXJncz1zZXRlbnYgYm9vdGFyZ3Mgcm9vdD0vZGV2L3JhbSByd1wwIgkJCVwKCSJuYW5kX2FyZ3M9c2V0ZW52IGJvb3RhcmdzIHJvb3Q9L2Rldi9tdGRibG9jazUgcnciCQlcCgkJInJvb3Rmc3R5cGU9amZmczJcMCIJCQkJCVwKCSJhZGRpcD1zZXRlbnYgYm9vdGFyZ3MgJHtib290YXJnc30gIgkJCQlcCgkJImlwPSR7aXBhZGRyfToke3NlcnZlcmlwfToke2dhdGV3YXlpcH06JHtuZXRtYXNrfSIJXAoJCSI6JHtob3N0bmFtZX06JHtuZXRkZXZ9Om9mZiBwYW5pYz0xXDAiCQkJXAoJImFkZGNvbnM9c2V0ZW52IGJvb3RhcmdzICR7Ym9vdGFyZ3N9ICIJCQkJXAoJCSJjb25zb2xlPXR0eVMwLCR7YmF1ZHJhdGV9XDAiCQkJCVwKCSJmbGFzaF9uZnM9cnVuIG5mc2FyZ3MgYWRkaXAgYWRkY29uczsiCQkJCVwKCQkiYm9vdG0gJHtrZXJuZWxfYWRkcn1cMCIJCQkJXAoJImZsYXNoX25hbmQ9cnVuIG5hbmRfYXJncyBhZGRpcCBhZGRjb25zO2Jvb3RtICR7a2VybmVsX2FkZHJ9XDAiCVwKCSJuZXRfbmZzPXRmdHAgMjAwMDAwICR7Ym9vdGZpbGV9O3J1biBuZnNhcmdzIGFkZGlwIGFkZGNvbnM7IglcCgkJImJvb3RtXDAiCQkJCQkJXAoJInJvb3RwYXRoPS9vcHQvZWxkay9wcGNfNHh4XDAiCQkJCQlcCgkiYm9vdGZpbGU9L3RmdHBib290L3NjMy91SW1hZ2VcMCIJCQkJXAoJInUtYm9vdD0vdGZ0cGJvb3Qvc2MzL3UtYm9vdC5iaW5cMCIJCQkJXAoJInNldHVwPXRmdHAgMjAwMDAwIC90ZnRwYm9vdC9zYzMvc2V0dXAuaW1nO2F1dG9zY3IgMjAwMDAwXDAiCVwKCSJrZXJuZWxfYWRkcj1GRkUwODAwMFwwIgkJCQkJXAoJIiIKI3VuZGVmIENPTkZJR19CT09UQ09NTUFORAoKI2RlZmluZSBDT05GSUdfU0lMRU5UX0NPTlNPTEUJMQkvKiBlbmFibGUgc2lsZW50IHN0YXJ0dXAgKi8KI2RlZmluZSBDT05GSUdfU1lTX0RFVklDRV9OVUxMREVWCTEJLyogaW5jbHVkZSBudWxsZGV2IGRldmljZQkqLwoKI2lmIDEJLyogZmVlbCBmcmVlIHRvIGRpc2FibGUgZm9yIGRldmVsb3BtZW50ICovCiNkZWZpbmUgQ09ORklHX0FVVE9CT09UX0tFWUVECQkvKiBFbmFibGUgcGFzc3dvcmQgcHJvdGVjdGlvbgkqLwojZGVmaW5lIENPTkZJR19BVVRPQk9PVF9QUk9NUFQJCVwKCSJcblNDMyAtIGJvb3RpbmcuLi4gc3RvcCB3aXRoIEVOVEVSXG4iCiNkZWZpbmUgQ09ORklHX0FVVE9CT09UX0RFTEFZX1NUUgkiXHIiCS8qIDFzdCAicGFzc3dvcmQiCSovCiNkZWZpbmUgQ09ORklHX0FVVE9CT09UX0RFTEFZX1NUUjIJIlxuIgkvKiAxc3QgInBhc3N3b3JkIgkqLwojZW5kaWYKCi8qCiAqIGRlZmluZSBDT05GSUdfQk9PVENPTU1BTkQgdG8gdGhlIGF1dG9ib290IGNvbW1hbmRzLiBUaGV5IHdpbGwgcnVubmluZyBhZnRlcgogKiB0aGUgQ09ORklHX0JPT1RERUxBWSBkZWxheSB0byBib290IHlvdXIgbWFjaGluZQogKi8KI2RlZmluZSBDT05GSUdfQk9PVENPTU1BTkQJImJvb3RwO2RjYWNoZSBvbjtib290bSIKCi8qCiAqIGRlZmluZSBDT05GSUdfQk9PVEFSR1MgdG8gdGhlIGRlZmF1bHQga2VybmVsIHBhcmFtZXRlcnMuIFRoZXkgd2lsbCB1c2VkIGlmIHlvdSBkb24ndAogKiBzZXQgZGlmZmVyZW50IHZhbHVlcyBhdCB0aGUgdS1ib290IHByb21wdAogKi8KI2lmZGVmIFVTRV9WR0FfR1JBUEhJQ1MKICNkZWZpbmUgQ09ORklHX0JPT1RBUkdTCSJyb290PS9kZXYvbmZzIHJ3IGlwPWJvb3RwIG5mc3Jvb3Q9L3RmdHBib290L3NvbGlkY2FyZDNyZSIKI2Vsc2UKICNkZWZpbmUgQ09ORklHX0JPT1RBUkdTCSJjb25zb2xlPXR0eVMwLDExNTIwMCByb290PS9kZXYvbmZzIHJ3IGlwPWJvb3RwIgojZW5kaWYKLyoKICogSXMgdGhlIFVTQiBob3N0IGNvbnRyb2xsZXIgYXNzZW1ibGVkPyBJZiB5ZXMgZGVmaW5lIENPTkZJR19JU1AxMTYxX1BSRVNFTlQKICogVGhpcyByZXNlcnZlcyBtZW1vcnkgYmFuayAjNCBmb3IgdGhpcyBwdXJwb3NlCiAqLwojdW5kZWYgQ09ORklHX0lTUDExNjFfUFJFU0VOVAoKI3VuZGVmIENPTkZJR19MT0FEU19FQ0hPICAgLyogbm8gZWNobyBvbiBmb3Igc2VyaWFsIGRvd25sb2FkCSovCiNkZWZpbmUgQ09ORklHX1NZU19MT0FEU19CQVVEX0NIQU5HRQkxCS8qIGFsbG93IGJhdWRyYXRlIGNoYW5nZQkqLwoKI2RlZmluZSBDT05GSUdfTkVUX01VTFRJCi8qICNkZWZpbmUgQ09ORklHX0VFUFJPMTAwX1NST01fV1JJVEUgKi8KLyogI2RlZmluZSBDT05GSUdfU0hPV19NQUMgKi8KI2RlZmluZSBDT05GSUdfRUVQUk8xMDAKCiNkZWZpbmUgQ09ORklHX1BQQzR4eF9FTUFDCiNkZWZpbmUgQ09ORklHX01JSSAxCQkJLyogYWRkIDQwNUdQIE1JSSBQSFkgbWFuYWdlbWVudAkJKi8KI2RlZmluZSBDT05GSUdfUEhZX0FERFIgMQkvKiB0aGUgY29ubmVjdGVkIFBoeSBkZWZhdWx0cyB0byBhZGRyZXNzIDEgKi8KCi8qCiAqIEJPT1RQIG9wdGlvbnMKICovCiNkZWZpbmUgQ09ORklHX0JPT1RQX0JPT1RGSUxFU0laRQojZGVmaW5lIENPTkZJR19CT09UUF9CT09UUEFUSAojZGVmaW5lIENPTkZJR19CT09UUF9HQVRFV0FZCiNkZWZpbmUgQ09ORklHX0JPT1RQX0hPU1ROQU1FCgoKLyoKICogQ29tbWFuZCBsaW5lIGNvbmZpZ3VyYXRpb24uCiAqLwojaW5jbHVkZSA8Y29uZmlnX2NtZF9kZWZhdWx0Lmg+CgoKI2RlZmluZSBDT05GSUdfQ01EX0FVVE9TQ1JJUFQKI2RlZmluZSBDT05GSUdfQ01EX1BDSQojZGVmaW5lIENPTkZJR19DTURfSVJRCiNkZWZpbmUgQ09ORklHX0NNRF9ORVQKI2RlZmluZSBDT05GSUdfQ01EX01JSQojZGVmaW5lIENPTkZJR19DTURfUElORwojZGVmaW5lIENPTkZJR19DTURfTkFORAojZGVmaW5lIENPTkZJR19DTURfSkZGUzIKI2RlZmluZSBDT05GSUdfQ01EX0kyQwojZGVmaW5lIENPTkZJR19DTURfSURFCiNkZWZpbmUgQ09ORklHX0NNRF9EQVRFCiNkZWZpbmUgQ09ORklHX0NNRF9ESENQCiNkZWZpbmUgQ09ORklHX0NNRF9DQUNIRQojZGVmaW5lIENPTkZJR19DTURfRUxGCgoKI3VuZGVmIENPTkZJR19XQVRDSERPRwkJCS8qIHdhdGNoZG9nIGRpc2FibGVkCQkqLwoKLyoKICogTWlzY2VsbGFuZW91cyBjb25maWd1cmFibGUgb3B0aW9ucwogKi8KI2RlZmluZSBDT05GSUdfU1lTX0xPTkdIRUxQCTEJCS8qIHVuZGVmIHRvIHNhdmUgbWVtb3J5CQkqLwojZGVmaW5lIENPTkZJR19TWVNfUFJPTVBUCSJTQzM+ICIJLyogTW9uaXRvciBDb21tYW5kIFByb21wdAkqLwojZGVmaW5lCUNPTkZJR19TWVNfQ0JTSVpFCTI1NgkJLyogQ29uc29sZSBJL08gQnVmZmVyIFNpemUJKi8KCiNkZWZpbmUgQ09ORklHX1NZU19QQlNJWkUgKENPTkZJR19TWVNfQ0JTSVpFK3NpemVvZihDT05GSUdfU1lTX1BST01QVCkrMTYpIC8qIFByaW50IEJ1ZmZlciBTaXplICovCgojZGVmaW5lIENPTkZJR19TWVNfTUFYQVJHUwkxNgkJLyogbWF4IG51bWJlciBvZiBjb21tYW5kIGFyZ3MJKi8KI2RlZmluZSBDT05GSUdfU1lTX0JBUkdTSVpFCUNPTkZJR19TWVNfQ0JTSVpFCS8qIEJvb3QgQXJndW1lbnQgQnVmZmVyIFNpemUJKi8KCiNkZWZpbmUgQ09ORklHX1NZU19NRU1URVNUX1NUQVJUCTB4MDQwMDAwMAkvKiBtZW10ZXN0IHdvcmtzIG9uCSovCiNkZWZpbmUgQ09ORklHX1NZU19NRU1URVNUX0VORAkJMHgwQzAwMDAwCS8qIDQgLi4uIDEyIE1CIGluIERSQU0JKi8KCi8qCiAqIElmIENPTkZJR19TWVNfRVhUX1NFUklBTF9DTE9DSywgdGhlbiB0aGUgVUFSVCBkaXZpc29yIGlzIDEuCiAqIElmIENPTkZJR19TWVNfNDA1X1VBUlRfRVJSQVRBXzU5LCB0aGVuIFVBUlQgZGl2aXNvciBpcyAzMS4KICogT3RoZXJ3aXNlLCBVQVJUIGRpdmlzb3IgaXMgZGV0ZXJtaW5lZCBieSBDUFUgQ2xvY2sgYW5kIENPTkZJR19TWVNfQkFTRV9CQVVEIHZhbHVlLgogKiBUaGUgTGludXggQkFTRV9CQVVEIGRlZmluZSBzaG91bGQgbWF0Y2ggdGhpcyBjb25maWd1cmF0aW9uLgogKiAgICBiYXNlQmF1ZCA9IGNwdUNsb2NrLyh1YXJ0RGl2aXNvcioxNikKICogSWYgQ09ORklHX1NZU180MDVfVUFSVF9FUlJBVEFfNTkgYW5kIDIwME1IeiBDUFUgY2xvY2ssCiAqIHNldCBMaW51eCBCQVNFX0JBVUQgdG8gNDAzMjAwLgogKgogKiBDb25zaWRlciB0aGUgT1BCIGNsb2NrISBJZiBpdCBnZXQgbG93ZXIgdGhlIEJBU0VfQkFVRCBtdXN0IGJlIGxvd2VyIHRvCiAqIChzZWUgNDA1R1AgZGF0YXNoZWV0IGZvciBkZXNjcml0cGlvbikKICovCiN1bmRlZglDT05GSUdfU1lTX0VYVF9TRVJJQUxfQ0xPQ0sJCS8qIGV4dGVybmFsIHNlcmlhbCBjbG9jayAqLwojdW5kZWYJQ09ORklHX1NZU180MDVfVUFSVF9FUlJBVEFfNTkJCS8qIDQwNUdQL0NSIFJldi4gRCBzaWxpY29uICovCiNkZWZpbmUgQ09ORklHX1NZU19CQVNFX0JBVUQJCTkyMTYwMAkvKiBpbnRlcm5hbCBjbG9jayAqLwoKLyogVGhlIGZvbGxvd2luZyB0YWJsZSBpbmNsdWRlcyB0aGUgc3VwcG9ydGVkIGJhdWRyYXRlcyAqLwojZGVmaW5lIENPTkZJR19TWVNfQkFVRFJBVEVfVEFCTEUgIFwKICAgIHszMDAsIDYwMCwgMTIwMCwgMjQwMCwgNDgwMCwgOTYwMCwgMTkyMDAsIDM4NDAwLCA1NzYwMCwgMTE1MjAwLCAyMzA0MDB9CgojZGVmaW5lIENPTkZJR19TWVNfTE9BRF9BRERSCQkweDEwMDAwMDAJLyogZGVmYXVsdCBsb2FkIGFkZHJlc3MgKi8KI2RlZmluZSBDT05GSUdfU1lTX0VYVEJESU5GTwkJMQkvKiBUbyB1c2UgZXh0ZW5kZWQgYm9hcmRfaW50byAoYmRfdCkgKi8KCiNkZWZpbmUJQ09ORklHX1NZU19IWgkJCTEwMDAJLyogZGVjcmVtZW50ZXIgZnJlcTogMSBtcyB0aWNrcwkqLwoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBJSUMgc3R1ZmYKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKi8KI2RlZmluZSAgQ09ORklHX0hBUkRfSTJDCQkvKiBJMkMgd2l0aCBoYXJkd2FyZSBzdXBwb3J0CSovCiN1bmRlZglDT05GSUdfU09GVF9JMkMJCQkvKiBJMkMgYml0LWJhbmdlZAkJKi8KCiNkZWZpbmUgSTJDX0lOSVQKI2RlZmluZSBJMkNfQUNUSVZFIDAKI2RlZmluZSBJMkNfVFJJU1RBVEUgMAoKI2RlZmluZSBDT05GSUdfU1lTX0kyQ19TUEVFRAkJMTAwMDAwCS8qIHVzZSB0aGUgc3RhbmRhcmQgMTAwa0h6IHNwZWVkICovCiNkZWZpbmUgQ09ORklHX1NZU19JMkNfU0xBVkUJCTB4N0YJCS8qIG1hc2sgdmFsaWQgYml0cyAqLwoKI2RlZmluZSBDT05GSUdfUlRDX0RTMTMzNwojZGVmaW5lIENPTkZJR19TWVNfSTJDX1JUQ19BRERSIDB4NjgKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogUENJIHN0dWZmCiAqLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICovCiNkZWZpbmUgUENJX0hPU1RfQURBUFRFUiAwCQkvKiBjb25maWd1cmUgYXIgcGNpIGFkYXB0ZXIJKi8KI2RlZmluZSBQQ0lfSE9TVF9GT1JDRQkxCQkvKiBjb25maWd1cmUgYXMgcGNpIGhvc3QJKi8KI2RlZmluZSBQQ0lfSE9TVF9BVVRPCTIJCS8qIGRldGVjdGVkIHZpYSBhcmJpdGVyIGVuYWJsZQkqLwoKI2RlZmluZSBDT05GSUdfUENJCQkJLyogaW5jbHVkZSBwY2kgc3VwcG9ydAkJKi8KI2RlZmluZSBDT05GSUdfUENJX0hPU1QJUENJX0hPU1RfRk9SQ0UJLyogc2VsZWN0IHBjaSBob3N0IGZ1bmN0aW9uCSovCiNkZWZpbmUgQ09ORklHX1BDSV9QTlAJCQkvKiBkbyBwY2kgcGx1Zy1hbmQtcGxheQkJKi8KCQkJCQkvKiByZXNvdXJjZSBjb25maWd1cmF0aW9uCSovCgovKiBJZiB5b3Ugd2FudCB0byBzZWUsIHdoYXRzIGNvbm5lY3RlZCB0byB5b3VyIFBDSSBidXMgKi8KLyogI2RlZmluZSBDT05GSUdfUENJX1NDQU5fU0hPVyAqLwoKI2RlZmluZSBDT05GSUdfU1lTX1BDSV9TVUJTWVNfVkVORE9SSUQgMHgwMDAwCS8qIFBDSSBWZW5kb3IgSUQ6IHRvLWRvISEhCSovCiNkZWZpbmUgQ09ORklHX1NZU19QQ0lfU1VCU1lTX0RFVklDRUlEIDB4MDAwMAkvKiBQQ0kgRGV2aWNlIElEOiB0by1kbyEhIQkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTFMQQkweDAwMDAwMDAwCS8qIHBvaW50IHRvIHNkcmFtCQkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTFNUwkweDgwMDAwMDAxCS8qIDJHQiwgZW5hYmxlIGhhcmQtd2lyZWQgdG8gMQkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTFQQ0kgMHgwMDAwMDAwMAkvKiBIb3N0OiB1c2UgdGhpcyBwY2kgYWRkcmVzcwkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTJMQQkweDAwMDAwMDAwCS8qIGRpc2FibGVkCQkJKi8KI2RlZmluZSBDT05GSUdfU1lTX1BDSV9QVE0yTVMJMHgwMDAwMDAwMAkvKiBkaXNhYmxlZAkJCSovCiNkZWZpbmUgQ09ORklHX1NZU19QQ0lfUFRNMlBDSSAweDA0MDAwMDAwCS8qIEhvc3Q6IHVzZSB0aGlzIHBjaSBhZGRyZXNzCSovCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIEV4dGVybmFsIHBlcmlwaGVyYWwgYmFzZSBhZGRyZXNzCiAqLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICovCiNpZiAhZGVmaW5lZChDT05GSUdfQ01EX0lERSkKCiN1bmRlZglDT05GSUdfSURFX0xFRAkJCS8qIG5vIGxlZCBmb3IgaWRlIHN1cHBvcnRlZAkqLwojdW5kZWYJQ09ORklHX0lERV9SRVNFVAkJLyogbm8gcmVzZXQgZm9yIGlkZSBzdXBwb3J0ZWQJKi8KCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogSURFL0FUQSBzdHVmZgogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqLwojZWxzZQojZGVmaW5lIENPTkZJR19TVEFSVF9JREUJMQkvKiBjaGVjaywgaWYgdXNlIElERSAqLwoKI3VuZGVmCUNPTkZJR19JREVfOHh4X0RJUkVDVAkJLyogbm8gcGNtY2lhIGludGVyZmFjZSByZXF1aXJlZCAqLwojdW5kZWYJQ09ORklHX0lERV9MRUQJCQkvKiBubyBsZWQgZm9yIGlkZSBzdXBwb3J0ZWQJKi8KI3VuZGVmCUNPTkZJR19JREVfUkVTRVQJCS8qIG5vIHJlc2V0IGZvciBpZGUgc3VwcG9ydGVkCSovCgojZGVmaW5lCUNPTkZJR19BVEFQSQojZGVmaW5lCUNPTkZJR19ET1NfUEFSVElUSU9OCiNkZWZpbmUJQ09ORklHX1NZU19JREVfTUFYREVWSUNFCShDT05GSUdfU1lTX0lERV9NQVhCVVMqMSkgLyogbWF4LiAxIGRyaXZlcyBwZXIgSURFIGJ1cyAqLwoKI2lmbmRlZiBJREVfVVNFU19JU0FfRU1VTEFUSU9OCgovKiBOZXcgYW5kIGZhc3RlciBhY2Nlc3MgKi8KI2RlZmluZQlDT05GSUdfU1lTX0FUQV9CQVNFX0FERFIJCTB4N0EwMDAwMDAJLyogc3RhcnQgb2YgSVNBIElPIGVtdWxhdGlvbiAqLwoKLyogSG93IG1hbnkgSURFIGJ1c3NlcyBhcmUgYXZhaWxhYmxlICovCiNkZWZpbmUJQ09ORklHX1NZU19JREVfTUFYQlVTCQkxCgovKiBXaGF0IElERSBwb3J0cyBhcmUgYXZhaWxhYmxlICovCiNkZWZpbmUJQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQJMHgwMDAJCS8qIGZpcnN0IGlzIGF2YWlsYWJsZSAqLwojdW5kZWYJQ09ORklHX1NZU19BVEFfSURFMV9PRkZTRVQJCQkvKiBzZWNvbmQgbm90IGF2YWlsYWJsZSAqLwoKLyogYWNjZXNzIHRvIHRoZSBkYXRhIHBvcnQgaXMgY2FsY3VsYXRlZDoKICAgQ09ORklHX1NZU19BVEFfQkFTRV9BRERSICsgQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQgKyBDT05GSUdfU1lTX0FUQV9EQVRBX09GRlNFVCArIDAgKi8KI2RlZmluZSBDT05GSUdfU1lTX0FUQV9EQVRBX09GRlNFVAkweDAwMDAJLyogT2Zmc2V0IGZvciBkYXRhIEkvTyAqLwoKLyogYWNjZXNzIHRvIHRoZSByZWdpc3RlcnMgaXMgY2FsY3VsYXRlZDoKICAgQ09ORklHX1NZU19BVEFfQkFTRV9BRERSICsgQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQgKyBDT05GSUdfU1lTX0FUQV9SRUdfT0ZGU0VUICsgWzEuLjddICovCiNkZWZpbmUJQ09ORklHX1NZU19BVEFfUkVHX09GRlNFVAkweDAwMDAJLyogT2Zmc2V0IGZvciBub3JtYWwgcmVnaXN0ZXIgYWNjZXNzZXMJKi8KCi8qIGFjY2VzcyB0byB0aGUgYWx0ZXJuYXRlIHJlZ2lzdGVyIGlzIGNhbGN1bGF0ZWQ6CiAgIENPTkZJR19TWVNfQVRBX0JBU0VfQUREUiArIENPTkZJR19TWVNfQVRBX0lERTBfT0ZGU0VUICsgQ09ORklHX1NZU19BVEFfQUxUX09GRlNFVCArIDYgKi8KI2RlZmluZSBDT05GSUdfU1lTX0FUQV9BTFRfT0ZGU0VUCTB4MDA4CQkvKiBPZmZzZXQgZm9yIGFsdGVybmF0ZSByZWdpc3RlcnMJKi8KCiNlbHNlIC8qIElERV9VU0VTX0lTQV9FTVVMQVRJT04gKi8KCiNkZWZpbmUJQ09ORklHX1NZU19BVEFfQkFTRV9BRERSCQkweDc5MDAwMDAwCS8qIHN0YXJ0IG9mIElTQSBJTyBlbXVsYXRpb24gKi8KCi8qIEhvdyBtYW55IElERSBidXNzZXMgYXJlIGF2YWlsYWJsZSAqLwojZGVmaW5lCUNPTkZJR19TWVNfSURFX01BWEJVUwkJMQoKLyogV2hhdCBJREUgcG9ydHMgYXJlIGF2YWlsYWJsZSAqLwojZGVmaW5lCUNPTkZJR19TWVNfQVRBX0lERTBfT0ZGU0VUCTB4MDFGMAkvKiBmaXJzdCBpcyBhdmFpbGFibGUgKi8KI3VuZGVmCUNPTkZJR19TWVNfQVRBX0lERTFfT0ZGU0VUCQkJCS8qIHNlY29uZCBub3QgYXZhaWxhYmxlICovCgovKiBhY2Nlc3MgdG8gdGhlIGRhdGEgcG9ydCBpcyBjYWxjdWxhdGVkOgogICBDT05GSUdfU1lTX0FUQV9CQVNFX0FERFIgKyBDT05GSUdfU1lTX0FUQV9JREUwX09GRlNFVCArIENPTkZJR19TWVNfQVRBX0RBVEFfT0ZGU0VUICsgMCAqLwojZGVmaW5lIENPTkZJR19TWVNfQVRBX0RBVEFfT0ZGU0VUCTB4MDAwMAkvKiBPZmZzZXQgZm9yIGRhdGEgSS9PICovCgovKiBhY2Nlc3MgdG8gdGhlIHJlZ2lzdGVycyBpcyBjYWxjdWxhdGVkOgogICBDT05GSUdfU1lTX0FUQV9CQVNFX0FERFIgKyBDT05GSUdfU1lTX0FUQV9JREUwX09GRlNFVCArIENPTkZJR19TWVNfQVRBX1JFR19PRkZTRVQgKyBbMS4uN10gKi8KI2RlZmluZQlDT05GSUdfU1lTX0FUQV9SRUdfT0ZGU0VUCTB4MDAwMAkvKiBPZmZzZXQgZm9yIG5vcm1hbCByZWdpc3RlciBhY2Nlc3NlcwkqLwoKLyogYWNjZXNzIHRvIHRoZSBhbHRlcm5hdGUgcmVnaXN0ZXIgaXMgY2FsY3VsYXRlZDoKICAgQ09ORklHX1NZU19BVEFfQkFTRV9BRERSICsgQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQgKyBDT05GSUdfU1lTX0FUQV9BTFRfT0ZGU0VUICsgNiAqLwojZGVmaW5lIENPTkZJR19TWVNfQVRBX0FMVF9PRkZTRVQJMHgwM0YwCQkvKiBPZmZzZXQgZm9yIGFsdGVybmF0ZSByZWdpc3RlcnMJKi8KCiNlbmRpZiAvKiBJREVfVVNFU19JU0FfRU1VTEFUSU9OICovCgojZW5kaWYKCi8qCiNkZWZpbmUJQ09ORklHX1NZU19LRVlfUkVHX0JBU0VfQUREUgkweEYwMTAwMDAwCiNkZWZpbmUJQ09ORklHX1NZU19JUl9SRUdfQkFTRV9BRERSCTB4RjAyMDAwMDAKI2RlZmluZQlDT05GSUdfU1lTX0ZQR0FfUkVHX0JBU0VfQUREUgkweEYwMzAwMDAwCiovCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFN0YXJ0IGFkZHJlc3NlcyBmb3IgdGhlIGZpbmFsIG1lbW9yeSBjb25maWd1cmF0aW9uCiAqIChTZXQgdXAgYnkgdGhlIHN0YXJ0dXAgY29kZSkKICogUGxlYXNlIG5vdGUgdGhhdCBDT05GSUdfU1lTX1NEUkFNX0JBU0UgX211c3RfIHN0YXJ0IGF0IDAKICoKICogQ09ORklHX1NZU19GTEFTSF9CQVNFICAgLT4gc3RhcnQgYWRkcmVzcyBvZiBpbnRlcm5hbCBmbGFzaAogKiBDT05GSUdfU1lTX01PTklUT1JfQkFTRSAtPiBzdGFydCBvZiB1LWJvb3QKICovCiNpZm5kZWYgX19BU1NFTUJMRVJfXwpleHRlcm4gdW5zaWduZWQgbG9uZyBvZmZzZXRPZkJpZ0ZsYXNoOwpleHRlcm4gdW5zaWduZWQgbG9uZyBvZmZzZXRPZkVudmlyb25tZW50OwojZW5kaWYKCiNkZWZpbmUgQ09ORklHX1NZU19TRFJBTV9CQVNFCQkweDAwMDAwMDAwCiNkZWZpbmUgQ09ORklHX1NZU19GTEFTSF9CQVNFCQkweEZGRTAwMDAwCiNkZWZpbmUgQ09ORklHX1NZU19NT05JVE9SX0JBU0UJMHhGRkZDMDAwMCAgICAgLyogcGxhY2VkIGxhc3QgMjU2ayAqLwojZGVmaW5lIENPTkZJR19TWVNfTU9OSVRPUl9MRU4JCSgyMjQgKiAxMDI0KQkvKiBSZXNlcnZlIDIyNCBLaUIgZm9yIE1vbml0b3IJKi8KI2RlZmluZSBDT05GSUdfU1lTX01BTExPQ19MRU4JCSgxMjggKiAxMDI0KQkvKiBSZXNlcnZlIDEyOCBLaUIgZm9yIG1hbGxvYygpCSovCgovKgogKiBGb3IgYm9vdGluZyBMaW51eCwgdGhlIGJvYXJkIGluZm8gYW5kIGNvbW1hbmQgbGluZSBkYXRhCiAqIGhhdmUgdG8gYmUgaW4gdGhlIGZpcnN0IDggTWlCIG9mIG1lbW9yeSwgc2luY2UgdGhpcyBpcwogKiB0aGUgbWF4aW11bSBtYXBwZWQgYnkgdGhlIExpbnV4IGtlcm5lbCBkdXJpbmcgaW5pdGlhbGl6YXRpb24uCiAqLwojZGVmaW5lIENPTkZJR19TWVNfQk9PVE1BUFNaCQkoOCA8PCAyMCkJLyogSW5pdGlhbCBNZW1vcnkgbWFwIGZvciBMaW51eCAqLwovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIEZMQVNIIG9yZ2FuaXphdGlvbiAjIyBGSVhNRTogbG9va3VwIGluIGRhdGFzaGVldAogKi8KI2RlZmluZSBDT05GSUdfU1lTX01BWF9GTEFTSF9CQU5LUwkyCS8qIG1heCBudW1iZXIgb2YgbWVtb3J5IGJhbmtzCQkqLwojZGVmaW5lIENPTkZJR19TWVNfTUFYX0ZMQVNIX1NFQ1QJMjU2CS8qIG1heCBudW1iZXIgb2Ygc2VjdG9ycyBvbiBvbmUgY2hpcAkqLwoKI2RlZmluZSBDT05GSUdfU1lTX0ZMQVNIX0NGSQkJCS8qIGZsYXNoIGlzIENGSSBjb21wYXQuCSovCiNkZWZpbmUgQ09ORklHX0ZMQVNIX0NGSV9EUklWRVIJCS8qIFVzZSBjb21tb24gQ0ZJIGRyaXZlciovCiNkZWZpbmUgQ09ORklHX1NZU19GTEFTSF9FTVBUWV9JTkZPCQkvKiBwcmludCAnRScgZm9yIGVtcHR5IHNlY3RvcgkqLwojZGVmaW5lIENPTkZJR19TWVNfRkxBU0hfUVVJRVRfVEVTVAkxCS8qIGRvbid0IHdhcm4gdXBvbiB1bmtub3duIGZsYXNoKi8KI2RlZmluZSBDT05GSUdfU1lTX0ZMQVNIX0VSQVNFX1RPVVQJMTIwMDAwCS8qIFRpbWVvdXQgZm9yIEZsYXNoIEVyYXNlIChpbiBtcykJKi8KI2RlZmluZSBDT05GSUdfU1lTX0ZMQVNIX1dSSVRFX1RPVVQJNTAwCS8qIFRpbWVvdXQgZm9yIEZsYXNoIFdyaXRlIChpbiBtcykJKi8KI2RlZmluZSBDT05GSUdfU1lTX1dSSVRFX1NXQVBQRURfREFUQQkJLyogc3dhcCBEYXRhYnl0ZXMgYmV0d2VlbiByZWFkaW5nL3dyaXRpbmcgKi8KCiNkZWZpbmUgQ09ORklHX0VOVl9JU19JTl9GTEFTSAkxCiNpZmRlZiBDT05GSUdfRU5WX0lTX0lOX0ZMQVNICiNkZWZpbmUgQ09ORklHX0VOVl9PRkZTRVQJCTB4MDAwMDAwMDAgIC8qIE9mZnNldCBvZiBFbnZpcm9ubWVudCBTZWN0b3IgaW4gYm90dG9tIHR5cGUgKi8KI2RlZmluZSBDT05GSUdfRU5WX1NJWkUJCTB4NDAwMAkgICAgLyogVG90YWwgU2l6ZSBvZiBFbnZpcm9ubWVudCBTZWN0b3IJKi8KI2RlZmluZSBDT05GSUdfRU5WX1NFQ1RfU0laRQkweDQwMDAJICAgIC8qIHNlZSBSRUFETUUgLSBlbnYgc2VjdG9yIHRvdGFsIHNpemUJKi8KCi8qIEFkZHJlc3MgYW5kIHNpemUgb2YgUmVkdW5kYW50IEVudmlyb25tZW50IFNlY3RvcgkqLwojZGVmaW5lIENPTkZJR19FTlZfT0ZGU0VUX1JFRFVORAkoQ09ORklHX0VOVl9PRkZTRVQrQ09ORklHX0VOVl9TSVpFKQojZGVmaW5lIENPTkZJR19FTlZfU0laRV9SRURVTkQJKENPTkZJR19FTlZfU0laRSkKCiNlbmRpZgovKiBsZXQgdXMgY2hhbmdpbmcgYW55dGhpbmcgaW4gb3VyIGVudmlyb25tZW50ICovCiNkZWZpbmUgQ09ORklHX0VOVl9PVkVSV1JJVEUKCi8qCiAqIE5BTkQtRkxBU0ggc3R1ZmYKICovCiNkZWZpbmUgQ09ORklHX1NZU19NQVhfTkFORF9ERVZJQ0UJMQojZGVmaW5lIENPTkZJR19TWVNfTkFORF9CQVNFCQkweDc3RDAwMDAwCgoKI2RlZmluZSBDT05GSUdfSkZGUzJfTkFORCAxCQkJLyogamZmczIgb24gbmFuZCBzdXBwb3J0ICovCgovKiBObyBjb21tYW5kIGxpbmUsIG9uZSBzdGF0aWMgcGFydGl0aW9uICovCiN1bmRlZglDT05GSUdfSkZGUzJfQ01ETElORQojZGVmaW5lIENPTkZJR19KRkZTMl9ERVYJCSJuYW5kMCIKI2RlZmluZSBDT05GSUdfSkZGUzJfUEFSVF9TSVpFCQkweDAxMDAwMDAwCiNkZWZpbmUgQ09ORklHX0pGRlMyX1BBUlRfT0ZGU0VUCTB4MDAwMDAwMDAKCi8qCiAqIEluaXQgTWVtb3J5IENvbnRyb2xsZXI6CiAqCiAqLwoKI2RlZmluZSBGTEFTSF9CQVNFMF9QUkVMSU0JQ09ORklHX1NZU19GTEFTSF9CQVNFCiNkZWZpbmUgRkxBU0hfQkFTRTFfUFJFTElNCTAKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogU29tZSBpbmZvcm1hdGlvbnMgYWJvdXQgdGhlIGludGVybmFsIFNSQU0gKE9DTT1PbiBDaGlwIE1lbW9yeSkKICoKICogQ09ORklHX1NZU19PQ01fREFUQV9BRERSIC0+IGxvY2F0aW9uCiAqIENPTkZJR19TWVNfT0NNX0RBVEFfU0laRSAtPiBzaXplCiovCgojZGVmaW5lIENPTkZJR19TWVNfVEVNUF9TVEFDS19PQ00JMQojZGVmaW5lIENPTkZJR19TWVNfT0NNX0RBVEFfQUREUgkweEY4MDAwMDAwCiNkZWZpbmUgQ09ORklHX1NZU19PQ01fREFUQV9TSVpFCTB4MTAwMAoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBEZWZpbml0aW9ucyBmb3IgaW5pdGlhbCBzdGFjayBwb2ludGVyIGFuZCBkYXRhIGFyZWEgKGluIERQUkFNKToKICogLSB3ZSBhcmUgdXNpbmcgdGhlIGludGVybmFsIDRrIFNSQU0sIHNvIHdlIGRvbid0IG5lZWQgZGF0YSBjYWNoZSBtYXBwaW5nCiAqIC0gaW50ZXJuYWwgU1JBTSAoT0NNPU9uIENoaXAgTWVtb3J5KSBpcyBwbGFjZWQgdG8gQ09ORklHX1NZU19PQ01fREFUQV9BRERSCiAqIC0gU3RhY2twb2ludGVyIHdpbGwgYmUgbG9jYXRlZCB0bwogKiAgIChDT05GSUdfU1lTX0lOSVRfUkFNX0FERFImMHhGRkZGMDAwMCkgfCAoQ09ORklHX1NZU19JTklUX1NQX09GRlNFVCYweDAwMDBGRkZGKQogKiAgIGluIGNwdS9wcGM0eHgvc3RhcnQuUwogKi8KCiN1bmRlZiBDT05GSUdfU1lTX0lOSVRfRENBQ0hFX0NTCi8qIFdoZXJlIHRoZSBpbnRlcm5hbCBTUkFNIHN0YXJ0cyAqLwojZGVmaW5lIENPTkZJR19TWVNfSU5JVF9SQU1fQUREUglDT05GSUdfU1lTX09DTV9EQVRBX0FERFIKLyogV2hlcmUgdGhlIGludGVybmFsIFNSQU0gZW5kcyAob25seSBvZmZzZXQpICovCiNkZWZpbmUgQ09ORklHX1NZU19JTklUX1JBTV9FTkQJMHgwRjAwCgovKgoKIENPTkZJR19TWVNfSU5JVF9SQU1fQUREUiAtLS0tLS0+IC0tLS0tLS0tLS0tLSBsb3dlciBhZGRyZXNzCgkJCSAgIHwJICAgICAgfAoJCQkgICB8ICBeICAgICAgIHwKCQkJICAgfCAgfCAgICAgICB8CgkJCSAgIHwgIHwgU3RhY2sgfAogQ09ORklHX1NZU19HQkxfREFUQV9PRkZTRVQgLS0tLT4gLS0tLS0tLS0tLS0tCgkJCSAgIHwJICAgICAgfAoJCQkgICB8IDY0IEJ5dGVzIHwKCQkJICAgfAkgICAgICB8CiBDT05GSUdfU1lTX0lOSVRfUkFNX0VORCAgLS0tLS0tPiAtLS0tLS0tLS0tLS0gaGlnaGVyIGFkZHJlc3MKICAob2Zmc2V0IG9ubHkpCgoqLwovKiBzaXplIGluIGJ5dGVzIHJlc2VydmVkIGZvciBpbml0aWFsIGRhdGEgKi8KI2RlZmluZSBDT05GSUdfU1lTX0dCTF9EQVRBX1NJWkUgICAgIDY0CiNkZWZpbmUgQ09ORklHX1NZU19HQkxfREFUQV9PRkZTRVQgICAoQ09ORklHX1NZU19JTklUX1JBTV9FTkQgLSBDT05GSUdfU1lTX0dCTF9EQVRBX1NJWkUpCi8qIEluaXRpYWwgdmFsdWUgb2YgdGhlIHN0YWNrIHBvaW50ZXJuIGluIGludGVybmFsIFNSQU0gKi8KI2RlZmluZSBDT05GSUdfU1lTX0lOSVRfU1BfT0ZGU0VUICAgIENPTkZJR19TWVNfR0JMX0RBVEFfT0ZGU0VUCgovKgogKiBJbnRlcm5hbCBEZWZpbml0aW9ucwogKgogKiBCb290IEZsYWdzCiAqLwojZGVmaW5lIEJPT1RGTEFHX0NPTEQJMHgwMQkJLyogTm9ybWFsIFBvd2VyLU9uOiBCb290IGZyb20gRkxBU0gJKi8KI2RlZmluZSBCT09URkxBR19XQVJNCTB4MDIJCS8qIFNvZnR3YXJlIHJlYm9vdAkJCSovCgovKiAjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyAqLwovKiBUaGVzZSBkZWZpbmVzIHdpbGwgYmUgdXNlZCBpbiBjcHUvcHBjNHh4L2NwdV9pbml0LmMgdG8gc2V0dXAgZXh0ZXJuYWwgY2hpcCBzZWxlY3RzICAqLwovKiBUaGV5IGFyZSBjdXJyZW50bHkgdW5kZWZpbmVkIGNhdXNlIHRoZXkgYXJlIGluaXRpYWl6ZWQgaW4gYm9hcmQvc29saWRjYXJkMy9pbml0LlMgICAqLwoKLyogVGhpcyBjaGlwIHNlbGVjdCBhY2Nlc3NlcyB0aGUgYm9vdCBkZXZpY2UgKi8KLyogSXQgZGVwZW5kcyBvbiBib290IHNlbGVjdCBzd2l0Y2ggaWYgdGhpcyBkZXZpY2UgaXMgMTYgb3IgOCBiaXQgKi8KCiN1bmRlZiBDT05GSUdfU1lTX0VCQ19QQjBBUAojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIwQ1IKCiN1bmRlZiBDT05GSUdfU1lTX0VCQ19QQjFBUAojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIxQ1IKCiN1bmRlZiBDT05GSUdfU1lTX0VCQ19QQjJBUAojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIyQ1IKCiN1bmRlZiBDT05GSUdfU1lTX0VCQ19QQjNBUAojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIzQ1IKCiN1bmRlZiBDT05GSUdfU1lTX0VCQ19QQjRBUAojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI0Q1IKCiN1bmRlZiBDT05GSUdfU1lTX0VCQ19QQjVBUAojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI1Q1IKCiN1bmRlZiBDT05GSUdfU1lTX0VCQ19QQjZBUAojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI2Q1IKCiN1bmRlZiBDT05GSUdfU1lTX0VCQ19QQjdBUAojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI3Q1IKCiNkZWZpbmUgQ09ORklHX1NZU19FQkNfQ0ZHICAgIDB4Yjg0ZWYwMDAKCiNkZWZpbmUgQ09ORklHX1NEUkFNX0JBTkswCS8qIHVzZSB0aGUgc3RhbmRhcmQgU0RSQU0gaW5pdGlhbGl6YXRpb24gKi8KI3VuZGVmIENPTkZJR19TUERfRUVQUk9NCgovKgogKiBEZWZpbmUgdGhpcyB0byBnZXQgbW9yZSBpbmZvcm1hdGlvbiBhYm91dCBzeXN0ZW0gY29uZmlndXJhdGlvbgogKi8KLyogI2RlZmluZSBTQzNfREVCVUdPVVQgKi8KI3VuZGVmIFNDM19ERUJVR09VVAoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqIEV4dGVybmFsIHBlcmlwaGVyYWwgYmFzZSBhZGRyZXNzCiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCiNkZWZpbmUgQ09ORklHX1NZU19JU0FfTUVNX0JBU0VfQUREUkVTUyAweDc4MDAwMDAwCi8qCiBEaWUgR3JhZmlrLVRyZWliZXIgZ3JlaWZlbiD8YmVyIGRpZSBBZHJlc3NlIGluIGRpZXNlbSBNYWNybyBhdWYgZGVuIENoaXAgenUuCiBEYXMgZnVua3Rpb25pZXJ0IGJlaSBkZXJlbiBLYXJ0ZW4sIHdlaWwgc2llIGVpbmUgUENJLUJyaWRnZSBiZW51dHplbiwgZGllCiBkYXMgZ2xlaWNoZSBNYXBwaW5nIGR1cmNoZvxocmVuIGthbm4sIHdpZSBkZXIgU0M1MjAgKGFsc28gQXVmdGVpbGVuIHZvbiBJTy1adWdyaWZmZW4KIGF1ZiBJU0EtIHVuZCBQQ0ktWnlrbGVuKQogKi8KI2RlZmluZSBDT05GSUdfU1lTX0lTQV9JT19CQVNFX0FERFJFU1MgIDB4RTgwMDAwMDAKLyojZGVmaW5lIENPTkZJR19TWVNfSVNBX0lPX0JBU0VfQUREUkVTUyAgMHg3OTAwMDAwMCAqLwoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiBWaWRlbyBzdXBwb3J0CiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCgojaWZkZWYgVVNFX1ZHQV9HUkFQSElDUwojZGVmaW5lIENPTkZJR19WSURFTwkJLyogVG8gZW5hYmxlIHZpZGVvIGNvbnRyb2xsZXIgc3VwcG9ydCAqLwojZGVmaW5lIENPTkZJR19WSURFT19DVDY5MDAwCiNkZWZpbmUgQ09ORklHX0NGQl9DT05TT0xFCi8qICNkZWZpbmUgQ09ORklHX1ZJREVPX0xPR08gKi8KI2RlZmluZSBDT05GSUdfVkdBX0FTX1NJTkdMRV9ERVZJQ0UKI2RlZmluZSBDT05GSUdfVklERU9fU1dfQ1VSU09SCi8qICNkZWZpbmUgQ09ORklHX1ZJREVPX0hXX0NVUlNPUiAqLwojZGVmaW5lIENPTkZJR19WSURFT19PTkJPQVJECS8qIFZpZGVvIGNvbnRyb2xsZXIgaXMgb24tYm9hcmQgKi8KCiNkZWZpbmUgVklERU9fSFdfUkVDVEZJTEwKI2RlZmluZSBWSURFT19IV19CSVRCTFQKCiNlbmRpZgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiBJZGVudAogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwojZGVmaW5lIENPTkZJR19TQzNfVkVSU0lPTiAicjEuNCIKCiNkZWZpbmUgUE9TVF9PVVQoeCkgKCooKHZvbGF0aWxlIHVuc2lnbmVkIGNoYXIqKSgweDc5MDAwMDgwKSk9eCkKCiNlbmRpZgkvKiBfX0NPTkZJR19IICovCg==