LyoKICogUUVNVSBGbG9wcHkgZGlzayBlbXVsYXRvciAoSW50ZWwgODIwNzgpCiAqCiAqIENvcHlyaWdodCAoYykgMjAwMywgMjAwNyBKb2NlbHluIE1heWVyCiAqIENvcHlyaWdodCAoYykgMjAwOCBIZXJ26SBQb3Vzc2luZWF1CiAqCiAqIFBlcm1pc3Npb24gaXMgaGVyZWJ5IGdyYW50ZWQsIGZyZWUgb2YgY2hhcmdlLCB0byBhbnkgcGVyc29uIG9idGFpbmluZyBhIGNvcHkKICogb2YgdGhpcyBzb2Z0d2FyZSBhbmQgYXNzb2NpYXRlZCBkb2N1bWVudGF0aW9uIGZpbGVzICh0aGUgIlNvZnR3YXJlIiksIHRvIGRlYWwKICogaW4gdGhlIFNvZnR3YXJlIHdpdGhvdXQgcmVzdHJpY3Rpb24sIGluY2x1ZGluZyB3aXRob3V0IGxpbWl0YXRpb24gdGhlIHJpZ2h0cwogKiB0byB1c2UsIGNvcHksIG1vZGlmeSwgbWVyZ2UsIHB1Ymxpc2gsIGRpc3RyaWJ1dGUsIHN1YmxpY2Vuc2UsIGFuZC9vciBzZWxsCiAqIGNvcGllcyBvZiB0aGUgU29mdHdhcmUsIGFuZCB0byBwZXJtaXQgcGVyc29ucyB0byB3aG9tIHRoZSBTb2Z0d2FyZSBpcwogKiBmdXJuaXNoZWQgdG8gZG8gc28sIHN1YmplY3QgdG8gdGhlIGZvbGxvd2luZyBjb25kaXRpb25zOgogKgogKiBUaGUgYWJvdmUgY29weXJpZ2h0IG5vdGljZSBhbmQgdGhpcyBwZXJtaXNzaW9uIG5vdGljZSBzaGFsbCBiZSBpbmNsdWRlZCBpbgogKiBhbGwgY29waWVzIG9yIHN1YnN0YW50aWFsIHBvcnRpb25zIG9mIHRoZSBTb2Z0d2FyZS4KICoKICogVEhFIFNPRlRXQVJFIElTIFBST1ZJREVEICJBUyBJUyIsIFdJVEhPVVQgV0FSUkFOVFkgT0YgQU5ZIEtJTkQsIEVYUFJFU1MgT1IKICogSU1QTElFRCwgSU5DTFVESU5HIEJVVCBOT1QgTElNSVRFRCBUTyBUSEUgV0FSUkFOVElFUyBPRiBNRVJDSEFOVEFCSUxJVFksCiAqIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFIEFORCBOT05JTkZSSU5HRU1FTlQuIElOIE5PIEVWRU5UIFNIQUxMCiAqIFRIRSBBVVRIT1JTIE9SIENPUFlSSUdIVCBIT0xERVJTIEJFIExJQUJMRSBGT1IgQU5ZIENMQUlNLCBEQU1BR0VTIE9SIE9USEVSCiAqIExJQUJJTElUWSwgV0hFVEhFUiBJTiBBTiBBQ1RJT04gT0YgQ09OVFJBQ1QsIFRPUlQgT1IgT1RIRVJXSVNFLCBBUklTSU5HIEZST00sCiAqIE9VVCBPRiBPUiBJTiBDT05ORUNUSU9OIFdJVEggVEhFIFNPRlRXQVJFIE9SIFRIRSBVU0UgT1IgT1RIRVIgREVBTElOR1MgSU4KICogVEhFIFNPRlRXQVJFLgogKi8KLyoKICogVGhlIGNvbnRyb2xsZXIgaXMgdXNlZCBpbiBTdW40bSBzeXN0ZW1zIGluIGEgc2xpZ2h0bHkgZGlmZmVyZW50CiAqIHdheS4gVGhlcmUgYXJlIGNoYW5nZXMgaW4gRE9SIHJlZ2lzdGVyIGFuZCBETUEgaXMgbm90IGF2YWlsYWJsZS4KICovCgojaW5jbHVkZSAiaHcuaCIKI2luY2x1ZGUgImZkYy5oIgojaW5jbHVkZSAicWVtdS10aW1lci5oIgojaW5jbHVkZSAiaXNhLmgiCiNpbmNsdWRlICJzeXNidXMuaCIKI2luY2x1ZGUgInFkZXYtYWRkci5oIgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBkZWJ1ZyBGbG9wcHkgZGV2aWNlcyAqLwovLyNkZWZpbmUgREVCVUdfRkxPUFBZCgojaWZkZWYgREVCVUdfRkxPUFBZCiNkZWZpbmUgRkxPUFBZX0RQUklOVEYoZm10LCAuLi4pICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcCiAgICBkbyB7IHByaW50ZigiRkxPUFBZOiAiIGZtdCAsICMjIF9fVkFfQVJHU19fKTsgfSB3aGlsZSAoMCkKI2Vsc2UKI2RlZmluZSBGTE9QUFlfRFBSSU5URihmbXQsIC4uLikKI2VuZGlmCgojZGVmaW5lIEZMT1BQWV9FUlJPUihmbXQsIC4uLikgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBcCiAgICBkbyB7IHByaW50ZigiRkxPUFBZIEVSUk9SOiAlczogIiBmbXQsIF9fZnVuY19fICwgIyMgX19WQV9BUkdTX18pOyB9IHdoaWxlICgwKQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBGbG9wcHkgZHJpdmUgZW11bGF0aW9uICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICovCgojZGVmaW5lIEdFVF9DVVJfRFJWKGZkY3RybCkgKChmZGN0cmwpLT5jdXJfZHJ2KQojZGVmaW5lIFNFVF9DVVJfRFJWKGZkY3RybCwgZHJpdmUpICgoZmRjdHJsKS0+Y3VyX2RydiA9IChkcml2ZSkpCgovKiBXaWxsIGFsd2F5cyBiZSBhIGZpeGVkIHBhcmFtZXRlciBmb3IgdXMgKi8KI2RlZmluZSBGRF9TRUNUT1JfTEVOICAgICAgICAgIDUxMgojZGVmaW5lIEZEX1NFQ1RPUl9TQyAgICAgICAgICAgMiAgIC8qIFNlY3RvciBzaXplIGNvZGUgKi8KI2RlZmluZSBGRF9SRVNFVF9TRU5TRUlfQ09VTlQgIDQgICAvKiBOdW1iZXIgb2Ygc2Vuc2UgaW50ZXJydXB0cyBvbiBSRVNFVCAqLwoKLyogRmxvcHB5IGRpc2sgZHJpdmUgZW11bGF0aW9uICovCnR5cGVkZWYgZW51bSBGRGlza1R5cGUgewogICAgRkRSSVZFX0RJU0tfMjg4ICAgPSAweDAxLCAvKiAyLjg4IE1CIGRpc2sgICAgICAgICAgICovCiAgICBGRFJJVkVfRElTS18xNDQgICA9IDB4MDIsIC8qIDEuNDQgTUIgZGlzayAgICAgICAgICAgKi8KICAgIEZEUklWRV9ESVNLXzcyMCAgID0gMHgwMywgLyogNzIwIGtCIGRpc2sgICAgICAgICAgICAqLwogICAgRkRSSVZFX0RJU0tfVVNFUiAgPSAweDA0LCAvKiBVc2VyIGRlZmluZWQgZ2VvbWV0cnkgICovCiAgICBGRFJJVkVfRElTS19OT05FICA9IDB4MDUsIC8qIE5vIGRpc2sgICAgICAgICAgICAgICAgKi8KfSBGRGlza1R5cGU7Cgp0eXBlZGVmIGVudW0gRkRyaXZlVHlwZSB7CiAgICBGRFJJVkVfRFJWXzE0NCAgPSAweDAwLCAgIC8qIDEuNDQgTUIgMyI1IGRyaXZlICAgICAgKi8KICAgIEZEUklWRV9EUlZfMjg4ICA9IDB4MDEsICAgLyogMi44OCBNQiAzIjUgZHJpdmUgICAgICAqLwogICAgRkRSSVZFX0RSVl8xMjAgID0gMHgwMiwgICAvKiAxLjIgIE1CIDUiMjUgZHJpdmUgICAgICovCiAgICBGRFJJVkVfRFJWX05PTkUgPSAweDAzLCAgIC8qIE5vIGRyaXZlIGNvbm5lY3RlZCAgICAgKi8KfSBGRHJpdmVUeXBlOwoKdHlwZWRlZiBlbnVtIEZEaXNrRmxhZ3MgewogICAgRkRJU0tfREJMX1NJREVTICA9IDB4MDEsCn0gRkRpc2tGbGFnczsKCnR5cGVkZWYgc3RydWN0IEZEcml2ZSB7CiAgICBEcml2ZUluZm8gKmRpbmZvOwogICAgQmxvY2tEcml2ZXJTdGF0ZSAqYnM7CiAgICAvKiBEcml2ZSBzdGF0dXMgKi8KICAgIEZEcml2ZVR5cGUgZHJpdmU7CiAgICB1aW50OF90IHBlcnBlbmRpY3VsYXI7ICAgIC8qIDIuODggTUIgYWNjZXNzIG1vZGUgICAgKi8KICAgIC8qIFBvc2l0aW9uICovCiAgICB1aW50OF90IGhlYWQ7CiAgICB1aW50OF90IHRyYWNrOwogICAgdWludDhfdCBzZWN0OwogICAgLyogTWVkaWEgKi8KICAgIEZEaXNrRmxhZ3MgZmxhZ3M7CiAgICB1aW50OF90IGxhc3Rfc2VjdDsgICAgICAgIC8qIE5iIHNlY3RvciBwZXIgdHJhY2sgICAgKi8KICAgIHVpbnQ4X3QgbWF4X3RyYWNrOyAgICAgICAgLyogTmIgb2YgdHJhY2tzICAgICAgICAgICAqLwogICAgdWludDE2X3QgYnBzOyAgICAgICAgICAgICAvKiBCeXRlcyBwZXIgc2VjdG9yICAgICAgICovCiAgICB1aW50OF90IHJvOyAgICAgICAgICAgICAgIC8qIElzIHJlYWQtb25seSAgICAgICAgICAgKi8KfSBGRHJpdmU7CgpzdGF0aWMgdm9pZCBmZF9pbml0KEZEcml2ZSAqZHJ2KQp7CiAgICAvKiBEcml2ZSAqLwogICAgZHJ2LT5icyA9IGRydi0+ZGluZm8gPyBkcnYtPmRpbmZvLT5iZHJ2IDogTlVMTDsKICAgIGRydi0+ZHJpdmUgPSBGRFJJVkVfRFJWX05PTkU7CiAgICBkcnYtPnBlcnBlbmRpY3VsYXIgPSAwOwogICAgLyogRGlzayAqLwogICAgZHJ2LT5sYXN0X3NlY3QgPSAwOwogICAgZHJ2LT5tYXhfdHJhY2sgPSAwOwp9CgpzdGF0aWMgaW50IGZkX3NlY3Rvcl9jYWxjKHVpbnQ4X3QgaGVhZCwgdWludDhfdCB0cmFjaywgdWludDhfdCBzZWN0LAogICAgICAgICAgICAgICAgICAgICAgICAgIHVpbnQ4X3QgbGFzdF9zZWN0KQp7CiAgICByZXR1cm4gKCgodHJhY2sgKiAyKSArIGhlYWQpICogbGFzdF9zZWN0KSArIHNlY3QgLSAxOwp9CgovKiBSZXR1cm5zIGN1cnJlbnQgcG9zaXRpb24sIGluIHNlY3RvcnMsIGZvciBnaXZlbiBkcml2ZSAqLwpzdGF0aWMgaW50IGZkX3NlY3RvcihGRHJpdmUgKmRydikKewogICAgcmV0dXJuIGZkX3NlY3Rvcl9jYWxjKGRydi0+aGVhZCwgZHJ2LT50cmFjaywgZHJ2LT5zZWN0LCBkcnYtPmxhc3Rfc2VjdCk7Cn0KCi8qIFNlZWsgdG8gYSBuZXcgcG9zaXRpb246CiAqIHJldHVybnMgMCBpZiBhbHJlYWR5IG9uIHJpZ2h0IHRyYWNrCiAqIHJldHVybnMgMSBpZiB0cmFjayBjaGFuZ2VkCiAqIHJldHVybnMgMiBpZiB0cmFjayBpcyBpbnZhbGlkCiAqIHJldHVybnMgMyBpZiBzZWN0b3IgaXMgaW52YWxpZAogKiByZXR1cm5zIDQgaWYgc2VlayBpcyBkaXNhYmxlZAogKi8Kc3RhdGljIGludCBmZF9zZWVrKEZEcml2ZSAqZHJ2LCB1aW50OF90IGhlYWQsIHVpbnQ4X3QgdHJhY2ssIHVpbnQ4X3Qgc2VjdCwKICAgICAgICAgICAgICAgICAgIGludCBlbmFibGVfc2VlaykKewogICAgdWludDMyX3Qgc2VjdG9yOwogICAgaW50IHJldDsKCiAgICBpZiAodHJhY2sgPiBkcnYtPm1heF90cmFjayB8fAogICAgICAgIChoZWFkICE9IDAgJiYgKGRydi0+ZmxhZ3MgJiBGRElTS19EQkxfU0lERVMpID09IDApKSB7CiAgICAgICAgRkxPUFBZX0RQUklOVEYoInRyeSB0byByZWFkICVkICUwMnggJTAyeCAobWF4PSVkICVkICUwMnggJTAyeClcbiIsCiAgICAgICAgICAgICAgICAgICAgICAgaGVhZCwgdHJhY2ssIHNlY3QsIDEsCiAgICAgICAgICAgICAgICAgICAgICAgKGRydi0+ZmxhZ3MgJiBGRElTS19EQkxfU0lERVMpID09IDAgPyAwIDogMSwKICAgICAgICAgICAgICAgICAgICAgICBkcnYtPm1heF90cmFjaywgZHJ2LT5sYXN0X3NlY3QpOwogICAgICAgIHJldHVybiAyOwogICAgfQogICAgaWYgKHNlY3QgPiBkcnYtPmxhc3Rfc2VjdCkgewogICAgICAgIEZMT1BQWV9EUFJJTlRGKCJ0cnkgdG8gcmVhZCAlZCAlMDJ4ICUwMnggKG1heD0lZCAlZCAlMDJ4ICUwMngpXG4iLAogICAgICAgICAgICAgICAgICAgICAgIGhlYWQsIHRyYWNrLCBzZWN0LCAxLAogICAgICAgICAgICAgICAgICAgICAgIChkcnYtPmZsYWdzICYgRkRJU0tfREJMX1NJREVTKSA9PSAwID8gMCA6IDEsCiAgICAgICAgICAgICAgICAgICAgICAgZHJ2LT5tYXhfdHJhY2ssIGRydi0+bGFzdF9zZWN0KTsKICAgICAgICByZXR1cm4gMzsKICAgIH0KICAgIHNlY3RvciA9IGZkX3NlY3Rvcl9jYWxjKGhlYWQsIHRyYWNrLCBzZWN0LCBkcnYtPmxhc3Rfc2VjdCk7CiAgICByZXQgPSAwOwogICAgaWYgKHNlY3RvciAhPSBmZF9zZWN0b3IoZHJ2KSkgewojaWYgMAogICAgICAgIGlmICghZW5hYmxlX3NlZWspIHsKICAgICAgICAgICAgRkxPUFBZX0VSUk9SKCJubyBpbXBsaWNpdCBzZWVrICVkICUwMnggJTAyeCAobWF4PSVkICUwMnggJTAyeClcbiIsCiAgICAgICAgICAgICAgICAgICAgICAgICBoZWFkLCB0cmFjaywgc2VjdCwgMSwgZHJ2LT5tYXhfdHJhY2ssIGRydi0+bGFzdF9zZWN0KTsKICAgICAgICAgICAgcmV0dXJuIDQ7CiAgICAgICAgfQojZW5kaWYKICAgICAgICBkcnYtPmhlYWQgPSBoZWFkOwogICAgICAgIGlmIChkcnYtPnRyYWNrICE9IHRyYWNrKQogICAgICAgICAgICByZXQgPSAxOwogICAgICAgIGRydi0+dHJhY2sgPSB0cmFjazsKICAgICAgICBkcnYtPnNlY3QgPSBzZWN0OwogICAgfQoKICAgIHJldHVybiByZXQ7Cn0KCi8qIFNldCBkcml2ZSBiYWNrIHRvIHRyYWNrIDAgKi8Kc3RhdGljIHZvaWQgZmRfcmVjYWxpYnJhdGUoRkRyaXZlICpkcnYpCnsKICAgIEZMT1BQWV9EUFJJTlRGKCJyZWNhbGlicmF0ZVxuIik7CiAgICBkcnYtPmhlYWQgPSAwOwogICAgZHJ2LT50cmFjayA9IDA7CiAgICBkcnYtPnNlY3QgPSAxOwp9CgovKiBSZWNvZ25pemUgZmxvcHB5IGZvcm1hdHMgKi8KdHlwZWRlZiBzdHJ1Y3QgRkRGb3JtYXQgewogICAgRkRyaXZlVHlwZSBkcml2ZTsKICAgIEZEaXNrVHlwZSAgZGlzazsKICAgIHVpbnQ4X3QgbGFzdF9zZWN0OwogICAgdWludDhfdCBtYXhfdHJhY2s7CiAgICB1aW50OF90IG1heF9oZWFkOwogICAgY29uc3QgY2hhciAqc3RyOwp9IEZERm9ybWF0OwoKc3RhdGljIGNvbnN0IEZERm9ybWF0IGZkX2Zvcm1hdHNbXSA9IHsKICAgIC8qIEZpcnN0IGVudHJ5IGlzIGRlZmF1bHQgZm9ybWF0ICovCiAgICAvKiAxLjQ0IE1CIDMiMS8yIGZsb3BweSBkaXNrcyAqLwogICAgeyBGRFJJVkVfRFJWXzE0NCwgRkRSSVZFX0RJU0tfMTQ0LCAxOCwgODAsIDEsICIxLjQ0IE1CIDNcIjEvMiIsIH0sCiAgICB7IEZEUklWRV9EUlZfMTQ0LCBGRFJJVkVfRElTS18xNDQsIDIwLCA4MCwgMSwgICIxLjYgTUIgM1wiMS8yIiwgfSwKICAgIHsgRkRSSVZFX0RSVl8xNDQsIEZEUklWRV9ESVNLXzE0NCwgMjEsIDgwLCAxLCAiMS42OCBNQiAzXCIxLzIiLCB9LAogICAgeyBGRFJJVkVfRFJWXzE0NCwgRkRSSVZFX0RJU0tfMTQ0LCAyMSwgODIsIDEsICIxLjcyIE1CIDNcIjEvMiIsIH0sCiAgICB7IEZEUklWRV9EUlZfMTQ0LCBGRFJJVkVfRElTS18xNDQsIDIxLCA4MywgMSwgIjEuNzQgTUIgM1wiMS8yIiwgfSwKICAgIHsgRkRSSVZFX0RSVl8xNDQsIEZEUklWRV9ESVNLXzE0NCwgMjIsIDgwLCAxLCAiMS43NiBNQiAzXCIxLzIiLCB9LAogICAgeyBGRFJJVkVfRFJWXzE0NCwgRkRSSVZFX0RJU0tfMTQ0LCAyMywgODAsIDEsICIxLjg0IE1CIDNcIjEvMiIsIH0sCiAgICB7IEZEUklWRV9EUlZfMTQ0LCBGRFJJVkVfRElTS18xNDQsIDI0LCA4MCwgMSwgIjEuOTIgTUIgM1wiMS8yIiwgfSwKICAgIC8qIDIuODggTUIgMyIxLzIgZmxvcHB5IGRpc2tzICovCiAgICB7IEZEUklWRV9EUlZfMjg4LCBGRFJJVkVfRElTS18yODgsIDM2LCA4MCwgMSwgIjIuODggTUIgM1wiMS8yIiwgfSwKICAgIHsgRkRSSVZFX0RSVl8yODgsIEZEUklWRV9ESVNLXzI4OCwgMzksIDgwLCAxLCAiMy4xMiBNQiAzXCIxLzIiLCB9LAogICAgeyBGRFJJVkVfRFJWXzI4OCwgRkRSSVZFX0RJU0tfMjg4LCA0MCwgODAsIDEsICAiMy4yIE1CIDNcIjEvMiIsIH0sCiAgICB7IEZEUklWRV9EUlZfMjg4LCBGRFJJVkVfRElTS18yODgsIDQ0LCA4MCwgMSwgIjMuNTIgTUIgM1wiMS8yIiwgfSwKICAgIHsgRkRSSVZFX0RSVl8yODgsIEZEUklWRV9ESVNLXzI4OCwgNDgsIDgwLCAxLCAiMy44NCBNQiAzXCIxLzIiLCB9LAogICAgLyogNzIwIGtCIDMiMS8yIGZsb3BweSBkaXNrcyAqLwogICAgeyBGRFJJVkVfRFJWXzE0NCwgRkRSSVZFX0RJU0tfNzIwLCAgOSwgODAsIDEsICAiNzIwIGtCIDNcIjEvMiIsIH0sCiAgICB7IEZEUklWRV9EUlZfMTQ0LCBGRFJJVkVfRElTS183MjAsIDEwLCA4MCwgMSwgICI4MDAga0IgM1wiMS8yIiwgfSwKICAgIHsgRkRSSVZFX0RSVl8xNDQsIEZEUklWRV9ESVNLXzcyMCwgMTAsIDgyLCAxLCAgIjgyMCBrQiAzXCIxLzIiLCB9LAogICAgeyBGRFJJVkVfRFJWXzE0NCwgRkRSSVZFX0RJU0tfNzIwLCAxMCwgODMsIDEsICAiODMwIGtCIDNcIjEvMiIsIH0sCiAgICB7IEZEUklWRV9EUlZfMTQ0LCBGRFJJVkVfRElTS183MjAsIDEzLCA4MCwgMSwgIjEuMDQgTUIgM1wiMS8yIiwgfSwKICAgIHsgRkRSSVZFX0RSVl8xNDQsIEZEUklWRV9ESVNLXzcyMCwgMTQsIDgwLCAxLCAiMS4xMiBNQiAzXCIxLzIiLCB9LAogICAgLyogMS4yIE1CIDUiMS80IGZsb3BweSBkaXNrcyAqLwogICAgeyBGRFJJVkVfRFJWXzEyMCwgRkRSSVZFX0RJU0tfMjg4LCAxNSwgODAsIDEsICAiMS4yIGtCIDVcIjEvNCIsIH0sCiAgICB7IEZEUklWRV9EUlZfMTIwLCBGRFJJVkVfRElTS18yODgsIDE4LCA4MCwgMSwgIjEuNDQgTUIgNVwiMS80IiwgfSwKICAgIHsgRkRSSVZFX0RSVl8xMjAsIEZEUklWRV9ESVNLXzI4OCwgMTgsIDgyLCAxLCAiMS40OCBNQiA1XCIxLzQiLCB9LAogICAgeyBGRFJJVkVfRFJWXzEyMCwgRkRSSVZFX0RJU0tfMjg4LCAxOCwgODMsIDEsICIxLjQ5IE1CIDVcIjEvNCIsIH0sCiAgICB7IEZEUklWRV9EUlZfMTIwLCBGRFJJVkVfRElTS18yODgsIDIwLCA4MCwgMSwgICIxLjYgTUIgNVwiMS80IiwgfSwKICAgIC8qIDcyMCBrQiA1IjEvNCBmbG9wcHkgZGlza3MgKi8KICAgIHsgRkRSSVZFX0RSVl8xMjAsIEZEUklWRV9ESVNLXzI4OCwgIDksIDgwLCAxLCAgIjcyMCBrQiA1XCIxLzQiLCB9LAogICAgeyBGRFJJVkVfRFJWXzEyMCwgRkRSSVZFX0RJU0tfMjg4LCAxMSwgODAsIDEsICAiODgwIGtCIDVcIjEvNCIsIH0sCiAgICAvKiAzNjAga0IgNSIxLzQgZmxvcHB5IGRpc2tzICovCiAgICB7IEZEUklWRV9EUlZfMTIwLCBGRFJJVkVfRElTS18yODgsICA5LCA0MCwgMSwgICIzNjAga0IgNVwiMS80IiwgfSwKICAgIHsgRkRSSVZFX0RSVl8xMjAsIEZEUklWRV9ESVNLXzI4OCwgIDksIDQwLCAwLCAgIjE4MCBrQiA1XCIxLzQiLCB9LAogICAgeyBGRFJJVkVfRFJWXzEyMCwgRkRSSVZFX0RJU0tfMjg4LCAxMCwgNDEsIDEsICAiNDEwIGtCIDVcIjEvNCIsIH0sCiAgICB7IEZEUklWRV9EUlZfMTIwLCBGRFJJVkVfRElTS18yODgsIDEwLCA0MiwgMSwgICI0MjAga0IgNVwiMS80IiwgfSwKICAgIC8qIDMyMCBrQiA1IjEvNCBmbG9wcHkgZGlza3MgKi8KICAgIHsgRkRSSVZFX0RSVl8xMjAsIEZEUklWRV9ESVNLXzI4OCwgIDgsIDQwLCAxLCAgIjMyMCBrQiA1XCIxLzQiLCB9LAogICAgeyBGRFJJVkVfRFJWXzEyMCwgRkRSSVZFX0RJU0tfMjg4LCAgOCwgNDAsIDAsICAiMTYwIGtCIDVcIjEvNCIsIH0sCiAgICAvKiAzNjAga0IgbXVzdCBtYXRjaCA1IjEvNCBiZXR0ZXIgdGhhbiAzIjEvMi4uLiAqLwogICAgeyBGRFJJVkVfRFJWXzE0NCwgRkRSSVZFX0RJU0tfNzIwLCAgOSwgODAsIDAsICAiMzYwIGtCIDNcIjEvMiIsIH0sCiAgICAvKiBlbmQgKi8KICAgIHsgRkRSSVZFX0RSVl9OT05FLCBGRFJJVkVfRElTS19OT05FLCAtMSwgLTEsIDAsIE5VTEwsIH0sCn07CgovKiBSZXZhbGlkYXRlIGEgZGlzayBkcml2ZSBhZnRlciBhIGRpc2sgY2hhbmdlICovCnN0YXRpYyB2b2lkIGZkX3JldmFsaWRhdGUoRkRyaXZlICpkcnYpCnsKICAgIGNvbnN0IEZERm9ybWF0ICpwYXJzZTsKICAgIHVpbnQ2NF90IG5iX3NlY3RvcnMsIHNpemU7CiAgICBpbnQgaSwgZmlyc3RfbWF0Y2gsIG1hdGNoOwogICAgaW50IG5iX2hlYWRzLCBtYXhfdHJhY2ssIGxhc3Rfc2VjdCwgcm87CgogICAgRkxPUFBZX0RQUklOVEYoInJldmFsaWRhdGVcbiIpOwogICAgaWYgKGRydi0+YnMgIT0gTlVMTCAmJiBiZHJ2X2lzX2luc2VydGVkKGRydi0+YnMpKSB7CiAgICAgICAgcm8gPSBiZHJ2X2lzX3JlYWRfb25seShkcnYtPmJzKTsKICAgICAgICBiZHJ2X2dldF9nZW9tZXRyeV9oaW50KGRydi0+YnMsICZuYl9oZWFkcywgJm1heF90cmFjaywgJmxhc3Rfc2VjdCk7CiAgICAgICAgaWYgKG5iX2hlYWRzICE9IDAgJiYgbWF4X3RyYWNrICE9IDAgJiYgbGFzdF9zZWN0ICE9IDApIHsKICAgICAgICAgICAgRkxPUFBZX0RQUklOVEYoIlVzZXIgZGVmaW5lZCBkaXNrICglZCAlZCAlZCkiLAogICAgICAgICAgICAgICAgICAgICAgICAgICBuYl9oZWFkcyAtIDEsIG1heF90cmFjaywgbGFzdF9zZWN0KTsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgICBiZHJ2X2dldF9nZW9tZXRyeShkcnYtPmJzLCAmbmJfc2VjdG9ycyk7CiAgICAgICAgICAgIG1hdGNoID0gLTE7CiAgICAgICAgICAgIGZpcnN0X21hdGNoID0gLTE7CiAgICAgICAgICAgIGZvciAoaSA9IDA7OyBpKyspIHsKICAgICAgICAgICAgICAgIHBhcnNlID0gJmZkX2Zvcm1hdHNbaV07CiAgICAgICAgICAgICAgICBpZiAocGFyc2UtPmRyaXZlID09IEZEUklWRV9EUlZfTk9ORSkKICAgICAgICAgICAgICAgICAgICBicmVhazsKICAgICAgICAgICAgICAgIGlmIChkcnYtPmRyaXZlID09IHBhcnNlLT5kcml2ZSB8fAogICAgICAgICAgICAgICAgICAgIGRydi0+ZHJpdmUgPT0gRkRSSVZFX0RSVl9OT05FKSB7CiAgICAgICAgICAgICAgICAgICAgc2l6ZSA9IChwYXJzZS0+bWF4X2hlYWQgKyAxKSAqIHBhcnNlLT5tYXhfdHJhY2sgKgogICAgICAgICAgICAgICAgICAgICAgICBwYXJzZS0+bGFzdF9zZWN0OwogICAgICAgICAgICAgICAgICAgIGlmIChuYl9zZWN0b3JzID09IHNpemUpIHsKICAgICAgICAgICAgICAgICAgICAgICAgbWF0Y2ggPSBpOwogICAgICAgICAgICAgICAgICAgICAgICBicmVhazsKICAgICAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICAgICAgaWYgKGZpcnN0X21hdGNoID09IC0xKQogICAgICAgICAgICAgICAgICAgICAgICBmaXJzdF9tYXRjaCA9IGk7CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgIH0KICAgICAgICAgICAgaWYgKG1hdGNoID09IC0xKSB7CiAgICAgICAgICAgICAgICBpZiAoZmlyc3RfbWF0Y2ggPT0gLTEpCiAgICAgICAgICAgICAgICAgICAgbWF0Y2ggPSAxOwogICAgICAgICAgICAgICAgZWxzZQogICAgICAgICAgICAgICAgICAgIG1hdGNoID0gZmlyc3RfbWF0Y2g7CiAgICAgICAgICAgICAgICBwYXJzZSA9ICZmZF9mb3JtYXRzW21hdGNoXTsKICAgICAgICAgICAgfQogICAgICAgICAgICBuYl9oZWFkcyA9IHBhcnNlLT5tYXhfaGVhZCArIDE7CiAgICAgICAgICAgIG1heF90cmFjayA9IHBhcnNlLT5tYXhfdHJhY2s7CiAgICAgICAgICAgIGxhc3Rfc2VjdCA9IHBhcnNlLT5sYXN0X3NlY3Q7CiAgICAgICAgICAgIGRydi0+ZHJpdmUgPSBwYXJzZS0+ZHJpdmU7CiAgICAgICAgICAgIEZMT1BQWV9EUFJJTlRGKCIlcyBmbG9wcHkgZGlzayAoJWQgaCAlZCB0ICVkIHMpICVzXG4iLCBwYXJzZS0+c3RyLAogICAgICAgICAgICAgICAgICAgICAgICAgICBuYl9oZWFkcywgbWF4X3RyYWNrLCBsYXN0X3NlY3QsIHJvID8gInJvIiA6ICJydyIpOwogICAgICAgIH0KICAgICAgICBpZiAobmJfaGVhZHMgPT0gMSkgewogICAgICAgICAgICBkcnYtPmZsYWdzICY9IH5GRElTS19EQkxfU0lERVM7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgZHJ2LT5mbGFncyB8PSBGRElTS19EQkxfU0lERVM7CiAgICAgICAgfQogICAgICAgIGRydi0+bWF4X3RyYWNrID0gbWF4X3RyYWNrOwogICAgICAgIGRydi0+bGFzdF9zZWN0ID0gbGFzdF9zZWN0OwogICAgICAgIGRydi0+cm8gPSBybzsKICAgIH0gZWxzZSB7CiAgICAgICAgRkxPUFBZX0RQUklOVEYoIk5vIGRpc2sgaW4gZHJpdmVcbiIpOwogICAgICAgIGRydi0+bGFzdF9zZWN0ID0gMDsKICAgICAgICBkcnYtPm1heF90cmFjayA9IDA7CiAgICAgICAgZHJ2LT5mbGFncyAmPSB+RkRJU0tfREJMX1NJREVTOwogICAgfQp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qIEludGVsIDgyMDc4IGZsb3BweSBkaXNrIGNvbnRyb2xsZXIgZW11bGF0aW9uICAgICAgICAgICovCgpzdGF0aWMgdm9pZCBmZGN0cmxfcmVzZXQoRkRDdHJsICpmZGN0cmwsIGludCBkb19pcnEpOwpzdGF0aWMgdm9pZCBmZGN0cmxfcmVzZXRfZmlmbyhGREN0cmwgKmZkY3RybCk7CnN0YXRpYyBpbnQgZmRjdHJsX3RyYW5zZmVyX2hhbmRsZXIgKHZvaWQgKm9wYXF1ZSwgaW50IG5jaGFuLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBpbnQgZG1hX3BvcywgaW50IGRtYV9sZW4pOwpzdGF0aWMgdm9pZCBmZGN0cmxfcmFpc2VfaXJxKEZEQ3RybCAqZmRjdHJsLCB1aW50OF90IHN0YXR1czApOwoKc3RhdGljIHVpbnQzMl90IGZkY3RybF9yZWFkX3N0YXR1c0EoRkRDdHJsICpmZGN0cmwpOwpzdGF0aWMgdWludDMyX3QgZmRjdHJsX3JlYWRfc3RhdHVzQihGREN0cmwgKmZkY3RybCk7CnN0YXRpYyB1aW50MzJfdCBmZGN0cmxfcmVhZF9kb3IoRkRDdHJsICpmZGN0cmwpOwpzdGF0aWMgdm9pZCBmZGN0cmxfd3JpdGVfZG9yKEZEQ3RybCAqZmRjdHJsLCB1aW50MzJfdCB2YWx1ZSk7CnN0YXRpYyB1aW50MzJfdCBmZGN0cmxfcmVhZF90YXBlKEZEQ3RybCAqZmRjdHJsKTsKc3RhdGljIHZvaWQgZmRjdHJsX3dyaXRlX3RhcGUoRkRDdHJsICpmZGN0cmwsIHVpbnQzMl90IHZhbHVlKTsKc3RhdGljIHVpbnQzMl90IGZkY3RybF9yZWFkX21haW5fc3RhdHVzKEZEQ3RybCAqZmRjdHJsKTsKc3RhdGljIHZvaWQgZmRjdHJsX3dyaXRlX3JhdGUoRkRDdHJsICpmZGN0cmwsIHVpbnQzMl90IHZhbHVlKTsKc3RhdGljIHVpbnQzMl90IGZkY3RybF9yZWFkX2RhdGEoRkRDdHJsICpmZGN0cmwpOwpzdGF0aWMgdm9pZCBmZGN0cmxfd3JpdGVfZGF0YShGREN0cmwgKmZkY3RybCwgdWludDMyX3QgdmFsdWUpOwpzdGF0aWMgdWludDMyX3QgZmRjdHJsX3JlYWRfZGlyKEZEQ3RybCAqZmRjdHJsKTsKCmVudW0gewogICAgRkRfRElSX1dSSVRFICAgPSAwLAogICAgRkRfRElSX1JFQUQgICAgPSAxLAogICAgRkRfRElSX1NDQU5FICAgPSAyLAogICAgRkRfRElSX1NDQU5MICAgPSAzLAogICAgRkRfRElSX1NDQU5IICAgPSA0LAp9OwoKZW51bSB7CiAgICBGRF9TVEFURV9NVUxUSSAgPSAweDAxLAkvKiBtdWx0aSB0cmFjayBmbGFnICovCiAgICBGRF9TVEFURV9GT1JNQVQgPSAweDAyLAkvKiBmb3JtYXQgZmxhZyAqLwogICAgRkRfU1RBVEVfU0VFSyAgID0gMHgwNCwJLyogc2VlayBmbGFnICovCn07CgplbnVtIHsKICAgIEZEX1JFR19TUkEgPSAweDAwLAogICAgRkRfUkVHX1NSQiA9IDB4MDEsCiAgICBGRF9SRUdfRE9SID0gMHgwMiwKICAgIEZEX1JFR19URFIgPSAweDAzLAogICAgRkRfUkVHX01TUiA9IDB4MDQsCiAgICBGRF9SRUdfRFNSID0gMHgwNCwKICAgIEZEX1JFR19GSUZPID0gMHgwNSwKICAgIEZEX1JFR19ESVIgPSAweDA3LAp9OwoKZW51bSB7CiAgICBGRF9DTURfUkVBRF9UUkFDSyA9IDB4MDIsCiAgICBGRF9DTURfU1BFQ0lGWSA9IDB4MDMsCiAgICBGRF9DTURfU0VOU0VfRFJJVkVfU1RBVFVTID0gMHgwNCwKICAgIEZEX0NNRF9XUklURSA9IDB4MDUsCiAgICBGRF9DTURfUkVBRCA9IDB4MDYsCiAgICBGRF9DTURfUkVDQUxJQlJBVEUgPSAweDA3LAogICAgRkRfQ01EX1NFTlNFX0lOVEVSUlVQVF9TVEFUVVMgPSAweDA4LAogICAgRkRfQ01EX1dSSVRFX0RFTEVURUQgPSAweDA5LAogICAgRkRfQ01EX1JFQURfSUQgPSAweDBhLAogICAgRkRfQ01EX1JFQURfREVMRVRFRCA9IDB4MGMsCiAgICBGRF9DTURfRk9STUFUX1RSQUNLID0gMHgwZCwKICAgIEZEX0NNRF9EVU1QUkVHID0gMHgwZSwKICAgIEZEX0NNRF9TRUVLID0gMHgwZiwKICAgIEZEX0NNRF9WRVJTSU9OID0gMHgxMCwKICAgIEZEX0NNRF9TQ0FOX0VRVUFMID0gMHgxMSwKICAgIEZEX0NNRF9QRVJQRU5ESUNVTEFSX01PREUgPSAweDEyLAogICAgRkRfQ01EX0NPTkZJR1VSRSA9IDB4MTMsCiAgICBGRF9DTURfTE9DSyA9IDB4MTQsCiAgICBGRF9DTURfVkVSSUZZID0gMHgxNiwKICAgIEZEX0NNRF9QT1dFUkRPV05fTU9ERSA9IDB4MTcsCiAgICBGRF9DTURfUEFSVF9JRCA9IDB4MTgsCiAgICBGRF9DTURfU0NBTl9MT1dfT1JfRVFVQUwgPSAweDE5LAogICAgRkRfQ01EX1NDQU5fSElHSF9PUl9FUVVBTCA9IDB4MWQsCiAgICBGRF9DTURfU0FWRSA9IDB4MmUsCiAgICBGRF9DTURfT1BUSU9OID0gMHgzMywKICAgIEZEX0NNRF9SRVNUT1JFID0gMHg0ZSwKICAgIEZEX0NNRF9EUklWRV9TUEVDSUZJQ0FUSU9OX0NPTU1BTkQgPSAweDhlLAogICAgRkRfQ01EX1JFTEFUSVZFX1NFRUtfT1VUID0gMHg4ZiwKICAgIEZEX0NNRF9GT1JNQVRfQU5EX1dSSVRFID0gMHhjZCwKICAgIEZEX0NNRF9SRUxBVElWRV9TRUVLX0lOID0gMHhjZiwKfTsKCmVudW0gewogICAgRkRfQ09ORklHX1BSRVRSSyA9IDB4ZmYsIC8qIFByZS1jb21wZW5zYXRpb24gc2V0IHRvIHRyYWNrIDAgKi8KICAgIEZEX0NPTkZJR19GSUZPVEhSID0gMHgwZiwgLyogRklGTyB0aHJlc2hvbGQgc2V0IHRvIDEgYnl0ZSAqLwogICAgRkRfQ09ORklHX1BPTEwgID0gMHgxMCwgLyogUG9sbCBlbmFibGVkICovCiAgICBGRF9DT05GSUdfRUZJRk8gPSAweDIwLCAvKiBGSUZPIGRpc2FibGVkICovCiAgICBGRF9DT05GSUdfRUlTICAgPSAweDQwLCAvKiBObyBpbXBsaWVkIHNlZWtzICovCn07CgplbnVtIHsKICAgIEZEX1NSMF9FUVBNVCAgICA9IDB4MTAsCiAgICBGRF9TUjBfU0VFSyAgICAgPSAweDIwLAogICAgRkRfU1IwX0FCTlRFUk0gID0gMHg0MCwKICAgIEZEX1NSMF9JTlZDTUQgICA9IDB4ODAsCiAgICBGRF9TUjBfUkRZQ0hHICAgPSAweGMwLAp9OwoKZW51bSB7CiAgICBGRF9TUjFfRUMgICAgICAgPSAweDgwLCAvKiBFbmQgb2YgY3lsaW5kZXIgKi8KfTsKCmVudW0gewogICAgRkRfU1IyX1NOUyAgICAgID0gMHgwNCwgLyogU2NhbiBub3Qgc2F0aXNmaWVkICovCiAgICBGRF9TUjJfU0VIICAgICAgPSAweDA4LCAvKiBTY2FuIGVxdWFsIGhpdCAqLwp9OwoKZW51bSB7CiAgICBGRF9TUkFfRElSICAgICAgPSAweDAxLAogICAgRkRfU1JBX25XUCAgICAgID0gMHgwMiwKICAgIEZEX1NSQV9uSU5EWCAgICA9IDB4MDQsCiAgICBGRF9TUkFfSERTRUwgICAgPSAweDA4LAogICAgRkRfU1JBX25UUkswICAgID0gMHgxMCwKICAgIEZEX1NSQV9TVEVQICAgICA9IDB4MjAsCiAgICBGRF9TUkFfbkRSVjIgICAgPSAweDQwLAogICAgRkRfU1JBX0lOVFBFTkQgID0gMHg4MCwKfTsKCmVudW0gewogICAgRkRfU1JCX01UUjAgICAgID0gMHgwMSwKICAgIEZEX1NSQl9NVFIxICAgICA9IDB4MDIsCiAgICBGRF9TUkJfV0dBVEUgICAgPSAweDA0LAogICAgRkRfU1JCX1JEQVRBICAgID0gMHgwOCwKICAgIEZEX1NSQl9XREFUQSAgICA9IDB4MTAsCiAgICBGRF9TUkJfRFIwICAgICAgPSAweDIwLAp9OwoKZW51bSB7CiNpZiBNQVhfRkQgPT0gNAogICAgRkRfRE9SX1NFTE1BU0sgID0gMHgwMywKI2Vsc2UKICAgIEZEX0RPUl9TRUxNQVNLICA9IDB4MDEsCiNlbmRpZgogICAgRkRfRE9SX25SRVNFVCAgID0gMHgwNCwKICAgIEZEX0RPUl9ETUFFTiAgICA9IDB4MDgsCiAgICBGRF9ET1JfTU9URU4wICAgPSAweDEwLAogICAgRkRfRE9SX01PVEVOMSAgID0gMHgyMCwKICAgIEZEX0RPUl9NT1RFTjIgICA9IDB4NDAsCiAgICBGRF9ET1JfTU9URU4zICAgPSAweDgwLAp9OwoKZW51bSB7CiNpZiBNQVhfRkQgPT0gNAogICAgRkRfVERSX0JPT1RTRUwgID0gMHgwYywKI2Vsc2UKICAgIEZEX1REUl9CT09UU0VMICA9IDB4MDQsCiNlbmRpZgp9OwoKZW51bSB7CiAgICBGRF9EU1JfRFJBVEVNQVNLPSAweDAzLAogICAgRkRfRFNSX1BXUkRPV04gID0gMHg0MCwKICAgIEZEX0RTUl9TV1JFU0VUICA9IDB4ODAsCn07CgplbnVtIHsKICAgIEZEX01TUl9EUlYwQlVTWSA9IDB4MDEsCiAgICBGRF9NU1JfRFJWMUJVU1kgPSAweDAyLAogICAgRkRfTVNSX0RSVjJCVVNZID0gMHgwNCwKICAgIEZEX01TUl9EUlYzQlVTWSA9IDB4MDgsCiAgICBGRF9NU1JfQ01EQlVTWSAgPSAweDEwLAogICAgRkRfTVNSX05PTkRNQSAgID0gMHgyMCwKICAgIEZEX01TUl9ESU8gICAgICA9IDB4NDAsCiAgICBGRF9NU1JfUlFNICAgICAgPSAweDgwLAp9OwoKZW51bSB7CiAgICBGRF9ESVJfRFNLQ0hHICAgPSAweDgwLAp9OwoKI2RlZmluZSBGRF9NVUxUSV9UUkFDSyhzdGF0ZSkgKChzdGF0ZSkgJiBGRF9TVEFURV9NVUxUSSkKI2RlZmluZSBGRF9ESURfU0VFSyhzdGF0ZSkgKChzdGF0ZSkgJiBGRF9TVEFURV9TRUVLKQojZGVmaW5lIEZEX0ZPUk1BVF9DTUQoc3RhdGUpICgoc3RhdGUpICYgRkRfU1RBVEVfRk9STUFUKQoKc3RydWN0IEZEQ3RybCB7CiAgICAvKiBDb250cm9sbGVyJ3MgaWRlbnRpZmljYXRpb24gKi8KICAgIHVpbnQ4X3QgdmVyc2lvbjsKICAgIC8qIEhXICovCiAgICBxZW11X2lycSBpcnE7CiAgICBpbnQgZG1hX2NoYW5uOwogICAgLyogQ29udHJvbGxlciBzdGF0ZSAqLwogICAgUUVNVVRpbWVyICpyZXN1bHRfdGltZXI7CiAgICB1aW50OF90IHNyYTsKICAgIHVpbnQ4X3Qgc3JiOwogICAgdWludDhfdCBkb3I7CiAgICB1aW50OF90IGRvcl92bXN0YXRlOyAvKiBvbmx5IHVzZWQgYXMgdGVtcCBkdXJpbmcgdm1zdGF0ZSAqLwogICAgdWludDhfdCB0ZHI7CiAgICB1aW50OF90IGRzcjsKICAgIHVpbnQ4X3QgbXNyOwogICAgdWludDhfdCBjdXJfZHJ2OwogICAgdWludDhfdCBzdGF0dXMwOwogICAgdWludDhfdCBzdGF0dXMxOwogICAgdWludDhfdCBzdGF0dXMyOwogICAgLyogQ29tbWFuZCBGSUZPICovCiAgICB1aW50OF90ICpmaWZvOwogICAgaW50MzJfdCBmaWZvX3NpemU7CiAgICB1aW50MzJfdCBkYXRhX3BvczsKICAgIHVpbnQzMl90IGRhdGFfbGVuOwogICAgdWludDhfdCBkYXRhX3N0YXRlOwogICAgdWludDhfdCBkYXRhX2RpcjsKICAgIHVpbnQ4X3QgZW90OyAvKiBsYXN0IHdhbnRlZCBzZWN0b3IgKi8KICAgIC8qIFN0YXRlcyBrZXB0IG9ubHkgdG8gYmUgcmV0dXJuZWQgYmFjayAqLwogICAgLyogVGltZXJzIHN0YXRlICovCiAgICB1aW50OF90IHRpbWVyMDsKICAgIHVpbnQ4X3QgdGltZXIxOwogICAgLyogcHJlY29tcGVuc2F0aW9uICovCiAgICB1aW50OF90IHByZWNvbXBfdHJrOwogICAgdWludDhfdCBjb25maWc7CiAgICB1aW50OF90IGxvY2s7CiAgICAvKiBQb3dlciBkb3duIGNvbmZpZyAoYWxzbyB3aXRoIHN0YXR1cyByZWdCIGFjY2VzcyBtb2RlICovCiAgICB1aW50OF90IHB3cmQ7CiAgICAvKiBTdW40bSBxdWlya3M/ICovCiAgICBpbnQgc3VuNG07CiAgICAvKiBGbG9wcHkgZHJpdmVzICovCiAgICB1aW50OF90IG51bV9mbG9wcGllczsKICAgIEZEcml2ZSBkcml2ZXNbTUFYX0ZEXTsKICAgIGludCByZXNldF9zZW5zZWk7Cn07Cgp0eXBlZGVmIHN0cnVjdCBGREN0cmxTeXNCdXMgewogICAgU3lzQnVzRGV2aWNlIGJ1c2RldjsKICAgIHN0cnVjdCBGREN0cmwgc3RhdGU7Cn0gRkRDdHJsU3lzQnVzOwoKdHlwZWRlZiBzdHJ1Y3QgRkRDdHJsSVNBQnVzIHsKICAgIElTQURldmljZSBidXNkZXY7CiAgICBzdHJ1Y3QgRkRDdHJsIHN0YXRlOwp9IEZEQ3RybElTQUJ1czsKCnN0YXRpYyB1aW50MzJfdCBmZGN0cmxfcmVhZCAodm9pZCAqb3BhcXVlLCB1aW50MzJfdCByZWcpCnsKICAgIEZEQ3RybCAqZmRjdHJsID0gb3BhcXVlOwogICAgdWludDMyX3QgcmV0dmFsOwoKICAgIHN3aXRjaCAocmVnKSB7CiAgICBjYXNlIEZEX1JFR19TUkE6CiAgICAgICAgcmV0dmFsID0gZmRjdHJsX3JlYWRfc3RhdHVzQShmZGN0cmwpOwogICAgICAgIGJyZWFrOwogICAgY2FzZSBGRF9SRUdfU1JCOgogICAgICAgIHJldHZhbCA9IGZkY3RybF9yZWFkX3N0YXR1c0IoZmRjdHJsKTsKICAgICAgICBicmVhazsKICAgIGNhc2UgRkRfUkVHX0RPUjoKICAgICAgICByZXR2YWwgPSBmZGN0cmxfcmVhZF9kb3IoZmRjdHJsKTsKICAgICAgICBicmVhazsKICAgIGNhc2UgRkRfUkVHX1REUjoKICAgICAgICByZXR2YWwgPSBmZGN0cmxfcmVhZF90YXBlKGZkY3RybCk7CiAgICAgICAgYnJlYWs7CiAgICBjYXNlIEZEX1JFR19NU1I6CiAgICAgICAgcmV0dmFsID0gZmRjdHJsX3JlYWRfbWFpbl9zdGF0dXMoZmRjdHJsKTsKICAgICAgICBicmVhazsKICAgIGNhc2UgRkRfUkVHX0ZJRk86CiAgICAgICAgcmV0dmFsID0gZmRjdHJsX3JlYWRfZGF0YShmZGN0cmwpOwogICAgICAgIGJyZWFrOwogICAgY2FzZSBGRF9SRUdfRElSOgogICAgICAgIHJldHZhbCA9IGZkY3RybF9yZWFkX2RpcihmZGN0cmwpOwogICAgICAgIGJyZWFrOwogICAgZGVmYXVsdDoKICAgICAgICByZXR2YWwgPSAodWludDMyX3QpKC0xKTsKICAgICAgICBicmVhazsKICAgIH0KICAgIEZMT1BQWV9EUFJJTlRGKCJyZWFkIHJlZyVkOiAweCUwMnhcbiIsIHJlZyAmIDcsIHJldHZhbCk7CgogICAgcmV0dXJuIHJldHZhbDsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX3dyaXRlICh2b2lkICpvcGFxdWUsIHVpbnQzMl90IHJlZywgdWludDMyX3QgdmFsdWUpCnsKICAgIEZEQ3RybCAqZmRjdHJsID0gb3BhcXVlOwoKICAgIEZMT1BQWV9EUFJJTlRGKCJ3cml0ZSByZWclZDogMHglMDJ4XG4iLCByZWcgJiA3LCB2YWx1ZSk7CgogICAgc3dpdGNoIChyZWcpIHsKICAgIGNhc2UgRkRfUkVHX0RPUjoKICAgICAgICBmZGN0cmxfd3JpdGVfZG9yKGZkY3RybCwgdmFsdWUpOwogICAgICAgIGJyZWFrOwogICAgY2FzZSBGRF9SRUdfVERSOgogICAgICAgIGZkY3RybF93cml0ZV90YXBlKGZkY3RybCwgdmFsdWUpOwogICAgICAgIGJyZWFrOwogICAgY2FzZSBGRF9SRUdfRFNSOgogICAgICAgIGZkY3RybF93cml0ZV9yYXRlKGZkY3RybCwgdmFsdWUpOwogICAgICAgIGJyZWFrOwogICAgY2FzZSBGRF9SRUdfRklGTzoKICAgICAgICBmZGN0cmxfd3JpdGVfZGF0YShmZGN0cmwsIHZhbHVlKTsKICAgICAgICBicmVhazsKICAgIGRlZmF1bHQ6CiAgICAgICAgYnJlYWs7CiAgICB9Cn0KCnN0YXRpYyB1aW50MzJfdCBmZGN0cmxfcmVhZF9wb3J0ICh2b2lkICpvcGFxdWUsIHVpbnQzMl90IHJlZykKewogICAgcmV0dXJuIGZkY3RybF9yZWFkKG9wYXF1ZSwgcmVnICYgNyk7Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF93cml0ZV9wb3J0ICh2b2lkICpvcGFxdWUsIHVpbnQzMl90IHJlZywgdWludDMyX3QgdmFsdWUpCnsKICAgIGZkY3RybF93cml0ZShvcGFxdWUsIHJlZyAmIDcsIHZhbHVlKTsKfQoKc3RhdGljIHVpbnQzMl90IGZkY3RybF9yZWFkX21lbSAodm9pZCAqb3BhcXVlLCB0YXJnZXRfcGh5c19hZGRyX3QgcmVnKQp7CiAgICByZXR1cm4gZmRjdHJsX3JlYWQob3BhcXVlLCAodWludDMyX3QpcmVnKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX3dyaXRlX21lbSAodm9pZCAqb3BhcXVlLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICB0YXJnZXRfcGh5c19hZGRyX3QgcmVnLCB1aW50MzJfdCB2YWx1ZSkKewogICAgZmRjdHJsX3dyaXRlKG9wYXF1ZSwgKHVpbnQzMl90KXJlZywgdmFsdWUpOwp9CgpzdGF0aWMgQ1BVUmVhZE1lbW9yeUZ1bmMgKiBjb25zdCBmZGN0cmxfbWVtX3JlYWRbM10gPSB7CiAgICBmZGN0cmxfcmVhZF9tZW0sCiAgICBmZGN0cmxfcmVhZF9tZW0sCiAgICBmZGN0cmxfcmVhZF9tZW0sCn07CgpzdGF0aWMgQ1BVV3JpdGVNZW1vcnlGdW5jICogY29uc3QgZmRjdHJsX21lbV93cml0ZVszXSA9IHsKICAgIGZkY3RybF93cml0ZV9tZW0sCiAgICBmZGN0cmxfd3JpdGVfbWVtLAogICAgZmRjdHJsX3dyaXRlX21lbSwKfTsKCnN0YXRpYyBDUFVSZWFkTWVtb3J5RnVuYyAqIGNvbnN0IGZkY3RybF9tZW1fcmVhZF9zdHJpY3RbM10gPSB7CiAgICBmZGN0cmxfcmVhZF9tZW0sCiAgICBOVUxMLAogICAgTlVMTCwKfTsKCnN0YXRpYyBDUFVXcml0ZU1lbW9yeUZ1bmMgKiBjb25zdCBmZGN0cmxfbWVtX3dyaXRlX3N0cmljdFszXSA9IHsKICAgIGZkY3RybF93cml0ZV9tZW0sCiAgICBOVUxMLAogICAgTlVMTCwKfTsKCnN0YXRpYyBjb25zdCBWTVN0YXRlRGVzY3JpcHRpb24gdm1zdGF0ZV9mZHJpdmUgPSB7CiAgICAubmFtZSA9ICJmZHJpdmUiLAogICAgLnZlcnNpb25faWQgPSAxLAogICAgLm1pbmltdW1fdmVyc2lvbl9pZCA9IDEsCiAgICAubWluaW11bV92ZXJzaW9uX2lkX29sZCA9IDEsCiAgICAuZmllbGRzICAgICAgPSAoVk1TdGF0ZUZpZWxkIFtdKSB7CiAgICAgICAgVk1TVEFURV9VSU5UOChoZWFkLCBGRHJpdmUpLAogICAgICAgIFZNU1RBVEVfVUlOVDgodHJhY2ssIEZEcml2ZSksCiAgICAgICAgVk1TVEFURV9VSU5UOChzZWN0LCBGRHJpdmUpLAogICAgICAgIFZNU1RBVEVfRU5EX09GX0xJU1QoKQogICAgfQp9OwoKc3RhdGljIHZvaWQgZmRjX3ByZV9zYXZlKHZvaWQgKm9wYXF1ZSkKewogICAgRkRDdHJsICpzID0gb3BhcXVlOwoKICAgIHMtPmRvcl92bXN0YXRlID0gcy0+ZG9yIHwgR0VUX0NVUl9EUlYocyk7Cn0KCnN0YXRpYyBpbnQgZmRjX3Bvc3RfbG9hZCh2b2lkICpvcGFxdWUsIGludCB2ZXJzaW9uX2lkKQp7CiAgICBGREN0cmwgKnMgPSBvcGFxdWU7CgogICAgU0VUX0NVUl9EUlYocywgcy0+ZG9yX3Ztc3RhdGUgJiBGRF9ET1JfU0VMTUFTSyk7CiAgICBzLT5kb3IgPSBzLT5kb3Jfdm1zdGF0ZSAmIH5GRF9ET1JfU0VMTUFTSzsKICAgIHJldHVybiAwOwp9CgpzdGF0aWMgY29uc3QgVk1TdGF0ZURlc2NyaXB0aW9uIHZtc3RhdGVfZmRjID0gewogICAgLm5hbWUgPSAiZmRjIiwKICAgIC52ZXJzaW9uX2lkID0gMiwKICAgIC5taW5pbXVtX3ZlcnNpb25faWQgPSAyLAogICAgLm1pbmltdW1fdmVyc2lvbl9pZF9vbGQgPSAyLAogICAgLnByZV9zYXZlID0gZmRjX3ByZV9zYXZlLAogICAgLnBvc3RfbG9hZCA9IGZkY19wb3N0X2xvYWQsCiAgICAuZmllbGRzICAgICAgPSAoVk1TdGF0ZUZpZWxkIFtdKSB7CiAgICAgICAgLyogQ29udHJvbGxlciBTdGF0ZSAqLwogICAgICAgIFZNU1RBVEVfVUlOVDgoc3JhLCBGREN0cmwpLAogICAgICAgIFZNU1RBVEVfVUlOVDgoc3JiLCBGREN0cmwpLAogICAgICAgIFZNU1RBVEVfVUlOVDgoZG9yX3Ztc3RhdGUsIEZEQ3RybCksCiAgICAgICAgVk1TVEFURV9VSU5UOCh0ZHIsIEZEQ3RybCksCiAgICAgICAgVk1TVEFURV9VSU5UOChkc3IsIEZEQ3RybCksCiAgICAgICAgVk1TVEFURV9VSU5UOChtc3IsIEZEQ3RybCksCiAgICAgICAgVk1TVEFURV9VSU5UOChzdGF0dXMwLCBGREN0cmwpLAogICAgICAgIFZNU1RBVEVfVUlOVDgoc3RhdHVzMSwgRkRDdHJsKSwKICAgICAgICBWTVNUQVRFX1VJTlQ4KHN0YXR1czIsIEZEQ3RybCksCiAgICAgICAgLyogQ29tbWFuZCBGSUZPICovCiAgICAgICAgVk1TVEFURV9WQVJSQVlfSU5UMzIoZmlmbywgRkRDdHJsLCBmaWZvX3NpemUsIDAsIHZtc3RhdGVfaW5mb191aW50OCwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICB1aW50OF90KSwKICAgICAgICBWTVNUQVRFX1VJTlQzMihkYXRhX3BvcywgRkRDdHJsKSwKICAgICAgICBWTVNUQVRFX1VJTlQzMihkYXRhX2xlbiwgRkRDdHJsKSwKICAgICAgICBWTVNUQVRFX1VJTlQ4KGRhdGFfc3RhdGUsIEZEQ3RybCksCiAgICAgICAgVk1TVEFURV9VSU5UOChkYXRhX2RpciwgRkRDdHJsKSwKICAgICAgICBWTVNUQVRFX1VJTlQ4KGVvdCwgRkRDdHJsKSwKICAgICAgICAvKiBTdGF0ZXMga2VwdCBvbmx5IHRvIGJlIHJldHVybmVkIGJhY2sgKi8KICAgICAgICBWTVNUQVRFX1VJTlQ4KHRpbWVyMCwgRkRDdHJsKSwKICAgICAgICBWTVNUQVRFX1VJTlQ4KHRpbWVyMSwgRkRDdHJsKSwKICAgICAgICBWTVNUQVRFX1VJTlQ4KHByZWNvbXBfdHJrLCBGREN0cmwpLAogICAgICAgIFZNU1RBVEVfVUlOVDgoY29uZmlnLCBGREN0cmwpLAogICAgICAgIFZNU1RBVEVfVUlOVDgobG9jaywgRkRDdHJsKSwKICAgICAgICBWTVNUQVRFX1VJTlQ4KHB3cmQsIEZEQ3RybCksCiAgICAgICAgVk1TVEFURV9VSU5UOF9FUVVBTChudW1fZmxvcHBpZXMsIEZEQ3RybCksCiAgICAgICAgVk1TVEFURV9TVFJVQ1RfQVJSQVkoZHJpdmVzLCBGREN0cmwsIE1BWF9GRCwgMSwKICAgICAgICAgICAgICAgICAgICAgICAgICAgICB2bXN0YXRlX2Zkcml2ZSwgRkRyaXZlKSwKICAgICAgICBWTVNUQVRFX0VORF9PRl9MSVNUKCkKICAgIH0KfTsKCnN0YXRpYyB2b2lkIGZkY3RybF9leHRlcm5hbF9yZXNldF9zeXNidXMoRGV2aWNlU3RhdGUgKmQpCnsKICAgIEZEQ3RybFN5c0J1cyAqc3lzID0gY29udGFpbmVyX29mKGQsIEZEQ3RybFN5c0J1cywgYnVzZGV2LnFkZXYpOwogICAgRkRDdHJsICpzID0gJnN5cy0+c3RhdGU7CgogICAgZmRjdHJsX3Jlc2V0KHMsIDApOwp9CgpzdGF0aWMgdm9pZCBmZGN0cmxfZXh0ZXJuYWxfcmVzZXRfaXNhKERldmljZVN0YXRlICpkKQp7CiAgICBGREN0cmxJU0FCdXMgKmlzYSA9IGNvbnRhaW5lcl9vZihkLCBGREN0cmxJU0FCdXMsIGJ1c2Rldi5xZGV2KTsKICAgIEZEQ3RybCAqcyA9ICZpc2EtPnN0YXRlOwoKICAgIGZkY3RybF9yZXNldChzLCAwKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV90Yyh2b2lkICpvcGFxdWUsIGludCBpcnEsIGludCBsZXZlbCkKewogICAgLy9GREN0cmwgKnMgPSBvcGFxdWU7CgogICAgaWYgKGxldmVsKSB7CiAgICAgICAgLy8gWFhYCiAgICAgICAgRkxPUFBZX0RQUklOVEYoIlRDIHB1bHNlZFxuIik7CiAgICB9Cn0KCi8qIFhYWDogbWF5IGNoYW5nZSBpZiBtb3ZlZCB0byBiZHJ2ICovCmludCBmZGN0cmxfZ2V0X2RyaXZlX3R5cGUoRkRDdHJsICpmZGN0cmwsIGludCBkcml2ZV9udW0pCnsKICAgIHJldHVybiBmZGN0cmwtPmRyaXZlc1tkcml2ZV9udW1dLmRyaXZlOwp9CgovKiBDaGFuZ2UgSVJRIHN0YXRlICovCnN0YXRpYyB2b2lkIGZkY3RybF9yZXNldF9pcnEoRkRDdHJsICpmZGN0cmwpCnsKICAgIGlmICghKGZkY3RybC0+c3JhICYgRkRfU1JBX0lOVFBFTkQpKQogICAgICAgIHJldHVybjsKICAgIEZMT1BQWV9EUFJJTlRGKCJSZXNldCBpbnRlcnJ1cHRcbiIpOwogICAgcWVtdV9zZXRfaXJxKGZkY3RybC0+aXJxLCAwKTsKICAgIGZkY3RybC0+c3JhICY9IH5GRF9TUkFfSU5UUEVORDsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX3JhaXNlX2lycShGREN0cmwgKmZkY3RybCwgdWludDhfdCBzdGF0dXMwKQp7CiAgICAvKiBTcGFyYyBtdXRhdGlvbiAqLwogICAgaWYgKGZkY3RybC0+c3VuNG0gJiYgKGZkY3RybC0+bXNyICYgRkRfTVNSX0NNREJVU1kpKSB7CiAgICAgICAgLyogWFhYOiBub3Qgc3VyZSAqLwogICAgICAgIGZkY3RybC0+bXNyICY9IH5GRF9NU1JfQ01EQlVTWTsKICAgICAgICBmZGN0cmwtPm1zciB8PSBGRF9NU1JfUlFNIHwgRkRfTVNSX0RJTzsKICAgICAgICBmZGN0cmwtPnN0YXR1czAgPSBzdGF0dXMwOwogICAgICAgIHJldHVybjsKICAgIH0KICAgIGlmICghKGZkY3RybC0+c3JhICYgRkRfU1JBX0lOVFBFTkQpKSB7CiAgICAgICAgcWVtdV9zZXRfaXJxKGZkY3RybC0+aXJxLCAxKTsKICAgICAgICBmZGN0cmwtPnNyYSB8PSBGRF9TUkFfSU5UUEVORDsKICAgIH0KICAgIGZkY3RybC0+cmVzZXRfc2Vuc2VpID0gMDsKICAgIGZkY3RybC0+c3RhdHVzMCA9IHN0YXR1czA7CiAgICBGTE9QUFlfRFBSSU5URigiU2V0IGludGVycnVwdCBzdGF0dXMgdG8gMHglMDJ4XG4iLCBmZGN0cmwtPnN0YXR1czApOwp9CgovKiBSZXNldCBjb250cm9sbGVyICovCnN0YXRpYyB2b2lkIGZkY3RybF9yZXNldChGREN0cmwgKmZkY3RybCwgaW50IGRvX2lycSkKewogICAgaW50IGk7CgogICAgRkxPUFBZX0RQUklOVEYoInJlc2V0IGNvbnRyb2xsZXJcbiIpOwogICAgZmRjdHJsX3Jlc2V0X2lycShmZGN0cmwpOwogICAgLyogSW5pdGlhbGlzZSBjb250cm9sbGVyICovCiAgICBmZGN0cmwtPnNyYSA9IDA7CiAgICBmZGN0cmwtPnNyYiA9IDB4YzA7CiAgICBpZiAoIWZkY3RybC0+ZHJpdmVzWzFdLmJzKQogICAgICAgIGZkY3RybC0+c3JhIHw9IEZEX1NSQV9uRFJWMjsKICAgIGZkY3RybC0+Y3VyX2RydiA9IDA7CiAgICBmZGN0cmwtPmRvciA9IEZEX0RPUl9uUkVTRVQ7CiAgICBmZGN0cmwtPmRvciB8PSAoZmRjdHJsLT5kbWFfY2hhbm4gIT0gLTEpID8gRkRfRE9SX0RNQUVOIDogMDsKICAgIGZkY3RybC0+bXNyID0gRkRfTVNSX1JRTTsKICAgIC8qIEZJRk8gc3RhdGUgKi8KICAgIGZkY3RybC0+ZGF0YV9wb3MgPSAwOwogICAgZmRjdHJsLT5kYXRhX2xlbiA9IDA7CiAgICBmZGN0cmwtPmRhdGFfc3RhdGUgPSAwOwogICAgZmRjdHJsLT5kYXRhX2RpciA9IEZEX0RJUl9XUklURTsKICAgIGZvciAoaSA9IDA7IGkgPCBNQVhfRkQ7IGkrKykKICAgICAgICBmZF9yZWNhbGlicmF0ZSgmZmRjdHJsLT5kcml2ZXNbaV0pOwogICAgZmRjdHJsX3Jlc2V0X2ZpZm8oZmRjdHJsKTsKICAgIGlmIChkb19pcnEpIHsKICAgICAgICBmZGN0cmxfcmFpc2VfaXJxKGZkY3RybCwgRkRfU1IwX1JEWUNIRyk7CiAgICAgICAgZmRjdHJsLT5yZXNldF9zZW5zZWkgPSBGRF9SRVNFVF9TRU5TRUlfQ09VTlQ7CiAgICB9Cn0KCnN0YXRpYyBpbmxpbmUgRkRyaXZlICpkcnYwKEZEQ3RybCAqZmRjdHJsKQp7CiAgICByZXR1cm4gJmZkY3RybC0+ZHJpdmVzWyhmZGN0cmwtPnRkciAmIEZEX1REUl9CT09UU0VMKSA+PiAyXTsKfQoKc3RhdGljIGlubGluZSBGRHJpdmUgKmRydjEoRkRDdHJsICpmZGN0cmwpCnsKICAgIGlmICgoZmRjdHJsLT50ZHIgJiBGRF9URFJfQk9PVFNFTCkgPCAoMSA8PCAyKSkKICAgICAgICByZXR1cm4gJmZkY3RybC0+ZHJpdmVzWzFdOwogICAgZWxzZQogICAgICAgIHJldHVybiAmZmRjdHJsLT5kcml2ZXNbMF07Cn0KCiNpZiBNQVhfRkQgPT0gNApzdGF0aWMgaW5saW5lIEZEcml2ZSAqZHJ2MihGREN0cmwgKmZkY3RybCkKewogICAgaWYgKChmZGN0cmwtPnRkciAmIEZEX1REUl9CT09UU0VMKSA8ICgyIDw8IDIpKQogICAgICAgIHJldHVybiAmZmRjdHJsLT5kcml2ZXNbMl07CiAgICBlbHNlCiAgICAgICAgcmV0dXJuICZmZGN0cmwtPmRyaXZlc1sxXTsKfQoKc3RhdGljIGlubGluZSBGRHJpdmUgKmRydjMoRkRDdHJsICpmZGN0cmwpCnsKICAgIGlmICgoZmRjdHJsLT50ZHIgJiBGRF9URFJfQk9PVFNFTCkgPCAoMyA8PCAyKSkKICAgICAgICByZXR1cm4gJmZkY3RybC0+ZHJpdmVzWzNdOwogICAgZWxzZQogICAgICAgIHJldHVybiAmZmRjdHJsLT5kcml2ZXNbMl07Cn0KI2VuZGlmCgpzdGF0aWMgRkRyaXZlICpnZXRfY3VyX2RydihGREN0cmwgKmZkY3RybCkKewogICAgc3dpdGNoIChmZGN0cmwtPmN1cl9kcnYpIHsKICAgICAgICBjYXNlIDA6IHJldHVybiBkcnYwKGZkY3RybCk7CiAgICAgICAgY2FzZSAxOiByZXR1cm4gZHJ2MShmZGN0cmwpOwojaWYgTUFYX0ZEID09IDQKICAgICAgICBjYXNlIDI6IHJldHVybiBkcnYyKGZkY3RybCk7CiAgICAgICAgY2FzZSAzOiByZXR1cm4gZHJ2MyhmZGN0cmwpOwojZW5kaWYKICAgICAgICBkZWZhdWx0OiByZXR1cm4gTlVMTDsKICAgIH0KfQoKLyogU3RhdHVzIEEgcmVnaXN0ZXIgOiAweDAwIChyZWFkLW9ubHkpICovCnN0YXRpYyB1aW50MzJfdCBmZGN0cmxfcmVhZF9zdGF0dXNBKEZEQ3RybCAqZmRjdHJsKQp7CiAgICB1aW50MzJfdCByZXR2YWwgPSBmZGN0cmwtPnNyYTsKCiAgICBGTE9QUFlfRFBSSU5URigic3RhdHVzIHJlZ2lzdGVyIEE6IDB4JTAyeFxuIiwgcmV0dmFsKTsKCiAgICByZXR1cm4gcmV0dmFsOwp9CgovKiBTdGF0dXMgQiByZWdpc3RlciA6IDB4MDEgKHJlYWQtb25seSkgKi8Kc3RhdGljIHVpbnQzMl90IGZkY3RybF9yZWFkX3N0YXR1c0IoRkRDdHJsICpmZGN0cmwpCnsKICAgIHVpbnQzMl90IHJldHZhbCA9IGZkY3RybC0+c3JiOwoKICAgIEZMT1BQWV9EUFJJTlRGKCJzdGF0dXMgcmVnaXN0ZXIgQjogMHglMDJ4XG4iLCByZXR2YWwpOwoKICAgIHJldHVybiByZXR2YWw7Cn0KCi8qIERpZ2l0YWwgb3V0cHV0IHJlZ2lzdGVyIDogMHgwMiAqLwpzdGF0aWMgdWludDMyX3QgZmRjdHJsX3JlYWRfZG9yKEZEQ3RybCAqZmRjdHJsKQp7CiAgICB1aW50MzJfdCByZXR2YWwgPSBmZGN0cmwtPmRvcjsKCiAgICAvKiBTZWxlY3RlZCBkcml2ZSAqLwogICAgcmV0dmFsIHw9IGZkY3RybC0+Y3VyX2RydjsKICAgIEZMT1BQWV9EUFJJTlRGKCJkaWdpdGFsIG91dHB1dCByZWdpc3RlcjogMHglMDJ4XG4iLCByZXR2YWwpOwoKICAgIHJldHVybiByZXR2YWw7Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF93cml0ZV9kb3IoRkRDdHJsICpmZGN0cmwsIHVpbnQzMl90IHZhbHVlKQp7CiAgICBGTE9QUFlfRFBSSU5URigiZGlnaXRhbCBvdXRwdXQgcmVnaXN0ZXIgc2V0IHRvIDB4JTAyeFxuIiwgdmFsdWUpOwoKICAgIC8qIE1vdG9ycyAqLwogICAgaWYgKHZhbHVlICYgRkRfRE9SX01PVEVOMCkKICAgICAgICBmZGN0cmwtPnNyYiB8PSBGRF9TUkJfTVRSMDsKICAgIGVsc2UKICAgICAgICBmZGN0cmwtPnNyYiAmPSB+RkRfU1JCX01UUjA7CiAgICBpZiAodmFsdWUgJiBGRF9ET1JfTU9URU4xKQogICAgICAgIGZkY3RybC0+c3JiIHw9IEZEX1NSQl9NVFIxOwogICAgZWxzZQogICAgICAgIGZkY3RybC0+c3JiICY9IH5GRF9TUkJfTVRSMTsKCiAgICAvKiBEcml2ZSAqLwogICAgaWYgKHZhbHVlICYgMSkKICAgICAgICBmZGN0cmwtPnNyYiB8PSBGRF9TUkJfRFIwOwogICAgZWxzZQogICAgICAgIGZkY3RybC0+c3JiICY9IH5GRF9TUkJfRFIwOwoKICAgIC8qIFJlc2V0ICovCiAgICBpZiAoISh2YWx1ZSAmIEZEX0RPUl9uUkVTRVQpKSB7CiAgICAgICAgaWYgKGZkY3RybC0+ZG9yICYgRkRfRE9SX25SRVNFVCkgewogICAgICAgICAgICBGTE9QUFlfRFBSSU5URigiY29udHJvbGxlciBlbnRlciBSRVNFVCBzdGF0ZVxuIik7CiAgICAgICAgfQogICAgfSBlbHNlIHsKICAgICAgICBpZiAoIShmZGN0cmwtPmRvciAmIEZEX0RPUl9uUkVTRVQpKSB7CiAgICAgICAgICAgIEZMT1BQWV9EUFJJTlRGKCJjb250cm9sbGVyIG91dCBvZiBSRVNFVCBzdGF0ZVxuIik7CiAgICAgICAgICAgIGZkY3RybF9yZXNldChmZGN0cmwsIDEpOwogICAgICAgICAgICBmZGN0cmwtPmRzciAmPSB+RkRfRFNSX1BXUkRPV047CiAgICAgICAgfQogICAgfQogICAgLyogU2VsZWN0ZWQgZHJpdmUgKi8KICAgIGZkY3RybC0+Y3VyX2RydiA9IHZhbHVlICYgRkRfRE9SX1NFTE1BU0s7CgogICAgZmRjdHJsLT5kb3IgPSB2YWx1ZTsKfQoKLyogVGFwZSBkcml2ZSByZWdpc3RlciA6IDB4MDMgKi8Kc3RhdGljIHVpbnQzMl90IGZkY3RybF9yZWFkX3RhcGUoRkRDdHJsICpmZGN0cmwpCnsKICAgIHVpbnQzMl90IHJldHZhbCA9IGZkY3RybC0+dGRyOwoKICAgIEZMT1BQWV9EUFJJTlRGKCJ0YXBlIGRyaXZlIHJlZ2lzdGVyOiAweCUwMnhcbiIsIHJldHZhbCk7CgogICAgcmV0dXJuIHJldHZhbDsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX3dyaXRlX3RhcGUoRkRDdHJsICpmZGN0cmwsIHVpbnQzMl90IHZhbHVlKQp7CiAgICAvKiBSZXNldCBtb2RlICovCiAgICBpZiAoIShmZGN0cmwtPmRvciAmIEZEX0RPUl9uUkVTRVQpKSB7CiAgICAgICAgRkxPUFBZX0RQUklOVEYoIkZsb3BweSBjb250cm9sbGVyIGluIFJFU0VUIHN0YXRlICFcbiIpOwogICAgICAgIHJldHVybjsKICAgIH0KICAgIEZMT1BQWV9EUFJJTlRGKCJ0YXBlIGRyaXZlIHJlZ2lzdGVyIHNldCB0byAweCUwMnhcbiIsIHZhbHVlKTsKICAgIC8qIERpc2sgYm9vdCBzZWxlY3Rpb24gaW5kaWNhdG9yICovCiAgICBmZGN0cmwtPnRkciA9IHZhbHVlICYgRkRfVERSX0JPT1RTRUw7CiAgICAvKiBUYXBlIGluZGljYXRvcnM6IG5ldmVyIGFsbG93ICovCn0KCi8qIE1haW4gc3RhdHVzIHJlZ2lzdGVyIDogMHgwNCAocmVhZCkgKi8Kc3RhdGljIHVpbnQzMl90IGZkY3RybF9yZWFkX21haW5fc3RhdHVzKEZEQ3RybCAqZmRjdHJsKQp7CiAgICB1aW50MzJfdCByZXR2YWwgPSBmZGN0cmwtPm1zcjsKCiAgICBmZGN0cmwtPmRzciAmPSB+RkRfRFNSX1BXUkRPV047CiAgICBmZGN0cmwtPmRvciB8PSBGRF9ET1JfblJFU0VUOwoKICAgIC8qIFNwYXJjIG11dGF0aW9uICovCiAgICBpZiAoZmRjdHJsLT5zdW40bSkgewogICAgICAgIHJldHZhbCB8PSBGRF9NU1JfRElPOwogICAgICAgIGZkY3RybF9yZXNldF9pcnEoZmRjdHJsKTsKICAgIH07CgogICAgRkxPUFBZX0RQUklOVEYoIm1haW4gc3RhdHVzIHJlZ2lzdGVyOiAweCUwMnhcbiIsIHJldHZhbCk7CgogICAgcmV0dXJuIHJldHZhbDsKfQoKLyogRGF0YSBzZWxlY3QgcmF0ZSByZWdpc3RlciA6IDB4MDQgKHdyaXRlKSAqLwpzdGF0aWMgdm9pZCBmZGN0cmxfd3JpdGVfcmF0ZShGREN0cmwgKmZkY3RybCwgdWludDMyX3QgdmFsdWUpCnsKICAgIC8qIFJlc2V0IG1vZGUgKi8KICAgIGlmICghKGZkY3RybC0+ZG9yICYgRkRfRE9SX25SRVNFVCkpIHsKICAgICAgICBGTE9QUFlfRFBSSU5URigiRmxvcHB5IGNvbnRyb2xsZXIgaW4gUkVTRVQgc3RhdGUgIVxuIik7CiAgICAgICAgcmV0dXJuOwogICAgfQogICAgRkxPUFBZX0RQUklOVEYoInNlbGVjdCByYXRlIHJlZ2lzdGVyIHNldCB0byAweCUwMnhcbiIsIHZhbHVlKTsKICAgIC8qIFJlc2V0OiBhdXRvY2xlYXIgKi8KICAgIGlmICh2YWx1ZSAmIEZEX0RTUl9TV1JFU0VUKSB7CiAgICAgICAgZmRjdHJsLT5kb3IgJj0gfkZEX0RPUl9uUkVTRVQ7CiAgICAgICAgZmRjdHJsX3Jlc2V0KGZkY3RybCwgMSk7CiAgICAgICAgZmRjdHJsLT5kb3IgfD0gRkRfRE9SX25SRVNFVDsKICAgIH0KICAgIGlmICh2YWx1ZSAmIEZEX0RTUl9QV1JET1dOKSB7CiAgICAgICAgZmRjdHJsX3Jlc2V0KGZkY3RybCwgMSk7CiAgICB9CiAgICBmZGN0cmwtPmRzciA9IHZhbHVlOwp9CgpzdGF0aWMgaW50IGZkY3RybF9tZWRpYV9jaGFuZ2VkKEZEcml2ZSAqZHJ2KQp7CiAgICBpbnQgcmV0OwoKICAgIGlmICghZHJ2LT5icykKICAgICAgICByZXR1cm4gMDsKICAgIHJldCA9IGJkcnZfbWVkaWFfY2hhbmdlZChkcnYtPmJzKTsKICAgIGlmIChyZXQpIHsKICAgICAgICBmZF9yZXZhbGlkYXRlKGRydik7CiAgICB9CiAgICByZXR1cm4gcmV0Owp9CgovKiBEaWdpdGFsIGlucHV0IHJlZ2lzdGVyIDogMHgwNyAocmVhZC1vbmx5KSAqLwpzdGF0aWMgdWludDMyX3QgZmRjdHJsX3JlYWRfZGlyKEZEQ3RybCAqZmRjdHJsKQp7CiAgICB1aW50MzJfdCByZXR2YWwgPSAwOwoKICAgIGlmIChmZGN0cmxfbWVkaWFfY2hhbmdlZChkcnYwKGZkY3RybCkpCiAgICAgfHwgZmRjdHJsX21lZGlhX2NoYW5nZWQoZHJ2MShmZGN0cmwpKQojaWYgTUFYX0ZEID09IDQKICAgICB8fCBmZGN0cmxfbWVkaWFfY2hhbmdlZChkcnYyKGZkY3RybCkpCiAgICAgfHwgZmRjdHJsX21lZGlhX2NoYW5nZWQoZHJ2MyhmZGN0cmwpKQojZW5kaWYKICAgICAgICApCiAgICAgICAgcmV0dmFsIHw9IEZEX0RJUl9EU0tDSEc7CiAgICBpZiAocmV0dmFsICE9IDApIHsKICAgICAgICBGTE9QUFlfRFBSSU5URigiRmxvcHB5IGRpZ2l0YWwgaW5wdXQgcmVnaXN0ZXI6IDB4JTAyeFxuIiwgcmV0dmFsKTsKICAgIH0KCiAgICByZXR1cm4gcmV0dmFsOwp9CgovKiBGSUZPIHN0YXRlIGNvbnRyb2wgKi8Kc3RhdGljIHZvaWQgZmRjdHJsX3Jlc2V0X2ZpZm8oRkRDdHJsICpmZGN0cmwpCnsKICAgIGZkY3RybC0+ZGF0YV9kaXIgPSBGRF9ESVJfV1JJVEU7CiAgICBmZGN0cmwtPmRhdGFfcG9zID0gMDsKICAgIGZkY3RybC0+bXNyICY9IH4oRkRfTVNSX0NNREJVU1kgfCBGRF9NU1JfRElPKTsKfQoKLyogU2V0IEZJRk8gc3RhdHVzIGZvciB0aGUgaG9zdCB0byByZWFkICovCnN0YXRpYyB2b2lkIGZkY3RybF9zZXRfZmlmbyhGREN0cmwgKmZkY3RybCwgaW50IGZpZm9fbGVuLCBpbnQgZG9faXJxKQp7CiAgICBmZGN0cmwtPmRhdGFfZGlyID0gRkRfRElSX1JFQUQ7CiAgICBmZGN0cmwtPmRhdGFfbGVuID0gZmlmb19sZW47CiAgICBmZGN0cmwtPmRhdGFfcG9zID0gMDsKICAgIGZkY3RybC0+bXNyIHw9IEZEX01TUl9DTURCVVNZIHwgRkRfTVNSX1JRTSB8IEZEX01TUl9ESU87CiAgICBpZiAoZG9faXJxKQogICAgICAgIGZkY3RybF9yYWlzZV9pcnEoZmRjdHJsLCAweDAwKTsKfQoKLyogU2V0IGFuIGVycm9yOiB1bmltcGxlbWVudGVkL3Vua25vd24gY29tbWFuZCAqLwpzdGF0aWMgdm9pZCBmZGN0cmxfdW5pbXBsZW1lbnRlZChGREN0cmwgKmZkY3RybCwgaW50IGRpcmVjdGlvbikKewogICAgRkxPUFBZX0VSUk9SKCJ1bmltcGxlbWVudGVkIGNvbW1hbmQgMHglMDJ4XG4iLCBmZGN0cmwtPmZpZm9bMF0pOwogICAgZmRjdHJsLT5maWZvWzBdID0gRkRfU1IwX0lOVkNNRDsKICAgIGZkY3RybF9zZXRfZmlmbyhmZGN0cmwsIDEsIDApOwp9CgovKiBTZWVrIHRvIG5leHQgc2VjdG9yICovCnN0YXRpYyBpbnQgZmRjdHJsX3NlZWtfdG9fbmV4dF9zZWN0KEZEQ3RybCAqZmRjdHJsLCBGRHJpdmUgKmN1cl9kcnYpCnsKICAgIEZMT1BQWV9EUFJJTlRGKCJzZWVrIHRvIG5leHQgc2VjdG9yICglZCAlMDJ4ICUwMnggPT4gJWQpXG4iLAogICAgICAgICAgICAgICAgICAgY3VyX2Rydi0+aGVhZCwgY3VyX2Rydi0+dHJhY2ssIGN1cl9kcnYtPnNlY3QsCiAgICAgICAgICAgICAgICAgICBmZF9zZWN0b3IoY3VyX2RydikpOwogICAgLyogWFhYOiBjdXJfZHJ2LT5zZWN0ID49IGN1cl9kcnYtPmxhc3Rfc2VjdCBzaG91bGQgYmUgYW4KICAgICAgIGVycm9yIGluIGZhY3QgKi8KICAgIGlmIChjdXJfZHJ2LT5zZWN0ID49IGN1cl9kcnYtPmxhc3Rfc2VjdCB8fAogICAgICAgIGN1cl9kcnYtPnNlY3QgPT0gZmRjdHJsLT5lb3QpIHsKICAgICAgICBjdXJfZHJ2LT5zZWN0ID0gMTsKICAgICAgICBpZiAoRkRfTVVMVElfVFJBQ0soZmRjdHJsLT5kYXRhX3N0YXRlKSkgewogICAgICAgICAgICBpZiAoY3VyX2Rydi0+aGVhZCA9PSAwICYmCiAgICAgICAgICAgICAgICAoY3VyX2Rydi0+ZmxhZ3MgJiBGRElTS19EQkxfU0lERVMpICE9IDApIHsKICAgICAgICAgICAgICAgIGN1cl9kcnYtPmhlYWQgPSAxOwogICAgICAgICAgICB9IGVsc2UgewogICAgICAgICAgICAgICAgY3VyX2Rydi0+aGVhZCA9IDA7CiAgICAgICAgICAgICAgICBjdXJfZHJ2LT50cmFjaysrOwogICAgICAgICAgICAgICAgaWYgKChjdXJfZHJ2LT5mbGFncyAmIEZESVNLX0RCTF9TSURFUykgPT0gMCkKICAgICAgICAgICAgICAgICAgICByZXR1cm4gMDsKICAgICAgICAgICAgfQogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICAgIGN1cl9kcnYtPnRyYWNrKys7CiAgICAgICAgICAgIHJldHVybiAwOwogICAgICAgIH0KICAgICAgICBGTE9QUFlfRFBSSU5URigic2VlayB0byBuZXh0IHRyYWNrICglZCAlMDJ4ICUwMnggPT4gJWQpXG4iLAogICAgICAgICAgICAgICAgICAgICAgIGN1cl9kcnYtPmhlYWQsIGN1cl9kcnYtPnRyYWNrLAogICAgICAgICAgICAgICAgICAgICAgIGN1cl9kcnYtPnNlY3QsIGZkX3NlY3RvcihjdXJfZHJ2KSk7CiAgICB9IGVsc2UgewogICAgICAgIGN1cl9kcnYtPnNlY3QrKzsKICAgIH0KICAgIHJldHVybiAxOwp9CgovKiBDYWxsYmFjayBmb3IgdHJhbnNmZXIgZW5kIChzdG9wIG9yIGFib3J0KSAqLwpzdGF0aWMgdm9pZCBmZGN0cmxfc3RvcF90cmFuc2ZlcihGREN0cmwgKmZkY3RybCwgdWludDhfdCBzdGF0dXMwLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICB1aW50OF90IHN0YXR1czEsIHVpbnQ4X3Qgc3RhdHVzMikKewogICAgRkRyaXZlICpjdXJfZHJ2OwoKICAgIGN1cl9kcnYgPSBnZXRfY3VyX2RydihmZGN0cmwpOwogICAgRkxPUFBZX0RQUklOVEYoInRyYW5zZmVyIHN0YXR1czogJTAyeCAlMDJ4ICUwMnggKCUwMngpXG4iLAogICAgICAgICAgICAgICAgICAgc3RhdHVzMCwgc3RhdHVzMSwgc3RhdHVzMiwKICAgICAgICAgICAgICAgICAgIHN0YXR1czAgfCAoY3VyX2Rydi0+aGVhZCA8PCAyKSB8IEdFVF9DVVJfRFJWKGZkY3RybCkpOwogICAgZmRjdHJsLT5maWZvWzBdID0gc3RhdHVzMCB8IChjdXJfZHJ2LT5oZWFkIDw8IDIpIHwgR0VUX0NVUl9EUlYoZmRjdHJsKTsKICAgIGZkY3RybC0+Zmlmb1sxXSA9IHN0YXR1czE7CiAgICBmZGN0cmwtPmZpZm9bMl0gPSBzdGF0dXMyOwogICAgZmRjdHJsLT5maWZvWzNdID0gY3VyX2Rydi0+dHJhY2s7CiAgICBmZGN0cmwtPmZpZm9bNF0gPSBjdXJfZHJ2LT5oZWFkOwogICAgZmRjdHJsLT5maWZvWzVdID0gY3VyX2Rydi0+c2VjdDsKICAgIGZkY3RybC0+Zmlmb1s2XSA9IEZEX1NFQ1RPUl9TQzsKICAgIGZkY3RybC0+ZGF0YV9kaXIgPSBGRF9ESVJfUkVBRDsKICAgIGlmICghKGZkY3RybC0+bXNyICYgRkRfTVNSX05PTkRNQSkpIHsKICAgICAgICBETUFfcmVsZWFzZV9EUkVRKGZkY3RybC0+ZG1hX2NoYW5uKTsKICAgIH0KICAgIGZkY3RybC0+bXNyIHw9IEZEX01TUl9SUU0gfCBGRF9NU1JfRElPOwogICAgZmRjdHJsLT5tc3IgJj0gfkZEX01TUl9OT05ETUE7CiAgICBmZGN0cmxfc2V0X2ZpZm8oZmRjdHJsLCA3LCAxKTsKfQoKLyogUHJlcGFyZSBhIGRhdGEgdHJhbnNmZXIgKGVpdGhlciBETUEgb3IgRklGTykgKi8Kc3RhdGljIHZvaWQgZmRjdHJsX3N0YXJ0X3RyYW5zZmVyKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICBGRHJpdmUgKmN1cl9kcnY7CiAgICB1aW50OF90IGtoLCBrdCwga3M7CiAgICBpbnQgZGlkX3NlZWsgPSAwOwoKICAgIFNFVF9DVVJfRFJWKGZkY3RybCwgZmRjdHJsLT5maWZvWzFdICYgRkRfRE9SX1NFTE1BU0spOwogICAgY3VyX2RydiA9IGdldF9jdXJfZHJ2KGZkY3RybCk7CiAgICBrdCA9IGZkY3RybC0+Zmlmb1syXTsKICAgIGtoID0gZmRjdHJsLT5maWZvWzNdOwogICAga3MgPSBmZGN0cmwtPmZpZm9bNF07CiAgICBGTE9QUFlfRFBSSU5URigiU3RhcnQgdHJhbnNmZXIgYXQgJWQgJWQgJTAyeCAlMDJ4ICglZClcbiIsCiAgICAgICAgICAgICAgICAgICBHRVRfQ1VSX0RSVihmZGN0cmwpLCBraCwga3QsIGtzLAogICAgICAgICAgICAgICAgICAgZmRfc2VjdG9yX2NhbGMoa2gsIGt0LCBrcywgY3VyX2Rydi0+bGFzdF9zZWN0KSk7CiAgICBzd2l0Y2ggKGZkX3NlZWsoY3VyX2Rydiwga2gsIGt0LCBrcywgZmRjdHJsLT5jb25maWcgJiBGRF9DT05GSUdfRUlTKSkgewogICAgY2FzZSAyOgogICAgICAgIC8qIHNlY3QgdG9vIGJpZyAqLwogICAgICAgIGZkY3RybF9zdG9wX3RyYW5zZmVyKGZkY3RybCwgRkRfU1IwX0FCTlRFUk0sIDB4MDAsIDB4MDApOwogICAgICAgIGZkY3RybC0+Zmlmb1szXSA9IGt0OwogICAgICAgIGZkY3RybC0+Zmlmb1s0XSA9IGtoOwogICAgICAgIGZkY3RybC0+Zmlmb1s1XSA9IGtzOwogICAgICAgIHJldHVybjsKICAgIGNhc2UgMzoKICAgICAgICAvKiB0cmFjayB0b28gYmlnICovCiAgICAgICAgZmRjdHJsX3N0b3BfdHJhbnNmZXIoZmRjdHJsLCBGRF9TUjBfQUJOVEVSTSwgRkRfU1IxX0VDLCAweDAwKTsKICAgICAgICBmZGN0cmwtPmZpZm9bM10gPSBrdDsKICAgICAgICBmZGN0cmwtPmZpZm9bNF0gPSBraDsKICAgICAgICBmZGN0cmwtPmZpZm9bNV0gPSBrczsKICAgICAgICByZXR1cm47CiAgICBjYXNlIDQ6CiAgICAgICAgLyogTm8gc2VlayBlbmFibGVkICovCiAgICAgICAgZmRjdHJsX3N0b3BfdHJhbnNmZXIoZmRjdHJsLCBGRF9TUjBfQUJOVEVSTSwgMHgwMCwgMHgwMCk7CiAgICAgICAgZmRjdHJsLT5maWZvWzNdID0ga3Q7CiAgICAgICAgZmRjdHJsLT5maWZvWzRdID0ga2g7CiAgICAgICAgZmRjdHJsLT5maWZvWzVdID0ga3M7CiAgICAgICAgcmV0dXJuOwogICAgY2FzZSAxOgogICAgICAgIGRpZF9zZWVrID0gMTsKICAgICAgICBicmVhazsKICAgIGRlZmF1bHQ6CiAgICAgICAgYnJlYWs7CiAgICB9CgogICAgLyogU2V0IHRoZSBGSUZPIHN0YXRlICovCiAgICBmZGN0cmwtPmRhdGFfZGlyID0gZGlyZWN0aW9uOwogICAgZmRjdHJsLT5kYXRhX3BvcyA9IDA7CiAgICBmZGN0cmwtPm1zciB8PSBGRF9NU1JfQ01EQlVTWTsKICAgIGlmIChmZGN0cmwtPmZpZm9bMF0gJiAweDgwKQogICAgICAgIGZkY3RybC0+ZGF0YV9zdGF0ZSB8PSBGRF9TVEFURV9NVUxUSTsKICAgIGVsc2UKICAgICAgICBmZGN0cmwtPmRhdGFfc3RhdGUgJj0gfkZEX1NUQVRFX01VTFRJOwogICAgaWYgKGRpZF9zZWVrKQogICAgICAgIGZkY3RybC0+ZGF0YV9zdGF0ZSB8PSBGRF9TVEFURV9TRUVLOwogICAgZWxzZQogICAgICAgIGZkY3RybC0+ZGF0YV9zdGF0ZSAmPSB+RkRfU1RBVEVfU0VFSzsKICAgIGlmIChmZGN0cmwtPmZpZm9bNV0gPT0gMDApIHsKICAgICAgICBmZGN0cmwtPmRhdGFfbGVuID0gZmRjdHJsLT5maWZvWzhdOwogICAgfSBlbHNlIHsKICAgICAgICBpbnQgdG1wOwogICAgICAgIGZkY3RybC0+ZGF0YV9sZW4gPSAxMjggPDwgKGZkY3RybC0+Zmlmb1s1XSA+IDcgPyA3IDogZmRjdHJsLT5maWZvWzVdKTsKICAgICAgICB0bXAgPSAoZmRjdHJsLT5maWZvWzZdIC0ga3MgKyAxKTsKICAgICAgICBpZiAoZmRjdHJsLT5maWZvWzBdICYgMHg4MCkKICAgICAgICAgICAgdG1wICs9IGZkY3RybC0+Zmlmb1s2XTsKICAgICAgICBmZGN0cmwtPmRhdGFfbGVuICo9IHRtcDsKICAgIH0KICAgIGZkY3RybC0+ZW90ID0gZmRjdHJsLT5maWZvWzZdOwogICAgaWYgKGZkY3RybC0+ZG9yICYgRkRfRE9SX0RNQUVOKSB7CiAgICAgICAgaW50IGRtYV9tb2RlOwogICAgICAgIC8qIERNQSB0cmFuc2ZlciBhcmUgZW5hYmxlZC4gQ2hlY2sgaWYgRE1BIGNoYW5uZWwgaXMgd2VsbCBwcm9ncmFtbWVkICovCiAgICAgICAgZG1hX21vZGUgPSBETUFfZ2V0X2NoYW5uZWxfbW9kZShmZGN0cmwtPmRtYV9jaGFubik7CiAgICAgICAgZG1hX21vZGUgPSAoZG1hX21vZGUgPj4gMikgJiAzOwogICAgICAgIEZMT1BQWV9EUFJJTlRGKCJkbWFfbW9kZT0lZCBkaXJlY3Rpb249JWQgKCVkIC0gJWQpXG4iLAogICAgICAgICAgICAgICAgICAgICAgIGRtYV9tb2RlLCBkaXJlY3Rpb24sCiAgICAgICAgICAgICAgICAgICAgICAgKDEyOCA8PCBmZGN0cmwtPmZpZm9bNV0pICoKICAgICAgICAgICAgICAgICAgICAgICAoY3VyX2Rydi0+bGFzdF9zZWN0IC0ga3MgKyAxKSwgZmRjdHJsLT5kYXRhX2xlbik7CiAgICAgICAgaWYgKCgoZGlyZWN0aW9uID09IEZEX0RJUl9TQ0FORSB8fCBkaXJlY3Rpb24gPT0gRkRfRElSX1NDQU5MIHx8CiAgICAgICAgICAgICAgZGlyZWN0aW9uID09IEZEX0RJUl9TQ0FOSCkgJiYgZG1hX21vZGUgPT0gMCkgfHwKICAgICAgICAgICAgKGRpcmVjdGlvbiA9PSBGRF9ESVJfV1JJVEUgJiYgZG1hX21vZGUgPT0gMikgfHwKICAgICAgICAgICAgKGRpcmVjdGlvbiA9PSBGRF9ESVJfUkVBRCAmJiBkbWFfbW9kZSA9PSAxKSkgewogICAgICAgICAgICAvKiBObyBhY2Nlc3MgaXMgYWxsb3dlZCB1bnRpbCBETUEgdHJhbnNmZXIgaGFzIGNvbXBsZXRlZCAqLwogICAgICAgICAgICBmZGN0cmwtPm1zciAmPSB+RkRfTVNSX1JRTTsKICAgICAgICAgICAgLyogTm93LCB3ZSBqdXN0IGhhdmUgdG8gd2FpdCBmb3IgdGhlIERNQSBjb250cm9sbGVyIHRvCiAgICAgICAgICAgICAqIHJlY2FsbCB1cy4uLgogICAgICAgICAgICAgKi8KICAgICAgICAgICAgRE1BX2hvbGRfRFJFUShmZGN0cmwtPmRtYV9jaGFubik7CiAgICAgICAgICAgIERNQV9zY2hlZHVsZShmZGN0cmwtPmRtYV9jaGFubik7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgICBGTE9QUFlfRVJST1IoImRtYV9tb2RlPSVkIGRpcmVjdGlvbj0lZFxuIiwgZG1hX21vZGUsIGRpcmVjdGlvbik7CiAgICAgICAgfQogICAgfQogICAgRkxPUFBZX0RQUklOVEYoInN0YXJ0IG5vbi1ETUEgdHJhbnNmZXJcbiIpOwogICAgZmRjdHJsLT5tc3IgfD0gRkRfTVNSX05PTkRNQTsKICAgIGlmIChkaXJlY3Rpb24gIT0gRkRfRElSX1dSSVRFKQogICAgICAgIGZkY3RybC0+bXNyIHw9IEZEX01TUl9ESU87CiAgICAvKiBJTyBiYXNlZCB0cmFuc2ZlcjogY2FsY3VsYXRlIGxlbiAqLwogICAgZmRjdHJsX3JhaXNlX2lycShmZGN0cmwsIDB4MDApOwoKICAgIHJldHVybjsKfQoKLyogUHJlcGFyZSBhIHRyYW5zZmVyIG9mIGRlbGV0ZWQgZGF0YSAqLwpzdGF0aWMgdm9pZCBmZGN0cmxfc3RhcnRfdHJhbnNmZXJfZGVsKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICBGTE9QUFlfRVJST1IoImZkY3RybF9zdGFydF90cmFuc2Zlcl9kZWwoKSB1bmltcGxlbWVudGVkXG4iKTsKCiAgICAvKiBXZSBkb24ndCBoYW5kbGUgZGVsZXRlZCBkYXRhLAogICAgICogc28gd2UgZG9uJ3QgcmV0dXJuICpBTllUSElORyoKICAgICAqLwogICAgZmRjdHJsX3N0b3BfdHJhbnNmZXIoZmRjdHJsLCBGRF9TUjBfQUJOVEVSTSB8IEZEX1NSMF9TRUVLLCAweDAwLCAweDAwKTsKfQoKLyogaGFuZGxlcnMgZm9yIERNQSB0cmFuc2ZlcnMgKi8Kc3RhdGljIGludCBmZGN0cmxfdHJhbnNmZXJfaGFuZGxlciAodm9pZCAqb3BhcXVlLCBpbnQgbmNoYW4sCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGludCBkbWFfcG9zLCBpbnQgZG1hX2xlbikKewogICAgRkRDdHJsICpmZGN0cmw7CiAgICBGRHJpdmUgKmN1cl9kcnY7CiAgICBpbnQgbGVuLCBzdGFydF9wb3MsIHJlbF9wb3M7CiAgICB1aW50OF90IHN0YXR1czAgPSAweDAwLCBzdGF0dXMxID0gMHgwMCwgc3RhdHVzMiA9IDB4MDA7CgogICAgZmRjdHJsID0gb3BhcXVlOwogICAgaWYgKGZkY3RybC0+bXNyICYgRkRfTVNSX1JRTSkgewogICAgICAgIEZMT1BQWV9EUFJJTlRGKCJOb3QgaW4gRE1BIHRyYW5zZmVyIG1vZGUgIVxuIik7CiAgICAgICAgcmV0dXJuIDA7CiAgICB9CiAgICBjdXJfZHJ2ID0gZ2V0X2N1cl9kcnYoZmRjdHJsKTsKICAgIGlmIChmZGN0cmwtPmRhdGFfZGlyID09IEZEX0RJUl9TQ0FORSB8fCBmZGN0cmwtPmRhdGFfZGlyID09IEZEX0RJUl9TQ0FOTCB8fAogICAgICAgIGZkY3RybC0+ZGF0YV9kaXIgPT0gRkRfRElSX1NDQU5IKQogICAgICAgIHN0YXR1czIgPSBGRF9TUjJfU05TOwogICAgaWYgKGRtYV9sZW4gPiBmZGN0cmwtPmRhdGFfbGVuKQogICAgICAgIGRtYV9sZW4gPSBmZGN0cmwtPmRhdGFfbGVuOwogICAgaWYgKGN1cl9kcnYtPmJzID09IE5VTEwpIHsKICAgICAgICBpZiAoZmRjdHJsLT5kYXRhX2RpciA9PSBGRF9ESVJfV1JJVEUpCiAgICAgICAgICAgIGZkY3RybF9zdG9wX3RyYW5zZmVyKGZkY3RybCwgRkRfU1IwX0FCTlRFUk0gfCBGRF9TUjBfU0VFSywgMHgwMCwgMHgwMCk7CiAgICAgICAgZWxzZQogICAgICAgICAgICBmZGN0cmxfc3RvcF90cmFuc2ZlcihmZGN0cmwsIEZEX1NSMF9BQk5URVJNLCAweDAwLCAweDAwKTsKICAgICAgICBsZW4gPSAwOwogICAgICAgIGdvdG8gdHJhbnNmZXJfZXJyb3I7CiAgICB9CiAgICByZWxfcG9zID0gZmRjdHJsLT5kYXRhX3BvcyAlIEZEX1NFQ1RPUl9MRU47CiAgICBmb3IgKHN0YXJ0X3BvcyA9IGZkY3RybC0+ZGF0YV9wb3M7IGZkY3RybC0+ZGF0YV9wb3MgPCBkbWFfbGVuOykgewogICAgICAgIGxlbiA9IGRtYV9sZW4gLSBmZGN0cmwtPmRhdGFfcG9zOwogICAgICAgIGlmIChsZW4gKyByZWxfcG9zID4gRkRfU0VDVE9SX0xFTikKICAgICAgICAgICAgbGVuID0gRkRfU0VDVE9SX0xFTiAtIHJlbF9wb3M7CiAgICAgICAgRkxPUFBZX0RQUklOVEYoImNvcHkgJWQgYnl0ZXMgKCVkICVkICVkKSAlZCBwb3MgJWQgJTAyeCAiCiAgICAgICAgICAgICAgICAgICAgICAgIiglZC0weCUwOHggMHglMDh4KVxuIiwgbGVuLCBkbWFfbGVuLCBmZGN0cmwtPmRhdGFfcG9zLAogICAgICAgICAgICAgICAgICAgICAgIGZkY3RybC0+ZGF0YV9sZW4sIEdFVF9DVVJfRFJWKGZkY3RybCksIGN1cl9kcnYtPmhlYWQsCiAgICAgICAgICAgICAgICAgICAgICAgY3VyX2Rydi0+dHJhY2ssIGN1cl9kcnYtPnNlY3QsIGZkX3NlY3RvcihjdXJfZHJ2KSwKICAgICAgICAgICAgICAgICAgICAgICBmZF9zZWN0b3IoY3VyX2RydikgKiBGRF9TRUNUT1JfTEVOKTsKICAgICAgICBpZiAoZmRjdHJsLT5kYXRhX2RpciAhPSBGRF9ESVJfV1JJVEUgfHwKICAgICAgICAgICAgbGVuIDwgRkRfU0VDVE9SX0xFTiB8fCByZWxfcG9zICE9IDApIHsKICAgICAgICAgICAgLyogUkVBRCAmIFNDQU4gY29tbWFuZHMgYW5kIHJlYWxpZ24gdG8gYSBzZWN0b3IgZm9yIFdSSVRFICovCiAgICAgICAgICAgIGlmIChiZHJ2X3JlYWQoY3VyX2Rydi0+YnMsIGZkX3NlY3RvcihjdXJfZHJ2KSwKICAgICAgICAgICAgICAgICAgICAgICAgICBmZGN0cmwtPmZpZm8sIDEpIDwgMCkgewogICAgICAgICAgICAgICAgRkxPUFBZX0RQUklOVEYoIkZsb3BweTogZXJyb3IgZ2V0dGluZyBzZWN0b3IgJWRcbiIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBmZF9zZWN0b3IoY3VyX2RydikpOwogICAgICAgICAgICAgICAgLyogU3VyZSwgaW1hZ2Ugc2l6ZSBpcyB0b28gc21hbGwuLi4gKi8KICAgICAgICAgICAgICAgIG1lbXNldChmZGN0cmwtPmZpZm8sIDAsIEZEX1NFQ1RPUl9MRU4pOwogICAgICAgICAgICB9CiAgICAgICAgfQogICAgICAgIHN3aXRjaCAoZmRjdHJsLT5kYXRhX2RpcikgewogICAgICAgIGNhc2UgRkRfRElSX1JFQUQ6CiAgICAgICAgICAgIC8qIFJFQUQgY29tbWFuZHMgKi8KICAgICAgICAgICAgRE1BX3dyaXRlX21lbW9yeSAobmNoYW4sIGZkY3RybC0+ZmlmbyArIHJlbF9wb3MsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZkY3RybC0+ZGF0YV9wb3MsIGxlbik7CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgRkRfRElSX1dSSVRFOgogICAgICAgICAgICAvKiBXUklURSBjb21tYW5kcyAqLwogICAgICAgICAgICBETUFfcmVhZF9tZW1vcnkgKG5jaGFuLCBmZGN0cmwtPmZpZm8gKyByZWxfcG9zLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZkY3RybC0+ZGF0YV9wb3MsIGxlbik7CiAgICAgICAgICAgIGlmIChiZHJ2X3dyaXRlKGN1cl9kcnYtPmJzLCBmZF9zZWN0b3IoY3VyX2RydiksCiAgICAgICAgICAgICAgICAgICAgICAgICAgIGZkY3RybC0+ZmlmbywgMSkgPCAwKSB7CiAgICAgICAgICAgICAgICBGTE9QUFlfRVJST1IoIndyaXRpbmcgc2VjdG9yICVkXG4iLCBmZF9zZWN0b3IoY3VyX2RydikpOwogICAgICAgICAgICAgICAgZmRjdHJsX3N0b3BfdHJhbnNmZXIoZmRjdHJsLCBGRF9TUjBfQUJOVEVSTSB8IEZEX1NSMF9TRUVLLCAweDAwLCAweDAwKTsKICAgICAgICAgICAgICAgIGdvdG8gdHJhbnNmZXJfZXJyb3I7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgYnJlYWs7CiAgICAgICAgZGVmYXVsdDoKICAgICAgICAgICAgLyogU0NBTiBjb21tYW5kcyAqLwogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICB1aW50OF90IHRtcGJ1ZltGRF9TRUNUT1JfTEVOXTsKICAgICAgICAgICAgICAgIGludCByZXQ7CiAgICAgICAgICAgICAgICBETUFfcmVhZF9tZW1vcnkgKG5jaGFuLCB0bXBidWYsIGZkY3RybC0+ZGF0YV9wb3MsIGxlbik7CiAgICAgICAgICAgICAgICByZXQgPSBtZW1jbXAodG1wYnVmLCBmZGN0cmwtPmZpZm8gKyByZWxfcG9zLCBsZW4pOwogICAgICAgICAgICAgICAgaWYgKHJldCA9PSAwKSB7CiAgICAgICAgICAgICAgICAgICAgc3RhdHVzMiA9IEZEX1NSMl9TRUg7CiAgICAgICAgICAgICAgICAgICAgZ290byBlbmRfdHJhbnNmZXI7CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgICAgICBpZiAoKHJldCA8IDAgJiYgZmRjdHJsLT5kYXRhX2RpciA9PSBGRF9ESVJfU0NBTkwpIHx8CiAgICAgICAgICAgICAgICAgICAgKHJldCA+IDAgJiYgZmRjdHJsLT5kYXRhX2RpciA9PSBGRF9ESVJfU0NBTkgpKSB7CiAgICAgICAgICAgICAgICAgICAgc3RhdHVzMiA9IDB4MDA7CiAgICAgICAgICAgICAgICAgICAgZ290byBlbmRfdHJhbnNmZXI7CiAgICAgICAgICAgICAgICB9CiAgICAgICAgICAgIH0KICAgICAgICAgICAgYnJlYWs7CiAgICAgICAgfQogICAgICAgIGZkY3RybC0+ZGF0YV9wb3MgKz0gbGVuOwogICAgICAgIHJlbF9wb3MgPSBmZGN0cmwtPmRhdGFfcG9zICUgRkRfU0VDVE9SX0xFTjsKICAgICAgICBpZiAocmVsX3BvcyA9PSAwKSB7CiAgICAgICAgICAgIC8qIFNlZWsgdG8gbmV4dCBzZWN0b3IgKi8KICAgICAgICAgICAgaWYgKCFmZGN0cmxfc2Vla190b19uZXh0X3NlY3QoZmRjdHJsLCBjdXJfZHJ2KSkKICAgICAgICAgICAgICAgIGJyZWFrOwogICAgICAgIH0KICAgIH0KIGVuZF90cmFuc2ZlcjoKICAgIGxlbiA9IGZkY3RybC0+ZGF0YV9wb3MgLSBzdGFydF9wb3M7CiAgICBGTE9QUFlfRFBSSU5URigiZW5kIHRyYW5zZmVyICVkICVkICVkXG4iLAogICAgICAgICAgICAgICAgICAgZmRjdHJsLT5kYXRhX3BvcywgbGVuLCBmZGN0cmwtPmRhdGFfbGVuKTsKICAgIGlmIChmZGN0cmwtPmRhdGFfZGlyID09IEZEX0RJUl9TQ0FORSB8fAogICAgICAgIGZkY3RybC0+ZGF0YV9kaXIgPT0gRkRfRElSX1NDQU5MIHx8CiAgICAgICAgZmRjdHJsLT5kYXRhX2RpciA9PSBGRF9ESVJfU0NBTkgpCiAgICAgICAgc3RhdHVzMiA9IEZEX1NSMl9TRUg7CiAgICBpZiAoRkRfRElEX1NFRUsoZmRjdHJsLT5kYXRhX3N0YXRlKSkKICAgICAgICBzdGF0dXMwIHw9IEZEX1NSMF9TRUVLOwogICAgZmRjdHJsLT5kYXRhX2xlbiAtPSBsZW47CiAgICBmZGN0cmxfc3RvcF90cmFuc2ZlcihmZGN0cmwsIHN0YXR1czAsIHN0YXR1czEsIHN0YXR1czIpOwogdHJhbnNmZXJfZXJyb3I6CgogICAgcmV0dXJuIGxlbjsKfQoKLyogRGF0YSByZWdpc3RlciA6IDB4MDUgKi8Kc3RhdGljIHVpbnQzMl90IGZkY3RybF9yZWFkX2RhdGEoRkRDdHJsICpmZGN0cmwpCnsKICAgIEZEcml2ZSAqY3VyX2RydjsKICAgIHVpbnQzMl90IHJldHZhbCA9IDA7CiAgICBpbnQgcG9zOwoKICAgIGN1cl9kcnYgPSBnZXRfY3VyX2RydihmZGN0cmwpOwogICAgZmRjdHJsLT5kc3IgJj0gfkZEX0RTUl9QV1JET1dOOwogICAgaWYgKCEoZmRjdHJsLT5tc3IgJiBGRF9NU1JfUlFNKSB8fCAhKGZkY3RybC0+bXNyICYgRkRfTVNSX0RJTykpIHsKICAgICAgICBGTE9QUFlfRVJST1IoImNvbnRyb2xsZXIgbm90IHJlYWR5IGZvciByZWFkaW5nXG4iKTsKICAgICAgICByZXR1cm4gMDsKICAgIH0KICAgIHBvcyA9IGZkY3RybC0+ZGF0YV9wb3M7CiAgICBpZiAoZmRjdHJsLT5tc3IgJiBGRF9NU1JfTk9ORE1BKSB7CiAgICAgICAgcG9zICU9IEZEX1NFQ1RPUl9MRU47CiAgICAgICAgaWYgKHBvcyA9PSAwKSB7CiAgICAgICAgICAgIGlmIChmZGN0cmwtPmRhdGFfcG9zICE9IDApCiAgICAgICAgICAgICAgICBpZiAoIWZkY3RybF9zZWVrX3RvX25leHRfc2VjdChmZGN0cmwsIGN1cl9kcnYpKSB7CiAgICAgICAgICAgICAgICAgICAgRkxPUFBZX0RQUklOVEYoImVycm9yIHNlZWtpbmcgdG8gbmV4dCBzZWN0b3IgJWRcbiIsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZmRfc2VjdG9yKGN1cl9kcnYpKTsKICAgICAgICAgICAgICAgICAgICByZXR1cm4gMDsKICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgaWYgKGJkcnZfcmVhZChjdXJfZHJ2LT5icywgZmRfc2VjdG9yKGN1cl9kcnYpLCBmZGN0cmwtPmZpZm8sIDEpIDwgMCkgewogICAgICAgICAgICAgICAgRkxPUFBZX0RQUklOVEYoImVycm9yIGdldHRpbmcgc2VjdG9yICVkXG4iLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZmRfc2VjdG9yKGN1cl9kcnYpKTsKICAgICAgICAgICAgICAgIC8qIFN1cmUsIGltYWdlIHNpemUgaXMgdG9vIHNtYWxsLi4uICovCiAgICAgICAgICAgICAgICBtZW1zZXQoZmRjdHJsLT5maWZvLCAwLCBGRF9TRUNUT1JfTEVOKTsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgIH0KICAgIHJldHZhbCA9IGZkY3RybC0+Zmlmb1twb3NdOwogICAgaWYgKCsrZmRjdHJsLT5kYXRhX3BvcyA9PSBmZGN0cmwtPmRhdGFfbGVuKSB7CiAgICAgICAgZmRjdHJsLT5kYXRhX3BvcyA9IDA7CiAgICAgICAgLyogU3dpdGNoIGZyb20gdHJhbnNmZXIgbW9kZSB0byBzdGF0dXMgbW9kZQogICAgICAgICAqIHRoZW4gZnJvbSBzdGF0dXMgbW9kZSB0byBjb21tYW5kIG1vZGUKICAgICAgICAgKi8KICAgICAgICBpZiAoZmRjdHJsLT5tc3IgJiBGRF9NU1JfTk9ORE1BKSB7CiAgICAgICAgICAgIGZkY3RybF9zdG9wX3RyYW5zZmVyKGZkY3RybCwgRkRfU1IwX1NFRUssIDB4MDAsIDB4MDApOwogICAgICAgIH0gZWxzZSB7CiAgICAgICAgICAgIGZkY3RybF9yZXNldF9maWZvKGZkY3RybCk7CiAgICAgICAgICAgIGZkY3RybF9yZXNldF9pcnEoZmRjdHJsKTsKICAgICAgICB9CiAgICB9CiAgICBGTE9QUFlfRFBSSU5URigiZGF0YSByZWdpc3RlcjogMHglMDJ4XG4iLCByZXR2YWwpOwoKICAgIHJldHVybiByZXR2YWw7Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9mb3JtYXRfc2VjdG9yKEZEQ3RybCAqZmRjdHJsKQp7CiAgICBGRHJpdmUgKmN1cl9kcnY7CiAgICB1aW50OF90IGtoLCBrdCwga3M7CgogICAgU0VUX0NVUl9EUlYoZmRjdHJsLCBmZGN0cmwtPmZpZm9bMV0gJiBGRF9ET1JfU0VMTUFTSyk7CiAgICBjdXJfZHJ2ID0gZ2V0X2N1cl9kcnYoZmRjdHJsKTsKICAgIGt0ID0gZmRjdHJsLT5maWZvWzZdOwogICAga2ggPSBmZGN0cmwtPmZpZm9bN107CiAgICBrcyA9IGZkY3RybC0+Zmlmb1s4XTsKICAgIEZMT1BQWV9EUFJJTlRGKCJmb3JtYXQgc2VjdG9yIGF0ICVkICVkICUwMnggJTAyeCAoJWQpXG4iLAogICAgICAgICAgICAgICAgICAgR0VUX0NVUl9EUlYoZmRjdHJsKSwga2gsIGt0LCBrcywKICAgICAgICAgICAgICAgICAgIGZkX3NlY3Rvcl9jYWxjKGtoLCBrdCwga3MsIGN1cl9kcnYtPmxhc3Rfc2VjdCkpOwogICAgc3dpdGNoIChmZF9zZWVrKGN1cl9kcnYsIGtoLCBrdCwga3MsIGZkY3RybC0+Y29uZmlnICYgRkRfQ09ORklHX0VJUykpIHsKICAgIGNhc2UgMjoKICAgICAgICAvKiBzZWN0IHRvbyBiaWcgKi8KICAgICAgICBmZGN0cmxfc3RvcF90cmFuc2ZlcihmZGN0cmwsIEZEX1NSMF9BQk5URVJNLCAweDAwLCAweDAwKTsKICAgICAgICBmZGN0cmwtPmZpZm9bM10gPSBrdDsKICAgICAgICBmZGN0cmwtPmZpZm9bNF0gPSBraDsKICAgICAgICBmZGN0cmwtPmZpZm9bNV0gPSBrczsKICAgICAgICByZXR1cm47CiAgICBjYXNlIDM6CiAgICAgICAgLyogdHJhY2sgdG9vIGJpZyAqLwogICAgICAgIGZkY3RybF9zdG9wX3RyYW5zZmVyKGZkY3RybCwgRkRfU1IwX0FCTlRFUk0sIEZEX1NSMV9FQywgMHgwMCk7CiAgICAgICAgZmRjdHJsLT5maWZvWzNdID0ga3Q7CiAgICAgICAgZmRjdHJsLT5maWZvWzRdID0ga2g7CiAgICAgICAgZmRjdHJsLT5maWZvWzVdID0ga3M7CiAgICAgICAgcmV0dXJuOwogICAgY2FzZSA0OgogICAgICAgIC8qIE5vIHNlZWsgZW5hYmxlZCAqLwogICAgICAgIGZkY3RybF9zdG9wX3RyYW5zZmVyKGZkY3RybCwgRkRfU1IwX0FCTlRFUk0sIDB4MDAsIDB4MDApOwogICAgICAgIGZkY3RybC0+Zmlmb1szXSA9IGt0OwogICAgICAgIGZkY3RybC0+Zmlmb1s0XSA9IGtoOwogICAgICAgIGZkY3RybC0+Zmlmb1s1XSA9IGtzOwogICAgICAgIHJldHVybjsKICAgIGNhc2UgMToKICAgICAgICBmZGN0cmwtPmRhdGFfc3RhdGUgfD0gRkRfU1RBVEVfU0VFSzsKICAgICAgICBicmVhazsKICAgIGRlZmF1bHQ6CiAgICAgICAgYnJlYWs7CiAgICB9CiAgICBtZW1zZXQoZmRjdHJsLT5maWZvLCAwLCBGRF9TRUNUT1JfTEVOKTsKICAgIGlmIChjdXJfZHJ2LT5icyA9PSBOVUxMIHx8CiAgICAgICAgYmRydl93cml0ZShjdXJfZHJ2LT5icywgZmRfc2VjdG9yKGN1cl9kcnYpLCBmZGN0cmwtPmZpZm8sIDEpIDwgMCkgewogICAgICAgIEZMT1BQWV9FUlJPUigiZm9ybWF0dGluZyBzZWN0b3IgJWRcbiIsIGZkX3NlY3RvcihjdXJfZHJ2KSk7CiAgICAgICAgZmRjdHJsX3N0b3BfdHJhbnNmZXIoZmRjdHJsLCBGRF9TUjBfQUJOVEVSTSB8IEZEX1NSMF9TRUVLLCAweDAwLCAweDAwKTsKICAgIH0gZWxzZSB7CiAgICAgICAgaWYgKGN1cl9kcnYtPnNlY3QgPT0gY3VyX2Rydi0+bGFzdF9zZWN0KSB7CiAgICAgICAgICAgIGZkY3RybC0+ZGF0YV9zdGF0ZSAmPSB+RkRfU1RBVEVfRk9STUFUOwogICAgICAgICAgICAvKiBMYXN0IHNlY3RvciBkb25lICovCiAgICAgICAgICAgIGlmIChGRF9ESURfU0VFSyhmZGN0cmwtPmRhdGFfc3RhdGUpKQogICAgICAgICAgICAgICAgZmRjdHJsX3N0b3BfdHJhbnNmZXIoZmRjdHJsLCBGRF9TUjBfU0VFSywgMHgwMCwgMHgwMCk7CiAgICAgICAgICAgIGVsc2UKICAgICAgICAgICAgICAgIGZkY3RybF9zdG9wX3RyYW5zZmVyKGZkY3RybCwgMHgwMCwgMHgwMCwgMHgwMCk7CiAgICAgICAgfSBlbHNlIHsKICAgICAgICAgICAgLyogTW9yZSB0byBkbyAqLwogICAgICAgICAgICBmZGN0cmwtPmRhdGFfcG9zID0gMDsKICAgICAgICAgICAgZmRjdHJsLT5kYXRhX2xlbiA9IDQ7CiAgICAgICAgfQogICAgfQp9CgpzdGF0aWMgdm9pZCBmZGN0cmxfaGFuZGxlX2xvY2soRkRDdHJsICpmZGN0cmwsIGludCBkaXJlY3Rpb24pCnsKICAgIGZkY3RybC0+bG9jayA9IChmZGN0cmwtPmZpZm9bMF0gJiAweDgwKSA/IDEgOiAwOwogICAgZmRjdHJsLT5maWZvWzBdID0gZmRjdHJsLT5sb2NrIDw8IDQ7CiAgICBmZGN0cmxfc2V0X2ZpZm8oZmRjdHJsLCAxLCBmZGN0cmwtPmxvY2spOwp9CgpzdGF0aWMgdm9pZCBmZGN0cmxfaGFuZGxlX2R1bXByZWcoRkRDdHJsICpmZGN0cmwsIGludCBkaXJlY3Rpb24pCnsKICAgIEZEcml2ZSAqY3VyX2RydiA9IGdldF9jdXJfZHJ2KGZkY3RybCk7CgogICAgLyogRHJpdmVzIHBvc2l0aW9uICovCiAgICBmZGN0cmwtPmZpZm9bMF0gPSBkcnYwKGZkY3RybCktPnRyYWNrOwogICAgZmRjdHJsLT5maWZvWzFdID0gZHJ2MShmZGN0cmwpLT50cmFjazsKI2lmIE1BWF9GRCA9PSA0CiAgICBmZGN0cmwtPmZpZm9bMl0gPSBkcnYyKGZkY3RybCktPnRyYWNrOwogICAgZmRjdHJsLT5maWZvWzNdID0gZHJ2MyhmZGN0cmwpLT50cmFjazsKI2Vsc2UKICAgIGZkY3RybC0+Zmlmb1syXSA9IDA7CiAgICBmZGN0cmwtPmZpZm9bM10gPSAwOwojZW5kaWYKICAgIC8qIHRpbWVycyAqLwogICAgZmRjdHJsLT5maWZvWzRdID0gZmRjdHJsLT50aW1lcjA7CiAgICBmZGN0cmwtPmZpZm9bNV0gPSAoZmRjdHJsLT50aW1lcjEgPDwgMSkgfCAoZmRjdHJsLT5kb3IgJiBGRF9ET1JfRE1BRU4gPyAxIDogMCk7CiAgICBmZGN0cmwtPmZpZm9bNl0gPSBjdXJfZHJ2LT5sYXN0X3NlY3Q7CiAgICBmZGN0cmwtPmZpZm9bN10gPSAoZmRjdHJsLT5sb2NrIDw8IDcpIHwKICAgICAgICAoY3VyX2Rydi0+cGVycGVuZGljdWxhciA8PCAyKTsKICAgIGZkY3RybC0+Zmlmb1s4XSA9IGZkY3RybC0+Y29uZmlnOwogICAgZmRjdHJsLT5maWZvWzldID0gZmRjdHJsLT5wcmVjb21wX3RyazsKICAgIGZkY3RybF9zZXRfZmlmbyhmZGN0cmwsIDEwLCAwKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV92ZXJzaW9uKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICAvKiBDb250cm9sbGVyJ3MgdmVyc2lvbiAqLwogICAgZmRjdHJsLT5maWZvWzBdID0gZmRjdHJsLT52ZXJzaW9uOwogICAgZmRjdHJsX3NldF9maWZvKGZkY3RybCwgMSwgMSk7Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9oYW5kbGVfcGFydGlkKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICBmZGN0cmwtPmZpZm9bMF0gPSAweDQxOyAvKiBTdGVwcGluZyAxICovCiAgICBmZGN0cmxfc2V0X2ZpZm8oZmRjdHJsLCAxLCAwKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV9yZXN0b3JlKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICBGRHJpdmUgKmN1cl9kcnYgPSBnZXRfY3VyX2RydihmZGN0cmwpOwoKICAgIC8qIERyaXZlcyBwb3NpdGlvbiAqLwogICAgZHJ2MChmZGN0cmwpLT50cmFjayA9IGZkY3RybC0+Zmlmb1szXTsKICAgIGRydjEoZmRjdHJsKS0+dHJhY2sgPSBmZGN0cmwtPmZpZm9bNF07CiNpZiBNQVhfRkQgPT0gNAogICAgZHJ2MihmZGN0cmwpLT50cmFjayA9IGZkY3RybC0+Zmlmb1s1XTsKICAgIGRydjMoZmRjdHJsKS0+dHJhY2sgPSBmZGN0cmwtPmZpZm9bNl07CiNlbmRpZgogICAgLyogdGltZXJzICovCiAgICBmZGN0cmwtPnRpbWVyMCA9IGZkY3RybC0+Zmlmb1s3XTsKICAgIGZkY3RybC0+dGltZXIxID0gZmRjdHJsLT5maWZvWzhdOwogICAgY3VyX2Rydi0+bGFzdF9zZWN0ID0gZmRjdHJsLT5maWZvWzldOwogICAgZmRjdHJsLT5sb2NrID0gZmRjdHJsLT5maWZvWzEwXSA+PiA3OwogICAgY3VyX2Rydi0+cGVycGVuZGljdWxhciA9IChmZGN0cmwtPmZpZm9bMTBdID4+IDIpICYgMHhGOwogICAgZmRjdHJsLT5jb25maWcgPSBmZGN0cmwtPmZpZm9bMTFdOwogICAgZmRjdHJsLT5wcmVjb21wX3RyayA9IGZkY3RybC0+Zmlmb1sxMl07CiAgICBmZGN0cmwtPnB3cmQgPSBmZGN0cmwtPmZpZm9bMTNdOwogICAgZmRjdHJsX3Jlc2V0X2ZpZm8oZmRjdHJsKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV9zYXZlKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICBGRHJpdmUgKmN1cl9kcnYgPSBnZXRfY3VyX2RydihmZGN0cmwpOwoKICAgIGZkY3RybC0+Zmlmb1swXSA9IDA7CiAgICBmZGN0cmwtPmZpZm9bMV0gPSAwOwogICAgLyogRHJpdmVzIHBvc2l0aW9uICovCiAgICBmZGN0cmwtPmZpZm9bMl0gPSBkcnYwKGZkY3RybCktPnRyYWNrOwogICAgZmRjdHJsLT5maWZvWzNdID0gZHJ2MShmZGN0cmwpLT50cmFjazsKI2lmIE1BWF9GRCA9PSA0CiAgICBmZGN0cmwtPmZpZm9bNF0gPSBkcnYyKGZkY3RybCktPnRyYWNrOwogICAgZmRjdHJsLT5maWZvWzVdID0gZHJ2MyhmZGN0cmwpLT50cmFjazsKI2Vsc2UKICAgIGZkY3RybC0+Zmlmb1s0XSA9IDA7CiAgICBmZGN0cmwtPmZpZm9bNV0gPSAwOwojZW5kaWYKICAgIC8qIHRpbWVycyAqLwogICAgZmRjdHJsLT5maWZvWzZdID0gZmRjdHJsLT50aW1lcjA7CiAgICBmZGN0cmwtPmZpZm9bN10gPSBmZGN0cmwtPnRpbWVyMTsKICAgIGZkY3RybC0+Zmlmb1s4XSA9IGN1cl9kcnYtPmxhc3Rfc2VjdDsKICAgIGZkY3RybC0+Zmlmb1s5XSA9IChmZGN0cmwtPmxvY2sgPDwgNykgfAogICAgICAgIChjdXJfZHJ2LT5wZXJwZW5kaWN1bGFyIDw8IDIpOwogICAgZmRjdHJsLT5maWZvWzEwXSA9IGZkY3RybC0+Y29uZmlnOwogICAgZmRjdHJsLT5maWZvWzExXSA9IGZkY3RybC0+cHJlY29tcF90cms7CiAgICBmZGN0cmwtPmZpZm9bMTJdID0gZmRjdHJsLT5wd3JkOwogICAgZmRjdHJsLT5maWZvWzEzXSA9IDA7CiAgICBmZGN0cmwtPmZpZm9bMTRdID0gMDsKICAgIGZkY3RybF9zZXRfZmlmbyhmZGN0cmwsIDE1LCAxKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV9yZWFkaWQoRkRDdHJsICpmZGN0cmwsIGludCBkaXJlY3Rpb24pCnsKICAgIEZEcml2ZSAqY3VyX2RydiA9IGdldF9jdXJfZHJ2KGZkY3RybCk7CgogICAgLyogWFhYOiBzaG91bGQgc2V0IG1haW4gc3RhdHVzIHJlZ2lzdGVyIHRvIGJ1c3kgKi8KICAgIGN1cl9kcnYtPmhlYWQgPSAoZmRjdHJsLT5maWZvWzFdID4+IDIpICYgMTsKICAgIHFlbXVfbW9kX3RpbWVyKGZkY3RybC0+cmVzdWx0X3RpbWVyLAogICAgICAgICAgICAgICAgICAgcWVtdV9nZXRfY2xvY2sodm1fY2xvY2spICsgKGdldF90aWNrc19wZXJfc2VjKCkgLyA1MCkpOwp9CgpzdGF0aWMgdm9pZCBmZGN0cmxfaGFuZGxlX2Zvcm1hdF90cmFjayhGREN0cmwgKmZkY3RybCwgaW50IGRpcmVjdGlvbikKewogICAgRkRyaXZlICpjdXJfZHJ2OwoKICAgIFNFVF9DVVJfRFJWKGZkY3RybCwgZmRjdHJsLT5maWZvWzFdICYgRkRfRE9SX1NFTE1BU0spOwogICAgY3VyX2RydiA9IGdldF9jdXJfZHJ2KGZkY3RybCk7CiAgICBmZGN0cmwtPmRhdGFfc3RhdGUgfD0gRkRfU1RBVEVfRk9STUFUOwogICAgaWYgKGZkY3RybC0+Zmlmb1swXSAmIDB4ODApCiAgICAgICAgZmRjdHJsLT5kYXRhX3N0YXRlIHw9IEZEX1NUQVRFX01VTFRJOwogICAgZWxzZQogICAgICAgIGZkY3RybC0+ZGF0YV9zdGF0ZSAmPSB+RkRfU1RBVEVfTVVMVEk7CiAgICBmZGN0cmwtPmRhdGFfc3RhdGUgJj0gfkZEX1NUQVRFX1NFRUs7CiAgICBjdXJfZHJ2LT5icHMgPQogICAgICAgIGZkY3RybC0+Zmlmb1syXSA+IDcgPyAxNjM4NCA6IDEyOCA8PCBmZGN0cmwtPmZpZm9bMl07CiNpZiAwCiAgICBjdXJfZHJ2LT5sYXN0X3NlY3QgPQogICAgICAgIGN1cl9kcnYtPmZsYWdzICYgRkRJU0tfREJMX1NJREVTID8gZmRjdHJsLT5maWZvWzNdIDoKICAgICAgICBmZGN0cmwtPmZpZm9bM10gLyAyOwojZWxzZQogICAgY3VyX2Rydi0+bGFzdF9zZWN0ID0gZmRjdHJsLT5maWZvWzNdOwojZW5kaWYKICAgIC8qIFRPRE86IGltcGxlbWVudCBmb3JtYXQgdXNpbmcgRE1BIGV4cGVjdGVkIGJ5IHRoZSBCb2NocyBCSU9TCiAgICAgKiBhbmQgTGludXggZmRmb3JtYXQgKHJlYWQgMyBieXRlcyBwZXIgc2VjdG9yIHZpYSBETUEgYW5kIGZpbGwKICAgICAqIHRoZSBzZWN0b3Igd2l0aCB0aGUgc3BlY2lmaWVkIGZpbGwgYnl0ZQogICAgICovCiAgICBmZGN0cmwtPmRhdGFfc3RhdGUgJj0gfkZEX1NUQVRFX0ZPUk1BVDsKICAgIGZkY3RybF9zdG9wX3RyYW5zZmVyKGZkY3RybCwgMHgwMCwgMHgwMCwgMHgwMCk7Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9oYW5kbGVfc3BlY2lmeShGREN0cmwgKmZkY3RybCwgaW50IGRpcmVjdGlvbikKewogICAgZmRjdHJsLT50aW1lcjAgPSAoZmRjdHJsLT5maWZvWzFdID4+IDQpICYgMHhGOwogICAgZmRjdHJsLT50aW1lcjEgPSBmZGN0cmwtPmZpZm9bMl0gPj4gMTsKICAgIGlmIChmZGN0cmwtPmZpZm9bMl0gJiAxKQogICAgICAgIGZkY3RybC0+ZG9yICY9IH5GRF9ET1JfRE1BRU47CiAgICBlbHNlCiAgICAgICAgZmRjdHJsLT5kb3IgfD0gRkRfRE9SX0RNQUVOOwogICAgLyogTm8gcmVzdWx0IGJhY2sgKi8KICAgIGZkY3RybF9yZXNldF9maWZvKGZkY3RybCk7Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9oYW5kbGVfc2Vuc2VfZHJpdmVfc3RhdHVzKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICBGRHJpdmUgKmN1cl9kcnY7CgogICAgU0VUX0NVUl9EUlYoZmRjdHJsLCBmZGN0cmwtPmZpZm9bMV0gJiBGRF9ET1JfU0VMTUFTSyk7CiAgICBjdXJfZHJ2ID0gZ2V0X2N1cl9kcnYoZmRjdHJsKTsKICAgIGN1cl9kcnYtPmhlYWQgPSAoZmRjdHJsLT5maWZvWzFdID4+IDIpICYgMTsKICAgIC8qIDEgQnl0ZSBzdGF0dXMgYmFjayAqLwogICAgZmRjdHJsLT5maWZvWzBdID0gKGN1cl9kcnYtPnJvIDw8IDYpIHwKICAgICAgICAoY3VyX2Rydi0+dHJhY2sgPT0gMCA/IDB4MTAgOiAweDAwKSB8CiAgICAgICAgKGN1cl9kcnYtPmhlYWQgPDwgMikgfAogICAgICAgIEdFVF9DVVJfRFJWKGZkY3RybCkgfAogICAgICAgIDB4Mjg7CiAgICBmZGN0cmxfc2V0X2ZpZm8oZmRjdHJsLCAxLCAwKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV9yZWNhbGlicmF0ZShGREN0cmwgKmZkY3RybCwgaW50IGRpcmVjdGlvbikKewogICAgRkRyaXZlICpjdXJfZHJ2OwoKICAgIFNFVF9DVVJfRFJWKGZkY3RybCwgZmRjdHJsLT5maWZvWzFdICYgRkRfRE9SX1NFTE1BU0spOwogICAgY3VyX2RydiA9IGdldF9jdXJfZHJ2KGZkY3RybCk7CiAgICBmZF9yZWNhbGlicmF0ZShjdXJfZHJ2KTsKICAgIGZkY3RybF9yZXNldF9maWZvKGZkY3RybCk7CiAgICAvKiBSYWlzZSBJbnRlcnJ1cHQgKi8KICAgIGZkY3RybF9yYWlzZV9pcnEoZmRjdHJsLCBGRF9TUjBfU0VFSyk7Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9oYW5kbGVfc2Vuc2VfaW50ZXJydXB0X3N0YXR1cyhGREN0cmwgKmZkY3RybCwgaW50IGRpcmVjdGlvbikKewogICAgRkRyaXZlICpjdXJfZHJ2ID0gZ2V0X2N1cl9kcnYoZmRjdHJsKTsKCiAgICBpZihmZGN0cmwtPnJlc2V0X3NlbnNlaSA+IDApIHsKICAgICAgICBmZGN0cmwtPmZpZm9bMF0gPQogICAgICAgICAgICBGRF9TUjBfUkRZQ0hHICsgRkRfUkVTRVRfU0VOU0VJX0NPVU5UIC0gZmRjdHJsLT5yZXNldF9zZW5zZWk7CiAgICAgICAgZmRjdHJsLT5yZXNldF9zZW5zZWktLTsKICAgIH0gZWxzZSB7CiAgICAgICAgLyogWFhYOiBzdGF0dXMwIGhhbmRsaW5nIGlzIGJyb2tlbiBmb3IgcmVhZC93cml0ZQogICAgICAgICAgIGNvbW1hbmRzLCBzbyB3ZSBkbyB0aGlzIGhhY2suIEl0IHNob3VsZCBiZSBzdXBwcmVzc2VkCiAgICAgICAgICAgQVNBUCAqLwogICAgICAgIGZkY3RybC0+Zmlmb1swXSA9CiAgICAgICAgICAgIEZEX1NSMF9TRUVLIHwgKGN1cl9kcnYtPmhlYWQgPDwgMikgfCBHRVRfQ1VSX0RSVihmZGN0cmwpOwogICAgfQoKICAgIGZkY3RybC0+Zmlmb1sxXSA9IGN1cl9kcnYtPnRyYWNrOwogICAgZmRjdHJsX3NldF9maWZvKGZkY3RybCwgMiwgMCk7CiAgICBmZGN0cmxfcmVzZXRfaXJxKGZkY3RybCk7CiAgICBmZGN0cmwtPnN0YXR1czAgPSBGRF9TUjBfUkRZQ0hHOwp9CgpzdGF0aWMgdm9pZCBmZGN0cmxfaGFuZGxlX3NlZWsoRkRDdHJsICpmZGN0cmwsIGludCBkaXJlY3Rpb24pCnsKICAgIEZEcml2ZSAqY3VyX2RydjsKCiAgICBTRVRfQ1VSX0RSVihmZGN0cmwsIGZkY3RybC0+Zmlmb1sxXSAmIEZEX0RPUl9TRUxNQVNLKTsKICAgIGN1cl9kcnYgPSBnZXRfY3VyX2RydihmZGN0cmwpOwogICAgZmRjdHJsX3Jlc2V0X2ZpZm8oZmRjdHJsKTsKICAgIGlmIChmZGN0cmwtPmZpZm9bMl0gPiBjdXJfZHJ2LT5tYXhfdHJhY2spIHsKICAgICAgICBmZGN0cmxfcmFpc2VfaXJxKGZkY3RybCwgRkRfU1IwX0FCTlRFUk0gfCBGRF9TUjBfU0VFSyk7CiAgICB9IGVsc2UgewogICAgICAgIGN1cl9kcnYtPnRyYWNrID0gZmRjdHJsLT5maWZvWzJdOwogICAgICAgIC8qIFJhaXNlIEludGVycnVwdCAqLwogICAgICAgIGZkY3RybF9yYWlzZV9pcnEoZmRjdHJsLCBGRF9TUjBfU0VFSyk7CiAgICB9Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9oYW5kbGVfcGVycGVuZGljdWxhcl9tb2RlKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICBGRHJpdmUgKmN1cl9kcnYgPSBnZXRfY3VyX2RydihmZGN0cmwpOwoKICAgIGlmIChmZGN0cmwtPmZpZm9bMV0gJiAweDgwKQogICAgICAgIGN1cl9kcnYtPnBlcnBlbmRpY3VsYXIgPSBmZGN0cmwtPmZpZm9bMV0gJiAweDc7CiAgICAvKiBObyByZXN1bHQgYmFjayAqLwogICAgZmRjdHJsX3Jlc2V0X2ZpZm8oZmRjdHJsKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV9jb25maWd1cmUoRkRDdHJsICpmZGN0cmwsIGludCBkaXJlY3Rpb24pCnsKICAgIGZkY3RybC0+Y29uZmlnID0gZmRjdHJsLT5maWZvWzJdOwogICAgZmRjdHJsLT5wcmVjb21wX3RyayA9ICBmZGN0cmwtPmZpZm9bM107CiAgICAvKiBObyByZXN1bHQgYmFjayAqLwogICAgZmRjdHJsX3Jlc2V0X2ZpZm8oZmRjdHJsKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV9wb3dlcmRvd25fbW9kZShGREN0cmwgKmZkY3RybCwgaW50IGRpcmVjdGlvbikKewogICAgZmRjdHJsLT5wd3JkID0gZmRjdHJsLT5maWZvWzFdOwogICAgZmRjdHJsLT5maWZvWzBdID0gZmRjdHJsLT5maWZvWzFdOwogICAgZmRjdHJsX3NldF9maWZvKGZkY3RybCwgMSwgMSk7Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9oYW5kbGVfb3B0aW9uKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICAvKiBObyByZXN1bHQgYmFjayAqLwogICAgZmRjdHJsX3Jlc2V0X2ZpZm8oZmRjdHJsKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV9kcml2ZV9zcGVjaWZpY2F0aW9uX2NvbW1hbmQoRkRDdHJsICpmZGN0cmwsIGludCBkaXJlY3Rpb24pCnsKICAgIEZEcml2ZSAqY3VyX2RydiA9IGdldF9jdXJfZHJ2KGZkY3RybCk7CgogICAgaWYgKGZkY3RybC0+Zmlmb1tmZGN0cmwtPmRhdGFfcG9zIC0gMV0gJiAweDgwKSB7CiAgICAgICAgLyogQ29tbWFuZCBwYXJhbWV0ZXJzIGRvbmUgKi8KICAgICAgICBpZiAoZmRjdHJsLT5maWZvW2ZkY3RybC0+ZGF0YV9wb3MgLSAxXSAmIDB4NDApIHsKICAgICAgICAgICAgZmRjdHJsLT5maWZvWzBdID0gZmRjdHJsLT5maWZvWzFdOwogICAgICAgICAgICBmZGN0cmwtPmZpZm9bMl0gPSAwOwogICAgICAgICAgICBmZGN0cmwtPmZpZm9bM10gPSAwOwogICAgICAgICAgICBmZGN0cmxfc2V0X2ZpZm8oZmRjdHJsLCA0LCAxKTsKICAgICAgICB9IGVsc2UgewogICAgICAgICAgICBmZGN0cmxfcmVzZXRfZmlmbyhmZGN0cmwpOwogICAgICAgIH0KICAgIH0gZWxzZSBpZiAoZmRjdHJsLT5kYXRhX2xlbiA+IDcpIHsKICAgICAgICAvKiBFUlJPUiAqLwogICAgICAgIGZkY3RybC0+Zmlmb1swXSA9IDB4ODAgfAogICAgICAgICAgICAoY3VyX2Rydi0+aGVhZCA8PCAyKSB8IEdFVF9DVVJfRFJWKGZkY3RybCk7CiAgICAgICAgZmRjdHJsX3NldF9maWZvKGZkY3RybCwgMSwgMSk7CiAgICB9Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9oYW5kbGVfcmVsYXRpdmVfc2Vla19vdXQoRkRDdHJsICpmZGN0cmwsIGludCBkaXJlY3Rpb24pCnsKICAgIEZEcml2ZSAqY3VyX2RydjsKCiAgICBTRVRfQ1VSX0RSVihmZGN0cmwsIGZkY3RybC0+Zmlmb1sxXSAmIEZEX0RPUl9TRUxNQVNLKTsKICAgIGN1cl9kcnYgPSBnZXRfY3VyX2RydihmZGN0cmwpOwogICAgaWYgKGZkY3RybC0+Zmlmb1syXSArIGN1cl9kcnYtPnRyYWNrID49IGN1cl9kcnYtPm1heF90cmFjaykgewogICAgICAgIGN1cl9kcnYtPnRyYWNrID0gY3VyX2Rydi0+bWF4X3RyYWNrIC0gMTsKICAgIH0gZWxzZSB7CiAgICAgICAgY3VyX2Rydi0+dHJhY2sgKz0gZmRjdHJsLT5maWZvWzJdOwogICAgfQogICAgZmRjdHJsX3Jlc2V0X2ZpZm8oZmRjdHJsKTsKICAgIC8qIFJhaXNlIEludGVycnVwdCAqLwogICAgZmRjdHJsX3JhaXNlX2lycShmZGN0cmwsIEZEX1NSMF9TRUVLKTsKfQoKc3RhdGljIHZvaWQgZmRjdHJsX2hhbmRsZV9yZWxhdGl2ZV9zZWVrX2luKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKQp7CiAgICBGRHJpdmUgKmN1cl9kcnY7CgogICAgU0VUX0NVUl9EUlYoZmRjdHJsLCBmZGN0cmwtPmZpZm9bMV0gJiBGRF9ET1JfU0VMTUFTSyk7CiAgICBjdXJfZHJ2ID0gZ2V0X2N1cl9kcnYoZmRjdHJsKTsKICAgIGlmIChmZGN0cmwtPmZpZm9bMl0gPiBjdXJfZHJ2LT50cmFjaykgewogICAgICAgIGN1cl9kcnYtPnRyYWNrID0gMDsKICAgIH0gZWxzZSB7CiAgICAgICAgY3VyX2Rydi0+dHJhY2sgLT0gZmRjdHJsLT5maWZvWzJdOwogICAgfQogICAgZmRjdHJsX3Jlc2V0X2ZpZm8oZmRjdHJsKTsKICAgIC8qIFJhaXNlIEludGVycnVwdCAqLwogICAgZmRjdHJsX3JhaXNlX2lycShmZGN0cmwsIEZEX1NSMF9TRUVLKTsKfQoKc3RhdGljIGNvbnN0IHN0cnVjdCB7CiAgICB1aW50OF90IHZhbHVlOwogICAgdWludDhfdCBtYXNrOwogICAgY29uc3QgY2hhciogbmFtZTsKICAgIGludCBwYXJhbWV0ZXJzOwogICAgdm9pZCAoKmhhbmRsZXIpKEZEQ3RybCAqZmRjdHJsLCBpbnQgZGlyZWN0aW9uKTsKICAgIGludCBkaXJlY3Rpb247Cn0gaGFuZGxlcnNbXSA9IHsKICAgIHsgRkRfQ01EX1JFQUQsIDB4MWYsICJSRUFEIiwgOCwgZmRjdHJsX3N0YXJ0X3RyYW5zZmVyLCBGRF9ESVJfUkVBRCB9LAogICAgeyBGRF9DTURfV1JJVEUsIDB4M2YsICJXUklURSIsIDgsIGZkY3RybF9zdGFydF90cmFuc2ZlciwgRkRfRElSX1dSSVRFIH0sCiAgICB7IEZEX0NNRF9TRUVLLCAweGZmLCAiU0VFSyIsIDIsIGZkY3RybF9oYW5kbGVfc2VlayB9LAogICAgeyBGRF9DTURfU0VOU0VfSU5URVJSVVBUX1NUQVRVUywgMHhmZiwgIlNFTlNFIElOVEVSUlVQVCBTVEFUVVMiLCAwLCBmZGN0cmxfaGFuZGxlX3NlbnNlX2ludGVycnVwdF9zdGF0dXMgfSwKICAgIHsgRkRfQ01EX1JFQ0FMSUJSQVRFLCAweGZmLCAiUkVDQUxJQlJBVEUiLCAxLCBmZGN0cmxfaGFuZGxlX3JlY2FsaWJyYXRlIH0sCiAgICB7IEZEX0NNRF9GT1JNQVRfVFJBQ0ssIDB4YmYsICJGT1JNQVQgVFJBQ0siLCA1LCBmZGN0cmxfaGFuZGxlX2Zvcm1hdF90cmFjayB9LAogICAgeyBGRF9DTURfUkVBRF9UUkFDSywgMHhiZiwgIlJFQUQgVFJBQ0siLCA4LCBmZGN0cmxfc3RhcnRfdHJhbnNmZXIsIEZEX0RJUl9SRUFEIH0sCiAgICB7IEZEX0NNRF9SRVNUT1JFLCAweGZmLCAiUkVTVE9SRSIsIDE3LCBmZGN0cmxfaGFuZGxlX3Jlc3RvcmUgfSwgLyogcGFydCBvZiBSRUFEIERFTEVURUQgREFUQSAqLwogICAgeyBGRF9DTURfU0FWRSwgMHhmZiwgIlNBVkUiLCAwLCBmZGN0cmxfaGFuZGxlX3NhdmUgfSwgLyogcGFydCBvZiBSRUFEIERFTEVURUQgREFUQSAqLwogICAgeyBGRF9DTURfUkVBRF9ERUxFVEVELCAweDFmLCAiUkVBRCBERUxFVEVEIERBVEEiLCA4LCBmZGN0cmxfc3RhcnRfdHJhbnNmZXJfZGVsLCBGRF9ESVJfUkVBRCB9LAogICAgeyBGRF9DTURfU0NBTl9FUVVBTCwgMHgxZiwgIlNDQU4gRVFVQUwiLCA4LCBmZGN0cmxfc3RhcnRfdHJhbnNmZXIsIEZEX0RJUl9TQ0FORSB9LAogICAgeyBGRF9DTURfVkVSSUZZLCAweDFmLCAiVkVSSUZZIiwgOCwgZmRjdHJsX3VuaW1wbGVtZW50ZWQgfSwKICAgIHsgRkRfQ01EX1NDQU5fTE9XX09SX0VRVUFMLCAweDFmLCAiU0NBTiBMT1cgT1IgRVFVQUwiLCA4LCBmZGN0cmxfc3RhcnRfdHJhbnNmZXIsIEZEX0RJUl9TQ0FOTCB9LAogICAgeyBGRF9DTURfU0NBTl9ISUdIX09SX0VRVUFMLCAweDFmLCAiU0NBTiBISUdIIE9SIEVRVUFMIiwgOCwgZmRjdHJsX3N0YXJ0X3RyYW5zZmVyLCBGRF9ESVJfU0NBTkggfSwKICAgIHsgRkRfQ01EX1dSSVRFX0RFTEVURUQsIDB4M2YsICJXUklURSBERUxFVEVEIERBVEEiLCA4LCBmZGN0cmxfc3RhcnRfdHJhbnNmZXJfZGVsLCBGRF9ESVJfV1JJVEUgfSwKICAgIHsgRkRfQ01EX1JFQURfSUQsIDB4YmYsICJSRUFEIElEIiwgMSwgZmRjdHJsX2hhbmRsZV9yZWFkaWQgfSwKICAgIHsgRkRfQ01EX1NQRUNJRlksIDB4ZmYsICJTUEVDSUZZIiwgMiwgZmRjdHJsX2hhbmRsZV9zcGVjaWZ5IH0sCiAgICB7IEZEX0NNRF9TRU5TRV9EUklWRV9TVEFUVVMsIDB4ZmYsICJTRU5TRSBEUklWRSBTVEFUVVMiLCAxLCBmZGN0cmxfaGFuZGxlX3NlbnNlX2RyaXZlX3N0YXR1cyB9LAogICAgeyBGRF9DTURfUEVSUEVORElDVUxBUl9NT0RFLCAweGZmLCAiUEVSUEVORElDVUxBUiBNT0RFIiwgMSwgZmRjdHJsX2hhbmRsZV9wZXJwZW5kaWN1bGFyX21vZGUgfSwKICAgIHsgRkRfQ01EX0NPTkZJR1VSRSwgMHhmZiwgIkNPTkZJR1VSRSIsIDMsIGZkY3RybF9oYW5kbGVfY29uZmlndXJlIH0sCiAgICB7IEZEX0NNRF9QT1dFUkRPV05fTU9ERSwgMHhmZiwgIlBPV0VSRE9XTiBNT0RFIiwgMiwgZmRjdHJsX2hhbmRsZV9wb3dlcmRvd25fbW9kZSB9LAogICAgeyBGRF9DTURfT1BUSU9OLCAweGZmLCAiT1BUSU9OIiwgMSwgZmRjdHJsX2hhbmRsZV9vcHRpb24gfSwKICAgIHsgRkRfQ01EX0RSSVZFX1NQRUNJRklDQVRJT05fQ09NTUFORCwgMHhmZiwgIkRSSVZFIFNQRUNJRklDQVRJT04gQ09NTUFORCIsIDUsIGZkY3RybF9oYW5kbGVfZHJpdmVfc3BlY2lmaWNhdGlvbl9jb21tYW5kIH0sCiAgICB7IEZEX0NNRF9SRUxBVElWRV9TRUVLX09VVCwgMHhmZiwgIlJFTEFUSVZFIFNFRUsgT1VUIiwgMiwgZmRjdHJsX2hhbmRsZV9yZWxhdGl2ZV9zZWVrX291dCB9LAogICAgeyBGRF9DTURfRk9STUFUX0FORF9XUklURSwgMHhmZiwgIkZPUk1BVCBBTkQgV1JJVEUiLCAxMCwgZmRjdHJsX3VuaW1wbGVtZW50ZWQgfSwKICAgIHsgRkRfQ01EX1JFTEFUSVZFX1NFRUtfSU4sIDB4ZmYsICJSRUxBVElWRSBTRUVLIElOIiwgMiwgZmRjdHJsX2hhbmRsZV9yZWxhdGl2ZV9zZWVrX2luIH0sCiAgICB7IEZEX0NNRF9MT0NLLCAweDdmLCAiTE9DSyIsIDAsIGZkY3RybF9oYW5kbGVfbG9jayB9LAogICAgeyBGRF9DTURfRFVNUFJFRywgMHhmZiwgIkRVTVBSRUciLCAwLCBmZGN0cmxfaGFuZGxlX2R1bXByZWcgfSwKICAgIHsgRkRfQ01EX1ZFUlNJT04sIDB4ZmYsICJWRVJTSU9OIiwgMCwgZmRjdHJsX2hhbmRsZV92ZXJzaW9uIH0sCiAgICB7IEZEX0NNRF9QQVJUX0lELCAweGZmLCAiUEFSVCBJRCIsIDAsIGZkY3RybF9oYW5kbGVfcGFydGlkIH0sCiAgICB7IEZEX0NNRF9XUklURSwgMHgxZiwgIldSSVRFIChCZU9TKSIsIDgsIGZkY3RybF9zdGFydF90cmFuc2ZlciwgRkRfRElSX1dSSVRFIH0sIC8qIG5vdCBpbiBzcGVjaWZpY2F0aW9uIDsgQmVPUyA0LjUgYnVnICovCiAgICB7IDAsIDAsICJ1bmtub3duIiwgMCwgZmRjdHJsX3VuaW1wbGVtZW50ZWQgfSwgLyogZGVmYXVsdCBoYW5kbGVyICovCn07Ci8qIEFzc29jaWF0ZSBjb21tYW5kIHRvIGFuIGluZGV4IGluIHRoZSAnaGFuZGxlcnMnIGFycmF5ICovCnN0YXRpYyB1aW50OF90IGNvbW1hbmRfdG9faGFuZGxlclsyNTZdOwoKc3RhdGljIHZvaWQgZmRjdHJsX3dyaXRlX2RhdGEoRkRDdHJsICpmZGN0cmwsIHVpbnQzMl90IHZhbHVlKQp7CiAgICBGRHJpdmUgKmN1cl9kcnY7CiAgICBpbnQgcG9zOwoKICAgIC8qIFJlc2V0IG1vZGUgKi8KICAgIGlmICghKGZkY3RybC0+ZG9yICYgRkRfRE9SX25SRVNFVCkpIHsKICAgICAgICBGTE9QUFlfRFBSSU5URigiRmxvcHB5IGNvbnRyb2xsZXIgaW4gUkVTRVQgc3RhdGUgIVxuIik7CiAgICAgICAgcmV0dXJuOwogICAgfQogICAgaWYgKCEoZmRjdHJsLT5tc3IgJiBGRF9NU1JfUlFNKSB8fCAoZmRjdHJsLT5tc3IgJiBGRF9NU1JfRElPKSkgewogICAgICAgIEZMT1BQWV9FUlJPUigiY29udHJvbGxlciBub3QgcmVhZHkgZm9yIHdyaXRpbmdcbiIpOwogICAgICAgIHJldHVybjsKICAgIH0KICAgIGZkY3RybC0+ZHNyICY9IH5GRF9EU1JfUFdSRE9XTjsKICAgIC8qIElzIGl0IHdyaXRlIGNvbW1hbmQgdGltZSA/ICovCiAgICBpZiAoZmRjdHJsLT5tc3IgJiBGRF9NU1JfTk9ORE1BKSB7CiAgICAgICAgLyogRklGTyBkYXRhIHdyaXRlICovCiAgICAgICAgcG9zID0gZmRjdHJsLT5kYXRhX3BvcysrOwogICAgICAgIHBvcyAlPSBGRF9TRUNUT1JfTEVOOwogICAgICAgIGZkY3RybC0+Zmlmb1twb3NdID0gdmFsdWU7CiAgICAgICAgaWYgKHBvcyA9PSBGRF9TRUNUT1JfTEVOIC0gMSB8fAogICAgICAgICAgICBmZGN0cmwtPmRhdGFfcG9zID09IGZkY3RybC0+ZGF0YV9sZW4pIHsKICAgICAgICAgICAgY3VyX2RydiA9IGdldF9jdXJfZHJ2KGZkY3RybCk7CiAgICAgICAgICAgIGlmIChiZHJ2X3dyaXRlKGN1cl9kcnYtPmJzLCBmZF9zZWN0b3IoY3VyX2RydiksIGZkY3RybC0+ZmlmbywgMSkgPCAwKSB7CiAgICAgICAgICAgICAgICBGTE9QUFlfRVJST1IoIndyaXRpbmcgc2VjdG9yICVkXG4iLCBmZF9zZWN0b3IoY3VyX2RydikpOwogICAgICAgICAgICAgICAgcmV0dXJuOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGlmICghZmRjdHJsX3NlZWtfdG9fbmV4dF9zZWN0KGZkY3RybCwgY3VyX2RydikpIHsKICAgICAgICAgICAgICAgIEZMT1BQWV9EUFJJTlRGKCJlcnJvciBzZWVraW5nIHRvIG5leHQgc2VjdG9yICVkXG4iLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZmRfc2VjdG9yKGN1cl9kcnYpKTsKICAgICAgICAgICAgICAgIHJldHVybjsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgICAgICAvKiBTd2l0Y2ggZnJvbSB0cmFuc2ZlciBtb2RlIHRvIHN0YXR1cyBtb2RlCiAgICAgICAgICogdGhlbiBmcm9tIHN0YXR1cyBtb2RlIHRvIGNvbW1hbmQgbW9kZQogICAgICAgICAqLwogICAgICAgIGlmIChmZGN0cmwtPmRhdGFfcG9zID09IGZkY3RybC0+ZGF0YV9sZW4pCiAgICAgICAgICAgIGZkY3RybF9zdG9wX3RyYW5zZmVyKGZkY3RybCwgRkRfU1IwX1NFRUssIDB4MDAsIDB4MDApOwogICAgICAgIHJldHVybjsKICAgIH0KICAgIGlmIChmZGN0cmwtPmRhdGFfcG9zID09IDApIHsKICAgICAgICAvKiBDb21tYW5kICovCiAgICAgICAgcG9zID0gY29tbWFuZF90b19oYW5kbGVyW3ZhbHVlICYgMHhmZl07CiAgICAgICAgRkxPUFBZX0RQUklOVEYoIiVzIGNvbW1hbmRcbiIsIGhhbmRsZXJzW3Bvc10ubmFtZSk7CiAgICAgICAgZmRjdHJsLT5kYXRhX2xlbiA9IGhhbmRsZXJzW3Bvc10ucGFyYW1ldGVycyArIDE7CiAgICB9CgogICAgRkxPUFBZX0RQUklOVEYoIiVzOiAlMDJ4XG4iLCBfX2Z1bmNfXywgdmFsdWUpOwogICAgZmRjdHJsLT5maWZvW2ZkY3RybC0+ZGF0YV9wb3MrK10gPSB2YWx1ZTsKICAgIGlmIChmZGN0cmwtPmRhdGFfcG9zID09IGZkY3RybC0+ZGF0YV9sZW4pIHsKICAgICAgICAvKiBXZSBub3cgaGF2ZSBhbGwgcGFyYW1ldGVycwogICAgICAgICAqIGFuZCB3aWxsIGJlIGFibGUgdG8gdHJlYXQgdGhlIGNvbW1hbmQKICAgICAgICAgKi8KICAgICAgICBpZiAoZmRjdHJsLT5kYXRhX3N0YXRlICYgRkRfU1RBVEVfRk9STUFUKSB7CiAgICAgICAgICAgIGZkY3RybF9mb3JtYXRfc2VjdG9yKGZkY3RybCk7CiAgICAgICAgICAgIHJldHVybjsKICAgICAgICB9CgogICAgICAgIHBvcyA9IGNvbW1hbmRfdG9faGFuZGxlcltmZGN0cmwtPmZpZm9bMF0gJiAweGZmXTsKICAgICAgICBGTE9QUFlfRFBSSU5URigidHJlYXQgJXMgY29tbWFuZFxuIiwgaGFuZGxlcnNbcG9zXS5uYW1lKTsKICAgICAgICAoKmhhbmRsZXJzW3Bvc10uaGFuZGxlcikoZmRjdHJsLCBoYW5kbGVyc1twb3NdLmRpcmVjdGlvbik7CiAgICB9Cn0KCnN0YXRpYyB2b2lkIGZkY3RybF9yZXN1bHRfdGltZXIodm9pZCAqb3BhcXVlKQp7CiAgICBGREN0cmwgKmZkY3RybCA9IG9wYXF1ZTsKICAgIEZEcml2ZSAqY3VyX2RydiA9IGdldF9jdXJfZHJ2KGZkY3RybCk7CgogICAgLyogUHJldGVuZCB3ZSBhcmUgc3Bpbm5pbmcuCiAgICAgKiBUaGlzIGlzIG5lZWRlZCBmb3IgQ29oZXJlbnQsIHdoaWNoIHVzZXMgUkVBRCBJRCB0byBjaGVjayBmb3IKICAgICAqIHNlY3RvciBpbnRlcmxlYXZpbmcuCiAgICAgKi8KICAgIGlmIChjdXJfZHJ2LT5sYXN0X3NlY3QgIT0gMCkgewogICAgICAgIGN1cl9kcnYtPnNlY3QgPSAoY3VyX2Rydi0+c2VjdCAlIGN1cl9kcnYtPmxhc3Rfc2VjdCkgKyAxOwogICAgfQogICAgZmRjdHJsX3N0b3BfdHJhbnNmZXIoZmRjdHJsLCAweDAwLCAweDAwLCAweDAwKTsKfQoKLyogSW5pdCBmdW5jdGlvbnMgKi8Kc3RhdGljIHZvaWQgZmRjdHJsX2Nvbm5lY3RfZHJpdmVzKEZEQ3RybCAqZmRjdHJsKQp7CiAgICB1bnNpZ25lZCBpbnQgaTsKCiAgICBmb3IgKGkgPSAwOyBpIDwgTUFYX0ZEOyBpKyspIHsKICAgICAgICBmZF9pbml0KCZmZGN0cmwtPmRyaXZlc1tpXSk7CiAgICAgICAgZmRfcmV2YWxpZGF0ZSgmZmRjdHJsLT5kcml2ZXNbaV0pOwogICAgfQp9CgpGREN0cmwgKmZkY3RybF9pbml0X2lzYShEcml2ZUluZm8gKipmZHMpCnsKICAgIElTQURldmljZSAqZGV2OwoKICAgIGRldiA9IGlzYV9jcmVhdGUoImlzYS1mZGMiKTsKICAgIGlmIChmZHNbMF0pIHsKICAgICAgICBxZGV2X3Byb3Bfc2V0X2RyaXZlKCZkZXYtPnFkZXYsICJkcml2ZUEiLCBmZHNbMF0pOwogICAgfQogICAgaWYgKGZkc1sxXSkgewogICAgICAgIHFkZXZfcHJvcF9zZXRfZHJpdmUoJmRldi0+cWRldiwgImRyaXZlQiIsIGZkc1sxXSk7CiAgICB9CiAgICBpZiAocWRldl9pbml0KCZkZXYtPnFkZXYpIDwgMCkKICAgICAgICByZXR1cm4gTlVMTDsKICAgIHJldHVybiAmKERPX1VQQ0FTVChGREN0cmxJU0FCdXMsIGJ1c2RldiwgZGV2KS0+c3RhdGUpOwp9CgpGREN0cmwgKmZkY3RybF9pbml0X3N5c2J1cyhxZW11X2lycSBpcnEsIGludCBkbWFfY2hhbm4sCiAgICAgICAgICAgICAgICAgICAgICAgICAgIHRhcmdldF9waHlzX2FkZHJfdCBtbWlvX2Jhc2UsIERyaXZlSW5mbyAqKmZkcykKewogICAgRkRDdHJsICpmZGN0cmw7CiAgICBEZXZpY2VTdGF0ZSAqZGV2OwogICAgRkRDdHJsU3lzQnVzICpzeXM7CgogICAgZGV2ID0gcWRldl9jcmVhdGUoTlVMTCwgInN5c2J1cy1mZGMiKTsKICAgIHN5cyA9IERPX1VQQ0FTVChGREN0cmxTeXNCdXMsIGJ1c2Rldi5xZGV2LCBkZXYpOwogICAgZmRjdHJsID0gJnN5cy0+c3RhdGU7CiAgICBmZGN0cmwtPmRtYV9jaGFubiA9IGRtYV9jaGFubjsgLyogRklYTUUgKi8KICAgIGlmIChmZHNbMF0pIHsKICAgICAgICBxZGV2X3Byb3Bfc2V0X2RyaXZlKGRldiwgImRyaXZlQSIsIGZkc1swXSk7CiAgICB9CiAgICBpZiAoZmRzWzFdKSB7CiAgICAgICAgcWRldl9wcm9wX3NldF9kcml2ZShkZXYsICJkcml2ZUIiLCBmZHNbMV0pOwogICAgfQogICAgcWRldl9pbml0X25vZmFpbChkZXYpOwogICAgc3lzYnVzX2Nvbm5lY3RfaXJxKCZzeXMtPmJ1c2RldiwgMCwgaXJxKTsKICAgIHN5c2J1c19tbWlvX21hcCgmc3lzLT5idXNkZXYsIDAsIG1taW9fYmFzZSk7CgogICAgcmV0dXJuIGZkY3RybDsKfQoKRkRDdHJsICpzdW40bV9mZGN0cmxfaW5pdChxZW11X2lycSBpcnEsIHRhcmdldF9waHlzX2FkZHJfdCBpb19iYXNlLAogICAgICAgICAgICAgICAgICAgICAgICAgIERyaXZlSW5mbyAqKmZkcywgcWVtdV9pcnEgKmZkY190YykKewogICAgRGV2aWNlU3RhdGUgKmRldjsKICAgIEZEQ3RybFN5c0J1cyAqc3lzOwogICAgRkRDdHJsICpmZGN0cmw7CgogICAgZGV2ID0gcWRldl9jcmVhdGUoTlVMTCwgIlNVTlcsZmR0d28iKTsKICAgIGlmIChmZHNbMF0pIHsKICAgICAgICBxZGV2X3Byb3Bfc2V0X2RyaXZlKGRldiwgImRyaXZlIiwgZmRzWzBdKTsKICAgIH0KICAgIHFkZXZfaW5pdF9ub2ZhaWwoZGV2KTsKICAgIHN5cyA9IERPX1VQQ0FTVChGREN0cmxTeXNCdXMsIGJ1c2Rldi5xZGV2LCBkZXYpOwogICAgZmRjdHJsID0gJnN5cy0+c3RhdGU7CiAgICBzeXNidXNfY29ubmVjdF9pcnEoJnN5cy0+YnVzZGV2LCAwLCBpcnEpOwogICAgc3lzYnVzX21taW9fbWFwKCZzeXMtPmJ1c2RldiwgMCwgaW9fYmFzZSk7CiAgICAqZmRjX3RjID0gcWRldl9nZXRfZ3Bpb19pbihkZXYsIDApOwoKICAgIHJldHVybiBmZGN0cmw7Cn0KCnN0YXRpYyBpbnQgZmRjdHJsX2luaXRfY29tbW9uKEZEQ3RybCAqZmRjdHJsKQp7CiAgICBpbnQgaSwgajsKICAgIHN0YXRpYyBpbnQgY29tbWFuZF90YWJsZXNfaW5pdGVkID0gMDsKCiAgICAvKiBGaWxsICdjb21tYW5kX3RvX2hhbmRsZXInIGxvb2t1cCB0YWJsZSAqLwogICAgaWYgKCFjb21tYW5kX3RhYmxlc19pbml0ZWQpIHsKICAgICAgICBjb21tYW5kX3RhYmxlc19pbml0ZWQgPSAxOwogICAgICAgIGZvciAoaSA9IEFSUkFZX1NJWkUoaGFuZGxlcnMpIC0gMTsgaSA+PSAwOyBpLS0pIHsKICAgICAgICAgICAgZm9yIChqID0gMDsgaiA8IHNpemVvZihjb21tYW5kX3RvX2hhbmRsZXIpOyBqKyspIHsKICAgICAgICAgICAgICAgIGlmICgoaiAmIGhhbmRsZXJzW2ldLm1hc2spID09IGhhbmRsZXJzW2ldLnZhbHVlKSB7CiAgICAgICAgICAgICAgICAgICAgY29tbWFuZF90b19oYW5kbGVyW2pdID0gaTsKICAgICAgICAgICAgICAgIH0KICAgICAgICAgICAgfQogICAgICAgIH0KICAgIH0KCiAgICBGTE9QUFlfRFBSSU5URigiaW5pdCBjb250cm9sbGVyXG4iKTsKICAgIGZkY3RybC0+ZmlmbyA9IHFlbXVfbWVtYWxpZ24oNTEyLCBGRF9TRUNUT1JfTEVOKTsKICAgIGZkY3RybC0+Zmlmb19zaXplID0gNTEyOwogICAgZmRjdHJsLT5yZXN1bHRfdGltZXIgPSBxZW11X25ld190aW1lcih2bV9jbG9jaywKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZmRjdHJsX3Jlc3VsdF90aW1lciwgZmRjdHJsKTsKCiAgICBmZGN0cmwtPnZlcnNpb24gPSAweDkwOyAvKiBJbnRlbCA4MjA3OCBjb250cm9sbGVyICovCiAgICBmZGN0cmwtPmNvbmZpZyA9IEZEX0NPTkZJR19FSVMgfCBGRF9DT05GSUdfRUZJRk87IC8qIEltcGxpY2l0IHNlZWssIHBvbGxpbmcgJiBGSUZPIGVuYWJsZWQgKi8KICAgIGZkY3RybC0+bnVtX2Zsb3BwaWVzID0gTUFYX0ZEOwoKICAgIGlmIChmZGN0cmwtPmRtYV9jaGFubiAhPSAtMSkKICAgICAgICBETUFfcmVnaXN0ZXJfY2hhbm5lbChmZGN0cmwtPmRtYV9jaGFubiwgJmZkY3RybF90cmFuc2Zlcl9oYW5kbGVyLCBmZGN0cmwpOwogICAgZmRjdHJsX2Nvbm5lY3RfZHJpdmVzKGZkY3RybCk7CgogICAgcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgaXNhYnVzX2ZkY19pbml0MShJU0FEZXZpY2UgKmRldikKewogICAgRkRDdHJsSVNBQnVzICppc2EgPSBET19VUENBU1QoRkRDdHJsSVNBQnVzLCBidXNkZXYsIGRldik7CiAgICBGREN0cmwgKmZkY3RybCA9ICZpc2EtPnN0YXRlOwogICAgaW50IGlvYmFzZSA9IDB4M2YwOwogICAgaW50IGlzYWlycSA9IDY7CiAgICBpbnQgZG1hX2NoYW5uID0gMjsKICAgIGludCByZXQ7CgogICAgcmVnaXN0ZXJfaW9wb3J0X3JlYWQoaW9iYXNlICsgMHgwMSwgNSwgMSwKICAgICAgICAgICAgICAgICAgICAgICAgICZmZGN0cmxfcmVhZF9wb3J0LCBmZGN0cmwpOwogICAgcmVnaXN0ZXJfaW9wb3J0X3JlYWQoaW9iYXNlICsgMHgwNywgMSwgMSwKICAgICAgICAgICAgICAgICAgICAgICAgICZmZGN0cmxfcmVhZF9wb3J0LCBmZGN0cmwpOwogICAgcmVnaXN0ZXJfaW9wb3J0X3dyaXRlKGlvYmFzZSArIDB4MDEsIDUsIDEsCiAgICAgICAgICAgICAgICAgICAgICAgICAgJmZkY3RybF93cml0ZV9wb3J0LCBmZGN0cmwpOwogICAgcmVnaXN0ZXJfaW9wb3J0X3dyaXRlKGlvYmFzZSArIDB4MDcsIDEsIDEsCiAgICAgICAgICAgICAgICAgICAgICAgICAgJmZkY3RybF93cml0ZV9wb3J0LCBmZGN0cmwpOwogICAgaXNhX2luaXRfaXJxKCZpc2EtPmJ1c2RldiwgJmZkY3RybC0+aXJxLCBpc2FpcnEpOwogICAgZmRjdHJsLT5kbWFfY2hhbm4gPSBkbWFfY2hhbm47CgogICAgcWRldl9zZXRfbGVnYWN5X2luc3RhbmNlX2lkKCZkZXYtPnFkZXYsIGlvYmFzZSwgMik7CiAgICByZXQgPSBmZGN0cmxfaW5pdF9jb21tb24oZmRjdHJsKTsKCiAgICByZXR1cm4gcmV0Owp9CgpzdGF0aWMgaW50IHN5c2J1c19mZGNfaW5pdDEoU3lzQnVzRGV2aWNlICpkZXYpCnsKICAgIEZEQ3RybFN5c0J1cyAqc3lzID0gRE9fVVBDQVNUKEZEQ3RybFN5c0J1cywgYnVzZGV2LCBkZXYpOwogICAgRkRDdHJsICpmZGN0cmwgPSAmc3lzLT5zdGF0ZTsKICAgIGludCBpbzsKICAgIGludCByZXQ7CgogICAgaW8gPSBjcHVfcmVnaXN0ZXJfaW9fbWVtb3J5KGZkY3RybF9tZW1fcmVhZCwgZmRjdHJsX21lbV93cml0ZSwgZmRjdHJsKTsKICAgIHN5c2J1c19pbml0X21taW8oZGV2LCAweDA4LCBpbyk7CiAgICBzeXNidXNfaW5pdF9pcnEoZGV2LCAmZmRjdHJsLT5pcnEpOwogICAgcWRldl9pbml0X2dwaW9faW4oJmRldi0+cWRldiwgZmRjdHJsX2hhbmRsZV90YywgMSk7CiAgICBmZGN0cmwtPmRtYV9jaGFubiA9IC0xOwoKICAgIHFkZXZfc2V0X2xlZ2FjeV9pbnN0YW5jZV9pZCgmZGV2LT5xZGV2LCBpbywgMik7CiAgICByZXQgPSBmZGN0cmxfaW5pdF9jb21tb24oZmRjdHJsKTsKCiAgICByZXR1cm4gcmV0Owp9CgpzdGF0aWMgaW50IHN1bjRtX2ZkY19pbml0MShTeXNCdXNEZXZpY2UgKmRldikKewogICAgRkRDdHJsICpmZGN0cmwgPSAmKEZST01fU1lTQlVTKEZEQ3RybFN5c0J1cywgZGV2KS0+c3RhdGUpOwogICAgaW50IGlvOwoKICAgIGlvID0gY3B1X3JlZ2lzdGVyX2lvX21lbW9yeShmZGN0cmxfbWVtX3JlYWRfc3RyaWN0LAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZkY3RybF9tZW1fd3JpdGVfc3RyaWN0LCBmZGN0cmwpOwogICAgc3lzYnVzX2luaXRfbW1pbyhkZXYsIDB4MDgsIGlvKTsKICAgIHN5c2J1c19pbml0X2lycShkZXYsICZmZGN0cmwtPmlycSk7CiAgICBxZGV2X2luaXRfZ3Bpb19pbigmZGV2LT5xZGV2LCBmZGN0cmxfaGFuZGxlX3RjLCAxKTsKCiAgICBmZGN0cmwtPnN1bjRtID0gMTsKICAgIHFkZXZfc2V0X2xlZ2FjeV9pbnN0YW5jZV9pZCgmZGV2LT5xZGV2LCBpbywgMik7CiAgICByZXR1cm4gZmRjdHJsX2luaXRfY29tbW9uKGZkY3RybCk7Cn0KCnN0YXRpYyBjb25zdCBWTVN0YXRlRGVzY3JpcHRpb24gdm1zdGF0ZV9pc2FfZmRjID17CiAgICAubmFtZSA9ICJmZGMiLAogICAgLnZlcnNpb25faWQgPSAyLAogICAgLm1pbmltdW1fdmVyc2lvbl9pZCA9IDIsCiAgICAuZmllbGRzID0gKFZNU3RhdGVGaWVsZCBbXSkgewogICAgICAgIFZNU1RBVEVfU1RSVUNUKHN0YXRlLCBGREN0cmxJU0FCdXMsIDAsIHZtc3RhdGVfZmRjLCBGREN0cmwpLAogICAgICAgIFZNU1RBVEVfRU5EX09GX0xJU1QoKQogICAgfQp9OwoKc3RhdGljIElTQURldmljZUluZm8gaXNhX2ZkY19pbmZvID0gewogICAgLmluaXQgPSBpc2FidXNfZmRjX2luaXQxLAogICAgLnFkZXYubmFtZSAgPSAiaXNhLWZkYyIsCiAgICAucWRldi5zaXplICA9IHNpemVvZihGREN0cmxJU0FCdXMpLAogICAgLnFkZXYubm9fdXNlciA9IDEsCiAgICAucWRldi52bXNkICA9ICZ2bXN0YXRlX2lzYV9mZGMsCiAgICAucWRldi5yZXNldCA9IGZkY3RybF9leHRlcm5hbF9yZXNldF9pc2EsCiAgICAucWRldi5wcm9wcyA9IChQcm9wZXJ0eVtdKSB7CiAgICAgICAgREVGSU5FX1BST1BfRFJJVkUoImRyaXZlQSIsIEZEQ3RybElTQUJ1cywgc3RhdGUuZHJpdmVzWzBdLmRpbmZvKSwKICAgICAgICBERUZJTkVfUFJPUF9EUklWRSgiZHJpdmVCIiwgRkRDdHJsSVNBQnVzLCBzdGF0ZS5kcml2ZXNbMV0uZGluZm8pLAogICAgICAgIERFRklORV9QUk9QX0VORF9PRl9MSVNUKCksCiAgICB9LAp9OwoKc3RhdGljIGNvbnN0IFZNU3RhdGVEZXNjcmlwdGlvbiB2bXN0YXRlX3N5c2J1c19mZGMgPXsKICAgIC5uYW1lID0gImZkYyIsCiAgICAudmVyc2lvbl9pZCA9IDIsCiAgICAubWluaW11bV92ZXJzaW9uX2lkID0gMiwKICAgIC5maWVsZHMgPSAoVk1TdGF0ZUZpZWxkIFtdKSB7CiAgICAgICAgVk1TVEFURV9TVFJVQ1Qoc3RhdGUsIEZEQ3RybFN5c0J1cywgMCwgdm1zdGF0ZV9mZGMsIEZEQ3RybCksCiAgICAgICAgVk1TVEFURV9FTkRfT0ZfTElTVCgpCiAgICB9Cn07CgpzdGF0aWMgU3lzQnVzRGV2aWNlSW5mbyBzeXNidXNfZmRjX2luZm8gPSB7CiAgICAuaW5pdCA9IHN5c2J1c19mZGNfaW5pdDEsCiAgICAucWRldi5uYW1lICA9ICJzeXNidXMtZmRjIiwKICAgIC5xZGV2LnNpemUgID0gc2l6ZW9mKEZEQ3RybFN5c0J1cyksCiAgICAucWRldi52bXNkICA9ICZ2bXN0YXRlX3N5c2J1c19mZGMsCiAgICAucWRldi5yZXNldCA9IGZkY3RybF9leHRlcm5hbF9yZXNldF9zeXNidXMsCiAgICAucWRldi5wcm9wcyA9IChQcm9wZXJ0eVtdKSB7CiAgICAgICAgREVGSU5FX1BST1BfRFJJVkUoImRyaXZlQSIsIEZEQ3RybFN5c0J1cywgc3RhdGUuZHJpdmVzWzBdLmRpbmZvKSwKICAgICAgICBERUZJTkVfUFJPUF9EUklWRSgiZHJpdmVCIiwgRkRDdHJsU3lzQnVzLCBzdGF0ZS5kcml2ZXNbMV0uZGluZm8pLAogICAgICAgIERFRklORV9QUk9QX0VORF9PRl9MSVNUKCksCiAgICB9LAp9OwoKc3RhdGljIFN5c0J1c0RldmljZUluZm8gc3VuNG1fZmRjX2luZm8gPSB7CiAgICAuaW5pdCA9IHN1bjRtX2ZkY19pbml0MSwKICAgIC5xZGV2Lm5hbWUgID0gIlNVTlcsZmR0d28iLAogICAgLnFkZXYuc2l6ZSAgPSBzaXplb2YoRkRDdHJsU3lzQnVzKSwKICAgIC5xZGV2LnZtc2QgID0gJnZtc3RhdGVfc3lzYnVzX2ZkYywKICAgIC5xZGV2LnJlc2V0ID0gZmRjdHJsX2V4dGVybmFsX3Jlc2V0X3N5c2J1cywKICAgIC5xZGV2LnByb3BzID0gKFByb3BlcnR5W10pIHsKICAgICAgICBERUZJTkVfUFJPUF9EUklWRSgiZHJpdmUiLCBGREN0cmxTeXNCdXMsIHN0YXRlLmRyaXZlc1swXS5kaW5mbyksCiAgICAgICAgREVGSU5FX1BST1BfRU5EX09GX0xJU1QoKSwKICAgIH0sCn07CgpzdGF0aWMgdm9pZCBmZGNfcmVnaXN0ZXJfZGV2aWNlcyh2b2lkKQp7CiAgICBpc2FfcWRldl9yZWdpc3RlcigmaXNhX2ZkY19pbmZvKTsKICAgIHN5c2J1c19yZWdpc3Rlcl93aXRocHJvcCgmc3lzYnVzX2ZkY19pbmZvKTsKICAgIHN5c2J1c19yZWdpc3Rlcl93aXRocHJvcCgmc3VuNG1fZmRjX2luZm8pOwp9CgpkZXZpY2VfaW5pdChmZGNfcmVnaXN0ZXJfZGV2aWNlcykK