LyoKICogcHRocmVhZCBlbXVsYXRpb24gYmFzZWQgb24ga2VybmVsIHRocmVhZHMKICoKICogV2UgY2FuJ3QgdXNlIHB0aHJlYWRzIGRpcmVjdGx5LCBzbyB3aHkgbm90IGxldCBsaWJjcwogKiB0aGF0IHdhbnQgcHRocmVhZHMgdXNlIFdpbmUncyBvd24gdGhyZWFkaW5nIGluc3RlYWQuLi4KICoKICogQ29weXJpZ2h0IDE5OTkgT3ZlIEvldmVuCiAqIENvcHlyaWdodCAyMDAzIEFsZXhhbmRyZSBKdWxsaWFyZAogKgogKiBUaGlzIGxpYnJhcnkgaXMgZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yCiAqIG1vZGlmeSBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBMZXNzZXIgR2VuZXJhbCBQdWJsaWMKICogTGljZW5zZSBhcyBwdWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyCiAqIHZlcnNpb24gMi4xIG9mIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLgogKgogKiBUaGlzIGxpYnJhcnkgaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwKICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKICogTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFLiAgU2VlIHRoZSBHTlUKICogTGVzc2VyIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KICoKICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIExlc3NlciBHZW5lcmFsIFB1YmxpYwogKiBMaWNlbnNlIGFsb25nIHdpdGggdGhpcyBsaWJyYXJ5OyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDUxIEZyYW5rbGluIFN0LCBGaWZ0aCBGbG9vciwgQm9zdG9uLCBNQSAwMjExMC0xMzAxLCBVU0EKICovCgojaW5jbHVkZSAiY29uZmlnLmgiCiNpbmNsdWRlICJ3aW5lL3BvcnQuaCIKCnN0cnVjdCBfcHRocmVhZF9jbGVhbnVwX2J1ZmZlcjsKCiNpbmNsdWRlIDxhc3NlcnQuaD4KI2luY2x1ZGUgPGVycm5vLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KI2luY2x1ZGUgPHNpZ25hbC5oPgojaW5jbHVkZSA8c2V0am1wLmg+CiNpZmRlZiBIQVZFX1VOSVNURF9ICiMgaW5jbHVkZSA8dW5pc3RkLmg+CiNlbmRpZgojaW5jbHVkZSA8c3RyaW5nLmg+CiNpbmNsdWRlIDxzeXMvdHlwZXMuaD4KI2lmZGVmIEhBVkVfU1lTX1NPQ0tFVF9ICiMgaW5jbHVkZSA8c3lzL3NvY2tldC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfU1lTX01NQU5fSAojaW5jbHVkZSA8c3lzL21tYW4uaD4KI2VuZGlmCiNpZmRlZiBIQVZFX05FVElORVRfSU5fSAojIGluY2x1ZGUgPG5ldGluZXQvaW4uaD4KI2VuZGlmCiNpZmRlZiBIQVZFX0FSUEFfTkFNRVNFUl9ICiMgaW5jbHVkZSA8YXJwYS9uYW1lc2VyLmg+CiNlbmRpZgojaWZkZWYgSEFWRV9SRVNPTFZfSAojIGluY2x1ZGUgPHJlc29sdi5oPgojZW5kaWYKI2lmZGVmIEhBVkVfVkFMR1JJTkRfTUVNQ0hFQ0tfSAojaW5jbHVkZSA8dmFsZ3JpbmQvbWVtY2hlY2suaD4KI2VuZGlmCiNpZmRlZiBIQVZFX1NZU19TWVNDQUxMX0gKIyBpbmNsdWRlIDxzeXMvc3lzY2FsbC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfU1lTX0xXUF9ICiMgaW5jbHVkZSA8c3lzL2x3cC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfVUNPTlRFWFRfSAojIGluY2x1ZGUgPHVjb250ZXh0Lmg+CiNlbmRpZgojaWZkZWYgSEFWRV9TQ0hFRF9ICiNpbmNsdWRlIDxzY2hlZC5oPgojZW5kaWYKCiNpbmNsdWRlICJ3aW5lL2xpYnJhcnkuaCIKI2luY2x1ZGUgIndpbmUvcHRocmVhZC5oIgoKI2RlZmluZSBQX09VVFBVVChzdHVmZikgd3JpdGUoMixzdHVmZixzdHJsZW4oc3R1ZmYpKQoKI2RlZmluZSBQU1RSKHN0cikgX19BU01fTkFNRSgjc3RyKQoKc3RhdGljIHN0cnVjdCB3aW5lX3B0aHJlYWRfY2FsbGJhY2tzIGZ1bmNzOwoKLyogdGhyZWFkIGRlc2NyaXB0b3IgKi8KCiNkZWZpbmUgRklSU1RfS0VZIDAKI2RlZmluZSBNQVhfS0VZUyAxNiAvKiBsaWJjNiBkb2Vzbid0IHVzZSB0aGF0IG1hbnksIGJ1dC4uLiAqLwojZGVmaW5lIE1BWF9UU0QgIDE2CgpzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QKewogICAgY2hhciAgICAgICAgICAgICAgIGR1bW15WzIwNDhdOwogICAgaW50ICAgICAgICAgICAgICAgIHRocmVhZF9lcnJubzsKICAgIGludCAgICAgICAgICAgICAgICB0aHJlYWRfaF9lcnJubzsKICAgIGludCAgICAgICAgICAgICAgICBjYW5jZWxfc3RhdGU7CiAgICBpbnQgICAgICAgICAgICAgICAgY2FuY2VsX3R5cGU7CiAgICBzdHJ1Y3QgX19yZXNfc3RhdGUgcmVzX3N0YXRlOwogICAgY29uc3Qgdm9pZCAgICAgICAgKmtleV9kYXRhW01BWF9LRVlTXTsgIC8qIGZvciBub3JtYWwgcHRocmVhZCBrZXlzICovCiAgICBjb25zdCB2b2lkICAgICAgICAqdHNkX2RhdGFbTUFYX1RTRF07ICAgLyogZm9yIGxpYmMgaW50ZXJuYWwgdHNkIHZhcmlhYmxlcyAqLwp9OwoKdHlwZWRlZiBzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QgKnB0aHJlYWRfZGVzY3I7CgpzdGF0aWMgc3RydWN0IHB0aHJlYWRfZGVzY3Jfc3RydWN0IGluaXRpYWxfZGVzY3I7CgpwdGhyZWFkX2Rlc2NyIF9fcHRocmVhZF90aHJlYWRfc2VsZih2b2lkKQp7CiAgICBzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QgKmRlc2NyOwogICAgaWYgKCFmdW5jcy5wdHJfZ2V0X3RocmVhZF9kYXRhKSByZXR1cm4gJmluaXRpYWxfZGVzY3I7CiAgICBkZXNjciA9IGZ1bmNzLnB0cl9nZXRfdGhyZWFkX2RhdGEoKTsKICAgIGlmICghZGVzY3IpIHJldHVybiAmaW5pdGlhbF9kZXNjcjsKICAgIHJldHVybiBkZXNjcjsKfQoKc3RhdGljIGludCAoKmxpYmNfdXNlbG9jYWxlKShpbnQgc2V0KTsKc3RhdGljIGludCAqbGliY19tdWx0aXBsZV90aHJlYWRzOwoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBfX2Vycm5vX2xvY2F0aW9uL19fZXJyb3IvX19lcnJuby9fX19lcnJuby9fX3Rocl9lcnJubwogKgogKiBHZXQgdGhlIHBlci10aHJlYWQgZXJybm8gbG9jYXRpb24uCiAqLwppbnQgKl9fZXJybm9fbG9jYXRpb24odm9pZCkgICAgICAgICAgICAgICAgICAgICAgICAgICAgLyogTGludXggKi8KewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgcmV0dXJuICZkZXNjci0+dGhyZWFkX2Vycm5vOwp9CmludCAqX19lcnJvcih2b2lkKSAgICAgeyByZXR1cm4gX19lcnJub19sb2NhdGlvbigpOyB9ICAvKiBGcmVlQlNEICovCmludCAqX19lcnJubyh2b2lkKSAgICAgeyByZXR1cm4gX19lcnJub19sb2NhdGlvbigpOyB9ICAvKiBOZXRCU0QgKi8KaW50ICpfX19lcnJubyh2b2lkKSAgICB7IHJldHVybiBfX2Vycm5vX2xvY2F0aW9uKCk7IH0gIC8qIFNvbGFyaXMgKi8KaW50ICpfX3Rocl9lcnJubyh2b2lkKSB7IHJldHVybiBfX2Vycm5vX2xvY2F0aW9uKCk7IH0gIC8qIFVuaXhXYXJlICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIF9faF9lcnJub19sb2NhdGlvbgogKgogKiBHZXQgdGhlIHBlci10aHJlYWQgaF9lcnJubyBsb2NhdGlvbi4KICovCmludCAqX19oX2Vycm5vX2xvY2F0aW9uKHZvaWQpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIHJldHVybiAmZGVzY3ItPnRocmVhZF9oX2Vycm5vOwp9CgpzdHJ1Y3QgX19yZXNfc3RhdGUgKl9fcmVzX3N0YXRlKHZvaWQpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIHJldHVybiAmZGVzY3ItPnJlc19zdGF0ZTsKfQoKc3RhdGljIGlubGluZSB2b2lkIHdyaXRlanVtcCggY29uc3QgY2hhciAqc3ltYm9sLCB2b2lkICpkZXN0ICkKewojaWYgZGVmaW5lZChfX0dMSUJDX18pICYmIGRlZmluZWQoX19pMzg2X18pCiAgICB1bnNpZ25lZCBjaGFyICphZGRyID0gd2luZV9kbHN5bSggUlRMRF9ORVhULCBzeW1ib2wsIE5VTEwsIDAgKTsKCiAgICBpZiAoIWFkZHIpIHJldHVybjsKCiAgICAvKiB3cml0ZSBhIHJlbGF0aXZlIGp1bXAgYXQgdGhlIGZ1bmN0aW9uIGFkZHJlc3MgKi8KICAgIG1wcm90ZWN0KCh2b2lkKikoKHVuc2lnbmVkIGludClhZGRyICYgfihnZXRwYWdlc2l6ZSgpLTEpKSwgNSwgUFJPVF9SRUFEfFBST1RfRVhFQ3xQUk9UX1dSSVRFKTsKICAgIGFkZHJbMF0gPSAweGU5OwogICAgKihpbnQgKikoYWRkcisxKSA9ICh1bnNpZ25lZCBjaGFyICopZGVzdCAtIChhZGRyICsgNSk7CiAgICBtcHJvdGVjdCgodm9pZCopKCh1bnNpZ25lZCBpbnQpYWRkciAmIH4oZ2V0cGFnZXNpemUoKS0xKSksIDUsIFBST1RfUkVBRHxQUk9UX0VYRUMpOwoKIyBpZmRlZiBIQVZFX1ZBTEdSSU5EX01FTUNIRUNLX0gKICAgIFZBTEdSSU5EX0RJU0NBUkRfVFJBTlNMQVRJT05TKCBhZGRyLCA1ICk7CiMgZW5kaWYKI2VuZGlmICAvKiBfX0dMSUJDX18gJiYgX19pMzg2X18gKi8KfQoKLyogdGVtcG9yYXJ5IHN0YWNrcyB1c2VkIG9uIHRocmVhZCBleGl0ICovCiNkZWZpbmUgVEVNUF9TVEFDS19TSVpFIDEwMjQKI2RlZmluZSBOQl9URU1QX1NUQUNLUyAgOApzdGF0aWMgY2hhciB0ZW1wX3N0YWNrc1tOQl9URU1QX1NUQUNLU11bVEVNUF9TVEFDS19TSVpFXTsKc3RhdGljIGludCBuZXh0X3RlbXBfc3RhY2s7ICAvKiBuZXh0IHRlbXAgc3RhY2sgdG8gdXNlICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGdldF90ZW1wX3N0YWNrCiAqCiAqIEdldCBhIHRlbXBvcmFyeSBzdGFjayBhZGRyZXNzIHRvIHJ1biB0aGUgdGhyZWFkIGV4aXQgY29kZSBvbi4KICovCmlubGluZSBzdGF0aWMgY2hhciAqZ2V0X3RlbXBfc3RhY2sodm9pZCkKewogICAgdW5zaWduZWQgaW50IG5leHQgPSBpbnRlcmxvY2tlZF94Y2hnX2FkZCggJm5leHRfdGVtcF9zdGFjaywgMSApOwogICAgcmV0dXJuIHRlbXBfc3RhY2tzW25leHQgJSBOQl9URU1QX1NUQUNLU10gKyBURU1QX1NUQUNLX1NJWkU7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGNsZWFudXBfdGhyZWFkCiAqCiAqIENsZWFudXAgdGhlIHJlbWFpbnMgb2YgYSB0aHJlYWQuIFJ1bnMgb24gYSB0ZW1wb3Jhcnkgc3RhY2suCiAqLwpzdGF0aWMgdm9pZCBjbGVhbnVwX3RocmVhZCggdm9pZCAqcHRyICkKewogICAgLyogY29weSB0aGUgaW5mbyBzdHJ1Y3R1cmUgc2luY2UgaXQgaXMgb24gdGhlIHN0YWNrIHdlIHdpbGwgZnJlZSAqLwogICAgc3RydWN0IHdpbmVfcHRocmVhZF90aHJlYWRfaW5mbyBpbmZvID0gKihzdHJ1Y3Qgd2luZV9wdGhyZWFkX3RocmVhZF9pbmZvICopcHRyOwogICAgd2luZV9sZHRfZnJlZV9mcyggaW5mby50ZWJfc2VsICk7CiAgICBtdW5tYXAoIGluZm8uc3RhY2tfYmFzZSwgaW5mby5zdGFja19zaXplICk7CiAgICBtdW5tYXAoIGluZm8udGViX2Jhc2UsIGluZm8udGViX3NpemUgKTsKI2lmZGVmIEhBVkVfX0xXUF9DUkVBVEUKICAgIF9sd3BfZXhpdCgpOwojZW5kaWYKICAgIF9leGl0KCBpbmZvLmV4aXRfc3RhdHVzICk7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGluaXRfcHJvY2VzcwogKgogKiBJbml0aWFsaXphdGlvbiBmb3IgYSBuZXdseSBjcmVhdGVkIHByb2Nlc3MuCiAqLwpzdGF0aWMgdm9pZCBpbml0X3Byb2Nlc3MoIGNvbnN0IHN0cnVjdCB3aW5lX3B0aHJlYWRfY2FsbGJhY2tzICpjYWxsYmFja3MsIHNpemVfdCBzaXplICkKewogICAgbWVtY3B5KCAmZnVuY3MsIGNhbGxiYWNrcywgbWluKCBzaXplLCBzaXplb2YoZnVuY3MpICkpOwogICAgZnVuY3MucHRyX3NldF90aHJlYWRfZGF0YSggJmluaXRpYWxfZGVzY3IgKTsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgaW5pdF90aHJlYWQKICoKICogSW5pdGlhbGl6YXRpb24gZm9yIGEgbmV3bHkgY3JlYXRlZCB0aHJlYWQuCiAqLwpzdGF0aWMgdm9pZCBpbml0X3RocmVhZCggc3RydWN0IHdpbmVfcHRocmVhZF90aHJlYWRfaW5mbyAqaW5mbyApCnsKICAgIHN0cnVjdCBwdGhyZWFkX2Rlc2NyX3N0cnVjdCAqZGVzY3I7CgogICAgaWYgKGZ1bmNzLnB0cl9zZXRfdGhyZWFkX2RhdGEpCiAgICB7CiAgICAgICAgZGVzY3IgPSBjYWxsb2MoIDEsIHNpemVvZigqZGVzY3IpICk7CiAgICAgICAgZnVuY3MucHRyX3NldF90aHJlYWRfZGF0YSggZGVzY3IgKTsKICAgICAgICBpZiAobGliY19tdWx0aXBsZV90aHJlYWRzKSAqbGliY19tdWx0aXBsZV90aHJlYWRzID0gMTsKICAgIH0KICAgIGVsc2UgIC8qIGZpcnN0IHRocmVhZCAqLwogICAgewogICAgICAgIGRlc2NyID0gJmluaXRpYWxfZGVzY3I7CiAgICAgICAgd3JpdGVqdW1wKCAiX19lcnJub19sb2NhdGlvbiIsIF9fZXJybm9fbG9jYXRpb24gKTsKICAgICAgICB3cml0ZWp1bXAoICJfX2hfZXJybm9fbG9jYXRpb24iLCBfX2hfZXJybm9fbG9jYXRpb24gKTsKICAgICAgICB3cml0ZWp1bXAoICJfX3Jlc19zdGF0ZSIsIF9fcmVzX3N0YXRlICk7CiAgICB9CiAgICBkZXNjci0+Y2FuY2VsX3N0YXRlID0gUFRIUkVBRF9DQU5DRUxfRU5BQkxFOwogICAgZGVzY3ItPmNhbmNlbF90eXBlICA9IFBUSFJFQURfQ0FOQ0VMX0FTWU5DSFJPTk9VUzsKICAgIGlmIChsaWJjX3VzZWxvY2FsZSkgbGliY191c2Vsb2NhbGUoIC0xIC8qTENfR0xPQkFMX0xPQ0FMRSovICk7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGNyZWF0ZV90aHJlYWQKICovCnN0YXRpYyBpbnQgY3JlYXRlX3RocmVhZCggc3RydWN0IHdpbmVfcHRocmVhZF90aHJlYWRfaW5mbyAqaW5mbyApCnsKICAgIGlmICghaW5mby0+c3RhY2tfYmFzZSkKICAgIHsKICAgICAgICBpbmZvLT5zdGFja19iYXNlID0gd2luZV9hbm9uX21tYXAoIE5VTEwsIGluZm8tPnN0YWNrX3NpemUsCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBQUk9UX1JFQUQgfCBQUk9UX1dSSVRFIHwgUFJPVF9FWEVDLCAwICk7CiAgICAgICAgaWYgKGluZm8tPnN0YWNrX2Jhc2UgPT0gKHZvaWQgKiktMSkgcmV0dXJuIC0xOwogICAgfQojaWZkZWYgSEFWRV9DTE9ORQogICAgaWYgKGNsb25lKCAoaW50ICgqKSh2b2lkICopKWluZm8tPmVudHJ5LCAoY2hhciAqKWluZm8tPnN0YWNrX2Jhc2UgKyBpbmZvLT5zdGFja19zaXplLAogICAgICAgICAgICAgICBDTE9ORV9WTSB8IENMT05FX0ZTIHwgQ0xPTkVfRklMRVMgfCBTSUdDSExELCBpbmZvICkgPCAwKQogICAgICAgIHJldHVybiAtMTsKICAgIHJldHVybiAwOwojZWxpZiBkZWZpbmVkKEhBVkVfUkZPUkspCiAgICB7CiAgICAgICAgdm9pZCAqKnNwID0gKHZvaWQgKiopKChjaGFyICopaW5mby0+c3RhY2tfYmFzZSArIGluZm8tPnN0YWNrX3NpemUpOwogICAgICAgICotLXNwID0gaW5mbzsKICAgICAgICAqLS1zcCA9IDA7CiAgICAgICAgKi0tc3AgPSBpbmZvLT5lbnRyeTsKICAgICAgICBfX2FzbV9fIF9fdm9sYXRpbGVfXygKICAgICAgICAgICAgInB1c2hsICUyO1xuXHQiICAgICAgICAgICAgIC8qIGZsYWdzICovCiAgICAgICAgICAgICJwdXNobCAkMDtcblx0IiAgICAgICAgICAgICAvKiAwID8gKi8KICAgICAgICAgICAgIm1vdmwgJTEsJSVlYXg7XG5cdCIgICAgICAgIC8qIFNZU19yZm9yayAqLwogICAgICAgICAgICAiLmJ5dGUgMHg5YTsgLmxvbmcgMDsgLndvcmQgNztcblx0IiAvKiBsY2FsbCA3OjAuLi4gRnJlZUJTRCBzeXNjYWxsICovCiAgICAgICAgICAgICJjbXBsICQwLCAlJWVkeDtcblx0IgogICAgICAgICAgICAiamUgMWY7XG5cdCIKICAgICAgICAgICAgIm1vdmwgJTAsJSVlc3A7XG5cdCIgICAgICAgIC8qIGNoaWxkIC0+IG5ldyB0aHJlYWQgKi8KICAgICAgICAgICAgInJldDtcbiIKICAgICAgICAgICAgIjE6XG5cdCIgICAgICAgICAgICAgICAgICAgIC8qIHBhcmVudCAtPiBjYWxsZXIgdGhyZWFkICovCiAgICAgICAgICAgICJhZGRsICQ4LCUlZXNwIiA6CiAgICAgICAgICAgIDogInIiIChzcCksICJyIiAoU1lTX3Jmb3JrKSwgInIiIChSRlBST0MgfCBSRk1FTSB8IFJGVEhSRUFEKQogICAgICAgICAgICA6ICJlYXgiLCAiZWR4Iik7CiAgICAgICAgcmV0dXJuIDA7CiAgICB9CiNlbGlmIGRlZmluZWQoSEFWRV9fTFdQX0NSRUFURSkKICAgIHsKICAgICAgICB1Y29udGV4dF90IGNvbnRleHQ7CiAgICAgICAgX2x3cF9tYWtlY29udGV4dCggJmNvbnRleHQsICh2b2lkKCopKHZvaWQgKikpaW5mby0+ZW50cnksIGluZm8sCiAgICAgICAgICAgICAgICAgICAgICAgICAgTlVMTCwgaW5mby0+c3RhY2tfYmFzZSwgaW5mby0+c3RhY2tfc2l6ZSApOwogICAgICAgIGlmICggX2x3cF9jcmVhdGUoICZjb250ZXh0LCAwLCBOVUxMICkgKQogICAgICAgICAgICByZXR1cm4gLTE7CiAgICAgICAgcmV0dXJuIDA7CiAgICB9CiNlbmRpZgogICAgcmV0dXJuIC0xOwp9CgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBpbml0X2N1cnJlbnRfdGViCiAqCiAqIFNldCB0aGUgY3VycmVudCBURUIgZm9yIGEgbmV3IHRocmVhZC4KICovCnN0YXRpYyB2b2lkIGluaXRfY3VycmVudF90ZWIoIHN0cnVjdCB3aW5lX3B0aHJlYWRfdGhyZWFkX2luZm8gKmluZm8gKQp7CiNpZmRlZiBfX2kzODZfXwogICAgLyogT24gdGhlIGkzODYsIHRoZSBjdXJyZW50IHRocmVhZCBpcyBpbiB0aGUgJWZzIHJlZ2lzdGVyICovCiAgICBMRFRfRU5UUlkgZnNfZW50cnk7CgogICAgd2luZV9sZHRfc2V0X2Jhc2UoICZmc19lbnRyeSwgaW5mby0+dGViX2Jhc2UgKTsKICAgIHdpbmVfbGR0X3NldF9saW1pdCggJmZzX2VudHJ5LCBpbmZvLT50ZWJfc2l6ZSAtIDEgKTsKICAgIHdpbmVfbGR0X3NldF9mbGFncyggJmZzX2VudHJ5LCBXSU5FX0xEVF9GTEFHU19EQVRBfFdJTkVfTERUX0ZMQUdTXzMyQklUICk7CiAgICB3aW5lX2xkdF9pbml0X2ZzKCBpbmZvLT50ZWJfc2VsLCAmZnNfZW50cnkgKTsKI2VsaWYgZGVmaW5lZChIQVZFX19MV1BfQ1JFQVRFKQogICAgLyogT24gbm9uLWkzODYgU29sYXJpcywgd2UgdXNlIHRoZSBMV1AgcHJpdmF0ZSBwb2ludGVyICovCiAgICBfbHdwX3NldHByaXZhdGUoIGluZm8tPnRlYl9iYXNlICk7CiNlbGlmIGRlZmluZWQoX19wb3dlcnBjX18pCiAgICAvKiBPbiBQb3dlclBDLCB0aGUgY3VycmVudCBURUIgaXMgaW4gdGhlIGdwcjEzIHJlZ2lzdGVyICovCiMgaWZkZWYgX19BUFBMRV9fCiAgICBfX2FzbV9fIF9fdm9sYXRpbGVfXygibXIgcjEzLCAlMCIgOiA6ICJyIiAoaW5mby0+dGViX2Jhc2UpKTsKIyBlbHNlCiAgICBfX2FzbV9fIF9fdm9sYXRpbGVfXygibXIgMiwgJTAiIDogOiAiciIgKGluZm8tPnRlYl9iYXNlKSk7CiMgZW5kaWYKI2VsaWYgZGVmaW5lZChfX0FMUEhBX18pCiAgICAvKiBGSVhNRTogT24gQWxwaGEsIHRoZSBjdXJyZW50IFRFQiBpcyBub3QgYWNjZXNzaWJsZSB0byB1c2VyLXNwYWNlICovCi8qICAgIF9fYXNtX18gX192b2xhdGlsZV9fKCk7Ki8KI2Vsc2UKIyBlcnJvciBZb3UgbXVzdCBpbXBsZW1lbnQgaW5pdF9jdXJyZW50X3RlYiBmb3IgeW91ciBwbGF0Zm9ybQojZW5kaWYKCiAgICAvKiBzZXQgcGlkIGFuZCB0aWQgKi8KICAgIGluZm8tPnBpZCA9IGdldHBpZCgpOwojaWZkZWYgSEFWRV9fTFdQX1NFTEYKICAgIGluZm8tPnRpZCA9IF9sd3Bfc2VsZigpOwojZWxzZQogICAgaW5mby0+dGlkID0gLTE7CiNlbmRpZgp9CgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBnZXRfY3VycmVudF90ZWIKICovCnN0YXRpYyB2b2lkICpnZXRfY3VycmVudF90ZWIodm9pZCkKewogICAgdm9pZCAqcmV0OwoKI2lmZGVmIF9faTM4Nl9fCiAgICBfX2FzbV9fKCAiLmJ5dGUgMHg2NFxuXHRtb3ZsIDB4MTgsJTAiIDogIj1yIiAocmV0KSApOwojZWxpZiBkZWZpbmVkKEhBVkVfX0xXUF9DUkVBVEUpCiAgICByZXQgPSBfbHdwX2dldHByaXZhdGUoKTsKI2VsaWYgZGVmaW5lZChfX3Bvd2VycGNfXykKIyBpZmRlZiBfX0FQUExFX18KICAgIF9fYXNtX18oICJtciAlMCxyMTMiIDogIj1yIiAocmV0KSApOwojIGVsc2UKICAgIF9fYXNtX18oICJtciAlMCwyIiA6ICI9ciIgKHJldCkgKTsKIyBlbmRpZgojZWxpZiBkZWZpbmVkKF9fQUxQSEFfXykKICAgIC8qIDB4MDBhYiBpcyB0aGUgUEFMIG9wY29kZSBmb3IgcmR0ZWIgKi8KICAgIF9fYXNtX18oICJsZGEgJDMwLDgoJDMwKVxuXHQiCiAgICAgICAgICAgICAic3RxICQwLDAoJDMwKVxuXHQiCiAgICAgICAgICAgICAiY2FsbF9wYWwgMHgwMGFiXG5cdCIKICAgICAgICAgICAgICJtb3YgJDAsJTBcblx0IgogICAgICAgICAgICAgImxkcSAkMCwwKCQzMClcblx0IgogICAgICAgICAgICAgImxkYSAkMzAsLTgoJDMwKSIgOiAiPXIiIChyZXQpICk7CiNlbHNlCiMgZXJyb3IgZ2V0X2N1cnJlbnRfdGViIG5vdCBkZWZpbmVkIGZvciB0aGlzIGFyY2hpdGVjdHVyZQojZW5kaWYgIC8qIF9faTM4Nl9fICovCgogICAgcmV0dXJuIHJldDsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgZXhpdF90aHJlYWQKICovCnN0YXRpYyB2b2lkIERFQ0xTUEVDX05PUkVUVVJOIGV4aXRfdGhyZWFkKCBzdHJ1Y3Qgd2luZV9wdGhyZWFkX3RocmVhZF9pbmZvICppbmZvICkKewogICAgd2luZV9zd2l0Y2hfdG9fc3RhY2soIGNsZWFudXBfdGhyZWFkLCBpbmZvLCBnZXRfdGVtcF9zdGFjaygpICk7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGFib3J0X3RocmVhZAogKi8Kc3RhdGljIHZvaWQgREVDTFNQRUNfTk9SRVRVUk4gYWJvcnRfdGhyZWFkKCBsb25nIHN0YXR1cyApCnsKI2lmZGVmIEhBVkVfX0xXUF9DUkVBVEUKICAgIF9sd3BfZXhpdCgpOwojZW5kaWYKICAgIF9leGl0KCBzdGF0dXMgKTsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgcHRocmVhZF9mdW5jdGlvbnMKICovCmNvbnN0IHN0cnVjdCB3aW5lX3B0aHJlYWRfZnVuY3Rpb25zIHB0aHJlYWRfZnVuY3Rpb25zID0KewogICAgaW5pdF9wcm9jZXNzLAogICAgaW5pdF90aHJlYWQsCiAgICBjcmVhdGVfdGhyZWFkLAogICAgaW5pdF9jdXJyZW50X3RlYiwKICAgIGdldF9jdXJyZW50X3RlYiwKICAgIGV4aXRfdGhyZWFkLAogICAgYWJvcnRfdGhyZWFkLAogICAgc2lncHJvY21hc2sKfTsKCgovKiBDdXJyZW50bHkgdGhpcyBwcm9iYWJseSB3b3JrcyBvbmx5IGZvciBnbGliYzIsCiAqIHdoaWNoIGNoZWNrcyBmb3IgdGhlIHByZXNlbmNlIG9mIGRvdWJsZS11bmRlcnNjb3JlLXByZXBlbmRlZAogKiBwdGhyZWFkIHByaW1pdGl2ZXMsIGFuZCB1c2UgdGhlbSBpZiBhdmFpbGFibGUuCiAqIElmIHRoZXkgYXJlIG5vdCBhdmFpbGFibGUsIHRoZSBsaWJjIGRlZmF1bHRzIHRvCiAqIG5vbi10aHJlYWRzYWZlIG9wZXJhdGlvbiAobm90IGdvb2QpLiAqLwoKI2lmIGRlZmluZWQoSEFWRV9QVEhSRUFEX0gpICYmIChkZWZpbmVkKF9fR0xJQkNfXykgfHwgZGVmaW5lZChfX0ZyZWVCU0RfXykpCgovKiBhZGFwdCBhcyBuZWNlc3NhcnkgKGEgY29uc3RydWN0IGxpa2UgdGhpcyBpcyB1c2VkIGluIGdsaWJjIHNvdXJjZXMpICovCiNkZWZpbmUgc3Ryb25nX2FsaWFzKG9yaWcsIGFsaWFzKSBcCiBhc20oIi5nbG9ibCAiIFBTVFIoYWxpYXMpICJcbiIgXAogICAgICJcdC5zZXQgIiBQU1RSKGFsaWFzKSAiLCIgUFNUUihvcmlnKSkKCnN0cnVjdCBmb3JrX2Jsb2NrOwoKLyogcHRocmVhZCBmdW5jdGlvbnMgcmVkaXJlY3Rpb24gKi8KCnN0cnVjdCBwdGhyZWFkX2Z1bmN0aW9ucwp7CiAgcGlkX3QgKCpwdHJfcHRocmVhZF9mb3JrKSAoc3RydWN0IGZvcmtfYmxvY2sgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9kZXN0cm95KSAocHRocmVhZF9hdHRyX3QgKik7CiAgaW50ICgqcHRyX19fcHRocmVhZF9hdHRyX2luaXRfMl8wKSAocHRocmVhZF9hdHRyX3QgKik7CiAgaW50ICgqcHRyX19fcHRocmVhZF9hdHRyX2luaXRfMl8xKSAocHRocmVhZF9hdHRyX3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9nZXRkZXRhY2hzdGF0ZSkgKGNvbnN0IHB0aHJlYWRfYXR0cl90ICosIGludCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX3NldGRldGFjaHN0YXRlKSAocHRocmVhZF9hdHRyX3QgKiwgaW50KTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX2dldGluaGVyaXRzY2hlZCkgKGNvbnN0IHB0aHJlYWRfYXR0cl90ICosIGludCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX3NldGluaGVyaXRzY2hlZCkgKHB0aHJlYWRfYXR0cl90ICosIGludCk7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9nZXRzY2hlZHBhcmFtKSAoY29uc3QgcHRocmVhZF9hdHRyX3QgKiwgc3RydWN0IHNjaGVkX3BhcmFtICopOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfc2V0c2NoZWRwYXJhbSkgKHB0aHJlYWRfYXR0cl90ICosIGNvbnN0IHN0cnVjdCBzY2hlZF9wYXJhbSAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX2dldHNjaGVkcG9saWN5KSAoY29uc3QgcHRocmVhZF9hdHRyX3QgKiwgaW50ICopOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfc2V0c2NoZWRwb2xpY3kpIChwdGhyZWFkX2F0dHJfdCAqLCBpbnQpOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfZ2V0c2NvcGUpIChjb25zdCBwdGhyZWFkX2F0dHJfdCAqLCBpbnQgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9zZXRzY29wZSkgKHB0aHJlYWRfYXR0cl90ICosIGludCk7CiAgaW50ICgqcHRyX3B0aHJlYWRfY29uZGF0dHJfZGVzdHJveSkgKHB0aHJlYWRfY29uZGF0dHJfdCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9jb25kYXR0cl9pbml0KSAocHRocmVhZF9jb25kYXR0cl90ICopOwogIGludCAoKnB0cl9fX3B0aHJlYWRfY29uZF9icm9hZGNhc3QpIChwdGhyZWFkX2NvbmRfdCAqKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfZGVzdHJveSkgKHB0aHJlYWRfY29uZF90ICopOwogIGludCAoKnB0cl9fX3B0aHJlYWRfY29uZF9pbml0KSAocHRocmVhZF9jb25kX3QgKiwgY29uc3QgcHRocmVhZF9jb25kYXR0cl90ICopOwogIGludCAoKnB0cl9fX3B0aHJlYWRfY29uZF9zaWduYWwpIChwdGhyZWFkX2NvbmRfdCAqKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfd2FpdCkgKHB0aHJlYWRfY29uZF90ICosIHB0aHJlYWRfbXV0ZXhfdCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9lcXVhbCkgKHB0aHJlYWRfdCwgcHRocmVhZF90KTsKICB2b2lkICgqcHRyX19fcHRocmVhZF9leGl0KSAodm9pZCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9nZXRzY2hlZHBhcmFtKSAocHRocmVhZF90LCBpbnQgKiwgc3RydWN0IHNjaGVkX3BhcmFtICopOwogIGludCAoKnB0cl9wdGhyZWFkX3NldHNjaGVkcGFyYW0pIChwdGhyZWFkX3QsIGludCwgY29uc3Qgc3RydWN0IHNjaGVkX3BhcmFtICopOwogIGludCAoKnB0cl9wdGhyZWFkX211dGV4X2Rlc3Ryb3kpIChwdGhyZWFkX211dGV4X3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfbXV0ZXhfaW5pdCkgKHB0aHJlYWRfbXV0ZXhfdCAqLCBjb25zdCBwdGhyZWFkX211dGV4YXR0cl90ICopOwogIGludCAoKnB0cl9wdGhyZWFkX211dGV4X2xvY2spIChwdGhyZWFkX211dGV4X3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfbXV0ZXhfdHJ5bG9jaykgKHB0aHJlYWRfbXV0ZXhfdCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9tdXRleF91bmxvY2spIChwdGhyZWFkX211dGV4X3QgKik7CiAgcHRocmVhZF90ICgqcHRyX3B0aHJlYWRfc2VsZikgKHZvaWQpOwogIGludCAoKnB0cl9wdGhyZWFkX3NldGNhbmNlbHN0YXRlKSAoaW50LCBpbnQgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfc2V0Y2FuY2VsdHlwZSkgKGludCwgaW50ICopOwogIHZvaWQgKCpwdHJfcHRocmVhZF9kb19leGl0KSAodm9pZCAqcmV0dmFsLCBjaGFyICpjdXJyZW50ZnJhbWUpOwogIHZvaWQgKCpwdHJfcHRocmVhZF9jbGVhbnVwX3VwdG8pIChqbXBfYnVmIHRhcmdldCwgY2hhciAqdGFyZ2V0ZnJhbWUpOwogIHB0aHJlYWRfZGVzY3IgKCpwdHJfcHRocmVhZF90aHJlYWRfc2VsZikgKHZvaWQpOwogIGludCAoKnB0cl9wdGhyZWFkX2ludGVybmFsX3RzZF9zZXQpIChpbnQga2V5LCBjb25zdCB2b2lkICpwb2ludGVyKTsKICB2b2lkICogKCpwdHJfcHRocmVhZF9pbnRlcm5hbF90c2RfZ2V0KSAoaW50IGtleSk7CiAgdm9pZCAqKiBfX2F0dHJpYnV0ZV9fICgoX19jb25zdF9fKSkgKCpwdHJfcHRocmVhZF9pbnRlcm5hbF90c2RfYWRkcmVzcykgKGludCBrZXkpOwogIGludCAoKnB0cl9wdGhyZWFkX3NpZ2FjdGlvbikgKGludCBzaWcsIGNvbnN0IHN0cnVjdCBzaWdhY3Rpb24gKiBhY3QsIHN0cnVjdCBzaWdhY3Rpb24gKm9hY3QpOwogIGludCAoKnB0cl9wdGhyZWFkX3NpZ3dhaXQpIChjb25zdCBzaWdzZXRfdCAqc2V0LCBpbnQgKnNpZyk7CiAgaW50ICgqcHRyX3B0aHJlYWRfcmFpc2UpIChpbnQgc2lnKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfdGltZWR3YWl0KSAocHRocmVhZF9jb25kX3QgKiwgcHRocmVhZF9tdXRleF90ICosIGNvbnN0IHN0cnVjdCB0aW1lc3BlYyAqKTsKICB2b2lkICgqcHRyX19wdGhyZWFkX2NsZWFudXBfcHVzaCkgKHN0cnVjdCBfcHRocmVhZF9jbGVhbnVwX2J1ZmZlciAqIGJ1ZmZlciwgdm9pZCAoKnJvdXRpbmUpKHZvaWQgKiksIHZvaWQgKiBhcmcpOwogIHZvaWQgKCpwdHJfX3B0aHJlYWRfY2xlYW51cF9wb3ApIChzdHJ1Y3QgX3B0aHJlYWRfY2xlYW51cF9idWZmZXIgKiBidWZmZXIsIGludCBleGVjdXRlKTsKfTsKCnN0YXRpYyBwaWRfdCAoKmxpYmNfZm9yaykodm9pZCk7CnN0YXRpYyBpbnQgKCpsaWJjX3NpZ2FjdGlvbikoaW50IHNpZ251bSwgY29uc3Qgc3RydWN0IHNpZ2FjdGlvbiAqYWN0LCBzdHJ1Y3Qgc2lnYWN0aW9uICpvbGRhY3QpOwpzdGF0aWMgaW50ICooKmxpYmNfcHRocmVhZF9pbml0KSggY29uc3Qgc3RydWN0IHB0aHJlYWRfZnVuY3Rpb25zICpmdW5jcyApOwoKc3RhdGljIHN0cnVjdCBwdGhyZWFkX2Z1bmN0aW9ucyBsaWJjX3B0aHJlYWRfZnVuY3Rpb25zOwoKc3Ryb25nX2FsaWFzKF9fcHRocmVhZF90aHJlYWRfc2VsZiwgcHRocmVhZF90aHJlYWRfc2VsZik7CgovKiByZWRlZmluZSB0aGlzIHRvIHByZXZlbnQgbGlicHRocmVhZCBmcm9tIG92ZXJyaWRpbmcgb3VyIGZ1bmN0aW9uIHBvaW50ZXJzICovCmludCAqX19saWJjX3B0aHJlYWRfaW5pdCggY29uc3Qgc3RydWN0IHB0aHJlYWRfZnVuY3Rpb25zICpmdW5jcyApCnsKICAgIHJldHVybiBsaWJjX211bHRpcGxlX3RocmVhZHM7Cn0KCnR5cGVkZWYgc3RydWN0IF93aW5lX2NsZWFudXAgewogIHZvaWQgKCpyb3V0aW5lKSh2b2lkICopOwogIHZvaWQgKmFyZzsKfSAqd2luZV9jbGVhbnVwOwoKaW50IHB0aHJlYWRfY3JlYXRlKHB0aHJlYWRfdCogdGhyZWFkLCBjb25zdCBwdGhyZWFkX2F0dHJfdCogYXR0ciwgdm9pZCoKICAgICAgICAoKnN0YXJ0X3JvdXRpbmUpKHZvaWQgKiksIHZvaWQqIGFyZykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9jcmVhdGUgKTsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jcmVhdGUoIHRocmVhZCwgYXR0ciwgc3RhcnRfcm91dGluZSwgYXJnICk7Cn0KCmludCBwdGhyZWFkX2NhbmNlbChwdGhyZWFkX3QgdGhyZWFkKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX2NhbmNlbCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2NhbmNlbCggdGhyZWFkICk7Cn0KCmludCBwdGhyZWFkX2pvaW4ocHRocmVhZF90IHRocmVhZCwgdm9pZCAqKnZhbHVlX3B0cikKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9qb2luICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfam9pbiggdGhyZWFkLCB2YWx1ZV9wdHIgKTsKfQoKaW50IHB0aHJlYWRfZGV0YWNoKHB0aHJlYWRfdCB0aHJlYWQpCnsKICAgIGFzc2VydCggZnVuY3MucHRyX3B0aHJlYWRfZGV0YWNoICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfZGV0YWNoKCB0aHJlYWQgKTsKfQoKLyogRklYTUU6IHdlIGhhdmUgbm8gZXF1aXZhbGVudHMgaW4gd2luMzIgZm9yIHRoZSBwb2xpY3lzICovCi8qIHNvIGp1c3Qga2VlcCB0aGlzIGFzIGEgc3R1YiAqLwppbnQgcHRocmVhZF9hdHRyX3NldHNjaGVkcG9saWN5KHB0aHJlYWRfYXR0cl90ICphdHRyLCBpbnQgcG9saWN5KQp7CiAgUF9PVVRQVVQoIkZJWE1FOnB0aHJlYWRfYXR0cl9zZXRzY2hlZHBvbGljeVxuIik7CiAgcmV0dXJuIDA7Cn0KCi8qIEZJWE1FOiBubyB3aW4zMiBlcXVpdmFsZW50IGZvciBzY29wZSAqLwppbnQgcHRocmVhZF9hdHRyX3NldHNjb3BlKHB0aHJlYWRfYXR0cl90ICphdHRyLCBpbnQgc2NvcGUpCnsKICBQX09VVFBVVCgiRklYTUU6cHRocmVhZF9hdHRyX3NldHNjb3BlXG4iKTsKICByZXR1cm4gMDsgLyogcmV0dXJuIHN1Y2Nlc3MgKi8KfQoKLyogRklYTUU6IG5vIHdpbjMyIGVxdWl2YWxlbnQgZm9yIHNjaGVkdWxlIHBhcmFtICovCmludCBwdGhyZWFkX2F0dHJfc2V0c2NoZWRwYXJhbShwdGhyZWFkX2F0dHJfdCAqYXR0ciwKICAgIGNvbnN0IHN0cnVjdCBzY2hlZF9wYXJhbSAqcGFyYW0pCnsKICBQX09VVFBVVCgiRklYTUU6cHRocmVhZF9hdHRyX3NldHNjaGVkcGFyYW1cbiIpOwogIHJldHVybiAwOyAvKiByZXR1cm4gc3VjY2VzcyAqLwp9CgovKiBGSVhNRSAqLwppbnQgcHRocmVhZF9hdHRyX3NldHN0YWNrKHB0aHJlYWRfYXR0cl90ICphdHRyLCB2b2lkICphZGRyLCBzaXplX3Qgc2l6ZSkKewogIHJldHVybiAwOyAvKiByZXR1cm4gc3VjY2VzcyAqLwp9CgppbnQgX19wdGhyZWFkX29uY2UocHRocmVhZF9vbmNlX3QgKm9uY2VfY29udHJvbCwgdm9pZCAoKmluaXRfcm91dGluZSkodm9pZCkpCnsKICAgIHN0YXRpYyBwdGhyZWFkX29uY2VfdCB0aGVfb25jZSA9IFBUSFJFQURfT05DRV9JTklUOwogICAgaW50IG9uY2Vfbm93OwoKICAgIG1lbWNweSgmb25jZV9ub3csJnRoZV9vbmNlLHNpemVvZihvbmNlX25vdykpOwogICAgaWYgKGludGVybG9ja2VkX2NtcHhjaGcoKGludCopb25jZV9jb250cm9sLCBvbmNlX25vdysxLCBvbmNlX25vdykgPT0gb25jZV9ub3cpCiAgICAgICAgKCppbml0X3JvdXRpbmUpKCk7CiAgICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX29uY2UsIHB0aHJlYWRfb25jZSk7Cgp2b2lkIF9fcHRocmVhZF9raWxsX290aGVyX3RocmVhZHNfbnAodm9pZCkKewogICAgLyogd2UgZG9uJ3QgbmVlZCB0byBkbyBhbnl0aGluZyBoZXJlICovCn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9raWxsX290aGVyX3RocmVhZHNfbnAsIHB0aHJlYWRfa2lsbF9vdGhlcl90aHJlYWRzX25wKTsKCi8qKioqKiBhdGZvcmsgKioqKiovCgojZGVmaW5lIE1BWF9BVEZPUksgOCAgLyogbGliYyBkb2Vzbid0IG5lZWQgdGhhdCBtYW55IGFueXdheSAqLwoKc3RhdGljIHB0aHJlYWRfbXV0ZXhfdCBhdGZvcmtfbXV0ZXggPSBQVEhSRUFEX01VVEVYX0lOSVRJQUxJWkVSOwoKdHlwZWRlZiB2b2lkICgqYXRmb3JrX2hhbmRsZXIpKHZvaWQpOwpzdGF0aWMgYXRmb3JrX2hhbmRsZXIgYXRmb3JrX3ByZXBhcmVbTUFYX0FURk9SS107CnN0YXRpYyBhdGZvcmtfaGFuZGxlciBhdGZvcmtfcGFyZW50W01BWF9BVEZPUktdOwpzdGF0aWMgYXRmb3JrX2hhbmRsZXIgYXRmb3JrX2NoaWxkW01BWF9BVEZPUktdOwpzdGF0aWMgaW50IGF0Zm9ya19jb3VudDsKCmludCBfX3B0aHJlYWRfYXRmb3JrKHZvaWQgKCpwcmVwYXJlKSh2b2lkKSwgdm9pZCAoKnBhcmVudCkodm9pZCksIHZvaWQgKCpjaGlsZCkodm9pZCkpCnsKICAgIHB0aHJlYWRfbXV0ZXhfbG9jayggJmF0Zm9ya19tdXRleCApOwogICAgYXNzZXJ0KCBhdGZvcmtfY291bnQgPCBNQVhfQVRGT1JLICk7CiAgICBhdGZvcmtfcHJlcGFyZVthdGZvcmtfY291bnRdID0gcHJlcGFyZTsKICAgIGF0Zm9ya19wYXJlbnRbYXRmb3JrX2NvdW50XSA9IHBhcmVudDsKICAgIGF0Zm9ya19jaGlsZFthdGZvcmtfY291bnRdID0gY2hpbGQ7CiAgICBhdGZvcmtfY291bnQrKzsKICAgIHB0aHJlYWRfbXV0ZXhfdW5sb2NrKCAmYXRmb3JrX211dGV4ICk7CiAgICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2F0Zm9yaywgcHRocmVhZF9hdGZvcmspOwoKcGlkX3QgX19mb3JrKHZvaWQpCnsKICAgIHBpZF90IHBpZDsKICAgIGludCBpOwoKICAgIGlmICghbGliY19mb3JrKQogICAgewogICAgICAgIGxpYmNfZm9yayA9IHdpbmVfZGxzeW0oIFJUTERfTkVYVCwgImZvcmsiLCBOVUxMLCAwICk7CiAgICAgICAgYXNzZXJ0KCBsaWJjX2ZvcmsgKTsKICAgIH0KICAgIHB0aHJlYWRfbXV0ZXhfbG9jayggJmF0Zm9ya19tdXRleCApOwogICAgLyogcHJlcGFyZSBoYW5kbGVycyBhcmUgY2FsbGVkIGluIHJldmVyc2UgaW5zZXJ0aW9uIG9yZGVyICovCiAgICBmb3IgKGkgPSBhdGZvcmtfY291bnQgLSAxOyBpID49IDA7IGktLSkgaWYgKGF0Zm9ya19wcmVwYXJlW2ldKSBhdGZvcmtfcHJlcGFyZVtpXSgpOwogICAgaWYgKCEocGlkID0gbGliY19mb3JrKCkpKQogICAgewogICAgICAgIHB0aHJlYWRfbXV0ZXhfaW5pdCggJmF0Zm9ya19tdXRleCwgTlVMTCApOwogICAgICAgIGZvciAoaSA9IDA7IGkgPCBhdGZvcmtfY291bnQ7IGkrKykgaWYgKGF0Zm9ya19jaGlsZFtpXSkgYXRmb3JrX2NoaWxkW2ldKCk7CiAgICB9CiAgICBlbHNlCiAgICB7CiAgICAgICAgZm9yIChpID0gMDsgaSA8IGF0Zm9ya19jb3VudDsgaSsrKSBpZiAoYXRmb3JrX3BhcmVudFtpXSkgYXRmb3JrX3BhcmVudFtpXSgpOwogICAgICAgIHB0aHJlYWRfbXV0ZXhfdW5sb2NrKCAmYXRmb3JrX211dGV4ICk7CiAgICB9CiAgICByZXR1cm4gcGlkOwp9CnN0cm9uZ19hbGlhcyhfX2ZvcmssIGZvcmspOwoKLyoqKioqIE1VVEVYRVMgKioqKiovCgppbnQgX19wdGhyZWFkX211dGV4X2luaXQocHRocmVhZF9tdXRleF90ICptdXRleCwgY29uc3QgcHRocmVhZF9tdXRleGF0dHJfdCAqbXV0ZXhhdHRyKQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X2luaXQpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X2luaXQoIG11dGV4LCBtdXRleGF0dHIgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX211dGV4X2luaXQsIHB0aHJlYWRfbXV0ZXhfaW5pdCk7CgppbnQgX19wdGhyZWFkX211dGV4X2xvY2socHRocmVhZF9tdXRleF90ICptdXRleCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9tdXRleF9sb2NrKSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9tdXRleF9sb2NrKCBtdXRleCApOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhfbG9jaywgcHRocmVhZF9tdXRleF9sb2NrKTsKCmludCBfX3B0aHJlYWRfbXV0ZXhfdHJ5bG9jayhwdGhyZWFkX211dGV4X3QgKm11dGV4KQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X3RyeWxvY2spIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X3RyeWxvY2soIG11dGV4ICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleF90cnlsb2NrLCBwdGhyZWFkX211dGV4X3RyeWxvY2spOwoKaW50IF9fcHRocmVhZF9tdXRleF91bmxvY2socHRocmVhZF9tdXRleF90ICptdXRleCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9tdXRleF91bmxvY2spIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X3VubG9jayggbXV0ZXggKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX211dGV4X3VubG9jaywgcHRocmVhZF9tdXRleF91bmxvY2spOwoKaW50IF9fcHRocmVhZF9tdXRleF9kZXN0cm95KHB0aHJlYWRfbXV0ZXhfdCAqbXV0ZXgpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfbXV0ZXhfZGVzdHJveSkgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfbXV0ZXhfZGVzdHJveSggbXV0ZXggKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX211dGV4X2Rlc3Ryb3ksIHB0aHJlYWRfbXV0ZXhfZGVzdHJveSk7CgoKLyoqKioqIE1VVEVYIEFUVFJJQlVURVMgKioqKiovCi8qIGp1c3QgZHVtbWllcywgc2luY2UgY3JpdGljYWwgc2VjdGlvbnMgYXJlIGFsd2F5cyByZWN1cnNpdmUgKi8KCmludCBfX3B0aHJlYWRfbXV0ZXhhdHRyX2luaXQocHRocmVhZF9tdXRleGF0dHJfdCAqYXR0cikKewogIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhhdHRyX2luaXQsIHB0aHJlYWRfbXV0ZXhhdHRyX2luaXQpOwoKaW50IF9fcHRocmVhZF9tdXRleGF0dHJfZGVzdHJveShwdGhyZWFkX211dGV4YXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfZGVzdHJveSwgcHRocmVhZF9tdXRleGF0dHJfZGVzdHJveSk7CgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9zZXRraW5kX25wKHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIsIGludCBraW5kKQp7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfc2V0a2luZF9ucCwgcHRocmVhZF9tdXRleGF0dHJfc2V0a2luZF9ucCk7CgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9nZXRraW5kX25wKHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIsIGludCAqa2luZCkKewogICpraW5kID0gUFRIUkVBRF9NVVRFWF9SRUNVUlNJVkU7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfZ2V0a2luZF9ucCwgcHRocmVhZF9tdXRleGF0dHJfZ2V0a2luZF9ucCk7CgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9zZXR0eXBlKHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIsIGludCBraW5kKQp7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfc2V0dHlwZSwgcHRocmVhZF9tdXRleGF0dHJfc2V0dHlwZSk7CgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9nZXR0eXBlKGNvbnN0IHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIsIGludCAqa2luZCkKewogICpraW5kID0gUFRIUkVBRF9NVVRFWF9SRUNVUlNJVkU7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleGF0dHJfZ2V0dHlwZSwgcHRocmVhZF9tdXRleGF0dHJfZ2V0dHlwZSk7CgoKLyoqKioqIFRIUkVBRC1TUEVDSUZJQyBWQVJJQUJMRVMgKEtFWVMpICoqKioqLwoKaW50IF9fcHRocmVhZF9rZXlfY3JlYXRlKHB0aHJlYWRfa2V5X3QgKmtleSwgdm9pZCAoKmRlc3RyX2Z1bmN0aW9uKSh2b2lkICopKQp7CiAgICBzdGF0aWMgaW50IGtleWNudCA9IEZJUlNUX0tFWTsKICAgICprZXkgPSBpbnRlcmxvY2tlZF94Y2hnX2FkZCgma2V5Y250LCAxKTsKICAgIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfa2V5X2NyZWF0ZSwgcHRocmVhZF9rZXlfY3JlYXRlKTsKCmludCBfX3B0aHJlYWRfa2V5X2RlbGV0ZShwdGhyZWFkX2tleV90IGtleSkKewogIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfa2V5X2RlbGV0ZSwgcHRocmVhZF9rZXlfZGVsZXRlKTsKCmludCBfX3B0aHJlYWRfc2V0c3BlY2lmaWMocHRocmVhZF9rZXlfdCBrZXksIGNvbnN0IHZvaWQgKnBvaW50ZXIpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIGRlc2NyLT5rZXlfZGF0YVtrZXldID0gcG9pbnRlcjsKICAgIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfc2V0c3BlY2lmaWMsIHB0aHJlYWRfc2V0c3BlY2lmaWMpOwoKdm9pZCAqX19wdGhyZWFkX2dldHNwZWNpZmljKHB0aHJlYWRfa2V5X3Qga2V5KQp7CiAgICBwdGhyZWFkX2Rlc2NyIGRlc2NyID0gX19wdGhyZWFkX3RocmVhZF9zZWxmKCk7CiAgICByZXR1cm4gKHZvaWQgKilkZXNjci0+a2V5X2RhdGFba2V5XTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2dldHNwZWNpZmljLCBwdGhyZWFkX2dldHNwZWNpZmljKTsKCnN0YXRpYyBpbnQgcHRocmVhZF9pbnRlcm5hbF90c2Rfc2V0KCBpbnQga2V5LCBjb25zdCB2b2lkICpwb2ludGVyICkKewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgZGVzY3ItPnRzZF9kYXRhW2tleV0gPSBwb2ludGVyOwogICAgcmV0dXJuIDA7Cn0KaW50ICgqX19saWJjX2ludGVybmFsX3RzZF9zZXQpKGludCwgY29uc3Qgdm9pZCAqKSA9IHB0aHJlYWRfaW50ZXJuYWxfdHNkX3NldDsKCnN0YXRpYyB2b2lkICpwdGhyZWFkX2ludGVybmFsX3RzZF9nZXQoIGludCBrZXkgKQp7CiAgICBwdGhyZWFkX2Rlc2NyIGRlc2NyID0gX19wdGhyZWFkX3RocmVhZF9zZWxmKCk7CiAgICByZXR1cm4gKHZvaWQgKilkZXNjci0+dHNkX2RhdGFba2V5XTsKfQp2b2lkKiAoKl9fbGliY19pbnRlcm5hbF90c2RfZ2V0KShpbnQpID0gcHRocmVhZF9pbnRlcm5hbF90c2RfZ2V0OwoKc3RhdGljIHZvaWQgKiogX19hdHRyaWJ1dGVfXygoY29uc3QpKSBwdGhyZWFkX2ludGVybmFsX3RzZF9hZGRyZXNzKCBpbnQga2V5ICkKewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgcmV0dXJuICh2b2lkICoqKSZkZXNjci0+dHNkX2RhdGFba2V5XTsKfQp2b2lkKiogKCpfX2xpYmNfaW50ZXJuYWxfdHNkX2FkZHJlc3MpKGludCkgPSBwdGhyZWFkX2ludGVybmFsX3RzZF9hZGRyZXNzOwoKLyoqKioqICJFWENFUFRJT04iIEZSQU1FUyAqKioqKi8KLyogbm90IGltcGxlbWVudGVkIHJpZ2h0IG5vdyAqLwoKdm9pZCBfcHRocmVhZF9jbGVhbnVwX3B1c2goc3RydWN0IF9wdGhyZWFkX2NsZWFudXBfYnVmZmVyICpidWZmZXIsIHZvaWQgKCpyb3V0aW5lKSh2b2lkICopLCB2b2lkICphcmcpCnsKICAoKHdpbmVfY2xlYW51cClidWZmZXIpLT5yb3V0aW5lID0gcm91dGluZTsKICAoKHdpbmVfY2xlYW51cClidWZmZXIpLT5hcmcgPSBhcmc7Cn0KCnZvaWQgX3B0aHJlYWRfY2xlYW51cF9wb3Aoc3RydWN0IF9wdGhyZWFkX2NsZWFudXBfYnVmZmVyICpidWZmZXIsIGludCBleGVjdXRlKQp7CiAgaWYgKGV4ZWN1dGUpICgqKCgod2luZV9jbGVhbnVwKWJ1ZmZlciktPnJvdXRpbmUpKSgoKHdpbmVfY2xlYW51cClidWZmZXIpLT5hcmcpOwp9Cgp2b2lkIF9wdGhyZWFkX2NsZWFudXBfcHVzaF9kZWZlcihzdHJ1Y3QgX3B0aHJlYWRfY2xlYW51cF9idWZmZXIgKmJ1ZmZlciwgdm9pZCAoKnJvdXRpbmUpKHZvaWQgKiksIHZvaWQgKmFyZykKewogIF9wdGhyZWFkX2NsZWFudXBfcHVzaChidWZmZXIsIHJvdXRpbmUsIGFyZyk7Cn0KCnZvaWQgX3B0aHJlYWRfY2xlYW51cF9wb3BfcmVzdG9yZShzdHJ1Y3QgX3B0aHJlYWRfY2xlYW51cF9idWZmZXIgKmJ1ZmZlciwgaW50IGV4ZWN1dGUpCnsKICBfcHRocmVhZF9jbGVhbnVwX3BvcChidWZmZXIsIGV4ZWN1dGUpOwp9Cgp2b2lkIF9fcHRocmVhZF9jbGVhbnVwX3VwdG8oam1wX2J1ZiB0YXJnZXQsIGNoYXIgKmZyYW1lKQp7CiAgICAvKiBGSVhNRSAqLwp9CgovKioqKiogQ09ORElUSU9OUyAqKioqKi8KCmludCBfX3B0aHJlYWRfY29uZF9pbml0KHB0aHJlYWRfY29uZF90ICpjb25kLCBjb25zdCBwdGhyZWFkX2NvbmRhdHRyX3QgKmNvbmRfYXR0cikKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX2luaXQpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfaW5pdChjb25kLCBjb25kX2F0dHIpOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfY29uZF9pbml0LCBwdGhyZWFkX2NvbmRfaW5pdCk7CgppbnQgX19wdGhyZWFkX2NvbmRfZGVzdHJveShwdGhyZWFkX2NvbmRfdCAqY29uZCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX2Rlc3Ryb3kpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfZGVzdHJveShjb25kKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2NvbmRfZGVzdHJveSwgcHRocmVhZF9jb25kX2Rlc3Ryb3kpOwoKaW50IF9fcHRocmVhZF9jb25kX3NpZ25hbChwdGhyZWFkX2NvbmRfdCAqY29uZCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX3NpZ25hbCkgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfY29uZF9zaWduYWwoY29uZCk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9jb25kX3NpZ25hbCwgcHRocmVhZF9jb25kX3NpZ25hbCk7CgppbnQgX19wdGhyZWFkX2NvbmRfYnJvYWRjYXN0KHB0aHJlYWRfY29uZF90ICpjb25kKQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfYnJvYWRjYXN0KSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jb25kX2Jyb2FkY2FzdChjb25kKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2NvbmRfYnJvYWRjYXN0LCBwdGhyZWFkX2NvbmRfYnJvYWRjYXN0KTsKCmludCBfX3B0aHJlYWRfY29uZF93YWl0KHB0aHJlYWRfY29uZF90ICpjb25kLCBwdGhyZWFkX211dGV4X3QgKm11dGV4KQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfd2FpdCkgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfY29uZF93YWl0KGNvbmQsIG11dGV4KTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2NvbmRfd2FpdCwgcHRocmVhZF9jb25kX3dhaXQpOwoKaW50IF9fcHRocmVhZF9jb25kX3RpbWVkd2FpdChwdGhyZWFkX2NvbmRfdCAqY29uZCwgcHRocmVhZF9tdXRleF90ICptdXRleCwgY29uc3Qgc3RydWN0IHRpbWVzcGVjICphYnN0aW1lKQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfdGltZWR3YWl0KSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jb25kX3RpbWVkd2FpdChjb25kLCBtdXRleCwgYWJzdGltZSk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9jb25kX3RpbWVkd2FpdCwgcHRocmVhZF9jb25kX3RpbWVkd2FpdCk7CgovKioqKiBDT05ESVRJT04gQVRUUklCVVRFUyAqKioqKi8KLyogbm90IGltcGxlbWVudGVkIHJpZ2h0IG5vdyAqLwoKaW50IHB0aHJlYWRfY29uZGF0dHJfaW5pdChwdGhyZWFkX2NvbmRhdHRyX3QgKmF0dHIpCnsKICByZXR1cm4gMDsKfQoKaW50IHB0aHJlYWRfY29uZGF0dHJfZGVzdHJveShwdGhyZWFkX2NvbmRhdHRyX3QgKmF0dHIpCnsKICByZXR1cm4gMDsKfQoKLyoqKioqIFJFQUQtV1JJVEUgTE9DS1MgKioqKiovCgppbnQgX19wdGhyZWFkX3J3bG9ja19pbml0KHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaywgY29uc3QgcHRocmVhZF9yd2xvY2thdHRyX3QgKnJ3bG9ja19hdHRyKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja19pbml0ICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX2luaXQoIHJ3bG9jaywgcndsb2NrX2F0dHIgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja19pbml0LCBwdGhyZWFkX3J3bG9ja19pbml0KTsKCmludCBfX3B0aHJlYWRfcndsb2NrX2Rlc3Ryb3kocHRocmVhZF9yd2xvY2tfdCAqcndsb2NrKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja19kZXN0cm95ICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX2Rlc3Ryb3koIHJ3bG9jayApOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfcndsb2NrX2Rlc3Ryb3ksIHB0aHJlYWRfcndsb2NrX2Rlc3Ryb3kpOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfcmRsb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfcmRsb2NrKSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfcmRsb2NrKCByd2xvY2sgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja19yZGxvY2ssIHB0aHJlYWRfcndsb2NrX3JkbG9jayk7CgppbnQgX19wdGhyZWFkX3J3bG9ja190cnlyZGxvY2socHRocmVhZF9yd2xvY2tfdCAqcndsb2NrKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja190cnlyZGxvY2sgKTsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdHJ5cmRsb2NrKCByd2xvY2sgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja190cnlyZGxvY2ssIHB0aHJlYWRfcndsb2NrX3RyeXJkbG9jayk7CgppbnQgX19wdGhyZWFkX3J3bG9ja193cmxvY2socHRocmVhZF9yd2xvY2tfdCAqcndsb2NrKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja193cmxvY2sgKTsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfd3Jsb2NrKCByd2xvY2sgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja193cmxvY2ssIHB0aHJlYWRfcndsb2NrX3dybG9jayk7CgppbnQgX19wdGhyZWFkX3J3bG9ja190cnl3cmxvY2socHRocmVhZF9yd2xvY2tfdCAqcndsb2NrKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja190cnl3cmxvY2sgKTsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdHJ5d3Jsb2NrKCByd2xvY2sgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja190cnl3cmxvY2ssIHB0aHJlYWRfcndsb2NrX3RyeXdybG9jayk7CgppbnQgX19wdGhyZWFkX3J3bG9ja191bmxvY2socHRocmVhZF9yd2xvY2tfdCAqcndsb2NrKQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja191bmxvY2spIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja191bmxvY2soIHJ3bG9jayApOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfcndsb2NrX3VubG9jaywgcHRocmVhZF9yd2xvY2tfdW5sb2NrKTsKCi8qKioqIFJFQUQtV1JJVEUgTE9DSyBBVFRSSUJVVEVTICoqKioqLwovKiBub3QgaW1wbGVtZW50ZWQgcmlnaHQgbm93ICovCgppbnQgcHRocmVhZF9yd2xvY2thdHRyX2luaXQocHRocmVhZF9yd2xvY2thdHRyX3QgKmF0dHIpCnsKICByZXR1cm4gMDsKfQoKaW50IF9fcHRocmVhZF9yd2xvY2thdHRyX2Rlc3Ryb3kocHRocmVhZF9yd2xvY2thdHRyX3QgKmF0dHIpCnsKICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja2F0dHJfZGVzdHJveSwgcHRocmVhZF9yd2xvY2thdHRyX2Rlc3Ryb3kpOwoKaW50IHB0aHJlYWRfcndsb2NrYXR0cl9nZXRraW5kX25wKGNvbnN0IHB0aHJlYWRfcndsb2NrYXR0cl90ICphdHRyLCBpbnQgKnByZWYpCnsKICAqcHJlZiA9IDA7CiAgcmV0dXJuIDA7Cn0KCmludCBwdGhyZWFkX3J3bG9ja2F0dHJfc2V0a2luZF9ucChwdGhyZWFkX3J3bG9ja2F0dHJfdCAqYXR0ciwgaW50IHByZWYpCnsKICByZXR1cm4gMDsKfQoKLyoqKioqIE1JU0MgKioqKiovCgpwdGhyZWFkX3QgcHRocmVhZF9zZWxmKHZvaWQpCnsKICAgIGFzc2VydCggZnVuY3MucHRyX3B0aHJlYWRfc2VsZiApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX3NlbGYoKTsKfQoKaW50IHB0aHJlYWRfZXF1YWwocHRocmVhZF90IHRocmVhZDEsIHB0aHJlYWRfdCB0aHJlYWQyKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX2VxdWFsICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfZXF1YWwoIHRocmVhZDEsIHRocmVhZDIgKTsKfQoKdm9pZCBfX3B0aHJlYWRfZG9fZXhpdCh2b2lkICpyZXR2YWwsIGNoYXIgKmN1cnJlbnRmcmFtZSkKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9leGl0ICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfZXhpdCggcmV0dmFsLCBjdXJyZW50ZnJhbWUgKTsKfQoKdm9pZCBfX3B0aHJlYWRfZXhpdCh2b2lkICpyZXR2YWwpCnsKICAgIF9fcHRocmVhZF9kb19leGl0KCByZXR2YWwsIE5VTEwgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2V4aXQsIHB0aHJlYWRfZXhpdCk7CgppbnQgcHRocmVhZF9zZXRjYW5jZWxzdGF0ZShpbnQgc3RhdGUsIGludCAqb2xkc3RhdGUpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIGlmIChvbGRzdGF0ZSkgKm9sZHN0YXRlID0gZGVzY3ItPmNhbmNlbF9zdGF0ZTsKICAgIGRlc2NyLT5jYW5jZWxfc3RhdGUgPSBzdGF0ZTsKICAgIHJldHVybiAwOwp9CgppbnQgcHRocmVhZF9zZXRjYW5jZWx0eXBlKGludCB0eXBlLCBpbnQgKm9sZHR5cGUpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIGlmIChvbGR0eXBlKSAqb2xkdHlwZSA9IGRlc2NyLT5jYW5jZWxfdHlwZTsKICAgIGRlc2NyLT5jYW5jZWxfdHlwZSA9IHR5cGU7CiAgICByZXR1cm4gMDsKfQoKLyoqKioqIEFOVEktT1ZFUlJJREVTICoqKioqLwovKiBwdGhyZWFkcyB0cmllcyB0byBvdmVycmlkZSB0aGVzZSwgcG9pbnQgdGhlbSBiYWNrIHRvIGxpYmMgKi8KCmludCBzaWdhY3Rpb24oaW50IHNpZ251bSwgY29uc3Qgc3RydWN0IHNpZ2FjdGlvbiAqYWN0LCBzdHJ1Y3Qgc2lnYWN0aW9uICpvbGRhY3QpCnsKICAgIGlmICghbGliY19zaWdhY3Rpb24pCiAgICB7CiAgICAgICAgbGliY19zaWdhY3Rpb24gPSB3aW5lX2Rsc3ltKCBSVExEX05FWFQsICJzaWdhY3Rpb24iLCBOVUxMLCAwICk7CiAgICAgICAgYXNzZXJ0KCBsaWJjX3NpZ2FjdGlvbiApOwogICAgfQogICAgcmV0dXJuIGxpYmNfc2lnYWN0aW9uKHNpZ251bSwgYWN0LCBvbGRhY3QpOwp9Cgp2b2lkIF9fcHRocmVhZF9pbml0aWFsaXplKHZvaWQpCnsKICAgIHN0YXRpYyBpbnQgZG9uZTsKCiAgICBpZiAoIWRvbmUpCiAgICB7CiAgICAgICAgZG9uZSA9IDE7CiAgICAgICAgbGliY19mb3JrID0gd2luZV9kbHN5bSggUlRMRF9ORVhULCAiZm9yayIsIE5VTEwsIDAgKTsKICAgICAgICBsaWJjX3NpZ2FjdGlvbiA9IHdpbmVfZGxzeW0oIFJUTERfTkVYVCwgInNpZ2FjdGlvbiIsIE5VTEwsIDAgKTsKICAgICAgICBsaWJjX3VzZWxvY2FsZSA9IHdpbmVfZGxzeW0oIFJUTERfREVGQVVMVCwgInVzZWxvY2FsZSIsIE5VTEwsIDAgKTsKICAgICAgICBsaWJjX3B0aHJlYWRfaW5pdCA9IHdpbmVfZGxzeW0oIFJUTERfTkVYVCwgIl9fbGliY19wdGhyZWFkX2luaXQiLCBOVUxMLCAwICk7CiAgICAgICAgaWYgKGxpYmNfcHRocmVhZF9pbml0KSBsaWJjX211bHRpcGxlX3RocmVhZHMgPSBsaWJjX3B0aHJlYWRfaW5pdCggJmxpYmNfcHRocmVhZF9mdW5jdGlvbnMgKTsKICAgIH0KfQoKI2lmZGVmIF9fR05VQ19fCnN0YXRpYyB2b2lkIGluaXQodm9pZCkgX19hdHRyaWJ1dGVfXygoY29uc3RydWN0b3IpKTsKc3RhdGljIHZvaWQgaW5pdCh2b2lkKQp7CiAgICBfX3B0aHJlYWRfaW5pdGlhbGl6ZSgpOwp9CiNlbmRpZgoKc3RhdGljIHN0cnVjdCBwdGhyZWFkX2Z1bmN0aW9ucyBsaWJjX3B0aHJlYWRfZnVuY3Rpb25zID0KewogICAgTlVMTCwgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2ZvcmsgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX2Rlc3Ryb3kgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfX19wdGhyZWFkX2F0dHJfaW5pdF8yXzAgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfX19wdGhyZWFkX2F0dHJfaW5pdF8yXzEgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX2dldGRldGFjaHN0YXRlICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9zZXRkZXRhY2hzdGF0ZSAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2F0dHJfZ2V0aW5oZXJpdHNjaGVkICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9zZXRpbmhlcml0c2NoZWQgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX2dldHNjaGVkcGFyYW0gKi8KICAgIHB0aHJlYWRfYXR0cl9zZXRzY2hlZHBhcmFtLCAgICAvKiBwdHJfcHRocmVhZF9hdHRyX3NldHNjaGVkcGFyYW0gKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX2dldHNjaGVkcG9saWN5ICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9zZXRzY2hlZHBvbGljeSAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2F0dHJfZ2V0c2NvcGUgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX3NldHNjb3BlICovCiAgICBwdGhyZWFkX2NvbmRhdHRyX2Rlc3Ryb3ksICAgICAgLyogcHRyX3B0aHJlYWRfY29uZGF0dHJfZGVzdHJveSAqLwogICAgcHRocmVhZF9jb25kYXR0cl9pbml0LCAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2NvbmRhdHRyX2luaXQgKi8KICAgIF9fcHRocmVhZF9jb25kX2Jyb2FkY2FzdCwgICAgICAvKiBwdHJfX19wdGhyZWFkX2NvbmRfYnJvYWRjYXN0ICovCiAgICBfX3B0aHJlYWRfY29uZF9kZXN0cm95LCAgICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX2Rlc3Ryb3kgKi8KICAgIF9fcHRocmVhZF9jb25kX2luaXQsICAgICAgICAgICAvKiBwdHJfX19wdGhyZWFkX2NvbmRfaW5pdCAqLwogICAgX19wdGhyZWFkX2NvbmRfc2lnbmFsLCAgICAgICAgIC8qIHB0cl9fX3B0aHJlYWRfY29uZF9zaWduYWwgKi8KICAgIF9fcHRocmVhZF9jb25kX3dhaXQsICAgICAgICAgICAvKiBwdHJfX19wdGhyZWFkX2NvbmRfd2FpdCAqLwogICAgcHRocmVhZF9lcXVhbCwgICAgICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2VxdWFsICovCiAgICBfX3B0aHJlYWRfZXhpdCwgICAgICAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9leGl0ICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfZ2V0c2NoZWRwYXJhbSAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX3NldHNjaGVkcGFyYW0gKi8KICAgIF9fcHRocmVhZF9tdXRleF9kZXN0cm95LCAgICAgICAvKiBwdHJfcHRocmVhZF9tdXRleF9kZXN0cm95ICovCiAgICBfX3B0aHJlYWRfbXV0ZXhfaW5pdCwgICAgICAgICAgLyogcHRyX3B0aHJlYWRfbXV0ZXhfaW5pdCAqLwogICAgX19wdGhyZWFkX211dGV4X2xvY2ssICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX211dGV4X2xvY2sgKi8KICAgIF9fcHRocmVhZF9tdXRleF90cnlsb2NrLCAgICAgICAvKiBwdHJfcHRocmVhZF9tdXRleF90cnlsb2NrICovCiAgICBfX3B0aHJlYWRfbXV0ZXhfdW5sb2NrLCAgICAgICAgLyogcHRyX3B0aHJlYWRfbXV0ZXhfdW5sb2NrICovCiAgICBwdGhyZWFkX3NlbGYsICAgICAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfc2VsZiAqLwogICAgcHRocmVhZF9zZXRjYW5jZWxzdGF0ZSwgICAgICAgIC8qIHB0cl9wdGhyZWFkX3NldGNhbmNlbHN0YXRlICovCiAgICBwdGhyZWFkX3NldGNhbmNlbHR5cGUsICAgICAgICAgLyogcHRyX3B0aHJlYWRfc2V0Y2FuY2VsdHlwZSAqLwogICAgX19wdGhyZWFkX2RvX2V4aXQsICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2RvX2V4aXQgKi8KICAgIF9fcHRocmVhZF9jbGVhbnVwX3VwdG8sICAgICAgICAvKiBwdHJfcHRocmVhZF9jbGVhbnVwX3VwdG8gKi8KICAgIF9fcHRocmVhZF90aHJlYWRfc2VsZiwgICAgICAgICAvKiBwdHJfcHRocmVhZF90aHJlYWRfc2VsZiAqLwogICAgcHRocmVhZF9pbnRlcm5hbF90c2Rfc2V0LCAgICAgIC8qIHB0cl9wdGhyZWFkX2ludGVybmFsX3RzZF9zZXQgKi8KICAgIHB0aHJlYWRfaW50ZXJuYWxfdHNkX2dldCwgICAgICAvKiBwdHJfcHRocmVhZF9pbnRlcm5hbF90c2RfZ2V0ICovCiAgICBwdGhyZWFkX2ludGVybmFsX3RzZF9hZGRyZXNzLCAgLyogcHRyX3B0aHJlYWRfaW50ZXJuYWxfdHNkX2FkZHJlc3MgKi8KICAgIE5VTEwsICAgICAgICAgICAgICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9zaWdhY3Rpb24gKi8KICAgIE5VTEwsICAgICAgICAgICAgICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9zaWd3YWl0ICovCiAgICBOVUxMLCAgICAgICAgICAgICAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfcmFpc2UgKi8KICAgIF9fcHRocmVhZF9jb25kX3RpbWVkd2FpdCwgICAgICAvKiBwdHJfX19wdGhyZWFkX2NvbmRfdGltZWR3YWl0ICovCiAgICBfcHRocmVhZF9jbGVhbnVwX3B1c2gsICAgICAgICAgLyogcHRyX19wdGhyZWFkX2NsZWFudXBfcHVzaCAqLwogICAgX3B0aHJlYWRfY2xlYW51cF9wb3AgICAgICAgICAgIC8qIHB0cl9fcHRocmVhZF9jbGVhbnVwX3BvcCAqLwp9OwoKI2VuZGlmIC8qIEhBVkVfUFRIUkVBRF9IICYmIChfX0dMSUJDX18gfHwgX19GUkVFQlNEX18pICovCg==