LyoKICogRGVmaW5pdGlvbnMgZm9yIHRoZSBGVERJIFVTQiBTaW5nbGUgUG9ydCBTZXJpYWwgQ29udmVydGVyIC0gCiAqIGtub3duIGFzIEZURElfU0lPIChTZXJpYWwgSW5wdXQvT3V0cHV0IGFwcGxpY2F0aW9uIG9mIHRoZSBjaGlwc2V0KSAKICoKICogVGhlIGV4YW1wbGUgSSBoYXZlIGlzIGtub3duIGFzIHRoZSBVU0MtMTAwMCB3aGljaCBpcyBhdmFpbGFibGUgZnJvbQogKiBodHRwOi8vd3d3LmRzZS5jby5ueiAtIGNhdCBubyBYSDQyMTQgSXQgbG9va3Mgc2ltaWxhciB0byB0aGlzOgogKiBodHRwOi8vd3d3LmRhbnNkYXRhLmNvbS91c2JzZXIuaHRtIGJ1dCBJIGNhbid0IGJlIHN1cmUgVGhlcmUgYXJlIG90aGVyCiAqIFVTQy0xMDAwcyB3aGljaCBkb24ndCBsb29rIGxpa2UgbXkgZGV2aWNlIHRob3VnaCBzbyBiZXdhcmUhCiAqCiAqIFRoZSBkZXZpY2UgaXMgYmFzZWQgb24gdGhlIEZUREkgRlQ4VTEwMEFYIGNoaXAuIEl0IGhhcyBhIERCMjUgb24gb25lIHNpZGUsIAogKiBVU0Igb24gdGhlIG90aGVyLgogKgogKiBUaGFueCB0byBGVERJIChodHRwOi8vd3d3LmZ0ZGkuY28udWspIGZvciBzbyBraW5kbHkgcHJvdmlkaW5nIGRldGFpbHMKICogb2YgdGhlIHByb3RvY29sIHJlcXVpcmVkIHRvIHRhbGsgdG8gdGhlIGRldmljZSBhbmQgb25nb2luZyBhc3Npc3RlbmNlCiAqIGR1cmluZyBkZXZlbG9wbWVudC4KICoKICogQmlsbCBSeWRlciAtIGJyeWRlckBzZ2kuY29tIGZvcm1lcmx5IG9mIFNpbGljb24gR3JhcGhpY3MsIEluYy4tIHdyb3RlIHRoZSAKICogRlRESV9TSU8gaW1wbGVtZW50YXRpb24uCiAqCiAqIFBoaWxpcHAgR/xocmluZyAtIHBnQGZ1dHVyZXdhcmUuYXQgLSBhZGRlZCB0aGUgRGV2aWNlIElEIG9mIHRoZSBVU0IgcmVsYWlzCiAqIGZyb20gUnVkb2xmIEd1Z2xlcgogKgogKi8KCiNkZWZpbmUgRlRESV9WSUQJMHgwNDAzCS8qIFZlbmRvciBJZCAqLwojZGVmaW5lIEZURElfU0lPX1BJRAkweDgzNzIJLyogUHJvZHVjdCBJZCBTSU8gYXBwbGljYXRpb24gb2YgOFUxMDBBWCAgKi8KI2RlZmluZSBGVERJXzhVMjMyQU1fUElEIDB4NjAwMSAvKiBTaW1pbGFyIGRldmljZSB0byBTSU8gYWJvdmUgKi8KI2RlZmluZSBGVERJXzhVMjMyQU1fQUxUX1BJRCAweDYwMDYgLyogRlRESSdzIGFsdGVybmF0ZSBQSUQgZm9yIGFib3ZlICovCiNkZWZpbmUgRlRESV84VTIyMzJDX1BJRCAweDYwMTAgLyogRHVhbCBjaGFubmVsIGRldmljZSAqLwojZGVmaW5lIEZURElfUkVMQUlTX1BJRAkweEZBMTAgIC8qIFJlbGFpcyBkZXZpY2UgZnJvbSBSdWRvbGYgR3VnbGVyICovCiNkZWZpbmUgRlRESV9ORl9SSUNfVklECTB4MERDRAkvKiBWZW5kb3IgSWQgKi8KI2RlZmluZSBGVERJX05GX1JJQ19QSUQJMHgwMDAxCS8qIFByb2R1Y3QgSWQgKi8KCgovKiBBQ1QgU29sdXRpb25zIEhvbWVQcm8gWldhdmUgaW50ZXJmYWNlIChodHRwOi8vd3d3LmFjdC1zb2x1dGlvbnMuY29tL0hvbWVQcm8uaHRtKSAqLwojZGVmaW5lIEZURElfQUNUWldBVkVfUElECTB4RjJEMAoKCi8qIHd3dy5pcnRyYW5zLmRlIGRldmljZSAqLwojZGVmaW5lIEZURElfSVJUUkFOU19QSUQgMHhGQzYwIC8qIFByb2R1Y3QgSWQgKi8KCgovKiB3d3cudGhvdWdodHRlY2hub2xvZ3kuY29tLyBUVC1VU0IgcHJvdmlkZSB3aXRoIHByb2NvbXAgdXNlIGZ0ZGlfc2lvICovCiNkZWZpbmUgRlRESV9UVFVTQl9QSUQgMHhGRjIwIC8qIFByb2R1Y3QgSWQgKi8KCi8qIGlQbHVzIGRldmljZSAqLwojZGVmaW5lIEZURElfSVBMVVNfUElEIDB4RDA3MCAvKiBQcm9kdWN0IElkICovCgovKiB3d3cuY3J5c3RhbGZvbnR6LmNvbSBkZXZpY2VzIC0gdGhhbnggZm9yIHByb3ZpZGluZyBmcmVlIGRldmljZXMgZm9yIGV2YWx1YXRpb24gISAqLwovKiB0aGV5IHVzZSB0aGUgZnRkaSBjaGlwc2V0IGZvciB0aGUgVVNCIGludGVyZmFjZSBhbmQgdGhlIHZlbmRvciBpZCBpcyB0aGUgc2FtZSAqLwojZGVmaW5lIEZURElfWEZfNjMyX1BJRCAweEZDMDgJLyogNjMyOiAxNngyIENoYXJhY3RlciBEaXNwbGF5ICovCiNkZWZpbmUgRlRESV9YRl82MzRfUElEIDB4RkMwOQkvKiA2MzQ6IDIweDQgQ2hhcmFjdGVyIERpc3BsYXkgKi8KI2RlZmluZSBGVERJX1hGXzU0N19QSUQgMHhGQzBBCS8qIDU0NzogVHdvIGxpbmUgRGlzcGxheSAqLwojZGVmaW5lIEZURElfWEZfNjMzX1BJRCAweEZDMEIJLyogNjMzOiAxNngyIENoYXJhY3RlciBEaXNwbGF5IHdpdGggS2V5cyAqLwojZGVmaW5lIEZURElfWEZfNjMxX1BJRCAweEZDMEMJLyogNjMxOiAyMHgyIENoYXJhY3RlciBEaXNwbGF5ICovCiNkZWZpbmUgRlRESV9YRl82MzVfUElEIDB4RkMwRAkvKiA2MzU6IDIweDQgQ2hhcmFjdGVyIERpc3BsYXkgKi8KI2RlZmluZSBGVERJX1hGXzY0MF9QSUQgMHhGQzBFCS8qIDY0MDogVHdvIGxpbmUgRGlzcGxheSAqLwojZGVmaW5lIEZURElfWEZfNjQyX1BJRCAweEZDMEYJLyogNjQyOiBUd28gbGluZSBEaXNwbGF5ICovCgovKiBWaWRlbyBOZXR3b3JrcyBMaW1pdGVkIC8gSG9tZWNob2ljZSBpbiB0aGUgVUsgdXNlIGFuIGZ0ZGktYmFzZWQgZGV2aWNlIGZvciB0aGVpciAxTWIgKi8KLyogYnJvYWRiYW5kIGludGVybmV0IHNlcnZpY2UuICBUaGUgZm9sbG93aW5nIFBJRCBpcyBleGhpYml0ZWQgYnkgdGhlIHVzYiBkZXZpY2Ugc3VwcGxpZWQgKi8KLyogKHRoZSBWSUQgaXMgdGhlIHN0YW5kYXJkIGZ0ZGkgdmlkIChGVERJX1ZJRCkgKi8KI2RlZmluZSBGVERJX1ZOSENQQ1VTQl9EX1BJRCAweGZlMzggLyogUHJvZHVjdCBJZCAqLwoKLyoKICogUENESiB1c2UgZnRkaSBiYXNlZCBkai1jb250cm9sbGVycy4gIFRoZSBmb2xsb3dpbmcgUElEIGlzIGZvciB0aGVpciBEQUMtMiBkZXZpY2UKICogaHR0cDovL3d3dy5wY2RqaGFyZHdhcmUuY29tL0RBQzIuYXNwIChQSUQgc2VudCBieSBXb3V0ZXIgUGFlc2VuKQogKiAodGhlIFZJRCBpcyB0aGUgc3RhbmRhcmQgZnRkaSB2aWQgKEZURElfVklEKSAqLwojZGVmaW5lIEZURElfUENESl9EQUMyX1BJRCAweEZBODgKCi8qCiAqIFRoZSBmb2xsb3dpbmcgYXJlIHRoZSB2YWx1ZXMgZm9yIHRoZSBNYXRyaXggT3JiaXRhbCBMQ0QgZGlzcGxheXMsCiAqIHdoaWNoIGFyZSB0aGUgRlQyMzJCTSAoIHNpbWlsYXIgdG8gdGhlIDhVMjMyQU0gKQogKi8KI2RlZmluZSBGVERJX01UWE9SQl8wX1BJRCAgICAgIDB4RkEwMCAgLyogTWF0cml4IE9yYml0YWwgUHJvZHVjdCBJZCAqLwojZGVmaW5lIEZURElfTVRYT1JCXzFfUElEICAgICAgMHhGQTAxICAvKiBNYXRyaXggT3JiaXRhbCBQcm9kdWN0IElkICovCiNkZWZpbmUgRlRESV9NVFhPUkJfMl9QSUQgICAgICAweEZBMDIgIC8qIE1hdHJpeCBPcmJpdGFsIFByb2R1Y3QgSWQgKi8KI2RlZmluZSBGVERJX01UWE9SQl8zX1BJRCAgICAgIDB4RkEwMyAgLyogTWF0cml4IE9yYml0YWwgUHJvZHVjdCBJZCAqLwojZGVmaW5lIEZURElfTVRYT1JCXzRfUElEICAgICAgMHhGQTA0ICAvKiBNYXRyaXggT3JiaXRhbCBQcm9kdWN0IElkICovCiNkZWZpbmUgRlRESV9NVFhPUkJfNV9QSUQgICAgICAweEZBMDUgIC8qIE1hdHJpeCBPcmJpdGFsIFByb2R1Y3QgSWQgKi8KI2RlZmluZSBGVERJX01UWE9SQl82X1BJRCAgICAgIDB4RkEwNiAgLyogTWF0cml4IE9yYml0YWwgUHJvZHVjdCBJZCAqLwoKLyogSW50ZXJiaW9tZXRyaWNzIFVTQiBJL08gQm9hcmQgKi8KLyogRGV2ZWxvcGVkIGZvciBJbnRlcmJpb21ldHJpY3MgYnkgUnVkb2xmIEd1Z2xlciAqLwojZGVmaW5lIElOVEVSQklPTUVUUklDU19WSUQgICAgICAgICAgICAgIDB4MTIwOQojZGVmaW5lIElOVEVSQklPTUVUUklDU19JT0JPQVJEX1BJRCAgICAgIDB4MTAwMgojZGVmaW5lIElOVEVSQklPTUVUUklDU19NSU5JX0lPQk9BUkRfUElEIDB4MTAwNgoKLyoKICogVGhlIGZvbGxvd2luZyBhcmUgdGhlIHZhbHVlcyBmb3IgdGhlIFBlcmxlIFN5c3RlbXMKICogVWx0cmFQb3J0IFVTQiBzZXJpYWwgY29udmVydGVycwogKi8KI2RlZmluZSBGVERJX1BFUkxFX1VMVFJBUE9SVF9QSUQgMHhGMEMwCS8qIFBlcmxlIFVsdHJhUG9ydCBQcm9kdWN0IElkICovCgovKgogKiBUaGUgZm9sbG93aW5nIGFyZSB0aGUgdmFsdWVzIGZvciB0aGUgU2VhbGV2ZWwgU2VhTElOSysgYWRhcHRlcnMuCiAqIChPcmlnaW5hbCBsaXN0IHNlbnQgYnkgVHVhbiBIb2FuZy4gIElhbiBBYmJvdHQgcmVuYW1lZCB0aGUgbWFjcm9zIGFuZAogKiByZW1vdmVkIHNvbWUgUElEcyB0aGF0IGRvbid0IHNlZW0gdG8gbWF0Y2ggYW55IGV4aXN0aW5nIHByb2R1Y3RzLikKICovCiNkZWZpbmUgU0VBTEVWRUxfVklECQkweDBjNTIJLyogU2VhbGV2ZWwgVmVuZG9yIElEICovCiNkZWZpbmUgU0VBTEVWRUxfMjEwMV9QSUQJMHgyMTAxCS8qIFNlYUxJTksrMjMyICgyMTAxLzIxMDUpICovCiNkZWZpbmUgU0VBTEVWRUxfMjEwMl9QSUQJMHgyMTAyCS8qIFNlYUxJTksrNDg1ICgyMTAyKSAqLwojZGVmaW5lIFNFQUxFVkVMXzIxMDNfUElECTB4MjEwMwkvKiBTZWFMSU5LKzIzMkkgKDIxMDMpICovCiNkZWZpbmUgU0VBTEVWRUxfMjEwNF9QSUQJMHgyMTA0CS8qIFNlYUxJTksrNDg1SSAoMjEwNCkgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAxXzFfUElECTB4MjIxMQkvKiBTZWFQT1JUKzIvMjMyICgyMjAxKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAxXzJfUElECTB4MjIyMQkvKiBTZWFQT1JUKzIvMjMyICgyMjAxKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAyXzFfUElECTB4MjIxMgkvKiBTZWFQT1JUKzIvNDg1ICgyMjAyKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAyXzJfUElECTB4MjIyMgkvKiBTZWFQT1JUKzIvNDg1ICgyMjAyKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAzXzFfUElECTB4MjIxMwkvKiBTZWFQT1JUKzIgKDIyMDMpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzIyMDNfMl9QSUQJMHgyMjIzCS8qIFNlYVBPUlQrMiAoMjIwMykgUG9ydCAyICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMV8xX1BJRAkweDI0MTEJLyogU2VhUE9SVCs0LzIzMiAoMjQwMSkgUG9ydCAxICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMV8yX1BJRAkweDI0MjEJLyogU2VhUE9SVCs0LzIzMiAoMjQwMSkgUG9ydCAyICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMV8zX1BJRAkweDI0MzEJLyogU2VhUE9SVCs0LzIzMiAoMjQwMSkgUG9ydCAzICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMV80X1BJRAkweDI0NDEJLyogU2VhUE9SVCs0LzIzMiAoMjQwMSkgUG9ydCA0ICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMl8xX1BJRAkweDI0MTIJLyogU2VhUE9SVCs0LzQ4NSAoMjQwMikgUG9ydCAxICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMl8yX1BJRAkweDI0MjIJLyogU2VhUE9SVCs0LzQ4NSAoMjQwMikgUG9ydCAyICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMl8zX1BJRAkweDI0MzIJLyogU2VhUE9SVCs0LzQ4NSAoMjQwMikgUG9ydCAzICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMl80X1BJRAkweDI0NDIJLyogU2VhUE9SVCs0LzQ4NSAoMjQwMikgUG9ydCA0ICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwM18xX1BJRAkweDI0MTMJLyogU2VhUE9SVCs0ICgyNDAzKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAzXzJfUElECTB4MjQyMwkvKiBTZWFQT1JUKzQgKDI0MDMpIFBvcnQgMiAqLwojZGVmaW5lIFNFQUxFVkVMXzI0MDNfM19QSUQJMHgyNDMzCS8qIFNlYVBPUlQrNCAoMjQwMykgUG9ydCAzICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwM180X1BJRAkweDI0NDMJLyogU2VhUE9SVCs0ICgyNDAzKSBQb3J0IDQgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzFfUElECTBYMjgxMQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzJfUElECTBYMjgyMQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzNfUElECTBYMjgzMQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDMgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzRfUElECTBYMjg0MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDQgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzVfUElECTBYMjg1MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDUgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzZfUElECTBYMjg2MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDYgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzdfUElECTBYMjg3MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDcgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzhfUElECTBYMjg4MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDggKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzFfUElECTBYMjgxMgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzJfUElECTBYMjgyMgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzNfUElECTBYMjgzMgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDMgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzRfUElECTBYMjg0MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDQgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzVfUElECTBYMjg1MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDUgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzZfUElECTBYMjg2MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDYgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzdfUElECTBYMjg3MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDcgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzhfUElECTBYMjg4MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDggKi8KI2RlZmluZSBTRUFMRVZFTF8yODAzXzFfUElECTBYMjgxMwkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfMl9QSUQJMFgyODIzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgMiAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfM19QSUQJMFgyODMzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgMyAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfNF9QSUQJMFgyODQzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgNCAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfNV9QSUQJMFgyODUzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgNSAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfNl9QSUQJMFgyODYzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgNiAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfN19QSUQJMFgyODczIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgNyAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfOF9QSUQJMFgyODgzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgOCAqLwoKLyoKICogVGhlIGZvbGxvd2luZyBhcmUgdGhlIHZhbHVlcyBmb3IgdHdvIEtPQklMIGNoaXBjYXJkIHRlcm1pbmFscy4KICovCiNkZWZpbmUgS09CSUxfVklECQkweDBkNDYJLyogS09CSUwgVmVuZG9yIElEICovCiNkZWZpbmUgS09CSUxfQ09OVl9CMV9QSUQJMHgyMDIwCS8qIEtPQklMIEtvbnZlcnRlciBmb3IgQjEgKi8KI2RlZmluZSBLT0JJTF9DT05WX0tBQU5fUElECTB4MjAyMQkvKiBLT0JJTF9Lb252ZXJ0ZXIgZm9yIEtBQU4gKi8KCi8qCiAqIEljb20gSUQtMSBkaWdpdGFsIHRyYW5zY2VpdmVyCiAqLwoKI2RlZmluZSBJQ09NX0lEMV9WSUQgICAgICAgICAgICAweDBDMjYKI2RlZmluZSBJQ09NX0lEMV9QSUQgICAgICAgICAgICAweDAwMDQKCi8qCiAqIEFTSy5mciBkZXZpY2VzCiAqLwojZGVmaW5lIEZURElfQVNLX1JEUjQwMF9QSUQJMHhDOTkxCS8qIEFTSyBSRFIgNDAwIHNlcmllcyBjYXJkIHJlYWRlciAqLwoKLyoKICogRFNTLTIwIFN5bmMgU3RhdGlvbiBmb3IgU29ueSBFcmljc3NvbiBQODAwCiAqLwogCiNkZWZpbmUgRlRESV9EU1MyMF9QSUQgICAgICAgICAgMHhGQzgyICAKCi8qCiAqIEhvbWUgRWxlY3Ryb25pY3MgKHd3dy5ob21lLWVsZWN0cm8uY29tKSBVU0IgZ2FkZ2V0cwogKi8KI2RlZmluZSBGVERJX0hFX1RJUkExX1BJRAkweEZBNzgJLyogVGlyYS0xIElSIHRyYW5zY2VpdmVyICovCgovKiBVU0ItVUlSVCAtIEFuIGluZnJhcmVkIHJlY2VpdmVyIGFuZCB0cmFuc21pdHRlciB1c2luZyB0aGUgOFUyMzJBTSBjaGlwICovCi8qIGh0dHA6Ly9ob21lLmVhcnRobGluay5uZXQvfmpyaGVlcy9VU0JVSVJUL2luZGV4Lmh0bSAqLwojZGVmaW5lIEZURElfVVNCX1VJUlRfUElECTB4Rjg1MAkvKiBQcm9kdWN0IElkICovCgovKgogKiBFTFYgVVNCIGRldmljZXMgc3VibWl0dGVkIGJ5IENocmlzdGlhbiBBYnQgb2YgRUxWICh3d3cuZWx2LmRlKS4KICogQWxsIG9mIHRoZXNlIGRldmljZXMgdXNlIEZUREkncyB2ZW5kb3IgSUQgKDB4MDQwMykuCiAqCiAqIFRoZSBwcmV2aW91c2x5IGluY2x1ZGVkIFBJRCBmb3IgdGhlIFVPIDEwMCBtb2R1bGUgd2FzIGluY29ycmVjdC4KICogSW4gZmFjdCwgdGhhdCBQSUQgd2FzIGZvciBFTFYncyBVUiAxMDAgVVNCLVJTMjMyIGNvbnZlcnRlciAoMHhGQjU4KS4KICoKICogQXJtaW4gTGFldWdlciBvcmlnaW5hbGx5IHNlbnQgdGhlIFBJRCBmb3IgdGhlIFVNIDEwMCBtb2R1bGUuCiAqLwojZGVmaW5lIEZURElfRUxWX1VSMTAwX1BJRAkweEZCNTgJLyogVVNCLVJTMjMyLVVtc2V0emVyIChVUiAxMDApICovCiNkZWZpbmUgRlRESV9FTFZfVU0xMDBfUElECTB4RkI1QQkvKiBVU0ItTW9kdWwgVU0gMTAwICovCiNkZWZpbmUgRlRESV9FTFZfVU8xMDBfUElECTB4RkI1QgkvKiBVU0ItTW9kdWwgVU8gMTAwICovCiNkZWZpbmUgRlRESV9FTFZfQUxDODUwMF9QSUQJMHhGMDZFCS8qIEFMQyA4NTAwIEV4cGVydCAqLwovKiBBZGRpdGlvbmFsIEVMViBQSURzIHRoYXQgZGVmYXVsdCB0byB1c2luZyB0aGUgRlRESSBEMlhYIGRyaXZlcnMgb24KICogTVMgV2luZG93cywgcmF0aGVyIHRoYW4gdGhlIEZUREkgVmlydHVhbCBDb20gUG9ydCBkcml2ZXJzLgogKiBNYXliZSB0aGVzZSB3aWxsIGJlIGVhc2llciB0byB1c2Ugd2l0aCB0aGUgbGliZnRkaS9saWJ1c2IgdXNlci1zcGFjZQogKiBkcml2ZXJzLCBvciBwb3NzaWJseSB0aGUgQ29tZWRpIGRyaXZlcnMgaW4gc29tZSBjYXNlcy4gKi8KI2RlZmluZSBGVERJX0VMVl9DTEk3MDAwX1BJRAkweEZCNTkJLyogQ29tcHV0ZXItTGlnaHQtSW50ZXJmYWNlIChDTEkgNzAwMCkgKi8KI2RlZmluZSBGVERJX0VMVl9QUFM3MzMwX1BJRAkweEZCNUMJLyogUHJvY2Vzc29yLVBvd2VyLVN1cHBseSAoUFBTIDczMzApICovCiNkZWZpbmUgRlRESV9FTFZfVEZNMTAwX1BJRAkweEZCNUQJLyogVGVtcGVyYXJ0dXItRmV1Y2h0ZSBNZXNzZ2VyYWV0IChURk0gMTAwKSAqLwojZGVmaW5lIEZURElfRUxWX1VERjc3X1BJRAkweEZCNUUJLyogVVNCIERDRiBGdW5rdXJoIChVREYgNzcpICovCiNkZWZpbmUgRlRESV9FTFZfVUlPODhfUElECTB4RkI1RgkvKiBVU0ItSS9PIEludGVyZmFjZSAoVUlPIDg4KSAqLwojZGVmaW5lIEZURElfRUxWX1VBRDhfUElECTB4RjA2OAkvKiBVU0ItQUQtV2FuZGxlciAoVUFEIDgpICovCiNkZWZpbmUgRlRESV9FTFZfVURBN19QSUQJMHhGMDY5CS8qIFVTQi1EQS1XYW5kbGVyIChVREEgNykgKi8KI2RlZmluZSBGVERJX0VMVl9VU0kyX1BJRAkweEYwNkEJLyogVVNCLVNjaHJpdHRtb3RvcmVuLUludGVyZmFjZSAoVVNJIDIpICovCiNkZWZpbmUgRlRESV9FTFZfVDExMDBfUElECTB4RjA2QgkvKiBUaGVybW9tZXRlciAoVCAxMTAwKSAqLwojZGVmaW5lIEZURElfRUxWX1BDRDIwMF9QSUQJMHhGMDZDCS8qIFBDLURhdGVubG9nZ2VyIChQQ0QgMjAwKSAqLwojZGVmaW5lIEZURElfRUxWX1VMQTIwMF9QSUQJMHhGMDZECS8qIFVTQi1MQ0QtQW5zdGV1ZXJ1bmcgKFVMQSAyMDApICovCiNkZWZpbmUgRlRESV9FTFZfRkhaMTAwMFBDX1BJRAkweEYwNkYJLyogRkhaIDEwMDAgUEMgKi8KI2RlZmluZSBGVERJX0VMVl9DU0k4X1BJRAkweEUwRjAJLyogQ29tcHV0ZXItU2NoYWx0LUludGVyZmFjZSAoQ1NJIDgpICovCiNkZWZpbmUgRlRESV9FTFZfRU0xMDAwRExfUElECTB4RTBGMQkvKiBQQy1EYXRlbmxvZ2dlciBmdWVyIEVuZXJnaWVtb25pdG9yIChFTSAxMDAwIERMKSAqLwojZGVmaW5lIEZURElfRUxWX1BDSzEwMF9QSUQJMHhFMEYyCS8qIFBDLUthYmVsdGVzdGVyIChQQ0sgMTAwKSAqLwojZGVmaW5lIEZURElfRUxWX1JGUDUwMF9QSUQJMHhFMEYzCS8qIEhGLUxlaXN0dW5nc21lc3NlciAoUkZQIDUwMCkgKi8KI2RlZmluZSBGVERJX0VMVl9GUzIwU0lHX1BJRAkweEUwRjQJLyogU2lnbmFsZ2ViZXIgKEZTIDIwIFNJRykgKi8KI2RlZmluZSBGVERJX0VMVl9XUzMwMFBDX1BJRAkweEUwRjYJLyogUEMtV2V0dGVyc3RhdGlvbiAoV1MgMzAwIFBDKSAqLwojZGVmaW5lIEZURElfRUxWX0ZIWjEzMDBQQ19QSUQJMHhFMEU4CS8qIEZIWiAxMzAwIFBDICovCiNkZWZpbmUgRlRESV9FTFZfV1M1MDBfUElECTB4RTBFOQkvKiBQQy1XZXR0ZXJzdGF0aW9uIChXUyA1MDApICovCgovKgogKiBEZWZpbml0aW9ucyBmb3IgSUQgVEVDSCAod3d3LmlkdC1uZXQuY29tKSBkZXZpY2VzCiAqLwojZGVmaW5lIElEVEVDSF9WSUQJCTB4MEFDRAkvKiBJRCBURUNIIFZlbmRvciBJRCAqLwojZGVmaW5lIElEVEVDSF9JRFQxMjIxVV9QSUQJMHgwMzAwCS8qIElEVDEyMjFVIFVTQiB0byBSUy0yMzIgYWRhcHRlciAqLwoKLyoKICogRGVmaW5pdGlvbnMgZm9yIE9tbmlkaXJlY3Rpb25hbCBDb250cm9sIFRlY2hub2xvZ3ksIEluYy4gZGV2aWNlcwogKi8KI2RlZmluZSBPQ1RfVklECQkJMHgwQjM5CS8qIE9DVCB2ZW5kb3IgSUQgKi8KLyogTm90ZTogT0NUIFVTMTAxIGlzIGFsc28gcmViYWRnZWQgYXMgRGljayBTbWl0aCBFbGVjdHJvbmljcyAoTlopIFhINjM4MSAqLwovKiBBbHNvIHJlYmFkZ2VkIGFzIERpY2sgU21pdGggRWxlY3Ryb25pY3MgKEF1cykgWEg2NDUxICovCi8qIEFsc28gcmViYWRnZWQgYXMgU0lJRyBJbmMuIG1vZGVsIFVTMjMwOCBoYXJkd2FyZSB2ZXJzaW9uIDEgKi8KI2RlZmluZSBPQ1RfVVMxMDFfUElECQkweDA0MjEJLyogT0NUIFVTMTAxIFVTQiB0byBSUy0yMzIgKi8KCi8qIGFuIGluZnJhcmVkIHJlY2VpdmVyIGZvciB1c2VyIGFjY2VzcyBjb250cm9sIHdpdGggSVIgdGFncyAqLwojZGVmaW5lIEZURElfUElFR1JPVVBfUElECTB4RjIwOAkvKiBQcm9kdWN0IElkICovCgovKgogKiBEZWZpbml0aW9ucyBmb3IgQXJ0ZW1pcyBhc3Ryb25vbWljYWwgVVNCIGJhc2VkIGNhbWVyYXMKICogQ2hlY2sgaXQgYXQgaHR0cDovL3d3dy5hcnRlbWlzY2NkLmNvLnVrLwogKi8KI2RlZmluZSBGVERJX0FSVEVNSVNfUElECTB4REYyOAkvKiBBbGwgQXJ0ZW1pcyBDYW1lcmFzICovCgovKgogKiBEZWZpbml0aW9ucyBmb3IgQVRJSyBJbnN0cnVtZW50cyBhc3Ryb25vbWljYWwgVVNCIGJhc2VkIGNhbWVyYXMKICogQ2hlY2sgaXQgYXQgaHR0cDovL3d3dy5hdGlrLWluc3RydW1lbnRzLmNvbS8KICovCiNkZWZpbmUgRlRESV9BVElLX0FUSzE2X1BJRAkweERGMzAJLyogQVRJSyBBVEstMTYgR3JheXNjYWxlIENhbWVyYSAqLwojZGVmaW5lIEZURElfQVRJS19BVEsxNkNfUElECTB4REYzMgkvKiBBVElLIEFUSy0xNkMgQ29sb3VyIENhbWVyYSAqLwojZGVmaW5lIEZURElfQVRJS19BVEsxNkhSX1BJRAkweERGMzEJLyogQVRJSyBBVEstMTZIUiBHcmF5c2NhbGUgQ2FtZXJhICovCiNkZWZpbmUgRlRESV9BVElLX0FUSzE2SFJDX1BJRAkweERGMzMJLyogQVRJSyBBVEstMTZIUkMgQ29sb3VyIENhbWVyYSAqLwoKLyoKICogUHJvdGVnbyBwcm9kdWN0IGlkcwogKi8KI2RlZmluZSBQUk9URUdPX1NQRUNJQUxfMQkweEZDNzAJLyogc3BlY2lhbC91bmtub3duIGRldmljZSAqLwojZGVmaW5lIFBST1RFR09fUjJYMAkJMHhGQzcxCS8qIFIyMDAtVVNCIFRSTkcgdW5pdCAoUjIxMCwgUjIyMCwgYW5kIFIyMzApICovCiNkZWZpbmUgUFJPVEVHT19TUEVDSUFMXzMJMHhGQzcyCS8qIHNwZWNpYWwvdW5rbm93biBkZXZpY2UgKi8KI2RlZmluZSBQUk9URUdPX1NQRUNJQUxfNAkweEZDNzMJLyogc3BlY2lhbC91bmtub3duIGRldmljZSAqLwoKLyoKICogR3VkZSBBbmFsb2ctIHVuZCBEaWdpdGFsc3lzdGVtZSBHbWJICiAqLwojZGVmaW5lIEZURElfR1VERUFEU19FODA4X1BJRCAgICAweEU4MDgKI2RlZmluZSBGVERJX0dVREVBRFNfRTgwOV9QSUQgICAgMHhFODA5CiNkZWZpbmUgRlRESV9HVURFQURTX0U4MEFfUElEICAgIDB4RTgwQQojZGVmaW5lIEZURElfR1VERUFEU19FODBCX1BJRCAgICAweEU4MEIKI2RlZmluZSBGVERJX0dVREVBRFNfRTgwQ19QSUQgICAgMHhFODBDCiNkZWZpbmUgRlRESV9HVURFQURTX0U4MERfUElEICAgIDB4RTgwRAojZGVmaW5lIEZURElfR1VERUFEU19FODBFX1BJRCAgICAweEU4MEUKI2RlZmluZSBGVERJX0dVREVBRFNfRTgwRl9QSUQgICAgMHhFODBGCiNkZWZpbmUgRlRESV9HVURFQURTX0U4ODhfUElEICAgIDB4RTg4OCAgLyogRXhwZXJ0IElTRE4gQ29udHJvbCBVU0IgKi8KI2RlZmluZSBGVERJX0dVREVBRFNfRTg4OV9QSUQgICAgMHhFODg5ICAvKiBVU0IgUlMtMjMyIE9wdG9CcmlkZ2UgKi8KI2RlZmluZSBGVERJX0dVREVBRFNfRTg4QV9QSUQgICAgMHhFODhBCiNkZWZpbmUgRlRESV9HVURFQURTX0U4OEJfUElEICAgIDB4RTg4QgojZGVmaW5lIEZURElfR1VERUFEU19FODhDX1BJRCAgICAweEU4OEMKI2RlZmluZSBGVERJX0dVREVBRFNfRTg4RF9QSUQgICAgMHhFODhECiNkZWZpbmUgRlRESV9HVURFQURTX0U4OEVfUElEICAgIDB4RTg4RQojZGVmaW5lIEZURElfR1VERUFEU19FODhGX1BJRCAgICAweEU4OEYKCi8qCiAqIExpbnggVGVjaG5vbG9naWVzIHByb2R1Y3QgaWRzCiAqLwojZGVmaW5lIExJTlhfU0RNVVNCUVNTX1BJRAkweEY0NDgJLyogTGlueCBTRE0tVVNCLVFTLVMgKi8KI2RlZmluZSBMSU5YX01BU1RFUkRFVkVMMl9QSUQgICAweEY0NDkgICAvKiBMaW54IE1hc3RlciBEZXZlbG9wbWVudCAyLjAgKi8KI2RlZmluZSBMSU5YX0ZVVFVSRV8wX1BJRCAgIDB4RjQ0QSAgIC8qIExpbnggZnV0dXJlIGRldmljZSAqLwojZGVmaW5lIExJTlhfRlVUVVJFXzFfUElEICAgMHhGNDRCICAgLyogTGlueCBmdXR1cmUgZGV2aWNlICovCiNkZWZpbmUgTElOWF9GVVRVUkVfMl9QSUQgICAweEY0NEMgICAvKiBMaW54IGZ1dHVyZSBkZXZpY2UgKi8KCi8qIENDUyBJbmMuIElDRFUvSUNEVTQwIHByb2R1Y3QgSUQgLSB0aGUgRlQyMzJCTSBpcyB1c2VkIGluIGFuIGluLWNpcmN1aXQtZGVidWdnZXIgKi8KLyogdW5pdCBmb3IgUElDMTYncy9QSUMxOCdzICovCiNkZWZpbmUgRlRESV9DQ1NJQ0RVMjBfMF9QSUQgICAgMHhGOUQwICAgICAKI2RlZmluZSBGVERJX0NDU0lDRFU0MF8xX1BJRCAgICAweEY5RDEgICAgIAoKLyogSW5zaWRlIEFjY2Vzc28gY29udGFjdGxlc3MgcmVhZGVyIChodHRwOi8vd3d3Lmluc2lkZWZyLmNvbSkgKi8KI2RlZmluZSBJTlNJREVfQUNDRVNTTwkJMHhGQUQwCgovKgogKiBJbnRyZXBpZCBDb250cm9sIFN5c3RlbXMgKGh0dHA6Ly93d3cuaW50cmVwaWRjcy5jb20vKSBWYWx1ZUNBTiBhbmQgTmVvVkkKICovCiNkZWZpbmUgSU5UUkVQSURfVklECQkweDA5M0MKI2RlZmluZSBJTlRSRVBJRF9WQUxVRUNBTl9QSUQJMHgwNjAxCiNkZWZpbmUgSU5UUkVQSURfTkVPVklfUElECTB4MDcwMQoKLyoKICogRmFsY29tIFdpcmVsZXNzIENvbW11bmljYXRpb25zIEdtYkgKICovCiNkZWZpbmUgRkFMQ09NX1ZJRAkJMHgwRjk0CS8qIFZlbmRvciBJZCAqLwojZGVmaW5lIEZBTENPTV9UV0lTVF9QSUQJMHgwMDAxCS8qIEZhbGNvbSBUd2lzdCBVU0IgR1BSUyBtb2RlbSAqLwojZGVmaW5lIEZBTENPTV9TQU1CQV9QSUQJMHgwMDA1CS8qIEZhbGNvbSBTYW1iYSBVU0IgR1BSUyBtb2RlbSAqLwoKLyoKICogU1VVTlRPIHByb2R1Y3QgaWRzCiAqLwojZGVmaW5lIEZURElfU1VVTlRPX1NQT1JUU19QSUQJMHhGNjgwCS8qIFN1dW50byBTcG9ydHMgaW5zdHJ1bWVudCAqLwoKLyoKICogRGVmaW5pdGlvbnMgZm9yIEImQiBFbGVjdHJvbmljcyBwcm9kdWN0cy4KICovCiNkZWZpbmUgQkFOREJfVklECQkweDA4NTYJLyogQiZCIEVsZWN0cm9uaWNzIFZlbmRvciBJRCAqLwojZGVmaW5lIEJBTkRCX1VTT1RMNF9QSUQJMHhBQzAxCS8qIFVTT1RMNCBJc29sYXRlZCBSUy00ODUgQ29udmVydGVyICovCiNkZWZpbmUgQkFOREJfVVNUTDRfUElECQkweEFDMDIJLyogVVNUTDQgUlMtNDg1IENvbnZlcnRlciAqLwojZGVmaW5lIEJBTkRCX1VTTzlNTDJfUElECTB4QUMwMwkvKiBVU085TUwyIElzb2xhdGVkIFJTLTIzMiBDb252ZXJ0ZXIgKi8KCi8qCiAqIFJNIE1pY2hhZWxpZGVzIENBTnZpZXcgVVNCIChodHRwOi8vd3d3LnJtY2FuLmNvbSkKICogQ0FOIGZpZWxkYnVzIGludGVyZmFjZSBhZGFwdGVyLCBhZGRlZCBieSBwb3J0IEdtYkggd3d3LnBvcnQuZGUpCiAqIElhbiBBYmJvdHQgY2hhbmdlZCB0aGUgbWFjcm8gbmFtZXMgZm9yIGNvbnNpc3RlbmN5LgogKi8KI2RlZmluZSBGVERJX1JNX0NBTlZJRVdfUElECTB4ZmQ2MAkvKiBQcm9kdWN0IElkICovCgovKgogKiBFVkVSIEVjbyBQcm8gVVBTIChodHRwOi8vd3d3LmV2ZXIuY29tLnBsLykKICovCgojZGVmaW5lCUVWRVJfRUNPX1BST19DRFMJMHhlNTIwCS8qIFJTLTIzMiBjb252ZXJ0ZXIgKi8KCi8qCiAqIDROLUdBTEFYWS5ERSBQSURzIGZvciBDQU4tVVNCLCBVU0ItUlMyMzIsIFVTQi1SUzQyMiwgVVNCLVJTNDg1LAogKiBVU0ItVFRZIGFjdGl2LCBVU0ItVFRZIHBhc3Npdi4gIFNvbWUgUElEcyBhcmUgdXNlZCBieSBzZXZlcmFsIGRldmljZXMKICogYW5kIEknbSBub3QgZW50aXJlbHkgc3VyZSB3aGljaCBhcmUgdXNlZCBieSB3aGljaC4KICovCiNkZWZpbmUgRlRESV80Tl9HQUxBWFlfREVfMF9QSUQJMHg4MzcyCiNkZWZpbmUgRlRESV80Tl9HQUxBWFlfREVfMV9QSUQJMHhGM0MwCiNkZWZpbmUgRlRESV80Tl9HQUxBWFlfREVfMl9QSUQJMHhGM0MxCgovKgogKiBNb2JpbGl0eSBFbGVjdHJvbmljcyBwcm9kdWN0cy4KICovCiNkZWZpbmUgTU9CSUxJVFlfVklECQkJMHgxMzQyCiNkZWZpbmUgTU9CSUxJVFlfVVNCX1NFUklBTF9QSUQJCTB4MDIwMgkvKiBFYXNpRG9jayBVU0IgMjAwIHNlcmlhbCAqLwoKLyoKICogbWljcm9IQU0gcHJvZHVjdCBJRHMgKGh0dHA6Ly93d3cubWljcm9oYW0uY29tKS4KICogU3VibWl0dGVkIGJ5IEp1c3RpbiBCdXJrZXQgKEtMMVJMKSA8em9ydG9uQGp0YW4uY29tPgogKiBhbmQgTWlrZSBTdHVkZXIgKEs2RUVQKSA8azZlZXBAaGFtc29mdHdhcmUub3JnPi4KICogSWFuIEFiYm90dCA8YWJib3R0aUBtZXYuY28udWs+IGFkZGVkIGEgZmV3IG1vcmUgZnJvbSB0aGUgZHJpdmVyIElORiBmaWxlLgogKi8KI2RlZmluZSBGVERJX01IQU1fS1dfUElEIDB4RUVFOAkJLyogVVNCLUtXIGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9ZU19QSUQgMHhFRUU5CQkvKiBVU0ItWVMgaW50ZXJmYWNlICovCiNkZWZpbmUgRlRESV9NSEFNX1k2X1BJRCAweEVFRUEJCS8qIFVTQi1ZNiBpbnRlcmZhY2UgKi8KI2RlZmluZSBGVERJX01IQU1fWThfUElEIDB4RUVFQgkJLyogVVNCLVk4IGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9JQ19QSUQgMHhFRUVDCQkvKiBVU0ItSUMgaW50ZXJmYWNlICovCiNkZWZpbmUgRlRESV9NSEFNX0RCOV9QSUQgMHhFRUVECS8qIFVTQi1EQjkgaW50ZXJmYWNlICovCiNkZWZpbmUgRlRESV9NSEFNX1JTMjMyX1BJRCAweEVFRUUJLyogVVNCLVJTMjMyIGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9ZOV9QSUQgMHhFRUVGCQkvKiBVU0ItWTkgaW50ZXJmYWNlICovCgovKgogKiBBY3RpdmUgUm9ib3RzIHByb2R1Y3QgaWRzLgogKi8KI2RlZmluZSBGVERJX0FDVElWRV9ST0JPVFNfUElECTB4RTU0OAkvKiBVU0IgY29tbXMgYm9hcmQgKi8KCi8qCiAqIFhzZW5zIFRlY2hub2xvZ2llcyBCViBwcm9kdWN0cyAoaHR0cDovL3d3dy54c2Vucy5jb20pLgogKi8KI2RlZmluZSBYU0VOU19DT05WRVJURVJfMF9QSUQJMHhEMzg4CiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzFfUElECTB4RDM4OQojZGVmaW5lIFhTRU5TX0NPTlZFUlRFUl8yX1BJRAkweEQzOEEKI2RlZmluZSBYU0VOU19DT05WRVJURVJfM19QSUQJMHhEMzhCCiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzRfUElECTB4RDM4QwojZGVmaW5lIFhTRU5TX0NPTlZFUlRFUl81X1BJRAkweEQzOEQKI2RlZmluZSBYU0VOU19DT05WRVJURVJfNl9QSUQJMHhEMzhFCiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzdfUElECTB4RDM4RgoKLyoKICogVGVyYXRyb25payBwcm9kdWN0IGlkcy4KICogU3VibWl0dGVkIGJ5IE8uIFf2bGZlbHNjaG5laWRlci4KICovCiNkZWZpbmUgRlRESV9URVJBVFJPTklLX1ZDUF9QSUQJIDB4RUM4OAkvKiBUZXJhdHJvbmlrIGRldmljZSAocHJlZmVycmluZyBWQ1AgZHJpdmVyIG9uIHdpbmRvd3MpICovCiNkZWZpbmUgRlRESV9URVJBVFJPTklLX0QyWFhfUElEIDB4RUM4OQkvKiBUZXJhdHJvbmlrIGRldmljZSAocHJlZmVycmluZyBEMlhYIGRyaXZlciBvbiB3aW5kb3dzKSAqLwoKLyoKICogRXZvbHV0aW9uIFJvYm90aWNzIHByb2R1Y3RzIChodHRwOi8vd3d3LmV2b2x1dGlvbi5jb20vKS4KICogU3VibWl0dGVkIGJ5IFNoYXduIE0uIExhdmVsbGUuCiAqLwojZGVmaW5lIEVWT0xVVElPTl9WSUQJCTB4REVFRQkvKiBWZW5kb3IgSUQgKi8KI2RlZmluZSBFVk9MVVRJT05fRVIxX1BJRAkweDAzMDAJLyogRVIxIENvbnRyb2wgTW9kdWxlICovCgovKiBQeXJhbWlkIENvbXB1dGVyIEdtYkggKi8KI2RlZmluZSBGVERJX1BZUkFNSURfUElECTB4RTZDOAkvKiBQeXJhbWlkIEFwcGxpYW5jZSBEaXNwbGF5ICovCgovKgogKiBQb3NpZmxleCBpbmMgcmV0YWlsIGVxdWlwbWVudCAoaHR0cDovL3d3dy5wb3NpZmxleC5jb20udHcpCiAqLwojZGVmaW5lIFBPU0lGTEVYX1ZJRAkJMHgwZDNhICAvKiBWZW5kb3IgSUQgKi8KI2RlZmluZSBQT1NJRkxFWF9QUDcwMDBfUElECTB4MDMwMCAgLyogUFAtNzAwMElJIHRoZXJtYWwgcHJpbnRlciAqLwoKLyoKICogV2VzdHJleCBJbnRlcm5hdGlvbmFsIGRldmljZXMgc3VibWl0dGVkIGJ5IENvcnkgTGVlCiAqLwojZGVmaW5lIEZURElfV0VTVFJFWF9NT0RFTF83NzdfUElECTB4REMwMAkvKiBNb2RlbCA3NzcgKi8KI2RlZmluZSBGVERJX1dFU1RSRVhfTU9ERUxfODkwMEZfUElECTB4REMwMQkvKiBNb2RlbCA4OTAwRiAqLwoKLyoKICogUlItQ2lyS2l0cyBMb2NvQnVmZmVyIFVTQiAoaHR0cDovL3d3dy5yci1jaXJraXRzLmNvbSkKICovCiNkZWZpbmUgRlRESV9SUkNJUktJVFNfTE9DT0JVRkZFUl9QSUQJMHhjN2QwCS8qIExvY29CdWZmZXIgVVNCICovCgovKgogKiBFY2xvIChodHRwOi8vd3d3LmVjbG8ucHQvKSBwcm9kdWN0IElEcy4KICogUElEIDB4RUE5MCBzdWJtaXR0ZWQgYnkgTWFydGluIEdyaWxsLgogKi8KI2RlZmluZSBGVERJX0VDTE9fQ09NXzFXSVJFX1BJRAkweEVBOTAJLyogQ09NIHRvIDEtV2lyZSBVU0IgYWRhcHRvciAqLwoKLyoKICogUGFwb3VjaCBwcm9kdWN0cyAoaHR0cDovL3d3dy5wYXBvdWNoLmNvbS8pCiAqIFN1Ym1pdHRlZCBieSBGb2xrZXJ0IHZhbiBIZXVzZGVuCiAqLwoKI2RlZmluZSBQQVBPVUNIX1ZJRAkJCTB4NTA1MAkvKiBWZW5kb3IgSUQgKi8KI2RlZmluZSBQQVBPVUNIX1RNVV9QSUQJCQkweDA0MDAJLyogVE1VIFVTQiBUaGVybW9tZXRlciAqLwoKLyoKICogQUNHIElkZW50aWZpY2F0aW9uIFRlY2hub2xvZ2llcyBHbWJIIHByb2R1Y3RzIChodHRwOi8vd3d3LmFjZy5kZS8pLgogKiBTdWJtaXR0ZWQgYnkgYW50b24gLWF0LSBnb3RvMTAgLWRvdC0gb3JnLgogKi8KI2RlZmluZSBGVERJX0FDR19IRkRVQUxfUElECQkweEREMjAJLyogSEYgRHVhbCBJU08gUmVhZGVyIChSRklEKSAqLwoKLyogQ29tbWFuZHMgKi8KI2RlZmluZSBGVERJX1NJT19SRVNFVCAJCTAgLyogUmVzZXQgdGhlIHBvcnQgKi8KI2RlZmluZSBGVERJX1NJT19NT0RFTV9DVFJMIAkxIC8qIFNldCB0aGUgbW9kZW0gY29udHJvbCByZWdpc3RlciAqLwojZGVmaW5lIEZURElfU0lPX1NFVF9GTE9XX0NUUkwJMiAvKiBTZXQgZmxvdyBjb250cm9sIHJlZ2lzdGVyICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0JBVURfUkFURQkzIC8qIFNldCBiYXVkIHJhdGUgKi8KI2RlZmluZSBGVERJX1NJT19TRVRfREFUQQk0IC8qIFNldCB0aGUgZGF0YSBjaGFyYWN0ZXJpc3RpY3Mgb2YgdGhlIHBvcnQgKi8KI2RlZmluZSBGVERJX1NJT19HRVRfTU9ERU1fU1RBVFVTCTUgLyogUmV0cmlldmUgY3VycmVudCB2YWx1ZSBvZiBtb2Rlcm4gc3RhdHVzIHJlZ2lzdGVyICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0VWRU5UX0NIQVIJNiAvKiBTZXQgdGhlIGV2ZW50IGNoYXJhY3RlciAqLwojZGVmaW5lIEZURElfU0lPX1NFVF9FUlJPUl9DSEFSCTcgLyogU2V0IHRoZSBlcnJvciBjaGFyYWN0ZXIgKi8KI2RlZmluZSBGVERJX1NJT19TRVRfTEFURU5DWV9USU1FUgk5IC8qIFNldCB0aGUgbGF0ZW5jeSB0aW1lciAqLwojZGVmaW5lIEZURElfU0lPX0dFVF9MQVRFTkNZX1RJTUVSCTEwIC8qIEdldCB0aGUgbGF0ZW5jeSB0aW1lciAqLwoKCi8qCiAqICAgQm1SZXF1ZXN0VHlwZTogIDExMDAgMDAwMGIKICogICBiUmVxdWVzdDogICAgICAgRlRESV9FMl9SRUFECiAqICAgd1ZhbHVlOiAgICAgICAgIDAKICogICB3SW5kZXg6ICAgICAgICAgQWRkcmVzcyBvZiB3b3JkIHRvIHJlYWQKICogICB3TGVuZ3RoOiAgICAgICAgMgogKiAgIERhdGE6ICAgICAgICAgICBXaWxsIHJldHVybiBhIHdvcmQgb2YgZGF0YSBmcm9tIEUyQWRkcmVzcwogKgogKi8KCi8qIFBvcnQgSWRlbnRpZmllciBUYWJsZSAqLwojZGVmaW5lIFBJVF9ERUZBVUxUIAkJMCAvKiBTSU9BICovCiNkZWZpbmUgUElUX1NJT0EJCTEgLyogU0lPQSAqLwovKiBUaGUgZGV2aWNlIHRoaXMgZHJpdmVyIGlzIHRlc3RlZCB3aXRoIG9uZSBoYXMgb25seSBvbmUgcG9ydCAqLwojZGVmaW5lIFBJVF9TSU9CCQkyIC8qIFNJT0IgKi8KI2RlZmluZSBQSVRfUEFSQUxMRUwJCTMgLyogUGFyYWxsZWwgKi8KCi8qIEZURElfU0lPX1JFU0VUICovCiNkZWZpbmUgRlRESV9TSU9fUkVTRVRfUkVRVUVTVCBGVERJX1NJT19SRVNFVAojZGVmaW5lIEZURElfU0lPX1JFU0VUX1JFUVVFU1RfVFlQRSAweDQwCiNkZWZpbmUgRlRESV9TSU9fUkVTRVRfU0lPIDAKI2RlZmluZSBGVERJX1NJT19SRVNFVF9QVVJHRV9SWCAxCiNkZWZpbmUgRlRESV9TSU9fUkVTRVRfUFVSR0VfVFggMgoKLyoKICogQm1SZXF1ZXN0VHlwZTogIDAxMDAgMDAwMEIKICogYlJlcXVlc3Q6ICAgICAgIEZURElfU0lPX1JFU0VUCiAqIHdWYWx1ZTogICAgICAgICBDb250cm9sIFZhbHVlIAogKiAgICAgICAgICAgICAgICAgICAwID0gUmVzZXQgU0lPCiAqICAgICAgICAgICAgICAgICAgIDEgPSBQdXJnZSBSWCBidWZmZXIKICogICAgICAgICAgICAgICAgICAgMiA9IFB1cmdlIFRYIGJ1ZmZlcgogKiB3SW5kZXg6ICAgICAgICAgUG9ydAogKiB3TGVuZ3RoOiAgICAgICAgMAogKiBEYXRhOiAgICAgICAgICAgTm9uZQogKgogKiBUaGUgUmVzZXQgU0lPIGNvbW1hbmQgaGFzIHRoaXMgZWZmZWN0OgogKgogKiAgICBTZXRzIGZsb3cgY29udHJvbCBzZXQgdG8gJ25vbmUnCiAqICAgIEV2ZW50IGNoYXIgPSAkMEQKICogICAgRXZlbnQgdHJpZ2dlciA9IGRpc2FibGVkCiAqICAgIFB1cmdlIFJYIGJ1ZmZlcgogKiAgICBQdXJnZSBUWCBidWZmZXIKICogICAgQ2xlYXIgRFRSCiAqICAgIENsZWFyIFJUUwogKiAgICBiYXVkIGFuZCBkYXRhIGZvcm1hdCBub3QgcmVzZXQKICoKICogVGhlIFB1cmdlIFJYIGFuZCBUWCBidWZmZXIgY29tbWFuZHMgYWZmZWN0IG5vdGhpbmcgZXhjZXB0IHRoZSBidWZmZXJzCiAqCiAgICovCgovKiBGVERJX1NJT19TRVRfQkFVRFJBVEUgKi8KI2RlZmluZSBGVERJX1NJT19TRVRfQkFVRFJBVEVfUkVRVUVTVF9UWVBFIDB4NDAKI2RlZmluZSBGVERJX1NJT19TRVRfQkFVRFJBVEVfUkVRVUVTVCAzCgovKgogKiBCbVJlcXVlc3RUeXBlOiAgMDEwMCAwMDAwQgogKiBiUmVxdWVzdDogICAgICAgRlRESV9TSU9fU0VUX0JBVURSQVRFCiAqIHdWYWx1ZTogICAgICAgICBCYXVkRGl2aXNvciB2YWx1ZSAtIHNlZSBiZWxvdwogKiB3SW5kZXg6ICAgICAgICAgUG9ydAogKiB3TGVuZ3RoOiAgICAgICAgMAogKiBEYXRhOiAgICAgICAgICAgTm9uZQogKiBUaGUgQmF1ZERpdmlzb3IgdmFsdWVzIGFyZSBjYWxjdWxhdGVkIGFzIGZvbGxvd3M6CiAqIC0gQmFzZUNsb2NrIGlzIGVpdGhlciAxMjAwMDAwMCBvciA0ODAwMDAwMCBkZXBlbmRpbmcgb24gdGhlIGRldmljZS4gRklYTUU6IEkgd2lzaAogKiAgIEkga25ldyBob3cgdG8gZGV0ZWN0IG9sZCBjaGlwcyB0byBzZWxlY3QgcHJvcGVyIGJhc2UgY2xvY2shCiAqIC0gQmF1ZERpdmlzb3IgaXMgYSBmaXhlZCBwb2ludCBudW1iZXIgZW5jb2RlZCBpbiBhIGZ1bm55IHdheS4KICogICAoLS1XUk9ORyBXQVkgT0YgVEhJTktJTkctLSkKICogICBCYXVkRGl2aXNvciBpcyBhIGZpeGVkIHBvaW50IG51bWJlciBlbmNvZGVkIHdpdGggZm9sbG93aW5nIGJpdCB3ZWlnaHM6CiAqICAgKC0yKSgtMSkoMTMuLjApLiBJdCBpcyBhIHJhZGljYWwgd2l0aCBhIGRlbm9taW5hdG9yIG9mIDQsIHNvIHZhbHVlcwogKiAgIGVuZCB3aXRoIDAuMCAoMDAuLi4pLCAwLjI1ICgxMC4uLiksIDAuNSAoMDEuLi4pLCBhbmQgMC43NSAoMTEuLi4pLgogKiAgICgtLVRIRSBSRUFMSVRZLS0pCiAqICAgVGhlIGJvdGgtYml0cy1zZXQgaGFzIHF1aXRlIGRpZmZlcmVudCBtZWFuaW5nIGZyb20gMC43NSAtIHRoZSBjaGlwIGRlc2lnbmVycwogKiAgIGhhdmUgZGVjaWRlZCBpdCB0byBtZWFuIDAuMTI1IGluc3RlYWQgb2YgMC43NS4KICogICBUaGlzIGluZm8gbG9va2VkIHVwIGluIEZUREkgYXBwbGljYXRpb24gbm90ZSAiRlQ4VTIzMiBERVZJQ0VTIFwgRGF0YSBSYXRlcwogKiAgIGFuZCBGbG93IENvbnRyb2wgQ29uc2lkZXJhdGlvbiBmb3IgVVNCIHRvIFJTMjMyIi4KICogLSBCYXVkRGl2aXNvciA9IChCYXNlQ2xvY2sgLyAxNikgLyBCYXVkUmF0ZSwgd2hlcmUgdGhlICg9KSBvcGVyYXRpb24gc2hvdWxkCiAqICAgYXV0b21hZ2ljYWxseSByZS1lbmNvZGUgdGhlIHJlc3VsdGluZyB2YWx1ZSB0byB0YWtlIGZyYWN0aW9ucyBpbnRvIGNvbnNpZGVyYXRpb24uCiAqIEFzIGFsbCB2YWx1ZXMgYXJlIGludGVnZXJzLCBzb21lIGJpdCB0d2lkZGxpbmcgaXMgaW4gb3JkZXI6CiAqICAgQmF1ZERpdmlzb3IgPSAoQmFzZUNsb2NrIC8gMTYgLyBCYXVkUmF0ZSkgfAogKiAgICgoKEJhc2VDbG9jayAvIDIgLyBCYXVkUmF0ZSkgJiA0KSA/IDB4NDAwMCAgICAvLyAwLjUKICogICAgOiAoKEJhc2VDbG9jayAvIDIgLyBCYXVkUmF0ZSkgJiAyKSA/IDB4ODAwMCAgLy8gMC4yNQogKiAgICA6ICgoQmFzZUNsb2NrIC8gMiAvIEJhdWRSYXRlKSAmIDEpID8gMHhjMDAwICAvLyAwLjEyNQogKiAgICA6IDApCiAqCiAqIEZvciB0aGUgRlQyMzJCTSwgYSAxN3RoIGRpdmlzb3IgYml0IHdhcyBpbnRyb2R1Y2VkIHRvIGVuY29kZSB0aGUgbXVsdGlwbGVzCiAqIG9mIDAuMTI1IG1pc3NpbmcgZnJvbSB0aGUgRlQ4VTIzMkFNLiAgQml0cyAxNiB0byAxNCBhcmUgY29kZWQgYXMgZm9sbG93cwogKiAodGhlIGZpcnN0IGZvdXIgY29kZXMgYXJlIHRoZSBzYW1lIGFzIGZvciB0aGUgRlQ4VTIzMkFNLCB3aGVyZSBiaXQgMTYgaXMKICogYWx3YXlzIDApOgogKiAgIDAwMCAtIGFkZCAuMDAwIHRvIGRpdmlzb3IKICogICAwMDEgLSBhZGQgLjUwMCB0byBkaXZpc29yCiAqICAgMDEwIC0gYWRkIC4yNTAgdG8gZGl2aXNvcgogKiAgIDAxMSAtIGFkZCAuMTI1IHRvIGRpdmlzb3IKICogICAxMDAgLSBhZGQgLjM3NSB0byBkaXZpc29yCiAqICAgMTAxIC0gYWRkIC42MjUgdG8gZGl2aXNvcgogKiAgIDExMCAtIGFkZCAuNzUwIHRvIGRpdmlzb3IKICogICAxMTEgLSBhZGQgLjg3NSB0byBkaXZpc29yCiAqIEJpdHMgMTUgdG8gMCBvZiB0aGUgMTctYml0IGRpdmlzb3IgYXJlIHBsYWNlZCBpbiB0aGUgdXJiIHZhbHVlLiAgQml0IDE2IGlzIAogKiBwbGFjZWQgaW4gYml0IDAgb2YgdGhlIHVyYiBpbmRleC4KICoKICogTm90ZSB0aGF0IHRoZXJlIGFyZSBhIGNvdXBsZSBvZiBzcGVjaWFsIGNhc2VzIHRvIHN1cHBvcnQgdGhlIGhpZ2hlc3QgYmF1ZAogKiByYXRlcy4gIElmIHRoZSBjYWxjdWxhdGVkIGRpdmlzb3IgdmFsdWUgaXMgMSwgdGhpcyBuZWVkcyB0byBiZSByZXBsYWNlZCB3aXRoCiAqIDAuICBBZGRpdGlvbmFsbHkgZm9yIHRoZSBGVDIzMkJNLCBpZiB0aGUgY2FsY3VsYXRlZCBkaXZpc29yIHZhbHVlIGlzIDB4NDAwMQogKiAoMS41KSwgdGhpcyBuZWVkcyB0byBiZSByZXBsYWNlZCB3aXRoIDB4MDAwMSAoMSkgKGJ1dCB0aGlzIGRpdmlzb3IgdmFsdWUgaXMKICogbm90IHN1cHBvcnRlZCBieSB0aGUgRlQ4VTIzMkFNKS4KICovCgp0eXBlZGVmIGVudW0gewoJU0lPID0gMSwKCUZUOFUyMzJBTSA9IDIsCglGVDIzMkJNID0gMywKCUZUMjIzMkMgPSA0LAp9IGZ0ZGlfY2hpcF90eXBlX3Q7Cgp0eXBlZGVmIGVudW0gewogZnRkaV9zaW9fYjMwMCA9IDAsIAogZnRkaV9zaW9fYjYwMCA9IDEsIAogZnRkaV9zaW9fYjEyMDAgPSAyLAogZnRkaV9zaW9fYjI0MDAgPSAzLAogZnRkaV9zaW9fYjQ4MDAgPSA0LAogZnRkaV9zaW9fYjk2MDAgPSA1LAogZnRkaV9zaW9fYjE5MjAwID0gNiwKIGZ0ZGlfc2lvX2IzODQwMCA9IDcsCiBmdGRpX3Npb19iNTc2MDAgPSA4LAogZnRkaV9zaW9fYjExNTIwMCA9IDkKfSBGVERJX1NJT19iYXVkcmF0ZV90IDsKCi8qCiAqIFRoZSBmdGRpXzhVMjMyQU1feHhNSHpfYnl5eSBjb25zdGFudHMgaGF2ZSBiZWVuIHJlbW92ZWQuIFRoZSBlbmNvZGVkIGRpdmlzb3IgdmFsdWVzCiAqIGFyZSBjYWxjdWxhdGVkIGludGVybmFsbHkuCiAqLwoKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9SRVFVRVNUIEZURElfU0lPX1NFVF9EQVRBCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfUkVRVUVTVF9UWVBFIDB4NDAKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9QQVJJVFlfTk9ORSAoMHgwIDw8IDggKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1BBUklUWV9PREQgKDB4MSA8PCA4ICkKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9QQVJJVFlfRVZFTiAoMHgyIDw8IDggKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1BBUklUWV9NQVJLICgweDMgPDwgOCApCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfUEFSSVRZX1NQQUNFICgweDQgPDwgOCApCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfU1RPUF9CSVRTXzEgKDB4MCA8PCAxMSApCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfU1RPUF9CSVRTXzE1ICgweDEgPDwgMTEgKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1NUT1BfQklUU18yICgweDIgPDwgMTEgKQojZGVmaW5lIEZURElfU0lPX1NFVF9CUkVBSyAoMHgxIDw8IDE0KQovKiBGVERJX1NJT19TRVRfREFUQSAqLwoKLyoKICogQm1SZXF1ZXN0VHlwZTogIDAxMDAgMDAwMEIgCiAqIGJSZXF1ZXN0OiAgICAgICBGVERJX1NJT19TRVRfREFUQQogKiB3VmFsdWU6ICAgICAgICAgRGF0YSBjaGFyYWN0ZXJpc3RpY3MgKHNlZSBiZWxvdykKICogd0luZGV4OiAgICAgICAgIFBvcnQKICogd0xlbmd0aDogICAgICAgIDAKICogRGF0YTogICAgICAgICAgIE5vCiAqCiAqIERhdGEgY2hhcmFjdGVyaXN0aWNzCiAqCiAqICAgQjAuLjcgICBOdW1iZXIgb2YgZGF0YSBiaXRzCiAqICAgQjguLjEwICBQYXJpdHkKICogICAgICAgICAgIDAgPSBOb25lCiAqICAgICAgICAgICAxID0gT2RkCiAqICAgICAgICAgICAyID0gRXZlbgogKiAgICAgICAgICAgMyA9IE1hcmsKICogICAgICAgICAgIDQgPSBTcGFjZQogKiAgIEIxMS4uMTMgU3RvcCBCaXRzCiAqICAgICAgICAgICAwID0gMQogKiAgICAgICAgICAgMSA9IDEuNQogKiAgICAgICAgICAgMiA9IDIKICogICBCMTQKICogICAgICAgICAgIDEgPSBUWCBPTiAoYnJlYWspCiAqICAgICAgICAgICAwID0gVFggT0ZGIChub3JtYWwgc3RhdGUpCiAqICAgQjE1IFJlc2VydmVkCiAqCiAqLwoKCgovKiBGVERJX1NJT19NT0RFTV9DVFJMICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX01PREVNX0NUUkxfUkVRVUVTVF9UWVBFIDB4NDAKI2RlZmluZSBGVERJX1NJT19TRVRfTU9ERU1fQ1RSTF9SRVFVRVNUIEZURElfU0lPX01PREVNX0NUUkwKCi8qIAogKiBCbVJlcXVlc3RUeXBlOiAgIDAxMDAgMDAwMEIKICogYlJlcXVlc3Q6ICAgICAgICBGVERJX1NJT19NT0RFTV9DVFJMCiAqIHdWYWx1ZTogICAgICAgICAgQ29udHJvbFZhbHVlIChzZWUgYmVsb3cpCiAqIHdJbmRleDogICAgICAgICAgUG9ydAogKiB3TGVuZ3RoOiAgICAgICAgIDAKICogRGF0YTogICAgICAgICAgICBOb25lCiAqCiAqIE5PVEU6IElmIHRoZSBkZXZpY2UgaXMgaW4gUlRTL0NUUyBmbG93IGNvbnRyb2wsIHRoZSBSVFMgc2V0IGJ5IHRoaXMKICogY29tbWFuZCB3aWxsIGJlIElHTk9SRUQgd2l0aG91dCBhbiBlcnJvciBiZWluZyByZXR1cm5lZAogKiBBbHNvIC0geW91IGNhbiBub3Qgc2V0IERUUiBhbmQgUlRTIHdpdGggb25lIGNvbnRyb2wgbWVzc2FnZQogKi8KCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RUUl9NQVNLIDB4MQojZGVmaW5lIEZURElfU0lPX1NFVF9EVFJfSElHSCAoIDEgfCAoIEZURElfU0lPX1NFVF9EVFJfTUFTSyAgPDwgOCkpCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RUUl9MT1cgICggMCB8ICggRlRESV9TSU9fU0VUX0RUUl9NQVNLICA8PCA4KSkKI2RlZmluZSBGVERJX1NJT19TRVRfUlRTX01BU0sgMHgyCiNkZWZpbmUgRlRESV9TSU9fU0VUX1JUU19ISUdIICggMiB8ICggRlRESV9TSU9fU0VUX1JUU19NQVNLIDw8IDggKSkKI2RlZmluZSBGVERJX1NJT19TRVRfUlRTX0xPVyAoIDAgfCAoIEZURElfU0lPX1NFVF9SVFNfTUFTSyA8PCA4ICkpCgovKgogKiBDb250cm9sVmFsdWUKICogQjAgICAgRFRSIHN0YXRlCiAqICAgICAgICAgIDAgPSByZXNldAogKiAgICAgICAgICAxID0gc2V0CiAqIEIxICAgIFJUUyBzdGF0ZQogKiAgICAgICAgICAwID0gcmVzZXQKICogICAgICAgICAgMSA9IHNldAogKiBCMi4uNyBSZXNlcnZlZAogKiBCOCAgICBEVFIgc3RhdGUgZW5hYmxlCiAqICAgICAgICAgIDAgPSBpZ25vcmUKICogICAgICAgICAgMSA9IHVzZSBEVFIgc3RhdGUKICogQjkgICAgUlRTIHN0YXRlIGVuYWJsZQogKiAgICAgICAgICAwID0gaWdub3JlCiAqICAgICAgICAgIDEgPSB1c2UgUlRTIHN0YXRlCiAqIEIxMC4uMTUgUmVzZXJ2ZWQKICovCgovKiBGVERJX1NJT19TRVRfRkxPV19DVFJMICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0ZMT1dfQ1RSTF9SRVFVRVNUX1RZUEUgMHg0MAojZGVmaW5lIEZURElfU0lPX1NFVF9GTE9XX0NUUkxfUkVRVUVTVCBGVERJX1NJT19TRVRfRkxPV19DVFJMCiNkZWZpbmUgRlRESV9TSU9fRElTQUJMRV9GTE9XX0NUUkwgMHgwIAojZGVmaW5lIEZURElfU0lPX1JUU19DVFNfSFMgKDB4MSA8PCA4KQojZGVmaW5lIEZURElfU0lPX0RUUl9EU1JfSFMgKDB4MiA8PCA4KQojZGVmaW5lIEZURElfU0lPX1hPTl9YT0ZGX0hTICgweDQgPDwgOCkKLyoKICogICBCbVJlcXVlc3RUeXBlOiAgMDEwMCAwMDAwYgogKiAgIGJSZXF1ZXN0OiAgICAgICBGVERJX1NJT19TRVRfRkxPV19DVFJMCiAqICAgd1ZhbHVlOiAgICAgICAgIFhvZmYvWG9uCiAqICAgd0luZGV4OiAgICAgICAgIFByb3RvY29sL1BvcnQgLSBoSW5kZXggaXMgcHJvdG9jbCAvIGxJbmRleCBpcyBwb3J0CiAqICAgd0xlbmd0aDogICAgICAgIDAgCiAqICAgRGF0YTogICAgICAgICAgIE5vbmUKICoKICogaEluZGV4IHByb3RvY29sIGlzOgogKiAgIEIwIE91dHB1dCBoYW5kc2hha2luZyB1c2luZyBSVFMvQ1RTCiAqICAgICAgIDAgPSBkaXNhYmxlZAogKiAgICAgICAxID0gZW5hYmxlZAogKiAgIEIxIE91dHB1dCBoYW5kc2hha2luZyB1c2luZyBEVFIvRFNSCiAqICAgICAgIDAgPSBkaXNhYmxlZAogKiAgICAgICAxID0gZW5hYmxlZAogKiAgIEIyIFhvbi9Yb2ZmIGhhbmRzaGFraW5nCiAqICAgICAgIDAgPSBkaXNhYmxlZAogKiAgICAgICAxID0gZW5hYmxlZAogKgogKiBBIHZhbHVlIG9mIHplcm8gaW4gdGhlIGhJbmRleCBmaWVsZCBkaXNhYmxlcyBoYW5kc2hha2luZwogKgogKiBJZiBYb24vWG9mZiBoYW5kc2hha2luZyBpcyBzcGVjaWZpZWQsIHRoZSBoVmFsdWUgZmllbGQgc2hvdWxkIGNvbnRhaW4gdGhlIFhPRkYgY2hhcmFjdGVyIAogKiBhbmQgdGhlIGxWYWx1ZSBmaWVsZCBjb250YWlucyB0aGUgWE9OIGNoYXJhY3Rlci4KICovICAKIAovKgogKiBGVERJX1NJT19HRVRfTEFURU5DWV9USU1FUgogKgogKiBTZXQgdGhlIHRpbWVvdXQgaW50ZXJ2YWwuIFRoZSBGVERJIGNvbGxlY3RzIGRhdGEgZnJvbSB0aGUgc2xhdmUKICogZGV2aWNlLCB0cmFuc21pdHRpbmcgaXQgdG8gdGhlIGhvc3Qgd2hlbiBlaXRoZXIgQSkgNjIgYnl0ZXMgYXJlCiAqIHJlY2VpdmVkLCBvciBCKSB0aGUgdGltZW91dCBpbnRlcnZhbCBoYXMgZWxhcHNlZCBhbmQgdGhlIGJ1ZmZlcgogKiBjb250YWlucyBhdCBsZWFzdCAxIGJ5dGUuICBTZXR0aW5nIHRoaXMgdmFsdWUgdG8gYSBzbWFsbCBudW1iZXIKICogY2FuIGRyYW1hdGljYWxseSBpbXByb3ZlIHBlcmZvcm1hbmNlIGZvciBhcHBsaWNhdGlvbnMgd2hpY2ggc2VuZAogKiBzbWFsbCBwYWNrZXRzLCBzaW5jZSB0aGUgZGVmYXVsdCB2YWx1ZSBpcyAxNm1zLgogKi8KI2RlZmluZSAgRlRESV9TSU9fR0VUX0xBVEVOQ1lfVElNRVJfUkVRVUVTVCBGVERJX1NJT19HRVRfTEFURU5DWV9USU1FUgojZGVmaW5lICBGVERJX1NJT19HRVRfTEFURU5DWV9USU1FUl9SRVFVRVNUX1RZUEUgMHhDMAoKLyogCiAqICBCbVJlcXVlc3RUeXBlOiAgIDExMDAgMDAwMGIKICogIGJSZXF1ZXN0OiAgICAgICAgRlRESV9TSU9fR0VUX0xBVEVOQ1lfVElNRVIKICogIHdWYWx1ZTogICAgICAgICAgMAogKiAgd0luZGV4OiAgICAgICAgICBQb3J0CiAqICB3TGVuZ3RoOiAgICAgICAgIDAKICogIERhdGE6ICAgICAgICAgICAgbGF0ZW5jeSAob24gcmV0dXJuKQogKi8KCi8qIAogKiBGVERJX1NJT19TRVRfTEFURU5DWV9USU1FUgogKgogKiBTZXQgdGhlIHRpbWVvdXQgaW50ZXJ2YWwuIFRoZSBGVERJIGNvbGxlY3RzIGRhdGEgZnJvbSB0aGUgc2xhdmUKICogZGV2aWNlLCB0cmFuc21pdHRpbmcgaXQgdG8gdGhlIGhvc3Qgd2hlbiBlaXRoZXIgQSkgNjIgYnl0ZXMgYXJlCiAqIHJlY2VpdmVkLCBvciBCKSB0aGUgdGltZW91dCBpbnRlcnZhbCBoYXMgZWxhcHNlZCBhbmQgdGhlIGJ1ZmZlcgogKiBjb250YWlucyBhdCBsZWFzdCAxIGJ5dGUuICBTZXR0aW5nIHRoaXMgdmFsdWUgdG8gYSBzbWFsbCBudW1iZXIKICogY2FuIGRyYW1hdGljYWxseSBpbXByb3ZlIHBlcmZvcm1hbmNlIGZvciBhcHBsaWNhdGlvbnMgd2hpY2ggc2VuZAogKiBzbWFsbCBwYWNrZXRzLCBzaW5jZSB0aGUgZGVmYXVsdCB2YWx1ZSBpcyAxNm1zLgogKi8KI2RlZmluZSAgRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVJfUkVRVUVTVCBGVERJX1NJT19TRVRfTEFURU5DWV9USU1FUgojZGVmaW5lICBGVERJX1NJT19TRVRfTEFURU5DWV9USU1FUl9SRVFVRVNUX1RZUEUgMHg0MAoKLyogCiAqICBCbVJlcXVlc3RUeXBlOiAgIDAxMDAgMDAwMGIKICogIGJSZXF1ZXN0OiAgICAgICAgRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVIKICogIHdWYWx1ZTogICAgICAgICAgTGF0ZW5jeSAobWlsbGlzZWNvbmRzKQogKiAgd0luZGV4OiAgICAgICAgICBQb3J0CiAqICB3TGVuZ3RoOiAgICAgICAgIDAKICogIERhdGE6ICAgICAgICAgICAgTm9uZQogKgogKiB3VmFsdWU6CiAqICAgQjAuLjcgICBMYXRlbmN5IHRpbWVyCiAqICAgQjguLjE1ICAwCiAqCiAqLwoKLyoKICogRlRESV9TSU9fU0VUX0VWRU5UX0NIQVIgCiAqCiAqIFNldCB0aGUgc3BlY2lhbCBldmVudCBjaGFyYWN0ZXIgZm9yIHRoZSBzcGVjaWZpZWQgY29tbXVuaWNhdGlvbnMgcG9ydC4KICogSWYgdGhlIGRldmljZSBzZWVzIHRoaXMgY2hhcmFjdGVyIGl0IHdpbGwgaW1tZWRpYXRlbHkgcmV0dXJuIHRoZQogKiBkYXRhIHJlYWQgc28gZmFyIC0gcmF0aGVyIHRoYW4gd2FpdCA0MG1zIG9yIHVudGlsIDYyIGJ5dGVzIGFyZSByZWFkCiAqIHdoaWNoIGlzIHdoYXQgbm9ybWFsbHkgaGFwcGVucy4KICovCgoKI2RlZmluZSAgRlRESV9TSU9fU0VUX0VWRU5UX0NIQVJfUkVRVUVTVCBGVERJX1NJT19TRVRfRVZFTlRfQ0hBUgojZGVmaW5lICBGVERJX1NJT19TRVRfRVZFTlRfQ0hBUl9SRVFVRVNUX1RZUEUgMHg0MAoKCi8qIAogKiAgQm1SZXF1ZXN0VHlwZTogICAwMTAwIDAwMDBiCiAqICBiUmVxdWVzdDogICAgICAgIEZURElfU0lPX1NFVF9FVkVOVF9DSEFSCiAqICB3VmFsdWU6ICAgICAgICAgIEV2ZW50Q2hhcgogKiAgd0luZGV4OiAgICAgICAgICBQb3J0CiAqICB3TGVuZ3RoOiAgICAgICAgIDAKICogIERhdGE6ICAgICAgICAgICAgTm9uZQogKgogKiB3VmFsdWU6CiAqICAgQjAuLjcgICBFdmVudCBDaGFyYWN0ZXIKICogICBCOCAgICAgIEV2ZW50IENoYXJhY3RlciBQcm9jZXNzaW5nCiAqICAgICAgICAgICAgIDAgPSBkaXNhYmxlZAogKiAgICAgICAgICAgICAxID0gZW5hYmxlZAogKiAgIEI5Li4xNSAgUmVzZXJ2ZWQKICoKICovCiAgICAgICAgICAKLyogRlRESV9TSU9fU0VUX0VSUk9SX0NIQVIgKi8KCi8qIFNldCB0aGUgcGFyaXR5IGVycm9yIHJlcGxhY2VtZW50IGNoYXJhY3RlciBmb3IgdGhlIHNwZWNpZmllZCBjb21tdW5pY2F0aW9ucyBwb3J0ICovCgovKiAKICogIEJtUmVxdWVzdFR5cGU6ICAwMTAwIDAwMDBiCiAqICBiUmVxdWVzdDogICAgICAgRlRESV9TSU9fU0VUX0VWRU5UX0NIQVIKICogIHdWYWx1ZTogICAgICAgICBFcnJvciBDaGFyCiAqICB3SW5kZXg6ICAgICAgICAgUG9ydAogKiAgd0xlbmd0aDogICAgICAgIDAKICogIERhdGE6ICAgICAgICAgICBOb25lCiAqCiAqRXJyb3IgQ2hhcgogKiAgQjAuLjcgIEVycm9yIENoYXJhY3RlcgogKiAgQjggICAgIEVycm9yIENoYXJhY3RlciBQcm9jZXNzaW5nCiAqICAgICAgICAgICAwID0gZGlzYWJsZWQKICogICAgICAgICAgIDEgPSBlbmFibGVkCiAqICBCOS4uMTUgUmVzZXJ2ZWQKICoKICovCgovKiBGVERJX1NJT19HRVRfTU9ERU1fU1RBVFVTICovCi8qIFJldHJpZXZlIHRoZSBjdXJyZW50IHZhbHVlIG9mIHRoZSBtb2RlbSBzdGF0dXMgcmVnaXN0ZXIgKi8KCiNkZWZpbmUgRlRESV9TSU9fR0VUX01PREVNX1NUQVRVU19SRVFVRVNUX1RZUEUgMHhjMAojZGVmaW5lIEZURElfU0lPX0dFVF9NT0RFTV9TVEFUVVNfUkVRVUVTVCBGVERJX1NJT19HRVRfTU9ERU1fU1RBVFVTCiNkZWZpbmUgRlRESV9TSU9fQ1RTX01BU0sgMHgxMAojZGVmaW5lIEZURElfU0lPX0RTUl9NQVNLIDB4MjAKI2RlZmluZSBGVERJX1NJT19SSV9NQVNLICAweDQwCiNkZWZpbmUgRlRESV9TSU9fUkxTRF9NQVNLIDB4ODAKLyogCiAqICAgQm1SZXF1ZXN0VHlwZTogICAxMTAwIDAwMDBiCiAqICAgYlJlcXVlc3Q6ICAgICAgICBGVERJX1NJT19HRVRfTU9ERU1fU1RBVFVTCiAqICAgd1ZhbHVlOiAgICAgICAgICB6ZXJvCiAqICAgd0luZGV4OiAgICAgICAgICBQb3J0CiAqICAgd0xlbmd0aDogICAgICAgICAxCiAqICAgRGF0YTogICAgICAgICAgICBTdGF0dXMKICogCiAqIE9uZSBieXRlIG9mIGRhdGEgaXMgcmV0dXJuZWQgCiAqIEIwLi4zIDAKICogQjQgICAgQ1RTCiAqICAgICAgICAgMCA9IGluYWN0aXZlCiAqICAgICAgICAgMSA9IGFjdGl2ZQogKiBCNSAgICBEU1IKICogICAgICAgICAwID0gaW5hY3RpdmUKICogICAgICAgICAxID0gYWN0aXZlCiAqIEI2ICAgIFJpbmcgSW5kaWNhdG9yIChSSSkKICogICAgICAgICAwID0gaW5hY3RpdmUKICogICAgICAgICAxID0gYWN0aXZlCiAqIEI3ICAgIFJlY2VpdmUgTGluZSBTaWduYWwgRGV0ZWN0IChSTFNEKQogKiAgICAgICAgIDAgPSBpbmFjdGl2ZQogKiAgICAgICAgIDEgPSBhY3RpdmUgCiAqLwoKCgovKiBEZXNjcmlwdG9ycyByZXR1cm5lZCBieSB0aGUgZGV2aWNlIAogKiAKICogIERldmljZSBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCVNpemUJVmFsdWUJRGVzY3JpcHRpb24KICogMAliTGVuZ3RoCQkxCTB4MTIJU2l6ZSBvZiBkZXNjcmlwdG9yIGluIGJ5dGVzCiAqIDEJYkRlc2NyaXB0b3JUeXBlCTEJMHgwMQlERVZJQ0UgRGVzY3JpcHRvciBUeXBlCiAqIDIJYmNkVVNCCQkyCTB4MDExMAlVU0IgU3BlYyBSZWxlYXNlIE51bWJlcgogKiA0CWJEZXZpY2VDbGFzcwkxCTB4MDAJQ2xhc3MgQ29kZQogKiA1CWJEZXZpY2VTdWJDbGFzcwkxCTB4MDAJU3ViQ2xhc3MgQ29kZQogKiA2CWJEZXZpY2VQcm90b2NvbAkxCTB4MDAJUHJvdG9jb2wgQ29kZQogKiA3CWJNYXhQYWNrZXRTaXplMCAxCTB4MDgJTWF4aW11bSBwYWNrZXQgc2l6ZSBmb3IgZW5kcG9pbnQgMAogKiA4CWlkVmVuZG9yCTIJMHgwNDAzCVZlbmRvciBJRAogKiAxMAlpZFByb2R1Y3QJMgkweDgzNzIJUHJvZHVjdCBJRCAoRlRESV9TSU9fUElEKQogKiAxMgliY2REZXZpY2UJMgkweDAwMDEJRGV2aWNlIHJlbGVhc2UgbnVtYmVyCiAqIDE0CWlNYW51ZmFjdHVyZXIJMQkweDAxCUluZGV4IG9mIG1hbi4gc3RyaW5nIGRlc2MKICogMTUJaVByb2R1Y3QJMQkweDAyCUluZGV4IG9mIHByb2Qgc3RyaW5nIGRlc2MKICogMTYJaVNlcmlhbE51bWJlcgkxCTB4MDIJSW5kZXggb2Ygc2VyaWFsIG5tciBzdHJpbmcgZGVzYwogKiAxNwliTnVtQ29uZmlndXJhdGlvbnMgMSAgICAweDAxCU51bWJlciBvZiBwb3NzaWJsZSBjb25maWd1cmF0aW9ucwogKiAKICogQ29uZmlndXJhdGlvbiBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCQlTaXplCVZhbHVlCiAqIDAJYkxlbmd0aAkJCTEJMHgwOQlTaXplIG9mIGRlc2NyaXB0b3IgaW4gYnl0ZXMKICogMQliRGVzY3JpcHRvclR5cGUJCTEJMHgwMglDT05GSUdVUkFUSU9OIERlc2NyaXB0b3IgVHlwZQogKiAyCXdUb3RhbExlbmd0aAkJMgkweDAwMjAJVG90YWwgbGVuZ3RoIG9mIGRhdGEKICogNAliTnVtSW50ZXJmYWNlcwkJMQkweDAxCU51bWJlciBvZiBpbnRlcmZhY2VzIHN1cHBvcnRlZAogKiA1CWJDb25maWd1cmF0aW9uVmFsdWUJMQkweDAxCUFyZ3VtZW50IGZvciBTZXRDT25maWd1cmF0aW9uKCkgcmVxCiAqIDYJaUNvbmZpZ3VyYXRpb24JCTEJMHgwMglJbmRleCBvZiBjb25maWcgc3RyaW5nIGRlc2NyaXB0b3IKICogNwlibUF0dHJpYnV0ZXMJCTEJMHgyMAlDb25maWcgY2hhcmFjdGVyaXN0aWNzIFJlbW90ZSBXYWtldXAKICogOAlNYXhQb3dlcgkJMQkweDFFCU1heCBwb3dlciBjb25zdW1wdGlvbgogKiAKICogSW50ZXJmYWNlIERlc2NyaXB0b3IKICogCiAqIE9mZnNldAlGaWVsZAkJCVNpemUJVmFsdWUKICogMAliTGVuZ3RoCQkJMQkweDA5CVNpemUgb2YgZGVzY3JpcHRvciBpbiBieXRlcwogKiAxCWJEZXNjcmlwdG9yVHlwZQkJMQkweDA0CUlOVEVSRkFDRSBEZXNjcmlwdG9yIFR5cGUKICogMgliSW50ZXJmYWNlTnVtYmVyCTEJMHgwMAlOdW1iZXIgb2YgaW50ZXJmYWNlCiAqIDMJYkFsdGVybmF0ZVNldHRpbmcJMQkweDAwCVZhbHVlIHVzZWQgdG8gc2VsZWN0IGFsdGVybmF0ZQogKiA0CWJOdW1FbmRwb2ludHMJCTEJMHgwMglOdW1iZXIgb2YgZW5kcG9pbnRzCiAqIDUJYkludGVyZmFjZUNsYXNzCQkxCTB4RkYJQ2xhc3MgQ29kZQogKiA2CWJJbnRlcmZhY2VTdWJDbGFzcwkxCTB4RkYJU3ViY2xhc3MgQ29kZQogKiA3CWJJbnRlcmZhY2VQcm90b2NvbAkxCTB4RkYJUHJvdG9jb2wgQ29kZQogKiA4CWlJbnRlcmZhY2UJCTEJMHgwMglJbmRleCBvZiBpbnRlcmZhY2Ugc3RyaW5nIGRlc2NyaXB0aW9uCiAqIAogKiBJTiBFbmRwb2ludCBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCQlTaXplCVZhbHVlCiAqIDAJYkxlbmd0aAkJCTEJMHgwNwlTaXplIG9mIGRlc2NyaXB0b3IgaW4gYnl0ZXMKICogMQliRGVzY3JpcHRvclR5cGUJCTEJMHgwNQlFTkRQT0lOVCBkZXNjcmlwdG9yIHR5cGUKICogMgliRW5kcG9pbnRBZGRyZXNzCTEJMHg4MglBZGRyZXNzIG9mIGVuZHBvaW50CiAqIDMJYm1BdHRyaWJ1dGVzCQkxCTB4MDIJRW5kcG9pbnQgYXR0cmlidXRlcyAtIEJ1bGsKICogNAliTnVtRW5kcG9pbnRzCQkyCTB4MDA0MAltYXhpbXVtIHBhY2tldCBzaXplCiAqIDUJYkludGVydmFsCQkxCTB4MDAJSW50ZXJ2YWwgZm9yIHBvbGxpbmcgZW5kcG9pbnQKICogCiAqIE9VVCBFbmRwb2ludCBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCQlTaXplCVZhbHVlCiAqIDAJYkxlbmd0aAkJCTEJMHgwNwlTaXplIG9mIGRlc2NyaXB0b3IgaW4gYnl0ZXMKICogMQliRGVzY3JpcHRvclR5cGUJCTEJMHgwNQlFTkRQT0lOVCBkZXNjcmlwdG9yIHR5cGUKICogMgliRW5kcG9pbnRBZGRyZXNzCTEJMHgwMglBZGRyZXNzIG9mIGVuZHBvaW50CiAqIDMJYm1BdHRyaWJ1dGVzCQkxCTB4MDIJRW5kcG9pbnQgYXR0cmlidXRlcyAtIEJ1bGsKICogNAliTnVtRW5kcG9pbnRzCQkyCTB4MDA0MAltYXhpbXVtIHBhY2tldCBzaXplCiAqIDUJYkludGVydmFsCQkxCTB4MDAJSW50ZXJ2YWwgZm9yIHBvbGxpbmcgZW5kcG9pbnQKICogICAgIAogKiBEQVRBIEZPUk1BVAogKiAKICogSU4gRW5kcG9pbnQKICogCiAqIFRoZSBkZXZpY2UgcmVzZXJ2ZXMgdGhlIGZpcnN0IHR3byBieXRlcyBvZiBkYXRhIG9uIHRoaXMgZW5kcG9pbnQgdG8gY29udGFpbiB0aGUgY3VycmVudAogKiB2YWx1ZXMgb2YgdGhlIG1vZGVtIGFuZCBsaW5lIHN0YXR1cyByZWdpc3RlcnMuIEluIHRoZSBhYnNlbmNlIG9mIGRhdGEsIHRoZSBkZXZpY2UgCiAqIGdlbmVyYXRlcyBhIG1lc3NhZ2UgY29uc2lzdGluZyBvZiB0aGVzZSB0d28gc3RhdHVzIGJ5dGVzIGV2ZXJ5IDQwIG1zCiAqIAogKiBCeXRlIDA6IE1vZGVtIFN0YXR1cwogKiAKICogT2Zmc2V0CURlc2NyaXB0aW9uCiAqIEIwCVJlc2VydmVkIC0gbXVzdCBiZSAxCiAqIEIxCVJlc2VydmVkIC0gbXVzdCBiZSAwCiAqIEIyCVJlc2VydmVkIC0gbXVzdCBiZSAwCiAqIEIzCVJlc2VydmVkIC0gbXVzdCBiZSAwCiAqIEI0CUNsZWFyIHRvIFNlbmQgKENUUykKICogQjUJRGF0YSBTZXQgUmVhZHkgKERTUikKICogQjYJUmluZyBJbmRpY2F0b3IgKFJJKQogKiBCNwlSZWNlaXZlIExpbmUgU2lnbmFsIERldGVjdCAoUkxTRCkKICogCiAqIEJ5dGUgMTogTGluZSBTdGF0dXMKICogCiAqIE9mZnNldAlEZXNjcmlwdGlvbgogKiBCMAlEYXRhIFJlYWR5IChEUikKICogQjEJT3ZlcnJ1biBFcnJvciAoT0UpCiAqIEIyCVBhcml0eSBFcnJvciAoUEUpCiAqIEIzCUZyYW1pbmcgRXJyb3IgKEZFKQogKiBCNAlCcmVhayBJbnRlcnJ1cHQgKEJJKQogKiBCNQlUcmFuc21pdHRlciBIb2xkaW5nIFJlZ2lzdGVyIChUSFJFKQogKiBCNglUcmFuc21pdHRlciBFbXB0eSAoVEVNVCkKICogQjcJRXJyb3IgaW4gUkNWUiBGSUZPCiAqIAogKi8KI2RlZmluZSBGVERJX1JTMF9DVFMJKDEgPDwgNCkKI2RlZmluZSBGVERJX1JTMF9EU1IJKDEgPDwgNSkKI2RlZmluZSBGVERJX1JTMF9SSQkoMSA8PCA2KQojZGVmaW5lIEZURElfUlMwX1JMU0QJKDEgPDwgNykKCiNkZWZpbmUgRlRESV9SU19EUiAgMQojZGVmaW5lIEZURElfUlNfT0UgKDE8PDEpCiNkZWZpbmUgRlRESV9SU19QRSAoMTw8MikKI2RlZmluZSBGVERJX1JTX0ZFICgxPDwzKQojZGVmaW5lIEZURElfUlNfQkkgKDE8PDQpCiNkZWZpbmUgRlRESV9SU19USFJFICgxPDw1KQojZGVmaW5lIEZURElfUlNfVEVNVCAoMTw8NikKI2RlZmluZSBGVERJX1JTX0ZJRk8gICgxPDw3KQoKLyoKICogT1VUIEVuZHBvaW50CiAqIAogKiBUaGlzIGRldmljZSByZXNlcnZlcyB0aGUgZmlyc3QgYnl0ZXMgb2YgZGF0YSBvbiB0aGlzIGVuZHBvaW50IGNvbnRhaW4gdGhlIGxlbmd0aAogKiBhbmQgcG9ydCBpZGVudGlmaWVyIG9mIHRoZSBtZXNzYWdlLiBGb3IgdGhlIEZUREkgVVNCIFNlcmlhbCBjb252ZXJ0ZXIgdGhlIHBvcnQgCiAqIGlkZW50aWZpZXIgaXMgYWx3YXlzIDEuCiAqIAogKiBCeXRlIDA6IExpbmUgU3RhdHVzCiAqIAogKiBPZmZzZXQJRGVzY3JpcHRpb24KICogQjAJUmVzZXJ2ZWQgLSBtdXN0IGJlIDEKICogQjEJUmVzZXJ2ZWQgLSBtdXN0IGJlIDAKICogQjIuLjcJTGVuZ3RoIG9mIG1lc3NhZ2UgLSAobm90IGluY2x1ZGluZyBCeXRlIDApCiAqIAogKi8KCg==