LyoKICogKEMpIENvcHlyaWdodCAyMDA3CiAqIEhlaWtvIFNjaG9jaGVyLCBERU5YIFNvZnR3YXJlIEVuZ2luZWVyaW5nLCA8aHNAZGVueC5kZT4uCiAqCiAqIEZyb206CiAqIChDKSBDb3B5cmlnaHQgMjAwMwogKiBKdWVyZ2VuIEJlaXNlcnQsIEV1cm9EZXNpZ24gZW1iZWRkZWQgdGVjaG5vbG9naWVzLCBqYmVpc2VydEBldXJvZHNuLmRlCiAqCiAqIFNlZSBmaWxlIENSRURJVFMgZm9yIGxpc3Qgb2YgcGVvcGxlIHdobyBjb250cmlidXRlZCB0byB0aGlzCiAqIHByb2plY3QuCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IKICogbW9kaWZ5IGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMKICogcHVibGlzaGVkIGJ5IHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVpdGhlciB2ZXJzaW9uIDIgb2YKICogdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLAogKiBidXQgV0lUSE9VVCBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZgogKiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuCSBTZWUgdGhlCiAqIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvciBtb3JlIGRldGFpbHMuCiAqCiAqIFlvdSBzaG91bGQgaGF2ZSByZWNlaXZlZCBhIGNvcHkgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlCiAqIGFsb25nIHdpdGggdGhpcyBwcm9ncmFtOyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDU5IFRlbXBsZSBQbGFjZSwgU3VpdGUgMzMwLCBCb3N0b24sCiAqIE1BIDAyMTExLTEzMDcgVVNBCiAqLwoKI2lmbmRlZiBfX0NPTkZJR19ICiNkZWZpbmUgX19DT05GSUdfSAoKI3VuZGVmIFVTRV9WR0FfR1JBUEhJQ1MKCi8qIE1lbW9yeSBNYXAKICogMHgwMDAwMDAwMCAuLi4uIDB4MDNGRkZGRkYgLT4gUkFNICh1cCB0byAxMjhNaUIpCiAqIDB4NzQwMDAwMDAgLi4uLiAweDc0MEZGRkZGIC0+IENTIzYKICogMHg3NDEwMDAwMCAuLi4uIDB4NzQxRkZGRkYgLT4gQ1MjNwogKiAweDc0MjAwMDAwIC4uLi4gMHg3NDJGRkZGRiAtPiBDUzQjIGlmIG5vIGludGVybmFsIFVTQgogKiAweDc0MzAwMDAwIC4uLi4gMHg3NDNGRkZGRiAtPiBDUzUjIGlmIG5vIGJvb3N0ZWQgSURFCiAqIDB4NzdDMDAwMDAgLi4uLiAweDc3Q0ZGRkZGIC0+IENTNCMgVVNCIEhDICgxIE1pQikKICogMHg3N0QwMDAwMCAuLi4uIDB4NzdERkZGRkYgLT4gQ1MxIyBOQU5ELUZsYXNoICgxIE1pQikKICogMHg3ODAwMDAwMCAuLi4uIDB4NzhGRkZGRkYgLT4gQ1MyIyBJU0EtQnVzIFNwZWljaGVyenVncmlmZiAoMTYgTWlCKQogKiAweDc5MDAwMDAwIC4uLi4gMHg3OTAwRkZGRiAtPiBDUzIjIElTQS1CdXMgSU8tWnVncmlmZiAoMTYgTWlCLCBtYXBwZWQ6IDY0a2lCKQogKiAweDc5MDEwMDAwIC4uLi4gMHg3OUZGRkZGRiAtPiBDUzIjIElTQS1CdXMgSU8tWnVncmlmZiAobWlycm9yZWQpCiAqIDB4N0EwMDAwMDAgLi4uLiAweDdBMEZGRkZGIC0+IENTNSMgSURFIGVtdWxhdGlvbiAoMU1pQikKICoKICogMHg4MDAwMDAwMCAuLi4uIDB4OUZGRkZGRkYgLT4gUENJLUJ1cyBTcGVpY2hlcnp1Z3JpZmYgKDUxMk1pQiwgbWFwcGVkOiAxOjEpCiAqIDB4QTAwMDAwMDAgLi4uLiAweEJGRkZGRkZGIC0+IFBDSS1CdXMgU3BlaWNoZXJ6dWdyaWZmICg1MTJNaUIsIG1hcHBlZDogMHgwMDAwMDAwMC4uLjB4MUZGRkZGRkYpCiAqIDB4RTgwMDAwMDAgLi4uLiAweEU4MDBGRkZGIC0+IFBDSS1CdXMgSU8tWnVncmlmZiAoNjRraUIsIHRyYW5zbGF0ZWQgdG8gUENJOiAweDAwMDAuLi4weEZGRkYpCiAqIDB4RTg4MDAwMDAgLi4uLiAweEVCRkZGRkZGIC0+IFBDSS1CdXMgSU8tWnVncmlmZiAoNTZNaUIsIHRyYW5zbGF0ZWQgdG8gUENJOiAweDAwODAwMDAwLi4uMHgzRkZGRkZGKQogKiAweEVFRDAwMDAwIC4uLi4gMHhFRUQwMDAwMyAtPiBQQ0ktQnVzCiAqIDB4RUY0MDAwMDAgLi4uLiAweEVGNDAwMDNGIC0+IFBDSS1CdXMgTG9jYWwgQ29uZmlndXJhdGlvbiBSZWdpc3RlcnMKICogMHhFRjQwMDAzRiAuLi4uIDB4RUY1RkZGRkYgLT4gcmVzZXJ2ZWQKICogMHhFRjYwMDAwMCAuLi4uIDB4RUZGRkZGRkYgLT4gNDA1R1AgaW50ZXJuYWwgRGV2aWNlcyAoMTAgTWlCKQogKiAweEYwMDAwMDAwIC4uLi4gMHhGMDFGRkZGRiAtPiBGbGFzaC1ST00gKDIgTWlCKQogKiAweEYwMjAwMDAwIC4uLi4gMHhGN0ZGRkZGRiAtPiBmcmVlIGZvciBmbGFzaCBkZXZpY2VzCiAqIDB4RjgwMDAwMDAgLi4uLiAweEY4MDAwRkZGIC0+IE9uQ2hpcE1lbW9yeSAoNGtpQikKICogMHhGODAwMTAwMCAuLi4uIDB4RkZERkZGRkYgLT4gZnJlZSBmb3IgZmxhc2ggZGV2aWNlcwogKiAweEZGRTAwMDAwIC4uLi4gMHhGRkZGRkZGRiAtPiBCT09ULVJPTSAoMiBNaUIpCiAqLwoKI2RlZmluZSBDT05GSUdfU0MzCTEKI2RlZmluZSBDT05GSUdfNHh4CTEKI2RlZmluZSBDT05GSUdfNDA1R1AJMQoKI2RlZmluZSBDT05GSUdfQk9BUkRfRUFSTFlfSU5JVF9GCTEKI2RlZmluZSBDT05GSUdfTUlTQ19JTklUX1IJCTEJLyogQ2FsbCBtaXNjX2luaXRfcigpICovCgovKgogKiBEZWZpbmUgSURFX1VTRVNfSVNBX0VNVUxBVElPTiBmb3Igc2xvd2VyIElERSBhY2Nlc3MgaW4gdGhlIElTQS1JTyBhZGRyZXNzIHJhbmdlCiAqIElmIHVuZGVmaW5lZCwgSURFIGFjY2VzcyB1c2VzIGEgc2VwZXJhdCBlbXVsYXRpb24gd2l0aCBoaWdoZXIgYWNjZXNzIHNwZWVkLgogKiBDb25zaWRlciB0byBpbmZvcm0geW91ciBMaW51eCBJREUgZHJpdmVyIGFib3V0IHRoZSBkaWZmZXJlbnQgYWRkcmVzc2VzIQogKiBJREVfVVNFU19JU0FfRU1VTEFUSU9OIGlzIG9ubHkgdXNlZCBpZiB5b3UgZGVmaW5lIENPTkZJR19DTURfSURFIQogKi8KI2RlZmluZSBJREVfVVNFU19JU0FfRU1VTEFUSU9OCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFNlcmlhbCBQb3J0CiAqLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCiNkZWZpbmUgQ09ORklHX0NPTlNfSU5ERVgJMQkvKiBVc2UgVUFSVDAJCQkqLwojZGVmaW5lIENPTkZJR19TWVNfTlMxNjU1MAojZGVmaW5lIENPTkZJR19TWVNfTlMxNjU1MF9TRVJJQUwKI2RlZmluZSBDT05GSUdfU1lTX05TMTY1NTBfUkVHX1NJWkUJMQojZGVmaW5lIENPTkZJR19TWVNfTlMxNjU1MF9DTEsJCWdldF9zZXJpYWxfY2xvY2soKQojZGVmaW5lIENPTkZJR19TRVJJQUxfTVVMVEkKCi8qCiAqIGRlZmluZSBDT05GSUdfU1lTX0NMS19GUkVRIHRvIHlvdXIgYmFzZSBjcnlzdGFsIGNsb2NrIGluIEh6CiAqLwojZGVmaW5lIENPTkZJR19TWVNfQ0xLX0ZSRVEJMzMzMzMzMzMKCi8qCiAqIGRlZmluZSBDT05GSUdfQkFVRFJBVEUgdG8gdGhlIGJhdWRyYXRlIHZhbHVlIHlvdSB3YW50IHRvIHVzZSBhcyBkZWZhdWx0CiAqLwojZGVmaW5lIENPTkZJR19CQVVEUkFURQkJMTE1MjAwCiNkZWZpbmUgQ09ORklHX0JPT1RERUxBWQkzIC8qIGF1dG9ib290IGFmdGVyIDMgc2Vjb25kcwkgICAgICAqLwoKI2RlZmluZSBDT05GSUdfUFJFQk9PVAkiZWNobzsiCVwKCSJlY2hvIFR5cGUgXFxcInJ1biBmbGFzaF9uZnNcXFwiIHRvIG1vdW50IHJvb3QgZmlsZXN5c3RlbSBvdmVyIE5GUzsiIFwKCSJlY2hvIgoKI3VuZGVmCUNPTkZJR19CT09UQVJHUwoKI2RlZmluZQlDT05GSUdfRVhUUkFfRU5WX1NFVFRJTkdTCQkJCQlcCgkibmV0ZGV2PWV0aDBcMCIJCQkJCQkJXAoJIm5mc2FyZ3M9c2V0ZW52IGJvb3RhcmdzIHJvb3Q9L2Rldi9uZnMgcncgIgkJCVwKCQkibmZzcm9vdD0ke3NlcnZlcmlwfToke3Jvb3RwYXRofVwwIgkJCVwKCSJyYW1hcmdzPXNldGVudiBib290YXJncyByb290PS9kZXYvcmFtIHJ3XDAiCQkJXAoJIm5hbmRfYXJncz1zZXRlbnYgYm9vdGFyZ3Mgcm9vdD0vZGV2L210ZGJsb2NrNSBydyIJCVwKCQkicm9vdGZzdHlwZT1qZmZzMlwwIgkJCQkJXAoJImFkZGlwPXNldGVudiBib290YXJncyAke2Jvb3RhcmdzfSAiCQkJCVwKCQkiaXA9JHtpcGFkZHJ9OiR7c2VydmVyaXB9OiR7Z2F0ZXdheWlwfToke25ldG1hc2t9IglcCgkJIjoke2hvc3RuYW1lfToke25ldGRldn06b2ZmIHBhbmljPTFcMCIJCQlcCgkiYWRkY29ucz1zZXRlbnYgYm9vdGFyZ3MgJHtib290YXJnc30gIgkJCQlcCgkJImNvbnNvbGU9dHR5UzAsJHtiYXVkcmF0ZX1cMCIJCQkJXAoJImZsYXNoX25mcz1ydW4gbmZzYXJncyBhZGRpcCBhZGRjb25zOyIJCQkJXAoJCSJib290bSAke2tlcm5lbF9hZGRyfVwwIgkJCQlcCgkiZmxhc2hfbmFuZD1ydW4gbmFuZF9hcmdzIGFkZGlwIGFkZGNvbnM7Ym9vdG0gJHtrZXJuZWxfYWRkcn1cMCIJXAoJIm5ldF9uZnM9dGZ0cCAyMDAwMDAgJHtib290ZmlsZX07cnVuIG5mc2FyZ3MgYWRkaXAgYWRkY29uczsiCVwKCQkiYm9vdG1cMCIJCQkJCQlcCgkicm9vdHBhdGg9L29wdC9lbGRrL3BwY180eHhcMCIJCQkJCVwKCSJib290ZmlsZT0vdGZ0cGJvb3Qvc2MzL3VJbWFnZVwwIgkJCQlcCgkidS1ib290PS90ZnRwYm9vdC9zYzMvdS1ib290LmJpblwwIgkJCQlcCgkic2V0dXA9dGZ0cCAyMDAwMDAgL3RmdHBib290L3NjMy9zZXR1cC5pbWc7c291cmNlIDIwMDAwMFwwIglcCgkia2VybmVsX2FkZHI9RkZFMDgwMDBcMCIJCQkJCVwKCSIiCiN1bmRlZiBDT05GSUdfQk9PVENPTU1BTkQKCiNkZWZpbmUgQ09ORklHX1NJTEVOVF9DT05TT0xFCTEJLyogZW5hYmxlIHNpbGVudCBzdGFydHVwICovCiNkZWZpbmUgQ09ORklHX1NZU19ERVZJQ0VfTlVMTERFVgkxCS8qIGluY2x1ZGUgbnVsbGRldiBkZXZpY2UJKi8KCiNpZiAxCS8qIGZlZWwgZnJlZSB0byBkaXNhYmxlIGZvciBkZXZlbG9wbWVudCAqLwojZGVmaW5lIENPTkZJR19BVVRPQk9PVF9LRVlFRAkJLyogRW5hYmxlIHBhc3N3b3JkIHByb3RlY3Rpb24JKi8KI2RlZmluZSBDT05GSUdfQVVUT0JPT1RfUFJPTVBUCQlcCgkiXG5TQzMgLSBib290aW5nLi4uIHN0b3Agd2l0aCBFTlRFUlxuIgojZGVmaW5lIENPTkZJR19BVVRPQk9PVF9ERUxBWV9TVFIJIlxyIgkvKiAxc3QgInBhc3N3b3JkIgkqLwojZGVmaW5lIENPTkZJR19BVVRPQk9PVF9ERUxBWV9TVFIyCSJcbiIJLyogMXN0ICJwYXNzd29yZCIJKi8KI2VuZGlmCgovKgogKiBkZWZpbmUgQ09ORklHX0JPT1RDT01NQU5EIHRvIHRoZSBhdXRvYm9vdCBjb21tYW5kcy4gVGhleSB3aWxsIHJ1bm5pbmcgYWZ0ZXIKICogdGhlIENPTkZJR19CT09UREVMQVkgZGVsYXkgdG8gYm9vdCB5b3VyIG1hY2hpbmUKICovCiNkZWZpbmUgQ09ORklHX0JPT1RDT01NQU5ECSJib290cDtkY2FjaGUgb247Ym9vdG0iCgovKgogKiBkZWZpbmUgQ09ORklHX0JPT1RBUkdTIHRvIHRoZSBkZWZhdWx0IGtlcm5lbCBwYXJhbWV0ZXJzLiBUaGV5IHdpbGwgdXNlZCBpZiB5b3UgZG9uJ3QKICogc2V0IGRpZmZlcmVudCB2YWx1ZXMgYXQgdGhlIHUtYm9vdCBwcm9tcHQKICovCiNpZmRlZiBVU0VfVkdBX0dSQVBISUNTCiAjZGVmaW5lIENPTkZJR19CT09UQVJHUwkicm9vdD0vZGV2L25mcyBydyBpcD1ib290cCBuZnNyb290PS90ZnRwYm9vdC9zb2xpZGNhcmQzcmUiCiNlbHNlCiAjZGVmaW5lIENPTkZJR19CT09UQVJHUwkiY29uc29sZT10dHlTMCwxMTUyMDAgcm9vdD0vZGV2L25mcyBydyBpcD1ib290cCIKI2VuZGlmCi8qCiAqIElzIHRoZSBVU0IgaG9zdCBjb250cm9sbGVyIGFzc2VtYmxlZD8gSWYgeWVzIGRlZmluZSBDT05GSUdfSVNQMTE2MV9QUkVTRU5UCiAqIFRoaXMgcmVzZXJ2ZXMgbWVtb3J5IGJhbmsgIzQgZm9yIHRoaXMgcHVycG9zZQogKi8KI3VuZGVmIENPTkZJR19JU1AxMTYxX1BSRVNFTlQKCiN1bmRlZiBDT05GSUdfTE9BRFNfRUNITyAgIC8qIG5vIGVjaG8gb24gZm9yIHNlcmlhbCBkb3dubG9hZAkqLwojZGVmaW5lIENPTkZJR19TWVNfTE9BRFNfQkFVRF9DSEFOR0UJMQkvKiBhbGxvdyBiYXVkcmF0ZSBjaGFuZ2UJKi8KCiNkZWZpbmUgQ09ORklHX05FVF9NVUxUSQovKiAjZGVmaW5lIENPTkZJR19FRVBSTzEwMF9TUk9NX1dSSVRFICovCi8qICNkZWZpbmUgQ09ORklHX1NIT1dfTUFDICovCiNkZWZpbmUgQ09ORklHX0VFUFJPMTAwCgojZGVmaW5lIENPTkZJR19QUEM0eHhfRU1BQwojZGVmaW5lIENPTkZJR19NSUkgMQkJCS8qIGFkZCA0MDVHUCBNSUkgUEhZIG1hbmFnZW1lbnQJCSovCiNkZWZpbmUgQ09ORklHX1BIWV9BRERSIDEJLyogdGhlIGNvbm5lY3RlZCBQaHkgZGVmYXVsdHMgdG8gYWRkcmVzcyAxICovCgovKgogKiBCT09UUCBvcHRpb25zCiAqLwojZGVmaW5lIENPTkZJR19CT09UUF9CT09URklMRVNJWkUKI2RlZmluZSBDT05GSUdfQk9PVFBfQk9PVFBBVEgKI2RlZmluZSBDT05GSUdfQk9PVFBfR0FURVdBWQojZGVmaW5lIENPTkZJR19CT09UUF9IT1NUTkFNRQoKCi8qCiAqIENvbW1hbmQgbGluZSBjb25maWd1cmF0aW9uLgogKi8KI2luY2x1ZGUgPGNvbmZpZ19jbWRfZGVmYXVsdC5oPgoKCiNkZWZpbmUgQ09ORklHX0NNRF9DQUNIRQojZGVmaW5lIENPTkZJR19DTURfREFURQojZGVmaW5lIENPTkZJR19DTURfREhDUAojZGVmaW5lIENPTkZJR19DTURfRUxGCiNkZWZpbmUgQ09ORklHX0NNRF9JMkMKI2RlZmluZSBDT05GSUdfQ01EX0lERQojZGVmaW5lIENPTkZJR19DTURfSVJRCiNkZWZpbmUgQ09ORklHX0NNRF9KRkZTMgojZGVmaW5lIENPTkZJR19DTURfTUlJCiNkZWZpbmUgQ09ORklHX0NNRF9OQU5ECiNkZWZpbmUgQ09ORklHX0NNRF9ORVQKI2RlZmluZSBDT05GSUdfQ01EX1BDSQojZGVmaW5lIENPTkZJR19DTURfUElORwojZGVmaW5lIENPTkZJR19DTURfU09VUkNFCgoKI3VuZGVmIENPTkZJR19XQVRDSERPRwkJCS8qIHdhdGNoZG9nIGRpc2FibGVkCQkqLwoKLyoKICogTWlzY2VsbGFuZW91cyBjb25maWd1cmFibGUgb3B0aW9ucwogKi8KI2RlZmluZSBDT05GSUdfU1lTX0xPTkdIRUxQCTEJCS8qIHVuZGVmIHRvIHNhdmUgbWVtb3J5CQkqLwojZGVmaW5lIENPTkZJR19TWVNfUFJPTVBUCSJTQzM+ICIJLyogTW9uaXRvciBDb21tYW5kIFByb21wdAkqLwojZGVmaW5lCUNPTkZJR19TWVNfQ0JTSVpFCTI1NgkJLyogQ29uc29sZSBJL08gQnVmZmVyIFNpemUJKi8KCiNkZWZpbmUgQ09ORklHX1NZU19QQlNJWkUgKENPTkZJR19TWVNfQ0JTSVpFK3NpemVvZihDT05GSUdfU1lTX1BST01QVCkrMTYpIC8qIFByaW50IEJ1ZmZlciBTaXplICovCgojZGVmaW5lIENPTkZJR19TWVNfTUFYQVJHUwkxNgkJLyogbWF4IG51bWJlciBvZiBjb21tYW5kIGFyZ3MJKi8KI2RlZmluZSBDT05GSUdfU1lTX0JBUkdTSVpFCUNPTkZJR19TWVNfQ0JTSVpFCS8qIEJvb3QgQXJndW1lbnQgQnVmZmVyIFNpemUJKi8KCiNkZWZpbmUgQ09ORklHX1NZU19NRU1URVNUX1NUQVJUCTB4MDQwMDAwMAkvKiBtZW10ZXN0IHdvcmtzIG9uCSovCiNkZWZpbmUgQ09ORklHX1NZU19NRU1URVNUX0VORAkJMHgwQzAwMDAwCS8qIDQgLi4uIDEyIE1CIGluIERSQU0JKi8KCi8qCiAqIElmIENPTkZJR19TWVNfRVhUX1NFUklBTF9DTE9DSywgdGhlbiB0aGUgVUFSVCBkaXZpc29yIGlzIDEuCiAqIElmIENPTkZJR19TWVNfNDA1X1VBUlRfRVJSQVRBXzU5LCB0aGVuIFVBUlQgZGl2aXNvciBpcyAzMS4KICogT3RoZXJ3aXNlLCBVQVJUIGRpdmlzb3IgaXMgZGV0ZXJtaW5lZCBieSBDUFUgQ2xvY2sgYW5kIENPTkZJR19TWVNfQkFTRV9CQVVEIHZhbHVlLgogKiBUaGUgTGludXggQkFTRV9CQVVEIGRlZmluZSBzaG91bGQgbWF0Y2ggdGhpcyBjb25maWd1cmF0aW9uLgogKiAgICBiYXNlQmF1ZCA9IGNwdUNsb2NrLyh1YXJ0RGl2aXNvcioxNikKICogSWYgQ09ORklHX1NZU180MDVfVUFSVF9FUlJBVEFfNTkgYW5kIDIwME1IeiBDUFUgY2xvY2ssCiAqIHNldCBMaW51eCBCQVNFX0JBVUQgdG8gNDAzMjAwLgogKgogKiBDb25zaWRlciB0aGUgT1BCIGNsb2NrISBJZiBpdCBnZXQgbG93ZXIgdGhlIEJBU0VfQkFVRCBtdXN0IGJlIGxvd2VyIHRvCiAqIChzZWUgNDA1R1AgZGF0YXNoZWV0IGZvciBkZXNjcml0cGlvbikKICovCiN1bmRlZglDT05GSUdfU1lTX0VYVF9TRVJJQUxfQ0xPQ0sJCS8qIGV4dGVybmFsIHNlcmlhbCBjbG9jayAqLwojdW5kZWYJQ09ORklHX1NZU180MDVfVUFSVF9FUlJBVEFfNTkJCS8qIDQwNUdQL0NSIFJldi4gRCBzaWxpY29uICovCiNkZWZpbmUgQ09ORklHX1NZU19CQVNFX0JBVUQJCTkyMTYwMAkvKiBpbnRlcm5hbCBjbG9jayAqLwoKLyogVGhlIGZvbGxvd2luZyB0YWJsZSBpbmNsdWRlcyB0aGUgc3VwcG9ydGVkIGJhdWRyYXRlcyAqLwojZGVmaW5lIENPTkZJR19TWVNfQkFVRFJBVEVfVEFCTEUgIFwKICAgIHszMDAsIDYwMCwgMTIwMCwgMjQwMCwgNDgwMCwgOTYwMCwgMTkyMDAsIDM4NDAwLCA1NzYwMCwgMTE1MjAwLCAyMzA0MDB9CgojZGVmaW5lIENPTkZJR19TWVNfTE9BRF9BRERSCQkweDEwMDAwMDAJLyogZGVmYXVsdCBsb2FkIGFkZHJlc3MgKi8KI2RlZmluZSBDT05GSUdfU1lTX0VYVEJESU5GTwkJMQkvKiBUbyB1c2UgZXh0ZW5kZWQgYm9hcmRfaW50byAoYmRfdCkgKi8KCiNkZWZpbmUJQ09ORklHX1NZU19IWgkJCTEwMDAJLyogZGVjcmVtZW50ZXIgZnJlcTogMSBtcyB0aWNrcwkqLwoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBJSUMgc3R1ZmYKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKi8KI2RlZmluZSAgQ09ORklHX0hBUkRfSTJDCQkvKiBJMkMgd2l0aCBoYXJkd2FyZSBzdXBwb3J0CSovCiN1bmRlZglDT05GSUdfU09GVF9JMkMJCQkvKiBJMkMgYml0LWJhbmdlZAkJKi8KI2RlZmluZSBDT05GSUdfUFBDNFhYX0kyQwkJLyogdXNlIFBQQzR4eCBkcml2ZXIJCSovCgojZGVmaW5lIEkyQ19JTklUCiNkZWZpbmUgSTJDX0FDVElWRSAwCiNkZWZpbmUgSTJDX1RSSVNUQVRFIDAKCiNkZWZpbmUgQ09ORklHX1NZU19JMkNfU1BFRUQJCTEwMDAwMAkvKiB1c2UgdGhlIHN0YW5kYXJkIDEwMGtIeiBzcGVlZCAqLwojZGVmaW5lIENPTkZJR19TWVNfSTJDX1NMQVZFCQkweDdGCQkvKiBtYXNrIHZhbGlkIGJpdHMgKi8KCiNkZWZpbmUgQ09ORklHX1JUQ19EUzEzMzcKI2RlZmluZSBDT05GSUdfU1lTX0kyQ19SVENfQUREUiAweDY4CgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFBDSSBzdHVmZgogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqLwojZGVmaW5lIFBDSV9IT1NUX0FEQVBURVIgMAkJLyogY29uZmlndXJlIGFyIHBjaSBhZGFwdGVyCSovCiNkZWZpbmUgUENJX0hPU1RfRk9SQ0UJMQkJLyogY29uZmlndXJlIGFzIHBjaSBob3N0CSovCiNkZWZpbmUgUENJX0hPU1RfQVVUTwkyCQkvKiBkZXRlY3RlZCB2aWEgYXJiaXRlciBlbmFibGUJKi8KCiNkZWZpbmUgQ09ORklHX1BDSQkJCS8qIGluY2x1ZGUgcGNpIHN1cHBvcnQJCSovCiNkZWZpbmUgQ09ORklHX1BDSV9IT1NUCVBDSV9IT1NUX0ZPUkNFCS8qIHNlbGVjdCBwY2kgaG9zdCBmdW5jdGlvbgkqLwojZGVmaW5lIENPTkZJR19QQ0lfUE5QCQkJLyogZG8gcGNpIHBsdWctYW5kLXBsYXkJCSovCgkJCQkJLyogcmVzb3VyY2UgY29uZmlndXJhdGlvbgkqLwoKLyogSWYgeW91IHdhbnQgdG8gc2VlLCB3aGF0cyBjb25uZWN0ZWQgdG8geW91ciBQQ0kgYnVzICovCi8qICNkZWZpbmUgQ09ORklHX1BDSV9TQ0FOX1NIT1cgKi8KCiNkZWZpbmUgQ09ORklHX1NZU19QQ0lfU1VCU1lTX1ZFTkRPUklEIDB4MDAwMAkvKiBQQ0kgVmVuZG9yIElEOiB0by1kbyEhIQkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1NVQlNZU19ERVZJQ0VJRCAweDAwMDAJLyogUENJIERldmljZSBJRDogdG8tZG8hISEJKi8KI2RlZmluZSBDT05GSUdfU1lTX1BDSV9QVE0xTEEJMHgwMDAwMDAwMAkvKiBwb2ludCB0byBzZHJhbQkJKi8KI2RlZmluZSBDT05GSUdfU1lTX1BDSV9QVE0xTVMJMHg4MDAwMDAwMQkvKiAyR0IsIGVuYWJsZSBoYXJkLXdpcmVkIHRvIDEJKi8KI2RlZmluZSBDT05GSUdfU1lTX1BDSV9QVE0xUENJIDB4MDAwMDAwMDAJLyogSG9zdDogdXNlIHRoaXMgcGNpIGFkZHJlc3MJKi8KI2RlZmluZSBDT05GSUdfU1lTX1BDSV9QVE0yTEEJMHgwMDAwMDAwMAkvKiBkaXNhYmxlZAkJCSovCiNkZWZpbmUgQ09ORklHX1NZU19QQ0lfUFRNMk1TCTB4MDAwMDAwMDAJLyogZGlzYWJsZWQJCQkqLwojZGVmaW5lIENPTkZJR19TWVNfUENJX1BUTTJQQ0kgMHgwNDAwMDAwMAkvKiBIb3N0OiB1c2UgdGhpcyBwY2kgYWRkcmVzcwkqLwoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBFeHRlcm5hbCBwZXJpcGhlcmFsIGJhc2UgYWRkcmVzcwogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqLwojaWYgIWRlZmluZWQoQ09ORklHX0NNRF9JREUpCgojdW5kZWYJQ09ORklHX0lERV9MRUQJCQkvKiBubyBsZWQgZm9yIGlkZSBzdXBwb3J0ZWQJKi8KI3VuZGVmCUNPTkZJR19JREVfUkVTRVQJCS8qIG5vIHJlc2V0IGZvciBpZGUgc3VwcG9ydGVkCSovCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIElERS9BVEEgc3R1ZmYKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKi8KI2Vsc2UKI2RlZmluZSBDT05GSUdfU1RBUlRfSURFCTEJLyogY2hlY2ssIGlmIHVzZSBJREUgKi8KCiN1bmRlZglDT05GSUdfSURFXzh4eF9ESVJFQ1QJCS8qIG5vIHBjbWNpYSBpbnRlcmZhY2UgcmVxdWlyZWQgKi8KI3VuZGVmCUNPTkZJR19JREVfTEVECQkJLyogbm8gbGVkIGZvciBpZGUgc3VwcG9ydGVkCSovCiN1bmRlZglDT05GSUdfSURFX1JFU0VUCQkvKiBubyByZXNldCBmb3IgaWRlIHN1cHBvcnRlZAkqLwoKI2RlZmluZQlDT05GSUdfQVRBUEkKI2RlZmluZQlDT05GSUdfRE9TX1BBUlRJVElPTgojZGVmaW5lCUNPTkZJR19TWVNfSURFX01BWERFVklDRQkoQ09ORklHX1NZU19JREVfTUFYQlVTKjEpIC8qIG1heC4gMSBkcml2ZXMgcGVyIElERSBidXMgKi8KCiNpZm5kZWYgSURFX1VTRVNfSVNBX0VNVUxBVElPTgoKLyogTmV3IGFuZCBmYXN0ZXIgYWNjZXNzICovCiNkZWZpbmUJQ09ORklHX1NZU19BVEFfQkFTRV9BRERSCQkweDdBMDAwMDAwCS8qIHN0YXJ0IG9mIElTQSBJTyBlbXVsYXRpb24gKi8KCi8qIEhvdyBtYW55IElERSBidXNzZXMgYXJlIGF2YWlsYWJsZSAqLwojZGVmaW5lCUNPTkZJR19TWVNfSURFX01BWEJVUwkJMQoKLyogV2hhdCBJREUgcG9ydHMgYXJlIGF2YWlsYWJsZSAqLwojZGVmaW5lCUNPTkZJR19TWVNfQVRBX0lERTBfT0ZGU0VUCTB4MDAwCQkvKiBmaXJzdCBpcyBhdmFpbGFibGUgKi8KI3VuZGVmCUNPTkZJR19TWVNfQVRBX0lERTFfT0ZGU0VUCQkJLyogc2Vjb25kIG5vdCBhdmFpbGFibGUgKi8KCi8qIGFjY2VzcyB0byB0aGUgZGF0YSBwb3J0IGlzIGNhbGN1bGF0ZWQ6CiAgIENPTkZJR19TWVNfQVRBX0JBU0VfQUREUiArIENPTkZJR19TWVNfQVRBX0lERTBfT0ZGU0VUICsgQ09ORklHX1NZU19BVEFfREFUQV9PRkZTRVQgKyAwICovCiNkZWZpbmUgQ09ORklHX1NZU19BVEFfREFUQV9PRkZTRVQJMHgwMDAwCS8qIE9mZnNldCBmb3IgZGF0YSBJL08gKi8KCi8qIGFjY2VzcyB0byB0aGUgcmVnaXN0ZXJzIGlzIGNhbGN1bGF0ZWQ6CiAgIENPTkZJR19TWVNfQVRBX0JBU0VfQUREUiArIENPTkZJR19TWVNfQVRBX0lERTBfT0ZGU0VUICsgQ09ORklHX1NZU19BVEFfUkVHX09GRlNFVCArIFsxLi43XSAqLwojZGVmaW5lCUNPTkZJR19TWVNfQVRBX1JFR19PRkZTRVQJMHgwMDAwCS8qIE9mZnNldCBmb3Igbm9ybWFsIHJlZ2lzdGVyIGFjY2Vzc2VzCSovCgovKiBhY2Nlc3MgdG8gdGhlIGFsdGVybmF0ZSByZWdpc3RlciBpcyBjYWxjdWxhdGVkOgogICBDT05GSUdfU1lTX0FUQV9CQVNFX0FERFIgKyBDT05GSUdfU1lTX0FUQV9JREUwX09GRlNFVCArIENPTkZJR19TWVNfQVRBX0FMVF9PRkZTRVQgKyA2ICovCiNkZWZpbmUgQ09ORklHX1NZU19BVEFfQUxUX09GRlNFVAkweDAwOAkJLyogT2Zmc2V0IGZvciBhbHRlcm5hdGUgcmVnaXN0ZXJzCSovCgojZWxzZSAvKiBJREVfVVNFU19JU0FfRU1VTEFUSU9OICovCgojZGVmaW5lCUNPTkZJR19TWVNfQVRBX0JBU0VfQUREUgkJMHg3OTAwMDAwMAkvKiBzdGFydCBvZiBJU0EgSU8gZW11bGF0aW9uICovCgovKiBIb3cgbWFueSBJREUgYnVzc2VzIGFyZSBhdmFpbGFibGUgKi8KI2RlZmluZQlDT05GSUdfU1lTX0lERV9NQVhCVVMJCTEKCi8qIFdoYXQgSURFIHBvcnRzIGFyZSBhdmFpbGFibGUgKi8KI2RlZmluZQlDT05GSUdfU1lTX0FUQV9JREUwX09GRlNFVAkweDAxRjAJLyogZmlyc3QgaXMgYXZhaWxhYmxlICovCiN1bmRlZglDT05GSUdfU1lTX0FUQV9JREUxX09GRlNFVAkJCQkvKiBzZWNvbmQgbm90IGF2YWlsYWJsZSAqLwoKLyogYWNjZXNzIHRvIHRoZSBkYXRhIHBvcnQgaXMgY2FsY3VsYXRlZDoKICAgQ09ORklHX1NZU19BVEFfQkFTRV9BRERSICsgQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQgKyBDT05GSUdfU1lTX0FUQV9EQVRBX09GRlNFVCArIDAgKi8KI2RlZmluZSBDT05GSUdfU1lTX0FUQV9EQVRBX09GRlNFVAkweDAwMDAJLyogT2Zmc2V0IGZvciBkYXRhIEkvTyAqLwoKLyogYWNjZXNzIHRvIHRoZSByZWdpc3RlcnMgaXMgY2FsY3VsYXRlZDoKICAgQ09ORklHX1NZU19BVEFfQkFTRV9BRERSICsgQ09ORklHX1NZU19BVEFfSURFMF9PRkZTRVQgKyBDT05GSUdfU1lTX0FUQV9SRUdfT0ZGU0VUICsgWzEuLjddICovCiNkZWZpbmUJQ09ORklHX1NZU19BVEFfUkVHX09GRlNFVAkweDAwMDAJLyogT2Zmc2V0IGZvciBub3JtYWwgcmVnaXN0ZXIgYWNjZXNzZXMJKi8KCi8qIGFjY2VzcyB0byB0aGUgYWx0ZXJuYXRlIHJlZ2lzdGVyIGlzIGNhbGN1bGF0ZWQ6CiAgIENPTkZJR19TWVNfQVRBX0JBU0VfQUREUiArIENPTkZJR19TWVNfQVRBX0lERTBfT0ZGU0VUICsgQ09ORklHX1NZU19BVEFfQUxUX09GRlNFVCArIDYgKi8KI2RlZmluZSBDT05GSUdfU1lTX0FUQV9BTFRfT0ZGU0VUCTB4MDNGMAkJLyogT2Zmc2V0IGZvciBhbHRlcm5hdGUgcmVnaXN0ZXJzCSovCgojZW5kaWYgLyogSURFX1VTRVNfSVNBX0VNVUxBVElPTiAqLwoKI2VuZGlmCgovKgojZGVmaW5lCUNPTkZJR19TWVNfS0VZX1JFR19CQVNFX0FERFIJMHhGMDEwMDAwMAojZGVmaW5lCUNPTkZJR19TWVNfSVJfUkVHX0JBU0VfQUREUgkweEYwMjAwMDAwCiNkZWZpbmUJQ09ORklHX1NZU19GUEdBX1JFR19CQVNFX0FERFIJMHhGMDMwMDAwMAoqLwoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBTdGFydCBhZGRyZXNzZXMgZm9yIHRoZSBmaW5hbCBtZW1vcnkgY29uZmlndXJhdGlvbgogKiAoU2V0IHVwIGJ5IHRoZSBzdGFydHVwIGNvZGUpCiAqIFBsZWFzZSBub3RlIHRoYXQgQ09ORklHX1NZU19TRFJBTV9CQVNFIF9tdXN0XyBzdGFydCBhdCAwCiAqCiAqIENPTkZJR19TWVNfRkxBU0hfQkFTRSAgIC0+IHN0YXJ0IGFkZHJlc3Mgb2YgaW50ZXJuYWwgZmxhc2gKICogQ09ORklHX1NZU19NT05JVE9SX0JBU0UgLT4gc3RhcnQgb2YgdS1ib290CiAqLwojZGVmaW5lIENPTkZJR19TWVNfU0RSQU1fQkFTRQkJMHgwMDAwMDAwMAojZGVmaW5lIENPTkZJR19TWVNfRkxBU0hfQkFTRQkJMHhGRkUwMDAwMAoKI2RlZmluZSBDT05GSUdfU1lTX01PTklUT1JfQkFTRQlURVhUX0JBU0UJLyogU3RhcnQgb2YgVS1Cb290CSovCiNkZWZpbmUgQ09ORklHX1NZU19NT05JVE9SX0xFTgkJKDB4RkZGRkZGRkYgLSBDT05GSUdfU1lTX01PTklUT1JfQkFTRSArIDEpCiNkZWZpbmUgQ09ORklHX1NZU19NQUxMT0NfTEVOCQkoMTI4ICogMTAyNCkJLyogUmVzZXJ2ZSAxMjggS2lCIGZvciBtYWxsb2MoKQkqLwoKLyoKICogRm9yIGJvb3RpbmcgTGludXgsIHRoZSBib2FyZCBpbmZvIGFuZCBjb21tYW5kIGxpbmUgZGF0YQogKiBoYXZlIHRvIGJlIGluIHRoZSBmaXJzdCA4IE1pQiBvZiBtZW1vcnksIHNpbmNlIHRoaXMgaXMKICogdGhlIG1heGltdW0gbWFwcGVkIGJ5IHRoZSBMaW51eCBrZXJuZWwgZHVyaW5nIGluaXRpYWxpemF0aW9uLgogKi8KI2RlZmluZSBDT05GSUdfU1lTX0JPT1RNQVBTWgkJKDggPDwgMjApCS8qIEluaXRpYWwgTWVtb3J5IG1hcCBmb3IgTGludXggKi8KLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBGTEFTSCBvcmdhbml6YXRpb24gIyMgRklYTUU6IGxvb2t1cCBpbiBkYXRhc2hlZXQKICovCiNkZWZpbmUgQ09ORklHX1NZU19NQVhfRkxBU0hfQkFOS1MJMgkvKiBtYXggbnVtYmVyIG9mIG1lbW9yeSBiYW5rcwkJKi8KI2RlZmluZSBDT05GSUdfU1lTX01BWF9GTEFTSF9TRUNUCTI1NgkvKiBtYXggbnVtYmVyIG9mIHNlY3RvcnMgb24gb25lIGNoaXAJKi8KCiNkZWZpbmUgQ09ORklHX1NZU19GTEFTSF9DRkkJCQkvKiBmbGFzaCBpcyBDRkkgY29tcGF0LgkqLwojZGVmaW5lIENPTkZJR19GTEFTSF9DRklfRFJJVkVSCQkvKiBVc2UgY29tbW9uIENGSSBkcml2ZXIqLwojZGVmaW5lIENPTkZJR19TWVNfRkxBU0hfRU1QVFlfSU5GTwkJLyogcHJpbnQgJ0UnIGZvciBlbXB0eSBzZWN0b3IJKi8KI2RlZmluZSBDT05GSUdfU1lTX0ZMQVNIX1FVSUVUX1RFU1QJMQkvKiBkb24ndCB3YXJuIHVwb24gdW5rbm93biBmbGFzaCovCiNkZWZpbmUgQ09ORklHX1NZU19GTEFTSF9FUkFTRV9UT1VUCTEyMDAwMAkvKiBUaW1lb3V0IGZvciBGbGFzaCBFcmFzZSAoaW4gbXMpCSovCiNkZWZpbmUgQ09ORklHX1NZU19GTEFTSF9XUklURV9UT1VUCTUwMAkvKiBUaW1lb3V0IGZvciBGbGFzaCBXcml0ZSAoaW4gbXMpCSovCiNkZWZpbmUgQ09ORklHX1NZU19XUklURV9TV0FQUEVEX0RBVEEJCS8qIHN3YXAgRGF0YWJ5dGVzIGJldHdlZW4gcmVhZGluZy93cml0aW5nICovCgojZGVmaW5lIENPTkZJR19FTlZfSVNfSU5fRkxBU0gJMQojaWZkZWYgQ09ORklHX0VOVl9JU19JTl9GTEFTSAojZGVmaW5lIENPTkZJR19FTlZfT0ZGU0VUCQkweDAwMDAwMDAwICAvKiBPZmZzZXQgb2YgRW52aXJvbm1lbnQgU2VjdG9yIGluIGJvdHRvbSB0eXBlICovCiNkZWZpbmUgQ09ORklHX0VOVl9TSVpFCQkweDQwMDAJICAgIC8qIFRvdGFsIFNpemUgb2YgRW52aXJvbm1lbnQgU2VjdG9yCSovCiNkZWZpbmUgQ09ORklHX0VOVl9TRUNUX1NJWkUJMHg0MDAwCSAgICAvKiBzZWUgUkVBRE1FIC0gZW52IHNlY3RvciB0b3RhbCBzaXplCSovCgovKiBBZGRyZXNzIGFuZCBzaXplIG9mIFJlZHVuZGFudCBFbnZpcm9ubWVudCBTZWN0b3IJKi8KI2RlZmluZSBDT05GSUdfRU5WX09GRlNFVF9SRURVTkQJKENPTkZJR19FTlZfT0ZGU0VUK0NPTkZJR19FTlZfU0laRSkKI2RlZmluZSBDT05GSUdfRU5WX1NJWkVfUkVEVU5ECShDT05GSUdfRU5WX1NJWkUpCgojZW5kaWYKLyogbGV0IHVzIGNoYW5naW5nIGFueXRoaW5nIGluIG91ciBlbnZpcm9ubWVudCAqLwojZGVmaW5lIENPTkZJR19FTlZfT1ZFUldSSVRFCgovKgogKiBOQU5ELUZMQVNIIHN0dWZmCiAqLwojZGVmaW5lIENPTkZJR19TWVNfTUFYX05BTkRfREVWSUNFCTEKI2RlZmluZSBDT05GSUdfU1lTX05BTkRfQkFTRQkJMHg3N0QwMDAwMAoKI2RlZmluZSBDT05GSUdfSkZGUzJfTkFORCAxCQkJLyogamZmczIgb24gbmFuZCBzdXBwb3J0ICovCgovKiBObyBjb21tYW5kIGxpbmUsIG9uZSBzdGF0aWMgcGFydGl0aW9uICovCiN1bmRlZglDT05GSUdfQ01EX01URFBBUlRTCiNkZWZpbmUgQ09ORklHX0pGRlMyX0RFVgkJIm5hbmQwIgojZGVmaW5lIENPTkZJR19KRkZTMl9QQVJUX1NJWkUJCTB4MDEwMDAwMDAKI2RlZmluZSBDT05GSUdfSkZGUzJfUEFSVF9PRkZTRVQJMHgwMDAwMDAwMAoKLyoKICogSW5pdCBNZW1vcnkgQ29udHJvbGxlcjoKICoKICovCgojZGVmaW5lIEZMQVNIX0JBU0UwX1BSRUxJTQlDT05GSUdfU1lTX0ZMQVNIX0JBU0UKI2RlZmluZSBGTEFTSF9CQVNFMV9QUkVMSU0JMAoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBTb21lIGluZm9ybWF0aW9ucyBhYm91dCB0aGUgaW50ZXJuYWwgU1JBTSAoT0NNPU9uIENoaXAgTWVtb3J5KQogKgogKiBDT05GSUdfU1lTX09DTV9EQVRBX0FERFIgLT4gbG9jYXRpb24KICogQ09ORklHX1NZU19PQ01fREFUQV9TSVpFIC0+IHNpemUKKi8KCiNkZWZpbmUgQ09ORklHX1NZU19URU1QX1NUQUNLX09DTQkxCiNkZWZpbmUgQ09ORklHX1NZU19PQ01fREFUQV9BRERSCTB4RjgwMDAwMDAKI2RlZmluZSBDT05GSUdfU1lTX09DTV9EQVRBX1NJWkUJMHgxMDAwCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIERlZmluaXRpb25zIGZvciBpbml0aWFsIHN0YWNrIHBvaW50ZXIgYW5kIGRhdGEgYXJlYSAoaW4gRFBSQU0pOgogKiAtIHdlIGFyZSB1c2luZyB0aGUgaW50ZXJuYWwgNGsgU1JBTSwgc28gd2UgZG9uJ3QgbmVlZCBkYXRhIGNhY2hlIG1hcHBpbmcKICogLSBpbnRlcm5hbCBTUkFNIChPQ009T24gQ2hpcCBNZW1vcnkpIGlzIHBsYWNlZCB0byBDT05GSUdfU1lTX09DTV9EQVRBX0FERFIKICogLSBTdGFja3BvaW50ZXIgd2lsbCBiZSBsb2NhdGVkIHRvCiAqICAgKENPTkZJR19TWVNfSU5JVF9SQU1fQUREUiYweEZGRkYwMDAwKSB8IChDT05GSUdfU1lTX0lOSVRfU1BfT0ZGU0VUJjB4MDAwMEZGRkYpCiAqICAgaW4gYXJjaC9wb3dlcnBjL2NwdS9wcGM0eHgvc3RhcnQuUwogKi8KCiN1bmRlZiBDT05GSUdfU1lTX0lOSVRfRENBQ0hFX0NTCi8qIFdoZXJlIHRoZSBpbnRlcm5hbCBTUkFNIHN0YXJ0cyAqLwojZGVmaW5lIENPTkZJR19TWVNfSU5JVF9SQU1fQUREUglDT05GSUdfU1lTX09DTV9EQVRBX0FERFIKLyogV2hlcmUgdGhlIGludGVybmFsIFNSQU0gZW5kcyAob25seSBvZmZzZXQpICovCiNkZWZpbmUgQ09ORklHX1NZU19JTklUX1JBTV9FTkQJMHgwRjAwCgovKgoKIENPTkZJR19TWVNfSU5JVF9SQU1fQUREUiAtLS0tLS0+IC0tLS0tLS0tLS0tLSBsb3dlciBhZGRyZXNzCgkJCSAgIHwJICAgICAgfAoJCQkgICB8ICBeICAgICAgIHwKCQkJICAgfCAgfCAgICAgICB8CgkJCSAgIHwgIHwgU3RhY2sgfAogQ09ORklHX1NZU19HQkxfREFUQV9PRkZTRVQgLS0tLT4gLS0tLS0tLS0tLS0tCgkJCSAgIHwJICAgICAgfAoJCQkgICB8IDY0IEJ5dGVzIHwKCQkJICAgfAkgICAgICB8CiBDT05GSUdfU1lTX0lOSVRfUkFNX0VORCAgLS0tLS0tPiAtLS0tLS0tLS0tLS0gaGlnaGVyIGFkZHJlc3MKICAob2Zmc2V0IG9ubHkpCgoqLwovKiBzaXplIGluIGJ5dGVzIHJlc2VydmVkIGZvciBpbml0aWFsIGRhdGEgKi8KI2RlZmluZSBDT05GSUdfU1lTX0dCTF9EQVRBX1NJWkUgICAgIDY0CiNkZWZpbmUgQ09ORklHX1NZU19HQkxfREFUQV9PRkZTRVQgICAoQ09ORklHX1NZU19JTklUX1JBTV9FTkQgLSBDT05GSUdfU1lTX0dCTF9EQVRBX1NJWkUpCi8qIEluaXRpYWwgdmFsdWUgb2YgdGhlIHN0YWNrIHBvaW50ZXJuIGluIGludGVybmFsIFNSQU0gKi8KI2RlZmluZSBDT05GSUdfU1lTX0lOSVRfU1BfT0ZGU0VUICAgIENPTkZJR19TWVNfR0JMX0RBVEFfT0ZGU0VUCgovKgogKiBJbnRlcm5hbCBEZWZpbml0aW9ucwogKgogKiBCb290IEZsYWdzCiAqLwojZGVmaW5lIEJPT1RGTEFHX0NPTEQJMHgwMQkJLyogTm9ybWFsIFBvd2VyLU9uOiBCb290IGZyb20gRkxBU0gJKi8KI2RlZmluZSBCT09URkxBR19XQVJNCTB4MDIJCS8qIFNvZnR3YXJlIHJlYm9vdAkJCSovCgovKiAjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyMjIyAqLwovKiBUaGVzZSBkZWZpbmVzIHdpbGwgYmUgdXNlZCBpbiBhcmNoL3Bvd2VycGMvY3B1L3BwYzR4eC9jcHVfaW5pdC5jIHRvIHNldHVwIGV4dGVybmFsIGNoaXAgc2VsZWN0cyAgKi8KLyogVGhleSBhcmUgY3VycmVudGx5IHVuZGVmaW5lZCBjYXVzZSB0aGV5IGFyZSBpbml0aWFpemVkIGluIGJvYXJkL3NvbGlkY2FyZDMvaW5pdC5TICAgKi8KCi8qIFRoaXMgY2hpcCBzZWxlY3QgYWNjZXNzZXMgdGhlIGJvb3QgZGV2aWNlICovCi8qIEl0IGRlcGVuZHMgb24gYm9vdCBzZWxlY3Qgc3dpdGNoIGlmIHRoaXMgZGV2aWNlIGlzIDE2IG9yIDggYml0ICovCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIwQVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCMENSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIxQVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCMUNSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIyQVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCMkNSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEIzQVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCM0NSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI0QVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCNENSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI1QVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCNUNSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI2QVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCNkNSCgojdW5kZWYgQ09ORklHX1NZU19FQkNfUEI3QVAKI3VuZGVmIENPTkZJR19TWVNfRUJDX1BCN0NSCgojZGVmaW5lIENPTkZJR19TWVNfRUJDX0NGRyAgICAweGI4NGVmMDAwCgojZGVmaW5lIENPTkZJR19TRFJBTV9CQU5LMAkvKiB1c2UgdGhlIHN0YW5kYXJkIFNEUkFNIGluaXRpYWxpemF0aW9uICovCiN1bmRlZiBDT05GSUdfU1BEX0VFUFJPTQoKLyoKICogRGVmaW5lIHRoaXMgdG8gZ2V0IG1vcmUgaW5mb3JtYXRpb24gYWJvdXQgc3lzdGVtIGNvbmZpZ3VyYXRpb24KICovCi8qICNkZWZpbmUgU0MzX0RFQlVHT1VUICovCiN1bmRlZiBTQzNfREVCVUdPVVQKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiBFeHRlcm5hbCBwZXJpcGhlcmFsIGJhc2UgYWRkcmVzcwogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCgojZGVmaW5lIENPTkZJR19TWVNfSVNBX01FTV9CQVNFX0FERFJFU1MgMHg3ODAwMDAwMAovKgogRGllIEdyYWZpay1UcmVpYmVyIGdyZWlmZW4g/GJlciBkaWUgQWRyZXNzZSBpbiBkaWVzZW0gTWFjcm8gYXVmIGRlbiBDaGlwIHp1LgogRGFzIGZ1bmt0aW9uaWVydCBiZWkgZGVyZW4gS2FydGVuLCB3ZWlsIHNpZSBlaW5lIFBDSS1CcmlkZ2UgYmVudXR6ZW4sIGRpZQogZGFzIGdsZWljaGUgTWFwcGluZyBkdXJjaGb8aHJlbiBrYW5uLCB3aWUgZGVyIFNDNTIwIChhbHNvIEF1ZnRlaWxlbiB2b24gSU8tWnVncmlmZmVuCiBhdWYgSVNBLSB1bmQgUENJLVp5a2xlbikKICovCiNkZWZpbmUgQ09ORklHX1NZU19JU0FfSU9fQkFTRV9BRERSRVNTICAweEU4MDAwMDAwCi8qI2RlZmluZSBDT05GSUdfU1lTX0lTQV9JT19CQVNFX0FERFJFU1MgIDB4NzkwMDAwMDAgKi8KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogVmlkZW8gc3VwcG9ydAogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKI2lmZGVmIFVTRV9WR0FfR1JBUEhJQ1MKI2RlZmluZSBDT05GSUdfVklERU8JCS8qIFRvIGVuYWJsZSB2aWRlbyBjb250cm9sbGVyIHN1cHBvcnQgKi8KI2RlZmluZSBDT05GSUdfVklERU9fQ1Q2OTAwMAojZGVmaW5lIENPTkZJR19DRkJfQ09OU09MRQovKiAjZGVmaW5lIENPTkZJR19WSURFT19MT0dPICovCiNkZWZpbmUgQ09ORklHX1ZHQV9BU19TSU5HTEVfREVWSUNFCiNkZWZpbmUgQ09ORklHX1ZJREVPX1NXX0NVUlNPUgovKiAjZGVmaW5lIENPTkZJR19WSURFT19IV19DVVJTT1IgKi8KI2RlZmluZSBDT05GSUdfVklERU9fT05CT0FSRAkvKiBWaWRlbyBjb250cm9sbGVyIGlzIG9uLWJvYXJkICovCgojZGVmaW5lIFZJREVPX0hXX1JFQ1RGSUxMCiNkZWZpbmUgVklERU9fSFdfQklUQkxUCgojZW5kaWYKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogSWRlbnQKICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KI2RlZmluZSBDT05GSUdfU0MzX1ZFUlNJT04gInIxLjQiCgojZGVmaW5lIFBPU1RfT1VUKHgpICgqKCh2b2xhdGlsZSB1bnNpZ25lZCBjaGFyKikoMHg3OTAwMDA4MCkpPXgpCgojZW5kaWYJLyogX19DT05GSUdfSCAqLwo=