LyoKICogRGVmaW5pdGlvbnMgZm9yIHRoZSBGVERJIFVTQiBTaW5nbGUgUG9ydCBTZXJpYWwgQ29udmVydGVyIC0gCiAqIGtub3duIGFzIEZURElfU0lPIChTZXJpYWwgSW5wdXQvT3V0cHV0IGFwcGxpY2F0aW9uIG9mIHRoZSBjaGlwc2V0KSAKICoKICogVGhlIGV4YW1wbGUgSSBoYXZlIGlzIGtub3duIGFzIHRoZSBVU0MtMTAwMCB3aGljaCBpcyBhdmFpbGFibGUgZnJvbQogKiBodHRwOi8vd3d3LmRzZS5jby5ueiAtIGNhdCBubyBYSDQyMTQgSXQgbG9va3Mgc2ltaWxhciB0byB0aGlzOgogKiBodHRwOi8vd3d3LmRhbnNkYXRhLmNvbS91c2JzZXIuaHRtIGJ1dCBJIGNhbid0IGJlIHN1cmUgVGhlcmUgYXJlIG90aGVyCiAqIFVTQy0xMDAwcyB3aGljaCBkb24ndCBsb29rIGxpa2UgbXkgZGV2aWNlIHRob3VnaCBzbyBiZXdhcmUhCiAqCiAqIFRoZSBkZXZpY2UgaXMgYmFzZWQgb24gdGhlIEZUREkgRlQ4VTEwMEFYIGNoaXAuIEl0IGhhcyBhIERCMjUgb24gb25lIHNpZGUsIAogKiBVU0Igb24gdGhlIG90aGVyLgogKgogKiBUaGFueCB0byBGVERJIChodHRwOi8vd3d3LmZ0ZGkuY28udWspIGZvciBzbyBraW5kbHkgcHJvdmlkaW5nIGRldGFpbHMKICogb2YgdGhlIHByb3RvY29sIHJlcXVpcmVkIHRvIHRhbGsgdG8gdGhlIGRldmljZSBhbmQgb25nb2luZyBhc3Npc3RlbmNlCiAqIGR1cmluZyBkZXZlbG9wbWVudC4KICoKICogQmlsbCBSeWRlciAtIGJyeWRlckBzZ2kuY29tIGZvcm1lcmx5IG9mIFNpbGljb24gR3JhcGhpY3MsIEluYy4tIHdyb3RlIHRoZSAKICogRlRESV9TSU8gaW1wbGVtZW50YXRpb24uCiAqCiAqIFBoaWxpcHAgR/xocmluZyAtIHBnQGZ1dHVyZXdhcmUuYXQgLSBhZGRlZCB0aGUgRGV2aWNlIElEIG9mIHRoZSBVU0IgcmVsYWlzCiAqIGZyb20gUnVkb2xmIEd1Z2xlcgogKgogKi8KCiNkZWZpbmUgRlRESV9WSUQJMHgwNDAzCS8qIFZlbmRvciBJZCAqLwojZGVmaW5lIEZURElfU0lPX1BJRAkweDgzNzIJLyogUHJvZHVjdCBJZCBTSU8gYXBwbGljYXRpb24gb2YgOFUxMDBBWCAgKi8KI2RlZmluZSBGVERJXzhVMjMyQU1fUElEIDB4NjAwMSAvKiBTaW1pbGFyIGRldmljZSB0byBTSU8gYWJvdmUgKi8KI2RlZmluZSBGVERJXzhVMjMyQU1fQUxUX1BJRCAweDYwMDYgLyogRlRESSdzIGFsdGVybmF0ZSBQSUQgZm9yIGFib3ZlICovCiNkZWZpbmUgRlRESV84VTIyMzJDX1BJRCAweDYwMTAgLyogRHVhbCBjaGFubmVsIGRldmljZSAqLwojZGVmaW5lIEZURElfUkVMQUlTX1BJRAkweEZBMTAgIC8qIFJlbGFpcyBkZXZpY2UgZnJvbSBSdWRvbGYgR3VnbGVyICovCiNkZWZpbmUgRlRESV9ORl9SSUNfVklECTB4MERDRAkvKiBWZW5kb3IgSWQgKi8KI2RlZmluZSBGVERJX05GX1JJQ19QSUQJMHgwMDAxCS8qIFByb2R1Y3QgSWQgKi8KCgovKiBBQ1QgU29sdXRpb25zIEhvbWVQcm8gWldhdmUgaW50ZXJmYWNlIChodHRwOi8vd3d3LmFjdC1zb2x1dGlvbnMuY29tL0hvbWVQcm8uaHRtKSAqLwojZGVmaW5lIEZURElfQUNUWldBVkVfUElECTB4RjJEMAoKCi8qIHd3dy5pcnRyYW5zLmRlIGRldmljZSAqLwojZGVmaW5lIEZURElfSVJUUkFOU19QSUQgMHhGQzYwIC8qIFByb2R1Y3QgSWQgKi8KCgovKiB3d3cudGhvdWdodHRlY2hub2xvZ3kuY29tLyBUVC1VU0IgcHJvdmlkZSB3aXRoIHByb2NvbXAgdXNlIGZ0ZGlfc2lvICovCiNkZWZpbmUgRlRESV9UVFVTQl9QSUQgMHhGRjIwIC8qIFByb2R1Y3QgSWQgKi8KCi8qIGlQbHVzIGRldmljZSAqLwojZGVmaW5lIEZURElfSVBMVVNfUElEIDB4RDA3MCAvKiBQcm9kdWN0IElkICovCgovKiB3d3cuY3J5c3RhbGZvbnR6LmNvbSBkZXZpY2VzIC0gdGhhbnggZm9yIHByb3ZpZGluZyBmcmVlIGRldmljZXMgZm9yIGV2YWx1YXRpb24gISAqLwovKiB0aGV5IHVzZSB0aGUgZnRkaSBjaGlwc2V0IGZvciB0aGUgVVNCIGludGVyZmFjZSBhbmQgdGhlIHZlbmRvciBpZCBpcyB0aGUgc2FtZSAqLwojZGVmaW5lIEZURElfWEZfNjMyX1BJRCAweEZDMDgJLyogNjMyOiAxNngyIENoYXJhY3RlciBEaXNwbGF5ICovCiNkZWZpbmUgRlRESV9YRl82MzRfUElEIDB4RkMwOQkvKiA2MzQ6IDIweDQgQ2hhcmFjdGVyIERpc3BsYXkgKi8KI2RlZmluZSBGVERJX1hGXzU0N19QSUQgMHhGQzBBCS8qIDU0NzogVHdvIGxpbmUgRGlzcGxheSAqLwojZGVmaW5lIEZURElfWEZfNjMzX1BJRCAweEZDMEIJLyogNjMzOiAxNngyIENoYXJhY3RlciBEaXNwbGF5IHdpdGggS2V5cyAqLwojZGVmaW5lIEZURElfWEZfNjMxX1BJRCAweEZDMEMJLyogNjMxOiAyMHgyIENoYXJhY3RlciBEaXNwbGF5ICovCiNkZWZpbmUgRlRESV9YRl82MzVfUElEIDB4RkMwRAkvKiA2MzU6IDIweDQgQ2hhcmFjdGVyIERpc3BsYXkgKi8KI2RlZmluZSBGVERJX1hGXzY0MF9QSUQgMHhGQzBFCS8qIDY0MDogVHdvIGxpbmUgRGlzcGxheSAqLwojZGVmaW5lIEZURElfWEZfNjQyX1BJRCAweEZDMEYJLyogNjQyOiBUd28gbGluZSBEaXNwbGF5ICovCgovKiBWaWRlbyBOZXR3b3JrcyBMaW1pdGVkIC8gSG9tZWNob2ljZSBpbiB0aGUgVUsgdXNlIGFuIGZ0ZGktYmFzZWQgZGV2aWNlIGZvciB0aGVpciAxTWIgKi8KLyogYnJvYWRiYW5kIGludGVybmV0IHNlcnZpY2UuICBUaGUgZm9sbG93aW5nIFBJRCBpcyBleGhpYml0ZWQgYnkgdGhlIHVzYiBkZXZpY2Ugc3VwcGxpZWQgKi8KLyogKHRoZSBWSUQgaXMgdGhlIHN0YW5kYXJkIGZ0ZGkgdmlkIChGVERJX1ZJRCkgKi8KI2RlZmluZSBGVERJX1ZOSENQQ1VTQl9EX1BJRCAweGZlMzggLyogUHJvZHVjdCBJZCAqLwoKLyoKICogUENESiB1c2UgZnRkaSBiYXNlZCBkai1jb250cm9sbGVycy4gIFRoZSBmb2xsb3dpbmcgUElEIGlzIGZvciB0aGVpciBEQUMtMiBkZXZpY2UKICogaHR0cDovL3d3dy5wY2RqaGFyZHdhcmUuY29tL0RBQzIuYXNwIChQSUQgc2VudCBieSBXb3V0ZXIgUGFlc2VuKQogKiAodGhlIFZJRCBpcyB0aGUgc3RhbmRhcmQgZnRkaSB2aWQgKEZURElfVklEKSAqLwojZGVmaW5lIEZURElfUENESl9EQUMyX1BJRCAweEZBODgKCi8qCiAqIFRoZSBmb2xsb3dpbmcgYXJlIHRoZSB2YWx1ZXMgZm9yIHRoZSBNYXRyaXggT3JiaXRhbCBMQ0QgZGlzcGxheXMsCiAqIHdoaWNoIGFyZSB0aGUgRlQyMzJCTSAoIHNpbWlsYXIgdG8gdGhlIDhVMjMyQU0gKQogKi8KI2RlZmluZSBGVERJX01UWE9SQl8wX1BJRCAgICAgIDB4RkEwMCAgLyogTWF0cml4IE9yYml0YWwgUHJvZHVjdCBJZCAqLwojZGVmaW5lIEZURElfTVRYT1JCXzFfUElEICAgICAgMHhGQTAxICAvKiBNYXRyaXggT3JiaXRhbCBQcm9kdWN0IElkICovCiNkZWZpbmUgRlRESV9NVFhPUkJfMl9QSUQgICAgICAweEZBMDIgIC8qIE1hdHJpeCBPcmJpdGFsIFByb2R1Y3QgSWQgKi8KI2RlZmluZSBGVERJX01UWE9SQl8zX1BJRCAgICAgIDB4RkEwMyAgLyogTWF0cml4IE9yYml0YWwgUHJvZHVjdCBJZCAqLwojZGVmaW5lIEZURElfTVRYT1JCXzRfUElEICAgICAgMHhGQTA0ICAvKiBNYXRyaXggT3JiaXRhbCBQcm9kdWN0IElkICovCiNkZWZpbmUgRlRESV9NVFhPUkJfNV9QSUQgICAgICAweEZBMDUgIC8qIE1hdHJpeCBPcmJpdGFsIFByb2R1Y3QgSWQgKi8KI2RlZmluZSBGVERJX01UWE9SQl82X1BJRCAgICAgIDB4RkEwNiAgLyogTWF0cml4IE9yYml0YWwgUHJvZHVjdCBJZCAqLwoKLyogSW50ZXJiaW9tZXRyaWNzIFVTQiBJL08gQm9hcmQgKi8KLyogRGV2ZWxvcGVkIGZvciBJbnRlcmJpb21ldHJpY3MgYnkgUnVkb2xmIEd1Z2xlciAqLwojZGVmaW5lIElOVEVSQklPTUVUUklDU19WSUQgICAgICAgICAgICAgIDB4MTIwOQojZGVmaW5lIElOVEVSQklPTUVUUklDU19JT0JPQVJEX1BJRCAgICAgIDB4MTAwMgojZGVmaW5lIElOVEVSQklPTUVUUklDU19NSU5JX0lPQk9BUkRfUElEIDB4MTAwNgoKLyoKICogVGhlIGZvbGxvd2luZyBhcmUgdGhlIHZhbHVlcyBmb3IgdGhlIFBlcmxlIFN5c3RlbXMKICogVWx0cmFQb3J0IFVTQiBzZXJpYWwgY29udmVydGVycwogKi8KI2RlZmluZSBGVERJX1BFUkxFX1VMVFJBUE9SVF9QSUQgMHhGMEMwCS8qIFBlcmxlIFVsdHJhUG9ydCBQcm9kdWN0IElkICovCgovKgogKiBUaGUgZm9sbG93aW5nIGFyZSB0aGUgdmFsdWVzIGZvciB0aGUgU2VhbGV2ZWwgU2VhTElOSysgYWRhcHRlcnMuCiAqIChPcmlnaW5hbCBsaXN0IHNlbnQgYnkgVHVhbiBIb2FuZy4gIElhbiBBYmJvdHQgcmVuYW1lZCB0aGUgbWFjcm9zIGFuZAogKiByZW1vdmVkIHNvbWUgUElEcyB0aGF0IGRvbid0IHNlZW0gdG8gbWF0Y2ggYW55IGV4aXN0aW5nIHByb2R1Y3RzLikKICovCiNkZWZpbmUgU0VBTEVWRUxfVklECQkweDBjNTIJLyogU2VhbGV2ZWwgVmVuZG9yIElEICovCiNkZWZpbmUgU0VBTEVWRUxfMjEwMV9QSUQJMHgyMTAxCS8qIFNlYUxJTksrMjMyICgyMTAxLzIxMDUpICovCiNkZWZpbmUgU0VBTEVWRUxfMjEwMl9QSUQJMHgyMTAyCS8qIFNlYUxJTksrNDg1ICgyMTAyKSAqLwojZGVmaW5lIFNFQUxFVkVMXzIxMDNfUElECTB4MjEwMwkvKiBTZWFMSU5LKzIzMkkgKDIxMDMpICovCiNkZWZpbmUgU0VBTEVWRUxfMjEwNF9QSUQJMHgyMTA0CS8qIFNlYUxJTksrNDg1SSAoMjEwNCkgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAxXzFfUElECTB4MjIxMQkvKiBTZWFQT1JUKzIvMjMyICgyMjAxKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAxXzJfUElECTB4MjIyMQkvKiBTZWFQT1JUKzIvMjMyICgyMjAxKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAyXzFfUElECTB4MjIxMgkvKiBTZWFQT1JUKzIvNDg1ICgyMjAyKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAyXzJfUElECTB4MjIyMgkvKiBTZWFQT1JUKzIvNDg1ICgyMjAyKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yMjAzXzFfUElECTB4MjIxMwkvKiBTZWFQT1JUKzIgKDIyMDMpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzIyMDNfMl9QSUQJMHgyMjIzCS8qIFNlYVBPUlQrMiAoMjIwMykgUG9ydCAyICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMV8xX1BJRAkweDI0MTEJLyogU2VhUE9SVCs0LzIzMiAoMjQwMSkgUG9ydCAxICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMV8yX1BJRAkweDI0MjEJLyogU2VhUE9SVCs0LzIzMiAoMjQwMSkgUG9ydCAyICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMV8zX1BJRAkweDI0MzEJLyogU2VhUE9SVCs0LzIzMiAoMjQwMSkgUG9ydCAzICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMV80X1BJRAkweDI0NDEJLyogU2VhUE9SVCs0LzIzMiAoMjQwMSkgUG9ydCA0ICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMl8xX1BJRAkweDI0MTIJLyogU2VhUE9SVCs0LzQ4NSAoMjQwMikgUG9ydCAxICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMl8yX1BJRAkweDI0MjIJLyogU2VhUE9SVCs0LzQ4NSAoMjQwMikgUG9ydCAyICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMl8zX1BJRAkweDI0MzIJLyogU2VhUE9SVCs0LzQ4NSAoMjQwMikgUG9ydCAzICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwMl80X1BJRAkweDI0NDIJLyogU2VhUE9SVCs0LzQ4NSAoMjQwMikgUG9ydCA0ICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwM18xX1BJRAkweDI0MTMJLyogU2VhUE9SVCs0ICgyNDAzKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yNDAzXzJfUElECTB4MjQyMwkvKiBTZWFQT1JUKzQgKDI0MDMpIFBvcnQgMiAqLwojZGVmaW5lIFNFQUxFVkVMXzI0MDNfM19QSUQJMHgyNDMzCS8qIFNlYVBPUlQrNCAoMjQwMykgUG9ydCAzICovCiNkZWZpbmUgU0VBTEVWRUxfMjQwM180X1BJRAkweDI0NDMJLyogU2VhUE9SVCs0ICgyNDAzKSBQb3J0IDQgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzFfUElECTBYMjgxMQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzJfUElECTBYMjgyMQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzNfUElECTBYMjgzMQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDMgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzRfUElECTBYMjg0MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDQgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzVfUElECTBYMjg1MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDUgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzZfUElECTBYMjg2MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDYgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzdfUElECTBYMjg3MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDcgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAxXzhfUElECTBYMjg4MQkvKiBTZWFMSU5LKzgvMjMyICgyODAxKSBQb3J0IDggKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzFfUElECTBYMjgxMgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDEgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzJfUElECTBYMjgyMgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDIgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzNfUElECTBYMjgzMgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDMgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzRfUElECTBYMjg0MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDQgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzVfUElECTBYMjg1MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDUgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzZfUElECTBYMjg2MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDYgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzdfUElECTBYMjg3MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDcgKi8KI2RlZmluZSBTRUFMRVZFTF8yODAyXzhfUElECTBYMjg4MgkvKiBTZWFMSU5LKzgvNDg1ICgyODAyKSBQb3J0IDggKi8KI2RlZmluZSBTRUFMRVZFTF8yODAzXzFfUElECTBYMjgxMwkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgMSAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfMl9QSUQJMFgyODIzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgMiAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfM19QSUQJMFgyODMzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgMyAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfNF9QSUQJMFgyODQzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgNCAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfNV9QSUQJMFgyODUzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgNSAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfNl9QSUQJMFgyODYzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgNiAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfN19QSUQJMFgyODczIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgNyAqLwojZGVmaW5lIFNFQUxFVkVMXzI4MDNfOF9QSUQJMFgyODgzIAkvKiBTZWFMSU5LKzggKDI4MDMpIFBvcnQgOCAqLwoKLyoKICogVGhlIGZvbGxvd2luZyBhcmUgdGhlIHZhbHVlcyBmb3IgdHdvIEtPQklMIGNoaXBjYXJkIHRlcm1pbmFscy4KICovCiNkZWZpbmUgS09CSUxfVklECQkweDBkNDYJLyogS09CSUwgVmVuZG9yIElEICovCiNkZWZpbmUgS09CSUxfQ09OVl9CMV9QSUQJMHgyMDIwCS8qIEtPQklMIEtvbnZlcnRlciBmb3IgQjEgKi8KI2RlZmluZSBLT0JJTF9DT05WX0tBQU5fUElECTB4MjAyMQkvKiBLT0JJTF9Lb252ZXJ0ZXIgZm9yIEtBQU4gKi8KCi8qCiAqIEljb20gSUQtMSBkaWdpdGFsIHRyYW5zY2VpdmVyCiAqLwoKI2RlZmluZSBJQ09NX0lEMV9WSUQgICAgICAgICAgICAweDBDMjYKI2RlZmluZSBJQ09NX0lEMV9QSUQgICAgICAgICAgICAweDAwMDQKCi8qCiAqIEFTSy5mciBkZXZpY2VzCiAqLwojZGVmaW5lIEZURElfQVNLX1JEUjQwMF9QSUQJMHhDOTkxCS8qIEFTSyBSRFIgNDAwIHNlcmllcyBjYXJkIHJlYWRlciAqLwoKLyoKICogRFNTLTIwIFN5bmMgU3RhdGlvbiBmb3IgU29ueSBFcmljc3NvbiBQODAwCiAqLwogCiNkZWZpbmUgRlRESV9EU1MyMF9QSUQgICAgICAgICAgMHhGQzgyICAKCi8qCiAqIEhvbWUgRWxlY3Ryb25pY3MgKHd3dy5ob21lLWVsZWN0cm8uY29tKSBVU0IgZ2FkZ2V0cwogKi8KI2RlZmluZSBGVERJX0hFX1RJUkExX1BJRAkweEZBNzgJLyogVGlyYS0xIElSIHRyYW5zY2VpdmVyICovCgovKiBVU0ItVUlSVCAtIEFuIGluZnJhcmVkIHJlY2VpdmVyIGFuZCB0cmFuc21pdHRlciB1c2luZyB0aGUgOFUyMzJBTSBjaGlwICovCi8qIGh0dHA6Ly9ob21lLmVhcnRobGluay5uZXQvfmpyaGVlcy9VU0JVSVJUL2luZGV4Lmh0bSAqLwojZGVmaW5lIEZURElfVVNCX1VJUlRfUElECTB4Rjg1MAkvKiBQcm9kdWN0IElkICovCgovKgogKiBFTFYgVVNCIGRldmljZXMgc3VibWl0dGVkIGJ5IENocmlzdGlhbiBBYnQgb2YgRUxWICh3d3cuZWx2LmRlKS4KICogQWxsIG9mIHRoZXNlIGRldmljZXMgdXNlIEZUREkncyB2ZW5kb3IgSUQgKDB4MDQwMykuCiAqCiAqIFRoZSBwcmV2aW91c2x5IGluY2x1ZGVkIFBJRCBmb3IgdGhlIFVPIDEwMCBtb2R1bGUgd2FzIGluY29ycmVjdC4KICogSW4gZmFjdCwgdGhhdCBQSUQgd2FzIGZvciBFTFYncyBVUiAxMDAgVVNCLVJTMjMyIGNvbnZlcnRlciAoMHhGQjU4KS4KICoKICogQXJtaW4gTGFldWdlciBvcmlnaW5hbGx5IHNlbnQgdGhlIFBJRCBmb3IgdGhlIFVNIDEwMCBtb2R1bGUuCiAqLwojZGVmaW5lIEZURElfRUxWX1VSMTAwX1BJRAkweEZCNTgJLyogVVNCLVJTMjMyLVVtc2V0emVyIChVUiAxMDApICovCiNkZWZpbmUgRlRESV9FTFZfVU0xMDBfUElECTB4RkI1QQkvKiBVU0ItTW9kdWwgVU0gMTAwICovCiNkZWZpbmUgRlRESV9FTFZfVU8xMDBfUElECTB4RkI1QgkvKiBVU0ItTW9kdWwgVU8gMTAwICovCiNkZWZpbmUgRlRESV9FTFZfQUxDODUwMF9QSUQJMHhGMDZFCS8qIEFMQyA4NTAwIEV4cGVydCAqLwovKiBBZGRpdGlvbmFsIEVMViBQSURzIHRoYXQgZGVmYXVsdCB0byB1c2luZyB0aGUgRlRESSBEMlhYIGRyaXZlcnMgb24KICogTVMgV2luZG93cywgcmF0aGVyIHRoYW4gdGhlIEZUREkgVmlydHVhbCBDb20gUG9ydCBkcml2ZXJzLgogKiBNYXliZSB0aGVzZSB3aWxsIGJlIGVhc2llciB0byB1c2Ugd2l0aCB0aGUgbGliZnRkaS9saWJ1c2IgdXNlci1zcGFjZQogKiBkcml2ZXJzLCBvciBwb3NzaWJseSB0aGUgQ29tZWRpIGRyaXZlcnMgaW4gc29tZSBjYXNlcy4gKi8KI2RlZmluZSBGVERJX0VMVl9DTEk3MDAwX1BJRAkweEZCNTkJLyogQ29tcHV0ZXItTGlnaHQtSW50ZXJmYWNlIChDTEkgNzAwMCkgKi8KI2RlZmluZSBGVERJX0VMVl9QUFM3MzMwX1BJRAkweEZCNUMJLyogUHJvY2Vzc29yLVBvd2VyLVN1cHBseSAoUFBTIDczMzApICovCiNkZWZpbmUgRlRESV9FTFZfVEZNMTAwX1BJRAkweEZCNUQJLyogVGVtcGVyYXJ0dXItRmV1Y2h0ZSBNZXNzZ2VyYWV0IChURk0gMTAwKSAqLwojZGVmaW5lIEZURElfRUxWX1VERjc3X1BJRAkweEZCNUUJLyogVVNCIERDRiBGdW5rdXJoIChVREYgNzcpICovCiNkZWZpbmUgRlRESV9FTFZfVUlPODhfUElECTB4RkI1RgkvKiBVU0ItSS9PIEludGVyZmFjZSAoVUlPIDg4KSAqLwojZGVmaW5lIEZURElfRUxWX1VBRDhfUElECTB4RjA2OAkvKiBVU0ItQUQtV2FuZGxlciAoVUFEIDgpICovCiNkZWZpbmUgRlRESV9FTFZfVURBN19QSUQJMHhGMDY5CS8qIFVTQi1EQS1XYW5kbGVyIChVREEgNykgKi8KI2RlZmluZSBGVERJX0VMVl9VU0kyX1BJRAkweEYwNkEJLyogVVNCLVNjaHJpdHRtb3RvcmVuLUludGVyZmFjZSAoVVNJIDIpICovCiNkZWZpbmUgRlRESV9FTFZfVDExMDBfUElECTB4RjA2QgkvKiBUaGVybW9tZXRlciAoVCAxMTAwKSAqLwojZGVmaW5lIEZURElfRUxWX1BDRDIwMF9QSUQJMHhGMDZDCS8qIFBDLURhdGVubG9nZ2VyIChQQ0QgMjAwKSAqLwojZGVmaW5lIEZURElfRUxWX1VMQTIwMF9QSUQJMHhGMDZECS8qIFVTQi1MQ0QtQW5zdGV1ZXJ1bmcgKFVMQSAyMDApICovCiNkZWZpbmUgRlRESV9FTFZfRkhaMTAwMFBDX1BJRAkweEYwNkYJLyogRkhaIDEwMDAgUEMgKi8KI2RlZmluZSBGVERJX0VMVl9DU0k4X1BJRAkweEUwRjAJLyogQ29tcHV0ZXItU2NoYWx0LUludGVyZmFjZSAoQ1NJIDgpICovCiNkZWZpbmUgRlRESV9FTFZfRU0xMDAwRExfUElECTB4RTBGMQkvKiBQQy1EYXRlbmxvZ2dlciBmdWVyIEVuZXJnaWVtb25pdG9yIChFTSAxMDAwIERMKSAqLwojZGVmaW5lIEZURElfRUxWX1BDSzEwMF9QSUQJMHhFMEYyCS8qIFBDLUthYmVsdGVzdGVyIChQQ0sgMTAwKSAqLwojZGVmaW5lIEZURElfRUxWX1JGUDUwMF9QSUQJMHhFMEYzCS8qIEhGLUxlaXN0dW5nc21lc3NlciAoUkZQIDUwMCkgKi8KI2RlZmluZSBGVERJX0VMVl9GUzIwU0lHX1BJRAkweEUwRjQJLyogU2lnbmFsZ2ViZXIgKEZTIDIwIFNJRykgKi8KI2RlZmluZSBGVERJX0VMVl9XUzMwMFBDX1BJRAkweEUwRjYJLyogUEMtV2V0dGVyc3RhdGlvbiAoV1MgMzAwIFBDKSAqLwojZGVmaW5lIEZURElfRUxWX0ZIWjEzMDBQQ19QSUQJMHhFMEU4CS8qIEZIWiAxMzAwIFBDICovCiNkZWZpbmUgRlRESV9FTFZfV1M1MDBfUElECTB4RTBFOQkvKiBQQy1XZXR0ZXJzdGF0aW9uIChXUyA1MDApICovCgovKgogKiBEZWZpbml0aW9ucyBmb3IgSUQgVEVDSCAod3d3LmlkdC1uZXQuY29tKSBkZXZpY2VzCiAqLwojZGVmaW5lIElEVEVDSF9WSUQJCTB4MEFDRAkvKiBJRCBURUNIIFZlbmRvciBJRCAqLwojZGVmaW5lIElEVEVDSF9JRFQxMjIxVV9QSUQJMHgwMzAwCS8qIElEVDEyMjFVIFVTQiB0byBSUy0yMzIgYWRhcHRlciAqLwoKLyoKICogRGVmaW5pdGlvbnMgZm9yIE9tbmlkaXJlY3Rpb25hbCBDb250cm9sIFRlY2hub2xvZ3ksIEluYy4gZGV2aWNlcwogKi8KI2RlZmluZSBPQ1RfVklECQkJMHgwQjM5CS8qIE9DVCB2ZW5kb3IgSUQgKi8KLyogTm90ZTogT0NUIFVTMTAxIGlzIGFsc28gcmViYWRnZWQgYXMgRGljayBTbWl0aCBFbGVjdHJvbmljcyAoTlopIFhINjM4MSAqLwovKiBBbHNvIHJlYmFkZ2VkIGFzIERpY2sgU21pdGggRWxlY3Ryb25pY3MgKEF1cykgWEg2NDUxICovCi8qIEFsc28gcmViYWRnZWQgYXMgU0lJRyBJbmMuIG1vZGVsIFVTMjMwOCBoYXJkd2FyZSB2ZXJzaW9uIDEgKi8KI2RlZmluZSBPQ1RfVVMxMDFfUElECQkweDA0MjEJLyogT0NUIFVTMTAxIFVTQiB0byBSUy0yMzIgKi8KCi8qIGFuIGluZnJhcmVkIHJlY2VpdmVyIGZvciB1c2VyIGFjY2VzcyBjb250cm9sIHdpdGggSVIgdGFncyAqLwojZGVmaW5lIEZURElfUElFR1JPVVBfUElECTB4RjIwOAkvKiBQcm9kdWN0IElkICovCgovKgogKiBEZWZpbml0aW9ucyBmb3IgQXJ0ZW1pcyBhc3Ryb25vbWljYWwgVVNCIGJhc2VkIGNhbWVyYXMKICogQ2hlY2sgaXQgYXQgaHR0cDovL3d3dy5hcnRlbWlzY2NkLmNvLnVrLwogKi8KI2RlZmluZSBGVERJX0FSVEVNSVNfUElECTB4REYyOAkvKiBBbGwgQXJ0ZW1pcyBDYW1lcmFzICovCgovKgogKiBEZWZpbml0aW9ucyBmb3IgQVRJSyBJbnN0cnVtZW50cyBhc3Ryb25vbWljYWwgVVNCIGJhc2VkIGNhbWVyYXMKICogQ2hlY2sgaXQgYXQgaHR0cDovL3d3dy5hdGlrLWluc3RydW1lbnRzLmNvbS8KICovCiNkZWZpbmUgRlRESV9BVElLX0FUSzE2X1BJRAkweERGMzAJLyogQVRJSyBBVEstMTYgR3JheXNjYWxlIENhbWVyYSAqLwojZGVmaW5lIEZURElfQVRJS19BVEsxNkNfUElECTB4REYzMgkvKiBBVElLIEFUSy0xNkMgQ29sb3VyIENhbWVyYSAqLwojZGVmaW5lIEZURElfQVRJS19BVEsxNkhSX1BJRAkweERGMzEJLyogQVRJSyBBVEstMTZIUiBHcmF5c2NhbGUgQ2FtZXJhICovCiNkZWZpbmUgRlRESV9BVElLX0FUSzE2SFJDX1BJRAkweERGMzMJLyogQVRJSyBBVEstMTZIUkMgQ29sb3VyIENhbWVyYSAqLwoKLyoKICogUHJvdGVnbyBwcm9kdWN0IGlkcwogKi8KI2RlZmluZSBQUk9URUdPX1NQRUNJQUxfMQkweEZDNzAJLyogc3BlY2lhbC91bmtub3duIGRldmljZSAqLwojZGVmaW5lIFBST1RFR09fUjJYMAkJMHhGQzcxCS8qIFIyMDAtVVNCIFRSTkcgdW5pdCAoUjIxMCwgUjIyMCwgYW5kIFIyMzApICovCiNkZWZpbmUgUFJPVEVHT19TUEVDSUFMXzMJMHhGQzcyCS8qIHNwZWNpYWwvdW5rbm93biBkZXZpY2UgKi8KI2RlZmluZSBQUk9URUdPX1NQRUNJQUxfNAkweEZDNzMJLyogc3BlY2lhbC91bmtub3duIGRldmljZSAqLwoKLyoKICogR3VkZSBBbmFsb2ctIHVuZCBEaWdpdGFsc3lzdGVtZSBHbWJICiAqLwojZGVmaW5lIEZURElfR1VERUFEU19FODA4X1BJRCAgICAweEU4MDgKI2RlZmluZSBGVERJX0dVREVBRFNfRTgwOV9QSUQgICAgMHhFODA5CiNkZWZpbmUgRlRESV9HVURFQURTX0U4MEFfUElEICAgIDB4RTgwQQojZGVmaW5lIEZURElfR1VERUFEU19FODBCX1BJRCAgICAweEU4MEIKI2RlZmluZSBGVERJX0dVREVBRFNfRTgwQ19QSUQgICAgMHhFODBDCiNkZWZpbmUgRlRESV9HVURFQURTX0U4MERfUElEICAgIDB4RTgwRAojZGVmaW5lIEZURElfR1VERUFEU19FODBFX1BJRCAgICAweEU4MEUKI2RlZmluZSBGVERJX0dVREVBRFNfRTgwRl9QSUQgICAgMHhFODBGCiNkZWZpbmUgRlRESV9HVURFQURTX0U4ODhfUElEICAgIDB4RTg4OCAgLyogRXhwZXJ0IElTRE4gQ29udHJvbCBVU0IgKi8KI2RlZmluZSBGVERJX0dVREVBRFNfRTg4OV9QSUQgICAgMHhFODg5ICAvKiBVU0IgUlMtMjMyIE9wdG9CcmlkZ2UgKi8KI2RlZmluZSBGVERJX0dVREVBRFNfRTg4QV9QSUQgICAgMHhFODhBCiNkZWZpbmUgRlRESV9HVURFQURTX0U4OEJfUElEICAgIDB4RTg4QgojZGVmaW5lIEZURElfR1VERUFEU19FODhDX1BJRCAgICAweEU4OEMKI2RlZmluZSBGVERJX0dVREVBRFNfRTg4RF9QSUQgICAgMHhFODhECiNkZWZpbmUgRlRESV9HVURFQURTX0U4OEVfUElEICAgIDB4RTg4RQojZGVmaW5lIEZURElfR1VERUFEU19FODhGX1BJRCAgICAweEU4OEYKCi8qCiAqIExpbnggVGVjaG5vbG9naWVzIHByb2R1Y3QgaWRzCiAqLwojZGVmaW5lIExJTlhfU0RNVVNCUVNTX1BJRAkweEY0NDgJLyogTGlueCBTRE0tVVNCLVFTLVMgKi8KI2RlZmluZSBMSU5YX01BU1RFUkRFVkVMMl9QSUQgICAweEY0NDkgICAvKiBMaW54IE1hc3RlciBEZXZlbG9wbWVudCAyLjAgKi8KI2RlZmluZSBMSU5YX0ZVVFVSRV8wX1BJRCAgIDB4RjQ0QSAgIC8qIExpbnggZnV0dXJlIGRldmljZSAqLwojZGVmaW5lIExJTlhfRlVUVVJFXzFfUElEICAgMHhGNDRCICAgLyogTGlueCBmdXR1cmUgZGV2aWNlICovCiNkZWZpbmUgTElOWF9GVVRVUkVfMl9QSUQgICAweEY0NEMgICAvKiBMaW54IGZ1dHVyZSBkZXZpY2UgKi8KCi8qIENDUyBJbmMuIElDRFUvSUNEVTQwIHByb2R1Y3QgSUQgLSB0aGUgRlQyMzJCTSBpcyB1c2VkIGluIGFuIGluLWNpcmN1aXQtZGVidWdnZXIgKi8KLyogdW5pdCBmb3IgUElDMTYncy9QSUMxOCdzICovCiNkZWZpbmUgRlRESV9DQ1NJQ0RVMjBfMF9QSUQgICAgMHhGOUQwICAgICAKI2RlZmluZSBGVERJX0NDU0lDRFU0MF8xX1BJRCAgICAweEY5RDEgICAgIAoKLyogSW5zaWRlIEFjY2Vzc28gY29udGFjdGxlc3MgcmVhZGVyIChodHRwOi8vd3d3Lmluc2lkZWZyLmNvbSkgKi8KI2RlZmluZSBJTlNJREVfQUNDRVNTTwkJMHhGQUQwCgovKgogKiBJbnRyZXBpZCBDb250cm9sIFN5c3RlbXMgKGh0dHA6Ly93d3cuaW50cmVwaWRjcy5jb20vKSBWYWx1ZUNBTiBhbmQgTmVvVkkKICovCiNkZWZpbmUgSU5UUkVQSURfVklECQkweDA5M0MKI2RlZmluZSBJTlRSRVBJRF9WQUxVRUNBTl9QSUQJMHgwNjAxCiNkZWZpbmUgSU5UUkVQSURfTkVPVklfUElECTB4MDcwMQoKLyoKICogRmFsY29tIFdpcmVsZXNzIENvbW11bmljYXRpb25zIEdtYkgKICovCiNkZWZpbmUgRkFMQ09NX1ZJRAkJMHgwRjk0CS8qIFZlbmRvciBJZCAqLwojZGVmaW5lIEZBTENPTV9UV0lTVF9QSUQJMHgwMDAxCS8qIEZhbGNvbSBUd2lzdCBVU0IgR1BSUyBtb2RlbSAqLwojZGVmaW5lIEZBTENPTV9TQU1CQV9QSUQJMHgwMDA1CS8qIEZhbGNvbSBTYW1iYSBVU0IgR1BSUyBtb2RlbSAqLwoKLyoKICogU1VVTlRPIHByb2R1Y3QgaWRzCiAqLwojZGVmaW5lIEZURElfU1VVTlRPX1NQT1JUU19QSUQJMHhGNjgwCS8qIFN1dW50byBTcG9ydHMgaW5zdHJ1bWVudCAqLwoKLyoKICogRGVmaW5pdGlvbnMgZm9yIEImQiBFbGVjdHJvbmljcyBwcm9kdWN0cy4KICovCiNkZWZpbmUgQkFOREJfVklECQkweDA4NTYJLyogQiZCIEVsZWN0cm9uaWNzIFZlbmRvciBJRCAqLwojZGVmaW5lIEJBTkRCX1VTT1RMNF9QSUQJMHhBQzAxCS8qIFVTT1RMNCBJc29sYXRlZCBSUy00ODUgQ29udmVydGVyICovCiNkZWZpbmUgQkFOREJfVVNUTDRfUElECQkweEFDMDIJLyogVVNUTDQgUlMtNDg1IENvbnZlcnRlciAqLwojZGVmaW5lIEJBTkRCX1VTTzlNTDJfUElECTB4QUMwMwkvKiBVU085TUwyIElzb2xhdGVkIFJTLTIzMiBDb252ZXJ0ZXIgKi8KCi8qCiAqIFJNIE1pY2hhZWxpZGVzIENBTnZpZXcgVVNCIChodHRwOi8vd3d3LnJtY2FuLmNvbSkKICogQ0FOIGZpZWxkYnVzIGludGVyZmFjZSBhZGFwdGVyLCBhZGRlZCBieSBwb3J0IEdtYkggd3d3LnBvcnQuZGUpCiAqIElhbiBBYmJvdHQgY2hhbmdlZCB0aGUgbWFjcm8gbmFtZXMgZm9yIGNvbnNpc3RlbmN5LgogKi8KI2RlZmluZSBGVERJX1JNX0NBTlZJRVdfUElECTB4ZmQ2MAkvKiBQcm9kdWN0IElkICovCgovKgogKiBFVkVSIEVjbyBQcm8gVVBTIChodHRwOi8vd3d3LmV2ZXIuY29tLnBsLykKICovCgojZGVmaW5lCUVWRVJfRUNPX1BST19DRFMJMHhlNTIwCS8qIFJTLTIzMiBjb252ZXJ0ZXIgKi8KCi8qCiAqIDROLUdBTEFYWS5ERSBQSURzIGZvciBDQU4tVVNCLCBVU0ItUlMyMzIsIFVTQi1SUzQyMiwgVVNCLVJTNDg1LAogKiBVU0ItVFRZIGFjdGl2LCBVU0ItVFRZIHBhc3Npdi4gIFNvbWUgUElEcyBhcmUgdXNlZCBieSBzZXZlcmFsIGRldmljZXMKICogYW5kIEknbSBub3QgZW50aXJlbHkgc3VyZSB3aGljaCBhcmUgdXNlZCBieSB3aGljaC4KICovCiNkZWZpbmUgRlRESV80Tl9HQUxBWFlfREVfMF9QSUQJMHg4MzcyCiNkZWZpbmUgRlRESV80Tl9HQUxBWFlfREVfMV9QSUQJMHhGM0MwCiNkZWZpbmUgRlRESV80Tl9HQUxBWFlfREVfMl9QSUQJMHhGM0MxCgovKgogKiBNb2JpbGl0eSBFbGVjdHJvbmljcyBwcm9kdWN0cy4KICovCiNkZWZpbmUgTU9CSUxJVFlfVklECQkJMHgxMzQyCiNkZWZpbmUgTU9CSUxJVFlfVVNCX1NFUklBTF9QSUQJCTB4MDIwMgkvKiBFYXNpRG9jayBVU0IgMjAwIHNlcmlhbCAqLwoKLyoKICogbWljcm9IQU0gcHJvZHVjdCBJRHMgKGh0dHA6Ly93d3cubWljcm9oYW0uY29tKS4KICogU3VibWl0dGVkIGJ5IEp1c3RpbiBCdXJrZXQgKEtMMVJMKSA8em9ydG9uQGp0YW4uY29tPgogKiBhbmQgTWlrZSBTdHVkZXIgKEs2RUVQKSA8azZlZXBAaGFtc29mdHdhcmUub3JnPi4KICogSWFuIEFiYm90dCA8YWJib3R0aUBtZXYuY28udWs+IGFkZGVkIGEgZmV3IG1vcmUgZnJvbSB0aGUgZHJpdmVyIElORiBmaWxlLgogKi8KI2RlZmluZSBGVERJX01IQU1fS1dfUElEIDB4RUVFOAkJLyogVVNCLUtXIGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9ZU19QSUQgMHhFRUU5CQkvKiBVU0ItWVMgaW50ZXJmYWNlICovCiNkZWZpbmUgRlRESV9NSEFNX1k2X1BJRCAweEVFRUEJCS8qIFVTQi1ZNiBpbnRlcmZhY2UgKi8KI2RlZmluZSBGVERJX01IQU1fWThfUElEIDB4RUVFQgkJLyogVVNCLVk4IGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9JQ19QSUQgMHhFRUVDCQkvKiBVU0ItSUMgaW50ZXJmYWNlICovCiNkZWZpbmUgRlRESV9NSEFNX0RCOV9QSUQgMHhFRUVECS8qIFVTQi1EQjkgaW50ZXJmYWNlICovCiNkZWZpbmUgRlRESV9NSEFNX1JTMjMyX1BJRCAweEVFRUUJLyogVVNCLVJTMjMyIGludGVyZmFjZSAqLwojZGVmaW5lIEZURElfTUhBTV9ZOV9QSUQgMHhFRUVGCQkvKiBVU0ItWTkgaW50ZXJmYWNlICovCgovKgogKiBBY3RpdmUgUm9ib3RzIHByb2R1Y3QgaWRzLgogKi8KI2RlZmluZSBGVERJX0FDVElWRV9ST0JPVFNfUElECTB4RTU0OAkvKiBVU0IgY29tbXMgYm9hcmQgKi8KCi8qCiAqIFhzZW5zIFRlY2hub2xvZ2llcyBCViBwcm9kdWN0cyAoaHR0cDovL3d3dy54c2Vucy5jb20pLgogKi8KI2RlZmluZSBYU0VOU19DT05WRVJURVJfMF9QSUQJMHhEMzg4CiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzFfUElECTB4RDM4OQojZGVmaW5lIFhTRU5TX0NPTlZFUlRFUl8yX1BJRAkweEQzOEEKI2RlZmluZSBYU0VOU19DT05WRVJURVJfM19QSUQJMHhEMzhCCiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzRfUElECTB4RDM4QwojZGVmaW5lIFhTRU5TX0NPTlZFUlRFUl81X1BJRAkweEQzOEQKI2RlZmluZSBYU0VOU19DT05WRVJURVJfNl9QSUQJMHhEMzhFCiNkZWZpbmUgWFNFTlNfQ09OVkVSVEVSXzdfUElECTB4RDM4RgoKLyoKICogVGVyYXRyb25payBwcm9kdWN0IGlkcy4KICogU3VibWl0dGVkIGJ5IE8uIFf2bGZlbHNjaG5laWRlci4KICovCiNkZWZpbmUgRlRESV9URVJBVFJPTklLX1ZDUF9QSUQJIDB4RUM4OAkvKiBUZXJhdHJvbmlrIGRldmljZSAocHJlZmVycmluZyBWQ1AgZHJpdmVyIG9uIHdpbmRvd3MpICovCiNkZWZpbmUgRlRESV9URVJBVFJPTklLX0QyWFhfUElEIDB4RUM4OQkvKiBUZXJhdHJvbmlrIGRldmljZSAocHJlZmVycmluZyBEMlhYIGRyaXZlciBvbiB3aW5kb3dzKSAqLwoKLyoKICogRXZvbHV0aW9uIFJvYm90aWNzIHByb2R1Y3RzIChodHRwOi8vd3d3LmV2b2x1dGlvbi5jb20vKS4KICogU3VibWl0dGVkIGJ5IFNoYXduIE0uIExhdmVsbGUuCiAqLwojZGVmaW5lIEVWT0xVVElPTl9WSUQJCTB4REVFRQkvKiBWZW5kb3IgSUQgKi8KI2RlZmluZSBFVk9MVVRJT05fRVIxX1BJRAkweDAzMDAJLyogRVIxIENvbnRyb2wgTW9kdWxlICovCgovKiBQeXJhbWlkIENvbXB1dGVyIEdtYkggKi8KI2RlZmluZSBGVERJX1BZUkFNSURfUElECTB4RTZDOAkvKiBQeXJhbWlkIEFwcGxpYW5jZSBEaXNwbGF5ICovCgovKgogKiBQb3NpZmxleCBpbmMgcmV0YWlsIGVxdWlwbWVudCAoaHR0cDovL3d3dy5wb3NpZmxleC5jb20udHcpCiAqLwojZGVmaW5lIFBPU0lGTEVYX1ZJRAkJMHgwZDNhICAvKiBWZW5kb3IgSUQgKi8KI2RlZmluZSBQT1NJRkxFWF9QUDcwMDBfUElECTB4MDMwMCAgLyogUFAtNzAwMElJIHRoZXJtYWwgcHJpbnRlciAqLwoKLyoKICogV2VzdHJleCBJbnRlcm5hdGlvbmFsIGRldmljZXMgc3VibWl0dGVkIGJ5IENvcnkgTGVlCiAqLwojZGVmaW5lIEZURElfV0VTVFJFWF9NT0RFTF83NzdfUElECTB4REMwMAkvKiBNb2RlbCA3NzcgKi8KI2RlZmluZSBGVERJX1dFU1RSRVhfTU9ERUxfODkwMEZfUElECTB4REMwMQkvKiBNb2RlbCA4OTAwRiAqLwoKLyoKICogUlItQ2lyS2l0cyBMb2NvQnVmZmVyIFVTQiAoaHR0cDovL3d3dy5yci1jaXJraXRzLmNvbSkKICovCiNkZWZpbmUgRlRESV9SUkNJUktJVFNfTE9DT0JVRkZFUl9QSUQJMHhjN2QwCS8qIExvY29CdWZmZXIgVVNCICovCgovKgogKiBFY2xvIChodHRwOi8vd3d3LmVjbG8ucHQvKSBwcm9kdWN0IElEcy4KICogUElEIDB4RUE5MCBzdWJtaXR0ZWQgYnkgTWFydGluIEdyaWxsLgogKi8KI2RlZmluZSBGVERJX0VDTE9fQ09NXzFXSVJFX1BJRAkweEVBOTAJLyogQ09NIHRvIDEtV2lyZSBVU0IgYWRhcHRvciAqLwoKLyoKICogUGFwb3VjaCBwcm9kdWN0cyAoaHR0cDovL3d3dy5wYXBvdWNoLmNvbS8pCiAqIFN1Ym1pdHRlZCBieSBGb2xrZXJ0IHZhbiBIZXVzZGVuCiAqLwoKI2RlZmluZSBQQVBPVUNIX1ZJRAkJCTB4NTA1MAkvKiBWZW5kb3IgSUQgKi8KI2RlZmluZSBQQVBPVUNIX1RNVV9QSUQJCQkweDA0MDAJLyogVE1VIFVTQiBUaGVybW9tZXRlciAqLwoKLyoKICogQUNHIElkZW50aWZpY2F0aW9uIFRlY2hub2xvZ2llcyBHbWJIIHByb2R1Y3RzIChodHRwOi8vd3d3LmFjZy5kZS8pLgogKiBTdWJtaXR0ZWQgYnkgYW50b24gLWF0LSBnb3RvMTAgLWRvdC0gb3JnLgogKi8KI2RlZmluZSBGVERJX0FDR19IRkRVQUxfUElECQkweEREMjAJLyogSEYgRHVhbCBJU08gUmVhZGVyIChSRklEKSAqLwoKLyoKICogWW9zdCBFbmdpbmVlcmluZywgSW5jLiBwcm9kdWN0cyAod3d3Lnlvc3RlbmdpbmVlcmluZy5jb20pLgogKiBQSUQgMHhFMDUwIHN1Ym1pdHRlZCBieSBBYXJvbiBQcm9zZS4KICovCiNkZWZpbmUgRlRESV9ZRUlfU0VSVk9DRU5URVIzMV9QSUQJMHhFMDUwCS8qIFlFSSBTZXJ2b0NlbnRlcjMuMSBVU0IgKi8KCi8qIENvbW1hbmRzICovCiNkZWZpbmUgRlRESV9TSU9fUkVTRVQgCQkwIC8qIFJlc2V0IHRoZSBwb3J0ICovCiNkZWZpbmUgRlRESV9TSU9fTU9ERU1fQ1RSTCAJMSAvKiBTZXQgdGhlIG1vZGVtIGNvbnRyb2wgcmVnaXN0ZXIgKi8KI2RlZmluZSBGVERJX1NJT19TRVRfRkxPV19DVFJMCTIgLyogU2V0IGZsb3cgY29udHJvbCByZWdpc3RlciAqLwojZGVmaW5lIEZURElfU0lPX1NFVF9CQVVEX1JBVEUJMyAvKiBTZXQgYmF1ZCByYXRlICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEEJNCAvKiBTZXQgdGhlIGRhdGEgY2hhcmFjdGVyaXN0aWNzIG9mIHRoZSBwb3J0ICovCiNkZWZpbmUgRlRESV9TSU9fR0VUX01PREVNX1NUQVRVUwk1IC8qIFJldHJpZXZlIGN1cnJlbnQgdmFsdWUgb2YgbW9kZXJuIHN0YXR1cyByZWdpc3RlciAqLwojZGVmaW5lIEZURElfU0lPX1NFVF9FVkVOVF9DSEFSCTYgLyogU2V0IHRoZSBldmVudCBjaGFyYWN0ZXIgKi8KI2RlZmluZSBGVERJX1NJT19TRVRfRVJST1JfQ0hBUgk3IC8qIFNldCB0aGUgZXJyb3IgY2hhcmFjdGVyICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVIJOSAvKiBTZXQgdGhlIGxhdGVuY3kgdGltZXIgKi8KI2RlZmluZSBGVERJX1NJT19HRVRfTEFURU5DWV9USU1FUgkxMCAvKiBHZXQgdGhlIGxhdGVuY3kgdGltZXIgKi8KCgovKgogKiAgIEJtUmVxdWVzdFR5cGU6ICAxMTAwIDAwMDBiCiAqICAgYlJlcXVlc3Q6ICAgICAgIEZURElfRTJfUkVBRAogKiAgIHdWYWx1ZTogICAgICAgICAwCiAqICAgd0luZGV4OiAgICAgICAgIEFkZHJlc3Mgb2Ygd29yZCB0byByZWFkCiAqICAgd0xlbmd0aDogICAgICAgIDIKICogICBEYXRhOiAgICAgICAgICAgV2lsbCByZXR1cm4gYSB3b3JkIG9mIGRhdGEgZnJvbSBFMkFkZHJlc3MKICoKICovCgovKiBQb3J0IElkZW50aWZpZXIgVGFibGUgKi8KI2RlZmluZSBQSVRfREVGQVVMVCAJCTAgLyogU0lPQSAqLwojZGVmaW5lIFBJVF9TSU9BCQkxIC8qIFNJT0EgKi8KLyogVGhlIGRldmljZSB0aGlzIGRyaXZlciBpcyB0ZXN0ZWQgd2l0aCBvbmUgaGFzIG9ubHkgb25lIHBvcnQgKi8KI2RlZmluZSBQSVRfU0lPQgkJMiAvKiBTSU9CICovCiNkZWZpbmUgUElUX1BBUkFMTEVMCQkzIC8qIFBhcmFsbGVsICovCgovKiBGVERJX1NJT19SRVNFVCAqLwojZGVmaW5lIEZURElfU0lPX1JFU0VUX1JFUVVFU1QgRlRESV9TSU9fUkVTRVQKI2RlZmluZSBGVERJX1NJT19SRVNFVF9SRVFVRVNUX1RZUEUgMHg0MAojZGVmaW5lIEZURElfU0lPX1JFU0VUX1NJTyAwCiNkZWZpbmUgRlRESV9TSU9fUkVTRVRfUFVSR0VfUlggMQojZGVmaW5lIEZURElfU0lPX1JFU0VUX1BVUkdFX1RYIDIKCi8qCiAqIEJtUmVxdWVzdFR5cGU6ICAwMTAwIDAwMDBCCiAqIGJSZXF1ZXN0OiAgICAgICBGVERJX1NJT19SRVNFVAogKiB3VmFsdWU6ICAgICAgICAgQ29udHJvbCBWYWx1ZSAKICogICAgICAgICAgICAgICAgICAgMCA9IFJlc2V0IFNJTwogKiAgICAgICAgICAgICAgICAgICAxID0gUHVyZ2UgUlggYnVmZmVyCiAqICAgICAgICAgICAgICAgICAgIDIgPSBQdXJnZSBUWCBidWZmZXIKICogd0luZGV4OiAgICAgICAgIFBvcnQKICogd0xlbmd0aDogICAgICAgIDAKICogRGF0YTogICAgICAgICAgIE5vbmUKICoKICogVGhlIFJlc2V0IFNJTyBjb21tYW5kIGhhcyB0aGlzIGVmZmVjdDoKICoKICogICAgU2V0cyBmbG93IGNvbnRyb2wgc2V0IHRvICdub25lJwogKiAgICBFdmVudCBjaGFyID0gJDBECiAqICAgIEV2ZW50IHRyaWdnZXIgPSBkaXNhYmxlZAogKiAgICBQdXJnZSBSWCBidWZmZXIKICogICAgUHVyZ2UgVFggYnVmZmVyCiAqICAgIENsZWFyIERUUgogKiAgICBDbGVhciBSVFMKICogICAgYmF1ZCBhbmQgZGF0YSBmb3JtYXQgbm90IHJlc2V0CiAqCiAqIFRoZSBQdXJnZSBSWCBhbmQgVFggYnVmZmVyIGNvbW1hbmRzIGFmZmVjdCBub3RoaW5nIGV4Y2VwdCB0aGUgYnVmZmVycwogKgogICAqLwoKLyogRlRESV9TSU9fU0VUX0JBVURSQVRFICovCiNkZWZpbmUgRlRESV9TSU9fU0VUX0JBVURSQVRFX1JFUVVFU1RfVFlQRSAweDQwCiNkZWZpbmUgRlRESV9TSU9fU0VUX0JBVURSQVRFX1JFUVVFU1QgMwoKLyoKICogQm1SZXF1ZXN0VHlwZTogIDAxMDAgMDAwMEIKICogYlJlcXVlc3Q6ICAgICAgIEZURElfU0lPX1NFVF9CQVVEUkFURQogKiB3VmFsdWU6ICAgICAgICAgQmF1ZERpdmlzb3IgdmFsdWUgLSBzZWUgYmVsb3cKICogd0luZGV4OiAgICAgICAgIFBvcnQKICogd0xlbmd0aDogICAgICAgIDAKICogRGF0YTogICAgICAgICAgIE5vbmUKICogVGhlIEJhdWREaXZpc29yIHZhbHVlcyBhcmUgY2FsY3VsYXRlZCBhcyBmb2xsb3dzOgogKiAtIEJhc2VDbG9jayBpcyBlaXRoZXIgMTIwMDAwMDAgb3IgNDgwMDAwMDAgZGVwZW5kaW5nIG9uIHRoZSBkZXZpY2UuIEZJWE1FOiBJIHdpc2gKICogICBJIGtuZXcgaG93IHRvIGRldGVjdCBvbGQgY2hpcHMgdG8gc2VsZWN0IHByb3BlciBiYXNlIGNsb2NrIQogKiAtIEJhdWREaXZpc29yIGlzIGEgZml4ZWQgcG9pbnQgbnVtYmVyIGVuY29kZWQgaW4gYSBmdW5ueSB3YXkuCiAqICAgKC0tV1JPTkcgV0FZIE9GIFRISU5LSU5HLS0pCiAqICAgQmF1ZERpdmlzb3IgaXMgYSBmaXhlZCBwb2ludCBudW1iZXIgZW5jb2RlZCB3aXRoIGZvbGxvd2luZyBiaXQgd2VpZ2hzOgogKiAgICgtMikoLTEpKDEzLi4wKS4gSXQgaXMgYSByYWRpY2FsIHdpdGggYSBkZW5vbWluYXRvciBvZiA0LCBzbyB2YWx1ZXMKICogICBlbmQgd2l0aCAwLjAgKDAwLi4uKSwgMC4yNSAoMTAuLi4pLCAwLjUgKDAxLi4uKSwgYW5kIDAuNzUgKDExLi4uKS4KICogICAoLS1USEUgUkVBTElUWS0tKQogKiAgIFRoZSBib3RoLWJpdHMtc2V0IGhhcyBxdWl0ZSBkaWZmZXJlbnQgbWVhbmluZyBmcm9tIDAuNzUgLSB0aGUgY2hpcCBkZXNpZ25lcnMKICogICBoYXZlIGRlY2lkZWQgaXQgdG8gbWVhbiAwLjEyNSBpbnN0ZWFkIG9mIDAuNzUuCiAqICAgVGhpcyBpbmZvIGxvb2tlZCB1cCBpbiBGVERJIGFwcGxpY2F0aW9uIG5vdGUgIkZUOFUyMzIgREVWSUNFUyBcIERhdGEgUmF0ZXMKICogICBhbmQgRmxvdyBDb250cm9sIENvbnNpZGVyYXRpb24gZm9yIFVTQiB0byBSUzIzMiIuCiAqIC0gQmF1ZERpdmlzb3IgPSAoQmFzZUNsb2NrIC8gMTYpIC8gQmF1ZFJhdGUsIHdoZXJlIHRoZSAoPSkgb3BlcmF0aW9uIHNob3VsZAogKiAgIGF1dG9tYWdpY2FsbHkgcmUtZW5jb2RlIHRoZSByZXN1bHRpbmcgdmFsdWUgdG8gdGFrZSBmcmFjdGlvbnMgaW50byBjb25zaWRlcmF0aW9uLgogKiBBcyBhbGwgdmFsdWVzIGFyZSBpbnRlZ2Vycywgc29tZSBiaXQgdHdpZGRsaW5nIGlzIGluIG9yZGVyOgogKiAgIEJhdWREaXZpc29yID0gKEJhc2VDbG9jayAvIDE2IC8gQmF1ZFJhdGUpIHwKICogICAoKChCYXNlQ2xvY2sgLyAyIC8gQmF1ZFJhdGUpICYgNCkgPyAweDQwMDAgICAgLy8gMC41CiAqICAgIDogKChCYXNlQ2xvY2sgLyAyIC8gQmF1ZFJhdGUpICYgMikgPyAweDgwMDAgIC8vIDAuMjUKICogICAgOiAoKEJhc2VDbG9jayAvIDIgLyBCYXVkUmF0ZSkgJiAxKSA/IDB4YzAwMCAgLy8gMC4xMjUKICogICAgOiAwKQogKgogKiBGb3IgdGhlIEZUMjMyQk0sIGEgMTd0aCBkaXZpc29yIGJpdCB3YXMgaW50cm9kdWNlZCB0byBlbmNvZGUgdGhlIG11bHRpcGxlcwogKiBvZiAwLjEyNSBtaXNzaW5nIGZyb20gdGhlIEZUOFUyMzJBTS4gIEJpdHMgMTYgdG8gMTQgYXJlIGNvZGVkIGFzIGZvbGxvd3MKICogKHRoZSBmaXJzdCBmb3VyIGNvZGVzIGFyZSB0aGUgc2FtZSBhcyBmb3IgdGhlIEZUOFUyMzJBTSwgd2hlcmUgYml0IDE2IGlzCiAqIGFsd2F5cyAwKToKICogICAwMDAgLSBhZGQgLjAwMCB0byBkaXZpc29yCiAqICAgMDAxIC0gYWRkIC41MDAgdG8gZGl2aXNvcgogKiAgIDAxMCAtIGFkZCAuMjUwIHRvIGRpdmlzb3IKICogICAwMTEgLSBhZGQgLjEyNSB0byBkaXZpc29yCiAqICAgMTAwIC0gYWRkIC4zNzUgdG8gZGl2aXNvcgogKiAgIDEwMSAtIGFkZCAuNjI1IHRvIGRpdmlzb3IKICogICAxMTAgLSBhZGQgLjc1MCB0byBkaXZpc29yCiAqICAgMTExIC0gYWRkIC44NzUgdG8gZGl2aXNvcgogKiBCaXRzIDE1IHRvIDAgb2YgdGhlIDE3LWJpdCBkaXZpc29yIGFyZSBwbGFjZWQgaW4gdGhlIHVyYiB2YWx1ZS4gIEJpdCAxNiBpcyAKICogcGxhY2VkIGluIGJpdCAwIG9mIHRoZSB1cmIgaW5kZXguCiAqCiAqIE5vdGUgdGhhdCB0aGVyZSBhcmUgYSBjb3VwbGUgb2Ygc3BlY2lhbCBjYXNlcyB0byBzdXBwb3J0IHRoZSBoaWdoZXN0IGJhdWQKICogcmF0ZXMuICBJZiB0aGUgY2FsY3VsYXRlZCBkaXZpc29yIHZhbHVlIGlzIDEsIHRoaXMgbmVlZHMgdG8gYmUgcmVwbGFjZWQgd2l0aAogKiAwLiAgQWRkaXRpb25hbGx5IGZvciB0aGUgRlQyMzJCTSwgaWYgdGhlIGNhbGN1bGF0ZWQgZGl2aXNvciB2YWx1ZSBpcyAweDQwMDEKICogKDEuNSksIHRoaXMgbmVlZHMgdG8gYmUgcmVwbGFjZWQgd2l0aCAweDAwMDEgKDEpIChidXQgdGhpcyBkaXZpc29yIHZhbHVlIGlzCiAqIG5vdCBzdXBwb3J0ZWQgYnkgdGhlIEZUOFUyMzJBTSkuCiAqLwoKdHlwZWRlZiBlbnVtIHsKCVNJTyA9IDEsCglGVDhVMjMyQU0gPSAyLAoJRlQyMzJCTSA9IDMsCglGVDIyMzJDID0gNCwKfSBmdGRpX2NoaXBfdHlwZV90OwoKdHlwZWRlZiBlbnVtIHsKIGZ0ZGlfc2lvX2IzMDAgPSAwLCAKIGZ0ZGlfc2lvX2I2MDAgPSAxLCAKIGZ0ZGlfc2lvX2IxMjAwID0gMiwKIGZ0ZGlfc2lvX2IyNDAwID0gMywKIGZ0ZGlfc2lvX2I0ODAwID0gNCwKIGZ0ZGlfc2lvX2I5NjAwID0gNSwKIGZ0ZGlfc2lvX2IxOTIwMCA9IDYsCiBmdGRpX3Npb19iMzg0MDAgPSA3LAogZnRkaV9zaW9fYjU3NjAwID0gOCwKIGZ0ZGlfc2lvX2IxMTUyMDAgPSA5Cn0gRlRESV9TSU9fYmF1ZHJhdGVfdCA7CgovKgogKiBUaGUgZnRkaV84VTIzMkFNX3h4TUh6X2J5eXkgY29uc3RhbnRzIGhhdmUgYmVlbiByZW1vdmVkLiBUaGUgZW5jb2RlZCBkaXZpc29yIHZhbHVlcwogKiBhcmUgY2FsY3VsYXRlZCBpbnRlcm5hbGx5LgogKi8KCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfUkVRVUVTVCBGVERJX1NJT19TRVRfREFUQQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1JFUVVFU1RfVFlQRSAweDQwCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfUEFSSVRZX05PTkUgKDB4MCA8PCA4ICkKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9QQVJJVFlfT0REICgweDEgPDwgOCApCiNkZWZpbmUgRlRESV9TSU9fU0VUX0RBVEFfUEFSSVRZX0VWRU4gKDB4MiA8PCA4ICkKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9QQVJJVFlfTUFSSyAoMHgzIDw8IDggKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1BBUklUWV9TUEFDRSAoMHg0IDw8IDggKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1NUT1BfQklUU18xICgweDAgPDwgMTEgKQojZGVmaW5lIEZURElfU0lPX1NFVF9EQVRBX1NUT1BfQklUU18xNSAoMHgxIDw8IDExICkKI2RlZmluZSBGVERJX1NJT19TRVRfREFUQV9TVE9QX0JJVFNfMiAoMHgyIDw8IDExICkKI2RlZmluZSBGVERJX1NJT19TRVRfQlJFQUsgKDB4MSA8PCAxNCkKLyogRlRESV9TSU9fU0VUX0RBVEEgKi8KCi8qCiAqIEJtUmVxdWVzdFR5cGU6ICAwMTAwIDAwMDBCIAogKiBiUmVxdWVzdDogICAgICAgRlRESV9TSU9fU0VUX0RBVEEKICogd1ZhbHVlOiAgICAgICAgIERhdGEgY2hhcmFjdGVyaXN0aWNzIChzZWUgYmVsb3cpCiAqIHdJbmRleDogICAgICAgICBQb3J0CiAqIHdMZW5ndGg6ICAgICAgICAwCiAqIERhdGE6ICAgICAgICAgICBObwogKgogKiBEYXRhIGNoYXJhY3RlcmlzdGljcwogKgogKiAgIEIwLi43ICAgTnVtYmVyIG9mIGRhdGEgYml0cwogKiAgIEI4Li4xMCAgUGFyaXR5CiAqICAgICAgICAgICAwID0gTm9uZQogKiAgICAgICAgICAgMSA9IE9kZAogKiAgICAgICAgICAgMiA9IEV2ZW4KICogICAgICAgICAgIDMgPSBNYXJrCiAqICAgICAgICAgICA0ID0gU3BhY2UKICogICBCMTEuLjEzIFN0b3AgQml0cwogKiAgICAgICAgICAgMCA9IDEKICogICAgICAgICAgIDEgPSAxLjUKICogICAgICAgICAgIDIgPSAyCiAqICAgQjE0CiAqICAgICAgICAgICAxID0gVFggT04gKGJyZWFrKQogKiAgICAgICAgICAgMCA9IFRYIE9GRiAobm9ybWFsIHN0YXRlKQogKiAgIEIxNSBSZXNlcnZlZAogKgogKi8KCgoKLyogRlRESV9TSU9fTU9ERU1fQ1RSTCAqLwojZGVmaW5lIEZURElfU0lPX1NFVF9NT0RFTV9DVFJMX1JFUVVFU1RfVFlQRSAweDQwCiNkZWZpbmUgRlRESV9TSU9fU0VUX01PREVNX0NUUkxfUkVRVUVTVCBGVERJX1NJT19NT0RFTV9DVFJMCgovKiAKICogQm1SZXF1ZXN0VHlwZTogICAwMTAwIDAwMDBCCiAqIGJSZXF1ZXN0OiAgICAgICAgRlRESV9TSU9fTU9ERU1fQ1RSTAogKiB3VmFsdWU6ICAgICAgICAgIENvbnRyb2xWYWx1ZSAoc2VlIGJlbG93KQogKiB3SW5kZXg6ICAgICAgICAgIFBvcnQKICogd0xlbmd0aDogICAgICAgICAwCiAqIERhdGE6ICAgICAgICAgICAgTm9uZQogKgogKiBOT1RFOiBJZiB0aGUgZGV2aWNlIGlzIGluIFJUUy9DVFMgZmxvdyBjb250cm9sLCB0aGUgUlRTIHNldCBieSB0aGlzCiAqIGNvbW1hbmQgd2lsbCBiZSBJR05PUkVEIHdpdGhvdXQgYW4gZXJyb3IgYmVpbmcgcmV0dXJuZWQKICogQWxzbyAtIHlvdSBjYW4gbm90IHNldCBEVFIgYW5kIFJUUyB3aXRoIG9uZSBjb250cm9sIG1lc3NhZ2UKICovCgojZGVmaW5lIEZURElfU0lPX1NFVF9EVFJfTUFTSyAweDEKI2RlZmluZSBGVERJX1NJT19TRVRfRFRSX0hJR0ggKCAxIHwgKCBGVERJX1NJT19TRVRfRFRSX01BU0sgIDw8IDgpKQojZGVmaW5lIEZURElfU0lPX1NFVF9EVFJfTE9XICAoIDAgfCAoIEZURElfU0lPX1NFVF9EVFJfTUFTSyAgPDwgOCkpCiNkZWZpbmUgRlRESV9TSU9fU0VUX1JUU19NQVNLIDB4MgojZGVmaW5lIEZURElfU0lPX1NFVF9SVFNfSElHSCAoIDIgfCAoIEZURElfU0lPX1NFVF9SVFNfTUFTSyA8PCA4ICkpCiNkZWZpbmUgRlRESV9TSU9fU0VUX1JUU19MT1cgKCAwIHwgKCBGVERJX1NJT19TRVRfUlRTX01BU0sgPDwgOCApKQoKLyoKICogQ29udHJvbFZhbHVlCiAqIEIwICAgIERUUiBzdGF0ZQogKiAgICAgICAgICAwID0gcmVzZXQKICogICAgICAgICAgMSA9IHNldAogKiBCMSAgICBSVFMgc3RhdGUKICogICAgICAgICAgMCA9IHJlc2V0CiAqICAgICAgICAgIDEgPSBzZXQKICogQjIuLjcgUmVzZXJ2ZWQKICogQjggICAgRFRSIHN0YXRlIGVuYWJsZQogKiAgICAgICAgICAwID0gaWdub3JlCiAqICAgICAgICAgIDEgPSB1c2UgRFRSIHN0YXRlCiAqIEI5ICAgIFJUUyBzdGF0ZSBlbmFibGUKICogICAgICAgICAgMCA9IGlnbm9yZQogKiAgICAgICAgICAxID0gdXNlIFJUUyBzdGF0ZQogKiBCMTAuLjE1IFJlc2VydmVkCiAqLwoKLyogRlRESV9TSU9fU0VUX0ZMT1dfQ1RSTCAqLwojZGVmaW5lIEZURElfU0lPX1NFVF9GTE9XX0NUUkxfUkVRVUVTVF9UWVBFIDB4NDAKI2RlZmluZSBGVERJX1NJT19TRVRfRkxPV19DVFJMX1JFUVVFU1QgRlRESV9TSU9fU0VUX0ZMT1dfQ1RSTAojZGVmaW5lIEZURElfU0lPX0RJU0FCTEVfRkxPV19DVFJMIDB4MCAKI2RlZmluZSBGVERJX1NJT19SVFNfQ1RTX0hTICgweDEgPDwgOCkKI2RlZmluZSBGVERJX1NJT19EVFJfRFNSX0hTICgweDIgPDwgOCkKI2RlZmluZSBGVERJX1NJT19YT05fWE9GRl9IUyAoMHg0IDw8IDgpCi8qCiAqICAgQm1SZXF1ZXN0VHlwZTogIDAxMDAgMDAwMGIKICogICBiUmVxdWVzdDogICAgICAgRlRESV9TSU9fU0VUX0ZMT1dfQ1RSTAogKiAgIHdWYWx1ZTogICAgICAgICBYb2ZmL1hvbgogKiAgIHdJbmRleDogICAgICAgICBQcm90b2NvbC9Qb3J0IC0gaEluZGV4IGlzIHByb3RvY2wgLyBsSW5kZXggaXMgcG9ydAogKiAgIHdMZW5ndGg6ICAgICAgICAwIAogKiAgIERhdGE6ICAgICAgICAgICBOb25lCiAqCiAqIGhJbmRleCBwcm90b2NvbCBpczoKICogICBCMCBPdXRwdXQgaGFuZHNoYWtpbmcgdXNpbmcgUlRTL0NUUwogKiAgICAgICAwID0gZGlzYWJsZWQKICogICAgICAgMSA9IGVuYWJsZWQKICogICBCMSBPdXRwdXQgaGFuZHNoYWtpbmcgdXNpbmcgRFRSL0RTUgogKiAgICAgICAwID0gZGlzYWJsZWQKICogICAgICAgMSA9IGVuYWJsZWQKICogICBCMiBYb24vWG9mZiBoYW5kc2hha2luZwogKiAgICAgICAwID0gZGlzYWJsZWQKICogICAgICAgMSA9IGVuYWJsZWQKICoKICogQSB2YWx1ZSBvZiB6ZXJvIGluIHRoZSBoSW5kZXggZmllbGQgZGlzYWJsZXMgaGFuZHNoYWtpbmcKICoKICogSWYgWG9uL1hvZmYgaGFuZHNoYWtpbmcgaXMgc3BlY2lmaWVkLCB0aGUgaFZhbHVlIGZpZWxkIHNob3VsZCBjb250YWluIHRoZSBYT0ZGIGNoYXJhY3RlciAKICogYW5kIHRoZSBsVmFsdWUgZmllbGQgY29udGFpbnMgdGhlIFhPTiBjaGFyYWN0ZXIuCiAqLyAgCiAKLyoKICogRlRESV9TSU9fR0VUX0xBVEVOQ1lfVElNRVIKICoKICogU2V0IHRoZSB0aW1lb3V0IGludGVydmFsLiBUaGUgRlRESSBjb2xsZWN0cyBkYXRhIGZyb20gdGhlIHNsYXZlCiAqIGRldmljZSwgdHJhbnNtaXR0aW5nIGl0IHRvIHRoZSBob3N0IHdoZW4gZWl0aGVyIEEpIDYyIGJ5dGVzIGFyZQogKiByZWNlaXZlZCwgb3IgQikgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgaGFzIGVsYXBzZWQgYW5kIHRoZSBidWZmZXIKICogY29udGFpbnMgYXQgbGVhc3QgMSBieXRlLiAgU2V0dGluZyB0aGlzIHZhbHVlIHRvIGEgc21hbGwgbnVtYmVyCiAqIGNhbiBkcmFtYXRpY2FsbHkgaW1wcm92ZSBwZXJmb3JtYW5jZSBmb3IgYXBwbGljYXRpb25zIHdoaWNoIHNlbmQKICogc21hbGwgcGFja2V0cywgc2luY2UgdGhlIGRlZmF1bHQgdmFsdWUgaXMgMTZtcy4KICovCiNkZWZpbmUgIEZURElfU0lPX0dFVF9MQVRFTkNZX1RJTUVSX1JFUVVFU1QgRlRESV9TSU9fR0VUX0xBVEVOQ1lfVElNRVIKI2RlZmluZSAgRlRESV9TSU9fR0VUX0xBVEVOQ1lfVElNRVJfUkVRVUVTVF9UWVBFIDB4QzAKCi8qIAogKiAgQm1SZXF1ZXN0VHlwZTogICAxMTAwIDAwMDBiCiAqICBiUmVxdWVzdDogICAgICAgIEZURElfU0lPX0dFVF9MQVRFTkNZX1RJTUVSCiAqICB3VmFsdWU6ICAgICAgICAgIDAKICogIHdJbmRleDogICAgICAgICAgUG9ydAogKiAgd0xlbmd0aDogICAgICAgICAwCiAqICBEYXRhOiAgICAgICAgICAgIGxhdGVuY3kgKG9uIHJldHVybikKICovCgovKiAKICogRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVIKICoKICogU2V0IHRoZSB0aW1lb3V0IGludGVydmFsLiBUaGUgRlRESSBjb2xsZWN0cyBkYXRhIGZyb20gdGhlIHNsYXZlCiAqIGRldmljZSwgdHJhbnNtaXR0aW5nIGl0IHRvIHRoZSBob3N0IHdoZW4gZWl0aGVyIEEpIDYyIGJ5dGVzIGFyZQogKiByZWNlaXZlZCwgb3IgQikgdGhlIHRpbWVvdXQgaW50ZXJ2YWwgaGFzIGVsYXBzZWQgYW5kIHRoZSBidWZmZXIKICogY29udGFpbnMgYXQgbGVhc3QgMSBieXRlLiAgU2V0dGluZyB0aGlzIHZhbHVlIHRvIGEgc21hbGwgbnVtYmVyCiAqIGNhbiBkcmFtYXRpY2FsbHkgaW1wcm92ZSBwZXJmb3JtYW5jZSBmb3IgYXBwbGljYXRpb25zIHdoaWNoIHNlbmQKICogc21hbGwgcGFja2V0cywgc2luY2UgdGhlIGRlZmF1bHQgdmFsdWUgaXMgMTZtcy4KICovCiNkZWZpbmUgIEZURElfU0lPX1NFVF9MQVRFTkNZX1RJTUVSX1JFUVVFU1QgRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVIKI2RlZmluZSAgRlRESV9TSU9fU0VUX0xBVEVOQ1lfVElNRVJfUkVRVUVTVF9UWVBFIDB4NDAKCi8qIAogKiAgQm1SZXF1ZXN0VHlwZTogICAwMTAwIDAwMDBiCiAqICBiUmVxdWVzdDogICAgICAgIEZURElfU0lPX1NFVF9MQVRFTkNZX1RJTUVSCiAqICB3VmFsdWU6ICAgICAgICAgIExhdGVuY3kgKG1pbGxpc2Vjb25kcykKICogIHdJbmRleDogICAgICAgICAgUG9ydAogKiAgd0xlbmd0aDogICAgICAgICAwCiAqICBEYXRhOiAgICAgICAgICAgIE5vbmUKICoKICogd1ZhbHVlOgogKiAgIEIwLi43ICAgTGF0ZW5jeSB0aW1lcgogKiAgIEI4Li4xNSAgMAogKgogKi8KCi8qCiAqIEZURElfU0lPX1NFVF9FVkVOVF9DSEFSIAogKgogKiBTZXQgdGhlIHNwZWNpYWwgZXZlbnQgY2hhcmFjdGVyIGZvciB0aGUgc3BlY2lmaWVkIGNvbW11bmljYXRpb25zIHBvcnQuCiAqIElmIHRoZSBkZXZpY2Ugc2VlcyB0aGlzIGNoYXJhY3RlciBpdCB3aWxsIGltbWVkaWF0ZWx5IHJldHVybiB0aGUKICogZGF0YSByZWFkIHNvIGZhciAtIHJhdGhlciB0aGFuIHdhaXQgNDBtcyBvciB1bnRpbCA2MiBieXRlcyBhcmUgcmVhZAogKiB3aGljaCBpcyB3aGF0IG5vcm1hbGx5IGhhcHBlbnMuCiAqLwoKCiNkZWZpbmUgIEZURElfU0lPX1NFVF9FVkVOVF9DSEFSX1JFUVVFU1QgRlRESV9TSU9fU0VUX0VWRU5UX0NIQVIKI2RlZmluZSAgRlRESV9TSU9fU0VUX0VWRU5UX0NIQVJfUkVRVUVTVF9UWVBFIDB4NDAKCgovKiAKICogIEJtUmVxdWVzdFR5cGU6ICAgMDEwMCAwMDAwYgogKiAgYlJlcXVlc3Q6ICAgICAgICBGVERJX1NJT19TRVRfRVZFTlRfQ0hBUgogKiAgd1ZhbHVlOiAgICAgICAgICBFdmVudENoYXIKICogIHdJbmRleDogICAgICAgICAgUG9ydAogKiAgd0xlbmd0aDogICAgICAgICAwCiAqICBEYXRhOiAgICAgICAgICAgIE5vbmUKICoKICogd1ZhbHVlOgogKiAgIEIwLi43ICAgRXZlbnQgQ2hhcmFjdGVyCiAqICAgQjggICAgICBFdmVudCBDaGFyYWN0ZXIgUHJvY2Vzc2luZwogKiAgICAgICAgICAgICAwID0gZGlzYWJsZWQKICogICAgICAgICAgICAgMSA9IGVuYWJsZWQKICogICBCOS4uMTUgIFJlc2VydmVkCiAqCiAqLwogICAgICAgICAgCi8qIEZURElfU0lPX1NFVF9FUlJPUl9DSEFSICovCgovKiBTZXQgdGhlIHBhcml0eSBlcnJvciByZXBsYWNlbWVudCBjaGFyYWN0ZXIgZm9yIHRoZSBzcGVjaWZpZWQgY29tbXVuaWNhdGlvbnMgcG9ydCAqLwoKLyogCiAqICBCbVJlcXVlc3RUeXBlOiAgMDEwMCAwMDAwYgogKiAgYlJlcXVlc3Q6ICAgICAgIEZURElfU0lPX1NFVF9FVkVOVF9DSEFSCiAqICB3VmFsdWU6ICAgICAgICAgRXJyb3IgQ2hhcgogKiAgd0luZGV4OiAgICAgICAgIFBvcnQKICogIHdMZW5ndGg6ICAgICAgICAwCiAqICBEYXRhOiAgICAgICAgICAgTm9uZQogKgogKkVycm9yIENoYXIKICogIEIwLi43ICBFcnJvciBDaGFyYWN0ZXIKICogIEI4ICAgICBFcnJvciBDaGFyYWN0ZXIgUHJvY2Vzc2luZwogKiAgICAgICAgICAgMCA9IGRpc2FibGVkCiAqICAgICAgICAgICAxID0gZW5hYmxlZAogKiAgQjkuLjE1IFJlc2VydmVkCiAqCiAqLwoKLyogRlRESV9TSU9fR0VUX01PREVNX1NUQVRVUyAqLwovKiBSZXRyaWV2ZSB0aGUgY3VycmVudCB2YWx1ZSBvZiB0aGUgbW9kZW0gc3RhdHVzIHJlZ2lzdGVyICovCgojZGVmaW5lIEZURElfU0lPX0dFVF9NT0RFTV9TVEFUVVNfUkVRVUVTVF9UWVBFIDB4YzAKI2RlZmluZSBGVERJX1NJT19HRVRfTU9ERU1fU1RBVFVTX1JFUVVFU1QgRlRESV9TSU9fR0VUX01PREVNX1NUQVRVUwojZGVmaW5lIEZURElfU0lPX0NUU19NQVNLIDB4MTAKI2RlZmluZSBGVERJX1NJT19EU1JfTUFTSyAweDIwCiNkZWZpbmUgRlRESV9TSU9fUklfTUFTSyAgMHg0MAojZGVmaW5lIEZURElfU0lPX1JMU0RfTUFTSyAweDgwCi8qIAogKiAgIEJtUmVxdWVzdFR5cGU6ICAgMTEwMCAwMDAwYgogKiAgIGJSZXF1ZXN0OiAgICAgICAgRlRESV9TSU9fR0VUX01PREVNX1NUQVRVUwogKiAgIHdWYWx1ZTogICAgICAgICAgemVybwogKiAgIHdJbmRleDogICAgICAgICAgUG9ydAogKiAgIHdMZW5ndGg6ICAgICAgICAgMQogKiAgIERhdGE6ICAgICAgICAgICAgU3RhdHVzCiAqIAogKiBPbmUgYnl0ZSBvZiBkYXRhIGlzIHJldHVybmVkIAogKiBCMC4uMyAwCiAqIEI0ICAgIENUUwogKiAgICAgICAgIDAgPSBpbmFjdGl2ZQogKiAgICAgICAgIDEgPSBhY3RpdmUKICogQjUgICAgRFNSCiAqICAgICAgICAgMCA9IGluYWN0aXZlCiAqICAgICAgICAgMSA9IGFjdGl2ZQogKiBCNiAgICBSaW5nIEluZGljYXRvciAoUkkpCiAqICAgICAgICAgMCA9IGluYWN0aXZlCiAqICAgICAgICAgMSA9IGFjdGl2ZQogKiBCNyAgICBSZWNlaXZlIExpbmUgU2lnbmFsIERldGVjdCAoUkxTRCkKICogICAgICAgICAwID0gaW5hY3RpdmUKICogICAgICAgICAxID0gYWN0aXZlIAogKi8KCgoKLyogRGVzY3JpcHRvcnMgcmV0dXJuZWQgYnkgdGhlIGRldmljZSAKICogCiAqICBEZXZpY2UgRGVzY3JpcHRvcgogKiAKICogT2Zmc2V0CUZpZWxkCQlTaXplCVZhbHVlCURlc2NyaXB0aW9uCiAqIDAJYkxlbmd0aAkJMQkweDEyCVNpemUgb2YgZGVzY3JpcHRvciBpbiBieXRlcwogKiAxCWJEZXNjcmlwdG9yVHlwZQkxCTB4MDEJREVWSUNFIERlc2NyaXB0b3IgVHlwZQogKiAyCWJjZFVTQgkJMgkweDAxMTAJVVNCIFNwZWMgUmVsZWFzZSBOdW1iZXIKICogNAliRGV2aWNlQ2xhc3MJMQkweDAwCUNsYXNzIENvZGUKICogNQliRGV2aWNlU3ViQ2xhc3MJMQkweDAwCVN1YkNsYXNzIENvZGUKICogNgliRGV2aWNlUHJvdG9jb2wJMQkweDAwCVByb3RvY29sIENvZGUKICogNwliTWF4UGFja2V0U2l6ZTAgMQkweDA4CU1heGltdW0gcGFja2V0IHNpemUgZm9yIGVuZHBvaW50IDAKICogOAlpZFZlbmRvcgkyCTB4MDQwMwlWZW5kb3IgSUQKICogMTAJaWRQcm9kdWN0CTIJMHg4MzcyCVByb2R1Y3QgSUQgKEZURElfU0lPX1BJRCkKICogMTIJYmNkRGV2aWNlCTIJMHgwMDAxCURldmljZSByZWxlYXNlIG51bWJlcgogKiAxNAlpTWFudWZhY3R1cmVyCTEJMHgwMQlJbmRleCBvZiBtYW4uIHN0cmluZyBkZXNjCiAqIDE1CWlQcm9kdWN0CTEJMHgwMglJbmRleCBvZiBwcm9kIHN0cmluZyBkZXNjCiAqIDE2CWlTZXJpYWxOdW1iZXIJMQkweDAyCUluZGV4IG9mIHNlcmlhbCBubXIgc3RyaW5nIGRlc2MKICogMTcJYk51bUNvbmZpZ3VyYXRpb25zIDEgICAgMHgwMQlOdW1iZXIgb2YgcG9zc2libGUgY29uZmlndXJhdGlvbnMKICogCiAqIENvbmZpZ3VyYXRpb24gRGVzY3JpcHRvcgogKiAKICogT2Zmc2V0CUZpZWxkCQkJU2l6ZQlWYWx1ZQogKiAwCWJMZW5ndGgJCQkxCTB4MDkJU2l6ZSBvZiBkZXNjcmlwdG9yIGluIGJ5dGVzCiAqIDEJYkRlc2NyaXB0b3JUeXBlCQkxCTB4MDIJQ09ORklHVVJBVElPTiBEZXNjcmlwdG9yIFR5cGUKICogMgl3VG90YWxMZW5ndGgJCTIJMHgwMDIwCVRvdGFsIGxlbmd0aCBvZiBkYXRhCiAqIDQJYk51bUludGVyZmFjZXMJCTEJMHgwMQlOdW1iZXIgb2YgaW50ZXJmYWNlcyBzdXBwb3J0ZWQKICogNQliQ29uZmlndXJhdGlvblZhbHVlCTEJMHgwMQlBcmd1bWVudCBmb3IgU2V0Q09uZmlndXJhdGlvbigpIHJlcQogKiA2CWlDb25maWd1cmF0aW9uCQkxCTB4MDIJSW5kZXggb2YgY29uZmlnIHN0cmluZyBkZXNjcmlwdG9yCiAqIDcJYm1BdHRyaWJ1dGVzCQkxCTB4MjAJQ29uZmlnIGNoYXJhY3RlcmlzdGljcyBSZW1vdGUgV2FrZXVwCiAqIDgJTWF4UG93ZXIJCTEJMHgxRQlNYXggcG93ZXIgY29uc3VtcHRpb24KICogCiAqIEludGVyZmFjZSBEZXNjcmlwdG9yCiAqIAogKiBPZmZzZXQJRmllbGQJCQlTaXplCVZhbHVlCiAqIDAJYkxlbmd0aAkJCTEJMHgwOQlTaXplIG9mIGRlc2NyaXB0b3IgaW4gYnl0ZXMKICogMQliRGVzY3JpcHRvclR5cGUJCTEJMHgwNAlJTlRFUkZBQ0UgRGVzY3JpcHRvciBUeXBlCiAqIDIJYkludGVyZmFjZU51bWJlcgkxCTB4MDAJTnVtYmVyIG9mIGludGVyZmFjZQogKiAzCWJBbHRlcm5hdGVTZXR0aW5nCTEJMHgwMAlWYWx1ZSB1c2VkIHRvIHNlbGVjdCBhbHRlcm5hdGUKICogNAliTnVtRW5kcG9pbnRzCQkxCTB4MDIJTnVtYmVyIG9mIGVuZHBvaW50cwogKiA1CWJJbnRlcmZhY2VDbGFzcwkJMQkweEZGCUNsYXNzIENvZGUKICogNgliSW50ZXJmYWNlU3ViQ2xhc3MJMQkweEZGCVN1YmNsYXNzIENvZGUKICogNwliSW50ZXJmYWNlUHJvdG9jb2wJMQkweEZGCVByb3RvY29sIENvZGUKICogOAlpSW50ZXJmYWNlCQkxCTB4MDIJSW5kZXggb2YgaW50ZXJmYWNlIHN0cmluZyBkZXNjcmlwdGlvbgogKiAKICogSU4gRW5kcG9pbnQgRGVzY3JpcHRvcgogKiAKICogT2Zmc2V0CUZpZWxkCQkJU2l6ZQlWYWx1ZQogKiAwCWJMZW5ndGgJCQkxCTB4MDcJU2l6ZSBvZiBkZXNjcmlwdG9yIGluIGJ5dGVzCiAqIDEJYkRlc2NyaXB0b3JUeXBlCQkxCTB4MDUJRU5EUE9JTlQgZGVzY3JpcHRvciB0eXBlCiAqIDIJYkVuZHBvaW50QWRkcmVzcwkxCTB4ODIJQWRkcmVzcyBvZiBlbmRwb2ludAogKiAzCWJtQXR0cmlidXRlcwkJMQkweDAyCUVuZHBvaW50IGF0dHJpYnV0ZXMgLSBCdWxrCiAqIDQJYk51bUVuZHBvaW50cwkJMgkweDAwNDAJbWF4aW11bSBwYWNrZXQgc2l6ZQogKiA1CWJJbnRlcnZhbAkJMQkweDAwCUludGVydmFsIGZvciBwb2xsaW5nIGVuZHBvaW50CiAqIAogKiBPVVQgRW5kcG9pbnQgRGVzY3JpcHRvcgogKiAKICogT2Zmc2V0CUZpZWxkCQkJU2l6ZQlWYWx1ZQogKiAwCWJMZW5ndGgJCQkxCTB4MDcJU2l6ZSBvZiBkZXNjcmlwdG9yIGluIGJ5dGVzCiAqIDEJYkRlc2NyaXB0b3JUeXBlCQkxCTB4MDUJRU5EUE9JTlQgZGVzY3JpcHRvciB0eXBlCiAqIDIJYkVuZHBvaW50QWRkcmVzcwkxCTB4MDIJQWRkcmVzcyBvZiBlbmRwb2ludAogKiAzCWJtQXR0cmlidXRlcwkJMQkweDAyCUVuZHBvaW50IGF0dHJpYnV0ZXMgLSBCdWxrCiAqIDQJYk51bUVuZHBvaW50cwkJMgkweDAwNDAJbWF4aW11bSBwYWNrZXQgc2l6ZQogKiA1CWJJbnRlcnZhbAkJMQkweDAwCUludGVydmFsIGZvciBwb2xsaW5nIGVuZHBvaW50CiAqICAgICAKICogREFUQSBGT1JNQVQKICogCiAqIElOIEVuZHBvaW50CiAqIAogKiBUaGUgZGV2aWNlIHJlc2VydmVzIHRoZSBmaXJzdCB0d28gYnl0ZXMgb2YgZGF0YSBvbiB0aGlzIGVuZHBvaW50IHRvIGNvbnRhaW4gdGhlIGN1cnJlbnQKICogdmFsdWVzIG9mIHRoZSBtb2RlbSBhbmQgbGluZSBzdGF0dXMgcmVnaXN0ZXJzLiBJbiB0aGUgYWJzZW5jZSBvZiBkYXRhLCB0aGUgZGV2aWNlIAogKiBnZW5lcmF0ZXMgYSBtZXNzYWdlIGNvbnNpc3Rpbmcgb2YgdGhlc2UgdHdvIHN0YXR1cyBieXRlcyBldmVyeSA0MCBtcwogKiAKICogQnl0ZSAwOiBNb2RlbSBTdGF0dXMKICogCiAqIE9mZnNldAlEZXNjcmlwdGlvbgogKiBCMAlSZXNlcnZlZCAtIG11c3QgYmUgMQogKiBCMQlSZXNlcnZlZCAtIG11c3QgYmUgMAogKiBCMglSZXNlcnZlZCAtIG11c3QgYmUgMAogKiBCMwlSZXNlcnZlZCAtIG11c3QgYmUgMAogKiBCNAlDbGVhciB0byBTZW5kIChDVFMpCiAqIEI1CURhdGEgU2V0IFJlYWR5IChEU1IpCiAqIEI2CVJpbmcgSW5kaWNhdG9yIChSSSkKICogQjcJUmVjZWl2ZSBMaW5lIFNpZ25hbCBEZXRlY3QgKFJMU0QpCiAqIAogKiBCeXRlIDE6IExpbmUgU3RhdHVzCiAqIAogKiBPZmZzZXQJRGVzY3JpcHRpb24KICogQjAJRGF0YSBSZWFkeSAoRFIpCiAqIEIxCU92ZXJydW4gRXJyb3IgKE9FKQogKiBCMglQYXJpdHkgRXJyb3IgKFBFKQogKiBCMwlGcmFtaW5nIEVycm9yIChGRSkKICogQjQJQnJlYWsgSW50ZXJydXB0IChCSSkKICogQjUJVHJhbnNtaXR0ZXIgSG9sZGluZyBSZWdpc3RlciAoVEhSRSkKICogQjYJVHJhbnNtaXR0ZXIgRW1wdHkgKFRFTVQpCiAqIEI3CUVycm9yIGluIFJDVlIgRklGTwogKiAKICovCiNkZWZpbmUgRlRESV9SUzBfQ1RTCSgxIDw8IDQpCiNkZWZpbmUgRlRESV9SUzBfRFNSCSgxIDw8IDUpCiNkZWZpbmUgRlRESV9SUzBfUkkJKDEgPDwgNikKI2RlZmluZSBGVERJX1JTMF9STFNECSgxIDw8IDcpCgojZGVmaW5lIEZURElfUlNfRFIgIDEKI2RlZmluZSBGVERJX1JTX09FICgxPDwxKQojZGVmaW5lIEZURElfUlNfUEUgKDE8PDIpCiNkZWZpbmUgRlRESV9SU19GRSAoMTw8MykKI2RlZmluZSBGVERJX1JTX0JJICgxPDw0KQojZGVmaW5lIEZURElfUlNfVEhSRSAoMTw8NSkKI2RlZmluZSBGVERJX1JTX1RFTVQgKDE8PDYpCiNkZWZpbmUgRlRESV9SU19GSUZPICAoMTw8NykKCi8qCiAqIE9VVCBFbmRwb2ludAogKiAKICogVGhpcyBkZXZpY2UgcmVzZXJ2ZXMgdGhlIGZpcnN0IGJ5dGVzIG9mIGRhdGEgb24gdGhpcyBlbmRwb2ludCBjb250YWluIHRoZSBsZW5ndGgKICogYW5kIHBvcnQgaWRlbnRpZmllciBvZiB0aGUgbWVzc2FnZS4gRm9yIHRoZSBGVERJIFVTQiBTZXJpYWwgY29udmVydGVyIHRoZSBwb3J0IAogKiBpZGVudGlmaWVyIGlzIGFsd2F5cyAxLgogKiAKICogQnl0ZSAwOiBMaW5lIFN0YXR1cwogKiAKICogT2Zmc2V0CURlc2NyaXB0aW9uCiAqIEIwCVJlc2VydmVkIC0gbXVzdCBiZSAxCiAqIEIxCVJlc2VydmVkIC0gbXVzdCBiZSAwCiAqIEIyLi43CUxlbmd0aCBvZiBtZXNzYWdlIC0gKG5vdCBpbmNsdWRpbmcgQnl0ZSAwKQogKiAKICovCgo=