LyoKICogKEMpIENvcHlyaWdodCAyMDA5CiAqIEdyYWVtZSBSdXNzLCBncmFlbWUucnVzc0BnbWFpbC5jb20KICoKICogKEMpIENvcHlyaWdodCAyMDA3CiAqIERhbmllbCBIZWxsc3Ryb20sIEdhaXNsZXIgUmVzZWFyY2gsIGRhbmllbEBnYWlzbGVyLmNvbQogKgogKiAoQykgQ29weXJpZ2h0IDIwMDYKICogRGV0bGV2IFp1bmRlbCwgREVOWCBTb2Z0d2FyZSBFbmdpbmVlcmluZywgZHp1QGRlbnguZGUKICoKICogKEMpIENvcHlyaWdodCAtMjAwMwogKiBXb2xmZ2FuZyBEZW5rLCBERU5YIFNvZnR3YXJlIEVuZ2luZWVyaW5nLCB3ZEBkZW54LmRlLgogKgogKiAoQykgQ29weXJpZ2h0IDIwMDIKICogRGFuaWVsIEVuZ3N0cvZtLCBPbWljcm9uIENldGkgQUIsIGRhbmllbEBvbWljcm9uLnNlCiAqCiAqIChDKSBDb3B5cmlnaHQgMjAwMQogKiBKb3NoIEh1YmVyIDxodWJlckBtY2x4LmNvbT4sIE1pc3Npb24gQ3JpdGljYWwgTGludXgsIEluYy4KICoKICogU2VlIGZpbGUgQ1JFRElUUyBmb3IgbGlzdCBvZiBwZW9wbGUgd2hvIGNvbnRyaWJ1dGVkIHRvIHRoaXMKICogcHJvamVjdC4KICoKICogVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vcgogKiBtb2RpZnkgaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcwogKiBwdWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyIHZlcnNpb24gMiBvZgogKiB0aGUgTGljZW5zZSwgb3IgKGF0IHlvdXIgb3B0aW9uKSBhbnkgbGF0ZXIgdmVyc2lvbi4KICoKICogVGhpcyBwcm9ncmFtIGlzIGRpc3RyaWJ1dGVkIGluIHRoZSBob3BlIHRoYXQgaXQgd2lsbCBiZSB1c2VmdWwsCiAqIGJ1dCBXSVRIT1VUIEFOWSBXQVJSQU5UWTsgd2l0aG91dCBldmVuIHRoZSBpbXBsaWVkIHdhcnJhbnR5IG9mCiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gIFNlZSB0aGUKICogR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KICoKICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UKICogYWxvbmcgd2l0aCB0aGlzIHByb2dyYW07IGlmIG5vdCwgd3JpdGUgdG8gdGhlIEZyZWUgU29mdHdhcmUKICogRm91bmRhdGlvbiwgSW5jLiwgNTkgVGVtcGxlIFBsYWNlLCBTdWl0ZSAzMzAsIEJvc3RvbiwKICogTUEgMDIxMTEtMTMwNyBVU0EKICovCgovKgogKiBUaGlzIGZpbGUgY29udGFpbnMgdGhlIGhpZ2gtbGV2ZWwgQVBJIGZvciB0aGUgaW50ZXJydXB0IHN1Yi1zeXN0ZW0KICogb2YgdGhlIGkzODYgcG9ydCBvZiBVLUJvb3QuIE1vc3Qgb2YgdGhlIGZ1bmN0aW9uYWxpdHkgaGFzIGJlZW4KICogc2hhbWVsZXNzbHkgc3RvbGVuIGZyb20gdGhlIGxlb24yIC8gbGVvbjMgcG9ydHMgb2YgVS1Cb290LgogKiBEYW5pZWwgSGVsbHN0cm9tLCBEZXRsZXYgWnVuZGVsLCBXb2xmZ2FuZyBEZW5rIGFuZCBKb3NoIEh1YmVyIGFyZQogKiBjcmVkaXRlZCBmb3IgdGhlIGNvcnJlc3BvbmRpbmcgd29yayBvbiB0aG9zZSBwb3J0cy4gVGhlIG9yaWdpbmFsCiAqIGludGVycnVwdCBoYW5kbGluZyByb3V0aW5lcyBmb3IgdGhlIGkzODYgcG9ydCB3ZXJlIHdyaXR0ZW4gYnkKICogRGFuaWVsIEVuZ3N0cvZtCiAqLwoKI2luY2x1ZGUgPGNvbW1vbi5oPgojaW5jbHVkZSA8YXNtL2ludGVycnVwdC5oPgoKc3RydWN0IGlycV9hY3Rpb24gewoJaW50ZXJydXB0X2hhbmRsZXJfdCAqaGFuZGxlcjsKCXZvaWQgKmFyZzsKCXVuc2lnbmVkIGludCBjb3VudDsKfTsKCnN0YXRpYyBzdHJ1Y3QgaXJxX2FjdGlvbiBpcnFfaGFuZGxlcnNbQ09ORklHX1NZU19OVU1fSVJRU10gPSB7IHswfSB9OwpzdGF0aWMgaW50IHNwdXJpb3VzX2lycV9jbnQgPSAwOwpzdGF0aWMgaW50IHNwdXJpb3VzX2lycSA9IDA7Cgp2b2lkIGlycV9pbnN0YWxsX2hhbmRsZXIoaW50IGlycSwgaW50ZXJydXB0X2hhbmRsZXJfdCAqaGFuZGxlciwgdm9pZCAqYXJnKQp7CglpbnQgc3RhdHVzOwoKCWlmIChpcnEgPCAwIHx8IGlycSA+PSBDT05GSUdfU1lTX05VTV9JUlFTKSB7CgkJcHJpbnRmKCJpcnFfaW5zdGFsbF9oYW5kbGVyOiBiYWQgaXJxIG51bWJlciAlZFxuIiwgaXJxKTsKCQlyZXR1cm47Cgl9CgoJaWYgKGlycV9oYW5kbGVyc1tpcnFdLmhhbmRsZXIgIT0gTlVMTCkKCQlwcmludGYoImlycV9pbnN0YWxsX2hhbmRsZXI6IDB4JTA4bHggcmVwbGFjaW5nIDB4JTA4bHhcbiIsCgkJICAgICAgICh1bG9uZykgaGFuZGxlciArIGdkLT5yZWxvY19vZmYsCgkJICAgICAgICh1bG9uZykgaXJxX2hhbmRsZXJzW2lycV0uaGFuZGxlcik7CgoJc3RhdHVzID0gZGlzYWJsZV9pbnRlcnJ1cHRzICgpOwoKCWlycV9oYW5kbGVyc1tpcnFdLmhhbmRsZXIgPSBoYW5kbGVyICsgZ2QtPnJlbG9jX29mZjsKCWlycV9oYW5kbGVyc1tpcnFdLmFyZyA9IGFyZzsKCWlycV9oYW5kbGVyc1tpcnFdLmNvdW50ID0gMDsKCgl1bm1hc2tfaXJxKGlycSk7CgoJaWYgKHN0YXR1cykKCQllbmFibGVfaW50ZXJydXB0cygpOwoKCXJldHVybjsKfQoKdm9pZCBpcnFfZnJlZV9oYW5kbGVyKGludCBpcnEpCnsKCWludCBzdGF0dXM7CgoJaWYgKGlycSA8IDAgfHwgaXJxID49IENPTkZJR19TWVNfTlVNX0lSUVMpIHsKCQlwcmludGYoImlycV9mcmVlX2hhbmRsZXI6IGJhZCBpcnEgbnVtYmVyICVkXG4iLCBpcnEpOwoJCXJldHVybjsKCX0KCglzdGF0dXMgPSBkaXNhYmxlX2ludGVycnVwdHMgKCk7CgoJbWFza19pcnEoaXJxKTsKCglpcnFfaGFuZGxlcnNbaXJxXS5oYW5kbGVyID0gTlVMTDsKCWlycV9oYW5kbGVyc1tpcnFdLmFyZyA9IE5VTEw7CgoJaWYgKHN0YXR1cykKCQllbmFibGVfaW50ZXJydXB0cygpOwoKCXJldHVybjsKfQoKX19pc3JfXyBkb19pcnEoaW50IGlycSkKewoJaWYgKGlycSA8IDAgfHwgaXJxID49IENPTkZJR19TWVNfTlVNX0lSUVMpIHsKCQlwcmludGYoImRvX2lycTogYmFkIGlycSBudW1iZXIgJWRcbiIsIGlycSk7CgkJcmV0dXJuOwoJfQoKCWlmIChpcnFfaGFuZGxlcnNbaXJxXS5oYW5kbGVyKSB7CgkJbWFza19pcnEoaXJxKTsKCgkJaXJxX2hhbmRsZXJzW2lycV0uaGFuZGxlcihpcnFfaGFuZGxlcnNbaXJxXS5hcmcpOwoJCWlycV9oYW5kbGVyc1tpcnFdLmNvdW50Kys7CgoJCXVubWFza19pcnEoaXJxKTsKCQlzcGVjaWZpY19lb2koaXJxKTsKCgl9IGVsc2UgewoJCWlmICgoaXJxICYgNykgIT0gNykgewoJCQlzcHVyaW91c19pcnFfY250Kys7CgkJCXNwdXJpb3VzX2lycSA9IGlycTsKCQl9Cgl9Cn0KCiNpZiBkZWZpbmVkKENPTkZJR19DTURfSVJRKQppbnQgZG9faXJxaW5mbyhjbWRfdGJsX3QgKmNtZHRwLCBpbnQgZmxhZywgaW50IGFyZ2MsIGNoYXIgKmFyZ3ZbXSkKewoJaW50IGlycTsKCglwcmludGYoIlNwdXJpb3VzIElSUTogJXUsIGxhc3QgdW5rbm93biBJUlE6ICVkXG4iLAoJICAgICAgIHNwdXJpb3VzX2lycV9jbnQsIHNwdXJpb3VzX2lycSk7CgoJcHJpbnRmICgiSW50ZXJydXB0LUluZm9ybWF0aW9uOlxuIik7CglwcmludGYgKCJOciAgUm91dGluZSAgIEFyZyAgICAgICBDb3VudFxuIik7CgoJZm9yIChpcnEgPSAwOyBpcnEgPD0gQ09ORklHX1NZU19OVU1fSVJRUzsgaXJxKyspIHsKCQlpZiAoaXJxX2hhbmRsZXJzW2lycV0uaGFuZGxlciAhPSBOVUxMKSB7CgkJCXByaW50ZiAoIiUwMmQgICUwOGx4ICAlMDhseCAgJWRcbiIsCgkJCQkJaXJxLAoJCQkJCSh1bG9uZylpcnFfaGFuZGxlcnNbaXJxXS5oYW5kbGVyLAoJCQkJCSh1bG9uZylpcnFfaGFuZGxlcnNbaXJxXS5hcmcsCgkJCQkJaXJxX2hhbmRsZXJzW2lycV0uY291bnQpOwoJCX0KCX0KCglyZXR1cm4gMDsKfQojZW5kaWYK