LyoKICogcHRocmVhZCBlbXVsYXRpb24gYmFzZWQgb24ga2VybmVsIHRocmVhZHMKICoKICogV2UgY2FuJ3QgdXNlIHB0aHJlYWRzIGRpcmVjdGx5LCBzbyB3aHkgbm90IGxldCBsaWJjcwogKiB0aGF0IHdhbnQgcHRocmVhZHMgdXNlIFdpbmUncyBvd24gdGhyZWFkaW5nIGluc3RlYWQuLi4KICoKICogQ29weXJpZ2h0IDE5OTkgT3ZlIEvldmVuCiAqIENvcHlyaWdodCAyMDAzIEFsZXhhbmRyZSBKdWxsaWFyZAogKgogKiBUaGlzIGxpYnJhcnkgaXMgZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yCiAqIG1vZGlmeSBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBMZXNzZXIgR2VuZXJhbCBQdWJsaWMKICogTGljZW5zZSBhcyBwdWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyCiAqIHZlcnNpb24gMi4xIG9mIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLgogKgogKiBUaGlzIGxpYnJhcnkgaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwKICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKICogTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFLiAgU2VlIHRoZSBHTlUKICogTGVzc2VyIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KICoKICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIExlc3NlciBHZW5lcmFsIFB1YmxpYwogKiBMaWNlbnNlIGFsb25nIHdpdGggdGhpcyBsaWJyYXJ5OyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDUxIEZyYW5rbGluIFN0LCBGaWZ0aCBGbG9vciwgQm9zdG9uLCBNQSAwMjExMC0xMzAxLCBVU0EKICovCgojaW5jbHVkZSAiY29uZmlnLmgiCiNpbmNsdWRlICJ3aW5lL3BvcnQuaCIKCnN0cnVjdCBfcHRocmVhZF9jbGVhbnVwX2J1ZmZlcjsKCiNpbmNsdWRlIDxhc3NlcnQuaD4KI2luY2x1ZGUgPGVycm5vLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KI2luY2x1ZGUgPHNpZ25hbC5oPgojaW5jbHVkZSA8c2V0am1wLmg+CiNpZmRlZiBIQVZFX1VOSVNURF9ICiMgaW5jbHVkZSA8dW5pc3RkLmg+CiNlbmRpZgojaW5jbHVkZSA8c3RyaW5nLmg+CiNpbmNsdWRlIDxzeXMvdHlwZXMuaD4KI2lmZGVmIEhBVkVfU1lTX1NPQ0tFVF9ICiMgaW5jbHVkZSA8c3lzL3NvY2tldC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfU1lTX01NQU5fSAojaW5jbHVkZSA8c3lzL21tYW4uaD4KI2VuZGlmCiNpZmRlZiBIQVZFX05FVElORVRfSU5fSAojIGluY2x1ZGUgPG5ldGluZXQvaW4uaD4KI2VuZGlmCiNpZmRlZiBIQVZFX0FSUEFfTkFNRVNFUl9ICiMgaW5jbHVkZSA8YXJwYS9uYW1lc2VyLmg+CiNlbmRpZgojaWZkZWYgSEFWRV9SRVNPTFZfSAojIGluY2x1ZGUgPHJlc29sdi5oPgojZW5kaWYKI2lmZGVmIEhBVkVfVkFMR1JJTkRfTUVNQ0hFQ0tfSAojaW5jbHVkZSA8dmFsZ3JpbmQvbWVtY2hlY2suaD4KI2VuZGlmCiNpZmRlZiBIQVZFX1NZU19TWVNDQUxMX0gKIyBpbmNsdWRlIDxzeXMvc3lzY2FsbC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfU1lTX0xXUF9ICiMgaW5jbHVkZSA8c3lzL2x3cC5oPgojZW5kaWYKI2lmZGVmIEhBVkVfVUNPTlRFWFRfSAojIGluY2x1ZGUgPHVjb250ZXh0Lmg+CiNlbmRpZgojaWZkZWYgSEFWRV9TQ0hFRF9ICiNpbmNsdWRlIDxzY2hlZC5oPgojZW5kaWYKCiNpbmNsdWRlICJ3aW5lL2xpYnJhcnkuaCIKI2luY2x1ZGUgIndpbmUvcHRocmVhZC5oIgoKI2RlZmluZSBQX09VVFBVVChzdHVmZikgd3JpdGUoMixzdHVmZixzdHJsZW4oc3R1ZmYpKQoKI2RlZmluZSBQU1RSKHN0cikgX19BU01fTkFNRSgjc3RyKQoKc3RhdGljIHN0cnVjdCB3aW5lX3B0aHJlYWRfY2FsbGJhY2tzIGZ1bmNzOwoKLyogdGhyZWFkIGRlc2NyaXB0b3IgKi8KCiNkZWZpbmUgRklSU1RfS0VZIDAKI2RlZmluZSBNQVhfS0VZUyAxNiAvKiBsaWJjNiBkb2Vzbid0IHVzZSB0aGF0IG1hbnksIGJ1dC4uLiAqLwojZGVmaW5lIE1BWF9UU0QgIDE2CgpzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QKewogICAgY2hhciAgICAgICAgICAgICAgIGR1bW15WzIwNDhdOwogICAgaW50ICAgICAgICAgICAgICAgIHRocmVhZF9lcnJubzsKICAgIGludCAgICAgICAgICAgICAgICB0aHJlYWRfaF9lcnJubzsKICAgIGludCAgICAgICAgICAgICAgICBjYW5jZWxfc3RhdGU7CiAgICBpbnQgICAgICAgICAgICAgICAgY2FuY2VsX3R5cGU7CiAgICBzdHJ1Y3QgX19yZXNfc3RhdGUgcmVzX3N0YXRlOwogICAgY29uc3Qgdm9pZCAgICAgICAgKmtleV9kYXRhW01BWF9LRVlTXTsgIC8qIGZvciBub3JtYWwgcHRocmVhZCBrZXlzICovCiAgICBjb25zdCB2b2lkICAgICAgICAqdHNkX2RhdGFbTUFYX1RTRF07ICAgLyogZm9yIGxpYmMgaW50ZXJuYWwgdHNkIHZhcmlhYmxlcyAqLwp9OwoKdHlwZWRlZiBzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QgKnB0aHJlYWRfZGVzY3I7CgpzdGF0aWMgc3RydWN0IHB0aHJlYWRfZGVzY3Jfc3RydWN0IGluaXRpYWxfZGVzY3I7CgpwdGhyZWFkX2Rlc2NyIF9fcHRocmVhZF90aHJlYWRfc2VsZih2b2lkKQp7CiAgICBzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QgKmRlc2NyOwogICAgaWYgKCFmdW5jcy5wdHJfZ2V0X3RocmVhZF9kYXRhKSByZXR1cm4gJmluaXRpYWxfZGVzY3I7CiAgICBkZXNjciA9IGZ1bmNzLnB0cl9nZXRfdGhyZWFkX2RhdGEoKTsKICAgIGlmICghZGVzY3IpIHJldHVybiAmaW5pdGlhbF9kZXNjcjsKICAgIHJldHVybiBkZXNjcjsKfQoKc3RhdGljIGludCAoKmxpYmNfdXNlbG9jYWxlKShpbnQgc2V0KTsKc3RhdGljIGludCAqbGliY19tdWx0aXBsZV90aHJlYWRzOwoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBfX2Vycm5vX2xvY2F0aW9uL19fZXJyb3IvX19lcnJuby9fX19lcnJuby9fX3Rocl9lcnJubwogKgogKiBHZXQgdGhlIHBlci10aHJlYWQgZXJybm8gbG9jYXRpb24uCiAqLwppbnQgKl9fZXJybm9fbG9jYXRpb24odm9pZCkgICAgICAgICAgICAgICAgICAgICAgICAgICAgLyogTGludXggKi8KewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgcmV0dXJuICZkZXNjci0+dGhyZWFkX2Vycm5vOwp9CmludCAqX19lcnJvcih2b2lkKSAgICAgeyByZXR1cm4gX19lcnJub19sb2NhdGlvbigpOyB9ICAvKiBGcmVlQlNEICovCmludCAqX19lcnJubyh2b2lkKSAgICAgeyByZXR1cm4gX19lcnJub19sb2NhdGlvbigpOyB9ICAvKiBOZXRCU0QgKi8KaW50ICpfX19lcnJubyh2b2lkKSAgICB7IHJldHVybiBfX2Vycm5vX2xvY2F0aW9uKCk7IH0gIC8qIFNvbGFyaXMgKi8KaW50ICpfX3Rocl9lcnJubyh2b2lkKSB7IHJldHVybiBfX2Vycm5vX2xvY2F0aW9uKCk7IH0gIC8qIFVuaXhXYXJlICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIF9faF9lcnJub19sb2NhdGlvbgogKgogKiBHZXQgdGhlIHBlci10aHJlYWQgaF9lcnJubyBsb2NhdGlvbi4KICovCmludCAqX19oX2Vycm5vX2xvY2F0aW9uKHZvaWQpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIHJldHVybiAmZGVzY3ItPnRocmVhZF9oX2Vycm5vOwp9CgpzdHJ1Y3QgX19yZXNfc3RhdGUgKl9fcmVzX3N0YXRlKHZvaWQpCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIHJldHVybiAmZGVzY3ItPnJlc19zdGF0ZTsKfQoKc3RhdGljIGlubGluZSB2b2lkIHdyaXRlanVtcCggY29uc3QgY2hhciAqc3ltYm9sLCB2b2lkICpkZXN0ICkKewojaWYgZGVmaW5lZChfX0dMSUJDX18pICYmIGRlZmluZWQoX19pMzg2X18pCiAgICB1bnNpZ25lZCBjaGFyICphZGRyID0gd2luZV9kbHN5bSggUlRMRF9ORVhULCBzeW1ib2wsIE5VTEwsIDAgKTsKCiAgICBpZiAoIWFkZHIpIHJldHVybjsKCiAgICAvKiB3cml0ZSBhIHJlbGF0aXZlIGp1bXAgYXQgdGhlIGZ1bmN0aW9uIGFkZHJlc3MgKi8KICAgIG1wcm90ZWN0KCh2b2lkKikoKHVuc2lnbmVkIGludClhZGRyICYgfihnZXRwYWdlc2l6ZSgpLTEpKSwgNSwgUFJPVF9SRUFEfFBST1RfRVhFQ3xQUk9UX1dSSVRFKTsKICAgIGFkZHJbMF0gPSAweGU5OwogICAgKihpbnQgKikoYWRkcisxKSA9ICh1bnNpZ25lZCBjaGFyICopZGVzdCAtIChhZGRyICsgNSk7CiAgICBtcHJvdGVjdCgodm9pZCopKCh1bnNpZ25lZCBpbnQpYWRkciAmIH4oZ2V0cGFnZXNpemUoKS0xKSksIDUsIFBST1RfUkVBRHxQUk9UX0VYRUMpOwoKIyBpZmRlZiBIQVZFX1ZBTEdSSU5EX01FTUNIRUNLX0gKICAgIFZBTEdSSU5EX0RJU0NBUkRfVFJBTlNMQVRJT05TKCBhZGRyLCA1ICk7CiMgZW5kaWYKI2VuZGlmICAvKiBfX0dMSUJDX18gJiYgX19pMzg2X18gKi8KfQoKLyogdGVtcG9yYXJ5IHN0YWNrcyB1c2VkIG9uIHRocmVhZCBleGl0ICovCiNkZWZpbmUgVEVNUF9TVEFDS19TSVpFIDEwMjQKI2RlZmluZSBOQl9URU1QX1NUQUNLUyAgOApzdGF0aWMgY2hhciB0ZW1wX3N0YWNrc1tOQl9URU1QX1NUQUNLU11bVEVNUF9TVEFDS19TSVpFXTsKc3RhdGljIGludCBuZXh0X3RlbXBfc3RhY2s7ICAvKiBuZXh0IHRlbXAgc3RhY2sgdG8gdXNlICovCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGdldF90ZW1wX3N0YWNrCiAqCiAqIEdldCBhIHRlbXBvcmFyeSBzdGFjayBhZGRyZXNzIHRvIHJ1biB0aGUgdGhyZWFkIGV4aXQgY29kZSBvbi4KICovCmlubGluZSBzdGF0aWMgY2hhciAqZ2V0X3RlbXBfc3RhY2sodm9pZCkKewogICAgdW5zaWduZWQgaW50IG5leHQgPSBpbnRlcmxvY2tlZF94Y2hnX2FkZCggJm5leHRfdGVtcF9zdGFjaywgMSApOwogICAgcmV0dXJuIHRlbXBfc3RhY2tzW25leHQgJSBOQl9URU1QX1NUQUNLU10gKyBURU1QX1NUQUNLX1NJWkU7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGNsZWFudXBfdGhyZWFkCiAqCiAqIENsZWFudXAgdGhlIHJlbWFpbnMgb2YgYSB0aHJlYWQuIFJ1bnMgb24gYSB0ZW1wb3Jhcnkgc3RhY2suCiAqLwpzdGF0aWMgdm9pZCBjbGVhbnVwX3RocmVhZCggdm9pZCAqcHRyICkKewogICAgLyogY29weSB0aGUgaW5mbyBzdHJ1Y3R1cmUgc2luY2UgaXQgaXMgb24gdGhlIHN0YWNrIHdlIHdpbGwgZnJlZSAqLwogICAgc3RydWN0IHdpbmVfcHRocmVhZF90aHJlYWRfaW5mbyBpbmZvID0gKihzdHJ1Y3Qgd2luZV9wdGhyZWFkX3RocmVhZF9pbmZvICopcHRyOwogICAgd2luZV9sZHRfZnJlZV9mcyggaW5mby50ZWJfc2VsICk7CiAgICBpZiAoaW5mby5zdGFja19zaXplKSBtdW5tYXAoIGluZm8uc3RhY2tfYmFzZSwgaW5mby5zdGFja19zaXplICk7CiAgICBpZiAoaW5mby50ZWJfc2l6ZSkgbXVubWFwKCBpbmZvLnRlYl9iYXNlLCBpbmZvLnRlYl9zaXplICk7CiNpZmRlZiBIQVZFX19MV1BfQ1JFQVRFCiAgICBfbHdwX2V4aXQoKTsKI2VuZGlmCiAgICBfZXhpdCggaW5mby5leGl0X3N0YXR1cyApOwp9CgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBpbml0X3Byb2Nlc3MKICoKICogSW5pdGlhbGl6YXRpb24gZm9yIGEgbmV3bHkgY3JlYXRlZCBwcm9jZXNzLgogKi8Kc3RhdGljIHZvaWQgaW5pdF9wcm9jZXNzKCBjb25zdCBzdHJ1Y3Qgd2luZV9wdGhyZWFkX2NhbGxiYWNrcyAqY2FsbGJhY2tzLCBzaXplX3Qgc2l6ZSApCnsKICAgIG1lbWNweSggJmZ1bmNzLCBjYWxsYmFja3MsIG1pbiggc2l6ZSwgc2l6ZW9mKGZ1bmNzKSApKTsKICAgIGZ1bmNzLnB0cl9zZXRfdGhyZWFkX2RhdGEoICZpbml0aWFsX2Rlc2NyICk7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGluaXRfdGhyZWFkCiAqCiAqIEluaXRpYWxpemF0aW9uIGZvciBhIG5ld2x5IGNyZWF0ZWQgdGhyZWFkLgogKi8Kc3RhdGljIHZvaWQgaW5pdF90aHJlYWQoIHN0cnVjdCB3aW5lX3B0aHJlYWRfdGhyZWFkX2luZm8gKmluZm8gKQp7CiAgICBzdHJ1Y3QgcHRocmVhZF9kZXNjcl9zdHJ1Y3QgKmRlc2NyOwoKICAgIGlmIChmdW5jcy5wdHJfc2V0X3RocmVhZF9kYXRhKQogICAgewogICAgICAgIGRlc2NyID0gY2FsbG9jKCAxLCBzaXplb2YoKmRlc2NyKSApOwogICAgICAgIGZ1bmNzLnB0cl9zZXRfdGhyZWFkX2RhdGEoIGRlc2NyICk7CiAgICAgICAgaWYgKGxpYmNfbXVsdGlwbGVfdGhyZWFkcykgKmxpYmNfbXVsdGlwbGVfdGhyZWFkcyA9IDE7CiAgICB9CiAgICBlbHNlICAvKiBmaXJzdCB0aHJlYWQgKi8KICAgIHsKICAgICAgICBkZXNjciA9ICZpbml0aWFsX2Rlc2NyOwogICAgICAgIHdyaXRlanVtcCggIl9fZXJybm9fbG9jYXRpb24iLCBfX2Vycm5vX2xvY2F0aW9uICk7CiAgICAgICAgd3JpdGVqdW1wKCAiX19oX2Vycm5vX2xvY2F0aW9uIiwgX19oX2Vycm5vX2xvY2F0aW9uICk7CiAgICAgICAgd3JpdGVqdW1wKCAiX19yZXNfc3RhdGUiLCBfX3Jlc19zdGF0ZSApOwogICAgfQogICAgZGVzY3ItPmNhbmNlbF9zdGF0ZSA9IFBUSFJFQURfQ0FOQ0VMX0VOQUJMRTsKICAgIGRlc2NyLT5jYW5jZWxfdHlwZSAgPSBQVEhSRUFEX0NBTkNFTF9BU1lOQ0hST05PVVM7CiAgICBpZiAobGliY191c2Vsb2NhbGUpIGxpYmNfdXNlbG9jYWxlKCAtMSAvKkxDX0dMT0JBTF9MT0NBTEUqLyApOwp9CgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBjcmVhdGVfdGhyZWFkCiAqLwpzdGF0aWMgaW50IGNyZWF0ZV90aHJlYWQoIHN0cnVjdCB3aW5lX3B0aHJlYWRfdGhyZWFkX2luZm8gKmluZm8gKQp7CiAgICBpZiAoIWluZm8tPnN0YWNrX2Jhc2UpCiAgICB7CiAgICAgICAgaW5mby0+c3RhY2tfYmFzZSA9IHdpbmVfYW5vbl9tbWFwKCBOVUxMLCBpbmZvLT5zdGFja19zaXplLAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgUFJPVF9SRUFEIHwgUFJPVF9XUklURSB8IFBST1RfRVhFQywgMCApOwogICAgICAgIGlmIChpbmZvLT5zdGFja19iYXNlID09ICh2b2lkICopLTEpIHJldHVybiAtMTsKICAgIH0KI2lmZGVmIEhBVkVfQ0xPTkUKICAgIGlmIChjbG9uZSggKGludCAoKikodm9pZCAqKSlpbmZvLT5lbnRyeSwgKGNoYXIgKilpbmZvLT5zdGFja19iYXNlICsgaW5mby0+c3RhY2tfc2l6ZSwKICAgICAgICAgICAgICAgQ0xPTkVfVk0gfCBDTE9ORV9GUyB8IENMT05FX0ZJTEVTIHwgU0lHQ0hMRCwgaW5mbyApIDwgMCkKICAgICAgICByZXR1cm4gLTE7CiAgICByZXR1cm4gMDsKI2VsaWYgZGVmaW5lZChIQVZFX1JGT1JLKQogICAgewogICAgICAgIHZvaWQgKipzcCA9ICh2b2lkICoqKSgoY2hhciAqKWluZm8tPnN0YWNrX2Jhc2UgKyBpbmZvLT5zdGFja19zaXplKTsKICAgICAgICAqLS1zcCA9IGluZm87CiAgICAgICAgKi0tc3AgPSAwOwogICAgICAgICotLXNwID0gaW5mby0+ZW50cnk7CiAgICAgICAgX19hc21fXyBfX3ZvbGF0aWxlX18oCiAgICAgICAgICAgICJwdXNobCAlMjtcblx0IiAgICAgICAgICAgICAvKiBmbGFncyAqLwogICAgICAgICAgICAicHVzaGwgJDA7XG5cdCIgICAgICAgICAgICAgLyogMCA/ICovCiAgICAgICAgICAgICJtb3ZsICUxLCUlZWF4O1xuXHQiICAgICAgICAvKiBTWVNfcmZvcmsgKi8KICAgICAgICAgICAgIi5ieXRlIDB4OWE7IC5sb25nIDA7IC53b3JkIDc7XG5cdCIgLyogbGNhbGwgNzowLi4uIEZyZWVCU0Qgc3lzY2FsbCAqLwogICAgICAgICAgICAiY21wbCAkMCwgJSVlZHg7XG5cdCIKICAgICAgICAgICAgImplIDFmO1xuXHQiCiAgICAgICAgICAgICJtb3ZsICUwLCUlZXNwO1xuXHQiICAgICAgICAvKiBjaGlsZCAtPiBuZXcgdGhyZWFkICovCiAgICAgICAgICAgICJyZXQ7XG4iCiAgICAgICAgICAgICIxOlxuXHQiICAgICAgICAgICAgICAgICAgICAvKiBwYXJlbnQgLT4gY2FsbGVyIHRocmVhZCAqLwogICAgICAgICAgICAiYWRkbCAkOCwlJWVzcCIgOgogICAgICAgICAgICA6ICJyIiAoc3ApLCAiciIgKFNZU19yZm9yayksICJyIiAoUkZQUk9DIHwgUkZNRU0gfCBSRlRIUkVBRCkKICAgICAgICAgICAgOiAiZWF4IiwgImVkeCIpOwogICAgICAgIHJldHVybiAwOwogICAgfQojZWxpZiBkZWZpbmVkKEhBVkVfX0xXUF9DUkVBVEUpCiAgICB7CiAgICAgICAgdWNvbnRleHRfdCBjb250ZXh0OwogICAgICAgIF9sd3BfbWFrZWNvbnRleHQoICZjb250ZXh0LCAodm9pZCgqKSh2b2lkICopKWluZm8tPmVudHJ5LCBpbmZvLAogICAgICAgICAgICAgICAgICAgICAgICAgIE5VTEwsIGluZm8tPnN0YWNrX2Jhc2UsIGluZm8tPnN0YWNrX3NpemUgKTsKICAgICAgICBpZiAoIF9sd3BfY3JlYXRlKCAmY29udGV4dCwgMCwgTlVMTCApICkKICAgICAgICAgICAgcmV0dXJuIC0xOwogICAgICAgIHJldHVybiAwOwogICAgfQojZW5kaWYKICAgIHJldHVybiAtMTsKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgaW5pdF9jdXJyZW50X3RlYgogKgogKiBTZXQgdGhlIGN1cnJlbnQgVEVCIGZvciBhIG5ldyB0aHJlYWQuCiAqLwpzdGF0aWMgdm9pZCBpbml0X2N1cnJlbnRfdGViKCBzdHJ1Y3Qgd2luZV9wdGhyZWFkX3RocmVhZF9pbmZvICppbmZvICkKewojaWZkZWYgX19pMzg2X18KICAgIC8qIE9uIHRoZSBpMzg2LCB0aGUgY3VycmVudCB0aHJlYWQgaXMgaW4gdGhlICVmcyByZWdpc3RlciAqLwogICAgTERUX0VOVFJZIGZzX2VudHJ5OwoKICAgIHdpbmVfbGR0X3NldF9iYXNlKCAmZnNfZW50cnksIGluZm8tPnRlYl9iYXNlICk7CiAgICB3aW5lX2xkdF9zZXRfbGltaXQoICZmc19lbnRyeSwgaW5mby0+dGViX3NpemUgLSAxICk7CiAgICB3aW5lX2xkdF9zZXRfZmxhZ3MoICZmc19lbnRyeSwgV0lORV9MRFRfRkxBR1NfREFUQXxXSU5FX0xEVF9GTEFHU18zMkJJVCApOwogICAgd2luZV9sZHRfaW5pdF9mcyggaW5mby0+dGViX3NlbCwgJmZzX2VudHJ5ICk7CiNlbGlmIGRlZmluZWQoSEFWRV9fTFdQX0NSRUFURSkKICAgIC8qIE9uIG5vbi1pMzg2IFNvbGFyaXMsIHdlIHVzZSB0aGUgTFdQIHByaXZhdGUgcG9pbnRlciAqLwogICAgX2x3cF9zZXRwcml2YXRlKCBpbmZvLT50ZWJfYmFzZSApOwojZWxpZiBkZWZpbmVkKF9fcG93ZXJwY19fKQogICAgLyogT24gUG93ZXJQQywgdGhlIGN1cnJlbnQgVEVCIGlzIGluIHRoZSBncHIxMyByZWdpc3RlciAqLwojIGlmZGVmIF9fQVBQTEVfXwogICAgX19hc21fXyBfX3ZvbGF0aWxlX18oIm1yIHIxMywgJTAiIDogOiAiciIgKGluZm8tPnRlYl9iYXNlKSk7CiMgZWxzZQogICAgX19hc21fXyBfX3ZvbGF0aWxlX18oIm1yIDIsICUwIiA6IDogInIiIChpbmZvLT50ZWJfYmFzZSkpOwojIGVuZGlmCiNlbGlmIGRlZmluZWQoX19BTFBIQV9fKQogICAgLyogRklYTUU6IE9uIEFscGhhLCB0aGUgY3VycmVudCBURUIgaXMgbm90IGFjY2Vzc2libGUgdG8gdXNlci1zcGFjZSAqLwovKiAgICBfX2FzbV9fIF9fdm9sYXRpbGVfXygpOyovCiNlbHNlCiMgZXJyb3IgWW91IG11c3QgaW1wbGVtZW50IGluaXRfY3VycmVudF90ZWIgZm9yIHlvdXIgcGxhdGZvcm0KI2VuZGlmCgogICAgLyogc2V0IHBpZCBhbmQgdGlkICovCiAgICBpbmZvLT5waWQgPSBnZXRwaWQoKTsKI2lmZGVmIEhBVkVfX0xXUF9TRUxGCiAgICBpbmZvLT50aWQgPSBfbHdwX3NlbGYoKTsKI2Vsc2UKICAgIGluZm8tPnRpZCA9IC0xOwojZW5kaWYKfQoKCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgZ2V0X2N1cnJlbnRfdGViCiAqLwpzdGF0aWMgdm9pZCAqZ2V0X2N1cnJlbnRfdGViKHZvaWQpCnsKICAgIHZvaWQgKnJldDsKCiNpZmRlZiBfX2kzODZfXwogICAgX19hc21fXyggIi5ieXRlIDB4NjRcblx0bW92bCAweDE4LCUwIiA6ICI9ciIgKHJldCkgKTsKI2VsaWYgZGVmaW5lZChIQVZFX19MV1BfQ1JFQVRFKQogICAgcmV0ID0gX2x3cF9nZXRwcml2YXRlKCk7CiNlbGlmIGRlZmluZWQoX19wb3dlcnBjX18pCiMgaWZkZWYgX19BUFBMRV9fCiAgICBfX2FzbV9fKCAibXIgJTAscjEzIiA6ICI9ciIgKHJldCkgKTsKIyBlbHNlCiAgICBfX2FzbV9fKCAibXIgJTAsMiIgOiAiPXIiIChyZXQpICk7CiMgZW5kaWYKI2VsaWYgZGVmaW5lZChfX0FMUEhBX18pCiAgICAvKiAweDAwYWIgaXMgdGhlIFBBTCBvcGNvZGUgZm9yIHJkdGViICovCiAgICBfX2FzbV9fKCAibGRhICQzMCw4KCQzMClcblx0IgogICAgICAgICAgICAgInN0cSAkMCwwKCQzMClcblx0IgogICAgICAgICAgICAgImNhbGxfcGFsIDB4MDBhYlxuXHQiCiAgICAgICAgICAgICAibW92ICQwLCUwXG5cdCIKICAgICAgICAgICAgICJsZHEgJDAsMCgkMzApXG5cdCIKICAgICAgICAgICAgICJsZGEgJDMwLC04KCQzMCkiIDogIj1yIiAocmV0KSApOwojZWxzZQojIGVycm9yIGdldF9jdXJyZW50X3RlYiBub3QgZGVmaW5lZCBmb3IgdGhpcyBhcmNoaXRlY3R1cmUKI2VuZGlmICAvKiBfX2kzODZfXyAqLwoKICAgIHJldHVybiByZXQ7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIGV4aXRfdGhyZWFkCiAqLwpzdGF0aWMgdm9pZCBERUNMU1BFQ19OT1JFVFVSTiBleGl0X3RocmVhZCggc3RydWN0IHdpbmVfcHRocmVhZF90aHJlYWRfaW5mbyAqaW5mbyApCnsKICAgIHdpbmVfc3dpdGNoX3RvX3N0YWNrKCBjbGVhbnVwX3RocmVhZCwgaW5mbywgZ2V0X3RlbXBfc3RhY2soKSApOwp9CgoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqICAgICAgICAgICBhYm9ydF90aHJlYWQKICovCnN0YXRpYyB2b2lkIERFQ0xTUEVDX05PUkVUVVJOIGFib3J0X3RocmVhZCggbG9uZyBzdGF0dXMgKQp7CiNpZmRlZiBIQVZFX19MV1BfQ1JFQVRFCiAgICBfbHdwX2V4aXQoKTsKI2VuZGlmCiAgICBfZXhpdCggc3RhdHVzICk7Cn0KCgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICogICAgICAgICAgIHB0aHJlYWRfZnVuY3Rpb25zCiAqLwpjb25zdCBzdHJ1Y3Qgd2luZV9wdGhyZWFkX2Z1bmN0aW9ucyBwdGhyZWFkX2Z1bmN0aW9ucyA9CnsKICAgIGluaXRfcHJvY2VzcywKICAgIGluaXRfdGhyZWFkLAogICAgY3JlYXRlX3RocmVhZCwKICAgIGluaXRfY3VycmVudF90ZWIsCiAgICBnZXRfY3VycmVudF90ZWIsCiAgICBleGl0X3RocmVhZCwKICAgIGFib3J0X3RocmVhZCwKICAgIHNpZ3Byb2NtYXNrCn07CgoKLyogQ3VycmVudGx5IHRoaXMgcHJvYmFibHkgd29ya3Mgb25seSBmb3IgZ2xpYmMyLAogKiB3aGljaCBjaGVja3MgZm9yIHRoZSBwcmVzZW5jZSBvZiBkb3VibGUtdW5kZXJzY29yZS1wcmVwZW5kZWQKICogcHRocmVhZCBwcmltaXRpdmVzLCBhbmQgdXNlIHRoZW0gaWYgYXZhaWxhYmxlLgogKiBJZiB0aGV5IGFyZSBub3QgYXZhaWxhYmxlLCB0aGUgbGliYyBkZWZhdWx0cyB0bwogKiBub24tdGhyZWFkc2FmZSBvcGVyYXRpb24gKG5vdCBnb29kKS4gKi8KCiNpZiBkZWZpbmVkKEhBVkVfUFRIUkVBRF9IKSAmJiAoZGVmaW5lZChfX0dMSUJDX18pIHx8IGRlZmluZWQoX19GcmVlQlNEX18pKQoKLyogYWRhcHQgYXMgbmVjZXNzYXJ5IChhIGNvbnN0cnVjdCBsaWtlIHRoaXMgaXMgdXNlZCBpbiBnbGliYyBzb3VyY2VzKSAqLwojZGVmaW5lIHN0cm9uZ19hbGlhcyhvcmlnLCBhbGlhcykgXAogYXNtKCIuZ2xvYmwgIiBQU1RSKGFsaWFzKSAiXG4iIFwKICAgICAiXHQuc2V0ICIgUFNUUihhbGlhcykgIiwiIFBTVFIob3JpZykpCgpzdHJ1Y3QgZm9ya19ibG9jazsKCi8qIHB0aHJlYWQgZnVuY3Rpb25zIHJlZGlyZWN0aW9uICovCgpzdHJ1Y3QgcHRocmVhZF9mdW5jdGlvbnMKewogIHBpZF90ICgqcHRyX3B0aHJlYWRfZm9yaykgKHN0cnVjdCBmb3JrX2Jsb2NrICopOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfZGVzdHJveSkgKHB0aHJlYWRfYXR0cl90ICopOwogIGludCAoKnB0cl9fX3B0aHJlYWRfYXR0cl9pbml0XzJfMCkgKHB0aHJlYWRfYXR0cl90ICopOwogIGludCAoKnB0cl9fX3B0aHJlYWRfYXR0cl9pbml0XzJfMSkgKHB0aHJlYWRfYXR0cl90ICopOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfZ2V0ZGV0YWNoc3RhdGUpIChjb25zdCBwdGhyZWFkX2F0dHJfdCAqLCBpbnQgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9zZXRkZXRhY2hzdGF0ZSkgKHB0aHJlYWRfYXR0cl90ICosIGludCk7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9nZXRpbmhlcml0c2NoZWQpIChjb25zdCBwdGhyZWFkX2F0dHJfdCAqLCBpbnQgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9zZXRpbmhlcml0c2NoZWQpIChwdGhyZWFkX2F0dHJfdCAqLCBpbnQpOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfZ2V0c2NoZWRwYXJhbSkgKGNvbnN0IHB0aHJlYWRfYXR0cl90ICosIHN0cnVjdCBzY2hlZF9wYXJhbSAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX3NldHNjaGVkcGFyYW0pIChwdGhyZWFkX2F0dHJfdCAqLCBjb25zdCBzdHJ1Y3Qgc2NoZWRfcGFyYW0gKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfYXR0cl9nZXRzY2hlZHBvbGljeSkgKGNvbnN0IHB0aHJlYWRfYXR0cl90ICosIGludCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX3NldHNjaGVkcG9saWN5KSAocHRocmVhZF9hdHRyX3QgKiwgaW50KTsKICBpbnQgKCpwdHJfcHRocmVhZF9hdHRyX2dldHNjb3BlKSAoY29uc3QgcHRocmVhZF9hdHRyX3QgKiwgaW50ICopOwogIGludCAoKnB0cl9wdGhyZWFkX2F0dHJfc2V0c2NvcGUpIChwdGhyZWFkX2F0dHJfdCAqLCBpbnQpOwogIGludCAoKnB0cl9wdGhyZWFkX2NvbmRhdHRyX2Rlc3Ryb3kpIChwdGhyZWFkX2NvbmRhdHRyX3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfY29uZGF0dHJfaW5pdCkgKHB0aHJlYWRfY29uZGF0dHJfdCAqKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfYnJvYWRjYXN0KSAocHRocmVhZF9jb25kX3QgKik7CiAgaW50ICgqcHRyX19fcHRocmVhZF9jb25kX2Rlc3Ryb3kpIChwdGhyZWFkX2NvbmRfdCAqKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfaW5pdCkgKHB0aHJlYWRfY29uZF90ICosIGNvbnN0IHB0aHJlYWRfY29uZGF0dHJfdCAqKTsKICBpbnQgKCpwdHJfX19wdGhyZWFkX2NvbmRfc2lnbmFsKSAocHRocmVhZF9jb25kX3QgKik7CiAgaW50ICgqcHRyX19fcHRocmVhZF9jb25kX3dhaXQpIChwdGhyZWFkX2NvbmRfdCAqLCBwdGhyZWFkX211dGV4X3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfZXF1YWwpIChwdGhyZWFkX3QsIHB0aHJlYWRfdCk7CiAgdm9pZCAoKnB0cl9fX3B0aHJlYWRfZXhpdCkgKHZvaWQgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfZ2V0c2NoZWRwYXJhbSkgKHB0aHJlYWRfdCwgaW50ICosIHN0cnVjdCBzY2hlZF9wYXJhbSAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9zZXRzY2hlZHBhcmFtKSAocHRocmVhZF90LCBpbnQsIGNvbnN0IHN0cnVjdCBzY2hlZF9wYXJhbSAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9tdXRleF9kZXN0cm95KSAocHRocmVhZF9tdXRleF90ICopOwogIGludCAoKnB0cl9wdGhyZWFkX211dGV4X2luaXQpIChwdGhyZWFkX211dGV4X3QgKiwgY29uc3QgcHRocmVhZF9tdXRleGF0dHJfdCAqKTsKICBpbnQgKCpwdHJfcHRocmVhZF9tdXRleF9sb2NrKSAocHRocmVhZF9tdXRleF90ICopOwogIGludCAoKnB0cl9wdGhyZWFkX211dGV4X3RyeWxvY2spIChwdGhyZWFkX211dGV4X3QgKik7CiAgaW50ICgqcHRyX3B0aHJlYWRfbXV0ZXhfdW5sb2NrKSAocHRocmVhZF9tdXRleF90ICopOwogIHB0aHJlYWRfdCAoKnB0cl9wdGhyZWFkX3NlbGYpICh2b2lkKTsKICBpbnQgKCpwdHJfcHRocmVhZF9zZXRjYW5jZWxzdGF0ZSkgKGludCwgaW50ICopOwogIGludCAoKnB0cl9wdGhyZWFkX3NldGNhbmNlbHR5cGUpIChpbnQsIGludCAqKTsKICB2b2lkICgqcHRyX3B0aHJlYWRfZG9fZXhpdCkgKHZvaWQgKnJldHZhbCwgY2hhciAqY3VycmVudGZyYW1lKTsKICB2b2lkICgqcHRyX3B0aHJlYWRfY2xlYW51cF91cHRvKSAoam1wX2J1ZiB0YXJnZXQsIGNoYXIgKnRhcmdldGZyYW1lKTsKICBwdGhyZWFkX2Rlc2NyICgqcHRyX3B0aHJlYWRfdGhyZWFkX3NlbGYpICh2b2lkKTsKICBpbnQgKCpwdHJfcHRocmVhZF9pbnRlcm5hbF90c2Rfc2V0KSAoaW50IGtleSwgY29uc3Qgdm9pZCAqcG9pbnRlcik7CiAgdm9pZCAqICgqcHRyX3B0aHJlYWRfaW50ZXJuYWxfdHNkX2dldCkgKGludCBrZXkpOwogIHZvaWQgKiogX19hdHRyaWJ1dGVfXyAoKF9fY29uc3RfXykpICgqcHRyX3B0aHJlYWRfaW50ZXJuYWxfdHNkX2FkZHJlc3MpIChpbnQga2V5KTsKICBpbnQgKCpwdHJfcHRocmVhZF9zaWdhY3Rpb24pIChpbnQgc2lnLCBjb25zdCBzdHJ1Y3Qgc2lnYWN0aW9uICogYWN0LCBzdHJ1Y3Qgc2lnYWN0aW9uICpvYWN0KTsKICBpbnQgKCpwdHJfcHRocmVhZF9zaWd3YWl0KSAoY29uc3Qgc2lnc2V0X3QgKnNldCwgaW50ICpzaWcpOwogIGludCAoKnB0cl9wdGhyZWFkX3JhaXNlKSAoaW50IHNpZyk7CiAgaW50ICgqcHRyX19fcHRocmVhZF9jb25kX3RpbWVkd2FpdCkgKHB0aHJlYWRfY29uZF90ICosIHB0aHJlYWRfbXV0ZXhfdCAqLCBjb25zdCBzdHJ1Y3QgdGltZXNwZWMgKik7CiAgdm9pZCAoKnB0cl9fcHRocmVhZF9jbGVhbnVwX3B1c2gpIChzdHJ1Y3QgX3B0aHJlYWRfY2xlYW51cF9idWZmZXIgKiBidWZmZXIsIHZvaWQgKCpyb3V0aW5lKSh2b2lkICopLCB2b2lkICogYXJnKTsKICB2b2lkICgqcHRyX19wdGhyZWFkX2NsZWFudXBfcG9wKSAoc3RydWN0IF9wdGhyZWFkX2NsZWFudXBfYnVmZmVyICogYnVmZmVyLCBpbnQgZXhlY3V0ZSk7Cn07CgpzdGF0aWMgcGlkX3QgKCpsaWJjX2ZvcmspKHZvaWQpOwpzdGF0aWMgaW50ICgqbGliY19zaWdhY3Rpb24pKGludCBzaWdudW0sIGNvbnN0IHN0cnVjdCBzaWdhY3Rpb24gKmFjdCwgc3RydWN0IHNpZ2FjdGlvbiAqb2xkYWN0KTsKc3RhdGljIGludCAqKCpsaWJjX3B0aHJlYWRfaW5pdCkoIGNvbnN0IHN0cnVjdCBwdGhyZWFkX2Z1bmN0aW9ucyAqZnVuY3MgKTsKCnN0YXRpYyBzdHJ1Y3QgcHRocmVhZF9mdW5jdGlvbnMgbGliY19wdGhyZWFkX2Z1bmN0aW9uczsKCnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfdGhyZWFkX3NlbGYsIHB0aHJlYWRfdGhyZWFkX3NlbGYpOwoKLyogcmVkZWZpbmUgdGhpcyB0byBwcmV2ZW50IGxpYnB0aHJlYWQgZnJvbSBvdmVycmlkaW5nIG91ciBmdW5jdGlvbiBwb2ludGVycyAqLwppbnQgKl9fbGliY19wdGhyZWFkX2luaXQoIGNvbnN0IHN0cnVjdCBwdGhyZWFkX2Z1bmN0aW9ucyAqZnVuY3MgKQp7CiAgICByZXR1cm4gbGliY19tdWx0aXBsZV90aHJlYWRzOwp9Cgp0eXBlZGVmIHN0cnVjdCBfd2luZV9jbGVhbnVwIHsKICB2b2lkICgqcm91dGluZSkodm9pZCAqKTsKICB2b2lkICphcmc7Cn0gKndpbmVfY2xlYW51cDsKCmludCBwdGhyZWFkX2NyZWF0ZShwdGhyZWFkX3QqIHRocmVhZCwgY29uc3QgcHRocmVhZF9hdHRyX3QqIGF0dHIsIHZvaWQqCiAgICAgICAgKCpzdGFydF9yb3V0aW5lKSh2b2lkICopLCB2b2lkKiBhcmcpCnsKICAgIGFzc2VydCggZnVuY3MucHRyX3B0aHJlYWRfY3JlYXRlICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfY3JlYXRlKCB0aHJlYWQsIGF0dHIsIHN0YXJ0X3JvdXRpbmUsIGFyZyApOwp9CgppbnQgcHRocmVhZF9jYW5jZWwocHRocmVhZF90IHRocmVhZCkKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9jYW5jZWwgKTsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jYW5jZWwoIHRocmVhZCApOwp9CgppbnQgcHRocmVhZF9qb2luKHB0aHJlYWRfdCB0aHJlYWQsIHZvaWQgKip2YWx1ZV9wdHIpCnsKICAgIGFzc2VydCggZnVuY3MucHRyX3B0aHJlYWRfam9pbiApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2pvaW4oIHRocmVhZCwgdmFsdWVfcHRyICk7Cn0KCmludCBwdGhyZWFkX2RldGFjaChwdGhyZWFkX3QgdGhyZWFkKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX2RldGFjaCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2RldGFjaCggdGhyZWFkICk7Cn0KCi8qIEZJWE1FOiB3ZSBoYXZlIG5vIGVxdWl2YWxlbnRzIGluIHdpbjMyIGZvciB0aGUgcG9saWN5cyAqLwovKiBzbyBqdXN0IGtlZXAgdGhpcyBhcyBhIHN0dWIgKi8KaW50IHB0aHJlYWRfYXR0cl9zZXRzY2hlZHBvbGljeShwdGhyZWFkX2F0dHJfdCAqYXR0ciwgaW50IHBvbGljeSkKewogIFBfT1VUUFVUKCJGSVhNRTpwdGhyZWFkX2F0dHJfc2V0c2NoZWRwb2xpY3lcbiIpOwogIHJldHVybiAwOwp9CgovKiBGSVhNRTogbm8gd2luMzIgZXF1aXZhbGVudCBmb3Igc2NvcGUgKi8KaW50IHB0aHJlYWRfYXR0cl9zZXRzY29wZShwdGhyZWFkX2F0dHJfdCAqYXR0ciwgaW50IHNjb3BlKQp7CiAgUF9PVVRQVVQoIkZJWE1FOnB0aHJlYWRfYXR0cl9zZXRzY29wZVxuIik7CiAgcmV0dXJuIDA7IC8qIHJldHVybiBzdWNjZXNzICovCn0KCi8qIEZJWE1FOiBubyB3aW4zMiBlcXVpdmFsZW50IGZvciBzY2hlZHVsZSBwYXJhbSAqLwppbnQgcHRocmVhZF9hdHRyX3NldHNjaGVkcGFyYW0ocHRocmVhZF9hdHRyX3QgKmF0dHIsCiAgICBjb25zdCBzdHJ1Y3Qgc2NoZWRfcGFyYW0gKnBhcmFtKQp7CiAgUF9PVVRQVVQoIkZJWE1FOnB0aHJlYWRfYXR0cl9zZXRzY2hlZHBhcmFtXG4iKTsKICByZXR1cm4gMDsgLyogcmV0dXJuIHN1Y2Nlc3MgKi8KfQoKLyogRklYTUUgKi8KaW50IHB0aHJlYWRfYXR0cl9zZXRzdGFjayhwdGhyZWFkX2F0dHJfdCAqYXR0ciwgdm9pZCAqYWRkciwgc2l6ZV90IHNpemUpCnsKICByZXR1cm4gMDsgLyogcmV0dXJuIHN1Y2Nlc3MgKi8KfQoKaW50IF9fcHRocmVhZF9vbmNlKHB0aHJlYWRfb25jZV90ICpvbmNlX2NvbnRyb2wsIHZvaWQgKCppbml0X3JvdXRpbmUpKHZvaWQpKQp7CiAgICBzdGF0aWMgcHRocmVhZF9vbmNlX3QgdGhlX29uY2UgPSBQVEhSRUFEX09OQ0VfSU5JVDsKICAgIGludCBvbmNlX25vdzsKCiAgICBtZW1jcHkoJm9uY2Vfbm93LCZ0aGVfb25jZSxzaXplb2Yob25jZV9ub3cpKTsKICAgIGlmIChpbnRlcmxvY2tlZF9jbXB4Y2hnKChpbnQqKW9uY2VfY29udHJvbCwgb25jZV9ub3crMSwgb25jZV9ub3cpID09IG9uY2Vfbm93KQogICAgICAgICgqaW5pdF9yb3V0aW5lKSgpOwogICAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9vbmNlLCBwdGhyZWFkX29uY2UpOwoKdm9pZCBfX3B0aHJlYWRfa2lsbF9vdGhlcl90aHJlYWRzX25wKHZvaWQpCnsKICAgIC8qIHdlIGRvbid0IG5lZWQgdG8gZG8gYW55dGhpbmcgaGVyZSAqLwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfa2lsbF9vdGhlcl90aHJlYWRzX25wLCBwdGhyZWFkX2tpbGxfb3RoZXJfdGhyZWFkc19ucCk7CgovKioqKiogYXRmb3JrICoqKioqLwoKI2RlZmluZSBNQVhfQVRGT1JLIDggIC8qIGxpYmMgZG9lc24ndCBuZWVkIHRoYXQgbWFueSBhbnl3YXkgKi8KCnN0YXRpYyBwdGhyZWFkX211dGV4X3QgYXRmb3JrX211dGV4ID0gUFRIUkVBRF9NVVRFWF9JTklUSUFMSVpFUjsKCnR5cGVkZWYgdm9pZCAoKmF0Zm9ya19oYW5kbGVyKSh2b2lkKTsKc3RhdGljIGF0Zm9ya19oYW5kbGVyIGF0Zm9ya19wcmVwYXJlW01BWF9BVEZPUktdOwpzdGF0aWMgYXRmb3JrX2hhbmRsZXIgYXRmb3JrX3BhcmVudFtNQVhfQVRGT1JLXTsKc3RhdGljIGF0Zm9ya19oYW5kbGVyIGF0Zm9ya19jaGlsZFtNQVhfQVRGT1JLXTsKc3RhdGljIGludCBhdGZvcmtfY291bnQ7CgppbnQgX19wdGhyZWFkX2F0Zm9yayh2b2lkICgqcHJlcGFyZSkodm9pZCksIHZvaWQgKCpwYXJlbnQpKHZvaWQpLCB2b2lkICgqY2hpbGQpKHZvaWQpKQp7CiAgICBwdGhyZWFkX211dGV4X2xvY2soICZhdGZvcmtfbXV0ZXggKTsKICAgIGFzc2VydCggYXRmb3JrX2NvdW50IDwgTUFYX0FURk9SSyApOwogICAgYXRmb3JrX3ByZXBhcmVbYXRmb3JrX2NvdW50XSA9IHByZXBhcmU7CiAgICBhdGZvcmtfcGFyZW50W2F0Zm9ya19jb3VudF0gPSBwYXJlbnQ7CiAgICBhdGZvcmtfY2hpbGRbYXRmb3JrX2NvdW50XSA9IGNoaWxkOwogICAgYXRmb3JrX2NvdW50Kys7CiAgICBwdGhyZWFkX211dGV4X3VubG9jayggJmF0Zm9ya19tdXRleCApOwogICAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9hdGZvcmssIHB0aHJlYWRfYXRmb3JrKTsKCnBpZF90IF9fZm9yayh2b2lkKQp7CiAgICBwaWRfdCBwaWQ7CiAgICBpbnQgaTsKCiAgICBpZiAoIWxpYmNfZm9yaykKICAgIHsKICAgICAgICBsaWJjX2ZvcmsgPSB3aW5lX2Rsc3ltKCBSVExEX05FWFQsICJmb3JrIiwgTlVMTCwgMCApOwogICAgICAgIGFzc2VydCggbGliY19mb3JrICk7CiAgICB9CiAgICBwdGhyZWFkX211dGV4X2xvY2soICZhdGZvcmtfbXV0ZXggKTsKICAgIC8qIHByZXBhcmUgaGFuZGxlcnMgYXJlIGNhbGxlZCBpbiByZXZlcnNlIGluc2VydGlvbiBvcmRlciAqLwogICAgZm9yIChpID0gYXRmb3JrX2NvdW50IC0gMTsgaSA+PSAwOyBpLS0pIGlmIChhdGZvcmtfcHJlcGFyZVtpXSkgYXRmb3JrX3ByZXBhcmVbaV0oKTsKICAgIGlmICghKHBpZCA9IGxpYmNfZm9yaygpKSkKICAgIHsKICAgICAgICBwdGhyZWFkX211dGV4X2luaXQoICZhdGZvcmtfbXV0ZXgsIE5VTEwgKTsKICAgICAgICBmb3IgKGkgPSAwOyBpIDwgYXRmb3JrX2NvdW50OyBpKyspIGlmIChhdGZvcmtfY2hpbGRbaV0pIGF0Zm9ya19jaGlsZFtpXSgpOwogICAgfQogICAgZWxzZQogICAgewogICAgICAgIGZvciAoaSA9IDA7IGkgPCBhdGZvcmtfY291bnQ7IGkrKykgaWYgKGF0Zm9ya19wYXJlbnRbaV0pIGF0Zm9ya19wYXJlbnRbaV0oKTsKICAgICAgICBwdGhyZWFkX211dGV4X3VubG9jayggJmF0Zm9ya19tdXRleCApOwogICAgfQogICAgcmV0dXJuIHBpZDsKfQpzdHJvbmdfYWxpYXMoX19mb3JrLCBmb3JrKTsKCi8qKioqKiBNVVRFWEVTICoqKioqLwoKaW50IF9fcHRocmVhZF9tdXRleF9pbml0KHB0aHJlYWRfbXV0ZXhfdCAqbXV0ZXgsIGNvbnN0IHB0aHJlYWRfbXV0ZXhhdHRyX3QgKm11dGV4YXR0cikKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9tdXRleF9pbml0KSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9tdXRleF9pbml0KCBtdXRleCwgbXV0ZXhhdHRyICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleF9pbml0LCBwdGhyZWFkX211dGV4X2luaXQpOwoKaW50IF9fcHRocmVhZF9tdXRleF9sb2NrKHB0aHJlYWRfbXV0ZXhfdCAqbXV0ZXgpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfbXV0ZXhfbG9jaykgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfbXV0ZXhfbG9jayggbXV0ZXggKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX211dGV4X2xvY2ssIHB0aHJlYWRfbXV0ZXhfbG9jayk7CgppbnQgX19wdGhyZWFkX211dGV4X3RyeWxvY2socHRocmVhZF9tdXRleF90ICptdXRleCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9tdXRleF90cnlsb2NrKSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9tdXRleF90cnlsb2NrKCBtdXRleCApOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhfdHJ5bG9jaywgcHRocmVhZF9tdXRleF90cnlsb2NrKTsKCmludCBfX3B0aHJlYWRfbXV0ZXhfdW5sb2NrKHB0aHJlYWRfbXV0ZXhfdCAqbXV0ZXgpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfbXV0ZXhfdW5sb2NrKSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9tdXRleF91bmxvY2soIG11dGV4ICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleF91bmxvY2ssIHB0aHJlYWRfbXV0ZXhfdW5sb2NrKTsKCmludCBfX3B0aHJlYWRfbXV0ZXhfZGVzdHJveShwdGhyZWFkX211dGV4X3QgKm11dGV4KQp7CiAgICBpZiAoIWZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X2Rlc3Ryb3kpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX211dGV4X2Rlc3Ryb3koIG11dGV4ICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9tdXRleF9kZXN0cm95LCBwdGhyZWFkX211dGV4X2Rlc3Ryb3kpOwoKCi8qKioqKiBNVVRFWCBBVFRSSUJVVEVTICoqKioqLwovKiBqdXN0IGR1bW1pZXMsIHNpbmNlIGNyaXRpY2FsIHNlY3Rpb25zIGFyZSBhbHdheXMgcmVjdXJzaXZlICovCgppbnQgX19wdGhyZWFkX211dGV4YXR0cl9pbml0KHB0aHJlYWRfbXV0ZXhhdHRyX3QgKmF0dHIpCnsKICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX211dGV4YXR0cl9pbml0LCBwdGhyZWFkX211dGV4YXR0cl9pbml0KTsKCmludCBfX3B0aHJlYWRfbXV0ZXhhdHRyX2Rlc3Ryb3kocHRocmVhZF9tdXRleGF0dHJfdCAqYXR0cikKewogIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhhdHRyX2Rlc3Ryb3ksIHB0aHJlYWRfbXV0ZXhhdHRyX2Rlc3Ryb3kpOwoKaW50IF9fcHRocmVhZF9tdXRleGF0dHJfc2V0a2luZF9ucChwdGhyZWFkX211dGV4YXR0cl90ICphdHRyLCBpbnQga2luZCkKewogIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhhdHRyX3NldGtpbmRfbnAsIHB0aHJlYWRfbXV0ZXhhdHRyX3NldGtpbmRfbnApOwoKaW50IF9fcHRocmVhZF9tdXRleGF0dHJfZ2V0a2luZF9ucChwdGhyZWFkX211dGV4YXR0cl90ICphdHRyLCBpbnQgKmtpbmQpCnsKICAqa2luZCA9IFBUSFJFQURfTVVURVhfUkVDVVJTSVZFOwogIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhhdHRyX2dldGtpbmRfbnAsIHB0aHJlYWRfbXV0ZXhhdHRyX2dldGtpbmRfbnApOwoKaW50IF9fcHRocmVhZF9tdXRleGF0dHJfc2V0dHlwZShwdGhyZWFkX211dGV4YXR0cl90ICphdHRyLCBpbnQga2luZCkKewogIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhhdHRyX3NldHR5cGUsIHB0aHJlYWRfbXV0ZXhhdHRyX3NldHR5cGUpOwoKaW50IF9fcHRocmVhZF9tdXRleGF0dHJfZ2V0dHlwZShjb25zdCBwdGhyZWFkX211dGV4YXR0cl90ICphdHRyLCBpbnQgKmtpbmQpCnsKICAqa2luZCA9IFBUSFJFQURfTVVURVhfUkVDVVJTSVZFOwogIHJldHVybiAwOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfbXV0ZXhhdHRyX2dldHR5cGUsIHB0aHJlYWRfbXV0ZXhhdHRyX2dldHR5cGUpOwoKCi8qKioqKiBUSFJFQUQtU1BFQ0lGSUMgVkFSSUFCTEVTIChLRVlTKSAqKioqKi8KCmludCBfX3B0aHJlYWRfa2V5X2NyZWF0ZShwdGhyZWFkX2tleV90ICprZXksIHZvaWQgKCpkZXN0cl9mdW5jdGlvbikodm9pZCAqKSkKewogICAgc3RhdGljIGludCBrZXljbnQgPSBGSVJTVF9LRVk7CiAgICAqa2V5ID0gaW50ZXJsb2NrZWRfeGNoZ19hZGQoJmtleWNudCwgMSk7CiAgICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2tleV9jcmVhdGUsIHB0aHJlYWRfa2V5X2NyZWF0ZSk7CgppbnQgX19wdGhyZWFkX2tleV9kZWxldGUocHRocmVhZF9rZXlfdCBrZXkpCnsKICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2tleV9kZWxldGUsIHB0aHJlYWRfa2V5X2RlbGV0ZSk7CgppbnQgX19wdGhyZWFkX3NldHNwZWNpZmljKHB0aHJlYWRfa2V5X3Qga2V5LCBjb25zdCB2b2lkICpwb2ludGVyKQp7CiAgICBwdGhyZWFkX2Rlc2NyIGRlc2NyID0gX19wdGhyZWFkX3RocmVhZF9zZWxmKCk7CiAgICBkZXNjci0+a2V5X2RhdGFba2V5XSA9IHBvaW50ZXI7CiAgICByZXR1cm4gMDsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3NldHNwZWNpZmljLCBwdGhyZWFkX3NldHNwZWNpZmljKTsKCnZvaWQgKl9fcHRocmVhZF9nZXRzcGVjaWZpYyhwdGhyZWFkX2tleV90IGtleSkKewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgcmV0dXJuICh2b2lkICopZGVzY3ItPmtleV9kYXRhW2tleV07Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9nZXRzcGVjaWZpYywgcHRocmVhZF9nZXRzcGVjaWZpYyk7CgpzdGF0aWMgaW50IHB0aHJlYWRfaW50ZXJuYWxfdHNkX3NldCggaW50IGtleSwgY29uc3Qgdm9pZCAqcG9pbnRlciApCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIGRlc2NyLT50c2RfZGF0YVtrZXldID0gcG9pbnRlcjsKICAgIHJldHVybiAwOwp9CmludCAoKl9fbGliY19pbnRlcm5hbF90c2Rfc2V0KShpbnQsIGNvbnN0IHZvaWQgKikgPSBwdGhyZWFkX2ludGVybmFsX3RzZF9zZXQ7CgpzdGF0aWMgdm9pZCAqcHRocmVhZF9pbnRlcm5hbF90c2RfZ2V0KCBpbnQga2V5ICkKewogICAgcHRocmVhZF9kZXNjciBkZXNjciA9IF9fcHRocmVhZF90aHJlYWRfc2VsZigpOwogICAgcmV0dXJuICh2b2lkICopZGVzY3ItPnRzZF9kYXRhW2tleV07Cn0Kdm9pZCogKCpfX2xpYmNfaW50ZXJuYWxfdHNkX2dldCkoaW50KSA9IHB0aHJlYWRfaW50ZXJuYWxfdHNkX2dldDsKCnN0YXRpYyB2b2lkICoqIF9fYXR0cmlidXRlX18oKGNvbnN0KSkgcHRocmVhZF9pbnRlcm5hbF90c2RfYWRkcmVzcyggaW50IGtleSApCnsKICAgIHB0aHJlYWRfZGVzY3IgZGVzY3IgPSBfX3B0aHJlYWRfdGhyZWFkX3NlbGYoKTsKICAgIHJldHVybiAodm9pZCAqKikmZGVzY3ItPnRzZF9kYXRhW2tleV07Cn0Kdm9pZCoqICgqX19saWJjX2ludGVybmFsX3RzZF9hZGRyZXNzKShpbnQpID0gcHRocmVhZF9pbnRlcm5hbF90c2RfYWRkcmVzczsKCi8qKioqKiAiRVhDRVBUSU9OIiBGUkFNRVMgKioqKiovCi8qIG5vdCBpbXBsZW1lbnRlZCByaWdodCBub3cgKi8KCnZvaWQgX3B0aHJlYWRfY2xlYW51cF9wdXNoKHN0cnVjdCBfcHRocmVhZF9jbGVhbnVwX2J1ZmZlciAqYnVmZmVyLCB2b2lkICgqcm91dGluZSkodm9pZCAqKSwgdm9pZCAqYXJnKQp7CiAgKCh3aW5lX2NsZWFudXApYnVmZmVyKS0+cm91dGluZSA9IHJvdXRpbmU7CiAgKCh3aW5lX2NsZWFudXApYnVmZmVyKS0+YXJnID0gYXJnOwp9Cgp2b2lkIF9wdGhyZWFkX2NsZWFudXBfcG9wKHN0cnVjdCBfcHRocmVhZF9jbGVhbnVwX2J1ZmZlciAqYnVmZmVyLCBpbnQgZXhlY3V0ZSkKewogIGlmIChleGVjdXRlKSAoKigoKHdpbmVfY2xlYW51cClidWZmZXIpLT5yb3V0aW5lKSkoKCh3aW5lX2NsZWFudXApYnVmZmVyKS0+YXJnKTsKfQoKdm9pZCBfcHRocmVhZF9jbGVhbnVwX3B1c2hfZGVmZXIoc3RydWN0IF9wdGhyZWFkX2NsZWFudXBfYnVmZmVyICpidWZmZXIsIHZvaWQgKCpyb3V0aW5lKSh2b2lkICopLCB2b2lkICphcmcpCnsKICBfcHRocmVhZF9jbGVhbnVwX3B1c2goYnVmZmVyLCByb3V0aW5lLCBhcmcpOwp9Cgp2b2lkIF9wdGhyZWFkX2NsZWFudXBfcG9wX3Jlc3RvcmUoc3RydWN0IF9wdGhyZWFkX2NsZWFudXBfYnVmZmVyICpidWZmZXIsIGludCBleGVjdXRlKQp7CiAgX3B0aHJlYWRfY2xlYW51cF9wb3AoYnVmZmVyLCBleGVjdXRlKTsKfQoKdm9pZCBfX3B0aHJlYWRfY2xlYW51cF91cHRvKGptcF9idWYgdGFyZ2V0LCBjaGFyICpmcmFtZSkKewogICAgLyogRklYTUUgKi8KfQoKLyoqKioqIENPTkRJVElPTlMgKioqKiovCgppbnQgX19wdGhyZWFkX2NvbmRfaW5pdChwdGhyZWFkX2NvbmRfdCAqY29uZCwgY29uc3QgcHRocmVhZF9jb25kYXR0cl90ICpjb25kX2F0dHIpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfY29uZF9pbml0KSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jb25kX2luaXQoY29uZCwgY29uZF9hdHRyKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX2NvbmRfaW5pdCwgcHRocmVhZF9jb25kX2luaXQpOwoKaW50IF9fcHRocmVhZF9jb25kX2Rlc3Ryb3kocHRocmVhZF9jb25kX3QgKmNvbmQpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfY29uZF9kZXN0cm95KSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9jb25kX2Rlc3Ryb3koY29uZCk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9jb25kX2Rlc3Ryb3ksIHB0aHJlYWRfY29uZF9kZXN0cm95KTsKCmludCBfX3B0aHJlYWRfY29uZF9zaWduYWwocHRocmVhZF9jb25kX3QgKmNvbmQpCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfY29uZF9zaWduYWwpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfc2lnbmFsKGNvbmQpOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfY29uZF9zaWduYWwsIHB0aHJlYWRfY29uZF9zaWduYWwpOwoKaW50IF9fcHRocmVhZF9jb25kX2Jyb2FkY2FzdChwdGhyZWFkX2NvbmRfdCAqY29uZCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX2Jyb2FkY2FzdCkgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfY29uZF9icm9hZGNhc3QoY29uZCk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9jb25kX2Jyb2FkY2FzdCwgcHRocmVhZF9jb25kX2Jyb2FkY2FzdCk7CgppbnQgX19wdGhyZWFkX2NvbmRfd2FpdChwdGhyZWFkX2NvbmRfdCAqY29uZCwgcHRocmVhZF9tdXRleF90ICptdXRleCkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX3dhaXQpIHJldHVybiAwOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2NvbmRfd2FpdChjb25kLCBtdXRleCk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9jb25kX3dhaXQsIHB0aHJlYWRfY29uZF93YWl0KTsKCmludCBfX3B0aHJlYWRfY29uZF90aW1lZHdhaXQocHRocmVhZF9jb25kX3QgKmNvbmQsIHB0aHJlYWRfbXV0ZXhfdCAqbXV0ZXgsIGNvbnN0IHN0cnVjdCB0aW1lc3BlYyAqYWJzdGltZSkKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9jb25kX3RpbWVkd2FpdCkgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfY29uZF90aW1lZHdhaXQoY29uZCwgbXV0ZXgsIGFic3RpbWUpOwp9CnN0cm9uZ19hbGlhcyhfX3B0aHJlYWRfY29uZF90aW1lZHdhaXQsIHB0aHJlYWRfY29uZF90aW1lZHdhaXQpOwoKLyoqKiogQ09ORElUSU9OIEFUVFJJQlVURVMgKioqKiovCi8qIG5vdCBpbXBsZW1lbnRlZCByaWdodCBub3cgKi8KCmludCBwdGhyZWFkX2NvbmRhdHRyX2luaXQocHRocmVhZF9jb25kYXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0KCmludCBwdGhyZWFkX2NvbmRhdHRyX2Rlc3Ryb3kocHRocmVhZF9jb25kYXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0KCi8qKioqKiBSRUFELVdSSVRFIExPQ0tTICoqKioqLwoKaW50IF9fcHRocmVhZF9yd2xvY2tfaW5pdChwdGhyZWFkX3J3bG9ja190ICpyd2xvY2ssIGNvbnN0IHB0aHJlYWRfcndsb2NrYXR0cl90ICpyd2xvY2tfYXR0cikKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfaW5pdCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja19pbml0KCByd2xvY2ssIHJ3bG9ja19hdHRyICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfaW5pdCwgcHRocmVhZF9yd2xvY2tfaW5pdCk7CgppbnQgX19wdGhyZWFkX3J3bG9ja19kZXN0cm95KHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfZGVzdHJveSApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX3J3bG9ja19kZXN0cm95KCByd2xvY2sgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja19kZXN0cm95LCBwdGhyZWFkX3J3bG9ja19kZXN0cm95KTsKCmludCBfX3B0aHJlYWRfcndsb2NrX3JkbG9jayhwdGhyZWFkX3J3bG9ja190ICpyd2xvY2spCnsKICAgIGlmICghZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3JkbG9jaykgcmV0dXJuIDA7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3JkbG9jayggcndsb2NrICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfcmRsb2NrLCBwdGhyZWFkX3J3bG9ja19yZGxvY2spOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfdHJ5cmRsb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdHJ5cmRsb2NrICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3RyeXJkbG9jayggcndsb2NrICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfdHJ5cmRsb2NrLCBwdGhyZWFkX3J3bG9ja190cnlyZGxvY2spOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfd3Jsb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfd3Jsb2NrICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3dybG9jayggcndsb2NrICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfd3Jsb2NrLCBwdGhyZWFkX3J3bG9ja193cmxvY2spOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfdHJ5d3Jsb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdHJ5d3Jsb2NrICk7CiAgICByZXR1cm4gZnVuY3MucHRyX3B0aHJlYWRfcndsb2NrX3RyeXdybG9jayggcndsb2NrICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2tfdHJ5d3Jsb2NrLCBwdGhyZWFkX3J3bG9ja190cnl3cmxvY2spOwoKaW50IF9fcHRocmVhZF9yd2xvY2tfdW5sb2NrKHB0aHJlYWRfcndsb2NrX3QgKnJ3bG9jaykKewogICAgaWYgKCFmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdW5sb2NrKSByZXR1cm4gMDsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9yd2xvY2tfdW5sb2NrKCByd2xvY2sgKTsKfQpzdHJvbmdfYWxpYXMoX19wdGhyZWFkX3J3bG9ja191bmxvY2ssIHB0aHJlYWRfcndsb2NrX3VubG9jayk7CgovKioqKiBSRUFELVdSSVRFIExPQ0sgQVRUUklCVVRFUyAqKioqKi8KLyogbm90IGltcGxlbWVudGVkIHJpZ2h0IG5vdyAqLwoKaW50IHB0aHJlYWRfcndsb2NrYXR0cl9pbml0KHB0aHJlYWRfcndsb2NrYXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0KCmludCBfX3B0aHJlYWRfcndsb2NrYXR0cl9kZXN0cm95KHB0aHJlYWRfcndsb2NrYXR0cl90ICphdHRyKQp7CiAgcmV0dXJuIDA7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9yd2xvY2thdHRyX2Rlc3Ryb3ksIHB0aHJlYWRfcndsb2NrYXR0cl9kZXN0cm95KTsKCmludCBwdGhyZWFkX3J3bG9ja2F0dHJfZ2V0a2luZF9ucChjb25zdCBwdGhyZWFkX3J3bG9ja2F0dHJfdCAqYXR0ciwgaW50ICpwcmVmKQp7CiAgKnByZWYgPSAwOwogIHJldHVybiAwOwp9CgppbnQgcHRocmVhZF9yd2xvY2thdHRyX3NldGtpbmRfbnAocHRocmVhZF9yd2xvY2thdHRyX3QgKmF0dHIsIGludCBwcmVmKQp7CiAgcmV0dXJuIDA7Cn0KCi8qKioqKiBNSVNDICoqKioqLwoKcHRocmVhZF90IHB0aHJlYWRfc2VsZih2b2lkKQp7CiAgICBhc3NlcnQoIGZ1bmNzLnB0cl9wdGhyZWFkX3NlbGYgKTsKICAgIHJldHVybiBmdW5jcy5wdHJfcHRocmVhZF9zZWxmKCk7Cn0KCmludCBwdGhyZWFkX2VxdWFsKHB0aHJlYWRfdCB0aHJlYWQxLCBwdGhyZWFkX3QgdGhyZWFkMikKewogICAgYXNzZXJ0KCBmdW5jcy5wdHJfcHRocmVhZF9lcXVhbCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2VxdWFsKCB0aHJlYWQxLCB0aHJlYWQyICk7Cn0KCnZvaWQgX19wdGhyZWFkX2RvX2V4aXQodm9pZCAqcmV0dmFsLCBjaGFyICpjdXJyZW50ZnJhbWUpCnsKICAgIGFzc2VydCggZnVuY3MucHRyX3B0aHJlYWRfZXhpdCApOwogICAgcmV0dXJuIGZ1bmNzLnB0cl9wdGhyZWFkX2V4aXQoIHJldHZhbCwgY3VycmVudGZyYW1lICk7Cn0KCnZvaWQgX19wdGhyZWFkX2V4aXQodm9pZCAqcmV0dmFsKQp7CiAgICBfX3B0aHJlYWRfZG9fZXhpdCggcmV0dmFsLCBOVUxMICk7Cn0Kc3Ryb25nX2FsaWFzKF9fcHRocmVhZF9leGl0LCBwdGhyZWFkX2V4aXQpOwoKaW50IHB0aHJlYWRfc2V0Y2FuY2Vsc3RhdGUoaW50IHN0YXRlLCBpbnQgKm9sZHN0YXRlKQp7CiAgICBwdGhyZWFkX2Rlc2NyIGRlc2NyID0gX19wdGhyZWFkX3RocmVhZF9zZWxmKCk7CiAgICBpZiAob2xkc3RhdGUpICpvbGRzdGF0ZSA9IGRlc2NyLT5jYW5jZWxfc3RhdGU7CiAgICBkZXNjci0+Y2FuY2VsX3N0YXRlID0gc3RhdGU7CiAgICByZXR1cm4gMDsKfQoKaW50IHB0aHJlYWRfc2V0Y2FuY2VsdHlwZShpbnQgdHlwZSwgaW50ICpvbGR0eXBlKQp7CiAgICBwdGhyZWFkX2Rlc2NyIGRlc2NyID0gX19wdGhyZWFkX3RocmVhZF9zZWxmKCk7CiAgICBpZiAob2xkdHlwZSkgKm9sZHR5cGUgPSBkZXNjci0+Y2FuY2VsX3R5cGU7CiAgICBkZXNjci0+Y2FuY2VsX3R5cGUgPSB0eXBlOwogICAgcmV0dXJuIDA7Cn0KCi8qKioqKiBBTlRJLU9WRVJSSURFUyAqKioqKi8KLyogcHRocmVhZHMgdHJpZXMgdG8gb3ZlcnJpZGUgdGhlc2UsIHBvaW50IHRoZW0gYmFjayB0byBsaWJjICovCgppbnQgc2lnYWN0aW9uKGludCBzaWdudW0sIGNvbnN0IHN0cnVjdCBzaWdhY3Rpb24gKmFjdCwgc3RydWN0IHNpZ2FjdGlvbiAqb2xkYWN0KQp7CiAgICBpZiAoIWxpYmNfc2lnYWN0aW9uKQogICAgewogICAgICAgIGxpYmNfc2lnYWN0aW9uID0gd2luZV9kbHN5bSggUlRMRF9ORVhULCAic2lnYWN0aW9uIiwgTlVMTCwgMCApOwogICAgICAgIGFzc2VydCggbGliY19zaWdhY3Rpb24gKTsKICAgIH0KICAgIHJldHVybiBsaWJjX3NpZ2FjdGlvbihzaWdudW0sIGFjdCwgb2xkYWN0KTsKfQoKdm9pZCBfX3B0aHJlYWRfaW5pdGlhbGl6ZSh2b2lkKQp7CiAgICBzdGF0aWMgaW50IGRvbmU7CgogICAgaWYgKCFkb25lKQogICAgewogICAgICAgIGRvbmUgPSAxOwogICAgICAgIGxpYmNfZm9yayA9IHdpbmVfZGxzeW0oIFJUTERfTkVYVCwgImZvcmsiLCBOVUxMLCAwICk7CiAgICAgICAgbGliY19zaWdhY3Rpb24gPSB3aW5lX2Rsc3ltKCBSVExEX05FWFQsICJzaWdhY3Rpb24iLCBOVUxMLCAwICk7CiAgICAgICAgbGliY191c2Vsb2NhbGUgPSB3aW5lX2Rsc3ltKCBSVExEX0RFRkFVTFQsICJ1c2Vsb2NhbGUiLCBOVUxMLCAwICk7CiAgICAgICAgbGliY19wdGhyZWFkX2luaXQgPSB3aW5lX2Rsc3ltKCBSVExEX05FWFQsICJfX2xpYmNfcHRocmVhZF9pbml0IiwgTlVMTCwgMCApOwogICAgICAgIGlmIChsaWJjX3B0aHJlYWRfaW5pdCkgbGliY19tdWx0aXBsZV90aHJlYWRzID0gbGliY19wdGhyZWFkX2luaXQoICZsaWJjX3B0aHJlYWRfZnVuY3Rpb25zICk7CiAgICB9Cn0KCiNpZmRlZiBfX0dOVUNfXwpzdGF0aWMgdm9pZCBpbml0KHZvaWQpIF9fYXR0cmlidXRlX18oKGNvbnN0cnVjdG9yKSk7CnN0YXRpYyB2b2lkIGluaXQodm9pZCkKewogICAgX19wdGhyZWFkX2luaXRpYWxpemUoKTsKfQojZW5kaWYKCnN0YXRpYyBzdHJ1Y3QgcHRocmVhZF9mdW5jdGlvbnMgbGliY19wdGhyZWFkX2Z1bmN0aW9ucyA9CnsKICAgIE5VTEwsICAgICAgICAgICAgICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9mb3JrICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9kZXN0cm95ICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9hdHRyX2luaXRfMl8wICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9hdHRyX2luaXRfMl8xICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9nZXRkZXRhY2hzdGF0ZSAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2F0dHJfc2V0ZGV0YWNoc3RhdGUgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX2dldGluaGVyaXRzY2hlZCAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2F0dHJfc2V0aW5oZXJpdHNjaGVkICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9nZXRzY2hlZHBhcmFtICovCiAgICBwdGhyZWFkX2F0dHJfc2V0c2NoZWRwYXJhbSwgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9zZXRzY2hlZHBhcmFtICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9nZXRzY2hlZHBvbGljeSAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2F0dHJfc2V0c2NoZWRwb2xpY3kgKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9hdHRyX2dldHNjb3BlICovCiAgICBOVUxMLCAvKiBGSVhNRSAqLyAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfYXR0cl9zZXRzY29wZSAqLwogICAgcHRocmVhZF9jb25kYXR0cl9kZXN0cm95LCAgICAgIC8qIHB0cl9wdGhyZWFkX2NvbmRhdHRyX2Rlc3Ryb3kgKi8KICAgIHB0aHJlYWRfY29uZGF0dHJfaW5pdCwgICAgICAgICAvKiBwdHJfcHRocmVhZF9jb25kYXR0cl9pbml0ICovCiAgICBfX3B0aHJlYWRfY29uZF9icm9hZGNhc3QsICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX2Jyb2FkY2FzdCAqLwogICAgX19wdGhyZWFkX2NvbmRfZGVzdHJveSwgICAgICAgIC8qIHB0cl9fX3B0aHJlYWRfY29uZF9kZXN0cm95ICovCiAgICBfX3B0aHJlYWRfY29uZF9pbml0LCAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX2luaXQgKi8KICAgIF9fcHRocmVhZF9jb25kX3NpZ25hbCwgICAgICAgICAvKiBwdHJfX19wdGhyZWFkX2NvbmRfc2lnbmFsICovCiAgICBfX3B0aHJlYWRfY29uZF93YWl0LCAgICAgICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX3dhaXQgKi8KICAgIHB0aHJlYWRfZXF1YWwsICAgICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9lcXVhbCAqLwogICAgX19wdGhyZWFkX2V4aXQsICAgICAgICAgICAgICAgIC8qIHB0cl9fX3B0aHJlYWRfZXhpdCAqLwogICAgTlVMTCwgLyogRklYTUUgKi8gICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX2dldHNjaGVkcGFyYW0gKi8KICAgIE5VTEwsIC8qIEZJWE1FICovICAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9zZXRzY2hlZHBhcmFtICovCiAgICBfX3B0aHJlYWRfbXV0ZXhfZGVzdHJveSwgICAgICAgLyogcHRyX3B0aHJlYWRfbXV0ZXhfZGVzdHJveSAqLwogICAgX19wdGhyZWFkX211dGV4X2luaXQsICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX211dGV4X2luaXQgKi8KICAgIF9fcHRocmVhZF9tdXRleF9sb2NrLCAgICAgICAgICAvKiBwdHJfcHRocmVhZF9tdXRleF9sb2NrICovCiAgICBfX3B0aHJlYWRfbXV0ZXhfdHJ5bG9jaywgICAgICAgLyogcHRyX3B0aHJlYWRfbXV0ZXhfdHJ5bG9jayAqLwogICAgX19wdGhyZWFkX211dGV4X3VubG9jaywgICAgICAgIC8qIHB0cl9wdGhyZWFkX211dGV4X3VubG9jayAqLwogICAgcHRocmVhZF9zZWxmLCAgICAgICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX3NlbGYgKi8KICAgIHB0aHJlYWRfc2V0Y2FuY2Vsc3RhdGUsICAgICAgICAvKiBwdHJfcHRocmVhZF9zZXRjYW5jZWxzdGF0ZSAqLwogICAgcHRocmVhZF9zZXRjYW5jZWx0eXBlLCAgICAgICAgIC8qIHB0cl9wdGhyZWFkX3NldGNhbmNlbHR5cGUgKi8KICAgIF9fcHRocmVhZF9kb19leGl0LCAgICAgICAgICAgICAvKiBwdHJfcHRocmVhZF9kb19leGl0ICovCiAgICBfX3B0aHJlYWRfY2xlYW51cF91cHRvLCAgICAgICAgLyogcHRyX3B0aHJlYWRfY2xlYW51cF91cHRvICovCiAgICBfX3B0aHJlYWRfdGhyZWFkX3NlbGYsICAgICAgICAgLyogcHRyX3B0aHJlYWRfdGhyZWFkX3NlbGYgKi8KICAgIHB0aHJlYWRfaW50ZXJuYWxfdHNkX3NldCwgICAgICAvKiBwdHJfcHRocmVhZF9pbnRlcm5hbF90c2Rfc2V0ICovCiAgICBwdGhyZWFkX2ludGVybmFsX3RzZF9nZXQsICAgICAgLyogcHRyX3B0aHJlYWRfaW50ZXJuYWxfdHNkX2dldCAqLwogICAgcHRocmVhZF9pbnRlcm5hbF90c2RfYWRkcmVzcywgIC8qIHB0cl9wdGhyZWFkX2ludGVybmFsX3RzZF9hZGRyZXNzICovCiAgICBOVUxMLCAgICAgICAgICAgICAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfc2lnYWN0aW9uICovCiAgICBOVUxMLCAgICAgICAgICAgICAgICAgICAgICAgICAgLyogcHRyX3B0aHJlYWRfc2lnd2FpdCAqLwogICAgTlVMTCwgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIHB0cl9wdGhyZWFkX3JhaXNlICovCiAgICBfX3B0aHJlYWRfY29uZF90aW1lZHdhaXQsICAgICAgLyogcHRyX19fcHRocmVhZF9jb25kX3RpbWVkd2FpdCAqLwogICAgX3B0aHJlYWRfY2xlYW51cF9wdXNoLCAgICAgICAgIC8qIHB0cl9fcHRocmVhZF9jbGVhbnVwX3B1c2ggKi8KICAgIF9wdGhyZWFkX2NsZWFudXBfcG9wICAgICAgICAgICAvKiBwdHJfX3B0aHJlYWRfY2xlYW51cF9wb3AgKi8KfTsKCiNlbmRpZiAvKiBIQVZFX1BUSFJFQURfSCAmJiAoX19HTElCQ19fIHx8IF9fRlJFRUJTRF9fKSAqLwo=