LyoKICogcHRocmVhZCBlbXVsYXRpb24gYmFzZWQgb24ga2VybmVsIHRocmVhZHMKICoKICogV2UgY2FuJ3QgdXNlIHB0aHJlYWRzIGRpcmVjdGx5LCBzbyB3aHkgbm90IGxldCBsaWJjcwogKiB0aGF0IHdhbnQgcHRocmVhZHMgdXNlIFdpbmUncyBvd24gdGhyZWFkaW5nIGluc3RlYWQuLi4KICoKICogQ29weXJpZ2h0IDE5OTkgT3ZlIEvldmVuCiAqIENvcHlyaWdodCAyMDAzIEFsZXhhbmRyZSBKdWxsaWFyZAogKgogKiBUaGlzIGxpYnJhcnkgaXMgZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yCiAqIG1vZGlmeSBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBMZXNzZXIgR2VuZXJhbCBQdWJsaWMKICogTGljZW5zZSBhcyBwdWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyCiAqIHZlcnNpb24gMi4xIG9mIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLgogKgogKiBUaGlzIGxpYnJhcnkgaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwKICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKICogTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFLiAgU2VlIHRoZSBHTlUKICogTGVzc2VyIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KICoKICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIExlc3NlciBHZW5lcmFsIFB1YmxpYwogKiBMaWNlbnNlIGFsb25nIHdpdGggdGhpcyBsaWJyYXJ5OyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDU5IFRlbXBsZSBQbGFjZSwgU3VpdGUgMzMwLCBCb3N0b24sIE1BICAwMjExMS0xMzA3ICBVU0EKICovCgojaW5jbHVkZSAiY29uZmlnLmgiCiNpbmNsdWRlICJ3aW5lL3BvcnQuaCIKCnN0cnVjdCBfcHRocmVhZF9jbGVhbnVwX2J1ZmZlcjsKCiNpbmNsdWRlIDxhc3NlcnQuaD4KI2luY2x1ZGUgPGVycm5vLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KI2luY2x1ZGUgPHNpZ25hbC5oPgojaW5jbHVkZSA8c2V0am1wLmg+CiNpZmRlZiBIQVZFX1VOSVNURF9ICiMgaW5jbHVkZSA8dW5pc3RkLmg+CiNlbmRpZgojaW5jbHVkZSA8c3RyaW5nLmg+CiNpbmNsdWRlIDxzeXMvdHlwZXMuaD4KI2lmZGVmIEhBVkVfU1lTX1NPQ0tFVF9ICiMgaW5jbHVkZSA8c3lzL3NvY2tldC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfU1lTX01NQU5fSAojaW5jbHVkZSA8c3lzL21tYW4uaD4KI2VuZGlmCiNpZmRlZiBIQVZFX05FVElORVRfSU5fSAojIGluY2x1ZGUgPG5ldGluZXQvaW4uaD4KI2VuZGlmCiNpZmRlZiBIQVZFX0FSUEFfTkFNRVNFUl9ICiMgaW5jbHVkZSA8YXJwYS9uYW1lc2VyLmg+CiNlbmRpZgojaWZkZWYgSEFWRV9SRVNPTFZfSAojIGluY2x1ZGUgPHJlc29sdi5oPgojZW5kaWYKI2lmZGVmIEhBVkVfVkFMR1JJTkRfTUVNQ0hFQ0tfSAojaW5jbHVkZSA8dmFsZ3JpbmQvbWVtY2hlY2suaD4KI2VuZGlmCiNpZmRlZiBIQVZFX1NZU19TWVNDQUxMX0gKIyBpbmNsdWRlIDxzeXMvc3lzY2FsbC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfU1lTX0xXUF9ICiMgaW5jbHVkZSA8c3lzL2x3cC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfVUNPTlRFWFRfSAojIGluY2x1ZGUgPHVjb250ZXh0Lmg+CiNlbmRpZgojaWZkZWYgSEFWRV9TQ0hFRF9ICiNpbmNsdWRlIDxzY2hlZC5oPgojZW5kaWYKCiNpbmNsdWRlICJ3aW5lL2xpYnJhcnkuaCIKI2luY2x1ZGUgIndpbmUvcHRocmVhZC5oIgoKI2RlZmluZSBQX09VVFBVVChzdHVmZikgd3JpdGUoMixzdHVmZixzdHJsZW4oc3R1ZmYpKQoKI2RlZmluZSBQU1RSKHN0cikgX19BU01fTkFNRSgjc3RyKQoKc3RhdGljIHN0cnVjdCB3aW5lX3B0aHJlYWRfZnVuY3Rpb25zIGZ1bmNzOwoKLyogdGhyZWFkIGRlc2NyaXB0b3IgKi8KCiNkZWZpbmUgRklSU1RfS0VZIDAKI2RlZmluZSBNQVhfS0VZUyAxNiAvKiBsaWJjNiBkb2Vzbid0IHVzZSB0aGF0IG1hbnksIGJ1dC4uLiAqLwojZGVmaW5lIE1BWF9UU0QgIDE2CgpzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QKewogICAgY2hhciAgICAgICAgICAgICAgIGR1bW15WzIwNDhdOwogICAgaW50ICAgICAgICAgICAgICAgIHRocmVhZF9lcnJubzsKICAgIGludCAgICAgICAgICAgICAgICB0aHJlYWRfaF9lcnJubzsKICAgIGludCAgICAgICAgICAgICAgICBjYW5jZWxfc3RhdGU7CiAgICBpbnQgICAgICAgICAgICAgICAgY2FuY2VsX3R5cGU7CiAgICBzdHJ1Y3QgX19yZXNfc3RhdGUgcmVzX3N0YXRlOwogICAgY29uc3Qgdm9pZCAgICAgICAgKmtleV9kYXRhW01BWF9LRVlTXTsgIC8qIGZvciBub3JtYWwgcHRocmVhZCBrZXlzICovCiAgICBjb25zdCB2b2lkICAgICAgICAqdHNkX2RhdGFbTUFYX1RTRF07ICAgLyogZm9yIGxpYmMgaW50ZXJuYWwgdHNkIHZhcmlhYmxlcyAqLwp9OwoKdHlwZWRlZiBzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QgKnB0aHJlYWRfZGVzY3I7CgpzdGF0aWMgc3RydWN0IHB0aHJlYWRfZGVzY3Jfc3RydWN0IGluaXRpYWxfZGVzY3I7CgpwdGhyZWFkX2Rlc2NyIF9fcHRocmVhZF90aHJlYWRfc2VsZih2b2lkKQp7CiAgICBzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QgKmRlc2NyOwogICAgaWYgKCFmdW5jcy5wdHJfZ2V0X3RocmVhZF9kYXRhKSByZXR1cm4gJmluaXRpYWxfZGVzY3I7CiAgICBkZXNjciA9IGZ1bmNzLnB0cl9nZXRfdGhyZWFkX2RhdGEoKTsKICAgIGlmICghZGVzY3IpIHJldHVybiAmaW5pdGlhbF9kZXNjcjsKICAgIHJldHVybiBkZXNjcjsKfQoKc3RhdGljIGludCAoKmxpYmNfdXNlbG9jYWxlKShpbnQgc2V0KTsKc3RhdGljIGludCAqbGliY19tdWx0aXBsZV90aHJlYWRzOwoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBfX2Vycm5vX2xvY2F0aW9uL19fZXJyb3IvX19lcnJuby9fX19lcnJuby9fX3Rocl9lcnJubwogKgogKiBHZXQgdGhlIHBlci10aHJlYWQgZXJybm8gbG9jYXRpb24uCiAqLwppbnQgKl9fZXJybm9fbG9jYXRpb24odm9pZCkgICAgICAgICAgICAgICAgICAgICAgICAgICAgLyogTGludXggKi8KewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgcmV0dXJuICZkZXNjci0+dGhyZWFkX2Vycm5vOwp9CmludCAqX19lcnJvcih2b2lkKSAgICAgeyByZXR1cm4gX19lcnJub19sb2NhdGlvbigpOyB9ICAvKiBGcmVlQlNEICovCmludCAqX19lcnJubyh2b2lkKSAgICAgeyByZXR1cm4gX19lcnJub19sb2NhdGlvbigpOyB9ICAvKiBOZXRCU0QgKi8KaW50ICpfX19lcnJubyh2b2lkKSAgICB7IHJldHVybiBfX2Vycm5vX2xvY2F0aW9uKCk7IH0gIC8qIFNvbGFyaXMgKi8KaW50ICpfX3Rocl9lcnJubyh2b2lkKSB7IHJldHVybiBfX2Vycm5vX2xvY2F0aW9uKCk7IH0gIC8qIFVuaXhXYXJlICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIF9faF9lcnJub19sb2NhdGlvbgogKgogKiBHZXQgdGhlIHBlci10aHJlYWQgaF9lcnJubyBsb2NhdGlvbi4KICovCmludCAqX19oX2Vycm5vX2xvY2F0aW9uKHZvaWQpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIHJldHVybiAmZGVzY3ItPnRocmVhZF9oX2Vycm5vOwp9CgpzdHJ1Y3QgX19yZXNfc3RhdGUgKl9fcmVzX3N0YXRlKHZvaWQpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIHJldHVybiAmZGVzY3ItPnJlc19zdGF0ZTsKfQoKc3RhdGljIGlubGluZSB2b2lkIHdyaXRlanVtcCggY29uc3QgY2hhciAqc3ltYm9sLCB2b2lkICpkZXN0ICkKewojaWYgZGVmaW5lZChfX0dMSUJDX18pICYmIGRlZmluZWQoX19pMzg2X18pCiAgICB1bnNpZ25lZCBjaGFyICphZGRyID0gZGxzeW0oIFJUTERfTkVYVCwgc3ltYm9sICk7CgogICAgaWYgKCFhZGRyKSByZXR1cm47CgogICAgLyogd3JpdGUgYSByZWxhdGl2ZSBqdW1wIGF0IHRoZSBmdW5jdGlvbiBhZGRyZXNzICovCiAgICBtcHJvdGVjdCgodm9pZCopKCh1bnNpZ25lZCBpbnQpYWRkciAmIH4oZ2V0cGFnZXNpemUoKS0xKSksIDUsIFBST1RfUkVBRHxQUk9UX0VYRUN8UFJPVF9XUklURSk7CiAgICBhZGRyWzBdID0gMHhlOTsKICAgICooaW50ICopKGFkZHIrMSkgPSAodW5zaWduZWQgY2hhciAqKWRlc3QgLSAoYWRkciArIDUpOwogICAgbXByb3RlY3QoKHZvaWQqKSgodW5zaWduZWQgaW50KWFkZHIgJiB+KGdldHBhZ2VzaXplKCktMSkpLCA1LCBQUk9UX1JFQUR8UFJPVF9FWEVDKTsKCiMgaWZkZWYgSEFWRV9WQUxHUklORF9NRU1DSEVDS19ICiAgICBWQUxHUklORF9ESVNDQVJEX1RSQU5TTEFUSU9OUyggYWRkciwgNSApOwojIGVuZGlmCiNlbmRpZiAgLyogX19HTElCQ19fICYmIF9faTM4Nl9fICovCn0KCi8qIHRlbXBvcmFyeSBzdGFja3MgdXNlZCBvbiB0aHJlYWQgZXhpdCAqLwojZGVmaW5lIFRFTVBfU1RBQ0tfU0laRSAxMDI0CiNkZWZpbmUgTkJfVEVNUF9TVEFDS1MgIDgKc3RhdGljIGNoYXIgdGVtcF9zdGFja3NbTkJfVEVNUF9TVEFDS1NdW1RFTVBfU1RBQ0tfU0laRV07CnN0YXRpYyBMT05HIG5leHRfdGVtcF9zdGFjazsgIC8qIG5leHQgdGVtcCBzdGFjayB0byB1c2UgKi8KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgZ2V0X3RlbXBfc3RhY2sKICoKICogR2V0IGEgdGVtcG9yYXJ5IHN0YWNrIGFkZHJlc3MgdG8gcnVuIHRoZSB0aHJlYWQgZXhpdCBjb2RlIG9uLgogKi8KaW5saW5lIHN0YXRpYyBjaGFyICpnZXRfdGVtcF9zdGFjayh2b2lkKQp7CiAgICB1bnNpZ25lZCBpbnQgbmV4dCA9IGludGVybG9ja2VkX3hjaGdfYWRkKCAmbmV4dF90ZW1wX3N0YWNrLCAxICk7CiAgICByZXR1cm4gdGVtcF9zdGFja3NbbmV4dCAlIE5CX1RFTVBfU1RBQ0tTXSArIFRFTVBfU1RBQ0tfU0laRTsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgY2xlYW51cF90aHJlYWQKICoKICogQ2xlYW51cCB0aGUgcmVtYWlucyBvZiBhIHRocmVhZC4gUnVucyBvbiBhIHRlbXBvcmFyeSBzdGFjay4KICovCnN0YXRpYyB2b2lkIGNsZWFudXBfdGhyZWFkKCB2b2lkICpwdHIgKQp7CiAgICAvKiBjb3B5IHRoZSBpbmZvIHN0cnVjdHVyZSBzaW5jZSBpdCBpcyBvbiB0aGUgc3RhY2sgd2Ugd2lsbCBmcmVlICovCiAgICBzdHJ1Y3Qgd2luZV9wdGhyZWFkX3RocmVhZF9pbmZvIGluZm8gPSAqKHN0cnVjdCB3aW5lX3B0aHJlYWRfdGhyZWFkX2luZm8gKilwdHI7CiAgICB3aW5lX2xkdF9mcmVlX2ZzKCBpbmZvLnRlYl9zZWwgKTsKICAgIG11bm1hcCggaW5mby5zdGFja19iYXNlLCBpbmZvLnN0YWNrX3NpemUgKTsKICAgIG11bm1hcCggaW5mby50ZWJfYmFzZSwgaW5mby50ZWJfc2l6ZSApOwojaWZkZWYgSEFWRV9fTFdQX0NSRUFURQogICAgX2x3cF9leGl0KCk7CiNlbmRpZgogICAgX2V4aXQoIGluZm8uZXhpdF9zdGF0dXMgKTsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgd2luZV9wdGhyZWFkX2luaXRfcHJvY2VzcwogKgogKiBJbml0aWFsaXphdGlvbiBmb3IgYSBuZXdseSBjcmVhdGVkIHByb2Nlc3MuCiAqLwp2b2lkIHdpbmVfcHRocmVhZF9pbml0X3Byb2Nlc3MoIGNvbnN0IHN0cnVjdCB3aW5lX3B0aHJlYWRfZnVuY3Rpb25zICpmdW5jdGlvbnMgKQp7CiAgICBtZW1jcHkoICZmdW5jcywgZnVuY3Rpb25zLCBtaW4oZnVuY3Rpb25zLT5zaXplLHNpemVvZihmdW5jcykpICk7CiAgICBmdW5jcy5wdHJfc2V0X3RocmVhZF9kYXRhKCAmaW5pdGlhbF9kZXNjciApOwp9CgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICB3aW5lX3B0aHJlYWRfaW5pdF90aHJlYWQKICoKICogSW5pdGlhbGl6YXRpb24gZm9yIGEgbmV3bHkgY3JlYXRlZCB0aHJlYWQuCiAqLwp2b2lkIHdpbmVfcHRocmVhZF9pbml0X3RocmVhZCggc3RydWN0IHdpbmVfcHRocmVhZF90aHJlYWRfaW5mbyAqaW5mbyApCnsKICAgIHN0cnVjdCBwdGhyZWFkX2Rlc2NyX3N0cnVjdCAqZGVzY3I7CgogICAgaWYgKGZ1bmNzLnB0cl9zZXRfdGhyZWFkX2RhdGEpCiAgICB7CiAgICAgICAgZGVzY3IgPSBjYWxsb2MoIDEsIHNpemVvZigqZGVzY3IpICk7CiAgICAgICAgZnVuY3MucHRyX3NldF90aHJlYWRfZGF0YSggZGVzY3IgKTsKICAgICAgICBpZiAobGliY19tdWx0aXBsZV90aHJlYWRzKSAqbGliY19tdWx0aXBsZV90aHJlYWRzID0gMTsKICAgIH0KICAgIGVsc2UgIC8qIGZpcnN0IHRocmVhZCAqLwogICAgewogICAgICAgIGRlc2NyID0gJmluaXRpYWxfZGVzY3I7CiAgICAgICAgd3JpdGVqdW1wKCAiX19lcnJub19sb2NhdGlvbiIsIF9fZXJybm9fbG9jYXRpb24gKTsKICAgICAgICB3cml0ZWp1bXAoICJfX2hfZXJybm9fbG9jYXRpb24iLCBfX2hfZXJybm9fbG9jYXRpb24gKTsKICAgICAgICB3cml0ZWp1bXAoICJfX3Jlc19zdGF0ZSIsIF9fcmVzX3N0YXRlICk7CiAgICB9CiAgICBkZXNjci0+Y2FuY2VsX3N0YXRlID0gUFRIUkVBRF9DQU5DRUxfRU5BQkxFOwogICAgZGVzY3ItPmNhbmNlbF90eXBlICA9IFBUSFJFQURfQ0FOQ0VMX0FTWU5DSFJPTk9VUzsKICAgIGlmIChsaWJjX3VzZWxvY2FsZSkgbGliY191c2Vsb2NhbGUoIC0xIC8qTENfR0xPQkFMX0xPQ0FMRSovICk7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIHdpbmVfcHRocmVhZF9jcmVhdGVfdGhyZWFkCiAqLwppbnQgd2luZV9wdGhyZWFkX2NyZWF0ZV90aHJlYWQoIHN0cnVjdCB3aW5lX3B0aHJlYWRfdGhyZWFkX2luZm8gKmluZm8gKQp7CiAgICBpZiAoIWluZm8tPnN0YWNrX2Jhc2UpCiAgICB7CiAgICAgICAgaW5mby0+c3RhY2tfYmFzZSA9IHdpbmVfYW5vbl9tbWFwKCBOVUxMLCBpbmZvLT5zdGFja19zaXplLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgUFJPVF9SRUFEIHwgUFJPVF9XUklURSB8IFBST1RfRVhFQywgMCApOwogICAgICAgIGlmIChpbmZvLT5zdGFja19iYXNlID09ICh2b2lkICopLTEpIHJldHVybiAtMTsKICAgIH0KI2lmZGVmIEhBVkVfQ0xPTkUKICAgIGlmIChjbG9uZSggKGludCAoKikodm9pZCAqKSlpbmZvLT5lbnRyeSwgKGNoYXIgKilpbmZvLT5zdGFja19iYXNlICsgaW5mby0+c3RhY2tfc2l6ZSwKICAgICAgICAgICAgICAgQ0xPTkVfVk0gfCBDTE9ORV9GUyB8IENMT05FX0ZJTEVTIHwgU0lHQ0hMRCwgaW5mbyApIDwgMCkKICAgICAgICByZXR1cm4gLTE7CiAgICByZXR1cm4gMDsKI2VsaWYgZGVmaW5lZChIQVZFX1JGT1JLKQogICAgewogICAgICAgIHZvaWQgKipzcCA9ICh2b2lkICoqKSgoY2hhciAqKWluZm8tPnN0YWNrX2Jhc2UgKyBpbmZvLT5zdGFja19zaXplKTsKICAgICAgICAqLS1zcCA9IGluZm87CiAgICAgICAgKi0tc3AgPSAwOwogICAgICAgICotLXNwID0gaW5mby0+ZW50cnk7CiAgICAgICAgX19hc21fXyBfX3ZvbGF0aWxlX18oCiAgICAgICAgICAgICJwdXNobCAlMjtcblx0IiAgICAgICAgICAgICAvKiBmbGFncyAqLwogICAgICAgICAgICAicHVzaGwgJDA7XG5cdCIgICAgICAgICAgICAgLyogMCA/ICovCiAgICAgICAgICAgICJtb3ZsICUxLCUlZWF4O1xuXHQiICAgICAgICAvKiBTWVNfcmZvcmsgKi8KICAgICAgICAgICAgIi5ieXRlIDB4OWE7IC5sb25nIDA7IC53b3JkIDc7XG5cdCIgLyogbGNhbGwgNzowLi4uIEZyZWVCU0Qgc3lzY2FsbCAqLwogICAgICAgICAgICAiY21wbCAkMCwgJSVlZHg7XG5cdCIKICAgICAgICAgICAgImplIDFmO1xuXHQiCiAgICAgICAgICAgICJtb3ZsICUwLCUlZXNwO1xuXHQiICAgICAgICAvKiBjaGlsZCAtPiBuZXcgdGhyZWFkICovCiAgICAgICAgICAgICJyZXQ7XG4iCiAgICAgICAgICAgICIxOlxuXHQiICAgICAgICAgICAgICAgICAgICAvKiBwYXJlbnQgLT4gY2FsbGVyIHRocmVhZCAqLwogICAgICAgICAgICAiYWRkbCAkOCwlJWVzcCIgOgogICAgICAgICAgICA6ICJyIiAoc3ApLCAiZyIgKFNZU19yZm9yayksICJnIiAoUkZQUk9DIHwgUkZNRU0gfCBSRlRIUkVBRCkKICAgICAgICAgICAgOiAiZWF4IiwgImVkeCIpOwogICAgICAgIHJldHVybiAwOwogICAgfQojZWxpZiBkZWZpbmVkKEhBVkVfX0xXUF9DUkVBVEUpCiAgICB7CiAgICAgICAgdWNvbnRleHRfdCBjb250ZXh0OwogICAgICAgIF9sd3BfbWFrZWNvbnRleHQoICZjb250ZXh0LCAodm9pZCgqKSh2b2lkICopKWluZm8tPmVudHJ5LCBpbmZvLAogICAgICAgICAgICAgICAgICAgICAgICAgIE5VTEwsIGluZm8tPnN0YWNrX2Jhc2UsIGluZm8tPnN0YWNrX3NpemUgKTsKICAgICAgICBpZiAoIF9sd3BfY3JlYXRlKCAmY29udGV4dCwgMCwgTlVMTCApICkKICAgICAgICAgICAgcmV0dXJuIC0xOwogICAgICAgIHJldHVybiAwOwogICAgfQojZW5kaWYKICAgIHJldHVybiAtMTsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgd2luZV9wdGhyZWFkX2luaXRfY3VycmVudF90ZWIKICoKICogU2V0IHRoZSBjdXJyZW50IFRFQiBmb3IgYSBuZXcgdGhyZWFkLgogKi8Kdm9pZCB3aW5lX3B0aHJlYWRfaW5pdF9jdXJyZW50X3RlYiggc3RydWN0IHdpbmVfcHRocmVhZF90aHJlYWRfaW5mbyAqaW5mbyApCnsKI2lmZGVmIF9faTM4Nl9fCiAgICAvKiBPbiB0aGUgaTM4NiwgdGhlIGN1cnJlbnQgdGhyZWFkIGlzIGluIHRoZSAlZnMgcmVnaXN0ZXIgKi8KICAgIExEVF9FTlRSWSBmc19lbnRyeTsKCiAgICB3aW5lX2xkdF9zZXRfYmFzZSggJmZzX2VudHJ5LCBpbmZvLT50ZWJfYmFzZSApOwogICAgd2luZV9sZHRfc2V0X2xpbWl0KCAmZnNfZW50cnksIGluZm8tPnRlYl9zaXplIC0gMSApOwogICAgd2luZV9sZHRfc2V0X2ZsYWdzKCAmZnNfZW50cnksIFdJTkVfTERUX0ZMQUdTX0RBVEF8V0lORV9MRFRfRkxBR1NfMzJCSVQgKTsKICAgIHdpbmVfbGR0X2luaXRfZnMoIGluZm8tPnRlYl9zZWwsICZmc19lbnRyeSApOwojZWxpZiBkZWZpbmVkKF9fcG93ZXJwY19fKQogICAgLyogT24gUG93ZXJQQywgdGhlIGN1cnJlbnQgVEVCIGlzIGluIHRoZSBncHIxMyByZWdpc3RlciAqLwojIGlmZGVmIF9fQVBQTEVfXwogICAgX19hc21fXyBfX3ZvbGF0aWxlX18oIm1yIHIxMywgJTAiIDogOiAiciIgKGluZm8tPnRlYl9iYXNlKSk7CiMgZWxzZQogICAgX19hc21fXyBfX3ZvbGF0aWxlX18oIm1yIDIsICUwIiA6IDogInIiIChpbmZvLT50ZWJfYmFzZSkpOwojIGVuZGlmCiNlbGlmIGRlZmluZWQoSEFWRV9fTFdQX0NSRUFURSkKICAgIC8qIE9uIG5vbi1pMzg2IFNvbGFyaXMsIHdlIHVzZSB0aGUgTFdQIHByaXZhdGUgcG9pbnRlciAqLwogICAgX2x3cF9zZXRwcml2YXRlKCBpbmZvLT50ZWJfYmFzZSApOwojZW5kaWYKCiAgICAvKiBzZXQgcGlkIGFuZCB0aWQgKi8KICAgIGluZm8tPnBpZCA9IGdldHBpZCgpOwojaWZkZWYgSEFWRV9fTFdQX1NFTEYKICAgIGluZm8tPnRpZCA9IF9sd3Bfc2VsZigpOwojZWxzZQogICAgaW5mby0+dGlkID0gLTE7CiNlbmRpZgp9CgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICB3aW5lX3B0aHJlYWRfZ2V0X2N1cnJlbnRfdGViCiAqLwp2b2lkICp3aW5lX3B0aHJlYWRfZ2V0X2N1cnJlbnRfdGViKHZvaWQpCnsKICAgIHZvaWQgKnJldDsKCiNpZmRlZiBfX2kzODZfXwogICAgX19hc21fXyggIi5ieXRlIDB4NjRcblx0bW92bCAweDE4LCUwIiA6ICI9ciIgKHJldCkgKTsKI2VsaWYgZGVmaW5lZChIQVZFX19MV1BfQ1JFQVRFKQogICAgcmV0ID0gX2x3cF9nZXRwcml2YXRlKCk7CiNlbGlmIGRlZmluZWQoX19wb3dlcnBjX18pCiMgaWZkZWYgX19BUFBMRV9fCiAgICBfX2FzbV9fKCAibXIgJTAscjEzIiA6ICI9ciIgKHJldCkgKTsKIyBlbHNlCiAgICBfX2FzbV9fKCAibXIgJTAsMiIgOiAiPXIiIChyZXQpICk7CiMgZW5kaWYKI2Vsc2UKIyBlcnJvciB3aW5lX3B0aHJlYWRfZ2V0X2N1cnJlbnRfdGViIG5vdCBkZWZpbmVkIGZvciB0aGlzIGFyY2hpdGVjdHVyZQojZW5kaWYgIC8qIF9faTM4Nl9fICovCgogICAgcmV0dXJuIHJldDsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgd2luZV9wdGhyZWFkX2V4aXRfdGhyZWFkCiAqLwp2b2lkIHdpbmVfcHRocmVhZF9leGl0X3RocmVhZCggc3RydWN0IHdpbmVfcHRocmVhZF90aHJlYWRfaW5mbyAqaW5mbyApCnsKICAgIHdpbmVfc3dpdGNoX3RvX3N0YWNrKCBjbGVhbnVwX3RocmVhZCwgaW5mbywgZ2V0X3RlbXBfc3RhY2soKSApOwp9CgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICB3aW5lX3B0aHJlYWRfYWJvcnRfdGhyZWFkCiAqLwp2b2lkIHdpbmVfcHRocmVhZF9hYm9ydF90aHJlYWQoIGludCBzdGF0dXMgKQp7CiNpZmRlZiBIQVZFX19MV1BfQ1JFQVRFCiAgICBfbHdwX2V4aXQoKTsKI2VuZGlmCiAgICBfZXhpdCggc3RhdHVzICk7Cn0KCgovKiBDdXJyZW50bHkgdGhpcyBwcm9iYWJseSB3b3JrcyBvbmx5IGZvciBnbGliYzIsCiAqIHdoaWNoIGNoZWNrcyBmb3IgdGhlIHByZXNlbmNlIG9mIGRvdWJsZS11bmRlcnNjb3JlLXByZXBlbmRlZAogKiBwdGhyZWFkIHByaW1pdGl2ZXMsIGFuZCB1c2UgdGhlbSBpZiBhdmFpbGFibGUuCiAqIElmIHRoZXkgYXJlIG5vdCBhdmFpbGFibGUsIHRoZSBsaWJjIGRlZmF1bHRzIHRvCiAqIG5vbi10aHJlYWRzYWZlIG9wZXJhdGlvbiAobm90IGdvb2QpLiAqLwoKI2lmIGRlZmluZWQoX19HTElCQ19fKSB8fCBkZWZpbmVkKF9fRnJlZUJTRF9fKQoKLyogYWRhcHQgYXMgbmVjZXNzYXJ5IChhIGNvbnN0cnVjdCBsaWtlIHRoaXMgaXMgdXNlZCBpbiBnbGliYyBzb3VyY2VzKSAqLwojZGVmaW5lIHN0cm9uZ19hbGlhcyhvcmlnLCBhbGlhcykgXAogYXNtKCIuZ2xvYmwgIiBQU1RSKGFsaWFzKSAiXG4iIFwKICAgICAiXHQuc2V0ICIgUFNUUihhbGlhcykgIiwiIFBTVFIob3JpZykpCgpzdHJ1Y3QgZm9ya19ibG9jazsKCi8qIHB0aHJlYWQgZnVuY3Rpb25zIHJlZGlyZWN0aW9uICovCgpzdHJ1Y3QgcHRocmVhZF9mdW5jdGlvbnMKewogIHBpZF90ICgqcHRyX3B0aHJlYWRfZm9yaykgKHN0cnVjdCBmb3JrX2Jsb2NrICopOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfZGVzdHJveSkgKHB0aHJlYWRfYXR0cl90ICopOwogIGludCAoKnB0cl9fX3B0aHJlYWRfYXR0cl9pbml0XzJfMCkgKHB0aHJlYWRfYXR0cl90ICopOwogIGludCAoKnB0cl9fX3B0aHJlYWRfYXR0cl9pbml0XzJfMSkgKHB0aHJlYWRfYXR0cl90ICopOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfZ2V0ZGV0YWNoc3RhdGUpIChjb25zdCBwdGhyZWFkX2F0dHJfdCAqLCBpbnQgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9zZXRkZXRhY2hzdGF0ZSkgKHB0aHJlYWRfYXR0cl90ICosIGludCk7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9nZXRpbmhlcml0c2NoZWQpIChjb25zdCBwdGhyZWFkX2F0dHJfdCAqLCBpbnQgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9zZXRpbmhlcml0c2NoZWQpIChwdGhyZWFkX2F0dHJfdCAqLCBpbnQpOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfZ2V0c2NoZWRwYXJhbSkgKGNvbnN0IHB0aHJlYWRfYXR0cl90ICosIHN0cnVjdCBzY2hlZF9wYXJhbSAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX3NldHNjaGVkcGFyYW0pIChwdGhyZWFkX2F0dHJfdCAqLCBjb25zdCBzdHJ1Y3Qgc2NoZWRfcGFyYW0gKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9nZXRzY2hlZHBvbGljeSkgKGNvbnN0IHB0aHJlYWRfYXR0cl90ICosIGludCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX3NldHNjaGVkcG9saWN5KSAocHRocmVhZF9hdHRyX3QgKiwgaW50KTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX2dldHNjb3BlKSAoY29uc3QgcHRocmVhZF9hdHRyX3QgKiwgaW50ICopOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfc2V0c2NvcGUpIChwdGhyZWFkX2F0dHJfdCAqLCBpbnQpOwogIGludCAoKnB0cl9wdGhyZWFkX2NvbmRhdHRyX2Rlc3Ryb3kpIChwdGhyZWFkX2NvbmRhdHRyX3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfY29uZGF0dHJfaW5pdCkgKHB0aHJlYWRfY29uZGF0dHJfdCAqKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfYnJvYWRjYXN0KSAocHRocmVhZF9jb25kX3QgKik7CiAgaW50ICgqcHRyX19fcHRocmVhZF9jb25kX2Rlc3Ryb3kpIChwdGhyZWFkX2NvbmRfdCAqKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfaW5pdCkgKHB0aHJlYWRfY29uZF90ICosIGNvbnN0IHB0aHJlYWRfY29uZGF0dHJfdCAqKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfc2lnbmFsKSAocHRocmVhZF9jb25kX3QgKik7CiAgaW50ICgqcHRyX19fcHRocmVhZF9jb25kX3dhaXQpIChwdGhyZWFkX2NvbmRfdCAqLCBwdGhyZWFkX211dGV4X3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfZXF1YWwpIChwdGhyZWFkX3QsIHB0aHJlYWRfdCk7CiAgdm9pZCAoKnB0cl9fX3B0aHJlYWRfZXhpdCkgKHZvaWQgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfZ2V0c2NoZWRwYXJhbSkgKHB0aHJlYWRfdCwgaW50ICosIHN0cnVjdCBzY2hlZF9wYXJhbSAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9zZXRzY2hlZHBhcmFtKSAocHRocmVhZF90LCBpbnQsIGNvbnN0IHN0cnVjdCBzY2hlZF9wYXJhbSAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9tdXRleF9kZXN0cm95KSAocHRocmVhZF9tdXRleF90ICopOwogIGludCAoKnB0cl9wdGhyZWFkX211dGV4X2luaXQpIChwdGhyZWFkX211dGV4X3QgKiwgY29uc3QgcHRocmVhZF9tdXRleGF0dHJfdCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9tdXRleF9sb2NrKSAocHRocmVhZF9tdXRleF90ICopOwogIGludCAoKnB0cl9wdGhyZWFkX211dGV4X3RyeWxvY2spIChwdGhyZWFkX211dGV4X3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfbXV0ZXhfdW5sb2NrKSAocHRocmVhZF9tdXRleF90ICopOwogIHB0aHJlYWRfdCAoKnB0cl9wdGhyZWFkX3NlbGYpICh2b2lkKTsKICBpbnQgKCpwdHJfcHRocmVhZF9zZXRjYW5jZWxzdGF0ZSkgKGludCwgaW50ICopOwogIGludCAoKnB0cl9wdGhyZWFkX3NldGNhbmNlbHR5cGUpIChpbnQsIGludCAqKTsKICB2b2lkICgqcHRyX3B0aHJlYWRfZG9fZXhpdCkgKHZvaWQgKnJldHZhbCwgY2hhciAqY3VycmVudGZyYW1lKTsKICB2b2lkICgqcHRyX3B0aHJlYWRfY2xlYW51cF91cHRvKSAoam1wX2J1ZiB0YXJnZXQsIGNoYXIgKnRhcmdldGZyYW1lKTsKICBwdGhyZWFkX2Rlc2NyICgqcHRyX3B0aHJlYWRfdGhyZWFkX3NlbGYpICh2b2lkKTsKICBpbnQgKCpwdHJfcHRocmVhZF9pbnRlcm5hbF90c2Rfc2V0KSAoaW50IGtleSwgY29uc3Qgdm9pZCAqcG9pbnRlcik7CiAgdm9pZCAqICgqcHRyX3B0aHJlYWRfaW50ZXJuYWxfdHNkX2dldCkgKGludCBrZXkpOwogIHZvaWQgKiogX19hdHRyaWJ1dGVfXyAoKF9fY29uc3RfXykpICgqcHRyX3B0aHJlYWRfaW50ZXJuYWxfdHNkX2FkZHJlc3MpIChpbnQga2V5KTsKICBpbnQgKCpwdHJfcHRocmVhZF9zaWdhY3Rpb24pIChpbnQgc2lnLCBjb25zdCBzdHJ1Y3Qgc2lnYWN0aW9uICogYWN0LCBzdHJ1Y3Qgc2lnYWN0aW9uICpvYWN0KTsKICBpbnQgKCpwdHJfcHRocmVhZF9zaWd3YWl0KSAoY29uc3Qgc2lnc2V0X3QgKnNldCwgaW50ICpzaWcpOwogIGludCAoKnB0cl9wdGhyZWFkX3JhaXNlKSAoaW50IHNpZyk7CiAgaW50ICgqcHRyX19fcHRocmVhZF9jb25kX3RpbWVkd2FpdCkgKHB0aHJlYWRfY29uZF90ICosIHB0aHJlYWRfbXV0ZXhfdCAqLCBjb25zdCBzdHJ1Y3QgdGltZXNwZWMgKik7CiAgdm9pZCAoKnB0cl9fcHRocmVhZF9jbGVhbnVwX3B1c2gpIChzdHJ1Y3QgX3B0aHJlYWRfY2xlYW51cF9idWZmZXIgKiBidWZmZXIsIHZvaWQgKCpyb3V0aW5lKSh2b2lkICopLCB2b2lkICogYXJnKTsKICB2b2lkICgqcHRyX19wdGhyZWFkX2NsZWFudXBfcG9wKSAoc3RydWN0IF9wdGhyZWFkX2NsZWFudXBfYnVmZmVyICogYnVmZmVyLCBpbnQgZXhlY3V0ZSk7Cn07CgpzdGF0aWMgcGlkX3QgKCpsaWJjX2ZvcmspKHZvaWQpOwpzdGF0aWMgaW50ICgqbGliY19zaWdhY3Rpb24pKGludCBzaWdudW0sIGNvbnN0IHN0cnVjdCBzaWdhY3Rpb24gKmFjdCwgc3RydWN0IHNpZ2FjdGlvbiAqb2xkYWN0KTsKc3RhdGljIGludCAqKCpsaWJjX3B0aHJlYWRfaW5pdCkoIGNvbnN0IHN0cnVjdCBwdGhyZWFkX2Z1bmN0aW9ucyAqZnVuY3MgKTsKCnN0YXRpYyBzdHJ1Y3QgcHRocmVhZF9mdW5jdGlvbnMgbGliY19wdGhyZWFkX2Z1bmN0aW9uczsKCnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfdGhyZWFkX3NlbGYsIHB0aHJlYWRfdGhyZWFkX3NlbGYpOwoKLyogcmVkZWZpbmUgdGhpcyB0byBwcmV2ZW50IGxpYnB0aHJlYWQgZnJvbSBvdmVycmlkaW5nIG91ciBmdW5jdGlvbiBwb2ludGVycyAqLwppbnQgKl9fbGliY19wdGhyZWFkX2luaXQoIGNvbnN0IHN0cnVjdCBwdGhyZWFkX2Z1bmN0aW9ucyAqZnVuY3MgKQp7CiAgICByZXR1cm4gbGliY19tdWx0aXBsZV90aHJlYWRzOwp9Cgp0eXBlZGVmIHN0cnVjdCBfd2luZV9jbGVhbnVwIHsKICB2b2lkICgqcm91dGluZSkodm9pZCAqKTsKICB2b2lkICphcmc7Cn0gKndpbmVfY2xlYW51cDsKCmludCBwdGhyZWFkX2NyZWF0ZShwdGhyZWFkX3QqIHRocmVhZCwgY29uc3QgcHRocmVhZF9hdHRyX3QqIGF0dHIsIHZvaWQqCiAgICAgICAgKCpzdGFydF9yb3V0aW5lKSh2b2lkICopLCB2b2lkKiBhcmcpCnsKICAgIGFzc2VydCggZnVuY3MucHRyX3B0aHJlYWRfY3JlYXRlICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfY3JlYXRlKCB0aHJlYWQsIGF0dHIsIHN0YXJ0X3JvdXRpbmUsIGFyZyApOwp9CgppbnQgcHRocmVhZF9jYW5jZWwocHRocmVhZF90IHRocmVhZCkKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9jYW5jZWwgKTsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jYW5jZWwoIHRocmVhZCApOwp9CgppbnQgcHRocmVhZF9qb2luKHB0aHJlYWRfdCB0aHJlYWQsIHZvaWQgKip2YWx1ZV9wdHIpCnsKICAgIGFzc2VydCggZnVuY3MucHRyX3B0aHJlYWRfam9pbiApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2pvaW4oIHRocmVhZCwgdmFsdWVfcHRyICk7Cn0KCmludCBwdGhyZWFkX2RldGFjaChwdGhyZWFkX3QgdGhyZWFkKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX2RldGFjaCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2RldGFjaCggdGhyZWFkICk7Cn0KCi8qIEZJWE1FOiB3ZSBoYXZlIG5vIGVxdWl2YWxlbnRzIGluIHdpbjMyIGZvciB0aGUgcG9saWN5cyAqLwovKiBzbyBqdXN0IGtlZXAgdGhpcyBhcyBhIHN0dWIgKi8KaW50IHB0aHJlYWRfYXR0cl9zZXRzY2hlZHBvbGljeShwdGhyZWFkX2F0dHJfdCAqYXR0ciwgaW50IHBvbGljeSkKewogIFBfT1VUUFVUKCJGSVhNRTpwdGhyZWFkX2F0dHJfc2V0c2NoZWRwb2xpY3lcbiIpOwogIHJldHVybiAwOwp9CgovKiBGSVhNRTogbm8gd2luMzIgZXF1aXZhbGVudCBmb3Igc2NvcGUgKi8KaW50IHB0aHJlYWRfYXR0cl9zZXRzY29wZShwdGhyZWFkX2F0dHJfdCAqYXR0ciwgaW50IHNjb3BlKQp7CiAgUF9PVVRQVVQoIkZJWE1FOnB0aHJlYWRfYXR0cl9zZXRzY29wZVxuIik7CiAgcmV0dXJuIDA7IC8qIHJldHVybiBzdWNjZXNzICovCn0KCi8qIEZJWE1FOiBubyB3aW4zMiBlcXVpdmFsZW50IGZvciBzY2hlZHVsZSBwYXJhbSAqLwppbnQgcHRocmVhZF9hdHRyX3NldHNjaGVkcGFyYW0ocHRocmVhZF9hdHRyX3QgKmF0dHIsCiAgICBjb25zdCBzdHJ1Y3Qgc2NoZWRfcGFyYW0gKnBhcmFtKQp7CiAgUF9PVVRQVVQoIkZJWE1FOnB0aHJlYWRfYXR0cl9zZXRzY2hlZHBhcmFtXG4iKTsKICByZXR1cm4gMDsgLyogcmV0dXJuIHN1Y2Nlc3MgKi8KfQoKLyogRklYTUUgKi8KaW50IHB0aHJlYWRfYXR0cl9zZXRzdGFjayhwdGhyZWFkX2F0dHJfdCAqYXR0ciwgdm9pZCAqYWRkciwgc2l6ZV90IHNpemUpCnsKICByZXR1cm4gMDsgLyogcmV0dXJuIHN1Y2Nlc3MgKi8KfQoKaW50IF9fcHRocmVhZF9vbmNlKHB0aHJlYWRfb25jZV90ICpvbmNlX2NvbnRyb2wsIHZvaWQgKCppbml0X3JvdXRpbmUpKHZvaWQpKQp7CiAgICBzdGF0aWMgcHRocmVhZF9vbmNlX3QgdGhlX29uY2UgPSBQVEhSRUFEX09OQ0VfSU5JVDsKICAgIGxvbmcgb25jZV9ub3c7CgogICAgbWVtY3B5KCZvbmNlX25vdywmdGhlX29uY2Usc2l6ZW9mKG9uY2Vfbm93KSk7CiAgICBpZiAoaW50ZXJsb2NrZWRfY21weGNoZygobG9uZyopb25jZV9jb250cm9sLCBvbmNlX25vdysxLCBvbmNlX25vdykgPT0gb25jZV9ub3cpCiAgICAgICAgKCppbml0X3JvdXRpbmUpKCk7CiAgICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX29uY2UsIHB0aHJlYWRfb25jZSk7Cgp2b2lkIF9fcHRocmVhZF9raWxsX290aGVyX3RocmVhZHNfbnAodm9pZCkKewogICAgLyogd2UgZG9uJ3QgbmVlZCB0byBkbyBhbnl0aGluZyBoZXJlICovCn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9raWxsX290aGVyX3RocmVhZHNfbnAsIHB0aHJlYWRfa2lsbF9vdGhlcl90aHJlYWRzX25wKTsKCi8qKioqKiBhdGZvcmsgKioqKiovCgojZGVmaW5lIE1BWF9BVEZPUksgOCAgLyogbGliYyBkb2Vzbid0IG5lZWQgdGhhdCBtYW55IGFueXdheSAqLwoKc3RhdGljIHB0aHJlYWRfbXV0ZXhfdCBhdGZvcmtfbXV0ZXggPSBQVEhSRUFEX01VVEVYX0lOSVRJQUxJWkVSOwoKdHlwZWRlZiB2b2lkICgqYXRmb3JrX2hhbmRsZXIpKCk7CnN0YXRpYyBhdGZvcmtfaGFuZGxlciBhdGZvcmtfcHJlcGFyZVtNQVhfQVRGT1JLXTsKc3RhdGljIGF0Zm9ya19oYW5kbGVyIGF0Zm9ya19wYXJlbnRbTUFYX0FURk9SS107CnN0YXRpYyBhdGZvcmtfaGFuZGxlciBhdGZvcmtfY2hpbGRbTUFYX0FURk9SS107CnN0YXRpYyBpbnQgYXRmb3JrX2NvdW50OwoKaW50IF9fcHRocmVhZF9hdGZvcmsodm9pZCAoKnByZXBhcmUpKHZvaWQpLCB2b2lkICgqcGFyZW50KSh2b2lkKSwgdm9pZCAoKmNoaWxkKSh2b2lkKSkKewogICAgcHRocmVhZF9tdXRleF9sb2NrKCAmYXRmb3JrX211dGV4ICk7CiAgICBhc3NlcnQoIGF0Zm9ya19jb3VudCA8IE1BWF9BVEZPUksgKTsKICAgIGF0Zm9ya19wcmVwYXJlW2F0Zm9ya19jb3VudF0gPSBwcmVwYXJlOwogICAgYXRmb3JrX3BhcmVudFthdGZvcmtfY291bnRdID0gcGFyZW50OwogICAgYXRmb3JrX2NoaWxkW2F0Zm9ya19jb3VudF0gPSBjaGlsZDsKICAgIGF0Zm9ya19jb3VudCsrOwogICAgcHRocmVhZF9tdXRleF91bmxvY2soICZhdGZvcmtfbXV0ZXggKTsKICAgIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfYXRmb3JrLCBwdGhyZWFkX2F0Zm9yayk7CgpwaWRfdCBfX2Zvcmsodm9pZCkKewogICAgcGlkX3QgcGlkOwogICAgaW50IGk7CgogICAgaWYgKCFsaWJjX2ZvcmspCiAgICB7CiAgICAgICAgbGliY19mb3JrID0gZGxzeW0oIFJUTERfTkVYVCwgImZvcmsiICk7CiAgICAgICAgYXNzZXJ0KCBsaWJjX2ZvcmsgKTsKICAgIH0KICAgIHB0aHJlYWRfbXV0ZXhfbG9jayggJmF0Zm9ya19tdXRleCApOwogICAgLyogcHJlcGFyZSBoYW5kbGVycyBhcmUgY2FsbGVkIGluIHJldmVyc2UgaW5zZXJ0aW9uIG9yZGVyICovCiAgICBmb3IgKGkgPSBhdGZvcmtfY291bnQgLSAxOyBpID49IDA7IGktLSkgaWYgKGF0Zm9ya19wcmVwYXJlW2ldKSBhdGZvcmtfcHJlcGFyZVtpXSgpOwogICAgaWYgKCEocGlkID0gbGliY19mb3JrKCkpKQogICAgewogICAgICAgIHB0aHJlYWRfbXV0ZXhfaW5pdCggJmF0Zm9ya19tdXRleCwgTlVMTCApOwogICAgICAgIGZvciAoaSA9IDA7IGkgPCBhdGZvcmtfY291bnQ7IGkrKykgaWYgKGF0Zm9ya19jaGlsZFtpXSkgYXRmb3JrX2NoaWxkW2ldKCk7CiAgICB9CiAgICBlbHNlCiAgICB7CiAgICAgICAgZm9yIChpID0gMDsgaSA8IGF0Zm9ya19jb3VudDsgaSsrKSBpZiAoYXRmb3JrX3BhcmVudFtpXSkgYXRmb3JrX3BhcmVudFtpXSgpOwogICAgICAgIHB0aHJlYWRfbXV0ZXhfdW5sb2NrKCAmYXRmb3JrX211dGV4ICk7CiAgICB9CiAgICByZXR1cm4gcGlkOwp9CnN0cm9uZ19hbGlhcyhfX2ZvcmssIGZvcmspOwoKLyoqKioqIE1VVEVYRVMgKioqKiovCgppbnQgX19wdGhyZWFkX211dGV4X2luaXQocHRocmVhZF9tdXRleF90ICptdXRleCwgY29uc3QgcHRocmVhZF9tdXRleGF0dHJfdCAqbXV0ZXhhdHRyKQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X2luaXQpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X2luaXQoIG11dGV4LCBtdXRleGF0dHIgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX211dGV4X2luaXQsIHB0aHJlYWRfbXV0ZXhfaW5pdCk7CgppbnQgX19wdGhyZWFkX211dGV4X2xvY2socHRocmVhZF9tdXRleF90ICptdXRleCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9tdXRleF9sb2NrKSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9tdXRleF9sb2NrKCBtdXRleCApOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhfbG9jaywgcHRocmVhZF9tdXRleF9sb2NrKTsKCmludCBfX3B0aHJlYWRfbXV0ZXhfdHJ5bG9jayhwdGhyZWFkX211dGV4X3QgKm11dGV4KQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X3RyeWxvY2spIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X3RyeWxvY2soIG11dGV4ICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleF90cnlsb2NrLCBwdGhyZWFkX211dGV4X3RyeWxvY2spOwoKaW50IF9fcHRocmVhZF9tdXRleF91bmxvY2socHRocmVhZF9tdXRleF90ICptdXRleCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9tdXRleF91bmxvY2spIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X3VubG9jayggbXV0ZXggKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX211dGV4X3VubG9jaywgcHRocmVhZF9tdXRleF91bmxvY2spOwoKaW50IF9fcHRocmVhZF9tdXRleF9kZXN0cm95KHB0aHJlYWRfbXV0ZXhfdCAqbXV0ZXgpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfbXV0ZXhfZGVzdHJveSkgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfbXV0ZXhfZGVzdHJveSggbXV0ZXggKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX211dGV4X2Rlc3Ryb3ksIHB0aHJlYWRfbXV0ZXhfZGVzdHJveSk7CgoKLyoqKioqIE1VVEVYIEFUVFJJQlVURVMgKioqKiovCi8qIGp1c3QgZHVtbWllcywgc2luY2UgY3JpdGljYWwgc2VjdGlvbnMgYXJlIGFsd2F5cyByZWN1cnNpdmUgKi8KCmludCBfX3B0aHJlYWRfbXV0ZXhhdHRyX2luaXQocHRocmVhZF9tdXRleGF0dHJfdCAqYXR0cikKewogIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhhdHRyX2luaXQsIHB0aHJlYWRfbXV0ZXhhdHRyX2luaXQpOwoKaW50IF9fcHRocmVhZF9tdXRleGF0dHJfZGVzdHJveShwdGhyZWFkX211dGV4YXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfZGVzdHJveSwgcHRocmVhZF9tdXRleGF0dHJfZGVzdHJveSk7CgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9zZXRraW5kX25wKHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIsIGludCBraW5kKQp7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfc2V0a2luZF9ucCwgcHRocmVhZF9tdXRleGF0dHJfc2V0a2luZF9ucCk7CgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9nZXRraW5kX25wKHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIsIGludCAqa2luZCkKewogICpraW5kID0gUFRIUkVBRF9NVVRFWF9SRUNVUlNJVkU7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfZ2V0a2luZF9ucCwgcHRocmVhZF9tdXRleGF0dHJfZ2V0a2luZF9ucCk7CgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9zZXR0eXBlKHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIsIGludCBraW5kKQp7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfc2V0dHlwZSwgcHRocmVhZF9tdXRleGF0dHJfc2V0dHlwZSk7CgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9nZXR0eXBlKHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIsIGludCAqa2luZCkKewogICpraW5kID0gUFRIUkVBRF9NVVRFWF9SRUNVUlNJVkU7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfZ2V0dHlwZSwgcHRocmVhZF9tdXRleGF0dHJfZ2V0dHlwZSk7CgoKLyoqKioqIFRIUkVBRC1TUEVDSUZJQyBWQVJJQUJMRVMgKEtFWVMpICoqKioqLwoKaW50IF9fcHRocmVhZF9rZXlfY3JlYXRlKHB0aHJlYWRfa2V5X3QgKmtleSwgdm9pZCAoKmRlc3RyX2Z1bmN0aW9uKSh2b2lkICopKQp7CiAgICBzdGF0aWMgbG9uZyBrZXljbnQgPSBGSVJTVF9LRVk7CiAgICAqa2V5ID0gaW50ZXJsb2NrZWRfeGNoZ19hZGQoJmtleWNudCwgMSk7CiAgICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2tleV9jcmVhdGUsIHB0aHJlYWRfa2V5X2NyZWF0ZSk7CgppbnQgX19wdGhyZWFkX2tleV9kZWxldGUocHRocmVhZF9rZXlfdCBrZXkpCnsKICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2tleV9kZWxldGUsIHB0aHJlYWRfa2V5X2RlbGV0ZSk7CgppbnQgX19wdGhyZWFkX3NldHNwZWNpZmljKHB0aHJlYWRfa2V5X3Qga2V5LCBjb25zdCB2b2lkICpwb2ludGVyKQp7CiAgICBwdGhyZWFkX2Rlc2NyIGRlc2NyID0gX19wdGhyZWFkX3RocmVhZF9zZWxmKCk7CiAgICBkZXNjci0+a2V5X2RhdGFba2V5XSA9IHBvaW50ZXI7CiAgICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3NldHNwZWNpZmljLCBwdGhyZWFkX3NldHNwZWNpZmljKTsKCnZvaWQgKl9fcHRocmVhZF9nZXRzcGVjaWZpYyhwdGhyZWFkX2tleV90IGtleSkKewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgcmV0dXJuICh2b2lkICopZGVzY3ItPmtleV9kYXRhW2tleV07Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9nZXRzcGVjaWZpYywgcHRocmVhZF9nZXRzcGVjaWZpYyk7CgpzdGF0aWMgaW50IHB0aHJlYWRfaW50ZXJuYWxfdHNkX3NldCggaW50IGtleSwgY29uc3Qgdm9pZCAqcG9pbnRlciApCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIGRlc2NyLT50c2RfZGF0YVtrZXldID0gcG9pbnRlcjsKICAgIHJldHVybiAwOwp9CmludCAoKl9fbGliY19pbnRlcm5hbF90c2Rfc2V0KShpbnQsIGNvbnN0IHZvaWQgKikgPSBwdGhyZWFkX2ludGVybmFsX3RzZF9zZXQ7CgpzdGF0aWMgdm9pZCAqcHRocmVhZF9pbnRlcm5hbF90c2RfZ2V0KCBpbnQga2V5ICkKewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgcmV0dXJuICh2b2lkICopZGVzY3ItPnRzZF9kYXRhW2tleV07Cn0Kdm9pZCogKCpfX2xpYmNfaW50ZXJuYWxfdHNkX2dldCkoaW50KSA9IHB0aHJlYWRfaW50ZXJuYWxfdHNkX2dldDsKCnN0YXRpYyB2b2lkICoqIF9fYXR0cmlidXRlX18oKGNvbnN0KSkgcHRocmVhZF9pbnRlcm5hbF90c2RfYWRkcmVzcyggaW50IGtleSApCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIHJldHVybiAodm9pZCAqKikmZGVzY3ItPnRzZF9kYXRhW2tleV07Cn0Kdm9pZCoqICgqX19saWJjX2ludGVybmFsX3RzZF9hZGRyZXNzKShpbnQpID0gcHRocmVhZF9pbnRlcm5hbF90c2RfYWRkcmVzczsKCi8qKioqKiAiRVhDRVBUSU9OIiBGUkFNRVMgKioqKiovCi8qIG5vdCBpbXBsZW1lbnRlZCByaWdodCBub3cgKi8KCnZvaWQgX3B0aHJlYWRfY2xlYW51cF9wdXNoKHN0cnVjdCBfcHRocmVhZF9jbGVhbnVwX2J1ZmZlciAqYnVmZmVyLCB2b2lkICgqcm91dGluZSkodm9pZCAqKSwgdm9pZCAqYXJnKQp7CiAgKCh3aW5lX2NsZWFudXApYnVmZmVyKS0+cm91dGluZSA9IHJvdXRpbmU7CiAgKCh3aW5lX2NsZWFudXApYnVmZmVyKS0+YXJnID0gYXJnOwp9Cgp2b2lkIF9wdGhyZWFkX2NsZWFudXBfcG9wKHN0cnVjdCBfcHRocmVhZF9jbGVhbnVwX2J1ZmZlciAqYnVmZmVyLCBpbnQgZXhlY3V0ZSkKewogIGlmIChleGVjdXRlKSAoKigoKHdpbmVfY2xlYW51cClidWZmZXIpLT5yb3V0aW5lKSkoKCh3aW5lX2NsZWFudXApYnVmZmVyKS0+YXJnKTsKfQoKdm9pZCBfcHRocmVhZF9jbGVhbnVwX3B1c2hfZGVmZXIoc3RydWN0IF9wdGhyZWFkX2NsZWFudXBfYnVmZmVyICpidWZmZXIsIHZvaWQgKCpyb3V0aW5lKSh2b2lkICopLCB2b2lkICphcmcpCnsKICBfcHRocmVhZF9jbGVhbnVwX3B1c2goYnVmZmVyLCByb3V0aW5lLCBhcmcpOwp9Cgp2b2lkIF9wdGhyZWFkX2NsZWFudXBfcG9wX3Jlc3RvcmUoc3RydWN0IF9wdGhyZWFkX2NsZWFudXBfYnVmZmVyICpidWZmZXIsIGludCBleGVjdXRlKQp7CiAgX3B0aHJlYWRfY2xlYW51cF9wb3AoYnVmZmVyLCBleGVjdXRlKTsKfQoKdm9pZCBfX3B0aHJlYWRfY2xlYW51cF91cHRvKGptcF9idWYgdGFyZ2V0LCBjaGFyICpmcmFtZSkKewogICAgLyogRklYTUUgKi8KfQoKLyoqKioqIENPTkRJVElPTlMgKioqKiovCgppbnQgX19wdGhyZWFkX2NvbmRfaW5pdChwdGhyZWFkX2NvbmRfdCAqY29uZCwgY29uc3QgcHRocmVhZF9jb25kYXR0cl90ICpjb25kX2F0dHIpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfY29uZF9pbml0KSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jb25kX2luaXQoY29uZCwgY29uZF9hdHRyKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2NvbmRfaW5pdCwgcHRocmVhZF9jb25kX2luaXQpOwoKaW50IF9fcHRocmVhZF9jb25kX2Rlc3Ryb3kocHRocmVhZF9jb25kX3QgKmNvbmQpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfY29uZF9kZXN0cm95KSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jb25kX2Rlc3Ryb3koY29uZCk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9jb25kX2Rlc3Ryb3ksIHB0aHJlYWRfY29uZF9kZXN0cm95KTsKCmludCBfX3B0aHJlYWRfY29uZF9zaWduYWwocHRocmVhZF9jb25kX3QgKmNvbmQpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfY29uZF9zaWduYWwpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfc2lnbmFsKGNvbmQpOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfY29uZF9zaWduYWwsIHB0aHJlYWRfY29uZF9zaWduYWwpOwoKaW50IF9fcHRocmVhZF9jb25kX2Jyb2FkY2FzdChwdGhyZWFkX2NvbmRfdCAqY29uZCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX2Jyb2FkY2FzdCkgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfY29uZF9icm9hZGNhc3QoY29uZCk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9jb25kX2Jyb2FkY2FzdCwgcHRocmVhZF9jb25kX2Jyb2FkY2FzdCk7CgppbnQgX19wdGhyZWFkX2NvbmRfd2FpdChwdGhyZWFkX2NvbmRfdCAqY29uZCwgcHRocmVhZF9tdXRleF90ICptdXRleCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX3dhaXQpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfd2FpdChjb25kLCBtdXRleCk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9jb25kX3dhaXQsIHB0aHJlYWRfY29uZF93YWl0KTsKCmludCBfX3B0aHJlYWRfY29uZF90aW1lZHdhaXQocHRocmVhZF9jb25kX3QgKmNvbmQsIHB0aHJlYWRfbXV0ZXhfdCAqbXV0ZXgsIGNvbnN0IHN0cnVjdCB0aW1lc3BlYyAqYWJzdGltZSkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX3RpbWVkd2FpdCkgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfY29uZF90aW1lZHdhaXQoY29uZCwgbXV0ZXgsIGFic3RpbWUpOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfY29uZF90aW1lZHdhaXQsIHB0aHJlYWRfY29uZF90aW1lZHdhaXQpOwoKLyoqKiogQ09ORElUSU9OIEFUVFJJQlVURVMgKioqKiovCi8qIG5vdCBpbXBsZW1lbnRlZCByaWdodCBub3cgKi8KCmludCBwdGhyZWFkX2NvbmRhdHRyX2luaXQocHRocmVhZF9jb25kYXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0KCmludCBwdGhyZWFkX2NvbmRhdHRyX2Rlc3Ryb3kocHRocmVhZF9jb25kYXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0KCi8qKioqKiBSRUFELVdSSVRFIExPQ0tTICoqKioqLwoKaW50IF9fcHRocmVhZF9yd2xvY2tfaW5pdChwdGhyZWFkX3J3bG9ja190ICpyd2xvY2ssIGNvbnN0IHB0aHJlYWRfcndsb2NrYXR0cl90ICpyd2xvY2tfYXR0cikKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfaW5pdCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja19pbml0KCByd2xvY2ssIHJ3bG9ja19hdHRyICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfaW5pdCwgcHRocmVhZF9yd2xvY2tfaW5pdCk7CgppbnQgX19wdGhyZWFkX3J3bG9ja19kZXN0cm95KHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfZGVzdHJveSApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja19kZXN0cm95KCByd2xvY2sgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja19kZXN0cm95LCBwdGhyZWFkX3J3bG9ja19kZXN0cm95KTsKCmludCBfX3B0aHJlYWRfcndsb2NrX3JkbG9jayhwdGhyZWFkX3J3bG9ja190ICpyd2xvY2spCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3JkbG9jaykgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3JkbG9jayggcndsb2NrICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfcmRsb2NrLCBwdGhyZWFkX3J3bG9ja19yZGxvY2spOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfdHJ5cmRsb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdHJ5cmRsb2NrICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3RyeXJkbG9jayggcndsb2NrICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfdHJ5cmRsb2NrLCBwdGhyZWFkX3J3bG9ja190cnlyZGxvY2spOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfd3Jsb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfd3Jsb2NrICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3dybG9jayggcndsb2NrICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfd3Jsb2NrLCBwdGhyZWFkX3J3bG9ja193cmxvY2spOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfdHJ5d3Jsb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdHJ5d3Jsb2NrICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3RyeXdybG9jayggcndsb2NrICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfdHJ5d3Jsb2NrLCBwdGhyZWFkX3J3bG9ja190cnl3cmxvY2spOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfdW5sb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdW5sb2NrKSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdW5sb2NrKCByd2xvY2sgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja191bmxvY2ssIHB0aHJlYWRfcndsb2NrX3VubG9jayk7CgovKioqKiBSRUFELVdSSVRFIExPQ0sgQVRUUklCVVRFUyAqKioqKi8KLyogbm90IGltcGxlbWVudGVkIHJpZ2h0IG5vdyAqLwoKaW50IHB0aHJlYWRfcndsb2NrYXR0cl9pbml0KHB0aHJlYWRfcndsb2NrYXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0KCmludCBfX3B0aHJlYWRfcndsb2NrYXR0cl9kZXN0cm95KHB0aHJlYWRfcndsb2NrYXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2thdHRyX2Rlc3Ryb3ksIHB0aHJlYWRfcndsb2NrYXR0cl9kZXN0cm95KTsKCmludCBwdGhyZWFkX3J3bG9ja2F0dHJfZ2V0a2luZF9ucChjb25zdCBwdGhyZWFkX3J3bG9ja2F0dHJfdCAqYXR0ciwgaW50ICpwcmVmKQp7CiAgKnByZWYgPSAwOwogIHJldHVybiAwOwp9CgppbnQgcHRocmVhZF9yd2xvY2thdHRyX3NldGtpbmRfbnAocHRocmVhZF9yd2xvY2thdHRyX3QgKmF0dHIsIGludCBwcmVmKQp7CiAgcmV0dXJuIDA7Cn0KCi8qKioqKiBNSVNDICoqKioqLwoKcHRocmVhZF90IHB0aHJlYWRfc2VsZih2b2lkKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX3NlbGYgKTsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9zZWxmKCk7Cn0KCmludCBwdGhyZWFkX2VxdWFsKHB0aHJlYWRfdCB0aHJlYWQxLCBwdGhyZWFkX3QgdGhyZWFkMikKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9lcXVhbCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2VxdWFsKCB0aHJlYWQxLCB0aHJlYWQyICk7Cn0KCnZvaWQgX19wdGhyZWFkX2RvX2V4aXQodm9pZCAqcmV0dmFsLCBjaGFyICpjdXJyZW50ZnJhbWUpCnsKICAgIGFzc2VydCggZnVuY3MucHRyX3B0aHJlYWRfZXhpdCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2V4aXQoIHJldHZhbCwgY3VycmVudGZyYW1lICk7Cn0KCnZvaWQgX19wdGhyZWFkX2V4aXQodm9pZCAqcmV0dmFsKQp7CiAgICBfX3B0aHJlYWRfZG9fZXhpdCggcmV0dmFsLCBOVUxMICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9leGl0LCBwdGhyZWFkX2V4aXQpOwoKaW50IHB0aHJlYWRfc2V0Y2FuY2Vsc3RhdGUoaW50IHN0YXRlLCBpbnQgKm9sZHN0YXRlKQp7CiAgICBwdGhyZWFkX2Rlc2NyIGRlc2NyID0gX19wdGhyZWFkX3RocmVhZF9zZWxmKCk7CiAgICBpZiAob2xkc3RhdGUpICpvbGRzdGF0ZSA9IGRlc2NyLT5jYW5jZWxfc3RhdGU7CiAgICBkZXNjci0+Y2FuY2VsX3N0YXRlID0gc3RhdGU7CiAgICByZXR1cm4gMDsKfQoKaW50IHB0aHJlYWRfc2V0Y2FuY2VsdHlwZShpbnQgdHlwZSwgaW50ICpvbGR0eXBlKQp7CiAgICBwdGhyZWFkX2Rlc2NyIGRlc2NyID0gX19wdGhyZWFkX3RocmVhZF9zZWxmKCk7CiAgICBpZiAob2xkdHlwZSkgKm9sZHR5cGUgPSBkZXNjci0+Y2FuY2VsX3R5cGU7CiAgICBkZXNjci0+Y2FuY2VsX3R5cGUgPSB0eXBlOwogICAgcmV0dXJuIDA7Cn0KCi8qKioqKiBBTlRJLU9WRVJSSURFUyAqKioqKi8KLyogcHRocmVhZHMgdHJpZXMgdG8gb3ZlcnJpZGUgdGhlc2UsIHBvaW50IHRoZW0gYmFjayB0byBsaWJjICovCgppbnQgc2lnYWN0aW9uKGludCBzaWdudW0sIGNvbnN0IHN0cnVjdCBzaWdhY3Rpb24gKmFjdCwgc3RydWN0IHNpZ2FjdGlvbiAqb2xkYWN0KQp7CiAgICBpZiAoIWxpYmNfc2lnYWN0aW9uKQogICAgewogICAgICAgIGxpYmNfc2lnYWN0aW9uID0gZGxzeW0oIFJUTERfTkVYVCwgInNpZ2FjdGlvbiIgKTsKICAgICAgICBhc3NlcnQoIGxpYmNfc2lnYWN0aW9uICk7CiAgICB9CiAgICByZXR1cm4gbGliY19zaWdhY3Rpb24oc2lnbnVtLCBhY3QsIG9sZGFjdCk7Cn0KCnZvaWQgX19wdGhyZWFkX2luaXRpYWxpemUodm9pZCkKewogICAgc3RhdGljIGludCBkb25lOwoKICAgIGlmICghZG9uZSkKICAgIHsKICAgICAgICBkb25lID0gMTsKICAgICAgICBsaWJjX2ZvcmsgPSBkbHN5bSggUlRMRF9ORVhULCAiZm9yayIgKTsKICAgICAgICBsaWJjX3NpZ2FjdGlvbiA9IGRsc3ltKCBSVExEX05FWFQsICJzaWdhY3Rpb24iICk7CiAgICAgICAgbGliY191c2Vsb2NhbGUgPSBkbHN5bSggUlRMRF9ORVhULCAidXNlbG9jYWxlIiApOwogICAgICAgIGxpYmNfcHRocmVhZF9pbml0ID0gZGxzeW0oIFJUTERfTkVYVCwgIl9fbGliY19wdGhyZWFkX2luaXQiICk7CiAgICAgICAgaWYgKGxpYmNfcHRocmVhZF9pbml0KSBsaWJjX211bHRpcGxlX3RocmVhZHMgPSBsaWJjX3B0aHJlYWRfaW5pdCggJmxpYmNfcHRocmVhZF9mdW5jdGlvbnMgKTsKICAgIH0KfQpERUNMX0dMT0JBTF9DT05TVFJVQ1RPUihpbml0KSB7IF9fcHRocmVhZF9pbml0aWFsaXplKCk7IH0KCnN0YXRpYyBzdHJ1Y3QgcHRocmVhZF9mdW5jdGlvbnMgbGliY19wdGhyZWFkX2Z1bmN0aW9ucyA9CnsKICAgIE5VTEwsICAgICAgICAgICAgICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9mb3JrICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9kZXN0cm95ICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9hdHRyX2luaXRfMl8wICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9hdHRyX2luaXRfMl8xICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9nZXRkZXRhY2hzdGF0ZSAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2F0dHJfc2V0ZGV0YWNoc3RhdGUgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX2dldGluaGVyaXRzY2hlZCAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2F0dHJfc2V0aW5oZXJpdHNjaGVkICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9nZXRzY2hlZHBhcmFtICovCiAgICBwdGhyZWFkX2F0dHJfc2V0c2NoZWRwYXJhbSwgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9zZXRzY2hlZHBhcmFtICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9nZXRzY2hlZHBvbGljeSAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2F0dHJfc2V0c2NoZWRwb2xpY3kgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX2dldHNjb3BlICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9zZXRzY29wZSAqLwogICAgcHRocmVhZF9jb25kYXR0cl9kZXN0cm95LCAgICAgIC8qIHB0cl9wdGhyZWFkX2NvbmRhdHRyX2Rlc3Ryb3kgKi8KICAgIHB0aHJlYWRfY29uZGF0dHJfaW5pdCwgICAgICAgICAvKiBwdHJfcHRocmVhZF9jb25kYXR0cl9pbml0ICovCiAgICBfX3B0aHJlYWRfY29uZF9icm9hZGNhc3QsICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX2Jyb2FkY2FzdCAqLwogICAgX19wdGhyZWFkX2NvbmRfZGVzdHJveSwgICAgICAgIC8qIHB0cl9fX3B0aHJlYWRfY29uZF9kZXN0cm95ICovCiAgICBfX3B0aHJlYWRfY29uZF9pbml0LCAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX2luaXQgKi8KICAgIF9fcHRocmVhZF9jb25kX3NpZ25hbCwgICAgICAgICAvKiBwdHJfX19wdGhyZWFkX2NvbmRfc2lnbmFsICovCiAgICBfX3B0aHJlYWRfY29uZF93YWl0LCAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX3dhaXQgKi8KICAgIHB0aHJlYWRfZXF1YWwsICAgICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9lcXVhbCAqLwogICAgX19wdGhyZWFkX2V4aXQsICAgICAgICAgICAgICAgIC8qIHB0cl9fX3B0aHJlYWRfZXhpdCAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2dldHNjaGVkcGFyYW0gKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9zZXRzY2hlZHBhcmFtICovCiAgICBfX3B0aHJlYWRfbXV0ZXhfZGVzdHJveSwgICAgICAgLyogcHRyX3B0aHJlYWRfbXV0ZXhfZGVzdHJveSAqLwogICAgX19wdGhyZWFkX211dGV4X2luaXQsICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX211dGV4X2luaXQgKi8KICAgIF9fcHRocmVhZF9tdXRleF9sb2NrLCAgICAgICAgICAvKiBwdHJfcHRocmVhZF9tdXRleF9sb2NrICovCiAgICBfX3B0aHJlYWRfbXV0ZXhfdHJ5bG9jaywgICAgICAgLyogcHRyX3B0aHJlYWRfbXV0ZXhfdHJ5bG9jayAqLwogICAgX19wdGhyZWFkX211dGV4X3VubG9jaywgICAgICAgIC8qIHB0cl9wdGhyZWFkX211dGV4X3VubG9jayAqLwogICAgcHRocmVhZF9zZWxmLCAgICAgICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX3NlbGYgKi8KICAgIHB0aHJlYWRfc2V0Y2FuY2Vsc3RhdGUsICAgICAgICAvKiBwdHJfcHRocmVhZF9zZXRjYW5jZWxzdGF0ZSAqLwogICAgcHRocmVhZF9zZXRjYW5jZWx0eXBlLCAgICAgICAgIC8qIHB0cl9wdGhyZWFkX3NldGNhbmNlbHR5cGUgKi8KICAgIF9fcHRocmVhZF9kb19leGl0LCAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9kb19leGl0ICovCiAgICBfX3B0aHJlYWRfY2xlYW51cF91cHRvLCAgICAgICAgLyogcHRyX3B0aHJlYWRfY2xlYW51cF91cHRvICovCiAgICBfX3B0aHJlYWRfdGhyZWFkX3NlbGYsICAgICAgICAgLyogcHRyX3B0aHJlYWRfdGhyZWFkX3NlbGYgKi8KICAgIHB0aHJlYWRfaW50ZXJuYWxfdHNkX3NldCwgICAgICAvKiBwdHJfcHRocmVhZF9pbnRlcm5hbF90c2Rfc2V0ICovCiAgICBwdGhyZWFkX2ludGVybmFsX3RzZF9nZXQsICAgICAgLyogcHRyX3B0aHJlYWRfaW50ZXJuYWxfdHNkX2dldCAqLwogICAgcHRocmVhZF9pbnRlcm5hbF90c2RfYWRkcmVzcywgIC8qIHB0cl9wdGhyZWFkX2ludGVybmFsX3RzZF9hZGRyZXNzICovCiAgICBOVUxMLCAgICAgICAgICAgICAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfc2lnYWN0aW9uICovCiAgICBOVUxMLCAgICAgICAgICAgICAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfc2lnd2FpdCAqLwogICAgTlVMTCwgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX3JhaXNlICovCiAgICBfX3B0aHJlYWRfY29uZF90aW1lZHdhaXQsICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX3RpbWVkd2FpdCAqLwogICAgX3B0aHJlYWRfY2xlYW51cF9wdXNoLCAgICAgICAgIC8qIHB0cl9fcHRocmVhZF9jbGVhbnVwX3B1c2ggKi8KICAgIF9wdGhyZWFkX2NsZWFudXBfcG9wICAgICAgICAgICAvKiBwdHJfX3B0aHJlYWRfY2xlYW51cF9wb3AgKi8KfTsKCiNlbmRpZiAvKiBfX0dMSUJDX18gfHwgX19GUkVFQlNEX18gKi8K