LyoKICogaThrLmMgLS0gTGludXggZHJpdmVyIGZvciBhY2Nlc3NpbmcgdGhlIFNNTSBCSU9TIG9uIERlbGwgbGFwdG9wcy4KICoJICAgIFNlZSBodHRwOi8vd3d3LmRlYmlhbi5vcmcvfmR6L2k4ay8gZm9yIG1vcmUgaW5mb3JtYXRpb24KICoJICAgIGFuZCBmb3IgbGF0ZXN0IHZlcnNpb24gb2YgdGhpcyBkcml2ZXIuCiAqCiAqIENvcHlyaWdodCAoQykgMjAwMSAgTWFzc2ltbyBEYWwgWm90dG8gPGR6QGRlYmlhbi5vcmc+CiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IgbW9kaWZ5IGl0CiAqIHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5IHRoZQogKiBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVpdGhlciB2ZXJzaW9uIDIsIG9yIChhdCB5b3VyIG9wdGlvbikgYW55CiAqIGxhdGVyIHZlcnNpb24uCiAqCiAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSB0aGF0IGl0IHdpbGwgYmUgdXNlZnVsLCBidXQKICogV0lUSE9VVCBBTlkgV0FSUkFOVFk7IHdpdGhvdXQgZXZlbiB0aGUgaW1wbGllZCB3YXJyYW50eSBvZgogKiBNRVJDSEFOVEFCSUxJVFkgb3IgRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuICBTZWUgdGhlIEdOVQogKiBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvciBtb3JlIGRldGFpbHMuCiAqLwoKI2luY2x1ZGUgPGxpbnV4L21vZHVsZS5oPgojaW5jbHVkZSA8bGludXgvdHlwZXMuaD4KI2luY2x1ZGUgPGxpbnV4L2luaXQuaD4KI2luY2x1ZGUgPGxpbnV4L3Byb2NfZnMuaD4KI2luY2x1ZGUgPGxpbnV4L3NlcV9maWxlLmg+CiNpbmNsdWRlIDxsaW51eC9kbWkuaD4KI2luY2x1ZGUgPGFzbS91YWNjZXNzLmg+CiNpbmNsdWRlIDxhc20vaW8uaD4KCiNpbmNsdWRlIDxsaW51eC9pOGsuaD4KCiNkZWZpbmUgSThLX1ZFUlNJT04JCSIxLjE0IDIxLzAyLzIwMDUiCgojZGVmaW5lIEk4S19TTU1fRk5fU1RBVFVTCTB4MDAyNQojZGVmaW5lIEk4S19TTU1fUE9XRVJfU1RBVFVTCTB4MDA2OQojZGVmaW5lIEk4S19TTU1fU0VUX0ZBTgkJMHgwMWEzCiNkZWZpbmUgSThLX1NNTV9HRVRfRkFOCQkweDAwYTMKI2RlZmluZSBJOEtfU01NX0dFVF9TUEVFRAkweDAyYTMKI2RlZmluZSBJOEtfU01NX0dFVF9URU1QCTB4MTBhMwojZGVmaW5lIEk4S19TTU1fR0VUX0RFTExfU0lHMQkweGZlYTMKI2RlZmluZSBJOEtfU01NX0dFVF9ERUxMX1NJRzIJMHhmZmEzCiNkZWZpbmUgSThLX1NNTV9CSU9TX1ZFUlNJT04JMHgwMGE2CgojZGVmaW5lIEk4S19GQU5fTVVMVAkJMzAKI2RlZmluZSBJOEtfTUFYX1RFTVAJCTEyNwoKI2RlZmluZSBJOEtfRk5fTk9ORQkJMHgwMAojZGVmaW5lIEk4S19GTl9VUAkJMHgwMQojZGVmaW5lIEk4S19GTl9ET1dOCQkweDAyCiNkZWZpbmUgSThLX0ZOX01VVEUJCTB4MDQKI2RlZmluZSBJOEtfRk5fTUFTSwkJMHgwNwojZGVmaW5lIEk4S19GTl9TSElGVAkJOAoKI2RlZmluZSBJOEtfUE9XRVJfQUMJCTB4MDUKI2RlZmluZSBJOEtfUE9XRVJfQkFUVEVSWQkweDAxCgojZGVmaW5lIEk4S19URU1QRVJBVFVSRV9CVUcJMQoKc3RhdGljIGNoYXIgYmlvc192ZXJzaW9uWzRdOwoKTU9EVUxFX0FVVEhPUigiTWFzc2ltbyBEYWwgWm90dG8gKGR6QGRlYmlhbi5vcmcpIik7Ck1PRFVMRV9ERVNDUklQVElPTigiRHJpdmVyIGZvciBhY2Nlc3NpbmcgU01NIEJJT1Mgb24gRGVsbCBsYXB0b3BzIik7Ck1PRFVMRV9MSUNFTlNFKCJHUEwiKTsKCnN0YXRpYyBpbnQgZm9yY2U7Cm1vZHVsZV9wYXJhbShmb3JjZSwgYm9vbCwgMCk7Ck1PRFVMRV9QQVJNX0RFU0MoZm9yY2UsICJGb3JjZSBsb2FkaW5nIHdpdGhvdXQgY2hlY2tpbmcgZm9yIHN1cHBvcnRlZCBtb2RlbHMiKTsKCnN0YXRpYyBpbnQgaWdub3JlX2RtaTsKbW9kdWxlX3BhcmFtKGlnbm9yZV9kbWksIGJvb2wsIDApOwpNT0RVTEVfUEFSTV9ERVNDKGlnbm9yZV9kbWksICJDb250aW51ZSBwcm9iaW5nIGhhcmR3YXJlIGV2ZW4gaWYgRE1JIGRhdGEgZG9lcyBub3QgbWF0Y2giKTsKCnN0YXRpYyBpbnQgcmVzdHJpY3RlZDsKbW9kdWxlX3BhcmFtKHJlc3RyaWN0ZWQsIGJvb2wsIDApOwpNT0RVTEVfUEFSTV9ERVNDKHJlc3RyaWN0ZWQsICJBbGxvdyBmYW4gY29udHJvbCBpZiBTWVNfQURNSU4gY2FwYWJpbGl0eSBzZXQiKTsKCnN0YXRpYyBpbnQgcG93ZXJfc3RhdHVzOwptb2R1bGVfcGFyYW0ocG93ZXJfc3RhdHVzLCBib29sLCAwNjAwKTsKTU9EVUxFX1BBUk1fREVTQyhwb3dlcl9zdGF0dXMsICJSZXBvcnQgcG93ZXIgc3RhdHVzIGluIC9wcm9jL2k4ayIpOwoKc3RhdGljIGludCBpOGtfb3Blbl9mcyhzdHJ1Y3QgaW5vZGUgKmlub2RlLCBzdHJ1Y3QgZmlsZSAqZmlsZSk7CnN0YXRpYyBpbnQgaThrX2lvY3RsKHN0cnVjdCBpbm9kZSAqLCBzdHJ1Y3QgZmlsZSAqLCB1bnNpZ25lZCBpbnQsCgkJICAgICB1bnNpZ25lZCBsb25nKTsKCnN0YXRpYyBzdHJ1Y3QgZmlsZV9vcGVyYXRpb25zIGk4a19mb3BzID0gewoJLm9wZW4JCT0gaThrX29wZW5fZnMsCgkucmVhZAkJPSBzZXFfcmVhZCwKCS5sbHNlZWsJCT0gc2VxX2xzZWVrLAoJLnJlbGVhc2UJPSBzaW5nbGVfcmVsZWFzZSwKCS5pb2N0bAkJPSBpOGtfaW9jdGwsCn07CgpzdHJ1Y3Qgc21tX3JlZ3MgewoJdW5zaWduZWQgaW50IGVheDsKCXVuc2lnbmVkIGludCBlYnggX19hdHRyaWJ1dGVfXyAoKHBhY2tlZCkpOwoJdW5zaWduZWQgaW50IGVjeCBfX2F0dHJpYnV0ZV9fICgocGFja2VkKSk7Cgl1bnNpZ25lZCBpbnQgZWR4IF9fYXR0cmlidXRlX18gKChwYWNrZWQpKTsKCXVuc2lnbmVkIGludCBlc2kgX19hdHRyaWJ1dGVfXyAoKHBhY2tlZCkpOwoJdW5zaWduZWQgaW50IGVkaSBfX2F0dHJpYnV0ZV9fICgocGFja2VkKSk7Cn07CgpzdGF0aWMgaW5saW5lIGNoYXIgKmk4a19nZXRfZG1pX2RhdGEoaW50IGZpZWxkKQp7CglyZXR1cm4gZG1pX2dldF9zeXN0ZW1faW5mbyhmaWVsZCkgPyA6ICJOL0EiOwp9CgovKgogKiBDYWxsIHRoZSBTeXN0ZW0gTWFuYWdlbWVudCBNb2RlIEJJT1MuIENvZGUgcHJvdmlkZWQgYnkgSm9uYXRoYW4gQnV6emFyZC4KICovCnN0YXRpYyBpbnQgaThrX3NtbShzdHJ1Y3Qgc21tX3JlZ3MgKnJlZ3MpCnsKCWludCByYzsKCWludCBlYXggPSByZWdzLT5lYXg7CgoJYXNtKCJwdXNobCAlJWVheFxuXHQiCgkgICAgIm1vdmwgMCglJWVheCksJSVlZHhcblx0IgoJICAgICJwdXNoICUlZWR4XG5cdCIKCSAgICAibW92bCA0KCUlZWF4KSwlJWVieFxuXHQiCgkgICAgIm1vdmwgOCglJWVheCksJSVlY3hcblx0IgoJICAgICJtb3ZsIDEyKCUlZWF4KSwlJWVkeFxuXHQiCgkgICAgIm1vdmwgMTYoJSVlYXgpLCUlZXNpXG5cdCIKCSAgICAibW92bCAyMCglJWVheCksJSVlZGlcblx0IgoJICAgICJwb3BsICUlZWF4XG5cdCIKCSAgICAib3V0ICUlYWwsJDB4YjJcblx0IgoJICAgICJvdXQgJSVhbCwkMHg4NFxuXHQiCgkgICAgInhjaGdsICUlZWF4LCglJWVzcClcblx0IgoJICAgICJtb3ZsICUlZWJ4LDQoJSVlYXgpXG5cdCIKCSAgICAibW92bCAlJWVjeCw4KCUlZWF4KVxuXHQiCgkgICAgIm1vdmwgJSVlZHgsMTIoJSVlYXgpXG5cdCIKCSAgICAibW92bCAlJWVzaSwxNiglJWVheClcblx0IgoJICAgICJtb3ZsICUlZWRpLDIwKCUlZWF4KVxuXHQiCgkgICAgInBvcGwgJSVlZHhcblx0IgoJICAgICJtb3ZsICUlZWR4LDAoJSVlYXgpXG5cdCIKCSAgICAibGFoZlxuXHQiCgkgICAgInNocmwgJDgsJSVlYXhcblx0IgoJICAgICJhbmRsICQxLCUlZWF4XG4iOiI9YSIocmMpCgkgICAgOiAgICAiYSIocmVncykKCSAgICA6ICAgICIlZWJ4IiwgIiVlY3giLCAiJWVkeCIsICIlZXNpIiwgIiVlZGkiLCAibWVtb3J5Iik7CgoJaWYgKHJjICE9IDAgfHwgKHJlZ3MtPmVheCAmIDB4ZmZmZikgPT0gMHhmZmZmIHx8IHJlZ3MtPmVheCA9PSBlYXgpCgkJcmV0dXJuIC1FSU5WQUw7CgoJcmV0dXJuIDA7Cn0KCi8qCiAqIFJlYWQgdGhlIGJpb3MgdmVyc2lvbi4gUmV0dXJuIHRoZSB2ZXJzaW9uIGFzIGFuIGludGVnZXIgY29ycmVzcG9uZGluZwogKiB0byB0aGUgYXNjaWkgdmFsdWUsIGZvciBleGFtcGxlICJBMTciIGlzIHJldHVybmVkIGFzIDB4MDA0MTMxMzcuCiAqLwpzdGF0aWMgaW50IGk4a19nZXRfYmlvc192ZXJzaW9uKHZvaWQpCnsKCXN0cnVjdCBzbW1fcmVncyByZWdzID0geyAuZWF4ID0gSThLX1NNTV9CSU9TX1ZFUlNJT04sIH07CgoJcmV0dXJuIGk4a19zbW0oJnJlZ3MpID8gOiByZWdzLmVheDsKfQoKLyoKICogUmVhZCB0aGUgRm4ga2V5IHN0YXR1cy4KICovCnN0YXRpYyBpbnQgaThrX2dldF9mbl9zdGF0dXModm9pZCkKewoJc3RydWN0IHNtbV9yZWdzIHJlZ3MgPSB7IC5lYXggPSBJOEtfU01NX0ZOX1NUQVRVUywgfTsKCWludCByYzsKCglpZiAoKHJjID0gaThrX3NtbSgmcmVncykpIDwgMCkKCQlyZXR1cm4gcmM7CgoJc3dpdGNoICgocmVncy5lYXggPj4gSThLX0ZOX1NISUZUKSAmIEk4S19GTl9NQVNLKSB7CgljYXNlIEk4S19GTl9VUDoKCQlyZXR1cm4gSThLX1ZPTF9VUDsKCWNhc2UgSThLX0ZOX0RPV046CgkJcmV0dXJuIEk4S19WT0xfRE9XTjsKCWNhc2UgSThLX0ZOX01VVEU6CgkJcmV0dXJuIEk4S19WT0xfTVVURTsKCWRlZmF1bHQ6CgkJcmV0dXJuIDA7Cgl9Cn0KCi8qCiAqIFJlYWQgdGhlIHBvd2VyIHN0YXR1cy4KICovCnN0YXRpYyBpbnQgaThrX2dldF9wb3dlcl9zdGF0dXModm9pZCkKewoJc3RydWN0IHNtbV9yZWdzIHJlZ3MgPSB7IC5lYXggPSBJOEtfU01NX1BPV0VSX1NUQVRVUywgfTsKCWludCByYzsKCglpZiAoKHJjID0gaThrX3NtbSgmcmVncykpIDwgMCkKCQlyZXR1cm4gcmM7CgoJcmV0dXJuIChyZWdzLmVheCAmIDB4ZmYpID09IEk4S19QT1dFUl9BQyA/IEk4S19BQyA6IEk4S19CQVRURVJZOwp9CgovKgogKiBSZWFkIHRoZSBmYW4gc3RhdHVzLgogKi8Kc3RhdGljIGludCBpOGtfZ2V0X2Zhbl9zdGF0dXMoaW50IGZhbikKewoJc3RydWN0IHNtbV9yZWdzIHJlZ3MgPSB7IC5lYXggPSBJOEtfU01NX0dFVF9GQU4sIH07CgoJcmVncy5lYnggPSBmYW4gJiAweGZmOwoJcmV0dXJuIGk4a19zbW0oJnJlZ3MpID8gOiByZWdzLmVheCAmIDB4ZmY7Cn0KCi8qCiAqIFJlYWQgdGhlIGZhbiBzcGVlZCBpbiBSUE0uCiAqLwpzdGF0aWMgaW50IGk4a19nZXRfZmFuX3NwZWVkKGludCBmYW4pCnsKCXN0cnVjdCBzbW1fcmVncyByZWdzID0geyAuZWF4ID0gSThLX1NNTV9HRVRfU1BFRUQsIH07CgoJcmVncy5lYnggPSBmYW4gJiAweGZmOwoJcmV0dXJuIGk4a19zbW0oJnJlZ3MpID8gOiAocmVncy5lYXggJiAweGZmZmYpICogSThLX0ZBTl9NVUxUOwp9CgovKgogKiBTZXQgdGhlIGZhbiBzcGVlZCAob2ZmLCBsb3csIGhpZ2gpLiBSZXR1cm5zIHRoZSBuZXcgZmFuIHN0YXR1cy4KICovCnN0YXRpYyBpbnQgaThrX3NldF9mYW4oaW50IGZhbiwgaW50IHNwZWVkKQp7CglzdHJ1Y3Qgc21tX3JlZ3MgcmVncyA9IHsgLmVheCA9IEk4S19TTU1fU0VUX0ZBTiwgfTsKCglzcGVlZCA9IChzcGVlZCA8IDApID8gMCA6ICgoc3BlZWQgPiBJOEtfRkFOX01BWCkgPyBJOEtfRkFOX01BWCA6IHNwZWVkKTsKCXJlZ3MuZWJ4ID0gKGZhbiAmIDB4ZmYpIHwgKHNwZWVkIDw8IDgpOwoKCXJldHVybiBpOGtfc21tKCZyZWdzKSA/IDogaThrX2dldF9mYW5fc3RhdHVzKGZhbik7Cn0KCi8qCiAqIFJlYWQgdGhlIGNwdSB0ZW1wZXJhdHVyZS4KICovCnN0YXRpYyBpbnQgaThrX2dldF90ZW1wKGludCBzZW5zb3IpCnsKCXN0cnVjdCBzbW1fcmVncyByZWdzID0geyAuZWF4ID0gSThLX1NNTV9HRVRfVEVNUCwgfTsKCWludCByYzsKCWludCB0ZW1wOwoKI2lmZGVmIEk4S19URU1QRVJBVFVSRV9CVUcKCXN0YXRpYyBpbnQgcHJldjsKI2VuZGlmCglyZWdzLmVieCA9IHNlbnNvciAmIDB4ZmY7CglpZiAoKHJjID0gaThrX3NtbSgmcmVncykpIDwgMCkKCQlyZXR1cm4gcmM7CgoJdGVtcCA9IHJlZ3MuZWF4ICYgMHhmZjsKCiNpZmRlZiBJOEtfVEVNUEVSQVRVUkVfQlVHCgkvKgoJICogU29tZXRpbWVzIHRoZSB0ZW1wZXJhdHVyZSBzZW5zb3IgcmV0dXJucyAweDk5LCB3aGljaCBpcyBvdXQgb2YgcmFuZ2UuCgkgKiBJbiB0aGlzIGNhc2Ugd2UgcmV0dXJuIChvbmNlKSB0aGUgcHJldmlvdXMgY2FjaGVkIHZhbHVlLiBGb3IgZXhhbXBsZToKCSAjIDEwMDM2NTUxMzcgMDAwMDAwNTggMDAwMDVhNGIKCSAjIDEwMDM2NTUxMzggMDAwMDAwOTkgMDAwMDNhODAgPC0tLSAweDk5ID0gMTUzIGRlZ3JlZXMKCSAjIDEwMDM2NTUxMzkgMDAwMDAwNTQgMDAwMDVjNTIKCSAqLwoJaWYgKHRlbXAgPiBJOEtfTUFYX1RFTVApIHsKCQl0ZW1wID0gcHJldjsKCQlwcmV2ID0gSThLX01BWF9URU1QOwoJfSBlbHNlIHsKCQlwcmV2ID0gdGVtcDsKCX0KI2VuZGlmCgoJcmV0dXJuIHRlbXA7Cn0KCnN0YXRpYyBpbnQgaThrX2dldF9kZWxsX3NpZ25hdHVyZShpbnQgcmVxX2ZuKQp7CglzdHJ1Y3Qgc21tX3JlZ3MgcmVncyA9IHsgLmVheCA9IHJlcV9mbiwgfTsKCWludCByYzsKCglpZiAoKHJjID0gaThrX3NtbSgmcmVncykpIDwgMCkKCQlyZXR1cm4gcmM7CgoJcmV0dXJuIHJlZ3MuZWF4ID09IDExNDU2NTE1MjcgJiYgcmVncy5lZHggPT0gMTE0NTM5MjIwNCA/IDAgOiAtMTsKfQoKc3RhdGljIGludCBpOGtfaW9jdGwoc3RydWN0IGlub2RlICppcCwgc3RydWN0IGZpbGUgKmZwLCB1bnNpZ25lZCBpbnQgY21kLAoJCSAgICAgdW5zaWduZWQgbG9uZyBhcmcpCnsKCWludCB2YWwgPSAwOwoJaW50IHNwZWVkOwoJdW5zaWduZWQgY2hhciBidWZmWzE2XTsKCWludCBfX3VzZXIgKmFyZ3AgPSAoaW50IF9fdXNlciAqKWFyZzsKCglpZiAoIWFyZ3ApCgkJcmV0dXJuIC1FSU5WQUw7CgoJc3dpdGNoIChjbWQpIHsKCWNhc2UgSThLX0JJT1NfVkVSU0lPTjoKCQl2YWwgPSBpOGtfZ2V0X2Jpb3NfdmVyc2lvbigpOwoJCWJyZWFrOwoKCWNhc2UgSThLX01BQ0hJTkVfSUQ6CgkJbWVtc2V0KGJ1ZmYsIDAsIDE2KTsKCQlzdHJsY3B5KGJ1ZmYsIGk4a19nZXRfZG1pX2RhdGEoRE1JX1BST0RVQ1RfU0VSSUFMKSwgc2l6ZW9mKGJ1ZmYpKTsKCQlicmVhazsKCgljYXNlIEk4S19GTl9TVEFUVVM6CgkJdmFsID0gaThrX2dldF9mbl9zdGF0dXMoKTsKCQlicmVhazsKCgljYXNlIEk4S19QT1dFUl9TVEFUVVM6CgkJdmFsID0gaThrX2dldF9wb3dlcl9zdGF0dXMoKTsKCQlicmVhazsKCgljYXNlIEk4S19HRVRfVEVNUDoKCQl2YWwgPSBpOGtfZ2V0X3RlbXAoMCk7CgkJYnJlYWs7CgoJY2FzZSBJOEtfR0VUX1NQRUVEOgoJCWlmIChjb3B5X2Zyb21fdXNlcigmdmFsLCBhcmdwLCBzaXplb2YoaW50KSkpCgkJCXJldHVybiAtRUZBVUxUOwoKCQl2YWwgPSBpOGtfZ2V0X2Zhbl9zcGVlZCh2YWwpOwoJCWJyZWFrOwoKCWNhc2UgSThLX0dFVF9GQU46CgkJaWYgKGNvcHlfZnJvbV91c2VyKCZ2YWwsIGFyZ3AsIHNpemVvZihpbnQpKSkKCQkJcmV0dXJuIC1FRkFVTFQ7CgoJCXZhbCA9IGk4a19nZXRfZmFuX3N0YXR1cyh2YWwpOwoJCWJyZWFrOwoKCWNhc2UgSThLX1NFVF9GQU46CgkJaWYgKHJlc3RyaWN0ZWQgJiYgIWNhcGFibGUoQ0FQX1NZU19BRE1JTikpCgkJCXJldHVybiAtRVBFUk07CgoJCWlmIChjb3B5X2Zyb21fdXNlcigmdmFsLCBhcmdwLCBzaXplb2YoaW50KSkpCgkJCXJldHVybiAtRUZBVUxUOwoKCQlpZiAoY29weV9mcm9tX3VzZXIoJnNwZWVkLCBhcmdwICsgMSwgc2l6ZW9mKGludCkpKQoJCQlyZXR1cm4gLUVGQVVMVDsKCgkJdmFsID0gaThrX3NldF9mYW4odmFsLCBzcGVlZCk7CgkJYnJlYWs7CgoJZGVmYXVsdDoKCQlyZXR1cm4gLUVJTlZBTDsKCX0KCglpZiAodmFsIDwgMCkKCQlyZXR1cm4gdmFsOwoKCXN3aXRjaCAoY21kKSB7CgljYXNlIEk4S19CSU9TX1ZFUlNJT046CgkJaWYgKGNvcHlfdG9fdXNlcihhcmdwLCAmdmFsLCA0KSkKCQkJcmV0dXJuIC1FRkFVTFQ7CgoJCWJyZWFrOwoJY2FzZSBJOEtfTUFDSElORV9JRDoKCQlpZiAoY29weV90b191c2VyKGFyZ3AsIGJ1ZmYsIDE2KSkKCQkJcmV0dXJuIC1FRkFVTFQ7CgoJCWJyZWFrOwoJZGVmYXVsdDoKCQlpZiAoY29weV90b191c2VyKGFyZ3AsICZ2YWwsIHNpemVvZihpbnQpKSkKCQkJcmV0dXJuIC1FRkFVTFQ7CgoJCWJyZWFrOwoJfQoKCXJldHVybiAwOwp9CgovKgogKiBQcmludCB0aGUgaW5mb3JtYXRpb24gZm9yIC9wcm9jL2k4ay4KICovCnN0YXRpYyBpbnQgaThrX3Byb2Nfc2hvdyhzdHJ1Y3Qgc2VxX2ZpbGUgKnNlcSwgdm9pZCAqb2Zmc2V0KQp7CglpbnQgZm5fa2V5LCBjcHVfdGVtcCwgYWNfcG93ZXI7CglpbnQgbGVmdF9mYW4sIHJpZ2h0X2ZhbiwgbGVmdF9zcGVlZCwgcmlnaHRfc3BlZWQ7CgoJY3B1X3RlbXAJPSBpOGtfZ2V0X3RlbXAoMCk7CQkJLyogMTExMDAgtXMgKi8KCWxlZnRfZmFuCT0gaThrX2dldF9mYW5fc3RhdHVzKEk4S19GQU5fTEVGVCk7CS8qICAgNTgwILVzICovCglyaWdodF9mYW4JPSBpOGtfZ2V0X2Zhbl9zdGF0dXMoSThLX0ZBTl9SSUdIVCk7CS8qICAgNTgwILVzICovCglsZWZ0X3NwZWVkCT0gaThrX2dldF9mYW5fc3BlZWQoSThLX0ZBTl9MRUZUKTsJLyogICA1ODAgtXMgKi8KCXJpZ2h0X3NwZWVkCT0gaThrX2dldF9mYW5fc3BlZWQoSThLX0ZBTl9SSUdIVCk7CS8qICAgNTgwILVzICovCglmbl9rZXkJCT0gaThrX2dldF9mbl9zdGF0dXMoKTsJCQkvKiAgIDc1MCC1cyAqLwoJaWYgKHBvd2VyX3N0YXR1cykKCQlhY19wb3dlciA9IGk4a19nZXRfcG93ZXJfc3RhdHVzKCk7CQkvKiAxNDcwMCC1cyAqLwoJZWxzZQoJCWFjX3Bvd2VyID0gLTE7CgoJLyoKCSAqIEluZm86CgkgKgoJICogMSkgIEZvcm1hdCB2ZXJzaW9uICh0aGlzIHdpbGwgY2hhbmdlIGlmIGZvcm1hdCBjaGFuZ2VzKQoJICogMikgIEJJT1MgdmVyc2lvbgoJICogMykgIEJJT1MgbWFjaGluZSBJRAoJICogNCkgIENwdSB0ZW1wZXJhdHVyZQoJICogNSkgIExlZnQgZmFuIHN0YXR1cwoJICogNikgIFJpZ2h0IGZhbiBzdGF0dXMKCSAqIDcpICBMZWZ0IGZhbiBzcGVlZAoJICogOCkgIFJpZ2h0IGZhbiBzcGVlZAoJICogOSkgIEFDIHBvd2VyCgkgKiAxMCkgRm4gS2V5IHN0YXR1cwoJICovCglyZXR1cm4gc2VxX3ByaW50ZihzZXEsICIlcyAlcyAlcyAlZCAlZCAlZCAlZCAlZCAlZCAlZFxuIiwKCQkJICBJOEtfUFJPQ19GTVQsCgkJCSAgYmlvc192ZXJzaW9uLAoJCQkgIGRtaV9nZXRfc3lzdGVtX2luZm8oRE1JX1BST0RVQ1RfU0VSSUFMKSA/IDogIk4vQSIsCgkJCSAgY3B1X3RlbXAsCgkJCSAgbGVmdF9mYW4sIHJpZ2h0X2ZhbiwgbGVmdF9zcGVlZCwgcmlnaHRfc3BlZWQsCgkJCSAgYWNfcG93ZXIsIGZuX2tleSk7Cn0KCnN0YXRpYyBpbnQgaThrX29wZW5fZnMoc3RydWN0IGlub2RlICppbm9kZSwgc3RydWN0IGZpbGUgKmZpbGUpCnsKCXJldHVybiBzaW5nbGVfb3BlbihmaWxlLCBpOGtfcHJvY19zaG93LCBOVUxMKTsKfQoKc3RhdGljIHN0cnVjdCBkbWlfc3lzdGVtX2lkIF9faW5pdGRhdGEgaThrX2RtaV90YWJsZVtdID0gewoJewoJCS5pZGVudCA9ICJEZWxsIEluc3Bpcm9uIiwKCQkubWF0Y2hlcyA9IHsKCQkJRE1JX01BVENIKERNSV9TWVNfVkVORE9SLCAiRGVsbCBDb21wdXRlciIpLAoJCQlETUlfTUFUQ0goRE1JX1BST0RVQ1RfTkFNRSwgIkluc3Bpcm9uIiksCgkJfSwKCX0sCgl7CgkJLmlkZW50ID0gIkRlbGwgTGF0aXR1ZGUiLAoJCS5tYXRjaGVzID0gewoJCQlETUlfTUFUQ0goRE1JX1NZU19WRU5ET1IsICJEZWxsIENvbXB1dGVyIiksCgkJCURNSV9NQVRDSChETUlfUFJPRFVDVF9OQU1FLCAiTGF0aXR1ZGUiKSwKCQl9LAoJfSwKCXsKCQkuaWRlbnQgPSAiRGVsbCBJbnNwaXJvbiAyIiwKCQkubWF0Y2hlcyA9IHsKCQkJRE1JX01BVENIKERNSV9TWVNfVkVORE9SLCAiRGVsbCBJbmMuIiksCgkJCURNSV9NQVRDSChETUlfUFJPRFVDVF9OQU1FLCAiSW5zcGlyb24iKSwKCQl9LAoJfSwKCXsKCQkuaWRlbnQgPSAiRGVsbCBMYXRpdHVkZSAyIiwKCQkubWF0Y2hlcyA9IHsKCQkJRE1JX01BVENIKERNSV9TWVNfVkVORE9SLCAiRGVsbCBJbmMuIiksCgkJCURNSV9NQVRDSChETUlfUFJPRFVDVF9OQU1FLCAiTGF0aXR1ZGUiKSwKCQl9LAoJfSwKCXsgfQp9OwoKLyoKICogUHJvYmUgZm9yIHRoZSBwcmVzZW5jZSBvZiBhIHN1cHBvcnRlZCBsYXB0b3AuCiAqLwpzdGF0aWMgaW50IF9faW5pdCBpOGtfcHJvYmUodm9pZCkKewoJY2hhciBidWZmWzRdOwoJaW50IHZlcnNpb247CgoJLyoKCSAqIEdldCBETUkgaW5mb3JtYXRpb24KCSAqLwoJaWYgKCFkbWlfY2hlY2tfc3lzdGVtKGk4a19kbWlfdGFibGUpKSB7CgkJaWYgKCFpZ25vcmVfZG1pICYmICFmb3JjZSkKCQkJcmV0dXJuIC1FTk9ERVY7CgoJCXByaW50ayhLRVJOX0lORk8gImk4azogbm90IHJ1bm5pbmcgb24gYSBzdXBwb3J0ZWQgRGVsbCBzeXN0ZW0uXG4iKTsKCQlwcmludGsoS0VSTl9JTkZPICJpOGs6IHZlbmRvcj0lcywgbW9kZWw9JXMsIHZlcnNpb249JXNcbiIsCgkJCWk4a19nZXRfZG1pX2RhdGEoRE1JX1NZU19WRU5ET1IpLAoJCQlpOGtfZ2V0X2RtaV9kYXRhKERNSV9QUk9EVUNUX05BTUUpLAoJCQlpOGtfZ2V0X2RtaV9kYXRhKERNSV9CSU9TX1ZFUlNJT04pKTsKCX0KCglzdHJsY3B5KGJpb3NfdmVyc2lvbiwgaThrX2dldF9kbWlfZGF0YShETUlfQklPU19WRVJTSU9OKSwgc2l6ZW9mKGJpb3NfdmVyc2lvbikpOwoKCS8qCgkgKiBHZXQgU01NIERlbGwgc2lnbmF0dXJlCgkgKi8KCWlmIChpOGtfZ2V0X2RlbGxfc2lnbmF0dXJlKEk4S19TTU1fR0VUX0RFTExfU0lHMSkgJiYKCSAgICBpOGtfZ2V0X2RlbGxfc2lnbmF0dXJlKEk4S19TTU1fR0VUX0RFTExfU0lHMikpIHsKCQlwcmludGsoS0VSTl9FUlIgImk4azogdW5hYmxlIHRvIGdldCBTTU0gRGVsbCBzaWduYXR1cmVcbiIpOwoJCWlmICghZm9yY2UpCgkJCXJldHVybiAtRU5PREVWOwoJfQoKCS8qCgkgKiBHZXQgU01NIEJJT1MgdmVyc2lvbi4KCSAqLwoJdmVyc2lvbiA9IGk4a19nZXRfYmlvc192ZXJzaW9uKCk7CglpZiAodmVyc2lvbiA8PSAwKSB7CgkJcHJpbnRrKEtFUk5fV0FSTklORyAiaThrOiB1bmFibGUgdG8gZ2V0IFNNTSBCSU9TIHZlcnNpb25cbiIpOwoJfSBlbHNlIHsKCQlidWZmWzBdID0gKHZlcnNpb24gPj4gMTYpICYgMHhmZjsKCQlidWZmWzFdID0gKHZlcnNpb24gPj4gOCkgJiAweGZmOwoJCWJ1ZmZbMl0gPSAodmVyc2lvbikgJiAweGZmOwoJCWJ1ZmZbM10gPSAnXDAnOwoJCS8qCgkJICogSWYgRE1JIEJJT1MgdmVyc2lvbiBpcyB1bmtub3duIHVzZSBTTU0gQklPUyB2ZXJzaW9uLgoJCSAqLwoJCWlmICghZG1pX2dldF9zeXN0ZW1faW5mbyhETUlfQklPU19WRVJTSU9OKSkKCQkJc3RybGNweShiaW9zX3ZlcnNpb24sIGJ1ZmYsIHNpemVvZihiaW9zX3ZlcnNpb24pKTsKCgkJLyoKCQkgKiBDaGVjayBpZiB0aGUgdHdvIHZlcnNpb25zIG1hdGNoLgoJCSAqLwoJCWlmIChzdHJuY21wKGJ1ZmYsIGJpb3NfdmVyc2lvbiwgc2l6ZW9mKGJpb3NfdmVyc2lvbikpICE9IDApCgkJCXByaW50ayhLRVJOX1dBUk5JTkcgImk4azogQklPUyB2ZXJzaW9uIG1pc21hdGNoOiAlcyAhPSAlc1xuIiwKCQkJCWJ1ZmYsIGJpb3NfdmVyc2lvbik7Cgl9CgoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgX19pbml0IGk4a19pbml0KHZvaWQpCnsKCXN0cnVjdCBwcm9jX2Rpcl9lbnRyeSAqcHJvY19pOGs7CgoJLyogQXJlIHdlIHJ1bm5pbmcgb24gYW4gc3VwcG9ydGVkIGxhcHRvcD8gKi8KCWlmIChpOGtfcHJvYmUoKSkKCQlyZXR1cm4gLUVOT0RFVjsKCgkvKiBSZWdpc3RlciB0aGUgcHJvYyBlbnRyeSAqLwoJcHJvY19pOGsgPSBjcmVhdGVfcHJvY19lbnRyeSgiaThrIiwgMCwgTlVMTCk7CglpZiAoIXByb2NfaThrKQoJCXJldHVybiAtRU5PRU5UOwoKCXByb2NfaThrLT5wcm9jX2ZvcHMgPSAmaThrX2ZvcHM7Cglwcm9jX2k4ay0+b3duZXIgPSBUSElTX01PRFVMRTsKCglwcmludGsoS0VSTl9JTkZPCgkgICAgICAgIkRlbGwgbGFwdG9wIFNNTSBkcml2ZXIgdiVzIE1hc3NpbW8gRGFsIFpvdHRvIChkekBkZWJpYW4ub3JnKVxuIiwKCSAgICAgICBJOEtfVkVSU0lPTik7CgoJcmV0dXJuIDA7Cn0KCnN0YXRpYyB2b2lkIF9fZXhpdCBpOGtfZXhpdCh2b2lkKQp7CglyZW1vdmVfcHJvY19lbnRyeSgiaThrIiwgTlVMTCk7Cn0KCm1vZHVsZV9pbml0KGk4a19pbml0KTsKbW9kdWxlX2V4aXQoaThrX2V4aXQpOwo=