LyoKICogKEMpIENvcHlyaWdodCAyMDAwLTIwMDQKICogV29sZmdhbmcgRGVuaywgREVOWCBTb2Z0d2FyZSBFbmdpbmVlcmluZywgd2RAZGVueC5kZS4KICoKICogRGVyaXZlZCBmcm9tIEZBRFM4NjBUIGRlZmluaXRpb25zIGJ5IE1hZ251cyBEYW1tLCBIZWxtdXQgQnVjaHNiYXVtLAogKiBhbmQgRGFuIE1hbGVrCiAqCiAqIE1vZGlmaWVkIGJ5LCBZdWxpIEJhcmNvaGVuLCBBcmFiZWxsYSBTb2Z0d2FyZSBMdGQuLCB5dWxpQGFyYWJlbGxhc3cuY29tCiAqCiAqIFRoaXMgaGVhZGVyIGZpbGUgY29udGFpbnMgdmFsdWVzIGNvbW1vbiB0byBhbGwgRkFEUyBmYW1pbHkgYm9hcmRzLgogKgogKiBTZWUgZmlsZSBDUkVESVRTIGZvciBsaXN0IG9mIHBlb3BsZSB3aG8gY29udHJpYnV0ZWQgdG8gdGhpcwogKiBwcm9qZWN0LgogKgogKiBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yCiAqIG1vZGlmeSBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGFzCiAqIHB1Ymxpc2hlZCBieSB0aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uOyBlaXRoZXIgdmVyc2lvbiAyIG9mCiAqIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLgogKgogKiBUaGlzIHByb2dyYW0gaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwKICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKICogTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFLiAgU2VlIHRoZQogKiBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBmb3IgbW9yZSBkZXRhaWxzLgogKgogKiBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZQogKiBhbG9uZyB3aXRoIHRoaXMgcHJvZ3JhbTsgaWYgbm90LCB3cml0ZSB0byB0aGUgRnJlZSBTb2Z0d2FyZQogKiBGb3VuZGF0aW9uLCBJbmMuLCA1OSBUZW1wbGUgUGxhY2UsIFN1aXRlIDMzMCwgQm9zdG9uLAogKiBNQSAwMjExMS0xMzA3IFVTQQogKi8KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqIEZsYXNoIE1lbW9yeSBNYXAgYXMgdXNlZCBieSBVLUJvb3Q6CiAqCiAqICAgICAgICAgICAgICAgICAgICAgICAgICBTdGFydCBBZGRyZXNzICAgIExlbmd0aAogKiArLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0rIDB4RkUwMF8wMDAwICAgICBTdGFydCBvZiBGbGFzaCAtLS0tLS0tLS0tLS0tLS0tLQogKiB8ICAgICAgICAgICAgICAgICAgICAgICB8IDB4RkUwMF8wMTAwICAgICBSZXNldCBWZWN0b3IKICogKyAgICAgICAgICAgICAgICAgICAgICAgKyAweEZFMD9fPz8/PwogKiB8IFUtQm9vdCBjb2RlICAgICAgICAgICB8CiAqIHwgICAgICAgICAgICAgICAgICAgICAgIHwKICogKy0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKyAweEZFMDRfMDAwMCAoc2VjdG9yIGJvcmRlcikKICogfCAgICAgICAgICAgICAgICAgICAgICAgfAogKiB8ICAgICAgICAgICAgICAgICAgICAgICB8CiAqIHwgVS1Cb290IGVudmlyb25tZW50ICAgIHwKICogfCAgICAgICAgICAgICAgICAgICAgICAgfCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIF4KICogfCAgICAgICAgICAgICAgICAgICAgICAgfCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIHwgVS1Cb290CiAqICs9PT09PT09PT09PT09PT09PT09PT09PSsgMHhGRTA4XzAwMDAgKHNlY3RvciBib3JkZXIpICAgIC0tLS0tLS0tLS0tLS0tLS0tCiAqIHwgQXZhaWxhYmxlICAgICAgICAgICAgIHwgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB8IEFwcGxpY2F0aW9ucwogKiB8IC4uLiAgICAgICAgICAgICAgICAgICB8ICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgdgogKgogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCgojaWYgMAojZGVmaW5lIENPTkZJR19CT09UREVMQVkJLTEJLyogYXV0b2Jvb3QgZGlzYWJsZWQJCSovCiNlbHNlCiNkZWZpbmUgQ09ORklHX0JPT1RERUxBWQk1CS8qIGF1dG9ib290IGFmdGVyIDUgc2Vjb25kcwkqLwojZW5kaWYKCiN1bmRlZglDT05GSUdfQk9PVEFSR1MKI2RlZmluZSBDT05GSUdfQk9PVENPTU1BTkQJCQkJCQkJXAogICAgImRoY3A7IgkJCQkJCQkJCVwKICAgICJzZXRlbnYgYm9vdGFyZ3Mgcm9vdD0vZGV2L25mcyBydyBuZnNyb290PSQoc2VydmVyaXApOiQocm9vdHBhdGgpICIJCVwKICAgICJpcD0kKGlwYWRkcik6JChzZXJ2ZXJpcCk6JChnYXRld2F5aXApOiQobmV0bWFzayk6JChob3N0bmFtZSk6Om9mZjsiCVwKICAgICJib290bSIKCiN1bmRlZglDT05GSUdfV0FUQ0hET0cJCQkvKiB3YXRjaGRvZyBkaXNhYmxlZAkJKi8KI2RlZmluZSBDT05GSUdfQlpJUDIJIC8qIGluY2x1ZGUgc3VwcG9ydCBmb3IgYnppcDIgY29tcHJlc3NlZCBpbWFnZXMgKi8KCi8qCiAqIE5ldyBNUEM4NnhBRFMgYW5kIER1ZXQgcHJvdmlkZSB0d28gRXRoZXJuZXQgY29ubmVjdGl2aXR5IG9wdGlvbnM6CiAqIDEwTWJpdC9zIG9uIFNDQyBhbmQgMTAwTWJpdC9zIG9uIEZFQy4gRkFEUyBwcm92aWRlcyBTQ0MgRXRoZXJuZXQgb24KICogbW90aGVyYm9hcmQgYW5kIEZFQyBFdGhlcm5ldCBvbiBkYXVnaHRlcmJvYXJkLiBBbGwgbmV3IFBRMSBjaGlwcyBoYXZlCiAqIGdvdCBGRUMgc28gRkVDIGlzIHRoZSBkZWZhdWx0LgogKi8KI2lmbmRlZiBDT05GSUdfQURTCiN1bmRlZglDT05GSUdfU0NDMV9FTkVUCQkvKiBEaXNhYmxlIFNDQzEgZXRoZXJuZXQgKi8KI2RlZmluZQlDT05GSUdfRkVDX0VORVQJCQkvKiBVc2UgRkVDIGV0aGVybmV0ICAqLwojZWxzZQkJCQkJLyogT2xkIEFEUyBoYXMgbm90IGdvdCBGRUMgb3B0aW9uICovCiNkZWZpbmUJQ09ORklHX1NDQzFfRU5FVAkJLyogVXNlIFNDQzEgZXRoZXJuZXQgKi8KI3VuZGVmCUNPTkZJR19GRUNfRU5FVAkJCS8qIE5vIEZFQyBldGhlcm5ldCAgKi8KI2VuZGlmIC8qICFDT05GSUdfQURTICovCgojaWYgZGVmaW5lZChDT05GSUdfU0NDMV9FTkVUKSAmJiBkZWZpbmVkKENPTkZJR19GRUNfRU5FVCkKI2Vycm9yIEJvdGggQ09ORklHX1NDQzFfRU5FVCBhbmQgQ09ORklHX0ZFQ19FTkVUIGNvbmZpZ3VyZWQKI2VuZGlmCgojaWZkZWYgQ09ORklHX0ZFQ19FTkVUCiNkZWZpbmUgQ0ZHX0RJU0NPVkVSX1BIWQojZW5kaWYKCiNpZm5kZWYgQ09ORklHX0NPTU1BTkRTCiNkZWZpbmUgQ09ORklHX0NPTU1BTkRTCShDT05GSUdfQ01EX0RGTCAgIFwKCQkJIHwgQ0ZHX0NNRF9ESENQICAgXAoJCQkgfCBDRkdfQ01EX0lNTUFQICBcCgkJCSB8IENGR19DTURfTUlJICAgIFwKCQkJIHwgQ0ZHX0NNRF9QQ01DSUEgXAoJCQkgfCBDRkdfQ01EX1BJTkcgICBcCgkJCSkKI2VuZGlmIC8qICFDT05GSUdfQ09NTUFORFMgKi8KCi8qIHRoaXMgbXVzdCBiZSBpbmNsdWRlZCBBRlRFUiB0aGUgZGVmaW5pdGlvbiBvZiBDT05GSUdfQ09NTUFORFMgKGlmIGFueSkgKi8KI2luY2x1ZGUgPGNtZF9jb25mZGVmcy5oPgoKLyoKICogTWlzY2VsbGFuZW91cyBjb25maWd1cmFibGUgb3B0aW9ucwogKi8KI3VuZGVmCUNGR19MT05HSEVMUAkJCS8qIHVuZGVmIHRvIHNhdmUgbWVtb3J5CQkqLwojZGVmaW5lCUNGR19QUk9NUFQJCSI9PiIJLyogTW9uaXRvciBDb21tYW5kIFByb21wdAkqLwojaWYgKENPTkZJR19DT01NQU5EUyAmIENGR19DTURfS0dEQikKI2RlZmluZQlDRkdfQ0JTSVpFCTEwMjQJCS8qIENvbnNvbGUgSS9PIEJ1ZmZlciBTaXplCSovCiNlbHNlCiNkZWZpbmUJQ0ZHX0NCU0laRQkyNTYJCS8qIENvbnNvbGUgSS9PIEJ1ZmZlciBTaXplCSovCiNlbmRpZgojZGVmaW5lCUNGR19QQlNJWkUgKENGR19DQlNJWkUrc2l6ZW9mKENGR19QUk9NUFQpKzE2KSAvKiBQcmludCBCdWZmZXIgU2l6ZSAqLwojZGVmaW5lCUNGR19NQVhBUkdTCTE2CQkvKiBtYXggbnVtYmVyIG9mIGNvbW1hbmQgYXJncwkqLwojZGVmaW5lIENGR19CQVJHU0laRQlDRkdfQ0JTSVpFCS8qIEJvb3QgQXJndW1lbnQgQnVmZmVyIFNpemUJKi8KCiNkZWZpbmUgQ0ZHX0xPQURfQUREUgkgCTB4MDAxMDAwMDAKCiNkZWZpbmUJQ0ZHX0haCQkgICAgICAgIDEwMDAJLyogZGVjcmVtZW50ZXIgZnJlcTogMSBtcyB0aWNrcyAqLwoKI2RlZmluZSBDRkdfQkFVRFJBVEVfVEFCTEUJeyA5NjAwLCAxOTIwMCwgMzg0MDAsIDU3NjAwLCAxMTUyMDAgfQoKLyoKICogTG93IExldmVsIENvbmZpZ3VyYXRpb24gU2V0dGluZ3MKICogKGFkZHJlc3MgbWFwcGluZ3MsIHJlZ2lzdGVyIGluaXRpYWwgdmFsdWVzLCBldGMuKQogKiBZb3Ugc2hvdWxkIGtub3cgd2hhdCB5b3UgYXJlIGRvaW5nIGlmIHlvdSBtYWtlIGNoYW5nZXMgaGVyZS4KICovCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogSW50ZXJuYWwgTWVtb3J5IE1hcHBlZCBSZWdpc3RlcgogKi8KI2RlZmluZSBDRkdfSU1NUgkJMHhGRjAwMDAwMAoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBEZWZpbml0aW9ucyBmb3IgaW5pdGlhbCBzdGFjayBwb2ludGVyIGFuZCBkYXRhIGFyZWEgKGluIERQUkFNKQogKi8KI2RlZmluZSBDRkdfSU5JVF9SQU1fQUREUglDRkdfSU1NUgojZGVmaW5lCUNGR19JTklUX1JBTV9FTkQJMHgyRjAwCS8qIEVuZCBvZiB1c2VkIGFyZWEgaW4gRFBSQU0JKi8KI2RlZmluZQlDRkdfR0JMX0RBVEFfU0laRQk2NCAgLyogc2l6ZSBpbiBieXRlcyByZXNlcnZlZCBmb3IgaW5pdGlhbCBkYXRhICovCiNkZWZpbmUgQ0ZHX0dCTF9EQVRBX09GRlNFVAkoQ0ZHX0lOSVRfUkFNX0VORCAtIENGR19HQkxfREFUQV9TSVpFKQojZGVmaW5lCUNGR19JTklUX1NQX09GRlNFVAlDRkdfR0JMX0RBVEFfT0ZGU0VUCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFN0YXJ0IGFkZHJlc3NlcyBmb3IgdGhlIGZpbmFsIG1lbW9yeSBjb25maWd1cmF0aW9uCiAqIChTZXQgdXAgYnkgdGhlIHN0YXJ0dXAgY29kZSkKICogUGxlYXNlIG5vdGUgdGhhdCBDRkdfU0RSQU1fQkFTRSBfbXVzdF8gc3RhcnQgYXQgMAogKi8KI2RlZmluZQlDRkdfU0RSQU1fQkFTRQkJMHgwMDAwMDAwMAojaWYgZGVmaW5lZChDT05GSUdfTVBDODZ4QURTKSB8fCBkZWZpbmVkKENPTkZJR19NUEM4ODVBRFMpIC8qIE5ldyBBRFMgb3IgRHVldCAqLwojZGVmaW5lCUNGR19TRFJBTV9TSVpFCQkweDAwODAwMDAwICAgICAgCS8qIDggTWJ5dGUgKi8KI2VsaWYgZGVmaW5lZChDT05GSUdfRkFEUykJCQkJLyogT2xkL25ldyBGQURTICovCiNkZWZpbmUJQ0ZHX1NEUkFNX1NJWkUJCTB4MDA0MDAwMDAJCS8qIDQgTWJ5dGUgKi8KI2Vsc2UJCQkJCQkJLyogT2xkIEFEUyAqLwojZGVmaW5lCUNGR19TRFJBTV9TSVpFCQkweDAwMDAwMDAwCQkvKiBObyBTRFJBTSAqLwojZW5kaWYKCiNkZWZpbmUgQ0ZHX01FTVRFU1RfU1RBUlQJMHgwMTAwMDAwCS8qIG1lbXRlc3Qgd29ya3Mgb24JKi8KI2lmIChDRkdfU0RSQU1fU0laRSkKI2RlZmluZSBDRkdfTUVNVEVTVF9FTkQJCUNGR19TRFJBTV9TSVpFCS8qIDEgLi4uIFNEUkFNX1NJWkUJKi8KI2Vsc2UKI2RlZmluZSBDRkdfTUVNVEVTVF9FTkQJCTB4MDQwMDAwMCAgICAgCS8qIDEgLi4uIDQgTUIgaW4gRFJBTQkqLwojZW5kaWYgLyogQ0ZHX1NEUkFNX1NJWkUgKi8KCi8qCiAqIEZvciBib290aW5nIExpbnV4LCB0aGUgYm9hcmQgaW5mbyBhbmQgY29tbWFuZCBsaW5lIGRhdGEKICogaGF2ZSB0byBiZSBpbiB0aGUgZmlyc3QgOCBNQiBvZiBtZW1vcnksIHNpbmNlIHRoaXMgaXMKICogdGhlIG1heGltdW0gbWFwcGVkIGJ5IHRoZSBMaW51eCBrZXJuZWwgZHVyaW5nIGluaXRpYWxpemF0aW9uLgogKi8KI2RlZmluZQlDRkdfQk9PVE1BUFNaCQkoOCA8PCAyMCkJLyogSW5pdGlhbCBNZW1vcnkgbWFwIGZvciBMaW51eAkqLwovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIEZsYXNoIG9yZ2FuaXphdGlvbgogKi8KI2RlZmluZSBDRkdfRkxBU0hfQkFTRQkJVEVYVF9CQVNFCiNkZWZpbmUgQ0ZHX0ZMQVNIX1NJWkUJCSgodWludCkoOCAqIDEwMjQgKiAxMDI0KSkJLyogbWF4IDhNYnl0ZSAqLwoKI2RlZmluZSBDRkdfTUFYX0ZMQVNIX0JBTktTCTEJLyogbWF4IG51bWJlciBvZiBtZW1vcnkgYmFua3MJCSovCiNkZWZpbmUgQ0ZHX01BWF9GTEFTSF9TRUNUCTE2ICAgICAgLyogbWF4IG51bWJlciBvZiBzZWN0b3JzIG9uIG9uZSBjaGlwCSovCgojZGVmaW5lIENGR19GTEFTSF9FUkFTRV9UT1VUCTEyMDAwMAkvKiBUaW1lb3V0IGZvciBGbGFzaCBFcmFzZSAoaW4gbXMpCSovCiNkZWZpbmUgQ0ZHX0ZMQVNIX1dSSVRFX1RPVVQJNTAwCS8qIFRpbWVvdXQgZm9yIEZsYXNoIFdyaXRlIChpbiBtcykJKi8KCiNkZWZpbmUJQ0ZHX0VOVl9JU19JTl9GTEFTSAkxCiNkZWZpbmUgQ0ZHX0VOVl9TRUNUX1NJWkUJMHg0MDAwMAkvKiBzZWUgUkVBRE1FIC0gZW52IHNlY3RvciB0b3RhbCBzaXplCSovCiNkZWZpbmUgQ0ZHX0VOVl9PRkZTRVQJCUNGR19FTlZfU0VDVF9TSVpFCiNkZWZpbmUJQ0ZHX0VOVl9TSVpFCQkweDQwMDAJLyogVG90YWwgU2l6ZSBvZiBFbnZpcm9ubWVudAkJKi8KCiNkZWZpbmUgQ0ZHX01PTklUT1JfQkFTRQlDRkdfRkxBU0hfQkFTRQojZGVmaW5lCUNGR19NT05JVE9SX0xFTgkJKDI1NiA8PCAxMCkJLyogUmVzZXJ2ZSAyNTYgS0IgZm9yIG1vbml0b3IJKi8KCiNpZmRlZiBDT05GSUdfQlpJUDIKI2RlZmluZQlDRkdfTUFMTE9DX0xFTgkJKDI1MDAgPDwgMTApCS8qIFJlc2VydmUgfjIuNSBNQiBmb3IgbWFsbG9jKCkJKi8KI2Vsc2UKI2RlZmluZQlDRkdfTUFMTE9DX0xFTgkJKDM4NCA8PCAxMCkJLyogUmVzZXJ2ZSAzODQga0IgZm9yIG1hbGxvYygpCSovCiNlbmRpZiAvKiBDT05GSUdfQlpJUDIgKi8KCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogQ2FjaGUgQ29uZmlndXJhdGlvbgogKi8KI2RlZmluZSBDRkdfQ0FDSEVMSU5FX1NJWkUJMTYJLyogRm9yIGFsbCBNUEM4eHggQ1BVcwkJCSovCiNpZiAoQ09ORklHX0NPTU1BTkRTICYgQ0ZHX0NNRF9LR0RCKQojZGVmaW5lIENGR19DQUNIRUxJTkVfU0hJRlQJNAkvKiBsb2cgYmFzZSAyIG9mIHRoZSBhYm92ZSB2YWx1ZQkqLwojZW5kaWYKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogSTJDIGNvbmZpZ3VyYXRpb24KICovCiNpZiAoQ09ORklHX0NPTU1BTkRTICYgQ0ZHX0NNRF9JMkMpCiNkZWZpbmUgQ09ORklHX0hBUkRfSTJDCQkxCS8qIEkyQyB3aXRoIGhhcmR3YXJlIHN1cHBvcnQgKi8KI2RlZmluZSBDRkdfSTJDX1NQRUVECQk0MDAwMDAJLyogSTJDIHNwZWVkIGFuZCBzbGF2ZSBhZGRyZXNzIGRlZmF1bHRzICovCiNkZWZpbmUgQ0ZHX0kyQ19TTEFWRQkJMHg3RgojZW5kaWYKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogU1lQQ1IgLSBTeXN0ZW0gUHJvdGVjdGlvbiBDb250cm9sCQkJCTExLTkKICogU1lQQ1IgY2FuIG9ubHkgYmUgd3JpdHRlbiBvbmNlIGFmdGVyIHJlc2V0IQogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFNvZnR3YXJlICYgQnVzIE1vbml0b3IgVGltZXIgbWF4LCBCdXMgTW9uaXRvciBlbmFibGUsIFNXIFdhdGNoZG9nIGZyZWV6ZQogKi8KI2lmIGRlZmluZWQoQ09ORklHX1dBVENIRE9HKQojZGVmaW5lIENGR19TWVBDUgkoU1lQQ1JfU1dUQyB8IFNZUENSX0JNVCB8IFNZUENSX0JNRSB8IFNZUENSX1NXRiB8IFwKCQkJIFNZUENSX1NXRSAgfCBTWVBDUl9TV1JJfCBTWVBDUl9TV1ApCiNlbHNlCiNkZWZpbmUgQ0ZHX1NZUENSCShTWVBDUl9TV1RDIHwgU1lQQ1JfQk1UIHwgU1lQQ1JfQk1FIHwgU1lQQ1JfU1dGIHwgU1lQQ1JfU1dQKQojZW5kaWYKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogU0lVTUNSIC0gU0lVIE1vZHVsZSBDb25maWd1cmF0aW9uCQkJCTExLTYKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBQQ01DSUEgY29uZmlnLiwgbXVsdGktZnVuY3Rpb24gcGluIHRyaS1zdGF0ZQogKi8KI2RlZmluZSBDRkdfU0lVTUNSCShTSVVNQ1JfREJHQzAwIHwgU0lVTUNSX0RCUEMwMCB8IFNJVU1DUl9NTFJDMDEpCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFRCU0NSIC0gVGltZSBCYXNlIFN0YXR1cyBhbmQgQ29udHJvbAkJCQkxMS0yNgogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIENsZWFyIFJlZmVyZW5jZSBJbnRlcnJ1cHQgU3RhdHVzLCBUaW1lYmFzZSBmcmVlemluZyBlbmFibGVkCiAqLwojZGVmaW5lIENGR19UQlNDUgkoVEJTQ1JfUkVGQSB8IFRCU0NSX1JFRkIgfCBUQlNDUl9UQkUpCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFBJU0NSIC0gUGVyaW9kaWMgSW50ZXJydXB0IFN0YXR1cyBhbmQgQ29udHJvbAkJMTEtMzEKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBDbGVhciBQZXJpb2RpYyBJbnRlcnJ1cHQgU3RhdHVzLCBJbnRlcnJ1cHQgVGltZXIgZnJlZXppbmcgZW5hYmxlZAogKi8KI2RlZmluZSBDRkdfUElTQ1IJKFBJU0NSX1BTIHwgUElTQ1JfUElURikKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogU0NDUiAtIFN5c3RlbSBDbG9jayBhbmQgcmVzZXQgQ29udHJvbCBSZWdpc3RlcgkJMTUtMjcKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBTZXQgY2xvY2sgb3V0cHV0LCB0aW1lYmFzZSBhbmQgUlRDIHNvdXJjZSBhbmQgZGl2aWRlciwKICogcG93ZXIgbWFuYWdlbWVudCBhbmQgc29tZSBvdGhlciBpbnRlcm5hbCBjbG9ja3MKICovCiNkZWZpbmUgU0NDUl9NQVNLCVNDQ1JfRUJERjExCiNkZWZpbmUgQ0ZHX1NDQ1IJKFNDQ1JfVEJTfFNDQ1JfQ09NMDB8U0NDUl9ERlNZTkMwMHxTQ0NSX0RGQlJHMDB8U0NDUl9ERk5MMDAwfFNDQ1JfREZOSDAwMHxTQ0NSX0RGTENEMDAwfFNDQ1JfREZBTENEMDApCgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqIFBMUFJDUiAtIFBMTCwgTG93LVBvd2VyLCBhbmQgUmVzZXQgQ29udHJvbCBSZWdpc3RlcgkJMTQtMjIKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBzZXQgdGhlIFBMTCwgdGhlIGxvdy1wb3dlciBtb2RlcyBhbmQgdGhlIHJlc2V0IGNvbnRyb2wKICovCiNpZm5kZWYgQ0ZHX1BMUFJDUgojZGVmaW5lIENGR19QTFBSQ1IJUExQUkNSX1RFWFBTCiNlbmRpZgoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKgogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqCiAqLwojZGVmaW5lIENGR19ERVIJCSAwCgovKiBCZWNhdXNlIG9mIHRoZSB3YXkgdGhlIDg2MCBzdGFydHMgdXAgYW5kIGFzc2lnbnMgQ1MwIHRoZQoqIGVudGlyZSBhZGRyZXNzIHNwYWNlLCB3ZSBoYXZlIHRvIHNldCB0aGUgbWVtb3J5IGNvbnRyb2xsZXIKKiBkaWZmZXJlbnRseS4gIE5vcm1hbGx5LCB5b3Ugd3JpdGUgdGhlIG9wdGlvbiByZWdpc3RlcgoqIGZpcnN0LCBhbmQgdGhlbiBlbmFibGUgdGhlIGNoaXAgc2VsZWN0IGJ5IHdyaXRpbmcgdGhlCiogYmFzZSByZWdpc3Rlci4gIEZvciBDUzAsIHlvdSBtdXN0IHdyaXRlIHRoZSBiYXNlIHJlZ2lzdGVyCiogZmlyc3QsIGZvbGxvd2VkIGJ5IHRoZSBvcHRpb24gcmVnaXN0ZXIuCiovCgovKgogKiBJbml0IE1lbW9yeSBDb250cm9sbGVyOgogKgogKiBCUjAvT1IwIChGbGFzaCkKICogQlIxL09SMSAoQkNTUikKICovCi8qIHRoZSBvdGhlciBDUzpzIGFyZSBkZXRlcm1pbmVkIGJ5IGxvb2tpbmcgYXQgcGFyYW1ldGVycyBpbiBCQ1NSeCAqLwoKI2RlZmluZSBCQ1NSX0FERFIJCSgodWludCkgMHhGRjA4MDAwMCkKCiNkZWZpbmUgQ0ZHX1BSRUxJTV9PUl9BTQkweEZGODAwMDAwCS8qIE9SIGFkZHIgbWFzayAqLwoKLyogRkxBU0ggdGltaW5nOiBBQ1MgPSAxMCwgVFJMWCA9IDEsIENTTlQgPSAxLCBTQ1kgPSAzLCBFSFRSID0gMCAqLwojZGVmaW5lIENGR19PUl9USU1JTkdfRkxBU0gJKE9SX0NTTlRfU0FNICB8IE9SX0FDU19ESVY0IHwgT1JfQkkgfCBPUl9TQ1lfM19DTEsgfCBPUl9UUkxYKQoKI2RlZmluZSBDRkdfT1IwX1BSRUxJTQkoQ0ZHX1BSRUxJTV9PUl9BTSB8IENGR19PUl9USU1JTkdfRkxBU0gpICAgLyogOCBNYnl0ZSB1bnRpbCBkZXRlY3RlZCAqLwojZGVmaW5lIENGR19CUjBfUFJFTElNCSgoQ0ZHX0ZMQVNIX0JBU0UgJiBCUl9CQV9NU0spIHwgQlJfViApCgovKiBCQ1NSeCAtIEJvYXJkIENvbnRyb2wgYW5kIFN0YXR1cyBSZWdpc3RlcnMgKi8KI2RlZmluZSBDRkdfT1IxX1BSRUxJTQkweEZGRkY4MTEwCQkvKiA2NEtieXRlIGFkZHJlc3Mgc3BhY2UgKi8KI2RlZmluZSBDRkdfQlIxX1BSRUxJTQkoKEJDU1JfQUREUikgfCBCUl9WKQoKLyoKICogSW50ZXJuYWwgRGVmaW5pdGlvbnMKICoKICogQm9vdCBGbGFncwogKi8KI2RlZmluZQlCT09URkxBR19DT0xECTB4MDEJCS8qIE5vcm1hbCBQb3dlci1PbjogQm9vdCBmcm9tIEZMQVNICSovCiNkZWZpbmUgQk9PVEZMQUdfV0FSTQkweDAyCQkvKiBTb2Z0d2FyZSByZWJvb3QJCQkqLwoKLyogdmFsdWVzIGFjY29yZGluZyB0byB0aGUgbWFudWFsICovCgojZGVmaW5lIFBDTUNJQV9NRU1fQUREUgkJKCh1aW50KTB4RkYwMjAwMDApCiNkZWZpbmUgUENNQ0lBX01FTV9TSVpFCQkoKHVpbnQpKDY0ICogMTAyNCkpCgojZGVmaW5lCUJDU1IwCQkJKCh1aW50KSAoQkNTUl9BRERSICsgMHgwMCkpCiNkZWZpbmUJQkNTUjEJCQkoKHVpbnQpIChCQ1NSX0FERFIgKyAweDA0KSkKI2RlZmluZQlCQ1NSMgkJCSgodWludCkgKEJDU1JfQUREUiArIDB4MDgpKQojZGVmaW5lCUJDU1IzCQkJKCh1aW50KSAoQkNTUl9BRERSICsgMHgwYykpCiNkZWZpbmUJQkNTUjQJCQkoKHVpbnQpIChCQ1NSX0FERFIgKyAweDEwKSkKCi8qCiAqIChGKUFEUyBiaXR2YWx1ZXMgYnkgSGVsbXV0IEJ1Y2hzYmF1bQogKgogKiBTZWUgVXNlcidzIE1hbnVhbCBmb3IgYSBwcm9wZXIKICogZGVzY3JpcHRpb24gb2YgdGhlIGZvbGxvd2luZyBzdHJ1Y3R1cmVzCiAqLwoKI2RlZmluZSBCQ1NSMF9FUkIgICAgICAgKCh1aW50KTB4ODAwMDAwMDApCiNkZWZpbmUgQkNTUjBfSVAgICAgICAgICgodWludCkweDQwMDAwMDAwKQojZGVmaW5lIEJDU1IwX0JESVMgICAgICAoKHVpbnQpMHgxMDAwMDAwMCkKI2RlZmluZSBCQ1NSMF9CUFNfTUFTSyAgKCh1aW50KTB4MEMwMDAwMDApCiNkZWZpbmUgQkNTUjBfSVNCX01BU0sgICgodWludCkweDAxODAwMDAwKQojZGVmaW5lIEJDU1IwX0RCR0NfTUFTSyAoKHVpbnQpMHgwMDYwMDAwMCkKI2RlZmluZSBCQ1NSMF9EQlBDX01BU0sgKCh1aW50KTB4MDAxODAwMDApCiNkZWZpbmUgQkNTUjBfRUJERl9NQVNLICgodWludCkweDAwMDYwMDAwKQoKI2RlZmluZSBCQ1NSMV9GTEFTSF9FTiAgICAgICAgICAgKCh1aW50KTB4ODAwMDAwMDApCiNkZWZpbmUgQkNTUjFfRFJBTV9FTiAgICAgICAgICAgICgodWludCkweDQwMDAwMDAwKQojZGVmaW5lIEJDU1IxX0VUSEVOICAgICAgICAgICAgICAoKHVpbnQpMHgyMDAwMDAwMCkKI2RlZmluZSBCQ1NSMV9JUkRFTiAgICAgICAgICAgICAgKCh1aW50KTB4MTAwMDAwMDApCiNkZWZpbmUgQkNTUjFfRkxBU0hfQ0ZHX0VOICAgICAgICgodWludCkweDA4MDAwMDAwKQojZGVmaW5lIEJDU1IxX0NOVF9SRUdfRU5fUFJPVEVDVCAoKHVpbnQpMHgwNDAwMDAwMCkKI2RlZmluZSBCQ1NSMV9CQ1NSX0VOICAgICAgICAgICAgKCh1aW50KTB4MDIwMDAwMDApCiNkZWZpbmUgQkNTUjFfUlMyMzJFTl8xICAgICAgICAgICgodWludCkweDAxMDAwMDAwKQojZGVmaW5lIEJDU1IxX1BDQ0VOICAgICAgICAgICAgICAoKHVpbnQpMHgwMDgwMDAwMCkKI2RlZmluZSBCQ1NSMV9QQ0NWQ0MwICAgICAgICAgICAgKCh1aW50KTB4MDA0MDAwMDApCiNkZWZpbmUgQkNTUjFfUENDVlBQX01BU0sgICAgICAgICgodWludCkweDAwMzAwMDAwKQojZGVmaW5lIEJDU1IxX0RSQU1fSEFMRl9XT1JEICAgICAoKHVpbnQpMHgwMDA4MDAwMCkKI2RlZmluZSBCQ1NSMV9SUzIzMkVOXzIgICAgICAgICAgKCh1aW50KTB4MDAwNDAwMDApCiNkZWZpbmUgQkNTUjFfU0RSQU1fRU4gICAgICAgICAgICgodWludCkweDAwMDIwMDAwKQojZGVmaW5lIEJDU1IxX1BDQ1ZDQzEgICAgICAgICAgICAoKHVpbnQpMHgwMDAxMDAwMCkKCiNkZWZpbmUgQkNTUjFfUENDVkNDT04JCSBCQ1NSMV9QQ0NWQ0MwCgojZGVmaW5lIEJDU1IyX0ZMQVNIX1BEX01BU0sgICAgICAoKHVpbnQpMHhGMDAwMDAwMCkKI2RlZmluZSBCQ1NSMl9EUkFNX1BEX01BU0sgICAgICAgKCh1aW50KTB4MDc4MDAwMDApCiNkZWZpbmUgQkNTUjJfRFJBTV9QRF9TSElGVCAgICAgIDIzCiNkZWZpbmUgQkNTUjJfRVhUVE9MSV9NQVNLICAgICAgICgodWludCkweDAwNzgwMDAwKQojZGVmaW5lIEJDU1IyX0RCUkVWTlJfTUFTSyAgICAgICAoKHVpbnQpMHgwMDAzMDAwMCkKCiNkZWZpbmUgQkNTUjNfREJJRF9NQVNLICAgICAgICAgICgodXNob3J0KTB4MzgwMCkKI2RlZmluZSBCQ1NSM19DTlRfUkVHX0VOX1BST1RFQ1QgKCh1c2hvcnQpMHgwNDAwKQojZGVmaW5lIEJDU1IzX0JSRVZOUjAgICAgICAgICAgICAoKHVzaG9ydCkweDAwODApCiNkZWZpbmUgQkNTUjNfRkxBU0hfUERfTUFTSyAgICAgICgodXNob3J0KTB4MDA3MCkKI2RlZmluZSBCQ1NSM19CUkVWTjEgICAgICAgICAgICAgKCh1c2hvcnQpMHgwMDA4KQojZGVmaW5lIEJDU1IzX0JSRVZOMl9NQVNLICAgICAgICAoKHVzaG9ydCkweDAwMDMpCgojZGVmaW5lIEJDU1I0X0VUSExPT1AgICAgICAgICAgICAoKHVpbnQpMHg4MDAwMDAwMCkKI2RlZmluZSBCQ1NSNF9URlBMREwgICAgICAgICAgICAgKCh1aW50KTB4NDAwMDAwMDApCiNkZWZpbmUgQkNTUjRfVFBTUUVMICAgICAgICAgICAgICgodWludCkweDIwMDAwMDAwKQojZGVmaW5lIEJDU1I0X1NJR05BTF9MQU1QICAgICAgICAoKHVpbnQpMHgxMDAwMDAwMCkKI2RlZmluZSBCQ1NSNF9GRVRIX0VOICAgICAgICAgICAgKCh1aW50KTB4MDgwMDAwMDApCiNkZWZpbmUgQkNTUjRfRkVUSENGRzAgICAgICAgICAgICgodWludCkweDA0MDAwMDAwKQojZGVmaW5lIEJDU1I0X0ZFVEhGREUgICAgICAgICAgICAoKHVpbnQpMHgwMjAwMDAwMCkKI2RlZmluZSBCQ1NSNF9GRVRIQ0ZHMSAgICAgICAgICAgKCh1aW50KTB4MDA0MDAwMDApCiNkZWZpbmUgQkNTUjRfRkVUSFJTVCAgICAgICAgICAgICgodWludCkweDAwMjAwMDAwKQoKI2lmZGVmIENPTkZJR19NUEM4MjMKI2RlZmluZSBCQ1NSNF9VU0JfRU4gICAgICAgICAgICAgKCh1aW50KTB4MDgwMDAwMDApCiNlbmRpZiAvKiBDT05GSUdfTVBDODIzICovCiNpZmRlZiBDT05GSUdfTVBDODYwU0FSCiNkZWZpbmUgQkNTUjRfVVRPUElBX0VOICAgICAgICAgICgodWludCkweDA4MDAwMDAwKQojZW5kaWYgLyogQ09ORklHX01QQzg2MFNBUiAqLwojaWZkZWYgQ09ORklHX01QQzg2MFQKI2RlZmluZSBCQ1NSNF9GRVRIX0VOICAgICAgICAgICAgKCh1aW50KTB4MDgwMDAwMDApCiNlbmRpZiAvKiBDT05GSUdfTVBDODYwVCAqLwojaWZkZWYgQ09ORklHX01QQzgyMwojZGVmaW5lIEJDU1I0X1VTQl9TUEVFRCAgICAgICAgICAoKHVpbnQpMHgwNDAwMDAwMCkKI2VuZGlmIC8qIENPTkZJR19NUEM4MjMgKi8KI2lmZGVmIENPTkZJR19NUEM4NjBUCiNkZWZpbmUgQkNTUjRfRkVUSENGRzAgICAgICAgICAgICgodWludCkweDA0MDAwMDAwKQojZW5kaWYgLyogQ09ORklHX01QQzg2MFQgKi8KI2lmZGVmIENPTkZJR19NUEM4MjMKI2RlZmluZSBCQ1NSNF9WQ0NPICAgICAgICAgICAgICAgKCh1aW50KTB4MDIwMDAwMDApCiNlbmRpZiAvKiBDT05GSUdfTVBDODIzICovCiNpZmRlZiBDT05GSUdfTVBDODYwVAojZGVmaW5lIEJDU1I0X0ZFVEhGREUgICAgICAgICAgICAoKHVpbnQpMHgwMjAwMDAwMCkKI2VuZGlmIC8qIENPTkZJR19NUEM4NjBUICovCiNpZmRlZiBDT05GSUdfTVBDODIzCiNkZWZpbmUgQkNTUjRfVklERU9fT04gICAgICAgICAgICgodWludCkweDAwODAwMDAwKQojZW5kaWYgLyogQ09ORklHX01QQzgyMyAqLwojaWZkZWYgQ09ORklHX01QQzgyMwojZGVmaW5lIEJDU1I0X1ZET19FS1RfQ0xLX0VOICAgICAoKHVpbnQpMHgwMDQwMDAwMCkKI2VuZGlmIC8qIENPTkZJR19NUEM4MjMgKi8KI2lmZGVmIENPTkZJR19NUEM4NjBUCiNkZWZpbmUgQkNTUjRfRkVUSENGRzEgICAgICAgICAgICgodWludCkweDAwNDAwMDAwKQojZW5kaWYgLyogQ09ORklHX01QQzg2MFQgKi8KI2lmZGVmIENPTkZJR19NUEM4MjMKI2RlZmluZSBCQ1NSNF9WSURFT19SU1QgICAgICAgICAgKCh1aW50KTB4MDAyMDAwMDApCiNlbmRpZiAvKiBDT05GSUdfTVBDODIzICovCiNpZmRlZiBDT05GSUdfTVBDODYwVAojZGVmaW5lIEJDU1I0X0ZFVEhSU1QgICAgICAgICAgICAoKHVpbnQpMHgwMDIwMDAwMCkKI2VuZGlmIC8qIENPTkZJR19NUEM4NjBUICovCiNpZmRlZiBDT05GSUdfTVBDODIzCiNkZWZpbmUgQkNTUjRfTU9ERU1fRU4gICAgICAgICAgICgodWludCkweDAwMTAwMDAwKQojZW5kaWYgLyogQ09ORklHX01QQzgyMyAqLwojaWZkZWYgQ09ORklHX01QQzgyMwojZGVmaW5lIEJDU1I0X0RBVEFfVk9JQ0UgICAgICAgICAoKHVpbnQpMHgwMDA4MDAwMCkKI2VuZGlmIC8qIENPTkZJR19NUEM4MjMgKi8KI2lmZGVmIENPTkZJR19NUEM4NTAKI2RlZmluZSBCQ1NSNF9EQVRBX1ZPSUNFICAgICAgICAgKCh1aW50KTB4MDAwODAwMDApCiNlbmRpZiAvKiBDT05GSUdfTVBDODUwICovCgovKiBCU0NSNSBleGlzdHMgb24gTVBDODZ4QURTIGFuZCBEdWV0IEFEUyBvbmx5ICovCgojZGVmaW5lIENGR19QSFlERVZfQUREUgkJKEJDU1JfQUREUiArIDB4MjAwMDApCgojZGVmaW5lIEJDU1I1CQkJKENGR19QSFlERVZfQUREUiArIDB4MzAwKQoKI2RlZmluZSBCQ1NSNV9NSUkyX0VOCQkweDQwCiNkZWZpbmUgQkNTUjVfTUlJMl9SU1QJCTB4MjAKI2RlZmluZSBCQ1NSNV9UMV9SU1QJCTB4MTAKI2RlZmluZSBCQ1NSNV9BVE0xNTVfUlNUCTB4MDgKI2RlZmluZSBCQ1NSNV9BVE0yNV9SU1QJCTB4MDQKI2RlZmluZSBCQ1NSNV9NSUkxX0VOCQkweDAyCiNkZWZpbmUgQkNTUjVfTUlJMV9SU1QJCTB4MDEKCi8qIFdlIGRvbid0IHVzZSB0aGUgODI1OS4KKi8KI2RlZmluZSBOUl84MjU5X0lOVFMJMAoKLyogTWFjaGluZSB0eXBlCiovCiNkZWZpbmUgX01BQ0hfOHh4IChfTUFDSF9mYWRzKQoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKiBQQ01DSUEgc3R1ZmYKICotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLQogKi8KI2RlZmluZSBDRkdfUENNQ0lBX01FTV9BRERSCSgweEUwMDAwMDAwKQojZGVmaW5lIENGR19QQ01DSUFfTUVNX1NJWkUJKCA2NCA8PCAyMCApCiNkZWZpbmUgQ0ZHX1BDTUNJQV9ETUFfQUREUgkoMHhFNDAwMDAwMCkKI2RlZmluZSBDRkdfUENNQ0lBX0RNQV9TSVpFCSggNjQgPDwgMjAgKQojZGVmaW5lIENGR19QQ01DSUFfQVRUUkJfQUREUgkoMHhFODAwMDAwMCkKI2RlZmluZSBDRkdfUENNQ0lBX0FUVFJCX1NJWkUJKCA2NCA8PCAyMCApCiNkZWZpbmUgQ0ZHX1BDTUNJQV9JT19BRERSCSgweEVDMDAwMDAwKQojZGVmaW5lIENGR19QQ01DSUFfSU9fU0laRQkoIDY0IDw8IDIwICkKCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0KICogSURFL0FUQSBzdHVmZgogKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tCiAqLwojZGVmaW5lIENPTkZJR19NQUNfUEFSVElUSU9OICAgIDEKI2RlZmluZSBDT05GSUdfRE9TX1BBUlRJVElPTiAgICAxCiNkZWZpbmUgQ09ORklHX0lTT19QQVJUSVRJT04JMQoKI3VuZGVmCUNPTkZJR19BVEFQSQojZGVmaW5lIENPTkZJR19JREVfOHh4X1BDQ0FSRAkxCS8qIFVzZSBJREUgd2l0aCBQQyBDYXJkIEFkYXB0ZXIgKi8KI3VuZGVmCUNPTkZJR19JREVfOHh4X0RJUkVDVAkJLyogRGlyZWN0IElERQkgbm90IHN1cHBvcnRlZAkqLwojdW5kZWYJQ09ORklHX0lERV9MRUQJCQkvKiBMRUQJIGZvciBpZGUgbm90IHN1cHBvcnRlZAkqLwojdW5kZWYJQ09ORklHX0lERV9SRVNFVAkJLyogcmVzZXQgZm9yIGlkZSBub3Qgc3VwcG9ydGVkCSovCgojZGVmaW5lIENGR19JREVfTUFYQlVTCQkxCS8qIG1heC4gMiBJREUgYnVzc2VzCSovCiNkZWZpbmUgQ0ZHX0lERV9NQVhERVZJQ0UJKENGR19JREVfTUFYQlVTKjIpIC8qIG1heC4gMiBkcml2ZXMgcGVyIElERSBidXMgKi8KCiNkZWZpbmUgQ0ZHX0FUQV9CQVNFX0FERFIJQ0ZHX1BDTUNJQV9NRU1fQUREUgojZGVmaW5lIENGR19BVEFfSURFMF9PRkZTRVQJMHgwMDAwCgovKiBPZmZzZXQgZm9yIGRhdGEgSS9PCQkJKi8KI2RlZmluZSBDRkdfQVRBX0RBVEFfT0ZGU0VUCShDRkdfUENNQ0lBX01FTV9TSVpFICsgMHgzMjApCi8qIE9mZnNldCBmb3Igbm9ybWFsIHJlZ2lzdGVyIGFjY2Vzc2VzCSovCiNkZWZpbmUgQ0ZHX0FUQV9SRUdfT0ZGU0VUCSgyICogQ0ZHX1BDTUNJQV9NRU1fU0laRSArIDB4MzIwKQovKiBPZmZzZXQgZm9yIGFsdGVybmF0ZSByZWdpc3RlcnMJKi8KI2RlZmluZSBDRkdfQVRBX0FMVF9PRkZTRVQJMHgwMDAwCgojZGVmaW5lIENPTkZJR19ESVNLX1NQSU5VUF9USU1FIDEwMDAwMDAKI3VuZGVmIENPTkZJR19ESVNLX1NQSU5VUF9USU1FCS8qIHVzaW60IENvbXBhY3QgRmxhc2ggKi8K