LyoKICogTkRSIGRlZmluaXRpb25zCiAqCiAqIENvcHlyaWdodCAyMDAxIE92ZSBL5XZlbiwgVHJhbnNHYW1pbmcgVGVjaG5vbG9naWVzCiAqCiAqIFRoaXMgbGlicmFyeSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IKICogbW9kaWZ5IGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIExlc3NlciBHZW5lcmFsIFB1YmxpYwogKiBMaWNlbnNlIGFzIHB1Ymxpc2hlZCBieSB0aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uOyBlaXRoZXIKICogdmVyc2lvbiAyLjEgb2YgdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiAqCiAqIFRoaXMgbGlicmFyeSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLAogKiBidXQgV0lUSE9VVCBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZgogKiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuICBTZWUgdGhlIEdOVQogKiBMZXNzZXIgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBmb3IgbW9yZSBkZXRhaWxzLgogKgogKiBZb3Ugc2hvdWxkIGhhdmUgcmVjZWl2ZWQgYSBjb3B5IG9mIHRoZSBHTlUgTGVzc2VyIEdlbmVyYWwgUHVibGljCiAqIExpY2Vuc2UgYWxvbmcgd2l0aCB0aGlzIGxpYnJhcnk7IGlmIG5vdCwgd3JpdGUgdG8gdGhlIEZyZWUgU29mdHdhcmUKICogRm91bmRhdGlvbiwgSW5jLiwgNTEgRnJhbmtsaW4gU3QsIEZpZnRoIEZsb29yLCBCb3N0b24sIE1BIDAyMTEwLTEzMDEsIFVTQQogKi8KCiNpZm5kZWYgX19XSU5FX05EUl9NSVNDX0gKI2RlZmluZSBfX1dJTkVfTkRSX01JU0NfSAoKI2luY2x1ZGUgPHN0ZGFyZy5oPgoKI2luY2x1ZGUgIndpbmRlZi5oIgojaW5jbHVkZSAid2luYmFzZS5oIgojaW5jbHVkZSAicnBjLmgiCiNpbmNsdWRlICJycGNuZHIuaCIKCnN0cnVjdCBJUFNGYWN0b3J5QnVmZmVyOwoKUEZPUk1BVF9TVFJJTkcgQ29tcHV0ZUNvbmZvcm1hbmNlT3JWYXJpYW5jZSgKICAgIE1JRExfU1RVQl9NRVNTQUdFICpwU3R1Yk1zZywgdW5zaWduZWQgY2hhciAqcE1lbW9yeSwKICAgIFBGT1JNQVRfU1RSSU5HIHBGb3JtYXQsIFVMT05HX1BUUiBkZWYsIFVMT05HX1BUUiAqcENvdW50KTsKCnN0YXRpYyBpbmxpbmUgUEZPUk1BVF9TVFJJTkcgQ29tcHV0ZUNvbmZvcm1hbmNlKFBNSURMX1NUVUJfTUVTU0FHRSBwU3R1Yk1zZywgdW5zaWduZWQgY2hhciAqcE1lbW9yeSwgUEZPUk1BVF9TVFJJTkcgcEZvcm1hdCwgVUxPTkcgZGVmKQp7CiAgICByZXR1cm4gQ29tcHV0ZUNvbmZvcm1hbmNlT3JWYXJpYW5jZShwU3R1Yk1zZywgcE1lbW9yeSwgcEZvcm1hdCwgZGVmLCAmcFN0dWJNc2ctPk1heENvdW50KTsKfQoKc3RhdGljIGlubGluZSBQRk9STUFUX1NUUklORyBDb21wdXRlVmFyaWFuY2UoUE1JRExfU1RVQl9NRVNTQUdFIHBTdHViTXNnLCB1bnNpZ25lZCBjaGFyICpwTWVtb3J5LCBQRk9STUFUX1NUUklORyBwRm9ybWF0LCBVTE9ORyBkZWYpCnsKICAgIFBGT1JNQVRfU1RSSU5HIHJldDsKICAgIFVMT05HX1BUUiBBY3R1YWxDb3VudCA9IHBTdHViTXNnLT5BY3R1YWxDb3VudDsKCiAgICBwU3R1Yk1zZy0+T2Zmc2V0ID0gMDsKICAgIHJldCA9IENvbXB1dGVDb25mb3JtYW5jZU9yVmFyaWFuY2UocFN0dWJNc2csIHBNZW1vcnksIHBGb3JtYXQsIGRlZiwgJkFjdHVhbENvdW50KTsKICAgIHBTdHViTXNnLT5BY3R1YWxDb3VudCA9IChVTE9ORylBY3R1YWxDb3VudDsKICAgIHJldHVybiByZXQ7Cn0KCnR5cGVkZWYgdW5zaWduZWQgY2hhciogKFdJTkFQSSAqTkRSX01BUlNIQUxMKSAgKFBNSURMX1NUVUJfTUVTU0FHRSwgdW5zaWduZWQgY2hhciosIFBGT1JNQVRfU1RSSU5HKTsKdHlwZWRlZiB1bnNpZ25lZCBjaGFyKiAoV0lOQVBJICpORFJfVU5NQVJTSEFMTCkoUE1JRExfU1RVQl9NRVNTQUdFLCB1bnNpZ25lZCBjaGFyKiosUEZPUk1BVF9TVFJJTkcsIHVuc2lnbmVkIGNoYXIpOwp0eXBlZGVmIHZvaWQgICAgICAgICAgIChXSU5BUEkgKk5EUl9CVUZGRVJTSVpFKShQTUlETF9TVFVCX01FU1NBR0UsIHVuc2lnbmVkIGNoYXIqLCBQRk9STUFUX1NUUklORyk7CnR5cGVkZWYgVUxPTkcgICAgICAgICAgKFdJTkFQSSAqTkRSX01FTU9SWVNJWkUpKFBNSURMX1NUVUJfTUVTU0FHRSwgICAgICAgICAgICAgICAgIFBGT1JNQVRfU1RSSU5HKTsKdHlwZWRlZiB2b2lkICAgICAgICAgICAoV0lOQVBJICpORFJfRlJFRSkgICAgICAoUE1JRExfU1RVQl9NRVNTQUdFLCB1bnNpZ25lZCBjaGFyKiwgUEZPUk1BVF9TVFJJTkcpOwoKZXh0ZXJuIGNvbnN0IE5EUl9NQVJTSEFMTCAgIE5kck1hcnNoYWxsZXJbXTsKZXh0ZXJuIGNvbnN0IE5EUl9VTk1BUlNIQUxMIE5kclVubWFyc2hhbGxlcltdOwpleHRlcm4gY29uc3QgTkRSX0JVRkZFUlNJWkUgTmRyQnVmZmVyU2l6ZXJbXTsKZXh0ZXJuIGNvbnN0IE5EUl9NRU1PUllTSVpFIE5kck1lbW9yeVNpemVyW107CmV4dGVybiBjb25zdCBORFJfRlJFRSAgICAgICBOZHJGcmVlcltdOwoKdW5zaWduZWQgbG9uZyBDb21wbGV4U3RydWN0U2l6ZShQTUlETF9TVFVCX01FU1NBR0UgcFN0dWJNc2csIFBGT1JNQVRfU1RSSU5HIHBGb3JtYXQpOwoKI2VuZGlmICAvKiBfX1dJTkVfTkRSX01JU0NfSCAqLwo=