LyoKICogRGVmaW5pdGlvbnMgZm9yIHRoZSBGVERJIFVTQiBTaW5nbGUgUG9ydCBTZXJpYWwgQ29udmVydGVyIC0gCiAqIGtub3duIGFzIEZURElfU0lPIChTZXJpYWwgSW5wdXQvT3V0cHV0IGFwcGxpY2F0aW9uIG9mIHRoZSBjaGlwc2V0KSAKICoKICogVGhlIGV4YW1wbGUgSSBoYXZlIGlzIGtub3duIGFzIHRoZSBVU0MtMTAwMCB3aGljaCBpcyBhdmFpbGFibGUgZnJvbQogKiBodHRwOi8vd3d3LmRzZS5jby5ueiAtIGNhdCBubyBYSDQyMTQgSXQgbG9va3Mgc2ltaWxhciB0byB0aGlzOgogKiBodHRwOi8vd3d3LmRhbnNkYXRhLmNvbS91c2JzZXIuaHRtIGJ1dCBJIGNhbid0IGJlIHN1cmUgVGhlcmUgYXJlIG90aGVyCiAqIFVTQy0xMDAwcyB3aGljaCBkb24ndCBsb29rIGxpa2UgbXkgZGV2aWNlIHRob3VnaCBzbyBiZXdhcmUhCiAqCiAqIFRoZSBkZXZpY2UgaXMgYmFzZWQgb24gdGhlIEZUREkgRlQ4VTEwMEFYIGNoaXAuIEl0IGhhcyBhIERCMjUgb24gb25lIHNpZGUsIAogKiBVU0Igb24gdGhlIG90aGVyLgogKgogKiBUaGFueCB0byBGVERJIChodHRwOi8vd3d3LmZ0ZGkuY28udWspIGZvciBzbyBraW5kbHkgcHJvdmlkaW5nIGRldGFpbHMKICogb2YgdGhlIHByb3RvY29sIHJlcXVpcmVkIHRvIHRhbGsgdG8gdGhlIGRldmljZSBhbmQgb25nb2luZyBhc3Npc3RlbmNlCiAqIGR1cmluZyBkZXZlbG9wbWVudC4KICoKICogQmlsbCBSeWRlciAtIGJyeWRlckBzZ2kuY29tIGZvcm1lcmx5IG9mIFNpbGljb24gR3JhcGhpY3MsIEluYy4tIHdyb3RlIHRoZSAKICogRlRESV9TSU8gaW1wbGVtZW50YXRpb24uCiAqCiAqIFBoaWxpcHAgR/xocmluZyAtIHBnQGZ1dHVyZXdhcmUuYXQgLSBhZGRlZCB0aGUgRGV2aWNlIElEIG9mIHRoZSBVU0IgcmVsYWlzCiAqIGZyb20gUnVkb2xmIEd1Z2xlcgogKgogKi8KCiNkZWZpbmUgRlRESV9WSUQJMHgwNDAzCS8qIFZlbmRvciBJZCAqLwojZGVmaW5lIEZURElfU0lPX1BJRAkweDgzNzIJLyogUHJvZHVjdCBJZCBTSU8gYXBwbGljYXRpb24gb2YgOFUxMDBBWCAgKi8KI2RlZmluZSBGVERJXzhVMjMyQU1fUElEIDB4NjAwMSAvKiBTaW1pbGFyIGRldmljZSB0byBTSU8gYWJvdmUgKi8KI2RlZmluZSBGVERJXzhVMjMyQU1fQUxUX1BJRCAweDYwMDYgLyogRlRESSdzIGFsdGVybmF0ZSBQSUQgZm9yIGFib3ZlICovCiNkZWZpbmUgRlRESV84VTIyMzJDX1BJRCAweDYwMTAgLyogRHVhbCBjaGFubmVsIGRldmljZSAqLwojZGVmaW5lIEZURElfMjMyUkxfUElEICAweEZCRkEgIC8qIFByb2R1Y3QgSUQgZm9yIEZUMjMyUkwgKi8KI2RlZmluZSBGVERJX1JFTEFJU19QSUQJMHhGQTEwICAvKiBSZWxhaXMgZGV2aWNlIGZyb20gUnVkb2xmIEd1Z2xlciAqLwojZGVmaW5lIEZURElfTkZfUklDX1ZJRAkweDBEQ0QJLyogVmVuZG9yIElkICovCiNkZWZpbmUgRlRESV9ORl9SSUNfUElECTB4MDAwMQkvKiBQcm9kdWN0IElkICovCgoKLyogd3d3LmNhbnVzYi5jb20gTGF3aWNlbCBDQU5VU0IgZGV2aWNlICovCiNkZWZpbmUgRlRESV9DQU5VU0JfUElEIDB4RkZBOCAvKiBQcm9kdWN0IElkICovCgovKiBBbHBoYU1pY3JvIENvbXBvbmVudHMgQU1DLTIzMlVTQjAxIGRldmljZSAqLwojZGVmaW5lIEZURElfQU1DMjMyX1BJRCAweEZGMDAgLyogUHJvZHVjdCBJZCAqLwoKLyogQUNUIFNvbHV0aW9ucyBIb21lUHJvIFpXYXZlIGludGVyZmFjZSAoaHR0cDovL3d3dy5hY3Qtc29sdXRpb25zLmNvbS9Ib21lUHJvLmh0bSkgKi8KI2RlZmluZSBGVERJX0FDVFpXQVZFX1BJRAkweEYyRDAKCgovKiB3d3cuc3RhcnRpbmctcG9pbnQtc3lzdGVtcy5jb20gtUNoYW1lbGVvbiBkZXZpY2UgKi8KI2RlZmluZSBGVERJX01JQ1JPX0NIQU1FTEVPTl9QSUQJMHhDQUEwCS8qIFByb2R1Y3QgSWQgKi8KCi8qIHd3dy5pcnRyYW5zLmRlIGRldmljZSAqLwojZGVmaW5lIEZURElfSVJUUkFOU19QSUQgMHhGQzYwIC8qIFByb2R1Y3QgSWQgKi8KCgovKiB3d3cudGhvdWdodHRlY2hub2xvZ3kuY29tLyBUVC1VU0IgcHJvdmlkZSB3aXRoIHByb2NvbXAgdXNlIGZ0ZGlfc2lvICovCiNkZWZpbmUgRlRESV9UVFVTQl9QSUQgMHhGRjIwIC8qIFByb2R1Y3QgSWQgKi8KCi8qIGlQbHVzIGRldmljZSAqLwojZGVmaW5lIEZURElfSVBMVVNfUElEIDB4RDA3MCAvKiBQcm9kdWN0IElkICovCgovKiBETVg0QUxMIERNWCBJbnRlcmZhY2VzICovCiNkZWZpbmUgRlRESV9ETVg0QUxMIDB4Qzg1MAoKLyogd3d3LmNyeXN0YWxmb250ei5jb20gZGV2aWNlcyAtIHRoYW54IGZvciBwcm92aWRpbmcgZnJlZSBkZXZpY2VzIGZvciBldmFsdWF0aW9uICEgKi8KLyogdGhleSB1c2UgdGhlIGZ0ZGkgY2hpcHNldCBmb3IgdGhlIFVTQiBpbnRlcmZhY2UgYW5kIHRoZSB2ZW5kb3IgaWQgaXMgdGhlIHNhbWUgKi8KI2RlZmluZSBGVERJX1hGXzYzMl9QSUQgMHhGQzA4CS8qIDYzMjogMTZ4MiBDaGFyYWN0ZXIgRGlzcGxheSAqLwojZGVmaW5lIEZURElfWEZfNjM0X1BJRCAweEZDMDkJLyogNjM0OiAyMHg0IENoYXJhY3RlciBEaXNwbGF5ICovCiNkZWZpbmUgRlRESV9YRl81NDdfUElEIDB4RkMwQQkvKiA1NDc6IFR3byBsaW5lIERpc3BsYXkgKi8KI2RlZmluZSBGVERJX1hGXzYzM19QSUQgMHhGQzBCCS8qIDYzMzogMTZ4MiBDaGFyYWN0ZXIgRGlzcGxheSB3aXRoIEtleXMgKi8KI2RlZmluZSBGVERJX1hGXzYzMV9QSUQgMHhGQzBDCS8qIDYzMTogMjB4MiBDaGFyYWN0ZXIgRGlzcGxheSAqLwojZGVmaW5lIEZURElfWEZfNjM1X1BJRCAweEZDMEQJLyogNjM1OiAyMHg0IENoYXJhY3RlciBEaXNwbGF5ICovCiNkZWZpbmUgRlRESV9YRl82NDBfUElEIDB4RkMwRQkvKiA2NDA6IFR3byBsaW5lIERpc3BsYXkgKi8KI2RlZmluZSBGVERJX1hGXzY0Ml9QSUQgMHhGQzBGCS8qIDY0MjogVHdvIGxpbmUgRGlzcGxheSAqLwoKLyogVmlkZW8gTmV0d29ya3MgTGltaXRlZCAvIEhvbWVjaG9pY2UgaW4gdGhlIFVLIHVzZSBhbiBmdGRpLWJhc2VkIGRldmljZSBmb3IgdGhlaXIgMU1iICovCi8qIGJyb2FkYmFuZCBpbnRlcm5ldCBzZXJ2aWNlLiAgVGhlIGZvbGxvd2luZyBQSUQgaXMgZXhoaWJpdGVkIGJ5IHRoZSB1c2IgZGV2aWNlIHN1cHBsaWVkICovCi8qICh0aGUgVklEIGlzIHRoZSBzdGFuZGFyZCBmdGRpIHZpZCAoRlRESV9WSUQpICovCiNkZWZpbmUgRlRESV9WTkhDUENVU0JfRF9QSUQgMHhmZTM4IC8qIFByb2R1Y3QgSWQgKi8KCi8qCiAqIFBDREogdXNlIGZ0ZGkgYmFzZWQgZGotY29udHJvbGxlcnMuICBUaGUgZm9sbG93aW5nIFBJRCBpcyBmb3IgdGhlaXIgREFDLTIgZGV2aWNlCiAqIGh0dHA6Ly93d3cucGNkamhhcmR3YXJlLmNvbS9EQUMyLmFzcCAoUElEIHNlbnQgYnkgV291dGVyIFBhZXNlbikKICogKHRoZSBWSUQgaXMgdGhlIHN0YW5kYXJkIGZ0ZGkgdmlkIChGVERJX1ZJRCkgKi8KI2RlZmluZSBGVERJX1BDREpfREFDMl9QSUQgMHhGQTg4CgovKgogKiBUaGUgZm9sbG93aW5nIGFyZSB0aGUgdmFsdWVzIGZvciB0aGUgTWF0cml4IE9yYml0YWwgTENEIGRpc3BsYXlzLAogKiB3aGljaCBhcmUgdGhlIEZUMjMyQk0gKCBzaW1pbGFyIHRvIHRoZSA4VTIzMkFNICkKICovCiNkZWZpbmUgRlRESV9NVFhPUkJfMF9QSUQgICAgICAweEZBMDAgIC8qIE1hdHJpeCBPcmJpdGFsIFByb2R1Y3QgSWQgKi8KI2RlZmluZSBGVERJX01UWE9SQl8xX1BJRCAgICAgIDB4RkEwMSAgLyogTWF0cml4IE9yYml0YWwgUHJvZHVjdCBJZCAqLwojZGVmaW5lIEZURElfTVRYT1JCXzJfUElEICAgICAgMHhGQTAyICAvKiBNYXRyaXggT3JiaXRhbCBQcm9kdWN0IElkICovCiNkZWZpbmUgRlRESV9NVFhPUkJfM19QSUQgICAgICAweEZBMDMgIC8qIE1hdHJpeCBPcmJpdGFsIFByb2R1Y3QgSWQgKi8KI2RlZmluZSBGVERJX01UWE9SQl80X1BJRCAgICAgIDB4RkEwNCAgLyogTWF0cml4IE9yYml0YWwgUHJvZHVjdCBJZCAqLwojZGVmaW5lIEZURElfTVRYT1JCXzVfUElEICAgICAgMHhGQTA1ICAvKiBNYXRyaXggT3JiaXRhbCBQcm9kdWN0IElkICovCiNkZWZpbmUgRlRESV9NVFhPUkJfNl9QSUQgICAgICAweEZBMDYgIC8qIE1hdHJpeCBPcmJpdGFsIFByb2R1Y3QgSWQgKi8KCi8qIEludGVyYmlvbWV0cmljcyBVU0IgSS9PIEJvYXJkICovCi8qIERldmVsb3BlZCBmb3IgSW50ZXJiaW9tZXRyaWNzIGJ5IFJ1ZG9sZiBHdWdsZXIgKi8KI2RlZmluZSBJTlRFUkJJT01FVFJJQ1NfVklEICAgICAgICAgICAgICAweDEyMDkKI2RlZmluZSBJTlRFUkJJT01FVFJJQ1NfSU9CT0FSRF9QSUQgICAgICAweDEwMDIKI2RlZmluZSBJTlRFUkJJT01FVFJJQ1NfTUlOSV9JT0JPQVJEX1BJRCAweDEwMDYKCi8qCiAqIFRoZSBmb2xsb3dpbmcgYXJlIHRoZSB2YWx1ZXMgZm9yIHRoZSBQZXJsZSBTeXN0ZW1zCiAqIFVsdHJhUG9ydCBVU0Igc2VyaWFsIGNvbnZlcnRlcnMKICovCiNkZWZpbmUgRlRESV9QRVJMRV9VTFRSQVBPUlRfUElEIDB4RjBDMAkvKiBQZXJsZSBVbHRyYVBvcnQgUHJvZHVjdCBJZCAqLwoKLyoKICogVGhlIGZvbGxvd2luZyBhcmUgdGhlIHZhbHVlcyBmb3IgdGhlIFNlYWxldmVsIFNlYUxJTksrIGFkYXB0ZXJzLgogKiAoT3JpZ2luYWwgbGlzdCBzZW50IGJ5IFR1YW4gSG9hbmcuICBJYW4gQWJib3R0IHJlbmFtZWQgdGhlIG1hY3JvcyBhbmQKICogcmVtb3ZlZCBzb21lIFBJRHMgdGhhdCBkb24ndCBzZWVtIHRvIG1hdGNoIGFueSBleGlzdGluZyBwcm9kdWN0cy4pCiAqLwojZGVmaW5lIFNFQUxFVkVMX1ZJRAkJMHgwYzUyCS8qIFNlYWxldmVsIFZlbmRvciBJRCAqLwojZGVmaW5lIFNFQUxFVkVMXzIxMDFfUElECTB4MjEwMQkvKiBTZWFMSU5LKzIzMiAoMjEwMS8yMTA1KSAqLwojZGVmaW5lIFNFQUxFVkVMXzIxMDJfUElECTB4MjEwMgkvKiBTZWFMSU5LKzQ4NSAoMjEwMikgKi8KI2RlZmluZSBTRUFMRVZFTF8yMTAzX1BJRAkweDIxMDMJLyogU2VhTElOSysyMzJJICgyMTAzKSAqLwojZGVmaW5lIFNFQUxFVkVMXzIxMDRfUElECTB4MjEwNAkvKiBTZWFMSU5LKzQ4NUkgKDIxMDQpICovCiNkZWZpbmUgU0VBTEVWRUxfMjEwNl9QSUQJMHg5MDIwCS8qIFNlYUxJTksrNDIyICgyMTA2KSAqLwojZGVmaW5lIFNFQUxFVkVMXzIyMDFfMV9QSUQJMHgyMjExCS8qIFNlYVBPUlQrMi8yMzIgKDIyMDEpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzIyMDFfMl9QSUQJMHgyMjIxCS8qIFNlYVBPUlQrMi8yMzIgKDIyMDEpIFBvcnQgMiAqLwojZGVmaW5lIFNFQUxFVkVMXzIyMDJfMV9QSUQJMHgyMjEyCS8qIFNlYVBPUlQrMi80ODUgKDIyMDIpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzIyMDJfMl9QSUQJMHgyMjIyCS8qIFNlYVBPUlQrMi80ODUgKDIyMDIpIFBvcnQgMiAqLwojZGVmaW5lIFNFQUxFVkVMXzIyMDNfMV9QSUQJMHgyMjEzCS8qIFNlYVBPUlQrMiAoMjIwMykgUG9ydCAxICovCiNkZWZpbmUgU0VBTEVWRUxfMjIwM18yX1BJRAkweDIyMjMJLyogU2VhUE9SVCsyICgyMjAzKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAxXzFfUElECTB4MjQxMQkvKiBTZWFQT1JUKzQvMjMyICgyNDAxKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAxXzJfUElECTB4MjQyMQkvKiBTZWFQT1JUKzQvMjMyICgyNDAxKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAxXzNfUElECTB4MjQzMQkvKiBTZWFQT1JUKzQvMjMyICgyNDAxKSBQb3J0IDMgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAxXzRfUElECTB4MjQ0MQkvKiBTZWFQT1JUKzQvMjMyICgyNDAxKSBQb3J0IDQgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAyXzFfUElECTB4MjQxMgkvKiBTZWFQT1JUKzQvNDg1ICgyNDAyKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAyXzJfUElECTB4MjQyMgkvKiBTZWFQT1JUKzQvNDg1ICgyNDAyKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAyXzNfUElECTB4MjQzMgkvKiBTZWFQT1JUKzQvNDg1ICgyNDAyKSBQb3J0IDMgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAyXzRfUElECTB4MjQ0MgkvKiBTZWFQT1JUKzQvNDg1ICgyNDAyKSBQb3J0IDQgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAzXzFfUElECTB4MjQxMwkvKiBTZWFQT1JUKzQgKDI0MDMpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzI0MDNfMl9QSUQJMHgyNDIzCS8qIFNlYVBPUlQrNCAoMjQwMykgUG9ydCAyICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwM18zX1BJRAkweDI0MzMJLyogU2VhUE9SVCs0ICgyNDAzKSBQb3J0IDMgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAzXzRfUElECTB4MjQ0MwkvKiBTZWFQT1JUKzQgKDI0MDMpIFBvcnQgNCAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDFfMV9QSUQJMFgyODExCS8qIFNlYUxJTksrOC8yMzIgKDI4MDEpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDFfMl9QSUQJMFgyODIxCS8qIFNlYUxJTksrOC8yMzIgKDI4MDEpIFBvcnQgMiAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDFfM19QSUQJMFgyODMxCS8qIFNlYUxJTksrOC8yMzIgKDI4MDEpIFBvcnQgMyAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDFfNF9QSUQJMFgyODQxCS8qIFNlYUxJTksrOC8yMzIgKDI4MDEpIFBvcnQgNCAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDFfNV9QSUQJMFgyODUxCS8qIFNlYUxJTksrOC8yMzIgKDI4MDEpIFBvcnQgNSAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDFfNl9QSUQJMFgyODYxCS8qIFNlYUxJTksrOC8yMzIgKDI4MDEpIFBvcnQgNiAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDFfN19QSUQJMFgyODcxCS8qIFNlYUxJTksrOC8yMzIgKDI4MDEpIFBvcnQgNyAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDFfOF9QSUQJMFgyODgxCS8qIFNlYUxJTksrOC8yMzIgKDI4MDEpIFBvcnQgOCAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDJfMV9QSUQJMFgyODEyCS8qIFNlYUxJTksrOC80ODUgKDI4MDIpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDJfMl9QSUQJMFgyODIyCS8qIFNlYUxJTksrOC80ODUgKDI4MDIpIFBvcnQgMiAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDJfM19QSUQJMFgyODMyCS8qIFNlYUxJTksrOC80ODUgKDI4MDIpIFBvcnQgMyAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDJfNF9QSUQJMFgyODQyCS8qIFNlYUxJTksrOC80ODUgKDI4MDIpIFBvcnQgNCAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDJfNV9QSUQJMFgyODUyCS8qIFNlYUxJTksrOC80ODUgKDI4MDIpIFBvcnQgNSAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDJfNl9QSUQJMFgyODYyCS8qIFNlYUxJTksrOC80ODUgKDI4MDIpIFBvcnQgNiAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDJfN19QSUQJMFgyODcyCS8qIFNlYUxJTksrOC80ODUgKDI4MDIpIFBvcnQgNyAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDJfOF9QSUQJMFgyODgyCS8qIFNlYUxJTksrOC80ODUgKDI4MDIpIFBvcnQgOCAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfMV9QSUQJMFgyODEzCS8qIFNlYUxJTksrOCAoMjgwMykgUG9ydCAxICovCiNkZWZpbmUgU0VBTEVWRUxfMjgwM18yX1BJRAkwWDI4MjMgCS8qIFNlYUxJTksrOCAoMjgwMykgUG9ydCAyICovCiNkZWZpbmUgU0VBTEVWRUxfMjgwM18zX1BJRAkwWDI4MzMgCS8qIFNlYUxJTksrOCAoMjgwMykgUG9ydCAzICovCiNkZWZpbmUgU0VBTEVWRUxfMjgwM180X1BJRAkwWDI4NDMgCS8qIFNlYUxJTksrOCAoMjgwMykgUG9ydCA0ICovCiNkZWZpbmUgU0VBTEVWRUxfMjgwM181X1BJRAkwWDI4NTMgCS8qIFNlYUxJTksrOCAoMjgwMykgUG9ydCA1ICovCiNkZWZpbmUgU0VBTEVWRUxfMjgwM182X1BJRAkwWDI4NjMgCS8qIFNlYUxJTksrOCAoMjgwMykgUG9ydCA2ICovCiNkZWZpbmUgU0VBTEVWRUxfMjgwM183X1BJRAkwWDI4NzMgCS8qIFNlYUxJTksrOCAoMjgwMykgUG9ydCA3ICovCiNkZWZpbmUgU0VBTEVWRUxfMjgwM184X1BJRAkwWDI4ODMgCS8qIFNlYUxJTksrOCAoMjgwMykgUG9ydCA4ICovCgovKgogKiBUaGUgZm9sbG93aW5nIGFyZSB0aGUgdmFsdWVzIGZvciB0d28gS09CSUwgY2hpcGNhcmQgdGVybWluYWxzLgogKi8KI2RlZmluZSBLT0JJTF9WSUQJCTB4MGQ0NgkvKiBLT0JJTCBWZW5kb3IgSUQgKi8KI2RlZmluZSBLT0JJTF9DT05WX0IxX1BJRAkweDIwMjAJLyogS09CSUwgS29udmVydGVyIGZvciBCMSAqLwojZGVmaW5lIEtPQklMX0NPTlZfS0FBTl9QSUQJMHgyMDIxCS8qIEtPQklMX0tvbnZlcnRlciBmb3IgS0FBTiAqLwoKLyoKICogSWNvbSBJRC0xIGRpZ2l0YWwgdHJhbnNjZWl2ZXIKICovCgojZGVmaW5lIElDT01fSUQxX1ZJRCAgICAgICAgICAgIDB4MEMyNgojZGVmaW5lIElDT01fSUQxX1BJRCAgICAgICAgICAgIDB4MDAwNAoKLyoKICogQVNLLmZyIGRldmljZXMKICovCiNkZWZpbmUgRlRESV9BU0tfUkRSNDAwX1BJRAkweEM5OTEJLyogQVNLIFJEUiA0MDAgc2VyaWVzIGNhcmQgcmVhZGVyICovCgovKgogKiBGVERJIFVTQiBVQVJUIGNoaXBzIHVzZWQgaW4gY29uc3RydWN0aW9uIHByb2plY3RzIGZyb20gdGhlCiAqIEVsZWt0b3IgRWxlY3Ryb25pY3MgbWFnYXppbmUgKGh0dHA6Ly9lbGVrdG9yLWVsZWN0cm9uaWNzLmNvLnVrKQogKi8KI2RlZmluZSBFTEVLVE9SX1ZJRAkJMHgwQzdECiNkZWZpbmUgRUxFS1RPUl9GVDMyM1JfUElECTB4MDAwNQkvKiBSRklELVJlYWRlciwgaXNzdWUgMDktMjAwNiAqLwoKLyoKICogRFNTLTIwIFN5bmMgU3RhdGlvbiBmb3IgU29ueSBFcmljc3NvbiBQODAwCiAqLwojZGVmaW5lIEZURElfRFNTMjBfUElEICAgICAgICAgIDB4RkM4MiAgCgovKgogKiBIb21lIEVsZWN0cm9uaWNzICh3d3cuaG9tZS1lbGVjdHJvLmNvbSkgVVNCIGdhZGdldHMKICovCiNkZWZpbmUgRlRESV9IRV9USVJBMV9QSUQJMHhGQTc4CS8qIFRpcmEtMSBJUiB0cmFuc2NlaXZlciAqLwoKLyogVVNCLVVJUlQgLSBBbiBpbmZyYXJlZCByZWNlaXZlciBhbmQgdHJhbnNtaXR0ZXIgdXNpbmcgdGhlIDhVMjMyQU0gY2hpcCAqLwovKiBodHRwOi8vaG9tZS5lYXJ0aGxpbmsubmV0L35qcmhlZXMvVVNCVUlSVC9pbmRleC5odG0gKi8KI2RlZmluZSBGVERJX1VTQl9VSVJUX1BJRAkweEY4NTAJLyogUHJvZHVjdCBJZCAqLwoKLyogVE5DLVggVVNCLXRvLXBhY2tldC1yYWRpbyBhZGFwdGVyLCB2ZXJzaW9ucyBwcmlvciB0byAzLjAgKERMUCBtb2R1bGUpICovCgojZGVmaW5lIEZURElfVE5DX1hfUElECQkweEVCRTAKCi8qCiAqIEVMViBVU0IgZGV2aWNlcyBzdWJtaXR0ZWQgYnkgQ2hyaXN0aWFuIEFidCBvZiBFTFYgKHd3dy5lbHYuZGUpLgogKiBBbGwgb2YgdGhlc2UgZGV2aWNlcyB1c2UgRlRESSdzIHZlbmRvciBJRCAoMHgwNDAzKS4KICoKICogVGhlIHByZXZpb3VzbHkgaW5jbHVkZWQgUElEIGZvciB0aGUgVU8gMTAwIG1vZHVsZSB3YXMgaW5jb3JyZWN0LgogKiBJbiBmYWN0LCB0aGF0IFBJRCB3YXMgZm9yIEVMVidzIFVSIDEwMCBVU0ItUlMyMzIgY29udmVydGVyICgweEZCNTgpLgogKgogKiBBcm1pbiBMYWV1Z2VyIG9yaWdpbmFsbHkgc2VudCB0aGUgUElEIGZvciB0aGUgVU0gMTAwIG1vZHVsZS4KICovCiNkZWZpbmUgRlRESV9FTFZfVVIxMDBfUElECTB4RkI1OAkvKiBVU0ItUlMyMzItVW1zZXR6ZXIgKFVSIDEwMCkgKi8KI2RlZmluZSBGVERJX0VMVl9VTTEwMF9QSUQJMHhGQjVBCS8qIFVTQi1Nb2R1bCBVTSAxMDAgKi8KI2RlZmluZSBGVERJX0VMVl9VTzEwMF9QSUQJMHhGQjVCCS8qIFVTQi1Nb2R1bCBVTyAxMDAgKi8KI2RlZmluZSBGVERJX0VMVl9BTEM4NTAwX1BJRAkweEYwNkUJLyogQUxDIDg1MDAgRXhwZXJ0ICovCi8qIEFkZGl0aW9uYWwgRUxWIFBJRHMgdGhhdCBkZWZhdWx0IHRvIHVzaW5nIHRoZSBGVERJIEQyWFggZHJpdmVycyBvbgogKiBNUyBXaW5kb3dzLCByYXRoZXIgdGhhbiB0aGUgRlRESSBWaXJ0dWFsIENvbSBQb3J0IGRyaXZlcnMuCiAqIE1heWJlIHRoZXNlIHdpbGwgYmUgZWFzaWVyIHRvIHVzZSB3aXRoIHRoZSBsaWJmdGRpL2xpYnVzYiB1c2VyLXNwYWNlCiAqIGRyaXZlcnMsIG9yIHBvc3NpYmx5IHRoZSBDb21lZGkgZHJpdmVycyBpbiBzb21lIGNhc2VzLiAqLwojZGVmaW5lIEZURElfRUxWX0NMSTcwMDBfUElECTB4RkI1OQkvKiBDb21wdXRlci1MaWdodC1JbnRlcmZhY2UgKENMSSA3MDAwKSAqLwojZGVmaW5lIEZURElfRUxWX1BQUzczMzBfUElECTB4RkI1QwkvKiBQcm9jZXNzb3ItUG93ZXItU3VwcGx5IChQUFMgNzMzMCkgKi8KI2RlZmluZSBGVERJX0VMVl9URk0xMDBfUElECTB4RkI1RAkvKiBUZW1wZXJhcnR1ci1GZXVjaHRlIE1lc3NnZXJhZXQgKFRGTSAxMDApICovCiNkZWZpbmUgRlRESV9FTFZfVURGNzdfUElECTB4RkI1RQkvKiBVU0IgRENGIEZ1bmt1cmggKFVERiA3NykgKi8KI2RlZmluZSBGVERJX0VMVl9VSU84OF9QSUQJMHhGQjVGCS8qIFVTQi1JL08gSW50ZXJmYWNlIChVSU8gODgpICovCiNkZWZpbmUgRlRESV9FTFZfVUFEOF9QSUQJMHhGMDY4CS8qIFVTQi1BRC1XYW5kbGVyIChVQUQgOCkgKi8KI2RlZmluZSBGVERJX0VMVl9VREE3X1BJRAkweEYwNjkJLyogVVNCLURBLVdhbmRsZXIgKFVEQSA3KSAqLwojZGVmaW5lIEZURElfRUxWX1VTSTJfUElECTB4RjA2QQkvKiBVU0ItU2Nocml0dG1vdG9yZW4tSW50ZXJmYWNlIChVU0kgMikgKi8KI2RlZmluZSBGVERJX0VMVl9UMTEwMF9QSUQJMHhGMDZCCS8qIFRoZXJtb21ldGVyIChUIDExMDApICovCiNkZWZpbmUgRlRESV9FTFZfUENEMjAwX1BJRAkweEYwNkMJLyogUEMtRGF0ZW5sb2dnZXIgKFBDRCAyMDApICovCiNkZWZpbmUgRlRESV9FTFZfVUxBMjAwX1BJRAkweEYwNkQJLyogVVNCLUxDRC1BbnN0ZXVlcnVuZyAoVUxBIDIwMCkgKi8KI2RlZmluZSBGVERJX0VMVl9GSFoxMDAwUENfUElECTB4RjA2RgkvKiBGSFogMTAwMCBQQyAqLwojZGVmaW5lIEZURElfRUxWX0NTSThfUElECTB4RTBGMAkvKiBDb21wdXRlci1TY2hhbHQtSW50ZXJmYWNlIChDU0kgOCkgKi8KI2RlZmluZSBGVERJX0VMVl9FTTEwMDBETF9QSUQJMHhFMEYxCS8qIFBDLURhdGVubG9nZ2VyIGZ1ZXIgRW5lcmdpZW1vbml0b3IgKEVNIDEwMDAgREwpICovCiNkZWZpbmUgRlRESV9FTFZfUENLMTAwX1BJRAkweEUwRjIJLyogUEMtS2FiZWx0ZXN0ZXIgKFBDSyAxMDApICovCiNkZWZpbmUgRlRESV9FTFZfUkZQNTAwX1BJRAkweEUwRjMJLyogSEYtTGVpc3R1bmdzbWVzc2VyIChSRlAgNTAwKSAqLwojZGVmaW5lIEZURElfRUxWX0ZTMjBTSUdfUElECTB4RTBGNAkvKiBTaWduYWxnZWJlciAoRlMgMjAgU0lHKSAqLwojZGVmaW5lIEZURElfRUxWX1dTMzAwUENfUElECTB4RTBGNgkvKiBQQy1XZXR0ZXJzdGF0aW9uIChXUyAzMDAgUEMpICovCiNkZWZpbmUgRlRESV9FTFZfRkhaMTMwMFBDX1BJRAkweEUwRTgJLyogRkhaIDEzMDAgUEMgKi8KI2RlZmluZSBGVERJX0VMVl9XUzUwMF9QSUQJMHhFMEU5CS8qIFBDLVdldHRlcnN0YXRpb24gKFdTIDUwMCkgKi8KCi8qCiAqIERlZmluaXRpb25zIGZvciBJRCBURUNIICh3d3cuaWR0LW5ldC5jb20pIGRldmljZXMKICovCiNkZWZpbmUgSURURUNIX1ZJRAkJMHgwQUNECS8qIElEIFRFQ0ggVmVuZG9yIElEICovCiNkZWZpbmUgSURURUNIX0lEVDEyMjFVX1BJRAkweDAzMDAJLyogSURUMTIyMVUgVVNCIHRvIFJTLTIzMiBhZGFwdGVyICovCgovKgogKiBEZWZpbml0aW9ucyBmb3IgT21uaWRpcmVjdGlvbmFsIENvbnRyb2wgVGVjaG5vbG9neSwgSW5jLiBkZXZpY2VzCiAqLwojZGVmaW5lIE9DVF9WSUQJCQkweDBCMzkJLyogT0NUIHZlbmRvciBJRCAqLwovKiBOb3RlOiBPQ1QgVVMxMDEgaXMgYWxzbyByZWJhZGdlZCBhcyBEaWNrIFNtaXRoIEVsZWN0cm9uaWNzIChOWikgWEg2MzgxICovCi8qIEFsc28gcmViYWRnZWQgYXMgRGljayBTbWl0aCBFbGVjdHJvbmljcyAoQXVzKSBYSDY0NTEgKi8KLyogQWxzbyByZWJhZGdlZCBhcyBTSUlHIEluYy4gbW9kZWwgVVMyMzA4IGhhcmR3YXJlIHZlcnNpb24gMSAqLwojZGVmaW5lIE9DVF9VUzEwMV9QSUQJCTB4MDQyMQkvKiBPQ1QgVVMxMDEgVVNCIHRvIFJTLTIzMiAqLwoKLyogYW4gaW5mcmFyZWQgcmVjZWl2ZXIgZm9yIHVzZXIgYWNjZXNzIGNvbnRyb2wgd2l0aCBJUiB0YWdzICovCiNkZWZpbmUgRlRESV9QSUVHUk9VUF9QSUQJMHhGMjA4CS8qIFByb2R1Y3QgSWQgKi8KCi8qCiAqIERlZmluaXRpb25zIGZvciBBcnRlbWlzIGFzdHJvbm9taWNhbCBVU0IgYmFzZWQgY2FtZXJhcwogKiBDaGVjayBpdCBhdCBodHRwOi8vd3d3LmFydGVtaXNjY2QuY28udWsvCiAqLwojZGVmaW5lIEZURElfQVJURU1JU19QSUQJMHhERjI4CS8qIEFsbCBBcnRlbWlzIENhbWVyYXMgKi8KCi8qCiAqIERlZmluaXRpb25zIGZvciBBVElLIEluc3RydW1lbnRzIGFzdHJvbm9taWNhbCBVU0IgYmFzZWQgY2FtZXJhcwogKiBDaGVjayBpdCBhdCBodHRwOi8vd3d3LmF0aWstaW5zdHJ1bWVudHMuY29tLwogKi8KI2RlZmluZSBGVERJX0FUSUtfQVRLMTZfUElECTB4REYzMAkvKiBBVElLIEFUSy0xNiBHcmF5c2NhbGUgQ2FtZXJhICovCiNkZWZpbmUgRlRESV9BVElLX0FUSzE2Q19QSUQJMHhERjMyCS8qIEFUSUsgQVRLLTE2QyBDb2xvdXIgQ2FtZXJhICovCiNkZWZpbmUgRlRESV9BVElLX0FUSzE2SFJfUElECTB4REYzMQkvKiBBVElLIEFUSy0xNkhSIEdyYXlzY2FsZSBDYW1lcmEgKi8KI2RlZmluZSBGVERJX0FUSUtfQVRLMTZIUkNfUElECTB4REYzMwkvKiBBVElLIEFUSy0xNkhSQyBDb2xvdXIgQ2FtZXJhICovCgovKgogKiBQcm90ZWdvIHByb2R1Y3QgaWRzCiAqLwojZGVmaW5lIFBST1RFR09fU1BFQ0lBTF8xCTB4RkM3MAkvKiBzcGVjaWFsL3Vua25vd24gZGV2aWNlICovCiNkZWZpbmUgUFJPVEVHT19SMlgwCQkweEZDNzEJLyogUjIwMC1VU0IgVFJORyB1bml0IChSMjEwLCBSMjIwLCBhbmQgUjIzMCkgKi8KI2RlZmluZSBQUk9URUdPX1NQRUNJQUxfMwkweEZDNzIJLyogc3BlY2lhbC91bmtub3duIGRldmljZSAqLwojZGVmaW5lIFBST1RFR09fU1BFQ0lBTF80CTB4RkM3MwkvKiBzcGVjaWFsL3Vua25vd24gZGV2aWNlICovCgovKgogKiBHdWRlIEFuYWxvZy0gdW5kIERpZ2l0YWxzeXN0ZW1lIEdtYkgKICovCiNkZWZpbmUgRlRESV9HVURFQURTX0U4MDhfUElEICAgIDB4RTgwOAojZGVmaW5lIEZURElfR1VERUFEU19FODA5X1BJRCAgICAweEU4MDkKI2RlZmluZSBGVERJX0dVREVBRFNfRTgwQV9QSUQgICAgMHhFODBBCiNkZWZpbmUgRlRESV9HVURFQURTX0U4MEJfUElEICAgIDB4RTgwQgojZGVmaW5lIEZURElfR1VERUFEU19FODBDX1BJRCAgICAweEU4MEMKI2RlZmluZSBGVERJX0dVREVBRFNfRTgwRF9QSUQgICAgMHhFODBECiNkZWZpbmUgRlRESV9HVURFQURTX0U4MEVfUElEICAgIDB4RTgwRQojZGVmaW5lIEZURElfR1VERUFEU19FODBGX1BJRCAgICAweEU4MEYKI2RlZmluZSBGVERJX0dVREVBRFNfRTg4OF9QSUQgICAgMHhFODg4ICAvKiBFeHBlcnQgSVNETiBDb250cm9sIFVTQiAqLwojZGVmaW5lIEZURElfR1VERUFEU19FODg5X1BJRCAgICAweEU4ODkgIC8qIFVTQiBSUy0yMzIgT3B0b0JyaWRnZSAqLwojZGVmaW5lIEZURElfR1VERUFEU19FODhBX1BJRCAgICAweEU4OEEKI2RlZmluZSBGVERJX0dVREVBRFNfRTg4Ql9QSUQgICAgMHhFODhCCiNkZWZpbmUgRlRESV9HVURFQURTX0U4OENfUElEICAgIDB4RTg4QwojZGVmaW5lIEZURElfR1VERUFEU19FODhEX1BJRCAgICAweEU4OEQKI2RlZmluZSBGVERJX0dVREVBRFNfRTg4RV9QSUQgICAgMHhFODhFCiNkZWZpbmUgRlRESV9HVURFQURTX0U4OEZfUElEICAgIDB4RTg4RgoKLyoKICogTGlueCBUZWNobm9sb2dpZXMgcHJvZHVjdCBpZHMKICovCiNkZWZpbmUgTElOWF9TRE1VU0JRU1NfUElECTB4RjQ0OAkvKiBMaW54IFNETS1VU0ItUVMtUyAqLwojZGVmaW5lIExJTlhfTUFTVEVSREVWRUwyX1BJRCAgIDB4RjQ0OSAgIC8qIExpbnggTWFzdGVyIERldmVsb3BtZW50IDIuMCAqLwojZGVmaW5lIExJTlhfRlVUVVJFXzBfUElEICAgMHhGNDRBICAgLyogTGlueCBmdXR1cmUgZGV2aWNlICovCiNkZWZpbmUgTElOWF9GVVRVUkVfMV9QSUQgICAweEY0NEIgICAvKiBMaW54IGZ1dHVyZSBkZXZpY2UgKi8KI2RlZmluZSBMSU5YX0ZVVFVSRV8yX1BJRCAgIDB4RjQ0QyAgIC8qIExpbnggZnV0dXJlIGRldmljZSAqLwoKLyogQ0NTIEluYy4gSUNEVS9JQ0RVNDAgcHJvZHVjdCBJRCAtIHRoZSBGVDIzMkJNIGlzIHVzZWQgaW4gYW4gaW4tY2lyY3VpdC1kZWJ1Z2dlciAqLwovKiB1bml0IGZvciBQSUMxNidzL1BJQzE4J3MgKi8KI2RlZmluZSBGVERJX0NDU0lDRFUyMF8wX1BJRCAgICAweEY5RDAKI2RlZmluZSBGVERJX0NDU0lDRFU0MF8xX1BJRCAgICAweEY5RDEKI2RlZmluZSBGVERJX0NDU01BQ0hYXzJfUElEICAgICAweEY5RDIKCi8qIEluc2lkZSBBY2Nlc3NvIGNvbnRhY3RsZXNzIHJlYWRlciAoaHR0cDovL3d3dy5pbnNpZGVmci5jb20pICovCiNkZWZpbmUgSU5TSURFX0FDQ0VTU08JCTB4RkFEMAoKLyoKICogSW50cmVwaWQgQ29udHJvbCBTeXN0ZW1zIChodHRwOi8vd3d3LmludHJlcGlkY3MuY29tLykgVmFsdWVDQU4gYW5kIE5lb1ZJCiAqLwojZGVmaW5lIElOVFJFUElEX1ZJRAkJMHgwOTNDCiNkZWZpbmUgSU5UUkVQSURfVkFMVUVDQU5fUElECTB4MDYwMQojZGVmaW5lIElOVFJFUElEX05FT1ZJX1BJRAkweDA3MDEKCi8qCiAqIEZhbGNvbSBXaXJlbGVzcyBDb21tdW5pY2F0aW9ucyBHbWJICiAqLwojZGVmaW5lIEZBTENPTV9WSUQJCTB4MEY5NAkvKiBWZW5kb3IgSWQgKi8KI2RlZmluZSBGQUxDT01fVFdJU1RfUElECTB4MDAwMQkvKiBGYWxjb20gVHdpc3QgVVNCIEdQUlMgbW9kZW0gKi8KI2RlZmluZSBGQUxDT01fU0FNQkFfUElECTB4MDAwNQkvKiBGYWxjb20gU2FtYmEgVVNCIEdQUlMgbW9kZW0gKi8KCi8qCiAqIFNVVU5UTyBwcm9kdWN0IGlkcwogKi8KI2RlZmluZSBGVERJX1NVVU5UT19TUE9SVFNfUElECTB4RjY4MAkvKiBTdXVudG8gU3BvcnRzIGluc3RydW1lbnQgKi8KCi8qCiAqIFRUaSAoVGh1cmxieSBUaGFuZGFyIEluc3RydW1lbnRzKQogKi8KI2RlZmluZSBUVElfVklECQkJMHgxMDNFCS8qIFZlbmRvciBJZCAqLwojZGVmaW5lIFRUSV9RTDM1NVBfUElECQkweDAzRTgJLyogVFRpIFFMMzU1UCBwb3dlciBzdXBwbHkgKi8KCi8qCiAqIERlZmluaXRpb25zIGZvciBCJkIgRWxlY3Ryb25pY3MgcHJvZHVjdHMuCiAqLwojZGVmaW5lIEJBTkRCX1ZJRAkJMHgwODU2CS8qIEImQiBFbGVjdHJvbmljcyBWZW5kb3IgSUQgKi8KI2RlZmluZSBCQU5EQl9VU09UTDRfUElECTB4QUMwMQkvKiBVU09UTDQgSXNvbGF0ZWQgUlMtNDg1IENvbnZlcnRlciAqLwojZGVmaW5lIEJBTkRCX1VTVEw0X1BJRAkJMHhBQzAyCS8qIFVTVEw0IFJTLTQ4NSBDb252ZXJ0ZXIgKi8KI2RlZmluZSBCQU5EQl9VU085TUwyX1BJRAkweEFDMDMJLyogVVNPOU1MMiBJc29sYXRlZCBSUy0yMzIgQ29udmVydGVyICovCgovKgogKiBSTSBNaWNoYWVsaWRlcyBDQU52aWV3IFVTQiAoaHR0cDovL3d3dy5ybWNhbi5jb20pCiAqIENBTiBmaWVsZGJ1cyBpbnRlcmZhY2UgYWRhcHRlciwgYWRkZWQgYnkgcG9ydCBHbWJIIHd3dy5wb3J0LmRlKQogKiBJYW4gQWJib3R0IGNoYW5nZWQgdGhlIG1hY3JvIG5hbWVzIGZvciBjb25zaXN0ZW5jeS4KICovCiNkZWZpbmUgRlRESV9STV9DQU5WSUVXX1BJRAkweGZkNjAJLyogUHJvZHVjdCBJZCAqLwoKLyoKICogRVZFUiBFY28gUHJvIFVQUyAoaHR0cDovL3d3dy5ldmVyLmNvbS5wbC8pCiAqLwoKI2RlZmluZQlFVkVSX0VDT19QUk9fQ0RTCTB4ZTUyMAkvKiBSUy0yMzIgY29udmVydGVyICovCgovKgogKiA0Ti1HQUxBWFkuREUgUElEcyBmb3IgQ0FOLVVTQiwgVVNCLVJTMjMyLCBVU0ItUlM0MjIsIFVTQi1SUzQ4NSwKICogVVNCLVRUWSBhY3RpdiwgVVNCLVRUWSBwYXNzaXYuICBTb21lIFBJRHMgYXJlIHVzZWQgYnkgc2V2ZXJhbCBkZXZpY2VzCiAqIGFuZCBJJ20gbm90IGVudGlyZWx5IHN1cmUgd2hpY2ggYXJlIHVzZWQgYnkgd2hpY2guCiAqLwojZGVmaW5lIEZURElfNE5fR0FMQVhZX0RFXzFfUElECTB4RjNDMAojZGVmaW5lIEZURElfNE5fR0FMQVhZX0RFXzJfUElECTB4RjNDMQoKLyoKICogTW9iaWxpdHkgRWxlY3Ryb25pY3MgcHJvZHVjdHMuCiAqLwojZGVmaW5lIE1PQklMSVRZX1ZJRAkJCTB4MTM0MgojZGVmaW5lIE1PQklMSVRZX1VTQl9TRVJJQUxfUElECQkweDAyMDIJLyogRWFzaURvY2sgVVNCIDIwMCBzZXJpYWwgKi8KCi8qCiAqIG1pY3JvSEFNIHByb2R1Y3QgSURzIChodHRwOi8vd3d3Lm1pY3JvaGFtLmNvbSkuCiAqIFN1Ym1pdHRlZCBieSBKdXN0aW4gQnVya2V0IChLTDFSTCkgPHpvcnRvbkBqdGFuLmNvbT4KICogYW5kIE1pa2UgU3R1ZGVyIChLNkVFUCkgPGs2ZWVwQGhhbXNvZnR3YXJlLm9yZz4uCiAqIElhbiBBYmJvdHQgPGFiYm90dGlAbWV2LmNvLnVrPiBhZGRlZCBhIGZldyBtb3JlIGZyb20gdGhlIGRyaXZlciBJTkYgZmlsZS4KICovCiNkZWZpbmUgRlRESV9NSEFNX0tXX1BJRCAweEVFRTgJCS8qIFVTQi1LVyBpbnRlcmZhY2UgKi8KI2RlZmluZSBGVERJX01IQU1fWVNfUElEIDB4RUVFOQkJLyogVVNCLVlTIGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9ZNl9QSUQgMHhFRUVBCQkvKiBVU0ItWTYgaW50ZXJmYWNlICovCiNkZWZpbmUgRlRESV9NSEFNX1k4X1BJRCAweEVFRUIJCS8qIFVTQi1ZOCBpbnRlcmZhY2UgKi8KI2RlZmluZSBGVERJX01IQU1fSUNfUElEIDB4RUVFQwkJLyogVVNCLUlDIGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9EQjlfUElEIDB4RUVFRAkvKiBVU0ItREI5IGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9SUzIzMl9QSUQgMHhFRUVFCS8qIFVTQi1SUzIzMiBpbnRlcmZhY2UgKi8KI2RlZmluZSBGVERJX01IQU1fWTlfUElEIDB4RUVFRgkJLyogVVNCLVk5IGludGVyZmFjZSAqLwoKLyoKICogQWN0aXZlIFJvYm90cyBwcm9kdWN0IGlkcy4KICovCiNkZWZpbmUgRlRESV9BQ1RJVkVfUk9CT1RTX1BJRAkweEU1NDgJLyogVVNCIGNvbW1zIGJvYXJkICovCgovKgogKiBYc2VucyBUZWNobm9sb2dpZXMgQlYgcHJvZHVjdHMgKGh0dHA6Ly93d3cueHNlbnMuY29tKS4KICovCiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzBfUElECTB4RDM4OAojZGVmaW5lIFhTRU5TX0NPTlZFUlRFUl8xX1BJRAkweEQzODkKI2RlZmluZSBYU0VOU19DT05WRVJURVJfMl9QSUQJMHhEMzhBCiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzNfUElECTB4RDM4QgojZGVmaW5lIFhTRU5TX0NPTlZFUlRFUl80X1BJRAkweEQzOEMKI2RlZmluZSBYU0VOU19DT05WRVJURVJfNV9QSUQJMHhEMzhECiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzZfUElECTB4RDM4RQojZGVmaW5lIFhTRU5TX0NPTlZFUlRFUl83X1BJRAkweEQzOEYKCi8qCiAqIFRlcmF0cm9uaWsgcHJvZHVjdCBpZHMuCiAqIFN1Ym1pdHRlZCBieSBPLiBX9mxmZWxzY2huZWlkZXIuCiAqLwojZGVmaW5lIEZURElfVEVSQVRST05JS19WQ1BfUElECSAweEVDODgJLyogVGVyYXRyb25payBkZXZpY2UgKHByZWZlcnJpbmcgVkNQIGRyaXZlciBvbiB3aW5kb3dzKSAqLwojZGVmaW5lIEZURElfVEVSQVRST05JS19EMlhYX1BJRCAweEVDODkJLyogVGVyYXRyb25payBkZXZpY2UgKHByZWZlcnJpbmcgRDJYWCBkcml2ZXIgb24gd2luZG93cykgKi8KCi8qCiAqIEV2b2x1dGlvbiBSb2JvdGljcyBwcm9kdWN0cyAoaHR0cDovL3d3dy5ldm9sdXRpb24uY29tLykuCiAqIFN1Ym1pdHRlZCBieSBTaGF3biBNLiBMYXZlbGxlLgogKi8KI2RlZmluZSBFVk9MVVRJT05fVklECQkweERFRUUJLyogVmVuZG9yIElEICovCiNkZWZpbmUgRVZPTFVUSU9OX0VSMV9QSUQJMHgwMzAwCS8qIEVSMSBDb250cm9sIE1vZHVsZSAqLwoKLyogUHlyYW1pZCBDb21wdXRlciBHbWJIICovCiNkZWZpbmUgRlRESV9QWVJBTUlEX1BJRAkweEU2QzgJLyogUHlyYW1pZCBBcHBsaWFuY2UgRGlzcGxheSAqLwoKLyoKICogUG9zaWZsZXggaW5jIHJldGFpbCBlcXVpcG1lbnQgKGh0dHA6Ly93d3cucG9zaWZsZXguY29tLnR3KQogKi8KI2RlZmluZSBQT1NJRkxFWF9WSUQJCTB4MGQzYSAgLyogVmVuZG9yIElEICovCiNkZWZpbmUgUE9TSUZMRVhfUFA3MDAwX1BJRAkweDAzMDAgIC8qIFBQLTcwMDBJSSB0aGVybWFsIHByaW50ZXIgKi8KCi8qCiAqIFdlc3RyZXggSW50ZXJuYXRpb25hbCBkZXZpY2VzIHN1Ym1pdHRlZCBieSBDb3J5IExlZQogKi8KI2RlZmluZSBGVERJX1dFU1RSRVhfTU9ERUxfNzc3X1BJRAkweERDMDAJLyogTW9kZWwgNzc3ICovCiNkZWZpbmUgRlRESV9XRVNUUkVYX01PREVMXzg5MDBGX1BJRAkweERDMDEJLyogTW9kZWwgODkwMEYgKi8KCi8qCiAqIFJSLUNpcktpdHMgTG9jb0J1ZmZlciBVU0IgKGh0dHA6Ly93d3cucnItY2lya2l0cy5jb20pCiAqLwojZGVmaW5lIEZURElfUlJDSVJLSVRTX0xPQ09CVUZGRVJfUElECTB4YzdkMAkvKiBMb2NvQnVmZmVyIFVTQiAqLwoKLyoKICogRWNsbyAoaHR0cDovL3d3dy5lY2xvLnB0LykgcHJvZHVjdCBJRHMuCiAqIFBJRCAweEVBOTAgc3VibWl0dGVkIGJ5IE1hcnRpbiBHcmlsbC4KICovCiNkZWZpbmUgRlRESV9FQ0xPX0NPTV8xV0lSRV9QSUQJMHhFQTkwCS8qIENPTSB0byAxLVdpcmUgVVNCIGFkYXB0b3IgKi8KCi8qCiAqIFBhcG91Y2ggcHJvZHVjdHMgKGh0dHA6Ly93d3cucGFwb3VjaC5jb20vKQogKiBTdWJtaXR0ZWQgYnkgRm9sa2VydCB2YW4gSGV1c2RlbgogKi8KCiNkZWZpbmUgUEFQT1VDSF9WSUQJCQkweDUwNTAJLyogVmVuZG9yIElEICovCiNkZWZpbmUgUEFQT1VDSF9UTVVfUElECQkJMHgwNDAwCS8qIFRNVSBVU0IgVGhlcm1vbWV0ZXIgKi8KCi8qCiAqIEFDRyBJZGVudGlmaWNhdGlvbiBUZWNobm9sb2dpZXMgR21iSCBwcm9kdWN0cyAoaHR0cDovL3d3dy5hY2cuZGUvKS4KICogU3VibWl0dGVkIGJ5IGFudG9uIC1hdC0gZ290bzEwIC1kb3QtIG9yZy4KICovCiNkZWZpbmUgRlRESV9BQ0dfSEZEVUFMX1BJRAkJMHhERDIwCS8qIEhGIER1YWwgSVNPIFJlYWRlciAoUkZJRCkgKi8KCi8qCiAqIFlvc3QgRW5naW5lZXJpbmcsIEluYy4gcHJvZHVjdHMgKHd3dy55b3N0ZW5naW5lZXJpbmcuY29tKS4KICogUElEIDB4RTA1MCBzdWJtaXR0ZWQgYnkgQWFyb24gUHJvc2UuCiAqLwojZGVmaW5lIEZURElfWUVJX1NFUlZPQ0VOVEVSMzFfUElECTB4RTA1MAkvKiBZRUkgU2Vydm9DZW50ZXIzLjEgVVNCICovCgovKgogKiBUaG9yTGFicyBVU0IgbW90b3IgZHJpdmVycwogKi8KI2RlZmluZSBGVERJX1RIT1JMQUJTX1BJRAkJMHhmYWYwIC8qIFRob3JMYWJzIFVTQiBtb3RvciBkcml2ZXJzICovCgovKgogKiBUZXN0byBwcm9kdWN0cyAoaHR0cDovL3d3dy50ZXN0by5jb20vKQogKiBTdWJtaXR0ZWQgYnkgQ29saW4gTGVyb3kKICovCiNkZWZpbmUgVEVTVE9fVklECQkJMHgxMjhECiNkZWZpbmUgVEVTVE9fVVNCX0lOVEVSRkFDRV9QSUQJCTB4MDAwMQoKLyoKICogR2FtbWEgU2NvdXQgKGh0dHA6Ly9nYW1tYS1zY291dC5jb20vKS4gU3VibWl0dGVkIGJ5IHJzY0BydW50dXguY29tLgogKi8KI2RlZmluZSBGVERJX0dBTU1BX1NDT1VUX1BJRAkJMHhENjc4CS8qIEdhbW1hIFNjb3V0IG9ubGluZSAqLwoKLyoKICogVGFjdHJpeCBPcGVuUG9ydCAoRUNVKSBkZXZpY2VzLgogKiBPcGVuUG9ydCAxLjNNIHN1Ym1pdHRlZCBieSBEb25vdXIgU2l6ZW1vcmUuCiAqIE9wZW5Qb3J0IDEuM1MgYW5kIDEuM1Ugc3VibWl0dGVkIGJ5IElhbiBBYmJvdHQuCiAqLwojZGVmaW5lIEZURElfVEFDVFJJWF9PUEVOUE9SVF8xM01fUElECTB4Q0M0OAkvKiBPcGVuUG9ydCAxLjMgTWl0c3ViaXNoaSAqLwojZGVmaW5lIEZURElfVEFDVFJJWF9PUEVOUE9SVF8xM1NfUElECTB4Q0M0OQkvKiBPcGVuUG9ydCAxLjMgU3ViYXJ1ICovCiNkZWZpbmUgRlRESV9UQUNUUklYX09QRU5QT1JUXzEzVV9QSUQJMHhDQzRBCS8qIE9wZW5Qb3J0IDEuMyBVbml2ZXJzYWwgKi8KCi8qCiAqIFRlbGxkdXMgVGVjaG5vbG9naWVzCiAqLwojZGVmaW5lIFRFTExEVVNfVklECQkJMHgxNzgxCS8qIFZlbmRvciBJRCAqLwojZGVmaW5lIFRFTExEVVNfVEVMTFNUSUNLX1BJRAkJMHgwQzMwCS8qIFJGIGNvbnRyb2wgZG9uZ2xlIDQzMyBNSHogdXNpbmcgRlQyMzJSTCAqLwoKLyoKICogSUJTIGVsZWt0cm9uaWsgcHJvZHVjdCBpZHMKICogU3VibWl0dGVkIGJ5IFRob21hcyBTY2hsZXVzZW5lcgogKi8KI2RlZmluZSBGVERJX0lCU19VUzQ4NV9QSUQJMHhmZjM4ICAvKiBJQlMgVVM0ODUgKFVTQjwtLT5SUzQyMi80ODUgaW50ZXJmYWNlKSAqLwojZGVmaW5lIEZURElfSUJTX1BJQ1BST19QSUQJMHhmZjM5ICAvKiBJQlMgUElDLVByb2dyYW1tZXIgKi8KI2RlZmluZSBGVERJX0lCU19QQ01DSUFfUElECTB4ZmYzYSAgLyogSUJTIENhcmQgcmVhZGVyIGZvciBQQ01DSUEgU1JBTS1jYXJkcyAqLwojZGVmaW5lIEZURElfSUJTX1BLMV9QSUQJMHhmZjNiICAvKiBJQlMgUEsxIC0gUGFydGljZWwgY291bnRlciAqLwojZGVmaW5lIEZURElfSUJTX1JTMjMyTU9OX1BJRAkweGZmM2MgIC8qIElCUyBSUzIzMiAtIE1vbml0b3IgKi8KI2RlZmluZSBGVERJX0lCU19BUFA3MF9QSUQJMHhmZjNkICAvKiBBUFAgNzAgKGR1c3QgbW9uaXRvcmluZyBzeXN0ZW0pICovCiNkZWZpbmUgRlRESV9JQlNfUEVET19QSUQJMHhmZjNlICAvKiBJQlMgUEVETy1Nb2RlbSAoUkYgbW9kZW0gODY4LjM1IE1IeikgKi8KI2RlZmluZSBGVERJX0lCU19QUk9EX1BJRAkweGZmM2YgIC8qIGZ1dHVyZSBkZXZpY2UgKi8KCi8qIENvbW1hbmRzICovCiNkZWZpbmUgRlRESV9TSU9fUkVTRVQgCQkwIC8qIFJlc2V0IHRoZSBwb3J0ICovCiNkZWZpbmUgRlRESV9TSU9fTU9ERU1fQ1RSTCAJMSAvKiBTZXQgdGhlIG1vZGVtIGNvbnRyb2wgcmVnaXN0ZXIgKi8KI2RlZmluZSBGVERJX1NJT19TRVRfRkxPV19DVFJMCTIgLyogU2V0IGZsb3cgY29udHJvbCByZWdpc3RlciAqLwojZGVmaW5lIEZURElfU0lPX1NFVF9CQVVEX1JBVEUJMyAvKiBTZXQgYmF1ZCByYXRlICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEEJNCAvKiBTZXQgdGhlIGRhdGEgY2hhcmFjdGVyaXN0aWNzIG9mIHRoZSBwb3J0ICovCiNkZWZpbmUgRlRESV9TSU9fR0VUX01PREVNX1NUQVRVUwk1IC8qIFJldHJpZXZlIGN1cnJlbnQgdmFsdWUgb2YgbW9kZXJuIHN0YXR1cyByZWdpc3RlciAqLwojZGVmaW5lIEZURElfU0lPX1NFVF9FVkVOVF9DSEFSCTYgLyogU2V0IHRoZSBldmVudCBjaGFyYWN0ZXIgKi8KI2RlZmluZSBGVERJX1NJT19TRVRfRVJST1JfQ0hBUgk3IC8qIFNldCB0aGUgZXJyb3IgY2hhcmFjdGVyICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVIJOSAvKiBTZXQgdGhlIGxhdGVuY3kgdGltZXIgKi8KI2RlZmluZSBGVERJX1NJT19HRVRfTEFURU5DWV9USU1FUgkxMCAvKiBHZXQgdGhlIGxhdGVuY3kgdGltZXIgKi8KCgovKgogKiAgIEJtUmVxdWVzdFR5cGU6ICAxMTAwIDAwMDBiCiAqICAgYlJlcXVlc3Q6ICAgICAgIEZURElfRTJfUkVBRAogKiAgIHdWYWx1ZTogICAgICAgICAwCiAqICAgd0luZGV4OiAgICAgICAgIEFkZHJlc3Mgb2Ygd29yZCB0byByZWFkCiAqICAgd0xlbmd0aDogICAgICAgIDIKICogICBEYXRhOiAgICAgICAgICAgV2lsbCByZXR1cm4gYSB3b3JkIG9mIGRhdGEgZnJvbSBFMkFkZHJlc3MKICoKICovCgovKiBQb3J0IElkZW50aWZpZXIgVGFibGUgKi8KI2RlZmluZSBQSVRfREVGQVVMVCAJCTAgLyogU0lPQSAqLwojZGVmaW5lIFBJVF9TSU9BCQkxIC8qIFNJT0EgKi8KLyogVGhlIGRldmljZSB0aGlzIGRyaXZlciBpcyB0ZXN0ZWQgd2l0aCBvbmUgaGFzIG9ubHkgb25lIHBvcnQgKi8KI2RlZmluZSBQSVRfU0lPQgkJMiAvKiBTSU9CICovCiNkZWZpbmUgUElUX1BBUkFMTEVMCQkzIC8qIFBhcmFsbGVsICovCgovKiBGVERJX1NJT19SRVNFVCAqLwojZGVmaW5lIEZURElfU0lPX1JFU0VUX1JFUVVFU1QgRlRESV9TSU9fUkVTRVQKI2RlZmluZSBGVERJX1NJT19SRVNFVF9SRVFVRVNUX1RZUEUgMHg0MAojZGVmaW5lIEZURElfU0lPX1JFU0VUX1NJTyAwCiNkZWZpbmUgRlRESV9TSU9fUkVTRVRfUFVSR0VfUlggMQojZGVmaW5lIEZURElfU0lPX1JFU0VUX1BVUkdFX1RYIDIKCi8qCiAqIEJtUmVxdWVzdFR5cGU6ICAwMTAwIDAwMDBCCiAqIGJSZXF1ZXN0OiAgICAgICBGVERJX1NJT19SRVNFVAogKiB3VmFsdWU6ICAgICAgICAgQ29udHJvbCBWYWx1ZSAKICogICAgICAgICAgICAgICAgICAgMCA9IFJlc2V0IFNJTwogKiAgICAgICAgICAgICAgICAgICAxID0gUHVyZ2UgUlggYnVmZmVyCiAqICAgICAgICAgICAgICAgICAgIDIgPSBQdXJnZSBUWCBidWZmZXIKICogd0luZGV4OiAgICAgICAgIFBvcnQKICogd0xlbmd0aDogICAgICAgIDAKICogRGF0YTogICAgICAgICAgIE5vbmUKICoKICogVGhlIFJlc2V0IFNJTyBjb21tYW5kIGhhcyB0aGlzIGVmZmVjdDoKICoKICogICAgU2V0cyBmbG93IGNvbnRyb2wgc2V0IHRvICdub25lJwogKiAgICBFdmVudCBjaGFyID0gJDBECiAqICAgIEV2ZW50IHRyaWdnZXIgPSBkaXNhYmxlZAogKiAgICBQdXJnZSBSWCBidWZmZXIKICogICAgUHVyZ2UgVFggYnVmZmVyCiAqICAgIENsZWFyIERUUgogKiAgICBDbGVhciBSVFMKICogICAgYmF1ZCBhbmQgZGF0YSBmb3JtYXQgbm90IHJlc2V0CiAqCiAqIFRoZSBQdXJnZSBSWCBhbmQgVFggYnVmZmVyIGNvbW1hbmRzIGFmZmVjdCBub3RoaW5nIGV4Y2VwdCB0aGUgYnVmZmVycwogKgogICAqLwoKLyogRlRESV9TSU9fU0VUX0JBVURSQVRFICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0JBVURSQVRFX1JFUVVFU1RfVFlQRSAweDQwCiNkZWZpbmUgRlRESV9TSU9fU0VUX0JBVURSQVRFX1JFUVVFU1QgMwoKLyoKICogQm1SZXF1ZXN0VHlwZTogIDAxMDAgMDAwMEIKICogYlJlcXVlc3Q6ICAgICAgIEZURElfU0lPX1NFVF9CQVVEUkFURQogKiB3VmFsdWU6ICAgICAgICAgQmF1ZERpdmlzb3IgdmFsdWUgLSBzZWUgYmVsb3cKICogd0luZGV4OiAgICAgICAgIFBvcnQKICogd0xlbmd0aDogICAgICAgIDAKICogRGF0YTogICAgICAgICAgIE5vbmUKICogVGhlIEJhdWREaXZpc29yIHZhbHVlcyBhcmUgY2FsY3VsYXRlZCBhcyBmb2xsb3dzOgogKiAtIEJhc2VDbG9jayBpcyBlaXRoZXIgMTIwMDAwMDAgb3IgNDgwMDAwMDAgZGVwZW5kaW5nIG9uIHRoZSBkZXZpY2UuIEZJWE1FOiBJIHdpc2gKICogICBJIGtuZXcgaG93IHRvIGRldGVjdCBvbGQgY2hpcHMgdG8gc2VsZWN0IHByb3BlciBiYXNlIGNsb2NrIQogKiAtIEJhdWREaXZpc29yIGlzIGEgZml4ZWQgcG9pbnQgbnVtYmVyIGVuY29kZWQgaW4gYSBmdW5ueSB3YXkuCiAqICAgKC0tV1JPTkcgV0FZIE9GIFRISU5LSU5HLS0pCiAqICAgQmF1ZERpdmlzb3IgaXMgYSBmaXhlZCBwb2ludCBudW1iZXIgZW5jb2RlZCB3aXRoIGZvbGxvd2luZyBiaXQgd2VpZ2hzOgogKiAgICgtMikoLTEpKDEzLi4wKS4gSXQgaXMgYSByYWRpY2FsIHdpdGggYSBkZW5vbWluYXRvciBvZiA0LCBzbyB2YWx1ZXMKICogICBlbmQgd2l0aCAwLjAgKDAwLi4uKSwgMC4yNSAoMTAuLi4pLCAwLjUgKDAxLi4uKSwgYW5kIDAuNzUgKDExLi4uKS4KICogICAoLS1USEUgUkVBTElUWS0tKQogKiAgIFRoZSBib3RoLWJpdHMtc2V0IGhhcyBxdWl0ZSBkaWZmZXJlbnQgbWVhbmluZyBmcm9tIDAuNzUgLSB0aGUgY2hpcCBkZXNpZ25lcnMKICogICBoYXZlIGRlY2lkZWQgaXQgdG8gbWVhbiAwLjEyNSBpbnN0ZWFkIG9mIDAuNzUuCiAqICAgVGhpcyBpbmZvIGxvb2tlZCB1cCBpbiBGVERJIGFwcGxpY2F0aW9uIG5vdGUgIkZUOFUyMzIgREVWSUNFUyBcIERhdGEgUmF0ZXMKICogICBhbmQgRmxvdyBDb250cm9sIENvbnNpZGVyYXRpb24gZm9yIFVTQiB0byBSUzIzMiIuCiAqIC0gQmF1ZERpdmlzb3IgPSAoQmFzZUNsb2NrIC8gMTYpIC8gQmF1ZFJhdGUsIHdoZXJlIHRoZSAoPSkgb3BlcmF0aW9uIHNob3VsZAogKiAgIGF1dG9tYWdpY2FsbHkgcmUtZW5jb2RlIHRoZSByZXN1bHRpbmcgdmFsdWUgdG8gdGFrZSBmcmFjdGlvbnMgaW50byBjb25zaWRlcmF0aW9uLgogKiBBcyBhbGwgdmFsdWVzIGFyZSBpbnRlZ2Vycywgc29tZSBiaXQgdHdpZGRsaW5nIGlzIGluIG9yZGVyOgogKiAgIEJhdWREaXZpc29yID0gKEJhc2VDbG9jayAvIDE2IC8gQmF1ZFJhdGUpIHwKICogICAoKChCYXNlQ2xvY2sgLyAyIC8gQmF1ZFJhdGUpICYgNCkgPyAweDQwMDAgICAgLy8gMC41CiAqICAgIDogKChCYXNlQ2xvY2sgLyAyIC8gQmF1ZFJhdGUpICYgMikgPyAweDgwMDAgIC8vIDAuMjUKICogICAgOiAoKEJhc2VDbG9jayAvIDIgLyBCYXVkUmF0ZSkgJiAxKSA/IDB4YzAwMCAgLy8gMC4xMjUKICogICAgOiAwKQogKgogKiBGb3IgdGhlIEZUMjMyQk0sIGEgMTd0aCBkaXZpc29yIGJpdCB3YXMgaW50cm9kdWNlZCB0byBlbmNvZGUgdGhlIG11bHRpcGxlcwogKiBvZiAwLjEyNSBtaXNzaW5nIGZyb20gdGhlIEZUOFUyMzJBTS4gIEJpdHMgMTYgdG8gMTQgYXJlIGNvZGVkIGFzIGZvbGxvd3MKICogKHRoZSBmaXJzdCBmb3VyIGNvZGVzIGFyZSB0aGUgc2FtZSBhcyBmb3IgdGhlIEZUOFUyMzJBTSwgd2hlcmUgYml0IDE2IGlzCiAqIGFsd2F5cyAwKToKICogICAwMDAgLSBhZGQgLjAwMCB0byBkaXZpc29yCiAqICAgMDAxIC0gYWRkIC41MDAgdG8gZGl2aXNvcgogKiAgIDAxMCAtIGFkZCAuMjUwIHRvIGRpdmlzb3IKICogICAwMTEgLSBhZGQgLjEyNSB0byBkaXZpc29yCiAqICAgMTAwIC0gYWRkIC4zNzUgdG8gZGl2aXNvcgogKiAgIDEwMSAtIGFkZCAuNjI1IHRvIGRpdmlzb3IKICogICAxMTAgLSBhZGQgLjc1MCB0byBkaXZpc29yCiAqICAgMTExIC0gYWRkIC44NzUgdG8gZGl2aXNvcgogKiBCaXRzIDE1IHRvIDAgb2YgdGhlIDE3LWJpdCBkaXZpc29yIGFyZSBwbGFjZWQgaW4gdGhlIHVyYiB2YWx1ZS4gIEJpdCAxNiBpcyAKICogcGxhY2VkIGluIGJpdCAwIG9mIHRoZSB1cmIgaW5kZXguCiAqCiAqIE5vdGUgdGhhdCB0aGVyZSBhcmUgYSBjb3VwbGUgb2Ygc3BlY2lhbCBjYXNlcyB0byBzdXBwb3J0IHRoZSBoaWdoZXN0IGJhdWQKICogcmF0ZXMuICBJZiB0aGUgY2FsY3VsYXRlZCBkaXZpc29yIHZhbHVlIGlzIDEsIHRoaXMgbmVlZHMgdG8gYmUgcmVwbGFjZWQgd2l0aAogKiAwLiAgQWRkaXRpb25hbGx5IGZvciB0aGUgRlQyMzJCTSwgaWYgdGhlIGNhbGN1bGF0ZWQgZGl2aXNvciB2YWx1ZSBpcyAweDQwMDEKICogKDEuNSksIHRoaXMgbmVlZHMgdG8gYmUgcmVwbGFjZWQgd2l0aCAweDAwMDEgKDEpIChidXQgdGhpcyBkaXZpc29yIHZhbHVlIGlzCiAqIG5vdCBzdXBwb3J0ZWQgYnkgdGhlIEZUOFUyMzJBTSkuCiAqLwoKdHlwZWRlZiBlbnVtIHsKCVNJTyA9IDEsCglGVDhVMjMyQU0gPSAyLAoJRlQyMzJCTSA9IDMsCglGVDIyMzJDID0gNCwKCUZUMjMyUkwgPSA1LAp9IGZ0ZGlfY2hpcF90eXBlX3Q7Cgp0eXBlZGVmIGVudW0gewogZnRkaV9zaW9fYjMwMCA9IDAsIAogZnRkaV9zaW9fYjYwMCA9IDEsIAogZnRkaV9zaW9fYjEyMDAgPSAyLAogZnRkaV9zaW9fYjI0MDAgPSAzLAogZnRkaV9zaW9fYjQ4MDAgPSA0LAogZnRkaV9zaW9fYjk2MDAgPSA1LAogZnRkaV9zaW9fYjE5MjAwID0gNiwKIGZ0ZGlfc2lvX2IzODQwMCA9IDcsCiBmdGRpX3Npb19iNTc2MDAgPSA4LAogZnRkaV9zaW9fYjExNTIwMCA9IDkKfSBGVERJX1NJT19iYXVkcmF0ZV90IDsKCi8qCiAqIFRoZSBmdGRpXzhVMjMyQU1feHhNSHpfYnl5eSBjb25zdGFudHMgaGF2ZSBiZWVuIHJlbW92ZWQuIFRoZSBlbmNvZGVkIGRpdmlzb3IgdmFsdWVzCiAqIGFyZSBjYWxjdWxhdGVkIGludGVybmFsbHkuCiAqLwoKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9SRVFVRVNUIEZURElfU0lPX1NFVF9EQVRBCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfUkVRVUVTVF9UWVBFIDB4NDAKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9QQVJJVFlfTk9ORSAoMHgwIDw8IDggKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1BBUklUWV9PREQgKDB4MSA8PCA4ICkKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9QQVJJVFlfRVZFTiAoMHgyIDw8IDggKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1BBUklUWV9NQVJLICgweDMgPDwgOCApCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfUEFSSVRZX1NQQUNFICgweDQgPDwgOCApCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfU1RPUF9CSVRTXzEgKDB4MCA8PCAxMSApCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfU1RPUF9CSVRTXzE1ICgweDEgPDwgMTEgKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1NUT1BfQklUU18yICgweDIgPDwgMTEgKQojZGVmaW5lIEZURElfU0lPX1NFVF9CUkVBSyAoMHgxIDw8IDE0KQovKiBGVERJX1NJT19TRVRfREFUQSAqLwoKLyoKICogQm1SZXF1ZXN0VHlwZTogIDAxMDAgMDAwMEIgCiAqIGJSZXF1ZXN0OiAgICAgICBGVERJX1NJT19TRVRfREFUQQogKiB3VmFsdWU6ICAgICAgICAgRGF0YSBjaGFyYWN0ZXJpc3RpY3MgKHNlZSBiZWxvdykKICogd0luZGV4OiAgICAgICAgIFBvcnQKICogd0xlbmd0aDogICAgICAgIDAKICogRGF0YTogICAgICAgICAgIE5vCiAqCiAqIERhdGEgY2hhcmFjdGVyaXN0aWNzCiAqCiAqICAgQjAuLjcgICBOdW1iZXIgb2YgZGF0YSBiaXRzCiAqICAgQjguLjEwICBQYXJpdHkKICogICAgICAgICAgIDAgPSBOb25lCiAqICAgICAgICAgICAxID0gT2RkCiAqICAgICAgICAgICAyID0gRXZlbgogKiAgICAgICAgICAgMyA9IE1hcmsKICogICAgICAgICAgIDQgPSBTcGFjZQogKiAgIEIxMS4uMTMgU3RvcCBCaXRzCiAqICAgICAgICAgICAwID0gMQogKiAgICAgICAgICAgMSA9IDEuNQogKiAgICAgICAgICAgMiA9IDIKICogICBCMTQKICogICAgICAgICAgIDEgPSBUWCBPTiAoYnJlYWspCiAqICAgICAgICAgICAwID0gVFggT0ZGIChub3JtYWwgc3RhdGUpCiAqICAgQjE1IFJlc2VydmVkCiAqCiAqLwoKCgovKiBGVERJX1NJT19NT0RFTV9DVFJMICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX01PREVNX0NUUkxfUkVRVUVTVF9UWVBFIDB4NDAKI2RlZmluZSBGVERJX1NJT19TRVRfTU9ERU1fQ1RSTF9SRVFVRVNUIEZURElfU0lPX01PREVNX0NUUkwKCi8qIAogKiBCbVJlcXVlc3RUeXBlOiAgIDAxMDAgMDAwMEIKICogYlJlcXVlc3Q6ICAgICAgICBGVERJX1NJT19NT0RFTV9DVFJMCiAqIHdWYWx1ZTogICAgICAgICAgQ29udHJvbFZhbHVlIChzZWUgYmVsb3cpCiAqIHdJbmRleDogICAgICAgICAgUG9ydAogKiB3TGVuZ3RoOiAgICAgICAgIDAKICogRGF0YTogICAgICAgICAgICBOb25lCiAqCiAqIE5PVEU6IElmIHRoZSBkZXZpY2UgaXMgaW4gUlRTL0NUUyBmbG93IGNvbnRyb2wsIHRoZSBSVFMgc2V0IGJ5IHRoaXMKICogY29tbWFuZCB3aWxsIGJlIElHTk9SRUQgd2l0aG91dCBhbiBlcnJvciBiZWluZyByZXR1cm5lZAogKiBBbHNvIC0geW91IGNhbiBub3Qgc2V0IERUUiBhbmQgUlRTIHdpdGggb25lIGNvbnRyb2wgbWVzc2FnZQogKi8KCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RUUl9NQVNLIDB4MQojZGVmaW5lIEZURElfU0lPX1NFVF9EVFJfSElHSCAoIDEgfCAoIEZURElfU0lPX1NFVF9EVFJfTUFTSyAgPDwgOCkpCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RUUl9MT1cgICggMCB8ICggRlRESV9TSU9fU0VUX0RUUl9NQVNLICA8PCA4KSkKI2RlZmluZSBGVERJX1NJT19TRVRfUlRTX01BU0sgMHgyCiNkZWZpbmUgRlRESV9TSU9fU0VUX1JUU19ISUdIICggMiB8ICggRlRESV9TSU9fU0VUX1JUU19NQVNLIDw8IDggKSkKI2RlZmluZSBGVERJX1NJT19TRVRfUlRTX0xPVyAoIDAgfCAoIEZURElfU0lPX1NFVF9SVFNfTUFTSyA8PCA4ICkpCgovKgogKiBDb250cm9sVmFsdWUKICogQjAgICAgRFRSIHN0YXRlCiAqICAgICAgICAgIDAgPSByZXNldAogKiAgICAgICAgICAxID0gc2V0CiAqIEIxICAgIFJUUyBzdGF0ZQogKiAgICAgICAgICAwID0gcmVzZXQKICogICAgICAgICAgMSA9IHNldAogKiBCMi4uNyBSZXNlcnZlZAogKiBCOCAgICBEVFIgc3RhdGUgZW5hYmxlCiAqICAgICAgICAgIDAgPSBpZ25vcmUKICogICAgICAgICAgMSA9IHVzZSBEVFIgc3RhdGUKICogQjkgICAgUlRTIHN0YXRlIGVuYWJsZQogKiAgICAgICAgICAwID0gaWdub3JlCiAqICAgICAgICAgIDEgPSB1c2UgUlRTIHN0YXRlCiAqIEIxMC4uMTUgUmVzZXJ2ZWQKICovCgovKiBGVERJX1NJT19TRVRfRkxPV19DVFJMICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0ZMT1dfQ1RSTF9SRVFVRVNUX1RZUEUgMHg0MAojZGVmaW5lIEZURElfU0lPX1NFVF9GTE9XX0NUUkxfUkVRVUVTVCBGVERJX1NJT19TRVRfRkxPV19DVFJMCiNkZWZpbmUgRlRESV9TSU9fRElTQUJMRV9GTE9XX0NUUkwgMHgwIAojZGVmaW5lIEZURElfU0lPX1JUU19DVFNfSFMgKDB4MSA8PCA4KQojZGVmaW5lIEZURElfU0lPX0RUUl9EU1JfSFMgKDB4MiA8PCA4KQojZGVmaW5lIEZURElfU0lPX1hPTl9YT0ZGX0hTICgweDQgPDwgOCkKLyoKICogICBCbVJlcXVlc3RUeXBlOiAgMDEwMCAwMDAwYgogKiAgIGJSZXF1ZXN0OiAgICAgICBGVERJX1NJT19TRVRfRkxPV19DVFJMCiAqICAgd1ZhbHVlOiAgICAgICAgIFhvZmYvWG9uCiAqICAgd0luZGV4OiAgICAgICAgIFByb3RvY29sL1BvcnQgLSBoSW5kZXggaXMgcHJvdG9jbCAvIGxJbmRleCBpcyBwb3J0CiAqICAgd0xlbmd0aDogICAgICAgIDAgCiAqICAgRGF0YTogICAgICAgICAgIE5vbmUKICoKICogaEluZGV4IHByb3RvY29sIGlzOgogKiAgIEIwIE91dHB1dCBoYW5kc2hha2luZyB1c2luZyBSVFMvQ1RTCiAqICAgICAgIDAgPSBkaXNhYmxlZAogKiAgICAgICAxID0gZW5hYmxlZAogKiAgIEIxIE91dHB1dCBoYW5kc2hha2luZyB1c2luZyBEVFIvRFNSCiAqICAgICAgIDAgPSBkaXNhYmxlZAogKiAgICAgICAxID0gZW5hYmxlZAogKiAgIEIyIFhvbi9Yb2ZmIGhhbmRzaGFraW5nCiAqICAgICAgIDAgPSBkaXNhYmxlZAogKiAgICAgICAxID0gZW5hYmxlZAogKgogKiBBIHZhbHVlIG9mIHplcm8gaW4gdGhlIGhJbmRleCBmaWVsZCBkaXNhYmxlcyBoYW5kc2hha2luZwogKgogKiBJZiBYb24vWG9mZiBoYW5kc2hha2luZyBpcyBzcGVjaWZpZWQsIHRoZSBoVmFsdWUgZmllbGQgc2hvdWxkIGNvbnRhaW4gdGhlIFhPRkYgY2hhcmFjdGVyIAogKiBhbmQgdGhlIGxWYWx1ZSBmaWVsZCBjb250YWlucyB0aGUgWE9OIGNoYXJhY3Rlci4KICovICAKIAovKgogKiBGVERJX1NJT19HRVRfTEFURU5DWV9USU1FUgogKgogKiBTZXQgdGhlIHRpbWVvdXQgaW50ZXJ2YWwuIFRoZSBGVERJIGNvbGxlY3RzIGRhdGEgZnJvbSB0aGUgc2xhdmUKICogZGV2aWNlLCB0cmFuc21pdHRpbmcgaXQgdG8gdGhlIGhvc3Qgd2hlbiBlaXRoZXIgQSkgNjIgYnl0ZXMgYXJlCiAqIHJlY2VpdmVkLCBvciBCKSB0aGUgdGltZW91dCBpbnRlcnZhbCBoYXMgZWxhcHNlZCBhbmQgdGhlIGJ1ZmZlcgogKiBjb250YWlucyBhdCBsZWFzdCAxIGJ5dGUuICBTZXR0aW5nIHRoaXMgdmFsdWUgdG8gYSBzbWFsbCBudW1iZXIKICogY2FuIGRyYW1hdGljYWxseSBpbXByb3ZlIHBlcmZvcm1hbmNlIGZvciBhcHBsaWNhdGlvbnMgd2hpY2ggc2VuZAogKiBzbWFsbCBwYWNrZXRzLCBzaW5jZSB0aGUgZGVmYXVsdCB2YWx1ZSBpcyAxNm1zLgogKi8KI2RlZmluZSAgRlRESV9TSU9fR0VUX0xBVEVOQ1lfVElNRVJfUkVRVUVTVCBGVERJX1NJT19HRVRfTEFURU5DWV9USU1FUgojZGVmaW5lICBGVERJX1NJT19HRVRfTEFURU5DWV9USU1FUl9SRVFVRVNUX1RZUEUgMHhDMAoKLyogCiAqICBCbVJlcXVlc3RUeXBlOiAgIDExMDAgMDAwMGIKICogIGJSZXF1ZXN0OiAgICAgICAgRlRESV9TSU9fR0VUX0xBVEVOQ1lfVElNRVIKICogIHdWYWx1ZTogICAgICAgICAgMAogKiAgd0luZGV4OiAgICAgICAgICBQb3J0CiAqICB3TGVuZ3RoOiAgICAgICAgIDAKICogIERhdGE6ICAgICAgICAgICAgbGF0ZW5jeSAob24gcmV0dXJuKQogKi8KCi8qIAogKiBGVERJX1NJT19TRVRfTEFURU5DWV9USU1FUgogKgogKiBTZXQgdGhlIHRpbWVvdXQgaW50ZXJ2YWwuIFRoZSBGVERJIGNvbGxlY3RzIGRhdGEgZnJvbSB0aGUgc2xhdmUKICogZGV2aWNlLCB0cmFuc21pdHRpbmcgaXQgdG8gdGhlIGhvc3Qgd2hlbiBlaXRoZXIgQSkgNjIgYnl0ZXMgYXJlCiAqIHJlY2VpdmVkLCBvciBCKSB0aGUgdGltZW91dCBpbnRlcnZhbCBoYXMgZWxhcHNlZCBhbmQgdGhlIGJ1ZmZlcgogKiBjb250YWlucyBhdCBsZWFzdCAxIGJ5dGUuICBTZXR0aW5nIHRoaXMgdmFsdWUgdG8gYSBzbWFsbCBudW1iZXIKICogY2FuIGRyYW1hdGljYWxseSBpbXByb3ZlIHBlcmZvcm1hbmNlIGZvciBhcHBsaWNhdGlvbnMgd2hpY2ggc2VuZAogKiBzbWFsbCBwYWNrZXRzLCBzaW5jZSB0aGUgZGVmYXVsdCB2YWx1ZSBpcyAxNm1zLgogKi8KI2RlZmluZSAgRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVJfUkVRVUVTVCBGVERJX1NJT19TRVRfTEFURU5DWV9USU1FUgojZGVmaW5lICBGVERJX1NJT19TRVRfTEFURU5DWV9USU1FUl9SRVFVRVNUX1RZUEUgMHg0MAoKLyogCiAqICBCbVJlcXVlc3RUeXBlOiAgIDAxMDAgMDAwMGIKICogIGJSZXF1ZXN0OiAgICAgICAgRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVIKICogIHdWYWx1ZTogICAgICAgICAgTGF0ZW5jeSAobWlsbGlzZWNvbmRzKQogKiAgd0luZGV4OiAgICAgICAgICBQb3J0CiAqICB3TGVuZ3RoOiAgICAgICAgIDAKICogIERhdGE6ICAgICAgICAgICAgTm9uZQogKgogKiB3VmFsdWU6CiAqICAgQjAuLjcgICBMYXRlbmN5IHRpbWVyCiAqICAgQjguLjE1ICAwCiAqCiAqLwoKLyoKICogRlRESV9TSU9fU0VUX0VWRU5UX0NIQVIgCiAqCiAqIFNldCB0aGUgc3BlY2lhbCBldmVudCBjaGFyYWN0ZXIgZm9yIHRoZSBzcGVjaWZpZWQgY29tbXVuaWNhdGlvbnMgcG9ydC4KICogSWYgdGhlIGRldmljZSBzZWVzIHRoaXMgY2hhcmFjdGVyIGl0IHdpbGwgaW1tZWRpYXRlbHkgcmV0dXJuIHRoZQogKiBkYXRhIHJlYWQgc28gZmFyIC0gcmF0aGVyIHRoYW4gd2FpdCA0MG1zIG9yIHVudGlsIDYyIGJ5dGVzIGFyZSByZWFkCiAqIHdoaWNoIGlzIHdoYXQgbm9ybWFsbHkgaGFwcGVucy4KICovCgoKI2RlZmluZSAgRlRESV9TSU9fU0VUX0VWRU5UX0NIQVJfUkVRVUVTVCBGVERJX1NJT19TRVRfRVZFTlRfQ0hBUgojZGVmaW5lICBGVERJX1NJT19TRVRfRVZFTlRfQ0hBUl9SRVFVRVNUX1RZUEUgMHg0MAoKCi8qIAogKiAgQm1SZXF1ZXN0VHlwZTogICAwMTAwIDAwMDBiCiAqICBiUmVxdWVzdDogICAgICAgIEZURElfU0lPX1NFVF9FVkVOVF9DSEFSCiAqICB3VmFsdWU6ICAgICAgICAgIEV2ZW50Q2hhcgogKiAgd0luZGV4OiAgICAgICAgICBQb3J0CiAqICB3TGVuZ3RoOiAgICAgICAgIDAKICogIERhdGE6ICAgICAgICAgICAgTm9uZQogKgogKiB3VmFsdWU6CiAqICAgQjAuLjcgICBFdmVudCBDaGFyYWN0ZXIKICogICBCOCAgICAgIEV2ZW50IENoYXJhY3RlciBQcm9jZXNzaW5nCiAqICAgICAgICAgICAgIDAgPSBkaXNhYmxlZAogKiAgICAgICAgICAgICAxID0gZW5hYmxlZAogKiAgIEI5Li4xNSAgUmVzZXJ2ZWQKICoKICovCiAgICAgICAgICAKLyogRlRESV9TSU9fU0VUX0VSUk9SX0NIQVIgKi8KCi8qIFNldCB0aGUgcGFyaXR5IGVycm9yIHJlcGxhY2VtZW50IGNoYXJhY3RlciBmb3IgdGhlIHNwZWNpZmllZCBjb21tdW5pY2F0aW9ucyBwb3J0ICovCgovKiAKICogIEJtUmVxdWVzdFR5cGU6ICAwMTAwIDAwMDBiCiAqICBiUmVxdWVzdDogICAgICAgRlRESV9TSU9fU0VUX0VWRU5UX0NIQVIKICogIHdWYWx1ZTogICAgICAgICBFcnJvciBDaGFyCiAqICB3SW5kZXg6ICAgICAgICAgUG9ydAogKiAgd0xlbmd0aDogICAgICAgIDAKICogIERhdGE6ICAgICAgICAgICBOb25lCiAqCiAqRXJyb3IgQ2hhcgogKiAgQjAuLjcgIEVycm9yIENoYXJhY3RlcgogKiAgQjggICAgIEVycm9yIENoYXJhY3RlciBQcm9jZXNzaW5nCiAqICAgICAgICAgICAwID0gZGlzYWJsZWQKICogICAgICAgICAgIDEgPSBlbmFibGVkCiAqICBCOS4uMTUgUmVzZXJ2ZWQKICoKICovCgovKiBGVERJX1NJT19HRVRfTU9ERU1fU1RBVFVTICovCi8qIFJldHJpZXZlIHRoZSBjdXJyZW50IHZhbHVlIG9mIHRoZSBtb2RlbSBzdGF0dXMgcmVnaXN0ZXIgKi8KCiNkZWZpbmUgRlRESV9TSU9fR0VUX01PREVNX1NUQVRVU19SRVFVRVNUX1RZUEUgMHhjMAojZGVmaW5lIEZURElfU0lPX0dFVF9NT0RFTV9TVEFUVVNfUkVRVUVTVCBGVERJX1NJT19HRVRfTU9ERU1fU1RBVFVTCiNkZWZpbmUgRlRESV9TSU9fQ1RTX01BU0sgMHgxMAojZGVmaW5lIEZURElfU0lPX0RTUl9NQVNLIDB4MjAKI2RlZmluZSBGVERJX1NJT19SSV9NQVNLICAweDQwCiNkZWZpbmUgRlRESV9TSU9fUkxTRF9NQVNLIDB4ODAKLyogCiAqICAgQm1SZXF1ZXN0VHlwZTogICAxMTAwIDAwMDBiCiAqICAgYlJlcXVlc3Q6ICAgICAgICBGVERJX1NJT19HRVRfTU9ERU1fU1RBVFVTCiAqICAgd1ZhbHVlOiAgICAgICAgICB6ZXJvCiAqICAgd0luZGV4OiAgICAgICAgICBQb3J0CiAqICAgd0xlbmd0aDogICAgICAgICAxCiAqICAgRGF0YTogICAgICAgICAgICBTdGF0dXMKICogCiAqIE9uZSBieXRlIG9mIGRhdGEgaXMgcmV0dXJuZWQgCiAqIEIwLi4zIDAKICogQjQgICAgQ1RTCiAqICAgICAgICAgMCA9IGluYWN0aXZlCiAqICAgICAgICAgMSA9IGFjdGl2ZQogKiBCNSAgICBEU1IKICogICAgICAgICAwID0gaW5hY3RpdmUKICogICAgICAgICAxID0gYWN0aXZlCiAqIEI2ICAgIFJpbmcgSW5kaWNhdG9yIChSSSkKICogICAgICAgICAwID0gaW5hY3RpdmUKICogICAgICAgICAxID0gYWN0aXZlCiAqIEI3ICAgIFJlY2VpdmUgTGluZSBTaWduYWwgRGV0ZWN0IChSTFNEKQogKiAgICAgICAgIDAgPSBpbmFjdGl2ZQogKiAgICAgICAgIDEgPSBhY3RpdmUgCiAqLwoKCgovKiBEZXNjcmlwdG9ycyByZXR1cm5lZCBieSB0aGUgZGV2aWNlIAogKiAKICogIERldmljZSBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCVNpemUJVmFsdWUJRGVzY3JpcHRpb24KICogMAliTGVuZ3RoCQkxCTB4MTIJU2l6ZSBvZiBkZXNjcmlwdG9yIGluIGJ5dGVzCiAqIDEJYkRlc2NyaXB0b3JUeXBlCTEJMHgwMQlERVZJQ0UgRGVzY3JpcHRvciBUeXBlCiAqIDIJYmNkVVNCCQkyCTB4MDExMAlVU0IgU3BlYyBSZWxlYXNlIE51bWJlcgogKiA0CWJEZXZpY2VDbGFzcwkxCTB4MDAJQ2xhc3MgQ29kZQogKiA1CWJEZXZpY2VTdWJDbGFzcwkxCTB4MDAJU3ViQ2xhc3MgQ29kZQogKiA2CWJEZXZpY2VQcm90b2NvbAkxCTB4MDAJUHJvdG9jb2wgQ29kZQogKiA3CWJNYXhQYWNrZXRTaXplMCAxCTB4MDgJTWF4aW11bSBwYWNrZXQgc2l6ZSBmb3IgZW5kcG9pbnQgMAogKiA4CWlkVmVuZG9yCTIJMHgwNDAzCVZlbmRvciBJRAogKiAxMAlpZFByb2R1Y3QJMgkweDgzNzIJUHJvZHVjdCBJRCAoRlRESV9TSU9fUElEKQogKiAxMgliY2REZXZpY2UJMgkweDAwMDEJRGV2aWNlIHJlbGVhc2UgbnVtYmVyCiAqIDE0CWlNYW51ZmFjdHVyZXIJMQkweDAxCUluZGV4IG9mIG1hbi4gc3RyaW5nIGRlc2MKICogMTUJaVByb2R1Y3QJMQkweDAyCUluZGV4IG9mIHByb2Qgc3RyaW5nIGRlc2MKICogMTYJaVNlcmlhbE51bWJlcgkxCTB4MDIJSW5kZXggb2Ygc2VyaWFsIG5tciBzdHJpbmcgZGVzYwogKiAxNwliTnVtQ29uZmlndXJhdGlvbnMgMSAgICAweDAxCU51bWJlciBvZiBwb3NzaWJsZSBjb25maWd1cmF0aW9ucwogKiAKICogQ29uZmlndXJhdGlvbiBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCQlTaXplCVZhbHVlCiAqIDAJYkxlbmd0aAkJCTEJMHgwOQlTaXplIG9mIGRlc2NyaXB0b3IgaW4gYnl0ZXMKICogMQliRGVzY3JpcHRvclR5cGUJCTEJMHgwMglDT05GSUdVUkFUSU9OIERlc2NyaXB0b3IgVHlwZQogKiAyCXdUb3RhbExlbmd0aAkJMgkweDAwMjAJVG90YWwgbGVuZ3RoIG9mIGRhdGEKICogNAliTnVtSW50ZXJmYWNlcwkJMQkweDAxCU51bWJlciBvZiBpbnRlcmZhY2VzIHN1cHBvcnRlZAogKiA1CWJDb25maWd1cmF0aW9uVmFsdWUJMQkweDAxCUFyZ3VtZW50IGZvciBTZXRDT25maWd1cmF0aW9uKCkgcmVxCiAqIDYJaUNvbmZpZ3VyYXRpb24JCTEJMHgwMglJbmRleCBvZiBjb25maWcgc3RyaW5nIGRlc2NyaXB0b3IKICogNwlibUF0dHJpYnV0ZXMJCTEJMHgyMAlDb25maWcgY2hhcmFjdGVyaXN0aWNzIFJlbW90ZSBXYWtldXAKICogOAlNYXhQb3dlcgkJMQkweDFFCU1heCBwb3dlciBjb25zdW1wdGlvbgogKiAKICogSW50ZXJmYWNlIERlc2NyaXB0b3IKICogCiAqIE9mZnNldAlGaWVsZAkJCVNpemUJVmFsdWUKICogMAliTGVuZ3RoCQkJMQkweDA5CVNpemUgb2YgZGVzY3JpcHRvciBpbiBieXRlcwogKiAxCWJEZXNjcmlwdG9yVHlwZQkJMQkweDA0CUlOVEVSRkFDRSBEZXNjcmlwdG9yIFR5cGUKICogMgliSW50ZXJmYWNlTnVtYmVyCTEJMHgwMAlOdW1iZXIgb2YgaW50ZXJmYWNlCiAqIDMJYkFsdGVybmF0ZVNldHRpbmcJMQkweDAwCVZhbHVlIHVzZWQgdG8gc2VsZWN0IGFsdGVybmF0ZQogKiA0CWJOdW1FbmRwb2ludHMJCTEJMHgwMglOdW1iZXIgb2YgZW5kcG9pbnRzCiAqIDUJYkludGVyZmFjZUNsYXNzCQkxCTB4RkYJQ2xhc3MgQ29kZQogKiA2CWJJbnRlcmZhY2VTdWJDbGFzcwkxCTB4RkYJU3ViY2xhc3MgQ29kZQogKiA3CWJJbnRlcmZhY2VQcm90b2NvbAkxCTB4RkYJUHJvdG9jb2wgQ29kZQogKiA4CWlJbnRlcmZhY2UJCTEJMHgwMglJbmRleCBvZiBpbnRlcmZhY2Ugc3RyaW5nIGRlc2NyaXB0aW9uCiAqIAogKiBJTiBFbmRwb2ludCBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCQlTaXplCVZhbHVlCiAqIDAJYkxlbmd0aAkJCTEJMHgwNwlTaXplIG9mIGRlc2NyaXB0b3IgaW4gYnl0ZXMKICogMQliRGVzY3JpcHRvclR5cGUJCTEJMHgwNQlFTkRQT0lOVCBkZXNjcmlwdG9yIHR5cGUKICogMgliRW5kcG9pbnRBZGRyZXNzCTEJMHg4MglBZGRyZXNzIG9mIGVuZHBvaW50CiAqIDMJYm1BdHRyaWJ1dGVzCQkxCTB4MDIJRW5kcG9pbnQgYXR0cmlidXRlcyAtIEJ1bGsKICogNAliTnVtRW5kcG9pbnRzCQkyCTB4MDA0MAltYXhpbXVtIHBhY2tldCBzaXplCiAqIDUJYkludGVydmFsCQkxCTB4MDAJSW50ZXJ2YWwgZm9yIHBvbGxpbmcgZW5kcG9pbnQKICogCiAqIE9VVCBFbmRwb2ludCBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCQlTaXplCVZhbHVlCiAqIDAJYkxlbmd0aAkJCTEJMHgwNwlTaXplIG9mIGRlc2NyaXB0b3IgaW4gYnl0ZXMKICogMQliRGVzY3JpcHRvclR5cGUJCTEJMHgwNQlFTkRQT0lOVCBkZXNjcmlwdG9yIHR5cGUKICogMgliRW5kcG9pbnRBZGRyZXNzCTEJMHgwMglBZGRyZXNzIG9mIGVuZHBvaW50CiAqIDMJYm1BdHRyaWJ1dGVzCQkxCTB4MDIJRW5kcG9pbnQgYXR0cmlidXRlcyAtIEJ1bGsKICogNAliTnVtRW5kcG9pbnRzCQkyCTB4MDA0MAltYXhpbXVtIHBhY2tldCBzaXplCiAqIDUJYkludGVydmFsCQkxCTB4MDAJSW50ZXJ2YWwgZm9yIHBvbGxpbmcgZW5kcG9pbnQKICogICAgIAogKiBEQVRBIEZPUk1BVAogKiAKICogSU4gRW5kcG9pbnQKICogCiAqIFRoZSBkZXZpY2UgcmVzZXJ2ZXMgdGhlIGZpcnN0IHR3byBieXRlcyBvZiBkYXRhIG9uIHRoaXMgZW5kcG9pbnQgdG8gY29udGFpbiB0aGUgY3VycmVudAogKiB2YWx1ZXMgb2YgdGhlIG1vZGVtIGFuZCBsaW5lIHN0YXR1cyByZWdpc3RlcnMuIEluIHRoZSBhYnNlbmNlIG9mIGRhdGEsIHRoZSBkZXZpY2UgCiAqIGdlbmVyYXRlcyBhIG1lc3NhZ2UgY29uc2lzdGluZyBvZiB0aGVzZSB0d28gc3RhdHVzIGJ5dGVzIGV2ZXJ5IDQwIG1zCiAqIAogKiBCeXRlIDA6IE1vZGVtIFN0YXR1cwogKiAKICogT2Zmc2V0CURlc2NyaXB0aW9uCiAqIEIwCVJlc2VydmVkIC0gbXVzdCBiZSAxCiAqIEIxCVJlc2VydmVkIC0gbXVzdCBiZSAwCiAqIEIyCVJlc2VydmVkIC0gbXVzdCBiZSAwCiAqIEIzCVJlc2VydmVkIC0gbXVzdCBiZSAwCiAqIEI0CUNsZWFyIHRvIFNlbmQgKENUUykKICogQjUJRGF0YSBTZXQgUmVhZHkgKERTUikKICogQjYJUmluZyBJbmRpY2F0b3IgKFJJKQogKiBCNwlSZWNlaXZlIExpbmUgU2lnbmFsIERldGVjdCAoUkxTRCkKICogCiAqIEJ5dGUgMTogTGluZSBTdGF0dXMKICogCiAqIE9mZnNldAlEZXNjcmlwdGlvbgogKiBCMAlEYXRhIFJlYWR5IChEUikKICogQjEJT3ZlcnJ1biBFcnJvciAoT0UpCiAqIEIyCVBhcml0eSBFcnJvciAoUEUpCiAqIEIzCUZyYW1pbmcgRXJyb3IgKEZFKQogKiBCNAlCcmVhayBJbnRlcnJ1cHQgKEJJKQogKiBCNQlUcmFuc21pdHRlciBIb2xkaW5nIFJlZ2lzdGVyIChUSFJFKQogKiBCNglUcmFuc21pdHRlciBFbXB0eSAoVEVNVCkKICogQjcJRXJyb3IgaW4gUkNWUiBGSUZPCiAqIAogKi8KI2RlZmluZSBGVERJX1JTMF9DVFMJKDEgPDwgNCkKI2RlZmluZSBGVERJX1JTMF9EU1IJKDEgPDwgNSkKI2RlZmluZSBGVERJX1JTMF9SSQkoMSA8PCA2KQojZGVmaW5lIEZURElfUlMwX1JMU0QJKDEgPDwgNykKCiNkZWZpbmUgRlRESV9SU19EUiAgMQojZGVmaW5lIEZURElfUlNfT0UgKDE8PDEpCiNkZWZpbmUgRlRESV9SU19QRSAoMTw8MikKI2RlZmluZSBGVERJX1JTX0ZFICgxPDwzKQojZGVmaW5lIEZURElfUlNfQkkgKDE8PDQpCiNkZWZpbmUgRlRESV9SU19USFJFICgxPDw1KQojZGVmaW5lIEZURElfUlNfVEVNVCAoMTw8NikKI2RlZmluZSBGVERJX1JTX0ZJRk8gICgxPDw3KQoKLyoKICogT1VUIEVuZHBvaW50CiAqIAogKiBUaGlzIGRldmljZSByZXNlcnZlcyB0aGUgZmlyc3QgYnl0ZXMgb2YgZGF0YSBvbiB0aGlzIGVuZHBvaW50IGNvbnRhaW4gdGhlIGxlbmd0aAogKiBhbmQgcG9ydCBpZGVudGlmaWVyIG9mIHRoZSBtZXNzYWdlLiBGb3IgdGhlIEZUREkgVVNCIFNlcmlhbCBjb252ZXJ0ZXIgdGhlIHBvcnQgCiAqIGlkZW50aWZpZXIgaXMgYWx3YXlzIDEuCiAqIAogKiBCeXRlIDA6IExpbmUgU3RhdHVzCiAqIAogKiBPZmZzZXQJRGVzY3JpcHRpb24KICogQjAJUmVzZXJ2ZWQgLSBtdXN0IGJlIDEKICogQjEJUmVzZXJ2ZWQgLSBtdXN0IGJlIDAKICogQjIuLjcJTGVuZ3RoIG9mIG1lc3NhZ2UgLSAobm90IGluY2x1ZGluZyBCeXRlIDApCiAqIAogKi8KCg==