LyogYWhhMTUyeC5jIC0tIEFkYXB0ZWMgQUhBLTE1MnggZHJpdmVyCiAqIEF1dGhvcjogSvxyZ2VuIEUuIEZpc2NoZXIsIGZpc2NoZXJAbm9yYml0LmRlCiAqIENvcHlyaWdodCAxOTkzLTIwMDQgSvxyZ2VuIEUuIEZpc2NoZXIKICoKICogVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vciBtb2RpZnkgaXQKICogdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnkgdGhlCiAqIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyIHZlcnNpb24gMiwgb3IgKGF0IHlvdXIgb3B0aW9uKSBhbnkKICogbGF0ZXIgdmVyc2lvbi4KICoKICogVGhpcyBwcm9ncmFtIGlzIGRpc3RyaWJ1dGVkIGluIHRoZSBob3BlIHRoYXQgaXQgd2lsbCBiZSB1c2VmdWwsIGJ1dAogKiBXSVRIT1VUIEFOWSBXQVJSQU5UWTsgd2l0aG91dCBldmVuIHRoZSBpbXBsaWVkIHdhcnJhbnR5IG9mCiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gIFNlZSB0aGUgR05VCiAqIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KICoKICoKICogJElkOiBhaGExNTJ4LmMsdiAyLjcgMjAwNC8wMS8yNCAxMTo0Mjo1OSBmaXNjaGVyIEV4cCAkCiAqCiAqICRMb2c6IGFoYTE1MnguYyx2ICQKICogUmV2aXNpb24gMi43ICAyMDA0LzAxLzI0IDExOjQyOjU5ICBmaXNjaGVyCiAqIC0gZ2F0aGVyIGNvZGUgdGhhdCBpcyBub3QgdXNlZCBieSBQQ01DSUEgYXQgdGhlIGVuZAogKiAtIG1vdmUgcmVxdWVzdF9yZWdpb24gZm9yICFQQ01DSUEgY2FzZSB0byBkZXRlY3Rpb24KICogLSBtaWdyYXRpb24gdG8gbmV3IHNjc2kgaG9zdCBhcGkgKHJlbW92ZSBsZWdhY3kgY29kZSkKICogLSBmcmVlIGhvc3Qgc2NyaWJibGUgYmVmb3JlIHNjc2lfZG9uZQogKiAtIGZpeCBlcnJvciBoYW5kbGluZwogKiAtIG9uZSBpc2FwbnAgZGV2aWNlIGFkZGVkIHRvIGlkX3RhYmxlCiAqCiAqIFJldmlzaW9uIDIuNiAgMjAwMy8xMC8zMCAyMDo1Mjo0NyAgZmlzY2hlcgogKiAtIGludGVyZmFjZXMgY2hhbmdlcyBmb3Iga2VybmVsIDIuNgogKiAtIGFoYTE1MnhfcHJvYmVfb25lIGludHJvZHVjZWQgZm9yIHBjbWNpYSBzdHViCiAqIC0gZml4ZWQgcG5wZGV2IGhhbmRsaW5nCiAqIC0gaW5zdGVhZCBvZiBhbGxvY2F0aW9uIGEgbmV3IG9uZSwgcmV1c2UgY29tbWFuZCBmb3IgcmVxdWVzdCBzZW5zZSBhZnRlciBjaGVjayBjb25kaXRpb24gYW5kIHJlc2V0CiAqIC0gZml4ZXMgcmFjZSBpbiBpc19jb21wbGV0ZQogKgogKiBSZXZpc2lvbiAyLjUgIDIwMDIvMDQvMTQgMTE6MjQ6NTMgIGZpc2NoZXIKICogLSBpc2FwbnAgc3VwcG9ydAogKiAtIGFib3J0IGZpeGVkCiAqIC0gMi41IHN1cHBvcnQKICoKICogUmV2aXNpb24gMi40ICAyMDAwLzEyLzE2IDEyOjUzOjU2ICBmaXNjaGVyCiAqIC0gYWxsb3cgUkVRVUVTVCBTRU5TRSB0byBiZSBxdWV1ZWQKICogLSBoYW5kbGUgc2hhcmVkIFBDSSBpbnRlcnJ1cHRzCiAqCiAqIFJldmlzaW9uIDIuMyAgMjAwMC8xMS8wNCAxNjo0MDoyNiAgZmlzY2hlcgogKiAtIGhhbmRsZSBkYXRhIG92ZXJydW5zCiAqIC0gZXh0ZW5kIHRpbWVvdXQgZm9yIGRhdGEgcGhhc2VzCiAqCiAqIFJldmlzaW9uIDIuMiAgMjAwMC8wOC8wOCAxOTo1NDo1MyAgZmlzY2hlcgogKiAtIG1pbm9yIGNoYW5nZXMKICoKICogUmV2aXNpb24gMi4xICAyMDAwLzA1LzE3IDE2OjIzOjE3ICBmaXNjaGVyCiAqIC0gc2lnbmF0dXJlIHVwZGF0ZQogKiAtIGZpeCBmb3IgZGF0YSBvdXQgdy9vIHNjYXR0ZXIgZ2F0aGVyCiAqCiAqIFJldmlzaW9uIDIuMCAgMTk5OS8xMi8yNSAxNTowNzozMiAgZmlzY2hlcgogKiAtIGludGVycnVwdCByb3V0aW5lIGNvbXBsZXRseSByZXdvcmtlZAogKiAtIGJhc2ljIHN1cHBvcnQgZm9yIG5ldyBlaCBjb2RlCiAqCiAqIFJldmlzaW9uIDEuMjEgIDE5OTkvMTEvMTAgMjM6NDY6MzYgIGZpc2NoZXIKICogLSBkZWZhdWx0IHRvIHN5bmNocm9ub3VzIG9wZXJhdGlvbgogKiAtIHN5bmNocm9ub3VzIG5lZ290aWF0aW9uIGZpeGVkCiAqIC0gYWRkZWQgdGltZW91dCB0byBsb29wcwogKiAtIGRlYnVnZ2luZyBvdXRwdXQgY2FuIGJlIGNvbnRyb2xsZWQgdGhyb3VnaCBwcm9jZnMKICoKICogUmV2aXNpb24gMS4yMCAgMTk5OS8xMS8wNyAxODozNzozMSAgZmlzY2hlcgogKiAtIHN5bmNocm9ub3VzIG9wZXJhdGlvbiB3b3JrcwogKiAtIHJlc2lkIHN1cHBvcnQgZm9yIHNnIGRyaXZlcgogKgogKiBSZXZpc2lvbiAxLjE5ICAxOTk5LzExLzAyIDIyOjM5OjU5ICBmaXNjaGVyCiAqIC0gbW92ZWQgbGVhZGluZyBjb21tZW50cyB0byBSRUFETUUuYWhhMTUyeAogKiAtIG5ldyBhZGRpdGlvbmFsIG1vZHVsZSBwYXJhbWV0ZXJzCiAqIC0gdXBkYXRlcyBmb3IgMi4zCiAqIC0gc3VwcG9ydCBmb3IgdGhlIFRyaXBhY2UgVEMxNTUwIGNvbnRyb2xsZXIKICogLSBpbnRlcnJ1cHQgaGFuZGxpbmcgY2hhbmdlZAogKgogKiBSZXZpc2lvbiAxLjE4ICAxOTk2LzA5LzA3IDIwOjEwOjQwICBmaXNjaGVyCiAqIC0gZml4ZWQgY2FuX3F1ZXVlIGhhbmRsaW5nIChtdWx0aXBsZSBvdXRzdGFuZGluZyBjb21tYW5kcyB3b3JraW5nIGFnYWluKQogKgogKiBSZXZpc2lvbiAxLjE3ICAxOTk2LzA4LzE3IDE2OjA1OjE0ICBmaXNjaGVyCiAqIC0gYmlvc3BhcmFtIGltcHJvdmVkCiAqIC0gaW50ZXJydXB0IHZlcmlmaWNhdGlvbgogKiAtIHVwZGF0ZWQgZG9jdW1lbnRhdGlvbgogKiAtIGNsZWFudXBzCiAqCiAqIFJldmlzaW9uIDEuMTYgIDE5OTYvMDYvMDkgMDA6MDQ6NTYgIHJvb3QKICogLSBhZGRlZCBjb25maWd1cmF0aW9uIHN5bWJvbHMgZm9yIGluc21vZCAoYWhhMTUyeC9haGExNTJ4MSkKICoKICogUmV2aXNpb24gMS4xNSAgMTk5Ni8wNC8zMCAxNDo1MjowNiAgZmlzY2hlcgogKiAtIHByb2MgaW5mbyBmaXhlZAogKiAtIHN1cHBvcnQgZm9yIGV4dGVuZGVkIHRyYW5zbGF0aW9uIGZvciA+MUdCIGRpc2tzCiAqCiAqIFJldmlzaW9uIDEuMTQgIDE5OTYvMDEvMTcgIDE1OjExOjIwICBmaXNjaGVyCiAqIC0gZml4ZWQgbG9ja3VwIGluIE1FU1NBR0UgSU4gcGhhc2UgYWZ0ZXIgcmVjb25uZWN0aW9uCiAqCiAqIFJldmlzaW9uIDEuMTMgIDE5OTYvMDEvMDkgIDAyOjE1OjUzICBmaXNjaGVyCiAqIC0gc29tZSBjbGVhbnVwcwogKiAtIG1vdmVkIHJlcXVlc3RfaXJxIGJlaGluZCBjb250cm9sbGVyIGluaXRpYWxpemF0aW9uCiAqICAgKHRvIGF2b2lkIHNwdXJpb3VzIGludGVycnVwdHMpCiAqCiAqIFJldmlzaW9uIDEuMTIgIDE5OTUvMTIvMTYgIDEyOjI2OjA3ICBmaXNjaGVyCiAqIC0gYmFycmllcigpcyBhZGRlZAogKiAtIGNvbmZpZ3VyYWJsZSBSRVNFVCBkZWxheSBhZGRlZAogKgogKiBSZXZpc2lvbiAxLjExICAxOTk1LzEyLzA2ICAyMToxODozNSAgZmlzY2hlcgogKiAtIHNvbWUgbWlub3IgdXBkYXRlcwogKgogKiBSZXZpc2lvbiAxLjEwICAxOTk1LzA3LzIyICAxOToxODo0NSAgZmlzY2hlcgogKiAtIHN1cHBvcnQgZm9yIDIgY29udHJvbGxlcnMKICogLSBzdGFydGVkIHN5bmNocm9ub3VzIGRhdGEgdHJhbnNmZXJzIChub3Qgd29ya2luZyB5ZXQpCiAqCiAqIFJldmlzaW9uIDEuOSAgMTk5NS8wMy8xOCAgMDk6MjA6MjQgIHJvb3QKICogLSBwYXRjaGVzIGZvciBQQ01DSUEgYW5kIG1vZHVsZXMKICoKICogUmV2aXNpb24gMS44ICAxOTk1LzAxLzIxICAyMjowNzoxOSAgcm9vdAogKiAtIHNuYXJmX3JlZ2lvbiA9PiByZXF1ZXN0X3JlZ2lvbgogKiAtIGFoYTE1MnhfaW50ciBpbnRlcmZhY2UgY2hhbmdlCiAqCiAqIFJldmlzaW9uIDEuNyAgMTk5NS8wMS8wMiAgMjM6MTk6MzYgIHJvb3QKICogLSB1cGRhdGVkIENPTU1BTkRfU0laRSB0byBjbWRfbGVuCiAqIC0gY2hhbmdlZCBzdGkoKSB0byByZXN0b3JlX2ZsYWdzKCkKICogLSBmaXhlZCBzb21lICNpZmRlZiB3aGljaCBnZW5lcmF0ZWQgd2FybmluZ3MKICoKICogUmV2aXNpb24gMS42ICAxOTk0LzExLzI0ICAyMDozNToyNyAgcm9vdAogKiAtIHByb2JsZW0gd2l0aCBvZGQgbnVtYmVyIG9mIGJ5dGVzIGluIGZpZm8gZml4ZWQKICoKICogUmV2aXNpb24gMS41ICAxOTk0LzEwLzMwICAxNDozOTo1NiAgcm9vdAogKiAtIGFib3J0IGNvZGUgZml4ZWQKICogLSBkZWJ1Z2dpbmcgaW1wcm92ZWQKICoKICogUmV2aXNpb24gMS40ICAxOTk0LzA5LzEyICAxMTozMzowMSAgcm9vdAogKiAtIGlycWFjdGlvbiB0byByZXF1ZXN0X2lycQogKiAtIGFib3J0aW9uIHVwZGF0ZWQKICoKICogUmV2aXNpb24gMS4zICAxOTk0LzA4LzA0ICAxMzo1MzowNSAgcm9vdAogKiAtIHVwZGF0ZXMgZm9yIG1pZC1sZXZlbC1kcml2ZXIgY2hhbmdlcwogKiAtIGFjY2VwdCB1bmV4cGVjdGVkIEJVU0ZSRUUgcGhhc2UgYXMgZXJyb3IgY29uZGl0aW9uCiAqIC0gcGFyaXR5IGNoZWNrIG5vdyBjb25maWd1cmFibGUKICoKICogUmV2aXNpb24gMS4yICAxOTk0LzA3LzAzICAxMjo1NjozNiAgcm9vdAogKiAtIGNsZWFuZWQgdXAgZGVidWdnaW5nIGNvZGUKICogLSBtb3JlIHR3ZWFraW5nIG9uIHJlc2V0IGRlbGF5cwogKiAtIHVwZGF0ZWQgYWJvcnQvcmVzZXQgY29kZSAocHJldHR5IHVudGVzdGVkLi4uKQogKgogKiBSZXZpc2lvbiAxLjEgIDE5OTQvMDUvMjggIDIxOjE4OjQ5ICByb290CiAqIC0gdXBkYXRlIGZvciBtaWQtbGV2ZWwgaW50ZXJmYWNlIGNoYW5nZSAoYWJvcnQtcmVzZXQpCiAqIC0gZGVsYXlzIGFmdGVyIHJlc2V0cyBhZGp1c3RlZCBmb3Igc29tZSBzbG93IGRldmljZXMKICoKICogUmV2aXNpb24gMS4wICAxOTk0LzAzLzI1ICAxMjo1MjowMCAgcm9vdAogKiAtIEZpeGVkICJtb3JlIGRhdGEgdGhhbiBleHBlY3RlZCIgcHJvYmxlbQogKiAtIGFkZGVkIG5ldyBCSU9TIHNpZ25hdHVyZXMKICoKICogUmV2aXNpb24gMC4xMDIgIDE5OTQvMDEvMzEgIDIwOjQ0OjEyICByb290CiAqIC0gbWlub3IgY2hhbmdlcyBpbiBpbnN3L291dHN3IGhhbmRsaW5nCiAqCiAqIFJldmlzaW9uIDAuMTAxICAxOTkzLzEyLzEzICAwMToxNjoyNyAgcm9vdAogKiAtIGZpeGVkIFNUQVRVUyBwaGFzZSAobm9uLUdPT0Qgc3RhdGkgd2VyZSBkcm9wcGVkIHNvbWV0aW1lczsKICogICBmaXhlcyBwcm9ibGVtcyB3aXRoIENELVJPTSBzZWN0b3Igc2l6ZSBkZXRlY3Rpb24gJiBtZWRpYSBjaGFuZ2UpCiAqCiAqIFJldmlzaW9uIDAuMTAwICAxOTkzLzEyLzEwICAxNjo1ODo0NyAgcm9vdAogKiAtIGZpeCBmb3IgdW5zdWNjZXNzZnVsIHNlbGVjdGlvbnMgaW4gY2FzZSBvZiBub24tY29udGludW91cyBpZCBhc3NpZ25tZW50cwogKiAgIG9uIHRoZSBzY3NpIGJ1cy4KICoKICogUmV2aXNpb24gMC45OSAgMTk5My8xMC8yNCAgMTY6MTk6NTkgIHJvb3QKICogLSBmaXhlZCBEQVRBIElOIChyYXJlIHJlYWQgZXJyb3JzIGdvbmUpCiAqCiAqIFJldmlzaW9uIDAuOTggIDE5OTMvMTAvMTcgIDEyOjU0OjQ0ICByb290CiAqIC0gZml4ZWQgc29tZSByZWNlbnQgZml4ZXMgKHNoYW1lIG9uIG1lKQogKiAtIG1vdmVkIGluaXRpYWxpemF0aW9uIG9mIHNjcmF0Y2ggYXJlYSB0byBhaGExNTJ4X3F1ZXVlCiAqCiAqIFJldmlzaW9uIDAuOTcgIDE5OTMvMTAvMDkgIDE4OjUzOjUzICByb290CiAqIC0gREFUQSBJTiBmaXhlZC4gUmFyZWx5IGxlZnQgZGF0YSBpbiB0aGUgZmlmby4KICoKICogUmV2aXNpb24gMC45NiAgMTk5My8xMC8wMyAgMDA6NTM6NTkgIHJvb3QKICogLSBtaW5vciBjaGFuZ2VzIG9uIERBVEEgSU4KICoKICogUmV2aXNpb24gMC45NSAgMTk5My8wOS8yNCAgMTA6MzY6MDEgIHJvb3QKICogLSBjaGFuZ2UgaGFuZGxpbmcgb2YgTVNHSSBhZnRlciByZXNlbGVjdGlvbgogKiAtIGZpeGVkIHN0aS9jbGkKICogLSBtaW5vciBjaGFuZ2VzCiAqCiAqIFJldmlzaW9uIDAuOTQgIDE5OTMvMDkvMTggIDE0OjA4OjIyICByb290CiAqIC0gZml4ZWQgYnVnIGluIG11bHRpcGxlIG91dHN0YW5kaW5nIGNvbW1hbmQgY29kZQogKiAtIGNoYW5nZWQgZGV0ZWN0aW9uCiAqIC0gc3VwcG9ydCBmb3Iga2VybmVsIGNvbW1hbmQgbGluZSBjb25maWd1cmF0aW9uCiAqIC0gcmVzZXQgY29ycmVjdGVkCiAqIC0gY2hhbmdlZCBtZXNzYWdlIGhhbmRsaW5nCiAqCiAqIFJldmlzaW9uIDAuOTMgIDE5OTMvMDkvMTUgIDIwOjQxOjE5ICByb290CiAqIC0gZml4ZWQgYnVncyB3aXRoIG11bHRpcGxlIG91dHN0YW5kaW5nIGNvbW1hbmRzCiAqCiAqIFJldmlzaW9uIDAuOTIgIDE5OTMvMDkvMTMgIDAyOjQ2OjMzICByb290CiAqIC0gbXVsdGlwbGUgb3V0c3RhbmRpbmcgY29tbWFuZHMgd29yayAobm8gcHJvYmxlbXMgd2l0aCBJQk0gZHJpdmUpCiAqCiAqIFJldmlzaW9uIDAuOTEgIDE5OTMvMDkvMTIgIDIwOjUxOjQ2ICByb290CiAqIGFkZGVkIG11bHRpcGxlIG91dHN0YW5kaW5nIGNvbW1hbmRzCiAqIChzb21lIHByb2JsZW0gd2l0aCB0aGlzICQlJj8gSUJNIGRldmljZSByZW1haW4pCiAqCiAqIFJldmlzaW9uIDAuOSAgMTk5My8wOS8xMiAgMTE6MTE6MjIgIHJvb3QKICogLSBjb3JyZWN0ZWQgYXV0by1jb25maWd1cmF0aW9uCiAqIC0gY2hhbmdlZCB0aGUgYXV0by1jb25maWd1cmF0aW9uIChhZGRlZCBzb21lICcjZGVmaW5lJ3MpCiAqIC0gYWRkZWQgc3VwcG9ydCBmb3IgZGlzLS9yZWNvbm5lY3Rpb24KICoKICogUmV2aXNpb24gMC44ICAxOTkzLzA5LzA2ICAyMzowOTozOSAgcm9vdAogKiAtIGFkZGVkIHN1cHBvcnQgZm9yIHRoZSBkcml2ZSBhY3Rpdml0eSBsaWdodAogKiAtIG1pbm9yIGNoYW5nZXMKICoKICogUmV2aXNpb24gMC43ICAxOTkzLzA5LzA1ICAxNDozMDoxNSAgcm9vdAogKiAtIGltcHJvdmVkIHBoYXNlIGRldGVjdGlvbgogKiAtIG5vdyB1c2luZyB0aGUgbmV3IHNuYXJmX3JlZ2lvbiBjb2RlIG9mIDAuOTlwbDEzCiAqCiAqIFJldmlzaW9uIDAuNiAgMTk5My8wOS8wMiAgMTE6MDE6MzggIHJvb3QKICogZmlyc3QgcHVibGljIHJlbGVhc2U7IGFkZGVkIHNvbWUgc2lnbmF0dXJlcyBhbmQgYmlvc3BhcmFtKCkKICoKICogUmV2aXNpb24gMC41ICAxOTkzLzA4LzMwICAxMDoyMzozMCAgcm9vdAogKiBmaXhlZCB0aW1pbmcgcHJvYmxlbXMgd2l0aCBteSBJQk0gZHJpdmUKICoKICogUmV2aXNpb24gMC40ICAxOTkzLzA4LzI5ICAxNDowNjo1MiAgcm9vdAogKiBmaXhlZCBzb21lIHByb2JsZW1zIHdpdGggdGltZW91dHMgZHVlIGluY29tcGxldGUgY29tbWFuZHMKICoKICogUmV2aXNpb24gMC4zICAxOTkzLzA4LzI4ICAxNTo1NTowMyAgcm9vdAogKiB3cml0aW5nIGRhdGEgd29ya3MgdG9vLiAgbW91bnRlZCBhbmQgd29ya2VkIG9uIGEgZG9zIHBhcnRpdGlvbgogKgogKiBSZXZpc2lvbiAwLjIgIDE5OTMvMDgvMjcgIDIyOjQyOjA3ICByb290CiAqIHJlYWRpbmcgZGF0YSB3b3Jrcy4gIE1vdW50ZWQgYSBtc2RvcyBwYXJ0aXRpb24uCiAqCiAqIFJldmlzaW9uIDAuMSAgMTk5My8wOC8yNSAgMTM6Mzg6MzAgIHJvb3QKICogZmlyc3QgImRhbW4gdGhpbmcgZG9lc24ndCB3b3JrIiB2ZXJzaW9uCiAqCiAqIFJldmlzaW9uIDAuMCAgMTk5My8wOC8xNCAgMTk6NTQ6MjUgIHJvb3QKICogZW1wdHkgZnVuY3Rpb24gYm9kaWVzOyBkZXRlY3QoKSB3b3Jrcy4KICoKICoKICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAKIHNlZSBEb2N1bWVudGF0aW9uL3Njc2kvYWhhMTUyeC50eHQgZm9yIGNvbmZpZ3VyYXRpb24gZGV0YWlscwoKICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKI2luY2x1ZGUgPGxpbnV4L21vZHVsZS5oPgojaW5jbHVkZSA8bGludXgvc2NoZWQuaD4KI2luY2x1ZGUgPGFzbS9pcnEuaD4KI2luY2x1ZGUgPGFzbS9pby5oPgojaW5jbHVkZSA8bGludXgvYmxrZGV2Lmg+CiNpbmNsdWRlIDxhc20vc3lzdGVtLmg+CiNpbmNsdWRlIDxsaW51eC9lcnJuby5oPgojaW5jbHVkZSA8bGludXgvc3RyaW5nLmg+CiNpbmNsdWRlIDxsaW51eC93YWl0Lmg+CiNpbmNsdWRlIDxsaW51eC9pb3BvcnQuaD4KI2luY2x1ZGUgPGxpbnV4L2RlbGF5Lmg+CiNpbmNsdWRlIDxsaW51eC9wcm9jX2ZzLmg+CiNpbmNsdWRlIDxsaW51eC9pbnRlcnJ1cHQuaD4KI2luY2x1ZGUgPGxpbnV4L2luaXQuaD4KI2luY2x1ZGUgPGxpbnV4L2tlcm5lbC5oPgojaW5jbHVkZSA8bGludXgvaXNhcG5wLmg+CiNpbmNsdWRlIDxsaW51eC9zcGlubG9jay5oPgojaW5jbHVkZSA8bGludXgvd29ya3F1ZXVlLmg+CiNpbmNsdWRlIDxhc20vc2VtYXBob3JlLmg+CiNpbmNsdWRlIDxzY3NpL3Njc2ljYW0uaD4KCiNpbmNsdWRlICJzY3NpLmgiCiNpbmNsdWRlIDxzY3NpL3Njc2lfZGJnLmg+CiNpbmNsdWRlIDxzY3NpL3Njc2lfaG9zdC5oPgojaW5jbHVkZSA8c2NzaS9zY3NpX3RyYW5zcG9ydF9zcGkuaD4KI2luY2x1ZGUgImFoYTE1MnguaCIKCgovKiBERUZJTkVTICovCgovKiBGb3IgUENNQ0lBIGNhcmRzLCBhbHdheXMgdXNlIEFVVE9DT05GICovCiNpZiBkZWZpbmVkKFBDTUNJQSkgfHwgZGVmaW5lZChNT0RVTEUpCiNpZiAhZGVmaW5lZChBVVRPQ09ORikKI2RlZmluZSBBVVRPQ09ORgojZW5kaWYKI2VuZGlmCgojaWYgIWRlZmluZWQoQVVUT0NPTkYpICYmICFkZWZpbmVkKFNFVFVQMCkKI2Vycm9yIGRlZmluZSBBVVRPQ09ORiBvciBTRVRVUDAKI2VuZGlmCgojaWYgZGVmaW5lZChBSEExNTJYX0RFQlVHKQojZGVmaW5lIERFQlVHX0RFRkFVTFQgZGVidWdfZWgKCiNkZWZpbmUgRFBSSU5USyh3aGVuLG1zZ3MuLi4pIFwKCWRvIHsgaWYoSE9TVERBVEEoc2hwbnQpLT5kZWJ1ZyAmICh3aGVuKSkgcHJpbnRrKG1zZ3MpOyB9IHdoaWxlKDApCgojZGVmaW5lIERPX0xPQ0soZmxhZ3MpCVwKCWRvIHsgXAoJCWlmKHNwaW5faXNfbG9ja2VkKCZRTE9DSykpIHsgXAoJCQlEUFJJTlRLKGRlYnVnX2ludHIsIERFQlVHX0xFQUQgIiglczolZCkgYWxyZWFkeSBsb2NrZWQgYXQgJXM6JWRcbiIsIENNRElORk8oQ1VSUkVOVF9TQyksIF9fRlVOQ1RJT05fXywgX19MSU5FX18sIFFMT0NLRVIsIFFMT0NLRVJMKTsgXAoJCX0gXAoJCURQUklOVEsoZGVidWdfbG9ja3MsIERFQlVHX0xFQUQgIiglczolZCkgbG9ja2luZ1xuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSwgX19GVU5DVElPTl9fLCBfX0xJTkVfXyk7IFwKCQlzcGluX2xvY2tfaXJxc2F2ZSgmUUxPQ0ssZmxhZ3MpOyBcCgkJRFBSSU5USyhkZWJ1Z19sb2NrcywgREVCVUdfTEVBRCAiKCVzOiVkKSBsb2NrZWRcbiIsIENNRElORk8oQ1VSUkVOVF9TQyksIF9fRlVOQ1RJT05fXywgX19MSU5FX18pOyBcCgkJUUxPQ0tFUj1fX0ZVTkNUSU9OX187IFwKCQlRTE9DS0VSTD1fX0xJTkVfXzsgXAoJfSB3aGlsZSgwKQoKI2RlZmluZSBET19VTkxPQ0soZmxhZ3MpCVwKCWRvIHsgXAoJCURQUklOVEsoZGVidWdfbG9ja3MsIERFQlVHX0xFQUQgIiglczolZCkgdW5sb2NraW5nIChsb2NrZWQgYXQgJXM6JWQpXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpLCBfX0ZVTkNUSU9OX18sIF9fTElORV9fLCBRTE9DS0VSLCBRTE9DS0VSTCk7IFwKCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZRTE9DSyxmbGFncyk7IFwKCQlEUFJJTlRLKGRlYnVnX2xvY2tzLCBERUJVR19MRUFEICIoJXM6JWQpIHVubG9ja2VkXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpLCBfX0ZVTkNUSU9OX18sIF9fTElORV9fKTsgXAoJCVFMT0NLRVI9Iihub3QgbG9ja2VkKSI7IFwKCQlRTE9DS0VSTD0wOyBcCgl9IHdoaWxlKDApCgojZWxzZQojZGVmaW5lIERQUklOVEsod2hlbixtc2dzLi4uKQojZGVmaW5lCURPX0xPQ0soZmxhZ3MpCQlzcGluX2xvY2tfaXJxc2F2ZSgmUUxPQ0ssZmxhZ3MpCiNkZWZpbmUJRE9fVU5MT0NLKGZsYWdzKQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZRTE9DSyxmbGFncykKI2VuZGlmCgojZGVmaW5lIExFQUQJCSIoc2NzaSVkOiVkOiVkKSAiCiNkZWZpbmUgV0FSTl9MRUFECUtFUk5fV0FSTklORwlMRUFECiNkZWZpbmUgSU5GT19MRUFECUtFUk5fSU5GTwlMRUFECiNkZWZpbmUgTk9URV9MRUFECUtFUk5fTk9USUNFCUxFQUQKI2RlZmluZSBFUlJfTEVBRAlLRVJOX0VSUglMRUFECiNkZWZpbmUgREVCVUdfTEVBRAlLRVJOX0RFQlVHCUxFQUQKI2RlZmluZSBDTURJTkZPKGNtZCkgXAoJCQkoY21kKSA/ICgoY21kKS0+ZGV2aWNlLT5ob3N0LT5ob3N0X25vKSA6IC0xLCBcCiAgICAgICAgICAgICAgICAgICAgICAgIChjbWQpID8gKChjbWQpLT5kZXZpY2UtPmlkICYgMHgwZikgOiAtMSwgXAoJCQkoY21kKSA/ICgoY21kKS0+ZGV2aWNlLT5sdW4gJiAweDA3KSA6IC0xCgojZGVmaW5lIERFTEFZX0RFRkFVTFQgMTAwMAoKI2lmIGRlZmluZWQoUENNQ0lBKQojZGVmaW5lIElSUV9NSU4gMAojZGVmaW5lIElSUV9NQVggMTYKI2Vsc2UKI2RlZmluZSBJUlFfTUlOIDkKI2lmIGRlZmluZWQoX19QUEMpCiNkZWZpbmUgSVJRX01BWCAoTlJfSVJRUy0xKQojZWxzZQojZGVmaW5lIElSUV9NQVggMTIKI2VuZGlmCiNlbmRpZgoKZW51bSB7Cglub3RfaXNzdWVkCT0gMHgwMDAxLAkvKiBjb21tYW5kIG5vdCB5ZXQgaXNzdWVkICovCglzZWxlY3RpbmcJPSAweDAwMDIsIAkvKiB0YXJnZXQgaXMgYmVlaW5nIHNlbGVjdGVkICovCglpZGVudGlmaWVkCT0gMHgwMDA0LAkvKiBJREVOVElGWSB3YXMgc2VudCAqLwoJZGlzY29ubmVjdGVkCT0gMHgwMDA4LAkvKiB0YXJnZXQgZGlzY29ubmVjdGVkICovCgljb21wbGV0ZWQJPSAweDAwMTAsCS8qIHRhcmdldCBzZW50IENPTU1BTkQgQ09NUExFVEUgKi8gCglhYm9ydGVkCQk9IDB4MDAyMCwJLyogQUJPUlQgd2FzIHNlbnQgKi8KCXJlc2V0dGVkCT0gMHgwMDQwLAkvKiBCVVMgREVWSUNFIFJFU0VUIHdhcyBzZW50ICovCglzcGlvcmR5CQk9IDB4MDA4MCwJLyogd2FpdGluZyBmb3IgU1BJT1JEWSB0byByYWlzZSAqLwoJc3luY25lZwkJPSAweDAxMDAsCS8qIHN5bmNocm9ub3VzIG5lZ290aWF0aW9uIGluIHByb2dyZXNzICovCglhYm9ydGluZwk9IDB4MDIwMCwJLyogQUJPUlQgaXMgcGVuZGluZyAqLwoJcmVzZXR0aW5nCT0gMHgwNDAwLAkvKiBCVVMgREVWSUNFIFJFU0VUIGlzIHBlbmRpbmcgKi8KCWNoZWNrX2NvbmRpdGlvbiA9IDB4MDgwMCwJLyogcmVxdWVzdGluZyBzZW5zZSBhZnRlciBDSEVDSyBDT05ESVRJT04gKi8KfTsKCk1PRFVMRV9BVVRIT1IoIkr8cmdlbiBGaXNjaGVyIik7Ck1PRFVMRV9ERVNDUklQVElPTihBSEExNTJYX1JFVklEKTsKTU9EVUxFX0xJQ0VOU0UoIkdQTCIpOwoKI2lmICFkZWZpbmVkKFBDTUNJQSkKI2lmIGRlZmluZWQoTU9EVUxFKQpzdGF0aWMgaW50IGlvW10gPSB7MCwgMH07Cm1vZHVsZV9wYXJhbV9hcnJheShpbywgaW50LCBOVUxMLCAwKTsKTU9EVUxFX1BBUk1fREVTQyhpbywiYmFzZSBpbyBhZGRyZXNzIG9mIGNvbnRyb2xsZXIiKTsKCnN0YXRpYyBpbnQgaXJxW10gPSB7MCwgMH07Cm1vZHVsZV9wYXJhbV9hcnJheShpcnEsIGludCwgTlVMTCwgMCk7Ck1PRFVMRV9QQVJNX0RFU0MoaXJxLCJpbnRlcnJ1cHQgZm9yIGNvbnRyb2xsZXIiKTsKCnN0YXRpYyBpbnQgc2NzaWlkW10gPSB7NywgN307Cm1vZHVsZV9wYXJhbV9hcnJheShzY3NpaWQsIGludCwgTlVMTCwgMCk7Ck1PRFVMRV9QQVJNX0RFU0Moc2NzaWlkLCJzY3NpIGlkIG9mIGNvbnRyb2xsZXIiKTsKCnN0YXRpYyBpbnQgcmVjb25uZWN0W10gPSB7MSwgMX07Cm1vZHVsZV9wYXJhbV9hcnJheShyZWNvbm5lY3QsIGludCwgTlVMTCwgMCk7Ck1PRFVMRV9QQVJNX0RFU0MocmVjb25uZWN0LCJhbGxvdyB0YXJnZXRzIHRvIGRpc2Nvbm5lY3QiKTsKCnN0YXRpYyBpbnQgcGFyaXR5W10gPSB7MSwgMX07Cm1vZHVsZV9wYXJhbV9hcnJheShwYXJpdHksIGludCwgTlVMTCwgMCk7Ck1PRFVMRV9QQVJNX0RFU0MocGFyaXR5LCJ1c2Ugc2NzaSBwYXJpdHkiKTsKCnN0YXRpYyBpbnQgc3luY1tdID0gezEsIDF9Owptb2R1bGVfcGFyYW1fYXJyYXkoc3luYywgaW50LCBOVUxMLCAwKTsKTU9EVUxFX1BBUk1fREVTQyhzeW5jLCJ1c2Ugc3luY2hyb25vdXMgdHJhbnNmZXJzIik7CgpzdGF0aWMgaW50IGRlbGF5W10gPSB7REVMQVlfREVGQVVMVCwgREVMQVlfREVGQVVMVH07Cm1vZHVsZV9wYXJhbV9hcnJheShkZWxheSwgaW50LCBOVUxMLCAwKTsKTU9EVUxFX1BBUk1fREVTQyhkZWxheSwic2NzaSByZXNldCBkZWxheSIpOwoKc3RhdGljIGludCBleHR0cmFuc1tdID0gezAsIDB9Owptb2R1bGVfcGFyYW1fYXJyYXkoZXh0dHJhbnMsIGludCwgTlVMTCwgMCk7Ck1PRFVMRV9QQVJNX0RFU0MoZXh0dHJhbnMsInVzZSBleHRlbmRlZCB0cmFuc2xhdGlvbiIpOwoKI2lmICFkZWZpbmVkKEFIQTE1MlhfREVCVUcpCnN0YXRpYyBpbnQgYWhhMTUyeFtdID0gezAsIDExLCA3LCAxLCAxLCAwLCBERUxBWV9ERUZBVUxULCAwfTsKbW9kdWxlX3BhcmFtX2FycmF5KGFoYTE1MngsIGludCwgTlVMTCwgMCk7Ck1PRFVMRV9QQVJNX0RFU0MoYWhhMTUyeCwgInBhcmFtZXRlcnMgZm9yIGZpcnN0IGNvbnRyb2xsZXIiKTsKCnN0YXRpYyBpbnQgYWhhMTUyeDFbXSA9IHswLCAxMSwgNywgMSwgMSwgMCwgREVMQVlfREVGQVVMVCwgMH07Cm1vZHVsZV9wYXJhbV9hcnJheShhaGExNTJ4MSwgaW50LCBOVUxMLCAwKTsKTU9EVUxFX1BBUk1fREVTQyhhaGExNTJ4MSwgInBhcmFtZXRlcnMgZm9yIHNlY29uZCBjb250cm9sbGVyIik7CiNlbHNlCnN0YXRpYyBpbnQgZGVidWdbXSA9IHtERUJVR19ERUZBVUxULCBERUJVR19ERUZBVUxUfTsKbW9kdWxlX3BhcmFtX2FycmF5KGRlYnVnLCBpbnQsIE5VTEwsIDApOwpNT0RVTEVfUEFSTV9ERVNDKGRlYnVnLCAiZmxhZ3MgZm9yIGRyaXZlciBkZWJ1Z2dpbmciKTsKCnN0YXRpYyBpbnQgYWhhMTUyeFtdICAgPSB7MCwgMTEsIDcsIDEsIDEsIDEsIERFTEFZX0RFRkFVTFQsIDAsIERFQlVHX0RFRkFVTFR9Owptb2R1bGVfcGFyYW1fYXJyYXkoYWhhMTUyeCwgaW50LCBOVUxMLCAwKTsKTU9EVUxFX1BBUk1fREVTQyhhaGExNTJ4LCAicGFyYW1ldGVycyBmb3IgZmlyc3QgY29udHJvbGxlciIpOwoKc3RhdGljIGludCBhaGExNTJ4MVtdICA9IHswLCAxMSwgNywgMSwgMSwgMSwgREVMQVlfREVGQVVMVCwgMCwgREVCVUdfREVGQVVMVH07Cm1vZHVsZV9wYXJhbV9hcnJheShhaGExNTJ4MSwgaW50LCBOVUxMLCAwKTsKTU9EVUxFX1BBUk1fREVTQyhhaGExNTJ4MSwgInBhcmFtZXRlcnMgZm9yIHNlY29uZCBjb250cm9sbGVyIik7CiNlbmRpZiAvKiAhZGVmaW5lZChBSEExNTJYX0RFQlVHKSAqLwojZW5kaWYgLyogTU9EVUxFICovCgojaWZkZWYgX19JU0FQTlBfXwpzdGF0aWMgc3RydWN0IGlzYXBucF9kZXZpY2VfaWQgaWRfdGFibGVbXSBfX2RldmluaXRkYXRhID0gewoJeyBJU0FQTlBfQU5ZX0lELCBJU0FQTlBfQU5ZX0lELAoJCUlTQVBOUF9WRU5ET1IoJ0EnLCdEJywnUCcpLCBJU0FQTlBfRlVOQ1RJT04oMHgxNTA1KSwgMCB9LAoJeyBJU0FQTlBfQU5ZX0lELCBJU0FQTlBfQU5ZX0lELAoJCUlTQVBOUF9WRU5ET1IoJ0EnLCdEJywnUCcpLCBJU0FQTlBfRlVOQ1RJT04oMHgxNTMwKSwgMCB9LAoJeyBJU0FQTlBfREVWSUNFX1NJTkdMRV9FTkQsIH0KfTsKTU9EVUxFX0RFVklDRV9UQUJMRShpc2FwbnAsIGlkX3RhYmxlKTsKI2VuZGlmIC8qIElTQVBOUCAqLwoKI2VuZGlmIC8qICFQQ01DSUEgKi8KCnN0YXRpYyBpbnQgcmVnaXN0ZXJlZF9jb3VudD0wOwpzdGF0aWMgc3RydWN0IFNjc2lfSG9zdCAqYWhhMTUyeF9ob3N0WzJdOwpzdGF0aWMgc3RydWN0IHNjc2lfaG9zdF90ZW1wbGF0ZSBhaGExNTJ4X2RyaXZlcl90ZW1wbGF0ZTsKCi8qCiAqIGludGVybmFsIHN0YXRlcyBvZiB0aGUgaG9zdAogKgogKi8gCmVudW0gYWhhMTUyeF9zdGF0ZSB7CglpZGxlPTAsCgl1bmtub3duLAoJc2VsZG8sCglzZWxkaSwKCXNlbHRvLAoJYnVzZnJlZSwKCW1zZ28sCgljbWQsCgltc2dpLAoJc3RhdHVzLAoJZGF0YWksCglkYXRhbywKCXBhcmVyciwKCXJzdGksCgltYXhzdGF0ZQp9OwoKLyoKICogY3VycmVudCBzdGF0ZSBpbmZvcm1hdGlvbiBvZiB0aGUgaG9zdAogKgogKi8Kc3RydWN0IGFoYTE1MnhfaG9zdGRhdGEgewoJU2NzaV9DbW5kICppc3N1ZV9TQzsKCQkvKiBwZW5kaW5nIGNvbW1hbmRzIHRvIGlzc3VlICovCgoJU2NzaV9DbW5kICpjdXJyZW50X1NDOwoJCS8qIGN1cnJlbnQgY29tbWFuZCBvbiB0aGUgYnVzICovCgoJU2NzaV9DbW5kICpkaXNjb25uZWN0ZWRfU0M7CgkJLyogY29tbWFuZHMgdGhhdCBkaXNjb25uZWN0ZWQgKi8KCglTY3NpX0NtbmQgKmRvbmVfU0M7CgkJLyogY29tbWFuZCB0aGF0IHdhcyBjb21wbGV0ZWQgKi8KCglzcGlubG9ja190IGxvY2s7CgkJLyogaG9zdCBsb2NrICovCgojaWYgZGVmaW5lZChBSEExNTJYX0RFQlVHKQoJY29uc3QgY2hhciAqbG9ja2VyOwoJCS8qIHdoaWNoIGZ1bmN0aW9uIGhhcyB0aGUgbG9jayAqLwoJaW50IGxvY2tlcmw7CS8qIHdoZXJlIGRpZCBpdCBnZXQgaXQgKi8KCglpbnQgZGVidWc7CS8qIGN1cnJlbnQgZGVidWdnaW5nIHNldHRpbmcgKi8KI2VuZGlmCgojaWYgZGVmaW5lZChBSEExNTJYX1NUQVQpCglpbnQgICAgICAgICAgIHRvdGFsX2NvbW1hbmRzOwoJaW50CSAgICAgIGRpc2Nvbm5lY3Rpb25zOwoJaW50CSAgICAgIGJ1c2ZyZWVfd2l0aG91dF9hbnlfYWN0aW9uOwoJaW50CSAgICAgIGJ1c2ZyZWVfd2l0aG91dF9vbGRfY29tbWFuZDsKCWludAkgICAgICBidXNmcmVlX3dpdGhvdXRfbmV3X2NvbW1hbmQ7CglpbnQJICAgICAgYnVzZnJlZV93aXRob3V0X2RvbmVfY29tbWFuZDsKCWludAkgICAgICBidXNmcmVlX3dpdGhfY2hlY2tfY29uZGl0aW9uOwoJaW50ICAgICAgICAgICBjb3VudFttYXhzdGF0ZV07CglpbnQgICAgICAgICAgIGNvdW50X3RyYW5zW21heHN0YXRlXTsKCXVuc2lnbmVkIGxvbmcgdGltZVttYXhzdGF0ZV07CiNlbmRpZgoKCWludCBjb21tYW5kczsJCS8qIGN1cnJlbnQgbnVtYmVyIG9mIGNvbW1hbmRzICovCgoJaW50IHJlY29ubmVjdDsJCS8qIGRpc2Nvbm5lY3Rpb24gYWxsb3dlZCAqLwoJaW50IHBhcml0eTsJCS8qIHBhcml0eSBjaGVja2luZyBlbmFibGVkICovCglpbnQgc3luY2hyb25vdXM7CS8qIHN5bmNocm9ub3VzIHRyYW5zZmVyZXMgZW5hYmxlZCAqLwoJaW50IGRlbGF5OwkJLyogcmVzZXQgb3V0IGRlbGF5ICovCglpbnQgZXh0X3RyYW5zOwkJLyogZXh0ZW5kZWQgdHJhbnNsYXRpb24gZW5hYmxlZCAqLwoKCWludCBzd2ludDsgCQkvKiBzb2Z0d2FyZS1pbnRlcnJ1cHQgd2FzIGZpcmVkIGR1cmluZyBkZXRlY3QoKSAqLwoJaW50IHNlcnZpY2U7CQkvKiBiaCBuZWVkcyB0byBiZSBydW4gKi8KCWludCBpbl9pbnRyOwkJLyogYmggaXMgcnVubmluZyAqLwoKCS8qIGN1cnJlbnQgc3RhdGUsCgkgICBwcmV2aW91cyBzdGF0ZSwKCSAgIGxhc3Qgc3RhdGUgZGlmZmVyZW50IGZyb20gY3VycmVudCBzdGF0ZSAqLwoJZW51bSBhaGExNTJ4X3N0YXRlIHN0YXRlLCBwcmV2c3RhdGUsIGxhc3RzdGF0ZTsKCglpbnQgdGFyZ2V0OwoJCS8qIHJlY29ubmVjdGluZyB0YXJnZXQgKi8KCgl1bnNpZ25lZCBjaGFyIHN5bmNyYXRlWzhdOwoJCS8qIGN1cnJlbnQgc3luY2hyb25vdXMgdHJhbnNmZXIgYWdyZWVtZW50cyAqLwoKCXVuc2lnbmVkIGNoYXIgc3luY25lZ1s4XTsKCQkvKiAwOiBubyBuZWdvdGlhdGlvbjsKCQkgKiAxOiBuZWdvdGlhdGlvbiBpbiBwcm9ncmVzczsKCQkgKiAyOiBuZWdvdGlhdGlvbiBjb21wbGV0ZWQKCQkgKi8KCglpbnQgY21kX2k7CgkJLyogbnVtYmVyIG9mIHNlbnQgYnl0ZXMgb2YgY3VycmVudCBjb21tYW5kICovCgoJaW50IG1zZ2lfbGVuOwoJCS8qIG51bWJlciBvZiByZWNlaXZlZCBtZXNzYWdlIGJ5dGVzICovCgl1bnNpZ25lZCBjaGFyIG1zZ2lbMjU2XTsKCQkvKiByZWNlaXZlZCBtZXNzYWdlIGJ5dGVzICovCgoJaW50IG1zZ29faSwgbXNnb19sZW47CQoJCS8qIG51bWJlciBvZiBzZW50IGJ5dGVzIGFuZCBsZW5ndGggb2YgY3VycmVudCBtZXNzYWdlcyAqLwoJdW5zaWduZWQgY2hhciBtc2dvWzI1Nl07CgkJLyogcGVuZGluZyBtZXNzYWdlcyAqLwoKCWludCBkYXRhX2xlbjsKCQkvKiBudW1iZXIgb2Ygc2VudC9yZWNlaXZlZCBieXRlcyBpbiBkYXRhcGhhc2UgKi8KCgl1bnNpZ25lZCBsb25nIGlvX3BvcnQwOwoJdW5zaWduZWQgbG9uZyBpb19wb3J0MTsKCiNpZmRlZiBfX0lTQVBOUF9fCglzdHJ1Y3QgcG5wX2RldiAqcG5wZGV2OwojZW5kaWYKfTsKCgovKgogKiBob3N0IHNwZWNpZmljIGNvbW1hbmQgZXh0ZW5zaW9uCiAqCiAqLwpzdHJ1Y3QgYWhhMTUyeF9zY2RhdGEgewoJU2NzaV9DbW5kICpuZXh0OwkvKiBuZXh0IHNjIGluIHF1ZXVlICovCglzdHJ1Y3Qgc2VtYXBob3JlICpzZW07CS8qIHNlbWFwaG9yZSB0byBibG9jayBvbiAqLwp9OwoKCi8qIGFjY2VzcyBtYWNyb3MgZm9yIGhvc3RkYXRhICovCgojZGVmaW5lIEhPU1REQVRBKHNocG50KQkJKChzdHJ1Y3QgYWhhMTUyeF9ob3N0ZGF0YSAqKSAmc2hwbnQtPmhvc3RkYXRhKQoKI2RlZmluZSBIT1NUTk8JCQkoKHNocG50KS0+aG9zdF9ubykKCiNkZWZpbmUgQ1VSUkVOVF9TQwkJKEhPU1REQVRBKHNocG50KS0+Y3VycmVudF9TQykKI2RlZmluZSBET05FX1NDCQkJKEhPU1REQVRBKHNocG50KS0+ZG9uZV9TQykKI2RlZmluZSBJU1NVRV9TQwkJKEhPU1REQVRBKHNocG50KS0+aXNzdWVfU0MpCiNkZWZpbmUgRElTQ09OTkVDVEVEX1NDCQkoSE9TVERBVEEoc2hwbnQpLT5kaXNjb25uZWN0ZWRfU0MpCiNkZWZpbmUgUUxPQ0sJCQkoSE9TVERBVEEoc2hwbnQpLT5sb2NrKQojZGVmaW5lIFFMT0NLRVIJCQkoSE9TVERBVEEoc2hwbnQpLT5sb2NrZXIpCiNkZWZpbmUgUUxPQ0tFUkwJCShIT1NUREFUQShzaHBudCktPmxvY2tlcmwpCgojZGVmaW5lIFNUQVRFCQkJKEhPU1REQVRBKHNocG50KS0+c3RhdGUpCiNkZWZpbmUgUFJFVlNUQVRFCQkoSE9TVERBVEEoc2hwbnQpLT5wcmV2c3RhdGUpCiNkZWZpbmUgTEFTVFNUQVRFCQkoSE9TVERBVEEoc2hwbnQpLT5sYXN0c3RhdGUpCgojZGVmaW5lIFJFQ09OTl9UQVJHRVQJCShIT1NUREFUQShzaHBudCktPnRhcmdldCkKCiNkZWZpbmUgQ01EX0kJCQkoSE9TVERBVEEoc2hwbnQpLT5jbWRfaSkKCiNkZWZpbmUgTVNHTyhpKQkJCShIT1NUREFUQShzaHBudCktPm1zZ29baV0pCiNkZWZpbmUgTVNHT19JCQkJKEhPU1REQVRBKHNocG50KS0+bXNnb19pKQojZGVmaW5lIE1TR09MRU4JCQkoSE9TVERBVEEoc2hwbnQpLT5tc2dvX2xlbikKI2RlZmluZSBBRERNU0dPKHgpCQkoTVNHT0xFTjwyNTYgPyAodm9pZCkoTVNHTyhNU0dPTEVOKyspPXgpIDogYWhhMTUyeF9lcnJvcihzaHBudCwiTVNHTyBvdmVyZmxvdyIpKQoKI2RlZmluZSBNU0dJKGkpCQkJKEhPU1REQVRBKHNocG50KS0+bXNnaVtpXSkKI2RlZmluZSBNU0dJTEVOCQkJKEhPU1REQVRBKHNocG50KS0+bXNnaV9sZW4pCiNkZWZpbmUgQURETVNHSSh4KQkJKE1TR0lMRU48MjU2ID8gKHZvaWQpKE1TR0koTVNHSUxFTisrKT14KSA6IGFoYTE1MnhfZXJyb3Ioc2hwbnQsIk1TR0kgb3ZlcmZsb3ciKSkKCiNkZWZpbmUgREFUQV9MRU4JCShIT1NUREFUQShzaHBudCktPmRhdGFfbGVuKQoKI2RlZmluZSBTWU5DUkFURQkJKEhPU1REQVRBKHNocG50KS0+c3luY3JhdGVbQ1VSUkVOVF9TQy0+ZGV2aWNlLT5pZF0pCiNkZWZpbmUgU1lOQ05FRwkJCShIT1NUREFUQShzaHBudCktPnN5bmNuZWdbQ1VSUkVOVF9TQy0+ZGV2aWNlLT5pZF0pCgojZGVmaW5lIERFTEFZCQkJKEhPU1REQVRBKHNocG50KS0+ZGVsYXkpCiNkZWZpbmUgRVhUX1RSQU5TCQkoSE9TVERBVEEoc2hwbnQpLT5leHRfdHJhbnMpCiNkZWZpbmUgVEMxNTUwCQkJKEhPU1REQVRBKHNocG50KS0+dGMxNTUwKQojZGVmaW5lIFJFQ09OTkVDVAkJKEhPU1REQVRBKHNocG50KS0+cmVjb25uZWN0KQojZGVmaW5lIFBBUklUWQkJCShIT1NUREFUQShzaHBudCktPnBhcml0eSkKI2RlZmluZSBTWU5DSFJPTk9VUwkJKEhPU1REQVRBKHNocG50KS0+c3luY2hyb25vdXMpCgojZGVmaW5lIEhPU1RJT1BPUlQwCQkoSE9TVERBVEEoc2hwbnQpLT5pb19wb3J0MCkKI2RlZmluZSBIT1NUSU9QT1JUMQkJKEhPU1REQVRBKHNocG50KS0+aW9fcG9ydDEpCgojZGVmaW5lIFNDREFUQShTQ3BudCkJCSgoc3RydWN0IGFoYTE1Mnhfc2NkYXRhICopIChTQ3BudCktPmhvc3Rfc2NyaWJibGUpCiNkZWZpbmUgU0NORVhUKFNDcG50KQkJU0NEQVRBKFNDcG50KS0+bmV4dAojZGVmaW5lIFNDU0VNKFNDcG50KQkJU0NEQVRBKFNDcG50KS0+c2VtCgojZGVmaW5lIFNHX0FERFJFU1MoYnVmZmVyKQkoKGNoYXIgKikgKHBhZ2VfYWRkcmVzcygoYnVmZmVyKS0+cGFnZSkrKGJ1ZmZlciktPm9mZnNldCkpCgovKiBzdGF0ZSBoYW5kbGluZyAqLwpzdGF0aWMgdm9pZCBzZWxkaV9ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwpzdGF0aWMgdm9pZCBzZWxkb19ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwpzdGF0aWMgdm9pZCBzZWx0b19ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwpzdGF0aWMgdm9pZCBidXNmcmVlX3J1bihzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CgpzdGF0aWMgdm9pZCBtc2dvX2luaXQoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwpzdGF0aWMgdm9pZCBtc2dvX3J1bihzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CnN0YXRpYyB2b2lkIG1zZ29fZW5kKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KTsKCnN0YXRpYyB2b2lkIGNtZF9pbml0KHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KTsKc3RhdGljIHZvaWQgY21kX3J1bihzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CnN0YXRpYyB2b2lkIGNtZF9lbmQoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwoKc3RhdGljIHZvaWQgZGF0YWlfaW5pdChzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CnN0YXRpYyB2b2lkIGRhdGFpX3J1bihzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CnN0YXRpYyB2b2lkIGRhdGFpX2VuZChzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CgpzdGF0aWMgdm9pZCBkYXRhb19pbml0KHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KTsKc3RhdGljIHZvaWQgZGF0YW9fcnVuKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KTsKc3RhdGljIHZvaWQgZGF0YW9fZW5kKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KTsKCnN0YXRpYyB2b2lkIHN0YXR1c19ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwoKc3RhdGljIHZvaWQgbXNnaV9ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwpzdGF0aWMgdm9pZCBtc2dpX2VuZChzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CgpzdGF0aWMgdm9pZCBwYXJlcnJfcnVuKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KTsKc3RhdGljIHZvaWQgcnN0aV9ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwoKc3RhdGljIHZvaWQgaXNfY29tcGxldGUoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwoKLyoKICogZHJpdmVyIHN0YXRlcwogKgogKi8Kc3RhdGljIHN0cnVjdCB7CgljaGFyCQkqbmFtZTsKCXZvaWQJCSgqaW5pdCkoc3RydWN0IFNjc2lfSG9zdCAqKTsKCXZvaWQJCSgqcnVuKShzdHJ1Y3QgU2NzaV9Ib3N0ICopOwoJdm9pZAkJKCplbmQpKHN0cnVjdCBTY3NpX0hvc3QgKik7CglpbnQJCXNwaW87Cn0gc3RhdGVzW10gPSB7Cgl7ICJpZGxlIiwJTlVMTCwJCU5VTEwsCQlOVUxMLAkJMH0sCgl7ICJ1bmtub3duIiwJTlVMTCwJCU5VTEwsCQlOVUxMLAkJMH0sCgl7ICJzZWxkbyIsCU5VTEwsCQlzZWxkb19ydW4sCU5VTEwsCQkwfSwKCXsgInNlbGRpIiwJTlVMTCwJCXNlbGRpX3J1biwJTlVMTCwJCTB9LAoJeyAic2VsdG8iLAlOVUxMLAkJc2VsdG9fcnVuLAlOVUxMLAkJMH0sCgl7ICJidXNmcmVlIiwJTlVMTCwJCWJ1c2ZyZWVfcnVuLAlOVUxMLAkJMH0sCgl7ICJtc2dvIiwJbXNnb19pbml0LAltc2dvX3J1biwJbXNnb19lbmQsCTF9LAoJeyAiY21kIiwJY21kX2luaXQsCWNtZF9ydW4sCWNtZF9lbmQsCTF9LAoJeyAibXNnaSIsCU5VTEwsCQltc2dpX3J1biwJbXNnaV9lbmQsCTF9LAoJeyAic3RhdHVzIiwJTlVMTCwJCXN0YXR1c19ydW4sCU5VTEwsCQkxfSwKCXsgImRhdGFpIiwJZGF0YWlfaW5pdCwJZGF0YWlfcnVuLAlkYXRhaV9lbmQsCTB9LAoJeyAiZGF0YW8iLAlkYXRhb19pbml0LAlkYXRhb19ydW4sCWRhdGFvX2VuZCwJMH0sCgl7ICJwYXJlcnIiLAlOVUxMLAkJcGFyZXJyX3J1biwJTlVMTCwJCTB9LAoJeyAicnN0aSIsCU5VTEwsCQlyc3RpX3J1biwJTlVMTCwJCTB9LAp9OwoKLyogc2V0dXAgJiBpbnRlcnJ1cHQgKi8Kc3RhdGljIGlycXJldHVybl90IGludHIoaW50IGlycSwgdm9pZCAqZGV2X2lkLCBzdHJ1Y3QgcHRfcmVncyAqKTsKc3RhdGljIHZvaWQgcmVzZXRfcG9ydHMoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpOwpzdGF0aWMgdm9pZCBhaGExNTJ4X2Vycm9yKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50LCBjaGFyICptc2cpOwpzdGF0aWMgdm9pZCBkb25lKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50LCBpbnQgZXJyb3IpOwoKLyogZGlhZ25vc3RpY3MgKi8Kc3RhdGljIHZvaWQgZGlzcF9wb3J0cyhzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CnN0YXRpYyB2b2lkIHNob3dfY29tbWFuZChTY3NpX0NtbmQgKiBwdHIpOwpzdGF0aWMgdm9pZCBzaG93X3F1ZXVlcyhzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCk7CnN0YXRpYyB2b2lkIGRpc3BfZW5pbnRyKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KTsKCgovKgogKiAgcXVldWUgc2VydmljZXM6CiAqCiAqLwpzdGF0aWMgaW5saW5lIHZvaWQgYXBwZW5kX1NDKFNjc2lfQ21uZCAqKlNDLCBTY3NpX0NtbmQgKm5ld19TQykKewoJU2NzaV9DbW5kICplbmQ7CgoJU0NORVhUKG5ld19TQykgPSBOVUxMOwoJaWYgKCEqU0MpCgkJKlNDID0gbmV3X1NDOwoJZWxzZSB7CgkJZm9yIChlbmQgPSAqU0M7IFNDTkVYVChlbmQpOyBlbmQgPSBTQ05FWFQoZW5kKSkKCQkJOwoJCVNDTkVYVChlbmQpID0gbmV3X1NDOwoJfQp9CgpzdGF0aWMgaW5saW5lIFNjc2lfQ21uZCAqcmVtb3ZlX2ZpcnN0X1NDKFNjc2lfQ21uZCAqKiBTQykKewoJU2NzaV9DbW5kICpwdHI7CgoJcHRyID0gKlNDOwoJaWYgKHB0cikgewoJCSpTQyA9IFNDTkVYVCgqU0MpOwoJCVNDTkVYVChwdHIpPU5VTEw7Cgl9CglyZXR1cm4gcHRyOwp9CgpzdGF0aWMgaW5saW5lIFNjc2lfQ21uZCAqcmVtb3ZlX2x1bl9TQyhTY3NpX0NtbmQgKiogU0MsIGludCB0YXJnZXQsIGludCBsdW4pCnsKCVNjc2lfQ21uZCAqcHRyLCAqcHJldjsKCglmb3IgKHB0ciA9ICpTQywgcHJldiA9IE5VTEw7CgkgICAgIHB0ciAmJiAoKHB0ci0+ZGV2aWNlLT5pZCAhPSB0YXJnZXQpIHx8IChwdHItPmRldmljZS0+bHVuICE9IGx1bikpOwoJICAgICBwcmV2ID0gcHRyLCBwdHIgPSBTQ05FWFQocHRyKSkKCSAgICAgOwoKCWlmIChwdHIpIHsKCQlpZiAocHJldikKCQkJU0NORVhUKHByZXYpID0gU0NORVhUKHB0cik7CgkJZWxzZQoJCQkqU0MgPSBTQ05FWFQocHRyKTsKCgkJU0NORVhUKHB0cik9TlVMTDsKCX0KCglyZXR1cm4gcHRyOwp9CgpzdGF0aWMgaW5saW5lIFNjc2lfQ21uZCAqcmVtb3ZlX1NDKFNjc2lfQ21uZCAqKlNDLCBTY3NpX0NtbmQgKlNDcCkKewoJU2NzaV9DbW5kICpwdHIsICpwcmV2OwoKCWZvciAocHRyID0gKlNDLCBwcmV2ID0gTlVMTDsKCSAgICAgcHRyICYmIFNDcCE9cHRyOwoJICAgICBwcmV2ID0gcHRyLCBwdHIgPSBTQ05FWFQocHRyKSkKCSAgICAgOwoKCWlmIChwdHIpIHsKCQlpZiAocHJldikKCQkJU0NORVhUKHByZXYpID0gU0NORVhUKHB0cik7CgkJZWxzZQoJCQkqU0MgPSBTQ05FWFQocHRyKTsKCgkJU0NORVhUKHB0cik9TlVMTDsKCX0KCglyZXR1cm4gcHRyOwp9CgpzdGF0aWMgaW5saW5lIHN0cnVjdCBTY3NpX0hvc3QgKmxvb2t1cF9pcnEoaW50IGlycW5vKQp7CglpbnQgaTsKCglmb3IoaT0wOyBpPEFSUkFZX1NJWkUoYWhhMTUyeF9ob3N0KTsgaSsrKQoJCWlmKGFoYTE1MnhfaG9zdFtpXSAmJiBhaGExNTJ4X2hvc3RbaV0tPmlycT09aXJxbm8pCgkJCXJldHVybiBhaGExNTJ4X2hvc3RbaV07CgoJcmV0dXJuIE5VTEw7Cn0KCnN0YXRpYyBpcnFyZXR1cm5fdCBzd2ludHIoaW50IGlycW5vLCB2b2lkICpkZXZfaWQsIHN0cnVjdCBwdF9yZWdzICpyZWdzKQp7CglzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCA9IGxvb2t1cF9pcnEoaXJxbm8pOwoKCWlmICghc2hwbnQpIHsKICAgICAgICAJcHJpbnRrKEtFUk5fRVJSICJhaGExNTJ4OiBjYXRjaGVkIHNvZnR3YXJlIGludGVycnVwdCAlZCBmb3IgdW5rbm93biBjb250cm9sbGVyLlxuIiwgaXJxbm8pOwoJCXJldHVybiBJUlFfTk9ORTsKCX0KCglIT1NUREFUQShzaHBudCktPnN3aW50Kys7CgoJU0VUUE9SVChETUFDTlRSTDAsIElOVEVOKTsKCXJldHVybiBJUlFfSEFORExFRDsKfQoKc3RydWN0IFNjc2lfSG9zdCAqYWhhMTUyeF9wcm9iZV9vbmUoc3RydWN0IGFoYTE1Mnhfc2V0dXAgKnNldHVwKQp7CglzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudDsKCglzaHBudCA9IHNjc2lfaG9zdF9hbGxvYygmYWhhMTUyeF9kcml2ZXJfdGVtcGxhdGUsIHNpemVvZihzdHJ1Y3QgYWhhMTUyeF9ob3N0ZGF0YSkpOwoJaWYgKCFzaHBudCkgewoJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeDogc2NzaV9ob3N0X2FsbG9jIGZhaWxlZFxuIik7CgkJcmV0dXJuIE5VTEw7Cgl9CgoJLyogbmVlZCB0byBoYXZlIGhvc3QgcmVnaXN0ZXJlZCBiZWZvcmUgdHJpZ2dlcmluZyBhbnkgaW50ZXJydXB0ICovCglhaGExNTJ4X2hvc3RbcmVnaXN0ZXJlZF9jb3VudF0gPSBzaHBudDsKCgltZW1zZXQoSE9TVERBVEEoc2hwbnQpLCAwLCBzaXplb2YgKkhPU1REQVRBKHNocG50KSk7CgoJc2hwbnQtPmlvX3BvcnQgICA9IHNldHVwLT5pb19wb3J0OwoJc2hwbnQtPm5faW9fcG9ydCA9IElPX1JBTkdFOwoJc2hwbnQtPmlycSAgICAgICA9IHNldHVwLT5pcnE7CgoJaWYgKCFzZXR1cC0+dGMxNTUwKSB7CgkJSE9TVElPUE9SVDAgPSBzZXR1cC0+aW9fcG9ydDsKCQlIT1NUSU9QT1JUMSA9IHNldHVwLT5pb19wb3J0OwoJfSBlbHNlIHsKCQlIT1NUSU9QT1JUMCA9IHNldHVwLT5pb19wb3J0KzB4MTA7CgkJSE9TVElPUE9SVDEgPSBzZXR1cC0+aW9fcG9ydC0weDEwOwoJfQoKCXNwaW5fbG9ja19pbml0KCZRTE9DSyk7CglSRUNPTk5FQ1QgICA9IHNldHVwLT5yZWNvbm5lY3Q7CglTWU5DSFJPTk9VUyA9IHNldHVwLT5zeW5jaHJvbm91czsKCVBBUklUWSAgICAgID0gc2V0dXAtPnBhcml0eTsKCURFTEFZICAgICAgID0gc2V0dXAtPmRlbGF5OwoJRVhUX1RSQU5TICAgPSBzZXR1cC0+ZXh0X3RyYW5zOwoKI2lmIGRlZmluZWQoQUhBMTUyWF9ERUJVRykKCUhPU1REQVRBKHNocG50KS0+ZGVidWcgPSBzZXR1cC0+ZGVidWc7CiNlbmRpZgoKCVNFVFBPUlQoU0NTSUlELCBzZXR1cC0+c2NzaWlkIDw8IDQpOwoJc2hwbnQtPnRoaXNfaWQgPSBzZXR1cC0+c2NzaWlkOwoKCWlmIChzZXR1cC0+cmVjb25uZWN0KQoJCXNocG50LT5jYW5fcXVldWUgPSBBSEExNTJYX01BWFFVRVVFOwoKCS8qIFJFU0VUIE9VVCAqLwoJcHJpbnRrKCJhaGExNTJ4OiByZXNldHRpbmcgYnVzLi4uXG4iKTsKCVNFVFBPUlQoU0NTSVNFUSwgU0NTSVJTVE8pOwoJbWRlbGF5KDI1Nik7CglTRVRQT1JUKFNDU0lTRVEsIDApOwoJbWRlbGF5KERFTEFZKTsKCglyZXNldF9wb3J0cyhzaHBudCk7CgoJcHJpbnRrKEtFUk5fSU5GTwoJICAgICAgICJhaGExNTJ4JWQlczogIgoJICAgICAgICJ2aXRhbCBkYXRhOiByZXY9JXgsICIKCSAgICAgICAiaW89MHglMDNseCAoMHglMDNseC8weCUwM2x4KSwgIgoJICAgICAgICJpcnE9JWQsICIKCSAgICAgICAic2NzaWlkPSVkLCAiCgkgICAgICAgInJlY29ubmVjdD0lcywgIgoJICAgICAgICJwYXJpdHk9JXMsICIKCSAgICAgICAic3luY2hyb25vdXM9JXMsICIKCSAgICAgICAiZGVsYXk9JWQsICIKCSAgICAgICAiZXh0ZW5kZWQgdHJhbnNsYXRpb249JXNcbiIsCgkgICAgICAgc2hwbnQtPmhvc3Rfbm8sIHNldHVwLT50YzE1NTAgPyAiICh0YzE1NTAgbW9kZSkiIDogIiIsCgkgICAgICAgR0VUUE9SVChSRVYpICYgMHg3LAoJICAgICAgIHNocG50LT5pb19wb3J0LCBIT1NUSU9QT1JUMCwgSE9TVElPUE9SVDEsCgkgICAgICAgc2hwbnQtPmlycSwKCSAgICAgICBzaHBudC0+dGhpc19pZCwKCSAgICAgICBSRUNPTk5FQ1QgPyAiZW5hYmxlZCIgOiAiZGlzYWJsZWQiLAoJICAgICAgIFBBUklUWSA/ICJlbmFibGVkIiA6ICJkaXNhYmxlZCIsCgkgICAgICAgU1lOQ0hST05PVVMgPyAiZW5hYmxlZCIgOiAiZGlzYWJsZWQiLAoJICAgICAgIERFTEFZLAoJICAgICAgIEVYVF9UUkFOUyA/ICJlbmFibGVkIiA6ICJkaXNhYmxlZCIpOwoKCS8qIG5vdCBleHBlY3RpbmcgYW55IGludGVycnVwdHMgKi8KCVNFVFBPUlQoU0lNT0RFMCwgMCk7CglTRVRQT1JUKFNJTU9ERTEsIDApOwoKCWlmKCByZXF1ZXN0X2lycShzaHBudC0+aXJxLCBzd2ludHIsIFNBX0lOVEVSUlVQVHxTQV9TSElSUSwgImFoYTE1MngiLCBzaHBudCkgKSB7CgkJcHJpbnRrKEtFUk5fRVJSICJhaGExNTJ4JWQ6IGlycSAlZCBidXN5LlxuIiwgc2hwbnQtPmhvc3Rfbm8sIHNocG50LT5pcnEpOwoJCWdvdG8gb3V0X2hvc3RfcHV0OwoJfQoKCUhPU1REQVRBKHNocG50KS0+c3dpbnQgPSAwOwoKCXByaW50ayhLRVJOX0lORk8gImFoYTE1MnglZDogdHJ5aW5nIHNvZnR3YXJlIGludGVycnVwdCwgIiwgc2hwbnQtPmhvc3Rfbm8pOwoKCW1iKCk7CglTRVRQT1JUKERNQUNOVFJMMCwgU1dJTlR8SU5URU4pOwoJbWRlbGF5KDEwMDApOwoJZnJlZV9pcnEoc2hwbnQtPmlycSwgc2hwbnQpOwoKCWlmICghSE9TVERBVEEoc2hwbnQpLT5zd2ludCkgewoJCWlmIChURVNUSEkoRE1BU1RBVCwgSU5UU1RBVCkpIHsKCQkJcHJpbnRrKCJsb3N0LlxuIik7CgkJfSBlbHNlIHsKCQkJcHJpbnRrKCJmYWlsZWQuXG4iKTsKCQl9CgoJCVNFVFBPUlQoRE1BQ05UUkwwLCBJTlRFTik7CgoJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeCVkOiBpcnEgJWQgcG9zc2libHkgd3JvbmcuICAiCgkJCQkiUGxlYXNlIHZlcmlmeS5cbiIsIHNocG50LT5ob3N0X25vLCBzaHBudC0+aXJxKTsKCQlnb3RvIG91dF9ob3N0X3B1dDsKCX0KCXByaW50aygib2suXG4iKTsKCgoJLyogY2xlYXIgaW50ZXJydXB0cyAqLwoJU0VUUE9SVChTU1RBVDAsIDB4N2YpOwoJU0VUUE9SVChTU1RBVDEsIDB4ZWYpOwoKCWlmICggcmVxdWVzdF9pcnEoc2hwbnQtPmlycSwgaW50ciwgU0FfSU5URVJSVVBUfFNBX1NISVJRLCAiYWhhMTUyeCIsIHNocG50KSApIHsKCQlwcmludGsoS0VSTl9FUlIgImFoYTE1MnglZDogZmFpbGVkIHRvIHJlYXNzaWduIGlycSAlZC5cbiIsIHNocG50LT5ob3N0X25vLCBzaHBudC0+aXJxKTsKCQlnb3RvIG91dF9ob3N0X3B1dDsKCX0KCglpZiggc2NzaV9hZGRfaG9zdChzaHBudCwgTlVMTCkgKSB7CgkJZnJlZV9pcnEoc2hwbnQtPmlycSwgc2hwbnQpOwoJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeCVkOiBmYWlsZWQgdG8gYWRkIGhvc3QuXG4iLCBzaHBudC0+aG9zdF9ubyk7CgkJZ290byBvdXRfaG9zdF9wdXQ7Cgl9CgoJc2NzaV9zY2FuX2hvc3Qoc2hwbnQpOwoKCXJlZ2lzdGVyZWRfY291bnQrKzsKCglyZXR1cm4gc2hwbnQ7CgpvdXRfaG9zdF9wdXQ6CglhaGExNTJ4X2hvc3RbcmVnaXN0ZXJlZF9jb3VudF09TlVMTDsKCXNjc2lfaG9zdF9wdXQoc2hwbnQpOwoKCXJldHVybiBOVUxMOwp9Cgp2b2lkIGFoYTE1MnhfcmVsZWFzZShzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCkKewoJaWYoIXNocG50KQoJCXJldHVybjsKCglpZiAoc2hwbnQtPmlycSkKCQlmcmVlX2lycShzaHBudC0+aXJxLCBzaHBudCk7CgojaWYgIWRlZmluZWQoUENNQ0lBKQoJaWYgKHNocG50LT5pb19wb3J0KQoJCXJlbGVhc2VfcmVnaW9uKHNocG50LT5pb19wb3J0LCBJT19SQU5HRSk7CiNlbmRpZgoKI2lmZGVmIF9fSVNBUE5QX18KCWlmIChIT1NUREFUQShzaHBudCktPnBucGRldikKCQlwbnBfZGV2aWNlX2RldGFjaChIT1NUREFUQShzaHBudCktPnBucGRldik7CiNlbmRpZgoKCXNjc2lfcmVtb3ZlX2hvc3Qoc2hwbnQpOwoJc2NzaV9ob3N0X3B1dChzaHBudCk7Cn0KCgovKgogKiBzZXR1cCBjb250cm9sbGVyIHRvIGdlbmVyYXRlIGludGVycnVwdHMgZGVwZW5kaW5nCiAqIG9uIGN1cnJlbnQgc3RhdGUgKGxvY2sgaGFzIHRvIGJlIGFjcXVpcmVkKQogKgogKi8gCnN0YXRpYyBpbnQgc2V0dXBfZXhwZWN0ZWRfaW50ZXJydXB0cyhzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCkKewoJaWYoQ1VSUkVOVF9TQykgewoJCUNVUlJFTlRfU0MtPlNDcC5waGFzZSB8PSAxIDw8IDE2OwoJCgkJaWYoQ1VSUkVOVF9TQy0+U0NwLnBoYXNlICYgc2VsZWN0aW5nKSB7CgkJCURQUklOVEsoZGVidWdfaW50ciwgREVCVUdfTEVBRCAiZXhwZWN0aW5nOiAoc2VsZG8pIChzZWx0aW1vKSAoc2VsZGkpXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCQkJU0VUUE9SVChTU1RBVDEsIFNFTFRPKTsKCQkJU0VUUE9SVChTSU1PREUwLCBFTlNFTERPIHwgKERJU0NPTk5FQ1RFRF9TQyA/IEVOU0VMREkgOiAwKSk7CgkJCVNFVFBPUlQoU0lNT0RFMSwgRU5TRUxUSU1PKTsKCQl9IGVsc2UgewoJCQlEUFJJTlRLKGRlYnVnX2ludHIsIERFQlVHX0xFQUQgImV4cGVjdGluZzogKHBoYXNlIGNoYW5nZSkgKGJ1c2ZyZWUpICVzXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpLCBDVVJSRU5UX1NDLT5TQ3AucGhhc2UgJiBzcGlvcmR5ID8gIihzcGlvcmR5KSIgOiAiIik7CgkJCVNFVFBPUlQoU0lNT0RFMCwgKENVUlJFTlRfU0MtPlNDcC5waGFzZSAmIHNwaW9yZHkpID8gRU5TUElPUkRZIDogMCk7CgkJCVNFVFBPUlQoU0lNT0RFMSwgRU5QSEFTRU1JUyB8IEVOU0NTSVJTVCB8IEVOU0NTSVBFUlIgfCBFTkJVU0ZSRUUpOyAKCQl9Cgl9IGVsc2UgaWYoU1RBVEU9PXNlbGRpKSB7CgkJRFBSSU5USyhkZWJ1Z19pbnRyLCBERUJVR19MRUFEICJleHBlY3Rpbmc6IChwaGFzZSBjaGFuZ2UpIChpZGVudGlmeSlcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCVNFVFBPUlQoU0lNT0RFMCwgMCk7CgkJU0VUUE9SVChTSU1PREUxLCBFTlBIQVNFTUlTIHwgRU5TQ1NJUlNUIHwgRU5TQ1NJUEVSUiB8IEVOQlVTRlJFRSk7IAoJfSBlbHNlIHsKCQlEUFJJTlRLKGRlYnVnX2ludHIsIERFQlVHX0xFQUQgImV4cGVjdGluZzogJXMgJXNcbiIsCgkJCUNNRElORk8oQ1VSUkVOVF9TQyksCgkJCURJU0NPTk5FQ1RFRF9TQyA/ICIocmVzZWxlY3Rpb24pIiA6ICIiLAoJCQlJU1NVRV9TQyA/ICIoYnVzZnJlZSkiIDogIiIpOwoJCVNFVFBPUlQoU0lNT0RFMCwgRElTQ09OTkVDVEVEX1NDID8gRU5TRUxESSA6IDApOwoJCVNFVFBPUlQoU0lNT0RFMSwgRU5TQ1NJUlNUIHwgKCAoSVNTVUVfU0N8fERPTkVfU0MpID8gRU5CVVNGUkVFIDogMCkpOwoJfQoKCWlmKCFIT1NUREFUQShzaHBudCktPmluX2ludHIpCgkJU0VUQklUUyhETUFDTlRSTDAsIElOVEVOKTsKCglyZXR1cm4gVEVTVEhJKERNQVNUQVQsIElOVFNUQVQpOwp9CgoKLyogCiAqICBRdWV1ZSBhIGNvbW1hbmQgYW5kIHNldHVwIGludGVycnVwdHMgZm9yIGEgZnJlZSBidXMuCiAqLwpzdGF0aWMgaW50IGFoYTE1MnhfaW50ZXJuYWxfcXVldWUoU2NzaV9DbW5kICpTQ3BudCwgc3RydWN0IHNlbWFwaG9yZSAqc2VtLCBpbnQgcGhhc2UsIHZvaWQgKCpkb25lKShTY3NpX0NtbmQgKikpCnsKCXN0cnVjdCBTY3NpX0hvc3QgKnNocG50ID0gU0NwbnQtPmRldmljZS0+aG9zdDsKCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CgojaWYgZGVmaW5lZChBSEExNTJYX0RFQlVHKQoJaWYgKEhPU1REQVRBKHNocG50KS0+ZGVidWcgJiBkZWJ1Z19xdWV1ZSkgewoJCXByaW50ayhJTkZPX0xFQUQgInF1ZXVlOiAlcDsgY21kX2xlbj0lZCBwaWVjZXM9JWQgc2l6ZT0ldSBjbW5kPSIsCgkJICAgICAgIENNRElORk8oU0NwbnQpLCBTQ3BudCwgU0NwbnQtPmNtZF9sZW4sIFNDcG50LT51c2Vfc2csIFNDcG50LT5yZXF1ZXN0X2J1ZmZsZW4pOwoJCV9fc2NzaV9wcmludF9jb21tYW5kKFNDcG50LT5jbW5kKTsKCX0KI2VuZGlmCgoJU0NwbnQtPnNjc2lfZG9uZQk9IGRvbmU7CglTQ3BudC0+cmVzaWQgCQk9IFNDcG50LT5yZXF1ZXN0X2J1ZmZsZW47CglTQ3BudC0+U0NwLnBoYXNlCT0gbm90X2lzc3VlZCB8IHBoYXNlOwoJU0NwbnQtPlNDcC5TdGF0dXMJPSBDSEVDS19DT05ESVRJT047CglTQ3BudC0+U0NwLk1lc3NhZ2UJPSAwOwoJU0NwbnQtPlNDcC5oYXZlX2RhdGFfaW4JPSAwOwoJU0NwbnQtPlNDcC5zZW50X2NvbW1hbmQJPSAwOwoKCWlmKFNDcG50LT5TQ3AucGhhc2UgJiAocmVzZXR0aW5nfGNoZWNrX2NvbmRpdGlvbikpIHsKCQlpZihTQ3BudC0+aG9zdF9zY3JpYmJsZT09MCB8fCBTQ1NFTShTQ3BudCkgfHwgU0NORVhUKFNDcG50KSkgewoJCQlwcmludGsoRVJSX0xFQUQgImNhbm5vdCByZXVzZSBjb21tYW5kXG4iLCBDTURJTkZPKFNDcG50KSk7CgkJCXJldHVybiBGQUlMRUQ7CgkJfQoJfSBlbHNlIHsKCQlTQ3BudC0+aG9zdF9zY3JpYmJsZSA9IGttYWxsb2Moc2l6ZW9mKHN0cnVjdCBhaGExNTJ4X3NjZGF0YSksIEdGUF9BVE9NSUMpOwoJCWlmKFNDcG50LT5ob3N0X3NjcmliYmxlPT0wKSB7CgkJCXByaW50ayhFUlJfTEVBRCAiYWxsb2NhdGlvbiBmYWlsZWRcbiIsIENNRElORk8oU0NwbnQpKTsKCQkJcmV0dXJuIEZBSUxFRDsKCQl9Cgl9CgoJU0NORVhUKFNDcG50KQkJPSBOVUxMOwoJU0NTRU0oU0NwbnQpCQk9IHNlbTsKCgkvKiBzZXR1cCBzY3JhdGNoIGFyZWEKCSAgIFNDcC5wdHIgICAgICAgICAgICAgIDogYnVmZmVyIHBvaW50ZXIKCSAgIFNDcC50aGlzX3Jlc2lkdWFsICAgIDogYnVmZmVyIGxlbmd0aAoJICAgU0NwLmJ1ZmZlciAgICAgICAgICAgOiBuZXh0IGJ1ZmZlcgoJICAgU0NwLmJ1ZmZlcnNfcmVzaWR1YWwgOiBsZWZ0IGJ1ZmZlcnMgaW4gbGlzdAoJICAgU0NwLnBoYXNlICAgICAgICAgICAgOiBjdXJyZW50IHN0YXRlIG9mIHRoZSBjb21tYW5kICovCglpZiAoU0NwbnQtPnVzZV9zZykgewoJCVNDcG50LT5TQ3AuYnVmZmVyICAgICAgICAgICA9IChzdHJ1Y3Qgc2NhdHRlcmxpc3QgKikgU0NwbnQtPnJlcXVlc3RfYnVmZmVyOwoJCVNDcG50LT5TQ3AucHRyICAgICAgICAgICAgICA9IFNHX0FERFJFU1MoU0NwbnQtPlNDcC5idWZmZXIpOwoJCVNDcG50LT5TQ3AudGhpc19yZXNpZHVhbCAgICA9IFNDcG50LT5TQ3AuYnVmZmVyLT5sZW5ndGg7CgkJU0NwbnQtPlNDcC5idWZmZXJzX3Jlc2lkdWFsID0gU0NwbnQtPnVzZV9zZyAtIDE7Cgl9IGVsc2UgewoJCVNDcG50LT5TQ3AucHRyICAgICAgICAgICAgICA9IChjaGFyICopIFNDcG50LT5yZXF1ZXN0X2J1ZmZlcjsKCQlTQ3BudC0+U0NwLnRoaXNfcmVzaWR1YWwgICAgPSBTQ3BudC0+cmVxdWVzdF9idWZmbGVuOwoJCVNDcG50LT5TQ3AuYnVmZmVyICAgICAgICAgICA9IE5VTEw7CgkJU0NwbnQtPlNDcC5idWZmZXJzX3Jlc2lkdWFsID0gMDsKCX0KCglET19MT0NLKGZsYWdzKTsKCiNpZiBkZWZpbmVkKEFIQTE1MlhfU1RBVCkKCUhPU1REQVRBKHNocG50KS0+dG90YWxfY29tbWFuZHMrKzsKI2VuZGlmCgoJLyogVHVybiBsZWQgb24sIHdoZW4gdGhpcyBpcyB0aGUgZmlyc3QgY29tbWFuZC4gKi8KCUhPU1REQVRBKHNocG50KS0+Y29tbWFuZHMrKzsKCWlmIChIT1NUREFUQShzaHBudCktPmNvbW1hbmRzPT0xKQoJCVNFVFBPUlQoUE9SVEEsIDEpOwoKCWFwcGVuZF9TQygmSVNTVUVfU0MsIFNDcG50KTsKCglpZighSE9TVERBVEEoc2hwbnQpLT5pbl9pbnRyKQoJCXNldHVwX2V4cGVjdGVkX2ludGVycnVwdHMoc2hwbnQpOwoKCURPX1VOTE9DSyhmbGFncyk7CgoJcmV0dXJuIDA7Cn0KCi8qCiAqICBxdWV1ZSBhIGNvbW1hbmQKICoKICovCnN0YXRpYyBpbnQgYWhhMTUyeF9xdWV1ZShTY3NpX0NtbmQgKlNDcG50LCB2b2lkICgqZG9uZSkoU2NzaV9DbW5kICopKQp7CiNpZiAwCglpZigqU0NwbnQtPmNtbmQgPT0gUkVRVUVTVF9TRU5TRSkgewoJCVNDcG50LT5yZXN1bHQgPSAwOwoJCWRvbmUoU0NwbnQpOwoKCQlyZXR1cm4gMDsKCX0KI2VuZGlmCgoJcmV0dXJuIGFoYTE1MnhfaW50ZXJuYWxfcXVldWUoU0NwbnQsIE5VTEwsIDAsIGRvbmUpOwp9CgoKLyoKICogIAogKgogKi8Kc3RhdGljIHZvaWQgcmVzZXRfZG9uZShTY3NpX0NtbmQgKlNDcG50KQp7CiNpZiAwCglzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCA9IFNDcG50LT5ob3N0OwoJRFBSSU5USyhkZWJ1Z19laCwgSU5GT19MRUFEICJyZXNldF9kb25lIGNhbGxlZFxuIiwgQ01ESU5GTyhTQ3BudCkpOwojZW5kaWYKCWlmKFNDU0VNKFNDcG50KSkgewoJCXVwKFNDU0VNKFNDcG50KSk7Cgl9IGVsc2UgewoJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeDogcmVzZXRfZG9uZSB3L28gc2VtYXBob3JlXG4iKTsKCX0KfQoKLyoKICogIEFib3J0IGEgY29tbWFuZAogKgogKi8Kc3RhdGljIGludCBhaGExNTJ4X2Fib3J0KFNjc2lfQ21uZCAqU0NwbnQpCnsKCXN0cnVjdCBTY3NpX0hvc3QgKnNocG50ID0gU0NwbnQtPmRldmljZS0+aG9zdDsKCVNjc2lfQ21uZCAqcHRyOwoJdW5zaWduZWQgbG9uZyBmbGFnczsKCiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCglpZihIT1NUREFUQShzaHBudCktPmRlYnVnICYgZGVidWdfZWgpIHsKCQlwcmludGsoREVCVUdfTEVBRCAiYWJvcnQoJXApIiwgQ01ESU5GTyhTQ3BudCksIFNDcG50KTsKCQlzaG93X3F1ZXVlcyhzaHBudCk7Cgl9CiNlbmRpZgoKCURPX0xPQ0soZmxhZ3MpOwoKCXB0cj1yZW1vdmVfU0MoJklTU1VFX1NDLCBTQ3BudCk7CgoJaWYocHRyKSB7CgkJRFBSSU5USyhkZWJ1Z19laCwgREVCVUdfTEVBRCAibm90IHlldCBpc3N1ZWQgLSBTVUNDRVNTXG4iLCBDTURJTkZPKFNDcG50KSk7CgoJCUhPU1REQVRBKHNocG50KS0+Y29tbWFuZHMtLTsKCQlpZiAoIUhPU1REQVRBKHNocG50KS0+Y29tbWFuZHMpCgkJCVNFVFBPUlQoUE9SVEEsIDApOwoJCURPX1VOTE9DSyhmbGFncyk7CgoJCWtmcmVlKFNDcG50LT5ob3N0X3NjcmliYmxlKTsKCQlTQ3BudC0+aG9zdF9zY3JpYmJsZT1OVUxMOwoKCQlyZXR1cm4gU1VDQ0VTUzsKCX0gCgoJRE9fVU5MT0NLKGZsYWdzKTsKCgkvKgoJICogRklYTUU6CgkgKiBmb3IgY3VycmVudCBjb21tYW5kOiBxdWV1ZSBBQk9SVCBmb3IgbWVzc2FnZSBvdXQgYW5kIHJhaXNlIEFUTgoJICogZm9yIGRpc2Nvbm5lY3RlZCBjb21tYW5kOiBwc2V1ZG8gU0Mgd2l0aCBBQk9SVCBtZXNzYWdlIG9yIEFCT1JUIG9uIHJlc2VsZWN0aW9uPwoJICoKCSAqLwoKCXByaW50ayhFUlJfTEVBRCAiY2Fubm90IGFib3J0IHJ1bm5pbmcgb3IgZGlzY29ubmVjdGVkIGNvbW1hbmRcbiIsIENNRElORk8oU0NwbnQpKTsKCglyZXR1cm4gRkFJTEVEOwp9CgpzdGF0aWMgdm9pZCB0aW1lcl9leHBpcmVkKHVuc2lnbmVkIGxvbmcgcCkKewoJU2NzaV9DbW5kCSAqU0NwICAgPSAoU2NzaV9DbW5kICopcDsKCXN0cnVjdCBzZW1hcGhvcmUgKnNlbSAgID0gU0NTRU0oU0NwKTsKCXN0cnVjdCBTY3NpX0hvc3QgKnNocG50ID0gU0NwLT5kZXZpY2UtPmhvc3Q7Cgl1bnNpZ25lZCBsb25nIGZsYWdzOwoKCS8qIHJlbW92ZSBjb21tYW5kIGZyb20gaXNzdWUgcXVldWUgKi8KCURPX0xPQ0soZmxhZ3MpOwoJcmVtb3ZlX1NDKCZJU1NVRV9TQywgU0NwKTsKCURPX1VOTE9DSyhmbGFncyk7CgoJdXAoc2VtKTsKfQoKLyoKICogUmVzZXQgYSBkZXZpY2UKICoKICovCnN0YXRpYyBpbnQgYWhhMTUyeF9kZXZpY2VfcmVzZXQoU2NzaV9DbW5kICogU0NwbnQpCnsKCXN0cnVjdCBTY3NpX0hvc3QgKnNocG50ID0gU0NwbnQtPmRldmljZS0+aG9zdDsKCURFQ0xBUkVfTVVURVhfTE9DS0VEKHNlbSk7CglzdHJ1Y3QgdGltZXJfbGlzdCB0aW1lcjsKCWludCByZXQsIGlzc3VlZCwgZGlzY29ubmVjdGVkOwoJdW5zaWduZWQgbG9uZyBmbGFnczsKCiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCglpZihIT1NUREFUQShzaHBudCktPmRlYnVnICYgZGVidWdfZWgpIHsKCQlwcmludGsoSU5GT19MRUFEICJhaGExNTJ4X2RldmljZV9yZXNldCglcCkiLCBDTURJTkZPKFNDcG50KSwgU0NwbnQpOwoJCXNob3dfcXVldWVzKHNocG50KTsKCX0KI2VuZGlmCgoJaWYoQ1VSUkVOVF9TQz09U0NwbnQpIHsKCQlwcmludGsoRVJSX0xFQUQgImNhbm5vdCByZXNldCBjdXJyZW50IGRldmljZVxuIiwgQ01ESU5GTyhTQ3BudCkpOwoJCXJldHVybiBGQUlMRUQ7Cgl9CgoJRE9fTE9DSyhmbGFncyk7Cglpc3N1ZWQgICAgICAgPSByZW1vdmVfU0MoJklTU1VFX1NDLCBTQ3BudCk9PTA7CglkaXNjb25uZWN0ZWQgPSBpc3N1ZWQgJiYgcmVtb3ZlX1NDKCZESVNDT05ORUNURURfU0MsIFNDcG50KTsKCURPX1VOTE9DSyhmbGFncyk7CgoJU0NwbnQtPmNtZF9sZW4gICAgICAgICA9IDA7CglTQ3BudC0+dXNlX3NnICAgICAgICAgID0gMDsKCVNDcG50LT5yZXF1ZXN0X2J1ZmZlciAgPSBOVUxMOwoJU0NwbnQtPnJlcXVlc3RfYnVmZmxlbiA9IDA7CgoJaW5pdF90aW1lcigmdGltZXIpOwoJdGltZXIuZGF0YSAgICAgPSAodW5zaWduZWQgbG9uZykgU0NwbnQ7Cgl0aW1lci5leHBpcmVzICA9IGppZmZpZXMgKyAxMDAqSFo7ICAgLyogMTBzICovCgl0aW1lci5mdW5jdGlvbiA9ICh2b2lkICgqKSh1bnNpZ25lZCBsb25nKSkgdGltZXJfZXhwaXJlZDsKCglhaGExNTJ4X2ludGVybmFsX3F1ZXVlKFNDcG50LCAmc2VtLCByZXNldHRpbmcsIHJlc2V0X2RvbmUpOwoJYWRkX3RpbWVyKCZ0aW1lcik7Cglkb3duKCZzZW0pOwoJZGVsX3RpbWVyKCZ0aW1lcik7CgkKCVNDcG50LT5jbWRfbGVuICAgICAgICAgPSBTQ3BudC0+b2xkX2NtZF9sZW47CglTQ3BudC0+dXNlX3NnICAgICAgICAgID0gU0NwbnQtPm9sZF91c2Vfc2c7CiAgCVNDcG50LT5yZXF1ZXN0X2J1ZmZlciAgPSBTQ3BudC0+YnVmZmVyOwogICAgICAgCVNDcG50LT5yZXF1ZXN0X2J1ZmZsZW4gPSBTQ3BudC0+YnVmZmxlbjsKCglET19MT0NLKGZsYWdzKTsKCglpZihTQ3BudC0+U0NwLnBoYXNlICYgcmVzZXR0ZWQpIHsKCQlIT1NUREFUQShzaHBudCktPmNvbW1hbmRzLS07CgkJaWYgKCFIT1NUREFUQShzaHBudCktPmNvbW1hbmRzKQoJCQlTRVRQT1JUKFBPUlRBLCAwKTsKCQlrZnJlZShTQ3BudC0+aG9zdF9zY3JpYmJsZSk7CgkJU0NwbnQtPmhvc3Rfc2NyaWJibGU9TlVMTDsKCgkJcmV0ID0gU1VDQ0VTUzsKCX0gZWxzZSB7CgkJLyogcmVxdWV1ZSAqLwoJCWlmKCFpc3N1ZWQpIHsKCQkJYXBwZW5kX1NDKCZJU1NVRV9TQywgU0NwbnQpOwoJCX0gZWxzZSBpZihkaXNjb25uZWN0ZWQpIHsKCQkJYXBwZW5kX1NDKCZESVNDT05ORUNURURfU0MsIFNDcG50KTsKCQl9CgkKCQlyZXQgPSBGQUlMRUQ7Cgl9CgoJRE9fVU5MT0NLKGZsYWdzKTsKCXJldHVybiByZXQ7Cn0KCnN0YXRpYyB2b2lkIGZyZWVfaGFyZF9yZXNldF9TQ3Moc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQsIFNjc2lfQ21uZCAqKlNDcykKewoJU2NzaV9DbW5kICpwdHI7CgoJcHRyPSpTQ3M7Cgl3aGlsZShwdHIpIHsKCQlTY3NpX0NtbmQgKm5leHQ7CgoJCWlmKFNDREFUQShwdHIpKSB7CgkJCW5leHQgPSBTQ05FWFQocHRyKTsKCQl9IGVsc2UgewoJCQlwcmludGsoREVCVUdfTEVBRCAicXVldWUgY29ycnVwdGVkIGF0ICVwXG4iLCBDTURJTkZPKHB0ciksIHB0cik7CgkJCW5leHQgPSBOVUxMOwoJCX0KCgkJaWYgKCFwdHItPmRldmljZS0+c29mdF9yZXNldCkgewoJCQlEUFJJTlRLKGRlYnVnX2VoLCBERUJVR19MRUFEICJkaXNjb25uZWN0ZWQgY29tbWFuZCAlcCByZW1vdmVkXG4iLCBDTURJTkZPKHB0ciksIHB0cik7CgkJCXJlbW92ZV9TQyhTQ3MsIHB0cik7CgkJCUhPU1REQVRBKHNocG50KS0+Y29tbWFuZHMtLTsKCQkJa2ZyZWUocHRyLT5ob3N0X3NjcmliYmxlKTsKCQkJcHRyLT5ob3N0X3NjcmliYmxlPU5VTEw7CgkJfQoKCQlwdHIgPSBuZXh0OwoJfQp9CgovKgogKiBSZXNldCB0aGUgYnVzCiAqCiAqLwpzdGF0aWMgaW50IGFoYTE1MnhfYnVzX3Jlc2V0KFNjc2lfQ21uZCAqU0NwbnQpCnsKCXN0cnVjdCBTY3NpX0hvc3QgKnNocG50ID0gU0NwbnQtPmRldmljZS0+aG9zdDsKCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CgoJRE9fTE9DSyhmbGFncyk7CgojaWYgZGVmaW5lZChBSEExNTJYX0RFQlVHKQoJaWYoSE9TVERBVEEoc2hwbnQpLT5kZWJ1ZyAmIGRlYnVnX2VoKSB7CgkJcHJpbnRrKERFQlVHX0xFQUQgImFoYTE1MnhfYnVzX3Jlc2V0KCVwKSIsIENNRElORk8oU0NwbnQpLCBTQ3BudCk7CgkJc2hvd19xdWV1ZXMoc2hwbnQpOwoJfQojZW5kaWYKCglmcmVlX2hhcmRfcmVzZXRfU0NzKHNocG50LCAmSVNTVUVfU0MpOwoJZnJlZV9oYXJkX3Jlc2V0X1NDcyhzaHBudCwgJkRJU0NPTk5FQ1RFRF9TQyk7CgoJRFBSSU5USyhkZWJ1Z19laCwgREVCVUdfTEVBRCAicmVzZXR0aW5nIGJ1c1xuIiwgQ01ESU5GTyhTQ3BudCkpOwoKCVNFVFBPUlQoU0NTSVNFUSwgU0NTSVJTVE8pOwoJbWRlbGF5KDI1Nik7CglTRVRQT1JUKFNDU0lTRVEsIDApOwoJbWRlbGF5KERFTEFZKTsKCglEUFJJTlRLKGRlYnVnX2VoLCBERUJVR19MRUFEICJidXMgcmVzZXR0ZWRcbiIsIENNRElORk8oU0NwbnQpKTsKCglzZXR1cF9leHBlY3RlZF9pbnRlcnJ1cHRzKHNocG50KTsKCWlmKEhPU1REQVRBKHNocG50KS0+Y29tbWFuZHM9PTApCgkJU0VUUE9SVChQT1JUQSwgMCk7CgoJRE9fVU5MT0NLKGZsYWdzKTsKCglyZXR1cm4gU1VDQ0VTUzsKfQoKCi8qCiAqICBSZXN0b3JlIGRlZmF1bHQgdmFsdWVzIHRvIHRoZSBBSUMtNjI2MCByZWdpc3RlcnMgYW5kIHJlc2V0IHRoZSBmaWZvcwogKgogKi8Kc3RhdGljIHZvaWQgcmVzZXRfcG9ydHMoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CgoJLyogZGlzYWJsZSBpbnRlcnJ1cHRzICovCglTRVRQT1JUKERNQUNOVFJMMCwgUlNURklGTyk7CgoJU0VUUE9SVChTQ1NJU0VRLCAwKTsKCglTRVRQT1JUKFNYRlJDVEwxLCAwKTsKCVNFVFBPUlQoU0NTSVNJRywgMCk7CglTRVRSQVRFKDApOwoKCS8qIGNsZWFyIGFsbCBpbnRlcnJ1cHQgY29uZGl0aW9ucyAqLwoJU0VUUE9SVChTU1RBVDAsIDB4N2YpOwoJU0VUUE9SVChTU1RBVDEsIDB4ZWYpOwoKCVNFVFBPUlQoU1NUQVQ0LCBTWU5DRVJSIHwgRldFUlIgfCBGUkVSUik7CgoJU0VUUE9SVChETUFDTlRSTDAsIDApOwoJU0VUUE9SVChETUFDTlRSTDEsIDApOwoKCVNFVFBPUlQoQlJTVENOVFJMLCAweGYxKTsKCgkvKiBjbGVhciBTQ1NJIGZpZm9zIGFuZCB0cmFuc2ZlciBjb3VudCAqLwoJU0VUUE9SVChTWEZSQ1RMMCwgQ0gxfENMUkNIMXxDTFJTVENOVCk7CglTRVRQT1JUKFNYRlJDVEwwLCBDSDEpOwoKCURPX0xPQ0soZmxhZ3MpOwoJc2V0dXBfZXhwZWN0ZWRfaW50ZXJydXB0cyhzaHBudCk7CglET19VTkxPQ0soZmxhZ3MpOwp9CgovKgogKiBSZXNldCB0aGUgaG9zdCAoYnVzIGFuZCBjb250cm9sbGVyKQogKgogKi8KaW50IGFoYTE1MnhfaG9zdF9yZXNldChTY3NpX0NtbmQgKiBTQ3BudCkKewojaWYgZGVmaW5lZChBSEExNTJYX0RFQlVHKQoJc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQgPSBTQ3BudC0+ZGV2aWNlLT5ob3N0OwojZW5kaWYKCglEUFJJTlRLKGRlYnVnX2VoLCBERUJVR19MRUFEICJhaGExNTJ4X2hvc3RfcmVzZXQoJXApXG4iLCBDTURJTkZPKFNDcG50KSwgU0NwbnQpOwoKCWFoYTE1MnhfYnVzX3Jlc2V0KFNDcG50KTsKCglEUFJJTlRLKGRlYnVnX2VoLCBERUJVR19MRUFEICJyZXNldHRpbmcgcG9ydHNcbiIsIENNRElORk8oU0NwbnQpKTsKCXJlc2V0X3BvcnRzKFNDcG50LT5kZXZpY2UtPmhvc3QpOwoKCXJldHVybiBTVUNDRVNTOwp9CgovKgogKiBSZXR1cm4gdGhlICJsb2dpY2FsIGdlb21ldHJ5IgogKgogKi8Kc3RhdGljIGludCBhaGExNTJ4X2Jpb3NwYXJhbShzdHJ1Y3Qgc2NzaV9kZXZpY2UgKnNkZXYsIHN0cnVjdCBibG9ja19kZXZpY2UgKmJkZXYsCgkJc2VjdG9yX3QgY2FwYWNpdHksIGludCAqaW5mb19hcnJheSkKewoJc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQgPSBzZGV2LT5ob3N0OwoKCS8qIHRyeSBkZWZhdWx0IHRyYW5zbGF0aW9uICovCglpbmZvX2FycmF5WzBdID0gNjQ7CglpbmZvX2FycmF5WzFdID0gMzI7CglpbmZvX2FycmF5WzJdID0gKHVuc2lnbmVkIGxvbmcpY2FwYWNpdHkgLyAoNjQgKiAzMik7CgoJLyogZm9yIGRpc2tzID4xR0IgZG8gc29tZSBndWVzc2luZyAqLwoJaWYgKGluZm9fYXJyYXlbMl0gPj0gMTAyNCkgewoJCWludCBpbmZvWzNdOwoKCQkvKiB0cnkgdG8gZmlndXJlIG91dCB0aGUgZ2VvbWV0cnkgZnJvbSB0aGUgcGFydGl0aW9uIHRhYmxlICovCgkJaWYgKHNjc2ljYW1fYmlvc19wYXJhbShiZGV2LCBjYXBhY2l0eSwgaW5mbykgPCAwIHx8CgkJICAgICEoKGluZm9bMF0gPT0gNjQgJiYgaW5mb1sxXSA9PSAzMikgfHwgKGluZm9bMF0gPT0gMjU1ICYmIGluZm9bMV0gPT0gNjMpKSkgewoJCQlpZiAoRVhUX1RSQU5TKSB7CgkJCQlwcmludGsoS0VSTl9OT1RJQ0UKCQkJCSAgICAgICAiYWhhMTUyeDogdW5hYmxlIHRvIHZlcmlmeSBnZW9tZXRyeSBmb3IgZGlzayB3aXRoID4xR0IuXG4iCgkJCQkgICAgICAgIiAgICAgICAgIHVzaW5nIGV4dGVuZGVkIHRyYW5zbGF0aW9uLlxuIik7CgkJCQlpbmZvX2FycmF5WzBdID0gMjU1OwoJCQkJaW5mb19hcnJheVsxXSA9IDYzOwoJCQkJaW5mb19hcnJheVsyXSA9ICh1bnNpZ25lZCBsb25nKWNhcGFjaXR5IC8gKDI1NSAqIDYzKTsKCQkJfSBlbHNlIHsKCQkJCXByaW50ayhLRVJOX05PVElDRQoJCQkJICAgICAgICJhaGExNTJ4OiB1bmFibGUgdG8gdmVyaWZ5IGdlb21ldHJ5IGZvciBkaXNrIHdpdGggPjFHQi5cbiIKCQkJCSAgICAgICAiICAgICAgICAgVXNpbmcgZGVmYXVsdCB0cmFuc2xhdGlvbi4gUGxlYXNlIHZlcmlmeSB5b3Vyc2VsZi5cbiIKCQkJCSAgICAgICAiICAgICAgICAgUGVyaGFwcyB5b3UgbmVlZCB0byBlbmFibGUgZXh0ZW5kZWQgdHJhbnNsYXRpb24gaW4gdGhlIGRyaXZlci5cbiIKCQkJCSAgICAgICAiICAgICAgICAgU2VlIERvY3VtZW50YXRpb24vc2NzaS9haGExNTJ4LnR4dCBmb3IgZGV0YWlscy5cbiIpOwoJCQl9CgkJfSBlbHNlIHsKCQkJaW5mb19hcnJheVswXSA9IGluZm9bMF07CgkJCWluZm9fYXJyYXlbMV0gPSBpbmZvWzFdOwoJCQlpbmZvX2FycmF5WzJdID0gaW5mb1syXTsKCgkJCWlmIChpbmZvWzBdID09IDI1NSAmJiAhRVhUX1RSQU5TKSB7CgkJCQlwcmludGsoS0VSTl9OT1RJQ0UKCQkJCSAgICAgICAiYWhhMTUyeDogY3VycmVudCBwYXJ0aXRpb24gdGFibGUgaXMgdXNpbmcgZXh0ZW5kZWQgdHJhbnNsYXRpb24uXG4iCgkJCQkgICAgICAgIiAgICAgICAgIHVzaW5nIGl0IGFsc28sIGFsdGhvdWdoIGl0J3Mgbm90IGV4cGxpY2l0bHkgZW5hYmxlZC5cbiIpOwoJCQl9CgkJfQoJfQoKCXJldHVybiAwOwp9CgovKgogKiAgSW50ZXJuYWwgZG9uZSBmdW5jdGlvbgogKgogKi8Kc3RhdGljIHZvaWQgZG9uZShzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCwgaW50IGVycm9yKQp7CglpZiAoQ1VSUkVOVF9TQykgewoJCWlmKERPTkVfU0MpCgkJCXByaW50ayhFUlJfTEVBRCAidGhlcmUncyBhbHJlYWR5IGEgY29tcGxldGVkIGNvbW1hbmQgJXAgLSB3aWxsIGNhdXNlIGFib3J0XG4iLCBDTURJTkZPKENVUlJFTlRfU0MpLCBET05FX1NDKTsKCgkJRE9ORV9TQyA9IENVUlJFTlRfU0M7CgkJQ1VSUkVOVF9TQyA9IE5VTEw7CgkJRE9ORV9TQy0+cmVzdWx0ID0gZXJyb3I7Cgl9IGVsc2UKCQlwcmludGsoS0VSTl9FUlIgImFoYTE1Mng6IGRvbmUoKSBjYWxsZWQgb3V0c2lkZSBvZiBjb21tYW5kXG4iKTsKfQoKc3RhdGljIHN0cnVjdCB3b3JrX3N0cnVjdCBhaGExNTJ4X3RxOwoKLyoKICogUnVuIHNlcnZpY2UgY29tcGxldGlvbnMgb24gdGhlIGNhcmQgd2l0aCBpbnRlcnJ1cHRzIGVuYWJsZWQuCiAqCiAqLwpzdGF0aWMgdm9pZCBydW4odm9pZCkKewoJaW50IGk7Cglmb3IgKGkgPSAwOyBpPEFSUkFZX1NJWkUoYWhhMTUyeF9ob3N0KTsgaSsrKSB7CgkJc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQgPSBhaGExNTJ4X2hvc3RbaV07CgkJaWYgKHNocG50ICYmIEhPU1REQVRBKHNocG50KS0+c2VydmljZSkgewoJCQlIT1NUREFUQShzaHBudCktPnNlcnZpY2U9MDsKCQkJaXNfY29tcGxldGUoc2hwbnQpOwoJCX0KCX0KfQoKLyoKICogICAgSW50ZXJydXB0cyBoYW5kbGVyCiAqCiAqLwoKc3RhdGljIGlycXJldHVybl90IGludHIoaW50IGlycW5vLCB2b2lkICpkZXZfaWQsIHN0cnVjdCBwdF9yZWdzICpyZWdzKQp7CglzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCA9IGxvb2t1cF9pcnEoaXJxbm8pOwoJdW5zaWduZWQgY2hhciByZXYsIGRtYWNudHJsMDsKCglpZiAoIXNocG50KSB7CgkJcHJpbnRrKEtFUk5fRVJSICJhaGExNTJ4OiBjYXRjaGVkIGludGVycnVwdCAlZCBmb3IgdW5rbm93biBjb250cm9sbGVyLlxuIiwgaXJxbm8pOwoJCXJldHVybiBJUlFfTk9ORTsKCX0KCgkvKgoJICogUmVhZCBhIGNvdXBsZSBvZiByZWdpc3RlcnMgdGhhdCBhcmUga25vd24gdG8gbm90IGJlIGFsbCAxJ3MuIElmCgkgKiB3ZSByZWFkIGFsbCAxJ3MgKC0xKSwgdGhhdCBtZWFucyB0aGF0IGVpdGhlcjoKCSAqCgkgKiBhLiBUaGUgaG9zdCBhZGFwdGVyIGNoaXAgaGFzIGdvbmUgYmFkLCBhbmQgd2UgY2Fubm90IGNvbnRyb2wgaXQsCgkgKglPUgoJICogYi4gVGhlIGhvc3QgYWRhcHRlciBpcyBhIFBDTUNJQSBjYXJkIHRoYXQgaGFzIGJlZW4gZWplY3RlZAoJICoKCSAqIEluIGVpdGhlciBjYXNlLCB3ZSBjYW5ub3QgZG8gYW55dGhpbmcgd2l0aCB0aGUgaG9zdCBhZGFwdGVyIGF0CgkgKiB0aGlzIHBvaW50IGluIHRpbWUuIFNvIGp1c3QgaWdub3JlIHRoZSBpbnRlcnJ1cHQgYW5kIHJldHVybi4KCSAqIEluIHRoZSBsYXR0ZXIgY2FzZSwgdGhlIGludGVycnVwdCBtaWdodCBhY3R1YWxseSBiZSBtZWFudCBmb3IKCSAqIHNvbWVvbmUgZWxzZSBzaGFyaW5nIHRoaXMgSVJRLCBhbmQgdGhhdCBkcml2ZXIgd2lsbCBoYW5kbGUgaXQuCgkgKi8KCXJldiA9IEdFVFBPUlQoUkVWKTsKCWRtYWNudHJsMCA9IEdFVFBPUlQoRE1BQ05UUkwwKTsKCWlmICgocmV2ID09IDB4RkYpICYmIChkbWFjbnRybDAgPT0gMHhGRikpCgkJcmV0dXJuIElSUV9OT05FOwoKCS8qIG5vIG1vcmUgaW50ZXJydXB0cyBmcm9tIHRoZSBjb250cm9sbGVyLCB3aGlsZSB3ZSdyZSBidXN5LgoJICAgSU5URU4gaXMgcmVzdG9yZWQgYnkgdGhlIEJIIGhhbmRsZXIgKi8KCUNMUkJJVFMoRE1BQ05UUkwwLCBJTlRFTik7CgojaWYgMAoJLyogY2hlY2sgaWYgdGhlcmUgaXMgYWxyZWFkeSBzb21ldGhpbmcgdG8gYmUKICAgICAgICAgICBzZXJ2aWNlZDsgc2hvdWxkIG5vdCBoYXBwZW4gKi8KCWlmKEhPU1REQVRBKHNocG50KS0+c2VydmljZSkgewoJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeCVkOiBsb3N0IGludGVycnVwdCAoJWQpXG4iLCBIT1NUTk8sIEhPU1REQVRBKHNocG50KS0+c2VydmljZSk7CgkgICAgICAgIHNob3dfcXVldWVzKHNocG50KTsKCX0KI2VuZGlmCgkKCS8qIFBva2UgdGhlIEJIIGhhbmRsZXIgKi8KCUhPU1REQVRBKHNocG50KS0+c2VydmljZSsrOwoJSU5JVF9XT1JLKCZhaGExNTJ4X3RxLCAodm9pZCAqKSBydW4sIE5VTEwpOwoJc2NoZWR1bGVfd29yaygmYWhhMTUyeF90cSk7CglyZXR1cm4gSVJRX0hBTkRMRUQ7Cn0KCi8qCiAqIGJ1c2ZyZWUgcGhhc2UKICogLSBoYW5kbGUgY29tcGxldGl0aW9uL2Rpc2Nvbm5lY3Rpb24vZXJyb3Igb2YgY3VycmVudCBjb21tYW5kCiAqIC0gc3RhcnQgc2VsZWN0aW9uIGZvciBuZXh0IGNvbW1hbmQgKGlmIGFueSkKICovCnN0YXRpYyB2b2lkIGJ1c2ZyZWVfcnVuKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7Cgl1bnNpZ25lZCBsb25nIGZsYWdzOwojaWYgZGVmaW5lZChBSEExNTJYX1NUQVQpCglpbnQgYWN0aW9uPTA7CiNlbmRpZgoKCVNFVFBPUlQoU1hGUkNUTDAsIENIMXxDTFJDSDF8Q0xSU1RDTlQpOwoJU0VUUE9SVChTWEZSQ1RMMCwgQ0gxKTsKCglTRVRQT1JUKFNTVEFUMSwgQ0xSQlVTRlJFRSk7CgkKCWlmKENVUlJFTlRfU0MpIHsKI2lmIGRlZmluZWQoQUhBMTUyWF9TVEFUKQoJCWFjdGlvbisrOwojZW5kaWYKCQlDVVJSRU5UX1NDLT5TQ3AucGhhc2UgJj0gfnN5bmNuZWc7CgoJCWlmKENVUlJFTlRfU0MtPlNDcC5waGFzZSAmIGNvbXBsZXRlZCkgewoJCQkvKiB0YXJnZXQgc2VudCBDT01NQU5EIENPTVBMRVRFICovCgkJCWRvbmUoc2hwbnQsIChDVVJSRU5UX1NDLT5TQ3AuU3RhdHVzICYgMHhmZikgfCAoKENVUlJFTlRfU0MtPlNDcC5NZXNzYWdlICYgMHhmZikgPDwgOCkgfCAoRElEX09LIDw8IDE2KSk7CgoJCX0gZWxzZSBpZihDVVJSRU5UX1NDLT5TQ3AucGhhc2UgJiBhYm9ydGVkKSB7CgkJCURQUklOVEsoZGVidWdfZWgsIERFQlVHX0xFQUQgIkFCT1JUIHNlbnRcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCQlkb25lKHNocG50LCAoQ1VSUkVOVF9TQy0+U0NwLlN0YXR1cyAmIDB4ZmYpIHwgKChDVVJSRU5UX1NDLT5TQ3AuTWVzc2FnZSAmIDB4ZmYpIDw8IDgpIHwgKERJRF9BQk9SVCA8PCAxNikpOwoKCQl9IGVsc2UgaWYoQ1VSUkVOVF9TQy0+U0NwLnBoYXNlICYgcmVzZXR0ZWQpIHsKCQkJRFBSSU5USyhkZWJ1Z19laCwgREVCVUdfTEVBRCAiQlVTIERFVklDRSBSRVNFVCBzZW50XG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCQkJZG9uZShzaHBudCwgKENVUlJFTlRfU0MtPlNDcC5TdGF0dXMgJiAweGZmKSB8ICgoQ1VSUkVOVF9TQy0+U0NwLk1lc3NhZ2UgJiAweGZmKSA8PCA4KSB8IChESURfUkVTRVQgPDwgMTYpKTsKCgkJfSBlbHNlIGlmKENVUlJFTlRfU0MtPlNDcC5waGFzZSAmIGRpc2Nvbm5lY3RlZCkgewoJCQkvKiB0YXJnZXQgc2VudCBESVNDT05ORUNUICovCgkJCURQUklOVEsoZGVidWdfc2VsZWN0aW9uLCBERUJVR19MRUFEICJ0YXJnZXQgZGlzY29ubmVjdGVkIGF0ICVkLyVkXG4iLAoJCQkJQ01ESU5GTyhDVVJSRU5UX1NDKSwKCQkJCUNVUlJFTlRfU0MtPnJlc2lkLAoJCQkJQ1VSUkVOVF9TQy0+cmVxdWVzdF9idWZmbGVuKTsKI2lmIGRlZmluZWQoQUhBMTUyWF9TVEFUKQoJCQlIT1NUREFUQShzaHBudCktPmRpc2Nvbm5lY3Rpb25zKys7CiNlbmRpZgoJCQlhcHBlbmRfU0MoJkRJU0NPTk5FQ1RFRF9TQywgQ1VSUkVOVF9TQyk7CgkJCUNVUlJFTlRfU0MtPlNDcC5waGFzZSB8PSAxIDw8IDE2OwoJCQlDVVJSRU5UX1NDID0gTlVMTDsKCgkJfSBlbHNlIHsKCQkJZG9uZShzaHBudCwgRElEX0VSUk9SIDw8IDE2KTsKCQl9CiNpZiBkZWZpbmVkKEFIQTE1MlhfU1RBVCkKCX0gZWxzZSB7CgkJSE9TVERBVEEoc2hwbnQpLT5idXNmcmVlX3dpdGhvdXRfb2xkX2NvbW1hbmQrKzsKI2VuZGlmCgl9CgoJRE9fTE9DSyhmbGFncyk7CgoJaWYoRE9ORV9TQykgewojaWYgZGVmaW5lZChBSEExNTJYX1NUQVQpCgkJYWN0aW9uKys7CiNlbmRpZgoKCQlpZihET05FX1NDLT5TQ3AucGhhc2UgJiBjaGVja19jb25kaXRpb24pIHsKI2lmIDAKCQkJaWYoSE9TVERBVEEoc2hwbnQpLT5kZWJ1ZyAmIGRlYnVnX2VoKSB7CgkJCQlwcmludGsoRVJSX0xFQUQgInJlY2VpdmVkIHNlbnNlOiAiLCBDTURJTkZPKERPTkVfU0MpKTsKCQkJCXNjc2lfcHJpbnRfc2Vuc2UoImJoIiwgRE9ORV9TQyk7CgkJCX0KI2VuZGlmCgoJCQkvKiByZXN0b3JlIG9sZCBjb21tYW5kICovCgkJCW1lbWNweSgodm9pZCAqKSBET05FX1NDLT5jbW5kLCAodm9pZCAqKSBET05FX1NDLT5kYXRhX2NtbmQsIHNpemVvZihET05FX1NDLT5kYXRhX2NtbmQpKTsKCQkJRE9ORV9TQy0+cmVxdWVzdF9idWZmZXIgID0gRE9ORV9TQy0+YnVmZmVyOwoJCQlET05FX1NDLT5yZXF1ZXN0X2J1ZmZsZW4gPSBET05FX1NDLT5idWZmbGVuOwoJCQlET05FX1NDLT51c2Vfc2cgICAgICAgICAgPSBET05FX1NDLT5vbGRfdXNlX3NnOwoJCQlET05FX1NDLT5jbWRfbGVuICAgICAgICAgPSBET05FX1NDLT5vbGRfY21kX2xlbjsKCgkJCURPTkVfU0MtPlNDcC5TdGF0dXMgPSAweDAyOwoKCQkJSE9TVERBVEEoc2hwbnQpLT5jb21tYW5kcy0tOwoJCQlpZiAoIUhPU1REQVRBKHNocG50KS0+Y29tbWFuZHMpCgkJCQlTRVRQT1JUKFBPUlRBLCAwKTsJLyogdHVybiBsZWQgb2ZmICovCgkJfSBlbHNlIGlmKERPTkVfU0MtPlNDcC5TdGF0dXM9PTB4MDIpIHsKI2lmIGRlZmluZWQoQUhBMTUyWF9TVEFUKQoJCQlIT1NUREFUQShzaHBudCktPmJ1c2ZyZWVfd2l0aF9jaGVja19jb25kaXRpb24rKzsKI2VuZGlmCiNpZiAwCgkJCURQUklOVEsoZGVidWdfZWgsIEVSUl9MRUFEICJDSEVDSyBDT05ESVRJT04gZm91bmRcbiIsIENNRElORk8oRE9ORV9TQykpOwojZW5kaWYKCgkJCWlmKCEoRE9ORV9TQy0+U0NwLlN0YXR1cyAmIG5vdF9pc3N1ZWQpKSB7CgkJCQlTY3NpX0NtbmQgKnB0ciA9IERPTkVfU0M7CgkJCQlET05FX1NDPU5VTEw7CiNpZiAwCgkJCQlEUFJJTlRLKGRlYnVnX2VoLCBFUlJfTEVBRCAicmVxdWVzdGluZyBzZW5zZVxuIiwgQ01ESU5GTyhwdHIpKTsKI2VuZGlmCgoJCQkJcHRyLT5jbW5kWzBdICAgICAgICAgPSBSRVFVRVNUX1NFTlNFOwoJCQkJcHRyLT5jbW5kWzFdICAgICAgICAgPSAwOwoJCQkJcHRyLT5jbW5kWzJdICAgICAgICAgPSAwOwoJCQkJcHRyLT5jbW5kWzNdICAgICAgICAgPSAwOwoJCQkJcHRyLT5jbW5kWzRdICAgICAgICAgPSBzaXplb2YocHRyLT5zZW5zZV9idWZmZXIpOwoJCQkJcHRyLT5jbW5kWzVdICAgICAgICAgPSAwOwoJCQkJcHRyLT5jbWRfbGVuICAgICAgICAgPSA2OwoJCQkJcHRyLT51c2Vfc2cgICAgICAgICAgPSAwOyAKCQkJCXB0ci0+cmVxdWVzdF9idWZmZXIgID0gcHRyLT5zZW5zZV9idWZmZXI7CgkJCQlwdHItPnJlcXVlc3RfYnVmZmxlbiA9IHNpemVvZihwdHItPnNlbnNlX2J1ZmZlcik7CgkJCQoJCQkJRE9fVU5MT0NLKGZsYWdzKTsKCQkJCWFoYTE1MnhfaW50ZXJuYWxfcXVldWUocHRyLCBOVUxMLCBjaGVja19jb25kaXRpb24sIHB0ci0+c2NzaV9kb25lKTsKCQkJCURPX0xPQ0soZmxhZ3MpOwojaWYgMAoJCQl9IGVsc2UgewoJCQkJRFBSSU5USyhkZWJ1Z19laCwgRVJSX0xFQUQgImNvbW1hbmQgbm90IGlzc3VlZCAtIENIRUNLIENPTkRJVElPTiBpZ25vcmVkXG4iLCBDTURJTkZPKERPTkVfU0MpKTsKI2VuZGlmCgkJCX0KCQl9CgoJCWlmKERPTkVfU0MgJiYgRE9ORV9TQy0+c2NzaV9kb25lKSB7CiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCgkJCWludCBob3N0bm89RE9ORV9TQy0+ZGV2aWNlLT5ob3N0LT5ob3N0X25vOwoJCQlpbnQgaWQ9RE9ORV9TQy0+ZGV2aWNlLT5pZCAmIDB4ZjsKCQkJaW50IGx1bj1ET05FX1NDLT5kZXZpY2UtPmx1biAmIDB4NzsKI2VuZGlmCgkJCVNjc2lfQ21uZCAqcHRyID0gRE9ORV9TQzsKCQkJRE9ORV9TQz1OVUxMOwoKCQkJLyogdHVybiBsZWQgb2ZmLCB3aGVuIG5vIGNvbW1hbmRzIGFyZSBpbiB0aGUgZHJpdmVyICovCgkJCUhPU1REQVRBKHNocG50KS0+Y29tbWFuZHMtLTsKCQkJaWYgKCFIT1NUREFUQShzaHBudCktPmNvbW1hbmRzKQoJCQkJU0VUUE9SVChQT1JUQSwgMCk7CS8qIHR1cm4gbGVkIG9mZiAqLwoKCQkJaWYocHRyLT5zY3NpX2RvbmUgIT0gcmVzZXRfZG9uZSkgewoJCQkJa2ZyZWUocHRyLT5ob3N0X3NjcmliYmxlKTsKCQkJCXB0ci0+aG9zdF9zY3JpYmJsZT1OVUxMOwoJCQl9CgoJCQlET19VTkxPQ0soZmxhZ3MpOwoJCQlEUFJJTlRLKGRlYnVnX2RvbmUsIERFQlVHX0xFQUQgImNhbGxpbmcgc2NzaV9kb25lKCVwKVxuIiwgaG9zdG5vLCBpZCwgbHVuLCBwdHIpOwogICAgICAgICAgICAgICAgCXB0ci0+c2NzaV9kb25lKHB0cik7CgkJCURQUklOVEsoZGVidWdfZG9uZSwgREVCVUdfTEVBRCAic2NzaV9kb25lKCVwKSByZXR1cm5lZFxuIiwgaG9zdG5vLCBpZCwgbHVuLCBwdHIpOwoJCQlET19MT0NLKGZsYWdzKTsKCQl9CgoJCURPTkVfU0M9TlVMTDsKI2lmIGRlZmluZWQoQUhBMTUyWF9TVEFUKQoJfSBlbHNlIHsKCQlIT1NUREFUQShzaHBudCktPmJ1c2ZyZWVfd2l0aG91dF9kb25lX2NvbW1hbmQrKzsKI2VuZGlmCgl9CgoJaWYoSVNTVUVfU0MpCgkJQ1VSUkVOVF9TQyA9IHJlbW92ZV9maXJzdF9TQygmSVNTVUVfU0MpOwoKCURPX1VOTE9DSyhmbGFncyk7CgoJaWYoQ1VSUkVOVF9TQykgewojaWYgZGVmaW5lZChBSEExNTJYX1NUQVQpCgkJYWN0aW9uKys7CiNlbmRpZgoJICAgIAlDVVJSRU5UX1NDLT5TQ3AucGhhc2UgfD0gc2VsZWN0aW5nOwoKCQlEUFJJTlRLKGRlYnVnX3NlbGVjdGlvbiwgREVCVUdfTEVBRCAic2VsZWN0aW5nIHRhcmdldFxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgoJCS8qIGNsZWFyIHNlbGVjdGlvbiB0aW1lb3V0ICovCgkJU0VUUE9SVChTU1RBVDEsIFNFTFRPKTsKCgkJU0VUUE9SVChTQ1NJSUQsIChzaHBudC0+dGhpc19pZCA8PCBPSURfKSB8IENVUlJFTlRfU0MtPmRldmljZS0+aWQpOwoJCVNFVFBPUlQoU1hGUkNUTDEsIChQQVJJVFkgPyBFTlNQQ0hLIDogMCApIHwgRU5TVElNRVIpOwoJCVNFVFBPUlQoU0NTSVNFUSwgRU5TRUxPIHwgRU5BVVRPQVROTyB8IChESVNDT05ORUNURURfU0MgPyBFTlJFU0VMSSA6IDApKTsKCX0gZWxzZSB7CiNpZiBkZWZpbmVkKEFIQTE1MlhfU1RBVCkKCQlIT1NUREFUQShzaHBudCktPmJ1c2ZyZWVfd2l0aG91dF9uZXdfY29tbWFuZCsrOwojZW5kaWYKCQlTRVRQT1JUKFNDU0lTRVEsIERJU0NPTk5FQ1RFRF9TQyA/IEVOUkVTRUxJIDogMCk7Cgl9CgojaWYgZGVmaW5lZChBSEExNTJYX1NUQVQpCglpZighYWN0aW9uKQoJCUhPU1REQVRBKHNocG50KS0+YnVzZnJlZV93aXRob3V0X2FueV9hY3Rpb24rKzsKI2VuZGlmCn0KCi8qCiAqIFNlbGVjdGlvbiBkb25lIChPVVQpCiAqIC0gcXVldWUgSURFTlRJRlkgbWVzc2FnZSBhbmQgU0RUUiB0byBzZWxlY3RlZCB0YXJnZXQgZm9yIG1lc3NhZ2Ugb3V0CiAqICAgKEFUTiBhc3NlcnRlZCBhdXRvbWFnaWNhbGx5IHZpYSBFTkFVVE9BVE5PIGluIGJ1c2ZyZWUoKSkKICovCnN0YXRpYyB2b2lkIHNlbGRvX3J1bihzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCkKewoJU0VUUE9SVChTQ1NJU0lHLCAwKTsKCVNFVFBPUlQoU1NUQVQxLCBDTFJCVVNGUkVFKTsKCVNFVFBPUlQoU1NUQVQxLCBDTFJQSEFTRUNIRyk7CgogICAgCUNVUlJFTlRfU0MtPlNDcC5waGFzZSAmPSB+KHNlbGVjdGluZ3xub3RfaXNzdWVkKTsKCglTRVRQT1JUKFNDU0lTRVEsIDApOwoKCWlmIChURVNUTE8oU1NUQVQwLCBTRUxETykpIHsKCQlwcmludGsoRVJSX0xFQUQgImFoYTE1Mng6IHBhc3NpbmcgYnVzIGZyZWUgY29uZGl0aW9uXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCQlkb25lKHNocG50LCBESURfTk9fQ09OTkVDVCA8PCAxNik7CgkJcmV0dXJuOwoJfQoKCVNFVFBPUlQoU1NUQVQwLCBDTFJTRUxETyk7CgkKCUFERE1TR08oSURFTlRJRlkoUkVDT05ORUNULCBDVVJSRU5UX1NDLT5kZXZpY2UtPmx1bikpOwoKCWlmIChDVVJSRU5UX1NDLT5TQ3AucGhhc2UgJiBhYm9ydGluZykgewoJCUFERE1TR08oQUJPUlQpOwoJfSBlbHNlIGlmIChDVVJSRU5UX1NDLT5TQ3AucGhhc2UgJiByZXNldHRpbmcpIHsKCQlBRERNU0dPKEJVU19ERVZJQ0VfUkVTRVQpOwoJfSBlbHNlIGlmIChTWU5DTkVHPT0wICYmIFNZTkNIUk9OT1VTKSB7CiAgICAJCUNVUlJFTlRfU0MtPlNDcC5waGFzZSB8PSBzeW5jbmVnOwoJCUFERE1TR08oRVhURU5ERURfTUVTU0FHRSk7CgkJQURETVNHTygzKTsKCQlBRERNU0dPKEVYVEVOREVEX1NEVFIpOwoJCUFERE1TR08oNTApOwkJLyogMjAwbnMgKi8KCQlBRERNU0dPKDgpOwkJLyogOCBieXRlIHJlcS9hY2sgb2Zmc2V0ICovCgoJCVNZTkNORUc9MTsJCS8qIG5lZ290aWF0aW9uIGluIHByb2dyZXNzICovCgl9CgoJU0VUUkFURShTWU5DUkFURSk7Cn0KCi8qCiAqIFNlbGVjdGlvbiB0aW1lb3V0CiAqIC0gcmV0dXJuIGNvbW1hbmQgdG8gbWlkLWxldmVsIHdpdGggZmFpbHVyZSBjYXVzZQogKgogKi8Kc3RhdGljIHZvaWQgc2VsdG9fcnVuKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglTRVRQT1JUKFNDU0lTRVEsIDApOwkJCglTRVRQT1JUKFNTVEFUMSwgQ0xSU0VMVElNTyk7CgoJRFBSSU5USyhkZWJ1Z19zZWxlY3Rpb24sIERFQlVHX0xFQUQgInNlbGVjdGlvbiB0aW1lb3V0XG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCglpZighQ1VSUkVOVF9TQykgewoJCURQUklOVEsoZGVidWdfc2VsZWN0aW9uLCBERUJVR19MRUFEICIhQ1VSUkVOVF9TQ1xuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJcmV0dXJuOwoJfQoKICAgIAlDVVJSRU5UX1NDLT5TQ3AucGhhc2UgJj0gfnNlbGVjdGluZzsKCglpZiAoQ1VSUkVOVF9TQy0+U0NwLnBoYXNlICYgYWJvcnRlZCkgewoJCURQUklOVEsoZGVidWdfc2VsZWN0aW9uLCBERUJVR19MRUFEICJhYm9ydGVkXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCQlkb25lKHNocG50LCBESURfQUJPUlQgPDwgMTYpOwoJfSBlbHNlIGlmIChURVNUTE8oU1NUQVQwLCBTRUxJTkdPKSkgewoJCURQUklOVEsoZGVidWdfc2VsZWN0aW9uLCBERUJVR19MRUFEICJhcmJpdHJhdGlvbiBub3Qgd29uXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCQlkb25lKHNocG50LCBESURfQlVTX0JVU1kgPDwgMTYpOwoJfSBlbHNlIHsKCQkvKiBBUkJJVFJBVElPTiB3b24sIGJ1dCBTRUxFQ1RJT04gZmFpbGVkICovCgkJRFBSSU5USyhkZWJ1Z19zZWxlY3Rpb24sIERFQlVHX0xFQUQgInNlbGVjdGlvbiBmYWlsZWRcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCWRvbmUoc2hwbnQsIERJRF9OT19DT05ORUNUIDw8IDE2KTsKCX0KfQoKLyoKICogU2VsZWN0aW9uIGluIGRvbmUKICogLSBwdXQgY3VycmVudCBjb21tYW5kIGJhY2sgdG8gaXNzdWUgcXVldWUKICogICAocmVjb25uZWN0aW9uIG9mIGEgZGlzY29ubmVjdGVkIG5leHVzIGluc3RlYWQKICogICAgb2Ygc3VjY2Vzc2Z1bCBzZWxlY3Rpb24gb3V0KQogKgogKi8Kc3RhdGljIHZvaWQgc2VsZGlfcnVuKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglpbnQgc2VsaWQ7CglpbnQgdGFyZ2V0OwoJdW5zaWduZWQgbG9uZyBmbGFnczsKCglTRVRQT1JUKFNDU0lTSUcsIDApOwoJU0VUUE9SVChTU1RBVDAsIENMUlNFTERJKTsKCVNFVFBPUlQoU1NUQVQxLCBDTFJCVVNGUkVFKTsKCVNFVFBPUlQoU1NUQVQxLCBDTFJQSEFTRUNIRyk7CgoJaWYoQ1VSUkVOVF9TQykgewoJCWlmKCEoQ1VSUkVOVF9TQy0+U0NwLnBoYXNlICYgbm90X2lzc3VlZCkpCgkJCXByaW50ayhFUlJfTEVBRCAiY29tbWFuZCBzaG91bGQgbm90IGhhdmUgYmVlbiBpc3N1ZWQgeWV0XG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCgkJRFBSSU5USyhkZWJ1Z19zZWxlY3Rpb24sIEVSUl9MRUFEICJjb21tYW5kIHJlcXVldWVkIC0gcmVzZWxlY3Rpb25cbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoKCQlET19MT0NLKGZsYWdzKTsKCQlhcHBlbmRfU0MoJklTU1VFX1NDLCBDVVJSRU5UX1NDKTsKCQlET19VTkxPQ0soZmxhZ3MpOwoKCQlDVVJSRU5UX1NDID0gTlVMTDsKCX0KCglpZighRElTQ09OTkVDVEVEX1NDKSB7CgkJRFBSSU5USyhkZWJ1Z19zZWxlY3Rpb24sIERFQlVHX0xFQUQgInVuZXhwZWN0ZWQgU0VMREkgIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJcmV0dXJuOwoJfQoKCVJFQ09OTl9UQVJHRVQ9LTE7CgoJc2VsaWQgPSBHRVRQT1JUKFNFTElEKSAmIH4oMSA8PCBzaHBudC0+dGhpc19pZCk7CgoJaWYgKHNlbGlkPT0wKSB7CgkJcHJpbnRrKCJhaGExNTJ4JWQ6IHRhcmdldCBpZCB1bmtub3duICglMDJ4KVxuIiwgSE9TVE5PLCBzZWxpZCk7CgkJcmV0dXJuOwoJfQoKCWZvcih0YXJnZXQ9NzsgIShzZWxpZCAmICgxIDw8IHRhcmdldCkpOyB0YXJnZXQtLSkKCQk7CgoJaWYoc2VsaWQgJiB+KDEgPDwgdGFyZ2V0KSkgewoJCXByaW50aygiYWhhMTUyeCVkOiBtdWx0aXBsZSB0YXJnZXRzIHJlY29ubmVjdGVkICglMDJ4KVxuIiwKCQkgICAgICAgSE9TVE5PLCBzZWxpZCk7Cgl9CgoKCVNFVFBPUlQoU0NTSUlELCAoc2hwbnQtPnRoaXNfaWQgPDwgT0lEXykgfCB0YXJnZXQpOwoJU0VUUE9SVChTQ1NJU0VRLCAwKTsKCglTRVRSQVRFKEhPU1REQVRBKHNocG50KS0+c3luY3JhdGVbdGFyZ2V0XSk7CgoJUkVDT05OX1RBUkdFVD10YXJnZXQ7CglEUFJJTlRLKGRlYnVnX3NlbGVjdGlvbiwgREVCVUdfTEVBRCAidGFyZ2V0ICVkIHJlc2VsZWN0ZWQgKCUwMngpLlxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSwgdGFyZ2V0LCBzZWxpZCk7Cn0KCi8qCiAqIG1lc3NhZ2UgaW4gcGhhc2UKICogLSBoYW5kbGUgaW5pdGlhbCBtZXNzYWdlIGFmdGVyIHJlY29ubmVjdGlvbiB0byBpZGVudGlmeQogKiAgIHJlY29ubmVjdGluZyBuZXh1cwogKiAtIHF1ZXVlIGNvbW1hbmQgb24gRElTQ09OTkVDVEVEX1NDIG9uIERJU0NPTk5FQ1QgbWVzc2FnZQogKiAtIHNldCBjb21wbGV0ZWQgZmxhZyBvbiBDT01NQU5EIENPTVBMRVRFCiAqICAgKG90aGVyIGNvbXBsZXRpdGlvbiBjb2RlIG1vdmVkIHRvIGJ1c2ZyZWVfcnVuKQogKiAtIGhhbmRsZSByZXNwb25zZSB0byBTRFRSCiAqIC0gY2xlYXIgc3luY2hyb25vdXMgdHJhbnNmZXIgYWdyZWVtZW50cyBvbiBCVVMgUkVTRVQKICoKICogRklYTUU6IHdoYXQgYWJvdXQgU0FWRSBQT0lOVEVSUywgUkVTVE9SRSBQT0lOVEVSUz8KICoKICovCnN0YXRpYyB2b2lkIG1zZ2lfcnVuKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7Cglmb3IoOzspIHsKCQlpbnQgc3N0YXQxID0gR0VUUE9SVChTU1RBVDEpOwoKCQlpZihzc3RhdDEgJiAoUEhBU0VDSEd8UEhBU0VNSVN8QlVTRlJFRSkgfHwgIShzc3RhdDEgJiBSRVFJTklUKSkKCQkJcmV0dXJuOwoKCQlpZihURVNUTE8oU1NUQVQwLFNQSU9SRFkpKSB7CgkJCURQUklOVEsoZGVidWdfbXNnaSwgREVCVUdfTEVBRCAiIVNQSU9SRFlcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCQlyZXR1cm47CgkJfQkKCgkJQURETVNHSShHRVRQT1JUKFNDU0lEQVQpKTsKCiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCgkJaWYgKEhPU1REQVRBKHNocG50KS0+ZGVidWcgJiBkZWJ1Z19tc2dpKSB7CgkJCXByaW50ayhJTkZPX0xFQUQgImluYm91bmQgbWVzc2FnZSAlMDJ4ICIsIENNRElORk8oQ1VSUkVOVF9TQyksIE1TR0koMCkpOwoJCQlzcGlfcHJpbnRfbXNnKCZNU0dJKDApKTsKCQkJcHJpbnRrKCJcbiIpOwoJCX0KI2VuZGlmCgoJCWlmKCFDVVJSRU5UX1NDKSB7CgkJCWlmKExBU1RTVEFURSE9c2VsZGkpIHsKCQkJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeCVkOiBtZXNzYWdlIGluIHcvbyBjdXJyZW50IGNvbW1hbmQgbm90IGFmdGVyIHJlc2VsZWN0aW9uXG4iLCBIT1NUTk8pOwoJCQl9CgoJCQkvKgoJIAkgCSAqIEhhbmRsZSByZXNlbGVjdGlvbgoJIAkJICovCgkJCWlmKCEoTVNHSSgwKSAmIElERU5USUZZX0JBU0UpKSB7CgkJCQlwcmludGsoS0VSTl9FUlIgImFoYTE1MnglZDogdGFyZ2V0IGRpZG4ndCBpZGVudGlmeSBhZnRlciByZXNlbGVjdGlvblxuIiwgSE9TVE5PKTsKCQkJCWNvbnRpbnVlOwoJCQl9CgoJCQlDVVJSRU5UX1NDID0gcmVtb3ZlX2x1bl9TQygmRElTQ09OTkVDVEVEX1NDLCBSRUNPTk5fVEFSR0VULCBNU0dJKDApICYgMHgzZik7CgoJCQlpZiAoIUNVUlJFTlRfU0MpIHsKCQkJCXNob3dfcXVldWVzKHNocG50KTsKCQkJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeCVkOiBubyBkaXNjb25uZWN0ZWQgY29tbWFuZCBmb3IgdGFyZ2V0ICVkLyVkXG4iLCBIT1NUTk8sIFJFQ09OTl9UQVJHRVQsIE1TR0koMCkgJiAweDNmKTsKCQkJCWNvbnRpbnVlOwoJCQl9CgoJCQlEUFJJTlRLKGRlYnVnX21zZ2ksIERFQlVHX0xFQUQgInRhcmdldCByZWNvbm5lY3RlZFxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgoJCQlDVVJSRU5UX1NDLT5TQ3AuTWVzc2FnZSA9IE1TR0koMCk7CgkJCUNVUlJFTlRfU0MtPlNDcC5waGFzZSAmPSB+ZGlzY29ubmVjdGVkOwoKCQkJTVNHSUxFTj0wOwoKCQkJLyogbmV4dCBtZXNzYWdlIGlmIGFueSAqLwoJCQljb250aW51ZTsKCQl9IAoKCQlDVVJSRU5UX1NDLT5TQ3AuTWVzc2FnZSA9IE1TR0koMCk7CgoJCXN3aXRjaCAoTVNHSSgwKSkgewoJCWNhc2UgRElTQ09OTkVDVDoKCQkJaWYgKCFSRUNPTk5FQ1QpCgkJCQlwcmludGsoV0FSTl9MRUFEICJ0YXJnZXQgd2FzIG5vdCBhbGxvd2VkIHRvIGRpc2Nvbm5lY3RcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoKCQkJQ1VSUkVOVF9TQy0+U0NwLnBoYXNlIHw9IGRpc2Nvbm5lY3RlZDsKCQkJYnJlYWs7CgoJCWNhc2UgQ09NTUFORF9DT01QTEVURToKCQkJaWYoQ1VSUkVOVF9TQy0+U0NwLnBoYXNlICYgY29tcGxldGVkKQoJCQkJRFBSSU5USyhkZWJ1Z19tc2dpLCBERUJVR19MRUFEICJhZ2FpbiBDT01NQU5EIENPTVBMRVRFXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCgkJCUNVUlJFTlRfU0MtPlNDcC5waGFzZSB8PSBjb21wbGV0ZWQ7CgkJCWJyZWFrOwoKCQljYXNlIE1FU1NBR0VfUkVKRUNUOgoJCQlpZiAoU1lOQ05FRz09MSkgewoJCQkJcHJpbnRrKElORk9fTEVBRCAiU3luY2hyb25vdXMgRGF0YSBUcmFuc2ZlciBSZXF1ZXN0IHdhcyByZWplY3RlZFxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJCQlTWU5DTkVHPTI7CS8qIG5lZ290aWF0aW9uIGNvbXBsZXRlZCAqLwoJCQl9IGVsc2UKCQkJCXByaW50ayhJTkZPX0xFQUQgImluYm91bmQgbWVzc2FnZSAoTUVTU0FHRSBSRUpFQ1QpXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCQkJYnJlYWs7CgoJCWNhc2UgU0FWRV9QT0lOVEVSUzoKCQkJYnJlYWs7CgoJCWNhc2UgUkVTVE9SRV9QT0lOVEVSUzoKCQkJYnJlYWs7CgoJCWNhc2UgRVhURU5ERURfTUVTU0FHRToKCQkJaWYoTVNHSUxFTjwyIHx8IE1TR0lMRU48TVNHSSgxKSsyKSB7CgkJCQkvKiBub3QgeWV0IGNvbXBsZXRlZCAqLwoJCQkJY29udGludWU7CgkJCX0KCgkJCXN3aXRjaCAoTVNHSSgyKSkgewoJCQljYXNlIEVYVEVOREVEX1NEVFI6CgkJCQl7CgkJCQkJbG9uZyB0aWNrczsKCgkJCQkJaWYgKE1TR0koMSkgIT0gMykgewoJCQkJCQlwcmludGsoRVJSX0xFQUQgIlNEVFIgbWVzc2FnZSBsZW5ndGghPTNcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCQkJCQlicmVhazsKCQkJCQl9CgoJCQkJCWlmICghSE9TVERBVEEoc2hwbnQpLT5zeW5jaHJvbm91cykKCQkJCQkJYnJlYWs7CgoJCQkJCXByaW50ayhJTkZPX0xFQUQsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCQkJCXNwaV9wcmludF9tc2coJk1TR0koMCkpOwoJCQkJCXByaW50aygiXG4iKTsKCgkJCQkJdGlja3MgPSAoTVNHSSgzKSAqIDQgKyA0OSkgLyA1MDsKCgkJCQkJaWYgKHN5bmNuZWcpIHsKCQkJCQkJLyogbmVnb3RpYXRpb24gaW4gcHJvZ3Jlc3MgKi8KCQkJCQkJaWYgKHRpY2tzID4gOSB8fCBNU0dJKDQpIDwgMSB8fCBNU0dJKDQpID4gOCkgewoJCQkJCQkJQURETVNHTyhNRVNTQUdFX1JFSkVDVCk7CgkJCQkJCQlwcmludGsoSU5GT19MRUFEICJyZWNlaXZlZCBTeW5jaHJvbm91cyBEYXRhIFRyYW5zZmVyIFJlcXVlc3QgaW52YWxpZCAtIHJlamVjdGVkXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCQkJCQkJCWJyZWFrOwoJCQkJCQl9CgkJCQkJCQoJCQkJCQlTWU5DUkFURSB8PSAoKHRpY2tzIC0gMikgPDwgNCkgKyBNU0dJKDQpOwoJCQkJCX0gZWxzZSBpZiAodGlja3MgPD0gOSAmJiBNU0dJKDQpID49IDEpIHsKCQkJCQkJQURETVNHTyhFWFRFTkRFRF9NRVNTQUdFKTsKCQkJCQkJQURETVNHTygzKTsKCQkJCQkJQURETVNHTyhFWFRFTkRFRF9TRFRSKTsKCQkJCQkJaWYgKHRpY2tzIDwgNCkgewoJCQkJCQkJdGlja3MgPSA0OwoJCQkJCQkJQURETVNHTyg1MCk7CgkJCQkJCX0gZWxzZQoJCQkJCQkJQURETVNHTyhNU0dJKDMpKTsKCgkJCQkJCWlmIChNU0dJKDQpID4gOCkKCQkJCQkJCU1TR0koNCkgPSA4OwoKCQkJCQkJQURETVNHTyhNU0dJKDQpKTsKCgkJCQkJCVNZTkNSQVRFIHw9ICgodGlja3MgLSAyKSA8PCA0KSArIE1TR0koNCk7CgkJCQkJfSBlbHNlIHsKCQkJCQkJLyogcmVxdWVzdGVkIFNEVFIgaXMgdG9vIHNsb3csIGRvIGl0IGFzeW5jaHJvbm91c2x5ICovCgkJCQkJCXByaW50ayhJTkZPX0xFQUQgIlN5bmNocm9ub3VzIERhdGEgVHJhbnNmZXIgUmVxdWVzdCB0b28gc2xvdyAtIFJlamVjdGluZ1xuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJCQkJCUFERE1TR08oTUVTU0FHRV9SRUpFQ1QpOwoJCQkJCX0KCgkJCQkJU1lOQ05FRz0yOwkJLyogbmVnb3RpYXRpb24gY29tcGxldGVkICovCgkJCQkJU0VUUkFURShTWU5DUkFURSk7CgkJCQl9CgkJCQlicmVhazsKCgkJCWNhc2UgQlVTX0RFVklDRV9SRVNFVDoKCQkJCXsKCQkJCQlpbnQgaTsKCgkJCQkJZm9yKGk9MDsgaTw4OyBpKyspIHsKCQkJCQkJSE9TVERBVEEoc2hwbnQpLT5zeW5jcmF0ZVtpXT0wOwoJCQkJCQlIT1NUREFUQShzaHBudCktPnN5bmNuZWdbaV09MDsKCQkJCQl9CgoJCQkJfQoJCQkJYnJlYWs7CgoJCQljYXNlIEVYVEVOREVEX01PRElGWV9EQVRBX1BPSU5URVI6CgkJCWNhc2UgRVhURU5ERURfRVhURU5ERURfSURFTlRJRlk6CgkJCWNhc2UgRVhURU5ERURfV0RUUjoKCQkJZGVmYXVsdDoKCQkJCUFERE1TR08oTUVTU0FHRV9SRUpFQ1QpOwoJCQkJYnJlYWs7CgkJCX0KCQkJYnJlYWs7CgkJfQoKCQlNU0dJTEVOPTA7Cgl9Cn0KCnN0YXRpYyB2b2lkIG1zZ2lfZW5kKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglpZihNU0dJTEVOPjApCgkJcHJpbnRrKFdBUk5fTEVBRCAidGFyZ2V0IGxlZnQgYmVmb3JlIG1lc3NhZ2UgY29tcGxldGVkICglZClcbiIsIENNRElORk8oQ1VSUkVOVF9TQyksIE1TR0lMRU4pOwoKCWlmIChNU0dPTEVOID4gMCAmJiAhKEdFVFBPUlQoU1NUQVQxKSAmIEJVU0ZSRUUpKSB7CgkJRFBSSU5USyhkZWJ1Z19tc2dpLCBERUJVR19MRUFEICJtc2dvIHBlbmRpbmdcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCVNFVFBPUlQoU0NTSVNJRywgUF9NU0dJIHwgU0lHX0FUTk8pOwoJfSAKfQoKLyoKICogbWVzc2FnZSBvdXQgcGhhc2UKICoKICovCnN0YXRpYyB2b2lkIG1zZ29faW5pdChzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCkKewoJaWYoTVNHT0xFTj09MCkgewoJCWlmKChDVVJSRU5UX1NDLT5TQ3AucGhhc2UgJiBzeW5jbmVnKSAmJiBTWU5DTkVHPT0yICYmIFNZTkNSQVRFPT0wKSB7CgkJCUFERE1TR08oSURFTlRJRlkoUkVDT05ORUNULCBDVVJSRU5UX1NDLT5kZXZpY2UtPmx1bikpOwoJCX0gZWxzZSB7CgkJCXByaW50ayhJTkZPX0xFQUQgInVuZXhwZWN0ZWQgTUVTU0FHRSBPVVQgcGhhc2U7IHJlamVjdGluZ1xuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJCUFERE1TR08oTUVTU0FHRV9SRUpFQ1QpOwoJCX0KCX0KCiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCglpZihIT1NUREFUQShzaHBudCktPmRlYnVnICYgZGVidWdfbXNnbykgewoJCWludCBpOwoKCQlwcmludGsoREVCVUdfTEVBRCAibWVzc2FnZXMoICIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCWZvciAoaT0wOyBpPE1TR09MRU47IGkrPXNwaV9wcmludF9tc2coJk1TR08oaSkpLCBwcmludGsoIiAiKSkKCQkJOwoJCXByaW50aygiKVxuIik7Cgl9CiNlbmRpZgp9CgovKgogKiBtZXNzYWdlIG91dCBwaGFzZQogKgogKi8Kc3RhdGljIHZvaWQgbXNnb19ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCWlmKE1TR09fST09TVNHT0xFTikKCQlEUFJJTlRLKGRlYnVnX21zZ28sIERFQlVHX0xFQUQgIm1lc3NhZ2VzIGFsbCBzZW50ICglZC8lZClcbiIsIENNRElORk8oQ1VSUkVOVF9TQyksIE1TR09fSSwgTVNHT0xFTik7CgoJd2hpbGUoTVNHT19JPE1TR09MRU4pIHsKCQlEUFJJTlRLKGRlYnVnX21zZ28sIERFQlVHX0xFQUQgIm1lc3NhZ2UgYnl0ZSAlMDJ4ICglZC8lZClcbiIsIENNRElORk8oQ1VSUkVOVF9TQyksIE1TR08oTVNHT19JKSwgTVNHT19JLCBNU0dPTEVOKTsKCgkJaWYoVEVTVExPKFNTVEFUMCwgU1BJT1JEWSkpIHsKCQkJRFBSSU5USyhkZWJ1Z19tc2dvLCBERUJVR19MRUFEICIhU1BJT1JEWVxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJCXJldHVybjsKCQl9CgoJCWlmIChNU0dPX0k9PU1TR09MRU4tMSkgewoJCQkvKiBMZWF2ZSBNRVNTQUdFIE9VVCBhZnRlciB0cmFuc2ZlciAqLwoJCQlTRVRQT1JUKFNTVEFUMSwgQ0xSQVROTyk7CgkJfQoKCgkJaWYgKE1TR08oTVNHT19JKSAmIElERU5USUZZX0JBU0UpCgkJCUNVUlJFTlRfU0MtPlNDcC5waGFzZSB8PSBpZGVudGlmaWVkOwoKCQlpZiAoTVNHTyhNU0dPX0kpPT1BQk9SVCkKCQkJQ1VSUkVOVF9TQy0+U0NwLnBoYXNlIHw9IGFib3J0ZWQ7CgoJCWlmIChNU0dPKE1TR09fSSk9PUJVU19ERVZJQ0VfUkVTRVQpCgkJCUNVUlJFTlRfU0MtPlNDcC5waGFzZSB8PSByZXNldHRlZDsKCgkJU0VUUE9SVChTQ1NJREFULCBNU0dPKE1TR09fSSsrKSk7Cgl9Cn0KCnN0YXRpYyB2b2lkIG1zZ29fZW5kKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglpZihNU0dPX0k8TVNHT0xFTikgewoJCXByaW50ayhFUlJfTEVBRCAibWVzc2FnZSBzZW50IGluY29tcGxldGVseSAoJWQvJWQpXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpLCBNU0dPX0ksIE1TR09MRU4pOwoJCWlmKFNZTkNORUc9PTEpIHsKCQkJcHJpbnRrKElORk9fTEVBRCAiU3luY2hyb25vdXMgRGF0YSBUcmFuc2ZlciBSZXF1ZXN0IHdhcyByZWplY3RlZFxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJCVNZTkNORUc9MjsKCQl9Cgl9CgkJCglNU0dPX0kgID0gMDsKCU1TR09MRU4gPSAwOwp9CgovKiAKICogY29tbWFuZCBwaGFzZQogKgogKi8Kc3RhdGljIHZvaWQgY21kX2luaXQoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCWlmIChDVVJSRU5UX1NDLT5TQ3Auc2VudF9jb21tYW5kKSB7CgkJcHJpbnRrKEVSUl9MRUFEICJjb21tYW5kIGFscmVhZHkgc2VudFxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJZG9uZShzaHBudCwgRElEX0VSUk9SIDw8IDE2KTsKCQlyZXR1cm47Cgl9CgojaWYgZGVmaW5lZChBSEExNTJYX0RFQlVHKQoJaWYgKEhPU1REQVRBKHNocG50KS0+ZGVidWcgJiBkZWJ1Z19jbWQpIHsKCQlwcmludGsoREVCVUdfTEVBRCAiY21kX2luaXQ6ICIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCV9fc2NzaV9wcmludF9jb21tYW5kKENVUlJFTlRfU0MtPmNtbmQpOwoJfQojZW5kaWYKCglDTURfST0wOwp9CgovKgogKiBjb21tYW5kIHBoYXNlCiAqCiAqLwpzdGF0aWMgdm9pZCBjbWRfcnVuKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglpZihDTURfST09Q1VSUkVOVF9TQy0+Y21kX2xlbikgewoJCURQUklOVEsoZGVidWdfY21kLCBERUJVR19MRUFEICJjb21tYW5kIGFscmVhZHkgY29tcGxldGVseSBzZW50ICglZC8lZCkiLCBDTURJTkZPKENVUlJFTlRfU0MpLCBDTURfSSwgQ1VSUkVOVF9TQy0+Y21kX2xlbik7CgkJZGlzcF9wb3J0cyhzaHBudCk7Cgl9CgoJd2hpbGUoQ01EX0k8Q1VSUkVOVF9TQy0+Y21kX2xlbikgewoJCURQUklOVEsoZGVidWdfY21kLCBERUJVR19MRUFEICJjb21tYW5kIGJ5dGUgJTAyeCAoJWQvJWQpXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpLCBDVVJSRU5UX1NDLT5jbW5kW0NNRF9JXSwgQ01EX0ksIENVUlJFTlRfU0MtPmNtZF9sZW4pOwoKCQlpZihURVNUTE8oU1NUQVQwLCBTUElPUkRZKSkgewoJCQlEUFJJTlRLKGRlYnVnX2NtZCwgREVCVUdfTEVBRCAiIVNQSU9SRFlcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCQlyZXR1cm47CgkJfQoKCQlTRVRQT1JUKFNDU0lEQVQsIENVUlJFTlRfU0MtPmNtbmRbQ01EX0krK10pOwoJfQp9CgpzdGF0aWMgdm9pZCBjbWRfZW5kKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglpZihDTURfSTxDVVJSRU5UX1NDLT5jbWRfbGVuKQoJCXByaW50ayhFUlJfTEVBRCAiY29tbWFuZCBzZW50IGluY29tcGxldGVseSAoJWQvJWQpXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpLCBDTURfSSwgQ1VSUkVOVF9TQy0+Y21kX2xlbik7CgllbHNlCgkJQ1VSUkVOVF9TQy0+U0NwLnNlbnRfY29tbWFuZCsrOwp9CgovKgogKiBzdGF0dXMgcGhhc2UKICoKICovCnN0YXRpYyB2b2lkIHN0YXR1c19ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCWlmKFRFU1RMTyhTU1RBVDAsU1BJT1JEWSkpIHsKCQlEUFJJTlRLKGRlYnVnX3N0YXR1cywgREVCVUdfTEVBRCAiIVNQSU9SRFlcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCXJldHVybjsKCX0KCglDVVJSRU5UX1NDLT5TQ3AuU3RhdHVzID0gR0VUUE9SVChTQ1NJREFUKTsKCiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCglpZiAoSE9TVERBVEEoc2hwbnQpLT5kZWJ1ZyAmIGRlYnVnX3N0YXR1cykgewoJCXByaW50ayhERUJVR19MRUFEICJpbmJvdW5kIHN0YXR1cyAlMDJ4ICIsIENNRElORk8oQ1VSUkVOVF9TQyksIENVUlJFTlRfU0MtPlNDcC5TdGF0dXMpOwoJCXNjc2lfcHJpbnRfc3RhdHVzKENVUlJFTlRfU0MtPlNDcC5TdGF0dXMpOwoJCXByaW50aygiXG4iKTsKCX0KI2VuZGlmCn0KCi8qCiAqIGRhdGEgaW4gcGhhc2UKICoKICovCnN0YXRpYyB2b2lkIGRhdGFpX2luaXQoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCVNFVFBPUlQoRE1BQ05UUkwwLCBSU1RGSUZPKTsKCVNFVFBPUlQoRE1BQ05UUkwwLCBSU1RGSUZPfEVORE1BKTsKCglTRVRQT1JUKFNYRlJDVEwwLCBDSDF8Q0xSU1RDTlQpOwoJU0VUUE9SVChTWEZSQ1RMMCwgQ0gxfFNDU0lFTnxETUFFTik7CgoJU0VUUE9SVChTSU1PREUwLCAwKTsKCVNFVFBPUlQoU0lNT0RFMSwgRU5TQ1NJUEVSUiB8IEVOU0NTSVJTVCB8IEVOUEhBU0VNSVMgfCBFTkJVU0ZSRUUpOwoKCURBVEFfTEVOPTA7CglEUFJJTlRLKGRlYnVnX2RhdGFpLAoJCURFQlVHX0xFQUQgImRhdGFpX2luaXQ6IHJlcXVlc3RfYnVmZmxlbj0lZCByZXNpZD0lZFxuIiwKCQlDTURJTkZPKENVUlJFTlRfU0MpLCBDVVJSRU5UX1NDLT5yZXF1ZXN0X2J1ZmZsZW4sIENVUlJFTlRfU0MtPnJlc2lkKTsKfQoKc3RhdGljIHZvaWQgZGF0YWlfcnVuKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7Cgl1bnNpZ25lZCBsb25nIHRoZV90aW1lOwoJaW50IGZpZm9kYXRhLCBkYXRhX2NvdW50OwoKCS8qCgkgKiBsb29wIHdoaWxlIHRoZSBwaGFzZSBwZXJzaXN0cyBvciB0aGUgZmlmb3MgYXJlIG5vdCBlbXB0eQoJICoKCSAqLwoJd2hpbGUoVEVTVExPKERNQVNUQVQsIElOVFNUQVQpIHx8IFRFU1RMTyhETUFTVEFULCBERklGT0VNUCkgfHwgVEVTVExPKFNTVEFUMiwgU0VNUFRZKSkgewoJCS8qIEZJWE1FOiBtYXliZSB0aGlzIHNob3VsZCBiZSBkb25lIGJ5IHNldHRpbmcgdXAKCQkgKiBTVENOVCB0byB0cmlnZ2VyIEVOU1dSQVAgaW50ZXJydXB0LCBpbnN0ZWFkIG9mCgkJICogcG9sbGluZyBmb3IgREZJRk9GVUxMCgkJICovCgkJdGhlX3RpbWU9amlmZmllcyArIDEwMCpIWjsKCQl3aGlsZShURVNUTE8oRE1BU1RBVCwgREZJRk9GVUxMfElOVFNUQVQpICYmIHRpbWVfYmVmb3JlKGppZmZpZXMsdGhlX3RpbWUpKQoJCQliYXJyaWVyKCk7CgoJCWlmKFRFU1RMTyhETUFTVEFULCBERklGT0ZVTEx8SU5UU1RBVCkpIHsKCQkJcHJpbnRrKEVSUl9MRUFEICJkYXRhaSB0aW1lb3V0IiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJCWRpc3BfcG9ydHMoc2hwbnQpOwoJCQlicmVhazsKCQl9CgoJCWlmKFRFU1RISShETUFTVEFULCBERklGT0ZVTEwpKSB7CgkJCWZpZm9kYXRhID0gMTI4OwoJCX0gZWxzZSB7CgkJCXRoZV90aW1lPWppZmZpZXMgKyAxMDAqSFo7CgkJCXdoaWxlKFRFU1RMTyhTU1RBVDIsIFNFTVBUWSkgJiYgdGltZV9iZWZvcmUoamlmZmllcyx0aGVfdGltZSkpCgkJCQliYXJyaWVyKCk7CgoJCQlpZihURVNUTE8oU1NUQVQyLCBTRU1QVFkpKSB7CgkJCQlwcmludGsoRVJSX0xFQUQgImRhdGFpIHNlbXB0eSB0aW1lb3V0IiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CgkJCQlkaXNwX3BvcnRzKHNocG50KTsKCQkJCWJyZWFrOwoJCQl9CgoJCQlmaWZvZGF0YSA9IEdFVFBPUlQoRklGT1NUQVQpOwoJCX0KCgkJaWYoQ1VSUkVOVF9TQy0+U0NwLnRoaXNfcmVzaWR1YWw+MCkgewoJCQl3aGlsZShmaWZvZGF0YT4wICYmIENVUlJFTlRfU0MtPlNDcC50aGlzX3Jlc2lkdWFsPjApIHsKICAgICAgICAgICAgICAgICAgICAgICAgCWRhdGFfY291bnQgPSBmaWZvZGF0YT5DVVJSRU5UX1NDLT5TQ3AudGhpc19yZXNpZHVhbCA/CgkJCQkJCUNVUlJFTlRfU0MtPlNDcC50aGlzX3Jlc2lkdWFsIDoKCQkJCQkJZmlmb2RhdGE7CgkJCQlmaWZvZGF0YSAtPSBkYXRhX2NvdW50OwoKICAgICAgICAgICAgICAgICAgICAgICAgCWlmKGRhdGFfY291bnQgJiAxKSB7CgkJCQkJRFBSSU5USyhkZWJ1Z19kYXRhaSwgREVCVUdfTEVBRCAiOGJpdFxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSk7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCVNFVFBPUlQoRE1BQ05UUkwwLCBFTkRNQXxfOEJJVCk7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCSpDVVJSRU5UX1NDLT5TQ3AucHRyKysgPSBHRVRQT1JUKERBVEFQT1JUKTsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAJQ1VSUkVOVF9TQy0+U0NwLnRoaXNfcmVzaWR1YWwtLTsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAJREFUQV9MRU4rKzsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAJU0VUUE9SVChETUFDTlRSTDAsIEVORE1BKTsKICAgICAgICAgICAgICAgICAgICAgICAgCX0KCQogICAgICAgICAgICAgICAgICAgICAgICAJaWYoZGF0YV9jb3VudCA+IDEpIHsKCQkJCQlEUFJJTlRLKGRlYnVnX2RhdGFpLCBERUJVR19MRUFEICIxNmJpdCglZClcbiIsIENNRElORk8oQ1VSUkVOVF9TQyksIGRhdGFfY291bnQpOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAlkYXRhX2NvdW50ID4+PSAxOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAlpbnN3KERBVEFQT1JULCBDVVJSRU5UX1NDLT5TQ3AucHRyLCBkYXRhX2NvdW50KTsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAJQ1VSUkVOVF9TQy0+U0NwLnB0ciAgICAgICAgICAgKz0gMiAqIGRhdGFfY291bnQ7CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCUNVUlJFTlRfU0MtPlNDcC50aGlzX3Jlc2lkdWFsIC09IDIgKiBkYXRhX2NvdW50OwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAlEQVRBX0xFTiAgICAgICAgICAgICAgICAgICAgICArPSAyICogZGF0YV9jb3VudDsKICAgICAgICAgICAgICAgICAgICAgICAgCX0KCQogICAgICAgICAgICAgICAgICAgICAgICAJaWYoQ1VSUkVOVF9TQy0+U0NwLnRoaXNfcmVzaWR1YWw9PTAgJiYgQ1VSUkVOVF9TQy0+U0NwLmJ1ZmZlcnNfcmVzaWR1YWw+MCkgewogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCQkvKiBhZHZhbmNlIHRvIG5leHQgYnVmZmVyICovCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAJCUNVUlJFTlRfU0MtPlNDcC5idWZmZXJzX3Jlc2lkdWFsLS07CiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAJCUNVUlJFTlRfU0MtPlNDcC5idWZmZXIrKzsKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIAkJQ1VSUkVOVF9TQy0+U0NwLnB0ciAgICAgICAgICAgPSBTR19BRERSRVNTKENVUlJFTlRfU0MtPlNDcC5idWZmZXIpOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgCQlDVVJSRU5UX1NDLT5TQ3AudGhpc19yZXNpZHVhbCA9IENVUlJFTlRfU0MtPlNDcC5idWZmZXItPmxlbmd0aDsKCQkJCX0gCiAgICAgICAgICAgICAgICAJfQoJCX0gZWxzZSBpZihmaWZvZGF0YT4wKSB7IAoJCQlwcmludGsoRVJSX0xFQUQgIm5vIGJ1ZmZlcnMgbGVmdCBmb3IgJWQoJWQpIGJ5dGVzIChkYXRhIG92ZXJydW4hPylcbiIsIENNRElORk8oQ1VSUkVOVF9TQyksIGZpZm9kYXRhLCBHRVRQT1JUKEZJRk9TVEFUKSk7CiAgICAgICAgICAgICAgICAgICAgICAgIFNFVFBPUlQoRE1BQ05UUkwwLCBFTkRNQXxfOEJJVCk7CgkJCXdoaWxlKGZpZm9kYXRhPjApIHsKCQkJCWludCBkYXRhOwoJCQkJZGF0YT1HRVRQT1JUKERBVEFQT1JUKTsKCQkJCURQUklOVEsoZGVidWdfZGF0YWksIERFQlVHX0xFQUQgImRhdGE9JTAyeFxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSwgZGF0YSk7CgkJCQlmaWZvZGF0YS0tOwoJCQkJREFUQV9MRU4rKzsKCQkJfQogICAgICAgICAgICAgICAgICAgICAgICBTRVRQT1JUKERNQUNOVFJMMCwgRU5ETUF8XzhCSVQpOwoJCX0KCX0KCglpZihURVNUTE8oRE1BU1RBVCwgSU5UU1RBVCkgfHwKCSAgIFRFU1RMTyhETUFTVEFULCBERklGT0VNUCkgfHwKCSAgIFRFU1RMTyhTU1RBVDIsIFNFTVBUWSkgfHwKCSAgIEdFVFBPUlQoRklGT1NUQVQpPjApIHsKCSAgIAkvKgoJCSAqIHNvbWV0aGluZyB3ZW50IHdyb25nLCBpZiB0aGVyZSdzIHNvbWV0aGluZyBsZWZ0IGluIHRoZSBmaWZvcwoJCSAqIG9yIHRoZSBwaGFzZSBkaWRuJ3QgY2hhbmdlCgkJICovCgkJcHJpbnRrKEVSUl9MRUFEICJmaWZvcyBzaG91bGQgYmUgZW1wdHkgYW5kIHBoYXNlIHNob3VsZCBoYXZlIGNoYW5nZWRcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCWRpc3BfcG9ydHMoc2hwbnQpOwoJfQoKCWlmKERBVEFfTEVOIT1HRVRTVENOVCgpKSB7CgkJcHJpbnRrKEVSUl9MRUFECgkJICAgICAgICJtYW51YWwgdHJhbnNmZXIgY291bnQgZGlmZmVycyBmcm9tIGF1dG9tYXRpYyAoY291bnQ9JWQ7c3RjbnQ9JWQ7ZGlmZj0lZDtmaWZvc3RhdD0lZCkiLAoJCSAgICAgICBDTURJTkZPKENVUlJFTlRfU0MpLCBEQVRBX0xFTiwgR0VUU1RDTlQoKSwgR0VUU1RDTlQoKS1EQVRBX0xFTiwgR0VUUE9SVChGSUZPU1RBVCkpOwoJCWRpc3BfcG9ydHMoc2hwbnQpOwoJCW1kZWxheSgxMDAwMCk7Cgl9Cn0KCnN0YXRpYyB2b2lkIGRhdGFpX2VuZChzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCkKewoJQ1VSUkVOVF9TQy0+cmVzaWQgLT0gR0VUU1RDTlQoKTsKCglEUFJJTlRLKGRlYnVnX2RhdGFpLAoJCURFQlVHX0xFQUQgImRhdGFpX2VuZDogcmVxdWVzdF9idWZmbGVuPSVkIHJlc2lkPSVkIHN0Y250PSVkXG4iLAoJCUNNRElORk8oQ1VSUkVOVF9TQyksIENVUlJFTlRfU0MtPnJlcXVlc3RfYnVmZmxlbiwgQ1VSUkVOVF9TQy0+cmVzaWQsIEdFVFNUQ05UKCkpOwoKCVNFVFBPUlQoU1hGUkNUTDAsIENIMXxDTFJTVENOVCk7CglTRVRQT1JUKERNQUNOVFJMMCwgMCk7Cn0KCi8qCiAqIGRhdGEgb3V0IHBoYXNlCiAqCiAqLwpzdGF0aWMgdm9pZCBkYXRhb19pbml0KHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglTRVRQT1JUKERNQUNOVFJMMCwgV1JJVEVfUkVBRCB8IFJTVEZJRk8pOwoJU0VUUE9SVChETUFDTlRSTDAsIFdSSVRFX1JFQUQgfCBFTkRNQSk7CgoJU0VUUE9SVChTWEZSQ1RMMCwgQ0gxfENMUlNUQ05UKTsKCVNFVFBPUlQoU1hGUkNUTDAsIENIMXxTQ1NJRU58RE1BRU4pOwoKCVNFVFBPUlQoU0lNT0RFMCwgMCk7CglTRVRQT1JUKFNJTU9ERTEsIEVOU0NTSVBFUlIgfCBFTlNDU0lSU1QgfCBFTlBIQVNFTUlTIHwgRU5CVVNGUkVFICk7CgoJREFUQV9MRU4gPSBDVVJSRU5UX1NDLT5yZXNpZDsKCglEUFJJTlRLKGRlYnVnX2RhdGFvLAoJCURFQlVHX0xFQUQgImRhdGFvX2luaXQ6IHJlcXVlc3RfYnVmZmxlbj0lZDsgcmVzaWQ9JWRcbiIsCgkJQ01ESU5GTyhDVVJSRU5UX1NDKSwgQ1VSUkVOVF9TQy0+cmVxdWVzdF9idWZmbGVuLCBDVVJSRU5UX1NDLT5yZXNpZCk7Cn0KCnN0YXRpYyB2b2lkIGRhdGFvX3J1bihzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCkKewoJdW5zaWduZWQgbG9uZyB0aGVfdGltZTsKCWludCBkYXRhX2NvdW50OwoKCS8qIHVudGlsIHBoYXNlIGNoYW5nZXMgb3IgYWxsIGRhdGEgc2VudCAqLwoJd2hpbGUoVEVTVExPKERNQVNUQVQsIElOVFNUQVQpICYmIENVUlJFTlRfU0MtPlNDcC50aGlzX3Jlc2lkdWFsPjApIHsKCQlkYXRhX2NvdW50ID0gMTI4OwoJCWlmKGRhdGFfY291bnQgPiBDVVJSRU5UX1NDLT5TQ3AudGhpc19yZXNpZHVhbCkKCQkJZGF0YV9jb3VudD1DVVJSRU5UX1NDLT5TQ3AudGhpc19yZXNpZHVhbDsKCgkJaWYoVEVTVExPKERNQVNUQVQsIERGSUZPRU1QKSkgewoJCQlwcmludGsoRVJSX0xFQUQgImRhdGFvIGZpZm8gbm90IGVtcHR5ICglZCkiLCBDTURJTkZPKENVUlJFTlRfU0MpLCBHRVRQT1JUKEZJRk9TVEFUKSk7CgkJCWRpc3BfcG9ydHMoc2hwbnQpOwoJCQlicmVhazsKCQl9CgoJCWlmKGRhdGFfY291bnQgJiAxKSB7CgkJCVNFVFBPUlQoRE1BQ05UUkwwLFdSSVRFX1JFQUR8RU5ETUF8XzhCSVQpOwoJCQlTRVRQT1JUKERBVEFQT1JULCAqQ1VSUkVOVF9TQy0+U0NwLnB0cisrKTsKCQkJQ1VSUkVOVF9TQy0+U0NwLnRoaXNfcmVzaWR1YWwtLTsKCQkJQ1VSUkVOVF9TQy0+cmVzaWQtLTsKCQkJU0VUUE9SVChETUFDTlRSTDAsV1JJVEVfUkVBRHxFTkRNQSk7CgkJfQoKCQlpZihkYXRhX2NvdW50ID4gMSkgewoJCQlkYXRhX2NvdW50ID4+PSAxOwoJCQlvdXRzdyhEQVRBUE9SVCwgQ1VSUkVOVF9TQy0+U0NwLnB0ciwgZGF0YV9jb3VudCk7CgkJCUNVUlJFTlRfU0MtPlNDcC5wdHIgICAgICAgICAgICs9IDIgKiBkYXRhX2NvdW50OwoJCQlDVVJSRU5UX1NDLT5TQ3AudGhpc19yZXNpZHVhbCAtPSAyICogZGF0YV9jb3VudDsKCQkJQ1VSUkVOVF9TQy0+cmVzaWQgICAgICAgICAgICAgLT0gMiAqIGRhdGFfY291bnQ7CgkgIAl9CgoJCWlmKENVUlJFTlRfU0MtPlNDcC50aGlzX3Jlc2lkdWFsPT0wICYmIENVUlJFTlRfU0MtPlNDcC5idWZmZXJzX3Jlc2lkdWFsPjApIHsKCQkJLyogYWR2YW5jZSB0byBuZXh0IGJ1ZmZlciAqLwoJCQlDVVJSRU5UX1NDLT5TQ3AuYnVmZmVyc19yZXNpZHVhbC0tOwoJCQlDVVJSRU5UX1NDLT5TQ3AuYnVmZmVyKys7CgkJCUNVUlJFTlRfU0MtPlNDcC5wdHIgICAgICAgICAgID0gU0dfQUREUkVTUyhDVVJSRU5UX1NDLT5TQ3AuYnVmZmVyKTsKCQkJQ1VSUkVOVF9TQy0+U0NwLnRoaXNfcmVzaWR1YWwgPSBDVVJSRU5UX1NDLT5TQ3AuYnVmZmVyLT5sZW5ndGg7CgkJfQoKCQl0aGVfdGltZT1qaWZmaWVzICsgMTAwKkhaOwoJCXdoaWxlKFRFU1RMTyhETUFTVEFULCBERklGT0VNUHxJTlRTVEFUKSAmJiB0aW1lX2JlZm9yZShqaWZmaWVzLHRoZV90aW1lKSkKCQkJYmFycmllcigpOwoKCQlpZihURVNUTE8oRE1BU1RBVCwgREZJRk9FTVB8SU5UU1RBVCkpIHsKCQkJcHJpbnRrKEVSUl9MRUFEICJkYXRhb3V0IHRpbWVvdXQiLCBDTURJTkZPKENVUlJFTlRfU0MpKTsKCQkJZGlzcF9wb3J0cyhzaHBudCk7CgkJCWJyZWFrOwoJCX0KCX0KfQoKc3RhdGljIHZvaWQgZGF0YW9fZW5kKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglpZihURVNUTE8oRE1BU1RBVCwgREZJRk9FTVApKSB7CgkJaW50IGRhdGFfY291bnQgPSAoREFUQV9MRU4gLSBDVVJSRU5UX1NDLT5yZXNpZCkgLSBHRVRTVENOVCgpOwoKCQlEUFJJTlRLKGRlYnVnX2RhdGFvLCBERUJVR19MRUFEICJkYXRhbzogJWQgYnl0ZXMgdG8gcmVzZW5kICglZCB3cml0dGVuLCAlZCB0cmFuc2ZlcnJlZClcbiIsCgkJCUNNRElORk8oQ1VSUkVOVF9TQyksCgkJCWRhdGFfY291bnQsCgkJCURBVEFfTEVOLUNVUlJFTlRfU0MtPnJlc2lkLAoJCQlHRVRTVENOVCgpKTsKCgkJQ1VSUkVOVF9TQy0+cmVzaWQgKz0gZGF0YV9jb3VudDsKCgkJaWYoQ1VSUkVOVF9TQy0+dXNlX3NnKSB7CgkJCWRhdGFfY291bnQgLT0gQ1VSUkVOVF9TQy0+U0NwLnB0ciAtIFNHX0FERFJFU1MoQ1VSUkVOVF9TQy0+U0NwLmJ1ZmZlcik7CgkJCXdoaWxlKGRhdGFfY291bnQ+MCkgewoJCQkJQ1VSUkVOVF9TQy0+U0NwLmJ1ZmZlci0tOwoJCQkJQ1VSUkVOVF9TQy0+U0NwLmJ1ZmZlcnNfcmVzaWR1YWwrKzsKCQkJCWRhdGFfY291bnQgLT0gQ1VSUkVOVF9TQy0+U0NwLmJ1ZmZlci0+bGVuZ3RoOwoJCQl9CgkJCUNVUlJFTlRfU0MtPlNDcC5wdHIgICAgICAgICAgID0gU0dfQUREUkVTUyhDVVJSRU5UX1NDLT5TQ3AuYnVmZmVyKSAtIGRhdGFfY291bnQ7CgkJCUNVUlJFTlRfU0MtPlNDcC50aGlzX3Jlc2lkdWFsID0gQ1VSUkVOVF9TQy0+U0NwLmJ1ZmZlci0+bGVuZ3RoICsgZGF0YV9jb3VudDsKCQl9IGVsc2UgewoJCQlDVVJSRU5UX1NDLT5TQ3AucHRyICAgICAgICAgICAtPSBkYXRhX2NvdW50OwoJCQlDVVJSRU5UX1NDLT5TQ3AudGhpc19yZXNpZHVhbCArPSBkYXRhX2NvdW50OwoJCX0KCX0KCglEUFJJTlRLKGRlYnVnX2RhdGFvLCBERUJVR19MRUFEICJkYXRhb19lbmQ6IHJlcXVlc3RfYnVmZmxlbj0lZDsgcmVzaWQ9JWQ7IHN0Y250PSVkXG4iLAoJCUNNRElORk8oQ1VSUkVOVF9TQyksCgkJQ1VSUkVOVF9TQy0+cmVxdWVzdF9idWZmbGVuLAoJCUNVUlJFTlRfU0MtPnJlc2lkLAoJCUdFVFNUQ05UKCkpOwoKCVNFVFBPUlQoU1hGUkNUTDAsIENIMXxDTFJDSDF8Q0xSU1RDTlQpOwoJU0VUUE9SVChTWEZSQ1RMMCwgQ0gxKTsKCglTRVRQT1JUKERNQUNOVFJMMCwgMCk7Cn0KCi8qCiAqIGZpZ3VyZSBvdXQgd2hhdCBzdGF0ZSB3ZSdyZSBpbgogKgogKi8Kc3RhdGljIGludCB1cGRhdGVfc3RhdGUoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCWludCBkYXRhcGhhc2U9MDsKCXVuc2lnbmVkIGludCBzdGF0MCA9IEdFVFBPUlQoU1NUQVQwKTsKCXVuc2lnbmVkIGludCBzdGF0MSA9IEdFVFBPUlQoU1NUQVQxKTsKCglQUkVWU1RBVEUgPSBTVEFURTsKCVNUQVRFPXVua25vd247CgoJaWYoc3RhdDEgJiBTQ1NJUlNUSSkgewoJCVNUQVRFPXJzdGk7CgkJU0VUUE9SVChTQ1NJU0VRLDApOwoJCVNFVFBPUlQoU1NUQVQxLFNDU0lSU1RJKTsKICAJfSBlbHNlIGlmKHN0YXQwICYgU0VMREkgJiYgUFJFVlNUQVRFPT1idXNmcmVlKSB7CgkJU1RBVEU9c2VsZGk7Cgl9IGVsc2UgaWYoc3RhdDAgJiBTRUxETyAmJiBDVVJSRU5UX1NDICYmIChDVVJSRU5UX1NDLT5TQ3AucGhhc2UgJiBzZWxlY3RpbmcpKSB7CgkJU1RBVEU9c2VsZG87Cgl9IGVsc2UgaWYoc3RhdDEgJiBTRUxUTykgewoJCVNUQVRFPXNlbHRvOwoJfSBlbHNlIGlmKHN0YXQxICYgQlVTRlJFRSkgewoJCVNUQVRFPWJ1c2ZyZWU7CgkJU0VUUE9SVChTU1RBVDEsQlVTRlJFRSk7Cgl9IGVsc2UgaWYoc3RhdDEgJiBTQ1NJUEVSUikgewoJCVNUQVRFPXBhcmVycjsKCQlTRVRQT1JUKFNTVEFUMSxTQ1NJUEVSUik7Cgl9IGVsc2UgaWYoc3RhdDEgJiBSRVFJTklUKSB7CgkJc3dpdGNoKEdFVFBPUlQoU0NTSVNJRykgJiBQX01BU0spIHsKCQljYXNlIFBfTVNHSToJU1RBVEU9bXNnaTsJYnJlYWs7CgkJY2FzZSBQX01TR086CVNUQVRFPW1zZ287CWJyZWFrOwoJCWNhc2UgUF9EQVRBTzoJU1RBVEU9ZGF0YW87CWJyZWFrOwoJCWNhc2UgUF9EQVRBSToJU1RBVEU9ZGF0YWk7CWJyZWFrOwoJCWNhc2UgUF9TVEFUVVM6CVNUQVRFPXN0YXR1czsJYnJlYWs7CgkJY2FzZSBQX0NNRDoJU1RBVEU9Y21kOwlicmVhazsKCQl9CgkJZGF0YXBoYXNlPTE7Cgl9CgoJaWYoKHN0YXQwICYgU0VMREkpICYmIFNUQVRFIT1zZWxkaSAmJiAhZGF0YXBoYXNlKSB7CgkJcHJpbnRrKElORk9fTEVBRCAicmVzZWxlY3Rpb24gbWlzc2VkPyIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJCWRpc3BfcG9ydHMoc2hwbnQpOwoJfQoKCWlmKFNUQVRFIT1QUkVWU1RBVEUpIHsKCQlMQVNUU1RBVEU9UFJFVlNUQVRFOwoJfQoKCXJldHVybiBkYXRhcGhhc2U7Cn0KCi8qCiAqIGhhbmRsZSBwYXJpdHkgZXJyb3IKICoKICogRklYTUU6IGluIHdoaWNoIHBoYXNlPwogKgogKi8Kc3RhdGljIHZvaWQgcGFyZXJyX3J1bihzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCkKewoJcHJpbnRrKEVSUl9MRUFEICJwYXJpdHkgZXJyb3JcbiIsIENNRElORk8oQ1VSUkVOVF9TQykpOwoJZG9uZShzaHBudCwgRElEX1BBUklUWSA8PCAxNik7Cn0KCi8qCiAqIGhhbmRsZSByZXNldCBpbgogKgogKi8Kc3RhdGljIHZvaWQgcnN0aV9ydW4oc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCVNjc2lfQ21uZCAqcHRyOwoKCXByaW50ayhLRVJOX05PVElDRSAiYWhhMTUyeCVkOiBzY3NpIHJlc2V0IGluXG4iLCBIT1NUTk8pOwoJCglwdHI9RElTQ09OTkVDVEVEX1NDOwoJd2hpbGUocHRyKSB7CgkJU2NzaV9DbW5kICpuZXh0ID0gU0NORVhUKHB0cik7CgoJCWlmICghcHRyLT5kZXZpY2UtPnNvZnRfcmVzZXQpIHsKCQkJcmVtb3ZlX1NDKCZESVNDT05ORUNURURfU0MsIHB0cik7CgoJCQlrZnJlZShwdHItPmhvc3Rfc2NyaWJibGUpOwoJCQlwdHItPmhvc3Rfc2NyaWJibGU9TlVMTDsKCgkJCXB0ci0+cmVzdWx0ID0gIERJRF9SRVNFVCA8PCAxNjsKCQkJcHRyLT5zY3NpX2RvbmUocHRyKTsKCQl9CgoJCXB0ciA9IG5leHQ7Cgl9CgoJaWYoQ1VSUkVOVF9TQyAmJiAhQ1VSUkVOVF9TQy0+ZGV2aWNlLT5zb2Z0X3Jlc2V0KQoJCWRvbmUoc2hwbnQsIERJRF9SRVNFVCA8PCAxNiApOwp9CgoKLyoKICogYm90dG9tLWhhbGYgaGFuZGxlcgogKgogKi8Kc3RhdGljIHZvaWQgaXNfY29tcGxldGUoc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCWludCBkYXRhcGhhc2U7Cgl1bnNpZ25lZCBsb25nIGZsYWdzOwoJaW50IHBlbmRpbmc7CgoJRE9fTE9DSyhmbGFncyk7CglpZihIT1NUREFUQShzaHBudCktPmluX2ludHIpIHsKCQlET19VTkxPQ0soZmxhZ3MpOwoJCS8qIGFoYTE1MnhfZXJyb3IgbmV2ZXIgcmV0dXJucy4uICovCgkJYWhhMTUyeF9lcnJvcihzaHBudCwgImJvdHRvbS1oYWxmIGFscmVhZHkgcnVubmluZyE/Iik7Cgl9CglIT1NUREFUQShzaHBudCktPmluX2ludHIrKzsKCgkvKgoJICogbG9vcCB3aGlsZSB0aGVyZSBhcmUgaW50ZXJydXB0IGNvbmRpdGlvbnMgcGVuZGluZwoJICoKCSAqLwoJZG8gewoJCXVuc2lnbmVkIGxvbmcgc3RhcnQgPSBqaWZmaWVzOwoJCURPX1VOTE9DSyhmbGFncyk7CgoJCWRhdGFwaGFzZT11cGRhdGVfc3RhdGUoc2hwbnQpOwoKCQlEUFJJTlRLKGRlYnVnX3BoYXNlcywgTEVBRCAic3RhcnQgJXMgJXMoJXMpXG4iLCBDTURJTkZPKENVUlJFTlRfU0MpLCBzdGF0ZXNbU1RBVEVdLm5hbWUsIHN0YXRlc1tQUkVWU1RBVEVdLm5hbWUsIHN0YXRlc1tMQVNUU1RBVEVdLm5hbWUpOwoKCQkvKgoJCSAqIGVuZCBwcmV2aW91cyBzdGF0ZQoJCSAqCgkJICovCgkJaWYoUFJFVlNUQVRFIT1TVEFURSAmJiBzdGF0ZXNbUFJFVlNUQVRFXS5lbmQpCgkJCXN0YXRlc1tQUkVWU1RBVEVdLmVuZChzaHBudCk7CgoJCS8qCgkJICogZGlzYWJsZSBTUElPIG1vZGUgaWYgcHJldmlvdXMgcGhhc2UgdXNlZCBpdAoJCSAqIGFuZCB0aGlzIG9uZSBkb2Vzbid0CgkJICoKCQkgKi8KCQlpZihzdGF0ZXNbUFJFVlNUQVRFXS5zcGlvICYmICFzdGF0ZXNbU1RBVEVdLnNwaW8pIHsKCQkJU0VUUE9SVChTWEZSQ1RMMCwgQ0gxKTsKCQkJU0VUUE9SVChETUFDTlRSTDAsIDApOwoJCQlpZihDVVJSRU5UX1NDKQoJCQkJQ1VSUkVOVF9TQy0+U0NwLnBoYXNlICY9IH5zcGlvcmR5OwoJCX0KCgkJLyoKCQkgKiBhY2NlcHQgY3VycmVudCBkYXRhcGhhc2UgcGhhc2UKCQkgKgoJCSAqLwoJCWlmKGRhdGFwaGFzZSkgewoJCQlTRVRQT1JUKFNTVEFUMCwgUkVRSU5JVCk7CgkJCVNFVFBPUlQoU0NTSVNJRywgR0VUUE9SVChTQ1NJU0lHKSAmIFBfTUFTSyk7CgkJCVNFVFBPUlQoU1NUQVQxLCBQSEFTRUNIRyk7ICAKCQl9CgkJCgkJLyoKCQkgKiBlbmFibGUgU1BJTyBtb2RlIGlmIHByZXZpb3VzIGRpZG4ndCB1c2UgaXQKCQkgKiBhbmQgdGhpcyBvbmUgZG9lcwoJCSAqCgkJICovCgkJaWYoIXN0YXRlc1tQUkVWU1RBVEVdLnNwaW8gJiYgc3RhdGVzW1NUQVRFXS5zcGlvKSB7CgkJCVNFVFBPUlQoRE1BQ05UUkwwLCAwKTsKCQkJU0VUUE9SVChTWEZSQ1RMMCwgQ0gxfFNQSU9FTik7CgkJCWlmKENVUlJFTlRfU0MpCgkJCQlDVVJSRU5UX1NDLT5TQ3AucGhhc2UgfD0gc3Bpb3JkeTsKCQl9CgkJCgkJLyoKCQkgKiBpbml0aWFsaXplIGZvciBuZXcgc3RhdGUKCQkgKgoJCSAqLwoJCWlmKFBSRVZTVEFURSE9U1RBVEUgJiYgc3RhdGVzW1NUQVRFXS5pbml0KQoJCQlzdGF0ZXNbU1RBVEVdLmluaXQoc2hwbnQpOwoJCQoJCS8qCgkJICogaGFuZGxlIGN1cnJlbnQgc3RhdGUKCQkgKgoJCSAqLwoJCWlmKHN0YXRlc1tTVEFURV0ucnVuKQoJCQlzdGF0ZXNbU1RBVEVdLnJ1bihzaHBudCk7CgkJZWxzZQoJCQlwcmludGsoRVJSX0xFQUQgInVuZXhwZWN0ZWQgc3RhdGUgKCV4KVxuIiwgQ01ESU5GTyhDVVJSRU5UX1NDKSwgU1RBVEUpOwoJCQoJCS8qCgkJICogc2V0dXAgY29udHJvbGxlciB0byBpbnRlcnJ1cHQgb24KCQkgKiB0aGUgbmV4dCBleHBlY3RlZCBjb25kaXRpb24gYW5kCgkJICogbG9vcCBpZiBpdCdzIGFscmVhZHkgdGhlcmUKCQkgKgoJCSAqLwoJCURPX0xPQ0soZmxhZ3MpOwoJCXBlbmRpbmc9c2V0dXBfZXhwZWN0ZWRfaW50ZXJydXB0cyhzaHBudCk7CiNpZiBkZWZpbmVkKEFIQTE1MlhfU1RBVCkKCQlIT1NUREFUQShzaHBudCktPmNvdW50W1NUQVRFXSsrOwoJCWlmKFBSRVZTVEFURSE9U1RBVEUpCgkJCUhPU1REQVRBKHNocG50KS0+Y291bnRfdHJhbnNbU1RBVEVdKys7CgkJSE9TVERBVEEoc2hwbnQpLT50aW1lW1NUQVRFXSArPSBqaWZmaWVzLXN0YXJ0OwojZW5kaWYKCgkJRFBSSU5USyhkZWJ1Z19waGFzZXMsIExFQUQgImVuZCAlcyAlcyglcylcbiIsIENNRElORk8oQ1VSUkVOVF9TQyksIHN0YXRlc1tTVEFURV0ubmFtZSwgc3RhdGVzW1BSRVZTVEFURV0ubmFtZSwgc3RhdGVzW0xBU1RTVEFURV0ubmFtZSk7Cgl9IHdoaWxlKHBlbmRpbmcpOwoKCS8qCgkgKiBlbmFibGUgaW50ZXJydXB0cyBhbmQgbGVhdmUgYm90dG9tLWhhbGYKCSAqCgkgKi8KCUhPU1REQVRBKHNocG50KS0+aW5faW50ci0tOwoJU0VUQklUUyhETUFDTlRSTDAsIElOVEVOKTsKCURPX1VOTE9DSyhmbGFncyk7Cn0KCgovKiAKICogRHVtcCB0aGUgY3VycmVudCBkcml2ZXIgc3RhdHVzIGFuZCBwYW5pYwogKi8Kc3RhdGljIHZvaWQgYWhhMTUyeF9lcnJvcihzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCwgY2hhciAqbXNnKQp7CglwcmludGsoS0VSTl9FTUVSRyAiXG5haGExNTJ4JWQ6ICVzXG4iLCBIT1NUTk8sIG1zZyk7CglzaG93X3F1ZXVlcyhzaHBudCk7CglwYW5pYygiYWhhMTUyeCBwYW5pY1xuIik7Cn0KCi8qCiAqIERpc3BsYXkgcmVnaXN0ZXJzIG9mIEFJQy02MjYwCiAqLwpzdGF0aWMgdm9pZCBkaXNwX3BvcnRzKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCglpbnQgczsKCglwcmludGsoIlxuJXM6ICVzKCVzKSAiLAoJCUNVUlJFTlRfU0MgPyAiYnVzeSIgOiAid2FpdGluZyIsCgkJc3RhdGVzW1NUQVRFXS5uYW1lLAoJCXN0YXRlc1tQUkVWU1RBVEVdLm5hbWUpOwoKCXMgPSBHRVRQT1JUKFNDU0lTRVEpOwoJcHJpbnRrKCJTQ1NJU0VRKCAiKTsKCWlmIChzICYgVEVNT0RFTykKCQlwcmludGsoIlRBUkdFVCBNT0RFICIpOwoJaWYgKHMgJiBFTlNFTE8pCgkJcHJpbnRrKCJTRUxPICIpOwoJaWYgKHMgJiBFTlNFTEkpCgkJcHJpbnRrKCJTRUxJICIpOwoJaWYgKHMgJiBFTlJFU0VMSSkKCQlwcmludGsoIlJFU0VMSSAiKTsKCWlmIChzICYgRU5BVVRPQVROTykKCQlwcmludGsoIkFVVE9BVE5PICIpOwoJaWYgKHMgJiBFTkFVVE9BVE5JKQoJCXByaW50aygiQVVUT0FUTkkgIik7CglpZiAocyAmIEVOQVVUT0FUTlApCgkJcHJpbnRrKCJBVVRPQVROUCAiKTsKCWlmIChzICYgU0NTSVJTVE8pCgkJcHJpbnRrKCJTQ1NJUlNUTyAiKTsKCXByaW50aygiKTsiKTsKCglwcmludGsoIiBTQ1NJU0lHKCIpOwoJcyA9IEdFVFBPUlQoU0NTSVNJRyk7Cglzd2l0Y2ggKHMgJiBQX01BU0spIHsKCWNhc2UgUF9EQVRBTzoKCQlwcmludGsoIkRBVEEgT1VUIik7CgkJYnJlYWs7CgljYXNlIFBfREFUQUk6CgkJcHJpbnRrKCJEQVRBIElOIik7CgkJYnJlYWs7CgljYXNlIFBfQ01EOgoJCXByaW50aygiQ09NTUFORCIpOwoJCWJyZWFrOwoJY2FzZSBQX1NUQVRVUzoKCQlwcmludGsoIlNUQVRVUyIpOwoJCWJyZWFrOwoJY2FzZSBQX01TR086CgkJcHJpbnRrKCJNRVNTQUdFIE9VVCIpOwoJCWJyZWFrOwoJY2FzZSBQX01TR0k6CgkJcHJpbnRrKCJNRVNTQUdFIElOIik7CgkJYnJlYWs7CglkZWZhdWx0OgoJCXByaW50aygiKmludmFsaWQqIik7CgkJYnJlYWs7Cgl9CgoJcHJpbnRrKCIpOyAiKTsKCglwcmludGsoIklOVFNUQVQgKCVzKTsgIiwgVEVTVEhJKERNQVNUQVQsIElOVFNUQVQpID8gImhpIiA6ICJsbyIpOwoKCXByaW50aygiU1NUQVQoICIpOwoJcyA9IEdFVFBPUlQoU1NUQVQwKTsKCWlmIChzICYgVEFSR0VUKQoJCXByaW50aygiVEFSR0VUICIpOwoJaWYgKHMgJiBTRUxETykKCQlwcmludGsoIlNFTERPICIpOwoJaWYgKHMgJiBTRUxESSkKCQlwcmludGsoIlNFTERJICIpOwoJaWYgKHMgJiBTRUxJTkdPKQoJCXByaW50aygiU0VMSU5HTyAiKTsKCWlmIChzICYgU1dSQVApCgkJcHJpbnRrKCJTV1JBUCAiKTsKCWlmIChzICYgU0RPTkUpCgkJcHJpbnRrKCJTRE9ORSAiKTsKCWlmIChzICYgU1BJT1JEWSkKCQlwcmludGsoIlNQSU9SRFkgIik7CglpZiAocyAmIERNQURPTkUpCgkJcHJpbnRrKCJETUFET05FICIpOwoKCXMgPSBHRVRQT1JUKFNTVEFUMSk7CglpZiAocyAmIFNFTFRPKQoJCXByaW50aygiU0VMVE8gIik7CglpZiAocyAmIEFUTlRBUkcpCgkJcHJpbnRrKCJBVE5UQVJHICIpOwoJaWYgKHMgJiBTQ1NJUlNUSSkKCQlwcmludGsoIlNDU0lSU1RJICIpOwoJaWYgKHMgJiBQSEFTRU1JUykKCQlwcmludGsoIlBIQVNFTUlTICIpOwoJaWYgKHMgJiBCVVNGUkVFKQoJCXByaW50aygiQlVTRlJFRSAiKTsKCWlmIChzICYgU0NTSVBFUlIpCgkJcHJpbnRrKCJTQ1NJUEVSUiAiKTsKCWlmIChzICYgUEhBU0VDSEcpCgkJcHJpbnRrKCJQSEFTRUNIRyAiKTsKCWlmIChzICYgUkVRSU5JVCkKCQlwcmludGsoIlJFUUlOSVQgIik7CglwcmludGsoIik7ICIpOwoKCglwcmludGsoIlNTVEFUKCAiKTsKCglzID0gR0VUUE9SVChTU1RBVDApICYgR0VUUE9SVChTSU1PREUwKTsKCglpZiAocyAmIFRBUkdFVCkKCQlwcmludGsoIlRBUkdFVCAiKTsKCWlmIChzICYgU0VMRE8pCgkJcHJpbnRrKCJTRUxETyAiKTsKCWlmIChzICYgU0VMREkpCgkJcHJpbnRrKCJTRUxESSAiKTsKCWlmIChzICYgU0VMSU5HTykKCQlwcmludGsoIlNFTElOR08gIik7CglpZiAocyAmIFNXUkFQKQoJCXByaW50aygiU1dSQVAgIik7CglpZiAocyAmIFNET05FKQoJCXByaW50aygiU0RPTkUgIik7CglpZiAocyAmIFNQSU9SRFkpCgkJcHJpbnRrKCJTUElPUkRZICIpOwoJaWYgKHMgJiBETUFET05FKQoJCXByaW50aygiRE1BRE9ORSAiKTsKCglzID0gR0VUUE9SVChTU1RBVDEpICYgR0VUUE9SVChTSU1PREUxKTsKCglpZiAocyAmIFNFTFRPKQoJCXByaW50aygiU0VMVE8gIik7CglpZiAocyAmIEFUTlRBUkcpCgkJcHJpbnRrKCJBVE5UQVJHICIpOwoJaWYgKHMgJiBTQ1NJUlNUSSkKCQlwcmludGsoIlNDU0lSU1RJICIpOwoJaWYgKHMgJiBQSEFTRU1JUykKCQlwcmludGsoIlBIQVNFTUlTICIpOwoJaWYgKHMgJiBCVVNGUkVFKQoJCXByaW50aygiQlVTRlJFRSAiKTsKCWlmIChzICYgU0NTSVBFUlIpCgkJcHJpbnRrKCJTQ1NJUEVSUiAiKTsKCWlmIChzICYgUEhBU0VDSEcpCgkJcHJpbnRrKCJQSEFTRUNIRyAiKTsKCWlmIChzICYgUkVRSU5JVCkKCQlwcmludGsoIlJFUUlOSVQgIik7CglwcmludGsoIik7ICIpOwoKCXByaW50aygiU1hGUkNUTDAoICIpOwoKCXMgPSBHRVRQT1JUKFNYRlJDVEwwKTsKCWlmIChzICYgU0NTSUVOKQoJCXByaW50aygiU0NTSUVOICIpOwoJaWYgKHMgJiBETUFFTikKCQlwcmludGsoIkRNQUVOICIpOwoJaWYgKHMgJiBDSDEpCgkJcHJpbnRrKCJDSDEgIik7CglpZiAocyAmIENMUlNUQ05UKQoJCXByaW50aygiQ0xSU1RDTlQgIik7CglpZiAocyAmIFNQSU9FTikKCQlwcmludGsoIlNQSU9FTiAiKTsKCWlmIChzICYgQ0xSQ0gxKQoJCXByaW50aygiQ0xSQ0gxICIpOwoJcHJpbnRrKCIpOyAiKTsKCglwcmludGsoIlNJR05BTCggIik7CgoJcyA9IEdFVFBPUlQoU0NTSVNJRyk7CglpZiAocyAmIFNJR19BVE5JKQoJCXByaW50aygiQVROSSAiKTsKCWlmIChzICYgU0lHX1NFTEkpCgkJcHJpbnRrKCJTRUxJICIpOwoJaWYgKHMgJiBTSUdfQlNZSSkKCQlwcmludGsoIkJTWUkgIik7CglpZiAocyAmIFNJR19SRVFJKQoJCXByaW50aygiUkVRSSAiKTsKCWlmIChzICYgU0lHX0FDS0kpCgkJcHJpbnRrKCJBQ0tJICIpOwoJcHJpbnRrKCIpOyAiKTsKCglwcmludGsoIlNFTElEICglMDJ4KSwgIiwgR0VUUE9SVChTRUxJRCkpOwoKCXByaW50aygiU1RDTlQgKCVkKSwgIiwgR0VUU1RDTlQoKSk7CgkKCXByaW50aygiU1NUQVQyKCAiKTsKCglzID0gR0VUUE9SVChTU1RBVDIpOwoJaWYgKHMgJiBTT0ZGU0VUKQoJCXByaW50aygiU09GRlNFVCAiKTsKCWlmIChzICYgU0VNUFRZKQoJCXByaW50aygiU0VNUFRZICIpOwoJaWYgKHMgJiBTRlVMTCkKCQlwcmludGsoIlNGVUxMICIpOwoJcHJpbnRrKCIpOyBTRkNOVCAoJWQpOyAiLCBzICYgKFNGVUxMIHwgU0ZDTlQpKTsKCglzID0gR0VUUE9SVChTU1RBVDMpOwoJcHJpbnRrKCJTQ1NJQ05UICglZCksIE9GRkNOVCglZCksICIsIChzICYgMHhmMCkgPj4gNCwgcyAmIDB4MGYpOwoKCXByaW50aygiU1NUQVQ0KCAiKTsKCXMgPSBHRVRQT1JUKFNTVEFUNCk7CglpZiAocyAmIFNZTkNFUlIpCgkJcHJpbnRrKCJTWU5DRVJSICIpOwoJaWYgKHMgJiBGV0VSUikKCQlwcmludGsoIkZXRVJSICIpOwoJaWYgKHMgJiBGUkVSUikKCQlwcmludGsoIkZSRVJSICIpOwoJcHJpbnRrKCIpOyAiKTsKCglwcmludGsoIkRNQUNOVFJMMCggIik7CglzID0gR0VUUE9SVChETUFDTlRSTDApOwoJcHJpbnRrKCIlcyAiLCBzICYgXzhCSVQgPyAiOEJJVCIgOiAiMTZCSVQiKTsKCXByaW50aygiJXMgIiwgcyAmIERNQSA/ICJETUEiIDogIlBJTyIpOwoJcHJpbnRrKCIlcyAiLCBzICYgV1JJVEVfUkVBRCA/ICJXUklURSIgOiAiUkVBRCIpOwoJaWYgKHMgJiBFTkRNQSkKCQlwcmludGsoIkVORE1BICIpOwoJaWYgKHMgJiBJTlRFTikKCQlwcmludGsoIklOVEVOICIpOwoJaWYgKHMgJiBSU1RGSUZPKQoJCXByaW50aygiUlNURklGTyAiKTsKCWlmIChzICYgU1dJTlQpCgkJcHJpbnRrKCJTV0lOVCAiKTsKCXByaW50aygiKTsgIik7CgoJcHJpbnRrKCJETUFTVEFUKCAiKTsKCXMgPSBHRVRQT1JUKERNQVNUQVQpOwoJaWYgKHMgJiBBVERPTkUpCgkJcHJpbnRrKCJBVERPTkUgIik7CglpZiAocyAmIFdPUkRSRFkpCgkJcHJpbnRrKCJXT1JEUkRZICIpOwoJaWYgKHMgJiBERklGT0ZVTEwpCgkJcHJpbnRrKCJERklGT0ZVTEwgIik7CglpZiAocyAmIERGSUZPRU1QKQoJCXByaW50aygiREZJRk9FTVAgIik7CglwcmludGsoIilcbiIpOwojZW5kaWYKfQoKLyoKICogZGlzcGxheSBlbmFibGVkIGludGVycnVwdHMKICovCnN0YXRpYyB2b2lkIGRpc3BfZW5pbnRyKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglpbnQgczsKCglwcmludGsoS0VSTl9ERUJVRyAiZW5hYmxlZCBpbnRlcnJ1cHRzICggIik7CgoJcyA9IEdFVFBPUlQoU0lNT0RFMCk7CglpZiAocyAmIEVOU0VMRE8pCgkJcHJpbnRrKCJFTlNFTERPICIpOwoJaWYgKHMgJiBFTlNFTERJKQoJCXByaW50aygiRU5TRUxESSAiKTsKCWlmIChzICYgRU5TRUxJTkdPKQoJCXByaW50aygiRU5TRUxJTkdPICIpOwoJaWYgKHMgJiBFTlNXUkFQKQoJCXByaW50aygiRU5TV1JBUCAiKTsKCWlmIChzICYgRU5TRE9ORSkKCQlwcmludGsoIkVOU0RPTkUgIik7CglpZiAocyAmIEVOU1BJT1JEWSkKCQlwcmludGsoIkVOU1BJT1JEWSAiKTsKCWlmIChzICYgRU5ETUFET05FKQoJCXByaW50aygiRU5ETUFET05FICIpOwoKCXMgPSBHRVRQT1JUKFNJTU9ERTEpOwoJaWYgKHMgJiBFTlNFTFRJTU8pCgkJcHJpbnRrKCJFTlNFTFRJTU8gIik7CglpZiAocyAmIEVOQVROVEFSRykKCQlwcmludGsoIkVOQVROVEFSRyAiKTsKCWlmIChzICYgRU5QSEFTRU1JUykKCQlwcmludGsoIkVOUEhBU0VNSVMgIik7CglpZiAocyAmIEVOQlVTRlJFRSkKCQlwcmludGsoIkVOQlVTRlJFRSAiKTsKCWlmIChzICYgRU5TQ1NJUEVSUikKCQlwcmludGsoIkVOU0NTSVBFUlIgIik7CglpZiAocyAmIEVOUEhBU0VDSEcpCgkJcHJpbnRrKCJFTlBIQVNFQ0hHICIpOwoJaWYgKHMgJiBFTlJFUUlOSVQpCgkJcHJpbnRrKCJFTlJFUUlOSVQgIik7CglwcmludGsoIilcbiIpOwp9CgovKgogKiBTaG93IHRoZSBjb21tYW5kIGRhdGEgb2YgYSBjb21tYW5kCiAqLwpzdGF0aWMgdm9pZCBzaG93X2NvbW1hbmQoU2NzaV9DbW5kICpwdHIpCnsKCXNjbWRfcHJpbnRrKEtFUk5fREVCVUcsIHB0ciwgIiVwOiBjbW5kPSgiLCBwdHIpOwoKCV9fc2NzaV9wcmludF9jb21tYW5kKHB0ci0+Y21uZCk7CgoJcHJpbnRrKEtFUk5fREVCVUcgIik7IHJlcXVlc3RfYnVmZmxlbj0lZDsgcmVzaWQ9JWQ7IHBoYXNlIHwiLAoJICAgICAgIHB0ci0+cmVxdWVzdF9idWZmbGVuLCBwdHItPnJlc2lkKTsKCglpZiAocHRyLT5TQ3AucGhhc2UgJiBub3RfaXNzdWVkKQoJCXByaW50aygibm90IGlzc3VlZHwiKTsKCWlmIChwdHItPlNDcC5waGFzZSAmIHNlbGVjdGluZykKCQlwcmludGsoInNlbGVjdGluZ3wiKTsKCWlmIChwdHItPlNDcC5waGFzZSAmIGlkZW50aWZpZWQpCgkJcHJpbnRrKCJpZGVudGlmaWVkfCIpOwoJaWYgKHB0ci0+U0NwLnBoYXNlICYgZGlzY29ubmVjdGVkKQoJCXByaW50aygiZGlzY29ubmVjdGVkfCIpOwoJaWYgKHB0ci0+U0NwLnBoYXNlICYgY29tcGxldGVkKQoJCXByaW50aygiY29tcGxldGVkfCIpOwoJaWYgKHB0ci0+U0NwLnBoYXNlICYgc3Bpb3JkeSkKCQlwcmludGsoInNwaW9yZHl8Iik7CglpZiAocHRyLT5TQ3AucGhhc2UgJiBzeW5jbmVnKQoJCXByaW50aygic3luY25lZ3wiKTsKCWlmIChwdHItPlNDcC5waGFzZSAmIGFib3J0ZWQpCgkJcHJpbnRrKCJhYm9ydGVkfCIpOwoJaWYgKHB0ci0+U0NwLnBoYXNlICYgcmVzZXR0ZWQpCgkJcHJpbnRrKCJyZXNldHRlZHwiKTsKCWlmKCBTQ0RBVEEocHRyKSApIHsKCQlwcmludGsoIjsgbmV4dD0weCVwXG4iLCBTQ05FWFQocHRyKSk7Cgl9IGVsc2UgewoJCXByaW50aygiOyBuZXh0PShob3N0IHNjcmliYmxlIE5VTEwpXG4iKTsKCX0KfQoKLyoKICogRHVtcCB0aGUgcXVldWVkIGRhdGEKICovCnN0YXRpYyB2b2lkIHNob3dfcXVldWVzKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50KQp7CglTY3NpX0NtbmQgKnB0cjsKCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CgoJRE9fTE9DSyhmbGFncyk7CglwcmludGsoS0VSTl9ERUJVRyAiXG5xdWV1ZSBzdGF0dXM6XG5pc3N1ZV9TQzpcbiIpOwoJZm9yIChwdHIgPSBJU1NVRV9TQzsgcHRyOyBwdHIgPSBTQ05FWFQocHRyKSkKCQlzaG93X2NvbW1hbmQocHRyKTsKCURPX1VOTE9DSyhmbGFncyk7CgoJcHJpbnRrKEtFUk5fREVCVUcgImN1cnJlbnRfU0M6XG4iKTsKCWlmIChDVVJSRU5UX1NDKQoJCXNob3dfY29tbWFuZChDVVJSRU5UX1NDKTsKCWVsc2UKCQlwcmludGsoS0VSTl9ERUJVRyAibm9uZVxuIik7CgoJcHJpbnRrKEtFUk5fREVCVUcgImRpc2Nvbm5lY3RlZF9TQzpcbiIpOwoJZm9yIChwdHIgPSBESVNDT05ORUNURURfU0M7IHB0cjsgcHRyID0gU0NEQVRBKHB0cikgPyBTQ05FWFQocHRyKSA6IE5VTEwpCgkJc2hvd19jb21tYW5kKHB0cik7CgoJZGlzcF9wb3J0cyhzaHBudCk7CglkaXNwX2VuaW50cihzaHBudCk7Cn0KCiN1bmRlZiBTUFJJTlRGCiNkZWZpbmUgU1BSSU5URihhcmdzLi4uKSBwb3MgKz0gc3ByaW50Zihwb3MsICMjIGFyZ3MpCgpzdGF0aWMgaW50IGdldF9jb21tYW5kKGNoYXIgKnBvcywgU2NzaV9DbW5kICogcHRyKQp7CgljaGFyICpzdGFydCA9IHBvczsKCWludCBpOwoKCVNQUklOVEYoIjB4JTA4eDogdGFyZ2V0PSVkOyBsdW49JWQ7IGNtbmQ9KCAiLAoJCSh1bnNpZ25lZCBpbnQpIHB0ciwgcHRyLT5kZXZpY2UtPmlkLCBwdHItPmRldmljZS0+bHVuKTsKCglmb3IgKGkgPSAwOyBpIDwgQ09NTUFORF9TSVpFKHB0ci0+Y21uZFswXSk7IGkrKykKCQlTUFJJTlRGKCIweCUwMnggIiwgcHRyLT5jbW5kW2ldKTsKCglTUFJJTlRGKCIpOyByZXNpZD0lZDsgcmVzaWR1YWw9JWQ7IGJ1ZmZlcnM9JWQ7IHBoYXNlIHwiLAoJCXB0ci0+cmVzaWQsIHB0ci0+U0NwLnRoaXNfcmVzaWR1YWwsIHB0ci0+U0NwLmJ1ZmZlcnNfcmVzaWR1YWwpOwoKCWlmIChwdHItPlNDcC5waGFzZSAmIG5vdF9pc3N1ZWQpCgkJU1BSSU5URigibm90IGlzc3VlZHwiKTsKCWlmIChwdHItPlNDcC5waGFzZSAmIHNlbGVjdGluZykKCQlTUFJJTlRGKCJzZWxlY3Rpbmd8Iik7CglpZiAocHRyLT5TQ3AucGhhc2UgJiBkaXNjb25uZWN0ZWQpCgkJU1BSSU5URigiZGlzY29ubmVjdGVkfCIpOwoJaWYgKHB0ci0+U0NwLnBoYXNlICYgYWJvcnRlZCkKCQlTUFJJTlRGKCJhYm9ydGVkfCIpOwoJaWYgKHB0ci0+U0NwLnBoYXNlICYgaWRlbnRpZmllZCkKCQlTUFJJTlRGKCJpZGVudGlmaWVkfCIpOwoJaWYgKHB0ci0+U0NwLnBoYXNlICYgY29tcGxldGVkKQoJCVNQUklOVEYoImNvbXBsZXRlZHwiKTsKCWlmIChwdHItPlNDcC5waGFzZSAmIHNwaW9yZHkpCgkJU1BSSU5URigic3Bpb3JkeXwiKTsKCWlmIChwdHItPlNDcC5waGFzZSAmIHN5bmNuZWcpCgkJU1BSSU5URigic3luY25lZ3wiKTsKCVNQUklOVEYoIjsgbmV4dD0weCVwXG4iLCBTQ05FWFQocHRyKSk7CgoJcmV0dXJuIChwb3MgLSBzdGFydCk7Cn0KCnN0YXRpYyBpbnQgZ2V0X3BvcnRzKHN0cnVjdCBTY3NpX0hvc3QgKnNocG50LCBjaGFyICpwb3MpCnsKCWNoYXIgKnN0YXJ0ID0gcG9zOwoJaW50IHM7CgoJU1BSSU5URigiXG4lczogJXMoJXMpICIsIENVUlJFTlRfU0MgPyAib24gYnVzIiA6ICJ3YWl0aW5nIiwgc3RhdGVzW1NUQVRFXS5uYW1lLCBzdGF0ZXNbUFJFVlNUQVRFXS5uYW1lKTsKCglzID0gR0VUUE9SVChTQ1NJU0VRKTsKCVNQUklOVEYoIlNDU0lTRVEoICIpOwoJaWYgKHMgJiBURU1PREVPKQoJCVNQUklOVEYoIlRBUkdFVCBNT0RFICIpOwoJaWYgKHMgJiBFTlNFTE8pCgkJU1BSSU5URigiU0VMTyAiKTsKCWlmIChzICYgRU5TRUxJKQoJCVNQUklOVEYoIlNFTEkgIik7CglpZiAocyAmIEVOUkVTRUxJKQoJCVNQUklOVEYoIlJFU0VMSSAiKTsKCWlmIChzICYgRU5BVVRPQVROTykKCQlTUFJJTlRGKCJBVVRPQVROTyAiKTsKCWlmIChzICYgRU5BVVRPQVROSSkKCQlTUFJJTlRGKCJBVVRPQVROSSAiKTsKCWlmIChzICYgRU5BVVRPQVROUCkKCQlTUFJJTlRGKCJBVVRPQVROUCAiKTsKCWlmIChzICYgU0NTSVJTVE8pCgkJU1BSSU5URigiU0NTSVJTVE8gIik7CglTUFJJTlRGKCIpOyIpOwoKCVNQUklOVEYoIiBTQ1NJU0lHKCIpOwoJcyA9IEdFVFBPUlQoU0NTSVNJRyk7Cglzd2l0Y2ggKHMgJiBQX01BU0spIHsKCWNhc2UgUF9EQVRBTzoKCQlTUFJJTlRGKCJEQVRBIE9VVCIpOwoJCWJyZWFrOwoJY2FzZSBQX0RBVEFJOgoJCVNQUklOVEYoIkRBVEEgSU4iKTsKCQlicmVhazsKCWNhc2UgUF9DTUQ6CgkJU1BSSU5URigiQ09NTUFORCIpOwoJCWJyZWFrOwoJY2FzZSBQX1NUQVRVUzoKCQlTUFJJTlRGKCJTVEFUVVMiKTsKCQlicmVhazsKCWNhc2UgUF9NU0dPOgoJCVNQUklOVEYoIk1FU1NBR0UgT1VUIik7CgkJYnJlYWs7CgljYXNlIFBfTVNHSToKCQlTUFJJTlRGKCJNRVNTQUdFIElOIik7CgkJYnJlYWs7CglkZWZhdWx0OgoJCVNQUklOVEYoIippbnZhbGlkKiIpOwoJCWJyZWFrOwoJfQoKCVNQUklOVEYoIik7ICIpOwoKCVNQUklOVEYoIklOVFNUQVQgKCVzKTsgIiwgVEVTVEhJKERNQVNUQVQsIElOVFNUQVQpID8gImhpIiA6ICJsbyIpOwoKCVNQUklOVEYoIlNTVEFUKCAiKTsKCXMgPSBHRVRQT1JUKFNTVEFUMCk7CglpZiAocyAmIFRBUkdFVCkKCQlTUFJJTlRGKCJUQVJHRVQgIik7CglpZiAocyAmIFNFTERPKQoJCVNQUklOVEYoIlNFTERPICIpOwoJaWYgKHMgJiBTRUxESSkKCQlTUFJJTlRGKCJTRUxESSAiKTsKCWlmIChzICYgU0VMSU5HTykKCQlTUFJJTlRGKCJTRUxJTkdPICIpOwoJaWYgKHMgJiBTV1JBUCkKCQlTUFJJTlRGKCJTV1JBUCAiKTsKCWlmIChzICYgU0RPTkUpCgkJU1BSSU5URigiU0RPTkUgIik7CglpZiAocyAmIFNQSU9SRFkpCgkJU1BSSU5URigiU1BJT1JEWSAiKTsKCWlmIChzICYgRE1BRE9ORSkKCQlTUFJJTlRGKCJETUFET05FICIpOwoKCXMgPSBHRVRQT1JUKFNTVEFUMSk7CglpZiAocyAmIFNFTFRPKQoJCVNQUklOVEYoIlNFTFRPICIpOwoJaWYgKHMgJiBBVE5UQVJHKQoJCVNQUklOVEYoIkFUTlRBUkcgIik7CglpZiAocyAmIFNDU0lSU1RJKQoJCVNQUklOVEYoIlNDU0lSU1RJICIpOwoJaWYgKHMgJiBQSEFTRU1JUykKCQlTUFJJTlRGKCJQSEFTRU1JUyAiKTsKCWlmIChzICYgQlVTRlJFRSkKCQlTUFJJTlRGKCJCVVNGUkVFICIpOwoJaWYgKHMgJiBTQ1NJUEVSUikKCQlTUFJJTlRGKCJTQ1NJUEVSUiAiKTsKCWlmIChzICYgUEhBU0VDSEcpCgkJU1BSSU5URigiUEhBU0VDSEcgIik7CglpZiAocyAmIFJFUUlOSVQpCgkJU1BSSU5URigiUkVRSU5JVCAiKTsKCVNQUklOVEYoIik7ICIpOwoKCglTUFJJTlRGKCJTU1RBVCggIik7CgoJcyA9IEdFVFBPUlQoU1NUQVQwKSAmIEdFVFBPUlQoU0lNT0RFMCk7CgoJaWYgKHMgJiBUQVJHRVQpCgkJU1BSSU5URigiVEFSR0VUICIpOwoJaWYgKHMgJiBTRUxETykKCQlTUFJJTlRGKCJTRUxETyAiKTsKCWlmIChzICYgU0VMREkpCgkJU1BSSU5URigiU0VMREkgIik7CglpZiAocyAmIFNFTElOR08pCgkJU1BSSU5URigiU0VMSU5HTyAiKTsKCWlmIChzICYgU1dSQVApCgkJU1BSSU5URigiU1dSQVAgIik7CglpZiAocyAmIFNET05FKQoJCVNQUklOVEYoIlNET05FICIpOwoJaWYgKHMgJiBTUElPUkRZKQoJCVNQUklOVEYoIlNQSU9SRFkgIik7CglpZiAocyAmIERNQURPTkUpCgkJU1BSSU5URigiRE1BRE9ORSAiKTsKCglzID0gR0VUUE9SVChTU1RBVDEpICYgR0VUUE9SVChTSU1PREUxKTsKCglpZiAocyAmIFNFTFRPKQoJCVNQUklOVEYoIlNFTFRPICIpOwoJaWYgKHMgJiBBVE5UQVJHKQoJCVNQUklOVEYoIkFUTlRBUkcgIik7CglpZiAocyAmIFNDU0lSU1RJKQoJCVNQUklOVEYoIlNDU0lSU1RJICIpOwoJaWYgKHMgJiBQSEFTRU1JUykKCQlTUFJJTlRGKCJQSEFTRU1JUyAiKTsKCWlmIChzICYgQlVTRlJFRSkKCQlTUFJJTlRGKCJCVVNGUkVFICIpOwoJaWYgKHMgJiBTQ1NJUEVSUikKCQlTUFJJTlRGKCJTQ1NJUEVSUiAiKTsKCWlmIChzICYgUEhBU0VDSEcpCgkJU1BSSU5URigiUEhBU0VDSEcgIik7CglpZiAocyAmIFJFUUlOSVQpCgkJU1BSSU5URigiUkVRSU5JVCAiKTsKCVNQUklOVEYoIik7ICIpOwoKCVNQUklOVEYoIlNYRlJDVEwwKCAiKTsKCglzID0gR0VUUE9SVChTWEZSQ1RMMCk7CglpZiAocyAmIFNDU0lFTikKCQlTUFJJTlRGKCJTQ1NJRU4gIik7CglpZiAocyAmIERNQUVOKQoJCVNQUklOVEYoIkRNQUVOICIpOwoJaWYgKHMgJiBDSDEpCgkJU1BSSU5URigiQ0gxICIpOwoJaWYgKHMgJiBDTFJTVENOVCkKCQlTUFJJTlRGKCJDTFJTVENOVCAiKTsKCWlmIChzICYgU1BJT0VOKQoJCVNQUklOVEYoIlNQSU9FTiAiKTsKCWlmIChzICYgQ0xSQ0gxKQoJCVNQUklOVEYoIkNMUkNIMSAiKTsKCVNQUklOVEYoIik7ICIpOwoKCVNQUklOVEYoIlNJR05BTCggIik7CgoJcyA9IEdFVFBPUlQoU0NTSVNJRyk7CglpZiAocyAmIFNJR19BVE5JKQoJCVNQUklOVEYoIkFUTkkgIik7CglpZiAocyAmIFNJR19TRUxJKQoJCVNQUklOVEYoIlNFTEkgIik7CglpZiAocyAmIFNJR19CU1lJKQoJCVNQUklOVEYoIkJTWUkgIik7CglpZiAocyAmIFNJR19SRVFJKQoJCVNQUklOVEYoIlJFUUkgIik7CglpZiAocyAmIFNJR19BQ0tJKQoJCVNQUklOVEYoIkFDS0kgIik7CglTUFJJTlRGKCIpOyAiKTsKCglTUFJJTlRGKCJTRUxJRCglMDJ4KSwgIiwgR0VUUE9SVChTRUxJRCkpOwoKCVNQUklOVEYoIlNUQ05UKCVkKSwgIiwgR0VUU1RDTlQoKSk7CgoJU1BSSU5URigiU1NUQVQyKCAiKTsKCglzID0gR0VUUE9SVChTU1RBVDIpOwoJaWYgKHMgJiBTT0ZGU0VUKQoJCVNQUklOVEYoIlNPRkZTRVQgIik7CglpZiAocyAmIFNFTVBUWSkKCQlTUFJJTlRGKCJTRU1QVFkgIik7CglpZiAocyAmIFNGVUxMKQoJCVNQUklOVEYoIlNGVUxMICIpOwoJU1BSSU5URigiKTsgU0ZDTlQgKCVkKTsgIiwgcyAmIChTRlVMTCB8IFNGQ05UKSk7CgoJcyA9IEdFVFBPUlQoU1NUQVQzKTsKCVNQUklOVEYoIlNDU0lDTlQgKCVkKSwgT0ZGQ05UKCVkKSwgIiwgKHMgJiAweGYwKSA+PiA0LCBzICYgMHgwZik7CgoJU1BSSU5URigiU1NUQVQ0KCAiKTsKCXMgPSBHRVRQT1JUKFNTVEFUNCk7CglpZiAocyAmIFNZTkNFUlIpCgkJU1BSSU5URigiU1lOQ0VSUiAiKTsKCWlmIChzICYgRldFUlIpCgkJU1BSSU5URigiRldFUlIgIik7CglpZiAocyAmIEZSRVJSKQoJCVNQUklOVEYoIkZSRVJSICIpOwoJU1BSSU5URigiKTsgIik7CgoJU1BSSU5URigiRE1BQ05UUkwwKCAiKTsKCXMgPSBHRVRQT1JUKERNQUNOVFJMMCk7CglTUFJJTlRGKCIlcyAiLCBzICYgXzhCSVQgPyAiOEJJVCIgOiAiMTZCSVQiKTsKCVNQUklOVEYoIiVzICIsIHMgJiBETUEgPyAiRE1BIiA6ICJQSU8iKTsKCVNQUklOVEYoIiVzICIsIHMgJiBXUklURV9SRUFEID8gIldSSVRFIiA6ICJSRUFEIik7CglpZiAocyAmIEVORE1BKQoJCVNQUklOVEYoIkVORE1BICIpOwoJaWYgKHMgJiBJTlRFTikKCQlTUFJJTlRGKCJJTlRFTiAiKTsKCWlmIChzICYgUlNURklGTykKCQlTUFJJTlRGKCJSU1RGSUZPICIpOwoJaWYgKHMgJiBTV0lOVCkKCQlTUFJJTlRGKCJTV0lOVCAiKTsKCVNQUklOVEYoIik7ICIpOwoKCVNQUklOVEYoIkRNQVNUQVQoICIpOwoJcyA9IEdFVFBPUlQoRE1BU1RBVCk7CglpZiAocyAmIEFURE9ORSkKCQlTUFJJTlRGKCJBVERPTkUgIik7CglpZiAocyAmIFdPUkRSRFkpCgkJU1BSSU5URigiV09SRFJEWSAiKTsKCWlmIChzICYgREZJRk9GVUxMKQoJCVNQUklOVEYoIkRGSUZPRlVMTCAiKTsKCWlmIChzICYgREZJRk9FTVApCgkJU1BSSU5URigiREZJRk9FTVAgIik7CglTUFJJTlRGKCIpXG4iKTsKCglTUFJJTlRGKCJlbmFibGVkIGludGVycnVwdHMoICIpOwoKCXMgPSBHRVRQT1JUKFNJTU9ERTApOwoJaWYgKHMgJiBFTlNFTERPKQoJCVNQUklOVEYoIkVOU0VMRE8gIik7CglpZiAocyAmIEVOU0VMREkpCgkJU1BSSU5URigiRU5TRUxESSAiKTsKCWlmIChzICYgRU5TRUxJTkdPKQoJCVNQUklOVEYoIkVOU0VMSU5HTyAiKTsKCWlmIChzICYgRU5TV1JBUCkKCQlTUFJJTlRGKCJFTlNXUkFQICIpOwoJaWYgKHMgJiBFTlNET05FKQoJCVNQUklOVEYoIkVOU0RPTkUgIik7CglpZiAocyAmIEVOU1BJT1JEWSkKCQlTUFJJTlRGKCJFTlNQSU9SRFkgIik7CglpZiAocyAmIEVORE1BRE9ORSkKCQlTUFJJTlRGKCJFTkRNQURPTkUgIik7CgoJcyA9IEdFVFBPUlQoU0lNT0RFMSk7CglpZiAocyAmIEVOU0VMVElNTykKCQlTUFJJTlRGKCJFTlNFTFRJTU8gIik7CglpZiAocyAmIEVOQVROVEFSRykKCQlTUFJJTlRGKCJFTkFUTlRBUkcgIik7CglpZiAocyAmIEVOUEhBU0VNSVMpCgkJU1BSSU5URigiRU5QSEFTRU1JUyAiKTsKCWlmIChzICYgRU5CVVNGUkVFKQoJCVNQUklOVEYoIkVOQlVTRlJFRSAiKTsKCWlmIChzICYgRU5TQ1NJUEVSUikKCQlTUFJJTlRGKCJFTlNDU0lQRVJSICIpOwoJaWYgKHMgJiBFTlBIQVNFQ0hHKQoJCVNQUklOVEYoIkVOUEhBU0VDSEcgIik7CglpZiAocyAmIEVOUkVRSU5JVCkKCQlTUFJJTlRGKCJFTlJFUUlOSVQgIik7CglTUFJJTlRGKCIpXG4iKTsKCglyZXR1cm4gKHBvcyAtIHN0YXJ0KTsKfQoKc3RhdGljIGludCBhaGExNTJ4X3NldF9pbmZvKGNoYXIgKmJ1ZmZlciwgaW50IGxlbmd0aCwgc3RydWN0IFNjc2lfSG9zdCAqc2hwbnQpCnsKCWlmKCFzaHBudCB8fCAhYnVmZmVyIHx8IGxlbmd0aDw4IHx8IHN0cm5jbXAoImFoYTE1MnggIiwgYnVmZmVyLCA4KSE9MCkKCQlyZXR1cm4gLUVJTlZBTDsKCiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCglpZihsZW5ndGg+MTQgJiYgc3RybmNtcCgiZGVidWcgIiwgYnVmZmVyKzgsIDYpPT0wKSB7CgkJaW50IGRlYnVnID0gSE9TVERBVEEoc2hwbnQpLT5kZWJ1ZzsKCgkJSE9TVERBVEEoc2hwbnQpLT5kZWJ1ZyA9IHNpbXBsZV9zdHJ0b3VsKGJ1ZmZlcisxNCwgTlVMTCwgMCk7CgoJCXByaW50ayhLRVJOX0lORk8gImFoYTE1MnglZDogZGVidWdnaW5nIG9wdGlvbnMgc2V0IHRvIDB4JTA0eCAod2VyZSAweCUwNHgpXG4iLCBIT1NUTk8sIEhPU1REQVRBKHNocG50KS0+ZGVidWcsIGRlYnVnKTsKCX0gZWxzZQojZW5kaWYKI2lmIGRlZmluZWQoQUhBMTUyWF9TVEFUKQoJaWYobGVuZ3RoPjEzICYmIHN0cm5jbXAoInJlc2V0IiwgYnVmZmVyKzgsIDUpPT0wKSB7CgkJaW50IGk7CgoJCUhPU1REQVRBKHNocG50KS0+dG90YWxfY29tbWFuZHM9MDsKCQlIT1NUREFUQShzaHBudCktPmRpc2Nvbm5lY3Rpb25zPTA7CgkJSE9TVERBVEEoc2hwbnQpLT5idXNmcmVlX3dpdGhvdXRfYW55X2FjdGlvbj0wOwoJCUhPU1REQVRBKHNocG50KS0+YnVzZnJlZV93aXRob3V0X29sZF9jb21tYW5kPTA7CgkJSE9TVERBVEEoc2hwbnQpLT5idXNmcmVlX3dpdGhvdXRfbmV3X2NvbW1hbmQ9MDsKCQlIT1NUREFUQShzaHBudCktPmJ1c2ZyZWVfd2l0aG91dF9kb25lX2NvbW1hbmQ9MDsKCQlIT1NUREFUQShzaHBudCktPmJ1c2ZyZWVfd2l0aF9jaGVja19jb25kaXRpb249MDsKCQlmb3IgKGkgPSBpZGxlOyBpPG1heHN0YXRlOyBpKyspIHsKCQkJSE9TVERBVEEoc2hwbnQpLT5jb3VudFtpXT0wOwoJCQlIT1NUREFUQShzaHBudCktPmNvdW50X3RyYW5zW2ldPTA7CgkJCUhPU1REQVRBKHNocG50KS0+dGltZVtpXT0wOwoJCX0KCgkJcHJpbnRrKEtFUk5fSU5GTyAiYWhhMTUyeCVkOiBzdGF0cyByZXNldGVkLlxuIiwgSE9TVE5PKTsKCgl9IGVsc2UKI2VuZGlmCgl7CgkJcmV0dXJuIC1FSU5WQUw7Cgl9CgoKCXJldHVybiBsZW5ndGg7Cn0KCiN1bmRlZiBTUFJJTlRGCiNkZWZpbmUgU1BSSU5URihhcmdzLi4uKSBcCglkbyB7IGlmKHBvcyA8IGJ1ZmZlciArIGxlbmd0aCkgcG9zICs9IHNwcmludGYocG9zLCAjIyBhcmdzKTsgfSB3aGlsZSgwKQoKc3RhdGljIGludCBhaGExNTJ4X3Byb2NfaW5mbyhzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCwgY2hhciAqYnVmZmVyLCBjaGFyICoqc3RhcnQsCgkJICAgICAgb2ZmX3Qgb2Zmc2V0LCBpbnQgbGVuZ3RoLCBpbnQgaW5vdXQpCnsKCWludCBpOwoJY2hhciAqcG9zID0gYnVmZmVyOwoJU2NzaV9DbW5kICpwdHI7Cgl1bnNpZ25lZCBsb25nIGZsYWdzOwoJaW50IHRoaXNsZW5ndGg7CgoJRFBSSU5USyhkZWJ1Z19wcm9jaW5mbywgCgkgICAgICAgS0VSTl9ERUJVRyAiYWhhMTUyeF9wcm9jX2luZm86IGJ1ZmZlcj0lcCBvZmZzZXQ9JWxkIGxlbmd0aD0lZCBob3N0bm89JWQgaW5vdXQ9JWRcbiIsCgkgICAgICAgYnVmZmVyLCBvZmZzZXQsIGxlbmd0aCwgc2hwbnQtPmhvc3Rfbm8sIGlub3V0KTsKCgoJaWYgKGlub3V0KQoJCXJldHVybiBhaGExNTJ4X3NldF9pbmZvKGJ1ZmZlciwgbGVuZ3RoLCBzaHBudCk7CgoJU1BSSU5URihBSEExNTJYX1JFVklEICJcbiIpOwoKCVNQUklOVEYoImlvcG9ydHMgMHglMDRseCB0byAweCUwNGx4XG4iLAoJCXNocG50LT5pb19wb3J0LCBzaHBudC0+aW9fcG9ydCArIHNocG50LT5uX2lvX3BvcnQgLSAxKTsKCVNQUklOVEYoImludGVycnVwdCAweCUwMnhcbiIsIHNocG50LT5pcnEpOwoJU1BSSU5URigiZGlzY29ubmVjdGlvbi9yZWNvbm5lY3Rpb24gJXNcbiIsCgkJUkVDT05ORUNUID8gImVuYWJsZWQiIDogImRpc2FibGVkIik7CglTUFJJTlRGKCJwYXJpdHkgY2hlY2tpbmcgJXNcbiIsCgkJUEFSSVRZID8gImVuYWJsZWQiIDogImRpc2FibGVkIik7CglTUFJJTlRGKCJzeW5jaHJvbm91cyB0cmFuc2ZlcnMgJXNcbiIsCgkJU1lOQ0hST05PVVMgPyAiZW5hYmxlZCIgOiAiZGlzYWJsZWQiKTsKCVNQUklOVEYoIiVkIGNvbW1hbmRzIGN1cnJlbnRseSBxdWV1ZWRcbiIsIEhPU1REQVRBKHNocG50KS0+Y29tbWFuZHMpOwoKCWlmKFNZTkNIUk9OT1VTKSB7CgkJU1BSSU5URigic3luY2hyb25vdXNseSBvcGVyYXRpbmcgdGFyZ2V0cyAodGljaz01MCBucyk6XG4iKTsKCQlmb3IgKGkgPSAwOyBpIDwgODsgaSsrKQoJCQlpZiAoSE9TVERBVEEoc2hwbnQpLT5zeW5jcmF0ZVtpXSAmIDB4N2YpCgkJCQlTUFJJTlRGKCJ0YXJnZXQgJWQ6IHBlcmlvZCAlZFQvJWRuczsgcmVxL2FjayBvZmZzZXQgJWRcbiIsCgkJCQkJaSwKCQkJCQkoKChIT1NUREFUQShzaHBudCktPnN5bmNyYXRlW2ldICYgMHg3MCkgPj4gNCkgKyAyKSwKCQkJCQkoKChIT1NUREFUQShzaHBudCktPnN5bmNyYXRlW2ldICYgMHg3MCkgPj4gNCkgKyAyKSAqIDUwLAoJCQkJICAgIEhPU1REQVRBKHNocG50KS0+c3luY3JhdGVbaV0gJiAweDBmKTsKCX0KI2lmIGRlZmluZWQoQUhBMTUyWF9ERUJVRykKI2RlZmluZSBQREVCVUcoZmxhZ3MsdHh0KSBcCglpZihIT1NUREFUQShzaHBudCktPmRlYnVnICYgZmxhZ3MpIFNQUklOVEYoIiglcykgIiwgdHh0KTsKCglTUFJJTlRGKCJlbmFibGVkIGRlYnVnZ2luZyBvcHRpb25zOiAiKTsKCglQREVCVUcoZGVidWdfcHJvY2luZm8sICJwcm9jaW5mbyIpOwoJUERFQlVHKGRlYnVnX3F1ZXVlLCAicXVldWUiKTsKCVBERUJVRyhkZWJ1Z19pbnRyLCAiaW50ZXJydXB0Iik7CglQREVCVUcoZGVidWdfc2VsZWN0aW9uLCAic2VsZWN0aW9uIik7CglQREVCVUcoZGVidWdfbXNnbywgIm1lc3NhZ2Ugb3V0Iik7CglQREVCVUcoZGVidWdfbXNnaSwgIm1lc3NhZ2UgaW4iKTsKCVBERUJVRyhkZWJ1Z19zdGF0dXMsICJzdGF0dXMiKTsKCVBERUJVRyhkZWJ1Z19jbWQsICJjb21tYW5kIik7CglQREVCVUcoZGVidWdfZGF0YWksICJkYXRhIGluIik7CglQREVCVUcoZGVidWdfZGF0YW8sICJkYXRhIG91dCIpOwoJUERFQlVHKGRlYnVnX2VoLCAiZWgiKTsKCVBERUJVRyhkZWJ1Z19sb2NrcywgImxvY2tzIik7CglQREVCVUcoZGVidWdfcGhhc2VzLCAicGhhc2VzIik7CgoJU1BSSU5URigiXG4iKTsKI2VuZGlmCgoJU1BSSU5URigiXG5xdWV1ZSBzdGF0dXM6XG4iKTsKCURPX0xPQ0soZmxhZ3MpOwoJaWYgKElTU1VFX1NDKSB7CgkJU1BSSU5URigibm90IHlldCBpc3N1ZWQgY29tbWFuZHM6XG4iKTsKCQlmb3IgKHB0ciA9IElTU1VFX1NDOyBwdHI7IHB0ciA9IFNDTkVYVChwdHIpKQoJCQlwb3MgKz0gZ2V0X2NvbW1hbmQocG9zLCBwdHIpOwoJfSBlbHNlCgkJU1BSSU5URigibm8gbm90IHlldCBpc3N1ZWQgY29tbWFuZHNcbiIpOwoJRE9fVU5MT0NLKGZsYWdzKTsKCglpZiAoQ1VSUkVOVF9TQykgewoJCVNQUklOVEYoImN1cnJlbnQgY29tbWFuZDpcbiIpOwoJCXBvcyArPSBnZXRfY29tbWFuZChwb3MsIENVUlJFTlRfU0MpOwoJfSBlbHNlCgkJU1BSSU5URigibm8gY3VycmVudCBjb21tYW5kXG4iKTsKCglpZiAoRElTQ09OTkVDVEVEX1NDKSB7CgkJU1BSSU5URigiZGlzY29ubmVjdGVkIGNvbW1hbmRzOlxuIik7CgkJZm9yIChwdHIgPSBESVNDT05ORUNURURfU0M7IHB0cjsgcHRyID0gU0NORVhUKHB0cikpCgkJCXBvcyArPSBnZXRfY29tbWFuZChwb3MsIHB0cik7Cgl9IGVsc2UKCQlTUFJJTlRGKCJubyBkaXNjb25uZWN0ZWQgY29tbWFuZHNcbiIpOwoKCXBvcyArPSBnZXRfcG9ydHMoc2hwbnQsIHBvcyk7CgojaWYgZGVmaW5lZChBSEExNTJYX1NUQVQpCglTUFJJTlRGKCJzdGF0aXN0aWNzOlxuIgoJICAgICAgICAidG90YWwgY29tbWFuZHM6ICAgICAgICAgICAgICAgJWRcbiIKCSAgICAgICAgImRpc2Nvbm5lY3Rpb25zOiAgICAgICAgICAgICAgICVkXG4iCgkJImJ1c2ZyZWUgd2l0aCBjaGVjayBjb25kaXRpb246ICVkXG4iCgkJImJ1c2ZyZWUgd2l0aG91dCBvbGQgY29tbWFuZDogICVkXG4iCgkJImJ1c2ZyZWUgd2l0aG91dCBuZXcgY29tbWFuZDogICVkXG4iCgkJImJ1c2ZyZWUgd2l0aG91dCBkb25lIGNvbW1hbmQ6ICVkXG4iCgkJImJ1c2ZyZWUgd2l0aG91dCBhbnkgYWN0aW9uOiAgICVkXG4iCgkJInN0YXRlICAgICAgIgoJCSJ0cmFuc2l0aW9ucyAgIgoJCSJjb3VudCAgICAgICAgIgoJCSJ0aW1lXG4iLAoJCUhPU1REQVRBKHNocG50KS0+dG90YWxfY29tbWFuZHMsCgkJSE9TVERBVEEoc2hwbnQpLT5kaXNjb25uZWN0aW9ucywKCQlIT1NUREFUQShzaHBudCktPmJ1c2ZyZWVfd2l0aF9jaGVja19jb25kaXRpb24sCgkJSE9TVERBVEEoc2hwbnQpLT5idXNmcmVlX3dpdGhvdXRfb2xkX2NvbW1hbmQsCgkJSE9TVERBVEEoc2hwbnQpLT5idXNmcmVlX3dpdGhvdXRfbmV3X2NvbW1hbmQsCgkJSE9TVERBVEEoc2hwbnQpLT5idXNmcmVlX3dpdGhvdXRfZG9uZV9jb21tYW5kLAoJCUhPU1REQVRBKHNocG50KS0+YnVzZnJlZV93aXRob3V0X2FueV9hY3Rpb24pOwoJZm9yKGk9MDsgaTxtYXhzdGF0ZTsgaSsrKSB7CgkJU1BSSU5URigiJS0xMHMgJS0xMmQgJS0xMmQgJS0xMmxkXG4iLAoJCSAgICAgICAgc3RhdGVzW2ldLm5hbWUsCgkJCUhPU1REQVRBKHNocG50KS0+Y291bnRfdHJhbnNbaV0sCgkJCUhPU1REQVRBKHNocG50KS0+Y291bnRbaV0sCgkJCUhPU1REQVRBKHNocG50KS0+dGltZVtpXSk7Cgl9CiNlbmRpZgoKCURQUklOVEsoZGVidWdfcHJvY2luZm8sIEtFUk5fREVCVUcgImFoYTE1MnhfcHJvY19pbmZvOiBwb3M9JXBcbiIsIHBvcyk7CgoJdGhpc2xlbmd0aCA9IHBvcyAtIChidWZmZXIgKyBvZmZzZXQpOwoJRFBSSU5USyhkZWJ1Z19wcm9jaW5mbywgS0VSTl9ERUJVRyAiYWhhMTUyeF9wcm9jX2luZm86IGxlbmd0aD0lZCB0aGlzbGVuZ3RoPSVkXG4iLCBsZW5ndGgsIHRoaXNsZW5ndGgpOwoKCWlmKHRoaXNsZW5ndGg8MCkgewoJCURQUklOVEsoZGVidWdfcHJvY2luZm8sIEtFUk5fREVCVUcgImFoYTE1MnhfcHJvY19pbmZvOiBvdXRwdXQgdG9vIHNob3J0XG4iKTsKCQkqc3RhcnQgPSBOVUxMOwoJCXJldHVybiAwOwoJfQoKCXRoaXNsZW5ndGggPSB0aGlzbGVuZ3RoPGxlbmd0aCA/IHRoaXNsZW5ndGggOiBsZW5ndGg7CgoJRFBSSU5USyhkZWJ1Z19wcm9jaW5mbywgS0VSTl9ERUJVRyAiYWhhMTUyeF9wcm9jX2luZm86IHJldHVybiAlZFxuIiwgdGhpc2xlbmd0aCk7CgoJKnN0YXJ0ID0gYnVmZmVyICsgb2Zmc2V0OwoJcmV0dXJuIHRoaXNsZW5ndGggPCBsZW5ndGggPyB0aGlzbGVuZ3RoIDogbGVuZ3RoOwp9CgpzdGF0aWMgc3RydWN0IHNjc2lfaG9zdF90ZW1wbGF0ZSBhaGExNTJ4X2RyaXZlcl90ZW1wbGF0ZSA9IHsKCS5tb2R1bGUJCQkJPSBUSElTX01PRFVMRSwKCS5uYW1lCQkJCT0gQUhBMTUyWF9SRVZJRCwKCS5wcm9jX25hbWUJCQk9ICJhaGExNTJ4IiwKCS5wcm9jX2luZm8JCQk9IGFoYTE1MnhfcHJvY19pbmZvLAoJLnF1ZXVlY29tbWFuZAkJCT0gYWhhMTUyeF9xdWV1ZSwKCS5laF9hYm9ydF9oYW5kbGVyCQk9IGFoYTE1MnhfYWJvcnQsCgkuZWhfZGV2aWNlX3Jlc2V0X2hhbmRsZXIJPSBhaGExNTJ4X2RldmljZV9yZXNldCwKCS5laF9idXNfcmVzZXRfaGFuZGxlcgkJPSBhaGExNTJ4X2J1c19yZXNldCwKCS5laF9ob3N0X3Jlc2V0X2hhbmRsZXIJCT0gYWhhMTUyeF9ob3N0X3Jlc2V0LAoJLmJpb3NfcGFyYW0JCQk9IGFoYTE1MnhfYmlvc3BhcmFtLAoJLmNhbl9xdWV1ZQkJCT0gMSwKCS50aGlzX2lkCQkJPSA3LAoJLnNnX3RhYmxlc2l6ZQkJCT0gU0dfQUxMLAoJLmNtZF9wZXJfbHVuCQkJPSAxLAoJLnVzZV9jbHVzdGVyaW5nCQkJPSBESVNBQkxFX0NMVVNURVJJTkcsCn07CgojaWYgIWRlZmluZWQoUENNQ0lBKQpzdGF0aWMgaW50IHNldHVwX2NvdW50OwpzdGF0aWMgc3RydWN0IGFoYTE1Mnhfc2V0dXAgc2V0dXBbMl07CgovKiBwb3NzaWJsZSBpL28gYWRkcmVzc2VzIGZvciB0aGUgQUlDLTYyNjA7IGRlZmF1bHQgZmlyc3QgKi8Kc3RhdGljIHVuc2lnbmVkIHNob3J0IHBvcnRzW10gPSB7IDB4MzQwLCAweDE0MCB9OwoKI2lmICFkZWZpbmVkKFNLSVBfQklPU1RFU1QpCi8qIHBvc3NpYmxlIGxvY2F0aW9ucyBmb3IgdGhlIEFkYXB0ZWMgQklPUzsgZGVmYXVsdHMgZmlyc3QgKi8Kc3RhdGljIHVuc2lnbmVkIGludCBhZGRyZXNzZXNbXSA9CnsKCTB4ZGMwMDAsCQkvKiBkZWZhdWx0IGZpcnN0ICovCgkweGM4MDAwLAoJMHhjYzAwMCwKCTB4ZDAwMDAsCgkweGQ0MDAwLAoJMHhkODAwMCwKCTB4ZTAwMDAsCgkweGViODAwLAkJLyogVlRlY2ggUGxhdGludW0gU01QICovCgkweGYwMDAwLAp9OwoKLyogc2lnbmF0dXJlcyBmb3IgdmFyaW91cyBBSUMtNlsyM102MCBiYXNlZCBjb250cm9sbGVycy4KICAgVGhlIHBvaW50IGluIGRldGVjdGluZyBzaWduYXR1cmVzIGlzIHRvIGF2b2lkIHVzZWxlc3MgYW5kIG1heWJlCiAgIGhhcm1mdWwgcHJvYmVzIG9uIHBvcnRzLiBJJ20gbm90IHN1cmUgdGhhdCBhbGwgbGlzdGVkIGJvYXJkcyBwYXNzCiAgIGF1dG8tY29uZmlndXJhdGlvbi4gRm9yIHRob3NlIHdoaWNoIGZhaWwgdGhlIEJJT1Mgc2lnbmF0dXJlIGlzCiAgIG9ic29sZXRlLCBiZWNhdXNlIHVzZXIgaW50ZXJ2ZW50aW9uIHRvIHN1cHBseSB0aGUgY29uZmlndXJhdGlvbiBpcwogICBuZWVkZWQgYW55d2F5LiAgTWF5IGJlIGFuIGluZm9ybWF0aW9uIHdoZXRoZXIgb3Igbm90IHRoZSBCSU9TIHN1cHBvcnRzCiAgIGV4dGVuZGVkIHRyYW5zbGF0aW9uIGNvdWxkIGJlIGFsc28gdXNlZnVsIGhlcmUuICovCnN0YXRpYyBzdHJ1Y3Qgc2lnbmF0dXJlIHsKCXVuc2lnbmVkIGNoYXIgKnNpZ25hdHVyZTsKCWludCBzaWdfb2Zmc2V0OwoJaW50IHNpZ19sZW5ndGg7Cn0gc2lnbmF0dXJlc1tdID0KewoJeyAiQWRhcHRlYyBBSEEtMTUyMCBCSU9TIiwJMHgxMDJlLCAyMSB9LAoJCS8qIEFkYXB0ZWMgMTUyeCAqLwoJeyAiQWRhcHRlYyBBSEEtMTUyMEIiLAkJMHgwMDBiLCAxNyB9LAoJCS8qIEFkYXB0ZWMgMTUyeCByZXYgQiAqLwoJeyAiQWRhcHRlYyBBSEEtMTUyMEIiLAkJMHgwMDI2LCAxNyB9LAoJCS8qIElvbWVnYSBKYXogSmV0IElTQSAoQUlDNjM3MFEpICovCgl7ICJBZGFwdGVjIEFTVy1CNjI2IEJJT1MiLAkweDEwMjksIDIxIH0sCgkJLyogb24tYm9hcmQgY29udHJvbGxlciAqLwoJeyAiQWRhcHRlYyBCSU9TOiBBU1ctQjYyNiIsCTB4MDAwZiwgMjIgfSwKCQkvKiBvbi1ib2FyZCBjb250cm9sbGVyICovCgl7ICJBZGFwdGVjIEFTVy1CNjI2IFMyIiwJMHgyZTZjLCAxOSB9LAoJCS8qIG9uLWJvYXJkIGNvbnRyb2xsZXIgKi8KCXsgIkFkYXB0ZWMgQklPUzpBSUMtNjM2MCIsCTB4MDAwYywgMjEgfSwKCQkvKiBvbi1ib2FyZCBjb250cm9sbGVyICovCgl7ICJTY3NpUHJvIFNQLTM2MCBCSU9TIiwJMHgyODczLCAxOSB9LAoJCS8qIFNjc2lQcm8tQ29udHJvbGxlciAgKi8KCXsgIkdBLTQwMCBMT0NBTCBCVVMgU0NTSSBCSU9TIiwgMHgxMDJlLCAyNiB9LAoJCS8qIEdpZ2FieXRlIExvY2FsLUJ1cy1TQ1NJICovCgl7ICJBZGFwdGVjIEJJT1M6QVZBLTI4MlgiLAkweDAwMGMsIDIxIH0sCgkJLyogQWRhcHRlYyAyODJ4ICovCgl7ICJBZGFwdGVjIElCTSBEb2NrIElJIFNDU0kiLCAgIDB4MmVkZCwgMjQgfSwKCQkvKiBJQk0gVGhpbmtwYWQgRG9jayBJSSAqLwoJeyAiQWRhcHRlYyBCSU9TOkFIQS0xNTMyUCIsICAgICAweDAwMWMsIDIyIH0sCgkJLyogSUJNIFRoaW5rcGFkIERvY2sgSUkgU0NTSSAqLwoJeyAiRFRDMzUyMEEgSG9zdCBBZGFwdGVyIEJJT1MiLCAweDMxOGEsIDI2IH0sCgkJLyogRFRDIDM1MjBBIElTQSBTQ1NJICovCn07CiNlbmRpZiAvKiAhU0tJUF9CSU9TVEVTVCAqLwoKLyoKICogVGVzdCwgaWYgcG9ydF9iYXNlIGlzIHZhbGlkLgogKgogKi8Kc3RhdGljIGludCBhaGExNTJ4X3BvcnR0ZXN0KGludCBpb19wb3J0KQp7CglpbnQgaTsKCglTRVRQT1JUKGlvX3BvcnQgKyBPX0RNQUNOVFJMMSwgMCk7CS8qIHJlc2V0IHN0YWNrIHBvaW50ZXIgKi8KCWZvciAoaSA9IDA7IGkgPCAxNjsgaSsrKQoJCVNFVFBPUlQoaW9fcG9ydCArIE9fU1RBQ0ssIGkpOwoKCVNFVFBPUlQoaW9fcG9ydCArIE9fRE1BQ05UUkwxLCAwKTsJLyogcmVzZXQgc3RhY2sgcG9pbnRlciAqLwoJZm9yIChpID0gMDsgaSA8IDE2ICYmIEdFVFBPUlQoaW9fcG9ydCArIE9fU1RBQ0spID09IGk7IGkrKykKCQk7CgoJcmV0dXJuIChpID09IDE2KTsKfQoKc3RhdGljIGludCB0YzE1NTBfcG9ydHRlc3QoaW50IGlvX3BvcnQpCnsKCWludCBpOwoKCVNFVFBPUlQoaW9fcG9ydCArIE9fVENfRE1BQ05UUkwxLCAwKTsJLyogcmVzZXQgc3RhY2sgcG9pbnRlciAqLwoJZm9yIChpID0gMDsgaSA8IDE2OyBpKyspCgkJU0VUUE9SVChpb19wb3J0ICsgT19TVEFDSywgaSk7CgoJU0VUUE9SVChpb19wb3J0ICsgT19UQ19ETUFDTlRSTDEsIDApOwkvKiByZXNldCBzdGFjayBwb2ludGVyICovCglmb3IgKGkgPSAwOyBpIDwgMTYgJiYgR0VUUE9SVChpb19wb3J0ICsgT19UQ19TVEFDSykgPT0gaTsgaSsrKQoJCTsKCglyZXR1cm4gKGkgPT0gMTYpOwp9CgoKc3RhdGljIGludCBjaGVja3NldHVwKHN0cnVjdCBhaGExNTJ4X3NldHVwICpzZXR1cCkKewoJaW50IGk7Cglmb3IgKGkgPSAwOyBpIDwgQVJSQVlfU0laRShwb3J0cykgJiYgKHNldHVwLT5pb19wb3J0ICE9IHBvcnRzW2ldKTsgaSsrKQoJCTsKCglpZiAoaSA9PSBBUlJBWV9TSVpFKHBvcnRzKSkKCQlyZXR1cm4gMDsKCglpZiAoIHJlcXVlc3RfcmVnaW9uKHNldHVwLT5pb19wb3J0LCBJT19SQU5HRSwgImFoYTE1MngiKT09MCApIHsKCQlwcmludGsoS0VSTl9FUlIgImFoYTE1Mng6IGlvIHBvcnQgMHgleCBidXN5LlxuIiwgc2V0dXAtPmlvX3BvcnQpOwoJCXJldHVybiAwOwoJfQoKCWlmKCBhaGExNTJ4X3BvcnR0ZXN0KHNldHVwLT5pb19wb3J0KSApIHsKCQlzZXR1cC0+dGMxNTUwPTA7Cgl9IGVsc2UgaWYoIHRjMTU1MF9wb3J0dGVzdChzZXR1cC0+aW9fcG9ydCkgKSB7CgkJc2V0dXAtPnRjMTU1MD0xOwoJfSBlbHNlIHsKCQlyZWxlYXNlX3JlZ2lvbihzZXR1cC0+aW9fcG9ydCwgSU9fUkFOR0UpOwoJCXJldHVybiAwOwoJfQoKCXJlbGVhc2VfcmVnaW9uKHNldHVwLT5pb19wb3J0LCBJT19SQU5HRSk7CgoJaWYgKChzZXR1cC0+aXJxIDwgSVJRX01JTikgfHwgKHNldHVwLT5pcnEgPiBJUlFfTUFYKSkKCQlyZXR1cm4gMDsKCglpZiAoKHNldHVwLT5zY3NpaWQgPCAwKSB8fCAoc2V0dXAtPnNjc2lpZCA+IDcpKQoJCXJldHVybiAwOwoKCWlmICgoc2V0dXAtPnJlY29ubmVjdCA8IDApIHx8IChzZXR1cC0+cmVjb25uZWN0ID4gMSkpCgkJcmV0dXJuIDA7CgoJaWYgKChzZXR1cC0+cGFyaXR5IDwgMCkgfHwgKHNldHVwLT5wYXJpdHkgPiAxKSkKCQlyZXR1cm4gMDsKCglpZiAoKHNldHVwLT5zeW5jaHJvbm91cyA8IDApIHx8IChzZXR1cC0+c3luY2hyb25vdXMgPiAxKSkKCQlyZXR1cm4gMDsKCglpZiAoKHNldHVwLT5leHRfdHJhbnMgPCAwKSB8fCAoc2V0dXAtPmV4dF90cmFucyA+IDEpKQoJCXJldHVybiAwOwoKCglyZXR1cm4gMTsKfQoKCnN0YXRpYyBpbnQgX19pbml0IGFoYTE1MnhfaW5pdCh2b2lkKQp7CglpbnQgaSwgaiwgb2s7CiNpZiBkZWZpbmVkKEFVVE9DT05GKQoJYWhhMTUyeF9jb25maWcgY29uZjsKI2VuZGlmCiNpZmRlZiBfX0lTQVBOUF9fCglzdHJ1Y3QgcG5wX2RldiAqZGV2PU5VTEwsICpwbnBkZXZbMl0gPSB7TlVMTCwgTlVMTH07CiNlbmRpZgoKCWlmICggc2V0dXBfY291bnQgKSB7CgkJcHJpbnRrKEtFUk5fSU5GTyAiYWhhMTUyeDogcHJvY2Vzc2luZyBjb21tYW5kbGluZTogIik7CgoJCWZvciAoaSA9IDA7IGk8c2V0dXBfY291bnQ7IGkrKykgewoJCQlpZiAoIWNoZWNrc2V0dXAoJnNldHVwW2ldKSkgewoJCQkJcHJpbnRrKEtFUk5fRVJSICJcbmFoYTE1Mng6ICVzXG4iLCBzZXR1cFtpXS5jb25mKTsKCQkJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeDogaW52YWxpZCBsaW5lXG4iKTsKCQkJfQoJCX0KCQlwcmludGsoIm9rXG4iKTsKCX0KCiNpZiBkZWZpbmVkKFNFVFVQMCkKCWlmIChzZXR1cF9jb3VudCA8IEFSUkFZX1NJWkUoc2V0dXApKSB7CgkJc3RydWN0IGFoYTE1Mnhfc2V0dXAgb3ZlcnJpZGUgPSBTRVRVUDA7CgoJCWlmIChzZXR1cF9jb3VudCA9PSAwIHx8IChvdmVycmlkZS5pb19wb3J0ICE9IHNldHVwWzBdLmlvX3BvcnQpKSB7CgkJCWlmICghY2hlY2tzZXR1cCgmb3ZlcnJpZGUpKSB7CgkJCQlwcmludGsoS0VSTl9FUlIgIlxuYWhhMTUyeDogaW52YWxpZCBvdmVycmlkZSBTRVRVUDA9ezB4JXgsJWQsJWQsJWQsJWQsJWQsJWQsJWR9XG4iLAoJCQkJICAgICAgIG92ZXJyaWRlLmlvX3BvcnQsCgkJCQkgICAgICAgb3ZlcnJpZGUuaXJxLAoJCQkJICAgICAgIG92ZXJyaWRlLnNjc2lpZCwKCQkJCSAgICAgICBvdmVycmlkZS5yZWNvbm5lY3QsCgkJCQkgICAgICAgb3ZlcnJpZGUucGFyaXR5LAoJCQkJICAgICAgIG92ZXJyaWRlLnN5bmNocm9ub3VzLAoJCQkJICAgICAgIG92ZXJyaWRlLmRlbGF5LAoJCQkJICAgICAgIG92ZXJyaWRlLmV4dF90cmFucyk7CgkJCX0gZWxzZQoJCQkJc2V0dXBbc2V0dXBfY291bnQrK10gPSBvdmVycmlkZTsKCQl9Cgl9CiNlbmRpZgoKI2lmIGRlZmluZWQoU0VUVVAxKQoJaWYgKHNldHVwX2NvdW50IDwgQVJSQVlfU0laRShzZXR1cCkpIHsKCQlzdHJ1Y3QgYWhhMTUyeF9zZXR1cCBvdmVycmlkZSA9IFNFVFVQMTsKCgkJaWYgKHNldHVwX2NvdW50ID09IDAgfHwgKG92ZXJyaWRlLmlvX3BvcnQgIT0gc2V0dXBbMF0uaW9fcG9ydCkpIHsKCQkJaWYgKCFjaGVja3NldHVwKCZvdmVycmlkZSkpIHsKCQkJCXByaW50ayhLRVJOX0VSUiAiXG5haGExNTJ4OiBpbnZhbGlkIG92ZXJyaWRlIFNFVFVQMT17MHgleCwlZCwlZCwlZCwlZCwlZCwlZCwlZH1cbiIsCgkJCQkgICAgICAgb3ZlcnJpZGUuaW9fcG9ydCwKCQkJCSAgICAgICBvdmVycmlkZS5pcnEsCgkJCQkgICAgICAgb3ZlcnJpZGUuc2NzaWlkLAoJCQkJICAgICAgIG92ZXJyaWRlLnJlY29ubmVjdCwKCQkJCSAgICAgICBvdmVycmlkZS5wYXJpdHksCgkJCQkgICAgICAgb3ZlcnJpZGUuc3luY2hyb25vdXMsCgkJCQkgICAgICAgb3ZlcnJpZGUuZGVsYXksCgkJCQkgICAgICAgb3ZlcnJpZGUuZXh0X3RyYW5zKTsKCQkJfSBlbHNlCgkJCQlzZXR1cFtzZXR1cF9jb3VudCsrXSA9IG92ZXJyaWRlOwoJCX0KCX0KI2VuZGlmCgojaWYgZGVmaW5lZChNT0RVTEUpCglpZiAoc2V0dXBfY291bnQ8QVJSQVlfU0laRShzZXR1cCkgJiYgKGFoYTE1MnhbMF0hPTAgfHwgaW9bMF0hPTAgfHwgaXJxWzBdIT0wKSkgewoJCWlmKGFoYTE1MnhbMF0hPTApIHsKCQkJc2V0dXBbc2V0dXBfY291bnRdLmNvbmYgICAgICAgID0gIiI7CgkJCXNldHVwW3NldHVwX2NvdW50XS5pb19wb3J0ICAgICA9IGFoYTE1MnhbMF07CgkJCXNldHVwW3NldHVwX2NvdW50XS5pcnEgICAgICAgICA9IGFoYTE1MnhbMV07CgkJCXNldHVwW3NldHVwX2NvdW50XS5zY3NpaWQgICAgICA9IGFoYTE1MnhbMl07CgkJCXNldHVwW3NldHVwX2NvdW50XS5yZWNvbm5lY3QgICA9IGFoYTE1MnhbM107CgkJCXNldHVwW3NldHVwX2NvdW50XS5wYXJpdHkgICAgICA9IGFoYTE1MnhbNF07CgkJCXNldHVwW3NldHVwX2NvdW50XS5zeW5jaHJvbm91cyA9IGFoYTE1MnhbNV07CgkJCXNldHVwW3NldHVwX2NvdW50XS5kZWxheSAgICAgICA9IGFoYTE1MnhbNl07CgkJCXNldHVwW3NldHVwX2NvdW50XS5leHRfdHJhbnMgICA9IGFoYTE1MnhbN107CiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCgkJCXNldHVwW3NldHVwX2NvdW50XS5kZWJ1ZyAgICAgICA9IGFoYTE1MnhbOF07CiNlbmRpZgoJICAJfSBlbHNlIGlmKGlvWzBdIT0wIHx8IGlycVswXSE9MCkgewoJCQlpZihpb1swXSE9MCkgIHNldHVwW3NldHVwX2NvdW50XS5pb19wb3J0ID0gaW9bMF07CgkJCWlmKGlycVswXSE9MCkgc2V0dXBbc2V0dXBfY291bnRdLmlycSAgICAgPSBpcnFbMF07CgoJICAgIAkJc2V0dXBbc2V0dXBfY291bnRdLnNjc2lpZCAgICAgID0gc2NzaWlkWzBdOwoJICAgIAkJc2V0dXBbc2V0dXBfY291bnRdLnJlY29ubmVjdCAgID0gcmVjb25uZWN0WzBdOwoJICAgIAkJc2V0dXBbc2V0dXBfY291bnRdLnBhcml0eSAgICAgID0gcGFyaXR5WzBdOwoJICAgIAkJc2V0dXBbc2V0dXBfY291bnRdLnN5bmNocm9ub3VzID0gc3luY1swXTsKCSAgICAJCXNldHVwW3NldHVwX2NvdW50XS5kZWxheSAgICAgICA9IGRlbGF5WzBdOwoJICAgIAkJc2V0dXBbc2V0dXBfY291bnRdLmV4dF90cmFucyAgID0gZXh0dHJhbnNbMF07CiNpZiBkZWZpbmVkKEFIQTE1MlhfREVCVUcpCgkJCXNldHVwW3NldHVwX2NvdW50XS5kZWJ1ZyAgICAgICA9IGRlYnVnWzBdOwojZW5kaWYKCQl9CgogICAgICAgICAgCWlmIChjaGVja3NldHVwKCZzZXR1cFtzZXR1cF9jb3VudF0pKQoJCQlzZXR1cF9jb3VudCsrOwoJCWVsc2UKCQkJcHJpbnRrKEtFUk5fRVJSICJhaGExNTJ4OiBpbnZhbGlkIG1vZHVsZSBwYXJhbXMgaW89MHgleCwgaXJxPSVkLHNjc2lpZD0lZCxyZWNvbm5lY3Q9JWQscGFyaXR5PSVkLHN5bmM9JWQsZGVsYXk9JWQsZXh0dHJhbnM9JWRcbiIsCgkJCSAgICAgICBzZXR1cFtzZXR1cF9jb3VudF0uaW9fcG9ydCwKCQkJICAgICAgIHNldHVwW3NldHVwX2NvdW50XS5pcnEsCgkJCSAgICAgICBzZXR1cFtzZXR1cF9jb3VudF0uc2NzaWlkLAoJCQkgICAgICAgc2V0dXBbc2V0dXBfY291bnRdLnJlY29ubmVjdCwKCQkJICAgICAgIHNldHVwW3NldHVwX2NvdW50XS5wYXJpdHksCgkJCSAgICAgICBzZXR1cFtzZXR1cF9jb3VudF0uc3luY2hyb25vdXMsCgkJCSAgICAgICBzZXR1cFtzZXR1cF9jb3VudF0uZGVsYXksCgkJCSAgICAgICBzZXR1cFtzZXR1cF9jb3VudF0uZXh0X3RyYW5zKTsKCX0KCglpZiAoc2V0dXBfY291bnQ8QVJSQVlfU0laRShzZXR1cCkgJiYgKGFoYTE1MngxWzBdIT0wIHx8IGlvWzFdIT0wIHx8IGlycVsxXSE9MCkpIHsKCQlpZihhaGExNTJ4MVswXSE9MCkgewoJCQlzZXR1cFtzZXR1cF9jb3VudF0uY29uZiAgICAgICAgPSAiIjsKCQkJc2V0dXBbc2V0dXBfY291bnRdLmlvX3BvcnQgICAgID0gYWhhMTUyeDFbMF07CgkJCXNldHVwW3NldHVwX2NvdW50XS5pcnEgICAgICAgICA9IGFoYTE1MngxWzFdOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uc2NzaWlkICAgICAgPSBhaGExNTJ4MVsyXTsKCQkJc2V0dXBbc2V0dXBfY291bnRdLnJlY29ubmVjdCAgID0gYWhhMTUyeDFbM107CgkJCXNldHVwW3NldHVwX2NvdW50XS5wYXJpdHkgICAgICA9IGFoYTE1MngxWzRdOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uc3luY2hyb25vdXMgPSBhaGExNTJ4MVs1XTsKCQkJc2V0dXBbc2V0dXBfY291bnRdLmRlbGF5ICAgICAgID0gYWhhMTUyeDFbNl07CgkJCXNldHVwW3NldHVwX2NvdW50XS5leHRfdHJhbnMgICA9IGFoYTE1MngxWzddOwojaWYgZGVmaW5lZChBSEExNTJYX0RFQlVHKQoJCQlzZXR1cFtzZXR1cF9jb3VudF0uZGVidWcgICAgICAgPSBhaGExNTJ4MVs4XTsKI2VuZGlmCgkgIAl9IGVsc2UgaWYoaW9bMV0hPTAgfHwgaXJxWzFdIT0wKSB7CgkJCWlmKGlvWzFdIT0wKSAgc2V0dXBbc2V0dXBfY291bnRdLmlvX3BvcnQgPSBpb1sxXTsKCQkJaWYoaXJxWzFdIT0wKSBzZXR1cFtzZXR1cF9jb3VudF0uaXJxICAgICA9IGlycVsxXTsKCgkgICAgCQlzZXR1cFtzZXR1cF9jb3VudF0uc2NzaWlkICAgICAgPSBzY3NpaWRbMV07CgkgICAgCQlzZXR1cFtzZXR1cF9jb3VudF0ucmVjb25uZWN0ICAgPSByZWNvbm5lY3RbMV07CgkgICAgCQlzZXR1cFtzZXR1cF9jb3VudF0ucGFyaXR5ICAgICAgPSBwYXJpdHlbMV07CgkgICAgCQlzZXR1cFtzZXR1cF9jb3VudF0uc3luY2hyb25vdXMgPSBzeW5jWzFdOwoJICAgIAkJc2V0dXBbc2V0dXBfY291bnRdLmRlbGF5ICAgICAgID0gZGVsYXlbMV07CgkgICAgCQlzZXR1cFtzZXR1cF9jb3VudF0uZXh0X3RyYW5zICAgPSBleHR0cmFuc1sxXTsKI2lmIGRlZmluZWQoQUhBMTUyWF9ERUJVRykKCQkJc2V0dXBbc2V0dXBfY291bnRdLmRlYnVnICAgICAgID0gZGVidWdbMV07CiNlbmRpZgoJCX0KCQlpZiAoY2hlY2tzZXR1cCgmc2V0dXBbc2V0dXBfY291bnRdKSkKCQkJc2V0dXBfY291bnQrKzsKCQllbHNlCgkJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeDogaW52YWxpZCBtb2R1bGUgcGFyYW1zIGlvPTB4JXgsIGlycT0lZCxzY3NpaWQ9JWQscmVjb25uZWN0PSVkLHBhcml0eT0lZCxzeW5jPSVkLGRlbGF5PSVkLGV4dHRyYW5zPSVkXG4iLAoJCQkgICAgICAgc2V0dXBbc2V0dXBfY291bnRdLmlvX3BvcnQsCgkJCSAgICAgICBzZXR1cFtzZXR1cF9jb3VudF0uaXJxLAoJCQkgICAgICAgc2V0dXBbc2V0dXBfY291bnRdLnNjc2lpZCwKCQkJICAgICAgIHNldHVwW3NldHVwX2NvdW50XS5yZWNvbm5lY3QsCgkJCSAgICAgICBzZXR1cFtzZXR1cF9jb3VudF0ucGFyaXR5LAoJCQkgICAgICAgc2V0dXBbc2V0dXBfY291bnRdLnN5bmNocm9ub3VzLAoJCQkgICAgICAgc2V0dXBbc2V0dXBfY291bnRdLmRlbGF5LAoJCQkgICAgICAgc2V0dXBbc2V0dXBfY291bnRdLmV4dF90cmFucyk7Cgl9CiNlbmRpZgoKI2lmZGVmIF9fSVNBUE5QX18KCWZvcihpPTA7IHNldHVwX2NvdW50PEFSUkFZX1NJWkUoc2V0dXApICYmIGlkX3RhYmxlW2ldLnZlbmRvcjsgaSsrKSB7CgkJd2hpbGUgKCBzZXR1cF9jb3VudDxBUlJBWV9TSVpFKHNldHVwKSAmJgoJCQkoZGV2PXBucF9maW5kX2RldihOVUxMLCBpZF90YWJsZVtpXS52ZW5kb3IsIGlkX3RhYmxlW2ldLmZ1bmN0aW9uLCBkZXYpKSApIHsKCQkJaWYgKHBucF9kZXZpY2VfYXR0YWNoKGRldikgPCAwKQoJCQkJY29udGludWU7CgoJCQlpZiAocG5wX2FjdGl2YXRlX2RldihkZXYpIDwgMCkgewoJCQkJcG5wX2RldmljZV9kZXRhY2goZGV2KTsKCQkJCWNvbnRpbnVlOwoJCQl9CgoJCQlpZiAoIXBucF9wb3J0X3ZhbGlkKGRldiwgMCkpIHsKCQkJCXBucF9kZXZpY2VfZGV0YWNoKGRldik7CgkJCQljb250aW51ZTsKCQkJfQoKCQkJaWYgKHNldHVwX2NvdW50PT0xICYmIHBucF9wb3J0X3N0YXJ0KGRldiwgMCk9PXNldHVwWzBdLmlvX3BvcnQpIHsKCQkJCXBucF9kZXZpY2VfZGV0YWNoKGRldik7CgkJCQljb250aW51ZTsKCQkJfQoKCQkJc2V0dXBbc2V0dXBfY291bnRdLmlvX3BvcnQgICAgID0gcG5wX3BvcnRfc3RhcnQoZGV2LCAwKTsKCQkJc2V0dXBbc2V0dXBfY291bnRdLmlycSAgICAgICAgID0gcG5wX2lycShkZXYsIDApOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uc2NzaWlkICAgICAgPSA3OwoJCQlzZXR1cFtzZXR1cF9jb3VudF0ucmVjb25uZWN0ICAgPSAxOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0ucGFyaXR5ICAgICAgPSAxOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uc3luY2hyb25vdXMgPSAxOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uZGVsYXkgICAgICAgPSBERUxBWV9ERUZBVUxUOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uZXh0X3RyYW5zICAgPSAwOwojaWYgZGVmaW5lZChBSEExNTJYX0RFQlVHKQoJCQlzZXR1cFtzZXR1cF9jb3VudF0uZGVidWcgICAgICAgPSBERUJVR19ERUZBVUxUOwojZW5kaWYKI2lmIGRlZmluZWQoX19JU0FQTlBfXykKCQkJcG5wZGV2W3NldHVwX2NvdW50XSAgICAgICAgICAgID0gZGV2OwojZW5kaWYKCQkJcHJpbnRrIChLRVJOX0lORk8KCQkJCSJhaGExNTJ4OiBmb3VuZCBJU0FQblAgYWRhcHRlciBhdCBpbz0weCUwM3gsIGlycT0lZFxuIiwKCQkJCXNldHVwW3NldHVwX2NvdW50XS5pb19wb3J0LCBzZXR1cFtzZXR1cF9jb3VudF0uaXJxKTsKCQkJc2V0dXBfY291bnQrKzsKCQl9Cgl9CiNlbmRpZgoKI2lmIGRlZmluZWQoQVVUT0NPTkYpCglpZiAoc2V0dXBfY291bnQ8QVJSQVlfU0laRShzZXR1cCkpIHsKI2lmICFkZWZpbmVkKFNLSVBfQklPU1RFU1QpCgkJb2sgPSAwOwoJCWZvciAoaSA9IDA7IGkgPCBBUlJBWV9TSVpFKGFkZHJlc3NlcykgJiYgIW9rOyBpKyspIHsKCQkJdm9pZCBfX2lvbWVtICpwID0gaW9yZW1hcChhZGRyZXNzZXNbaV0sIDB4NDAwMCk7CgkJCWlmICghcCkKCQkJCWNvbnRpbnVlOwoJCQlmb3IgKGogPSAwOyBqPEFSUkFZX1NJWkUoc2lnbmF0dXJlcykgJiYgIW9rOyBqKyspCgkJCQlvayA9IGNoZWNrX3NpZ25hdHVyZShwICsgc2lnbmF0dXJlc1tqXS5zaWdfb2Zmc2V0LAoJCQkJCQkJCXNpZ25hdHVyZXNbal0uc2lnbmF0dXJlLCBzaWduYXR1cmVzW2pdLnNpZ19sZW5ndGgpOwoJCQlpb3VubWFwKHApOwoJCX0KCQlpZiAoIW9rICYmIHNldHVwX2NvdW50ID09IDApCgkJCXJldHVybiAwOwoKCQlwcmludGsoS0VSTl9JTkZPICJhaGExNTJ4OiBCSU9TIHRlc3Q6IHBhc3NlZCwgIik7CiNlbHNlCgkJcHJpbnRrKEtFUk5fSU5GTyAiYWhhMTUyeDogIik7CiNlbmRpZgkJCQkvKiAhU0tJUF9CSU9TVEVTVCAqLwoKCQlvayA9IDA7CgkJZm9yIChpID0gMDsgaSA8IEFSUkFZX1NJWkUocG9ydHMpICYmIHNldHVwX2NvdW50IDwgMjsgaSsrKSB7CgkJCWlmICgoc2V0dXBfY291bnQgPT0gMSkgJiYgKHNldHVwWzBdLmlvX3BvcnQgPT0gcG9ydHNbaV0pKQoJCQkJY29udGludWU7CgoJCQlpZiAoIHJlcXVlc3RfcmVnaW9uKHBvcnRzW2ldLCBJT19SQU5HRSwgImFoYTE1MngiKT09MCApIHsKCQkJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeDogaW8gcG9ydCAweCV4IGJ1c3kuXG4iLCBwb3J0c1tpXSk7CgkJCQljb250aW51ZTsKCQkJfQoKCQkJaWYgKGFoYTE1MnhfcG9ydHRlc3QocG9ydHNbaV0pKSB7CgkJCQlzZXR1cFtzZXR1cF9jb3VudF0udGMxNTUwICA9IDA7CgoJCQkJY29uZi5jZl9wb3J0ID0KCQkJCSAgICAoR0VUUE9SVChwb3J0c1tpXSArIE9fUE9SVEEpIDw8IDgpICsgR0VUUE9SVChwb3J0c1tpXSArIE9fUE9SVEIpOwoJCQl9IGVsc2UgaWYgKHRjMTU1MF9wb3J0dGVzdChwb3J0c1tpXSkpIHsKCQkJCXNldHVwW3NldHVwX2NvdW50XS50YzE1NTAgID0gMTsKCgkJCQljb25mLmNmX3BvcnQgPQoJCQkJICAgIChHRVRQT1JUKHBvcnRzW2ldICsgT19UQ19QT1JUQSkgPDwgOCkgKyBHRVRQT1JUKHBvcnRzW2ldICsgT19UQ19QT1JUQik7CgkJCX0gZWxzZSB7CgkJCQlyZWxlYXNlX3JlZ2lvbihwb3J0c1tpXSwgSU9fUkFOR0UpOwoJCQkJY29udGludWU7CgkJCX0KCgkJCXJlbGVhc2VfcmVnaW9uKHBvcnRzW2ldLCBJT19SQU5HRSk7CgoJCQlvaysrOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uaW9fcG9ydCA9IHBvcnRzW2ldOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uaXJxID0gSVJRX01JTiArIGNvbmYuY2ZfaXJxOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uc2NzaWlkID0gY29uZi5jZl9pZDsKCQkJc2V0dXBbc2V0dXBfY291bnRdLnJlY29ubmVjdCA9IGNvbmYuY2ZfdGFyZGlzYzsKCQkJc2V0dXBbc2V0dXBfY291bnRdLnBhcml0eSA9ICFjb25mLmNmX3Bhcml0eTsKCQkJc2V0dXBbc2V0dXBfY291bnRdLnN5bmNocm9ub3VzID0gY29uZi5jZl9zeW5jbmVnOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uZGVsYXkgPSBERUxBWV9ERUZBVUxUOwoJCQlzZXR1cFtzZXR1cF9jb3VudF0uZXh0X3RyYW5zID0gMDsKI2lmIGRlZmluZWQoQUhBMTUyWF9ERUJVRykKCQkJc2V0dXBbc2V0dXBfY291bnRdLmRlYnVnID0gREVCVUdfREVGQVVMVDsKI2VuZGlmCgkJCXNldHVwX2NvdW50Kys7CgoJCX0KCgkJaWYgKG9rKQoJCQlwcmludGsoImF1dG8gY29uZmlndXJhdGlvbjogb2ssICIpOwoJfQojZW5kaWYKCglwcmludGsoIiVkIGNvbnRyb2xsZXIocykgY29uZmlndXJlZFxuIiwgc2V0dXBfY291bnQpOwoKCWZvciAoaT0wOyBpPHNldHVwX2NvdW50OyBpKyspIHsKCQlpZiAoIHJlcXVlc3RfcmVnaW9uKHNldHVwW2ldLmlvX3BvcnQsIElPX1JBTkdFLCAiYWhhMTUyeCIpICkgewoJCQlzdHJ1Y3QgU2NzaV9Ib3N0ICpzaHBudCA9IGFoYTE1MnhfcHJvYmVfb25lKCZzZXR1cFtpXSk7CgoJCQlpZiggIXNocG50ICkgewoJCQkJcmVsZWFzZV9yZWdpb24oc2V0dXBbaV0uaW9fcG9ydCwgSU9fUkFOR0UpOwojaWYgZGVmaW5lZChfX0lTQVBOUF9fKQoJCQl9IGVsc2UgaWYoIHBucGRldltpXSApIHsKCQkJCUhPU1REQVRBKHNocG50KS0+cG5wZGV2PXBucGRldltpXTsKCQkJCXBucGRldltpXT1OVUxMOwojZW5kaWYKCQkJfQoJCX0gZWxzZSB7CgkJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeDogaW8gcG9ydCAweCV4IGJ1c3kuXG4iLCBzZXR1cFtpXS5pb19wb3J0KTsKCQl9CgojaWYgZGVmaW5lZChfX0lTQVBOUF9fKQoJCWlmKCBwbnBkZXZbaV0gKQoJCQlwbnBfZGV2aWNlX2RldGFjaChwbnBkZXZbaV0pOwojZW5kaWYKCX0KCglyZXR1cm4gcmVnaXN0ZXJlZF9jb3VudD4wOwp9CgpzdGF0aWMgdm9pZCBfX2V4aXQgYWhhMTUyeF9leGl0KHZvaWQpCnsKCWludCBpOwoKCWZvcihpPTA7IGk8QVJSQVlfU0laRShzZXR1cCk7IGkrKykgewoJCWFoYTE1MnhfcmVsZWFzZShhaGExNTJ4X2hvc3RbaV0pOwoJCWFoYTE1MnhfaG9zdFtpXT1OVUxMOwoJfQp9Cgptb2R1bGVfaW5pdChhaGExNTJ4X2luaXQpOwptb2R1bGVfZXhpdChhaGExNTJ4X2V4aXQpOwoKI2lmICFkZWZpbmVkKE1PRFVMRSkKc3RhdGljIGludCBfX2luaXQgYWhhMTUyeF9zZXR1cChjaGFyICpzdHIpCnsKI2lmIGRlZmluZWQoQUhBMTUyWF9ERUJVRykKCWludCBpbnRzWzExXTsKI2Vsc2UKCWludCBpbnRzWzEwXTsKI2VuZGlmCglnZXRfb3B0aW9ucyhzdHIsIEFSUkFZX1NJWkUoaW50cyksIGludHMpOwoKCWlmKHNldHVwX2NvdW50Pj1BUlJBWV9TSVpFKHNldHVwKSkgewoJCXByaW50ayhLRVJOX0VSUiAiYWhhMTUyeDogeW91IGNhbiBvbmx5IGNvbmZpZ3VyZSB1cCB0byB0d28gY29udHJvbGxlcnNcbiIpOwoJCXJldHVybiAxOwoJfQoKCXNldHVwW3NldHVwX2NvdW50XS5jb25mICAgICAgICA9IHN0cjsKCXNldHVwW3NldHVwX2NvdW50XS5pb19wb3J0ICAgICA9IGludHNbMF0gPj0gMSA/IGludHNbMV0gOiAweDM0MDsKCXNldHVwW3NldHVwX2NvdW50XS5pcnEgICAgICAgICA9IGludHNbMF0gPj0gMiA/IGludHNbMl0gOiAxMTsKCXNldHVwW3NldHVwX2NvdW50XS5zY3NpaWQgICAgICA9IGludHNbMF0gPj0gMyA/IGludHNbM10gOiA3OwoJc2V0dXBbc2V0dXBfY291bnRdLnJlY29ubmVjdCAgID0gaW50c1swXSA+PSA0ID8gaW50c1s0XSA6IDE7CglzZXR1cFtzZXR1cF9jb3VudF0ucGFyaXR5ICAgICAgPSBpbnRzWzBdID49IDUgPyBpbnRzWzVdIDogMTsKCXNldHVwW3NldHVwX2NvdW50XS5zeW5jaHJvbm91cyA9IGludHNbMF0gPj0gNiA/IGludHNbNl0gOiAxOwoJc2V0dXBbc2V0dXBfY291bnRdLmRlbGF5ICAgICAgID0gaW50c1swXSA+PSA3ID8gaW50c1s3XSA6IERFTEFZX0RFRkFVTFQ7CglzZXR1cFtzZXR1cF9jb3VudF0uZXh0X3RyYW5zICAgPSBpbnRzWzBdID49IDggPyBpbnRzWzhdIDogMDsKI2lmIGRlZmluZWQoQUhBMTUyWF9ERUJVRykKCXNldHVwW3NldHVwX2NvdW50XS5kZWJ1ZyAgICAgICA9IGludHNbMF0gPj0gOSA/IGludHNbOV0gOiBERUJVR19ERUZBVUxUOwoJaWYgKGludHNbMF0gPiA5KSB7CgkJcHJpbnRrKEtFUk5fTk9USUNFICJhaGExNTJ4OiB1c2FnZTogYWhhMTUyeD08SU9CQVNFPlssPElSUT5bLDxTQ1NJIElEPiIKCQkgICAgICAgIlssPFJFQ09OTkVDVD5bLDxQQVJJVFk+Wyw8U1lOQ0hST05PVVM+Wyw8REVMQVk+Wyw8RVhUX1RSQU5TPlssPERFQlVHPl1dXV1dXV1dXG4iKTsKI2Vsc2UKCWlmIChpbnRzWzBdID4gOCkgeyAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qfSovCgkJcHJpbnRrKEtFUk5fTk9USUNFICJhaGExNTJ4OiB1c2FnZTogYWhhMTUyeD08SU9CQVNFPlssPElSUT5bLDxTQ1NJIElEPiIKCQkgICAgICAgIlssPFJFQ09OTkVDVD5bLDxQQVJJVFk+Wyw8U1lOQ0hST05PVVM+Wyw8REVMQVk+Wyw8RVhUX1RSQU5TPl1dXV1dXV1cbiIpOwojZW5kaWYKCX0gZWxzZSB7CgkJc2V0dXBfY291bnQrKzsKCQlyZXR1cm4gMDsKCX0KCglyZXR1cm4gMTsKfQpfX3NldHVwKCJhaGExNTJ4PSIsIGFoYTE1Mnhfc2V0dXApOwojZW5kaWYKCiNlbmRpZiAvKiAhUENNQ0lBICovCg==