LyoKICogbGludXgvZHJpdmVycy91c2IvZ2FkZ2V0L3MzYzI0MTBfdWRjLmMKICoKICogU2Ftc3VuZyBTM0MyNHh4IHNlcmllcyBvbi1jaGlwIGZ1bGwgc3BlZWQgVVNCIGRldmljZSBjb250cm9sbGVycwogKgogKiBDb3B5cmlnaHQgKEMpIDIwMDQtMjAwNyBIZXJiZXJ0IFD2dHpsIC0gQXJuYXVkIFBhdGFyZAogKglBZGRpdGlvbmFsIGNsZWFudXBzIGJ5IEJlbiBEb29rcyA8YmVuLWxpbnV4QGZsdWZmLm9yZz4KICoKICogVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9vciBtb2RpZnkKICogaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcyBwdWJsaXNoZWQgYnkKICogdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyIHZlcnNpb24gMiBvZiB0aGUgTGljZW5zZSwgb3IKICogKGF0IHlvdXIgb3B0aW9uKSBhbnkgbGF0ZXIgdmVyc2lvbi4KICoKICogVGhpcyBwcm9ncmFtIGlzIGRpc3RyaWJ1dGVkIGluIHRoZSBob3BlIHRoYXQgaXQgd2lsbCBiZSB1c2VmdWwsCiAqIGJ1dCBXSVRIT1VUIEFOWSBXQVJSQU5UWTsgd2l0aG91dCBldmVuIHRoZSBpbXBsaWVkIHdhcnJhbnR5IG9mCiAqIE1FUkNIQU5UQUJJTElUWSBvciBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gIFNlZSB0aGUKICogR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KICoKICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UKICogYWxvbmcgd2l0aCB0aGlzIHByb2dyYW07IGlmIG5vdCwgd3JpdGUgdG8gdGhlIEZyZWUgU29mdHdhcmUKICogRm91bmRhdGlvbiwgSW5jLiwgNTkgVGVtcGxlIFBsYWNlLCBTdWl0ZSAzMzAsIEJvc3RvbiwgTUEgIDAyMTExLTEzMDcgIFVTQQogKgogKi8KCiNpbmNsdWRlIDxsaW51eC9tb2R1bGUuaD4KI2luY2x1ZGUgPGxpbnV4L2tlcm5lbC5oPgojaW5jbHVkZSA8bGludXgvZGVsYXkuaD4KI2luY2x1ZGUgPGxpbnV4L2lvcG9ydC5oPgojaW5jbHVkZSA8bGludXgvc2NoZWQuaD4KI2luY2x1ZGUgPGxpbnV4L3NsYWIuaD4KI2luY2x1ZGUgPGxpbnV4L2Vycm5vLmg+CiNpbmNsdWRlIDxsaW51eC9pbml0Lmg+CiNpbmNsdWRlIDxsaW51eC90aW1lci5oPgojaW5jbHVkZSA8bGludXgvbGlzdC5oPgojaW5jbHVkZSA8bGludXgvaW50ZXJydXB0Lmg+CiNpbmNsdWRlIDxsaW51eC9wbGF0Zm9ybV9kZXZpY2UuaD4KI2luY2x1ZGUgPGxpbnV4L2Nsay5oPgojaW5jbHVkZSA8bGludXgvZ3Bpby5oPgojaW5jbHVkZSA8bGludXgvcHJlZmV0Y2guaD4KCiNpbmNsdWRlIDxsaW51eC9kZWJ1Z2ZzLmg+CiNpbmNsdWRlIDxsaW51eC9zZXFfZmlsZS5oPgoKI2luY2x1ZGUgPGxpbnV4L3VzYi5oPgojaW5jbHVkZSA8bGludXgvdXNiL2dhZGdldC5oPgoKI2luY2x1ZGUgPGFzbS9ieXRlb3JkZXIuaD4KI2luY2x1ZGUgPGFzbS9pby5oPgojaW5jbHVkZSA8YXNtL2lycS5oPgojaW5jbHVkZSA8YXNtL3N5c3RlbS5oPgojaW5jbHVkZSA8YXNtL3VuYWxpZ25lZC5oPgojaW5jbHVkZSA8bWFjaC9pcnFzLmg+CgojaW5jbHVkZSA8bWFjaC9oYXJkd2FyZS5oPgoKI2luY2x1ZGUgPHBsYXQvcmVncy11ZGMuaD4KI2luY2x1ZGUgPHBsYXQvdWRjLmg+CgoKI2luY2x1ZGUgInMzYzI0MTBfdWRjLmgiCgojZGVmaW5lIERSSVZFUl9ERVNDCSJTM0MyNDEwIFVTQiBEZXZpY2UgQ29udHJvbGxlciBHYWRnZXQiCiNkZWZpbmUgRFJJVkVSX1ZFUlNJT04JIjI5IEFwciAyMDA3IgojZGVmaW5lIERSSVZFUl9BVVRIT1IJIkhlcmJlcnQgUPZ0emwgPGhlcmJlcnRAMTN0aGZsb29yLmF0PiwgIiBcCgkJCSJBcm5hdWQgUGF0YXJkIDxhcm5hdWQucGF0YXJkQHJ0cC1uZXQub3JnPiIKCnN0YXRpYyBjb25zdCBjaGFyCQlnYWRnZXRfbmFtZVtdID0gInMzYzI0MTBfdWRjIjsKc3RhdGljIGNvbnN0IGNoYXIJCWRyaXZlcl9kZXNjW10gPSBEUklWRVJfREVTQzsKCnN0YXRpYyBzdHJ1Y3QgczNjMjQxMF91ZGMJKnRoZV9jb250cm9sbGVyOwpzdGF0aWMgc3RydWN0IGNsawkJKnVkY19jbG9jazsKc3RhdGljIHN0cnVjdCBjbGsJCSp1c2JfYnVzX2Nsb2NrOwpzdGF0aWMgdm9pZCBfX2lvbWVtCQkqYmFzZV9hZGRyOwpzdGF0aWMgdTY0CQkJcnNyY19zdGFydDsKc3RhdGljIHU2NAkJCXJzcmNfbGVuOwpzdGF0aWMgc3RydWN0IGRlbnRyeQkJKnMzYzI0MTBfdWRjX2RlYnVnZnNfcm9vdDsKCnN0YXRpYyBpbmxpbmUgdTMyIHVkY19yZWFkKHUzMiByZWcpCnsKCXJldHVybiByZWFkYihiYXNlX2FkZHIgKyByZWcpOwp9CgpzdGF0aWMgaW5saW5lIHZvaWQgdWRjX3dyaXRlKHUzMiB2YWx1ZSwgdTMyIHJlZykKewoJd3JpdGViKHZhbHVlLCBiYXNlX2FkZHIgKyByZWcpOwp9CgpzdGF0aWMgaW5saW5lIHZvaWQgdWRjX3dyaXRlYih2b2lkIF9faW9tZW0gKmJhc2UsIHUzMiB2YWx1ZSwgdTMyIHJlZykKewoJd3JpdGViKHZhbHVlLCBiYXNlICsgcmVnKTsKfQoKc3RhdGljIHN0cnVjdCBzM2MyNDEwX3VkY19tYWNoX2luZm8gKnVkY19pbmZvOwoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKiBERUJVRyBGVU5DVElPTiAqKioqKioqKioqKioqKioqKioqKioqKioqKiovCiNkZWZpbmUgREVCVUdfTk9STUFMCTEKI2RlZmluZSBERUJVR19WRVJCT1NFCTIKCiNpZmRlZiBDT05GSUdfVVNCX1MzQzI0MTBfREVCVUcKI2RlZmluZSBVU0JfUzNDMjQxMF9ERUJVR19MRVZFTCAwCgpzdGF0aWMgdWludDMyX3QgczNjMjQxMF90aWNrcyA9IDA7CgpzdGF0aWMgaW50IGRwcmludGsoaW50IGxldmVsLCBjb25zdCBjaGFyICpmbXQsIC4uLikKewoJc3RhdGljIGNoYXIgcHJpbnRrX2J1ZlsxMDI0XTsKCXN0YXRpYyBsb25nIHByZXZ0aWNrczsKCXN0YXRpYyBpbnQgaW52b2NhdGlvbjsKCXZhX2xpc3QgYXJnczsKCWludCBsZW47CgoJaWYgKGxldmVsID4gVVNCX1MzQzI0MTBfREVCVUdfTEVWRUwpCgkJcmV0dXJuIDA7CgoJaWYgKHMzYzI0MTBfdGlja3MgIT0gcHJldnRpY2tzKSB7CgkJcHJldnRpY2tzID0gczNjMjQxMF90aWNrczsKCQlpbnZvY2F0aW9uID0gMDsKCX0KCglsZW4gPSBzY25wcmludGYocHJpbnRrX2J1ZiwKCQkJc2l6ZW9mKHByaW50a19idWYpLCAiJTFsdS4lMDJkIFVTQjogIiwKCQkJcHJldnRpY2tzLCBpbnZvY2F0aW9uKyspOwoKCXZhX3N0YXJ0KGFyZ3MsIGZtdCk7CglsZW4gPSB2c2NucHJpbnRmKHByaW50a19idWYrbGVuLAoJCQlzaXplb2YocHJpbnRrX2J1ZiktbGVuLCBmbXQsIGFyZ3MpOwoJdmFfZW5kKGFyZ3MpOwoKCXJldHVybiBwcmludGsoS0VSTl9ERUJVRyAiJXMiLCBwcmludGtfYnVmKTsKfQojZWxzZQpzdGF0aWMgaW50IGRwcmludGsoaW50IGxldmVsLCBjb25zdCBjaGFyICpmbXQsIC4uLikKewoJcmV0dXJuIDA7Cn0KI2VuZGlmCnN0YXRpYyBpbnQgczNjMjQxMF91ZGNfZGVidWdmc19zZXFfc2hvdyhzdHJ1Y3Qgc2VxX2ZpbGUgKm0sIHZvaWQgKnApCnsKCXUzMiBhZGRyX3JlZyxwd3JfcmVnLGVwX2ludF9yZWcsdXNiX2ludF9yZWc7Cgl1MzIgZXBfaW50X2VuX3JlZywgdXNiX2ludF9lbl9yZWcsIGVwMF9jc3I7Cgl1MzIgZXAxX2lfY3NyMSxlcDFfaV9jc3IyLGVwMV9vX2NzcjEsZXAxX29fY3NyMjsKCXUzMiBlcDJfaV9jc3IxLGVwMl9pX2NzcjIsZXAyX29fY3NyMSxlcDJfb19jc3IyOwoKCWFkZHJfcmVnICAgICAgID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfRlVOQ19BRERSX1JFRyk7Cglwd3JfcmVnICAgICAgICA9IHVkY19yZWFkKFMzQzI0MTBfVURDX1BXUl9SRUcpOwoJZXBfaW50X3JlZyAgICAgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19FUF9JTlRfUkVHKTsKCXVzYl9pbnRfcmVnICAgID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfVVNCX0lOVF9SRUcpOwoJZXBfaW50X2VuX3JlZyAgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19FUF9JTlRfRU5fUkVHKTsKCXVzYl9pbnRfZW5fcmVnID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfVVNCX0lOVF9FTl9SRUcpOwoJdWRjX3dyaXRlKDAsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgllcDBfY3NyICAgICAgICA9IHVkY19yZWFkKFMzQzI0MTBfVURDX0lOX0NTUjFfUkVHKTsKCXVkY193cml0ZSgxLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJZXAxX2lfY3NyMSAgICAgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyk7CgllcDFfaV9jc3IyICAgICA9IHVkY19yZWFkKFMzQzI0MTBfVURDX0lOX0NTUjJfUkVHKTsKCWVwMV9vX2NzcjEgICAgID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfSU5fQ1NSMV9SRUcpOwoJZXAxX29fY3NyMiAgICAgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19JTl9DU1IyX1JFRyk7Cgl1ZGNfd3JpdGUoMiwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCWVwMl9pX2NzcjEgICAgID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfSU5fQ1NSMV9SRUcpOwoJZXAyX2lfY3NyMiAgICAgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19JTl9DU1IyX1JFRyk7CgllcDJfb19jc3IxICAgICA9IHVkY19yZWFkKFMzQzI0MTBfVURDX0lOX0NTUjFfUkVHKTsKCWVwMl9vX2NzcjIgICAgID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfSU5fQ1NSMl9SRUcpOwoKCXNlcV9wcmludGYobSwgIkZVTkNfQUREUl9SRUcgIDogMHglMDRYXG4iCgkJICJQV1JfUkVHICAgICAgICA6IDB4JTA0WFxuIgoJCSAiRVBfSU5UX1JFRyAgICAgOiAweCUwNFhcbiIKCQkgIlVTQl9JTlRfUkVHICAgIDogMHglMDRYXG4iCgkJICJFUF9JTlRfRU5fUkVHICA6IDB4JTA0WFxuIgoJCSAiVVNCX0lOVF9FTl9SRUcgOiAweCUwNFhcbiIKCQkgIkVQMF9DU1IgICAgICAgIDogMHglMDRYXG4iCgkJICJFUDFfSV9DU1IxICAgICA6IDB4JTA0WFxuIgoJCSAiRVAxX0lfQ1NSMiAgICAgOiAweCUwNFhcbiIKCQkgIkVQMV9PX0NTUjEgICAgIDogMHglMDRYXG4iCgkJICJFUDFfT19DU1IyICAgICA6IDB4JTA0WFxuIgoJCSAiRVAyX0lfQ1NSMSAgICAgOiAweCUwNFhcbiIKCQkgIkVQMl9JX0NTUjIgICAgIDogMHglMDRYXG4iCgkJICJFUDJfT19DU1IxICAgICA6IDB4JTA0WFxuIgoJCSAiRVAyX09fQ1NSMiAgICAgOiAweCUwNFhcbiIsCgkJCWFkZHJfcmVnLHB3cl9yZWcsZXBfaW50X3JlZyx1c2JfaW50X3JlZywKCQkJZXBfaW50X2VuX3JlZywgdXNiX2ludF9lbl9yZWcsIGVwMF9jc3IsCgkJCWVwMV9pX2NzcjEsZXAxX2lfY3NyMixlcDFfb19jc3IxLGVwMV9vX2NzcjIsCgkJCWVwMl9pX2NzcjEsZXAyX2lfY3NyMixlcDJfb19jc3IxLGVwMl9vX2NzcjIKCQkpOwoKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX2RlYnVnZnNfZm9wc19vcGVuKHN0cnVjdCBpbm9kZSAqaW5vZGUsCgkJCQkJIHN0cnVjdCBmaWxlICpmaWxlKQp7CglyZXR1cm4gc2luZ2xlX29wZW4oZmlsZSwgczNjMjQxMF91ZGNfZGVidWdmc19zZXFfc2hvdywgTlVMTCk7Cn0KCnN0YXRpYyBjb25zdCBzdHJ1Y3QgZmlsZV9vcGVyYXRpb25zIHMzYzI0MTBfdWRjX2RlYnVnZnNfZm9wcyA9IHsKCS5vcGVuCQk9IHMzYzI0MTBfdWRjX2RlYnVnZnNfZm9wc19vcGVuLAoJLnJlYWQJCT0gc2VxX3JlYWQsCgkubGxzZWVrCQk9IHNlcV9sc2VlaywKCS5yZWxlYXNlCT0gc2luZ2xlX3JlbGVhc2UsCgkub3duZXIJCT0gVEhJU19NT0RVTEUsCn07CgovKiBpbyBtYWNyb3MgKi8KCnN0YXRpYyBpbmxpbmUgdm9pZCBzM2MyNDEwX3VkY19jbGVhcl9lcDBfb3ByKHZvaWQgX19pb21lbSAqYmFzZSkKewoJdWRjX3dyaXRlYihiYXNlLCBTM0MyNDEwX1VEQ19JTkRFWF9FUDAsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7Cgl1ZGNfd3JpdGViKGJhc2UsIFMzQzI0MTBfVURDX0VQMF9DU1JfU09QS1RSRFksCgkJCVMzQzI0MTBfVURDX0VQMF9DU1JfUkVHKTsKfQoKc3RhdGljIGlubGluZSB2b2lkIHMzYzI0MTBfdWRjX2NsZWFyX2VwMF9zc3Qodm9pZCBfX2lvbWVtICpiYXNlKQp7Cgl1ZGNfd3JpdGViKGJhc2UsIFMzQzI0MTBfVURDX0lOREVYX0VQMCwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCXdyaXRlYigweDAwLCBiYXNlICsgUzNDMjQxMF9VRENfRVAwX0NTUl9SRUcpOwp9CgpzdGF0aWMgaW5saW5lIHZvaWQgczNjMjQxMF91ZGNfY2xlYXJfZXAwX3NlKHZvaWQgX19pb21lbSAqYmFzZSkKewoJdWRjX3dyaXRlYihiYXNlLCBTM0MyNDEwX1VEQ19JTkRFWF9FUDAsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7Cgl1ZGNfd3JpdGViKGJhc2UsIFMzQzI0MTBfVURDX0VQMF9DU1JfU1NFLCBTM0MyNDEwX1VEQ19FUDBfQ1NSX1JFRyk7Cn0KCnN0YXRpYyBpbmxpbmUgdm9pZCBzM2MyNDEwX3VkY19zZXRfZXAwX2lwcih2b2lkIF9faW9tZW0gKmJhc2UpCnsKCXVkY193cml0ZWIoYmFzZSwgUzNDMjQxMF9VRENfSU5ERVhfRVAwLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJdWRjX3dyaXRlYihiYXNlLCBTM0MyNDEwX1VEQ19FUDBfQ1NSX0lQS1JEWSwgUzNDMjQxMF9VRENfRVAwX0NTUl9SRUcpOwp9CgpzdGF0aWMgaW5saW5lIHZvaWQgczNjMjQxMF91ZGNfc2V0X2VwMF9kZSh2b2lkIF9faW9tZW0gKmJhc2UpCnsKCXVkY193cml0ZWIoYmFzZSwgUzNDMjQxMF9VRENfSU5ERVhfRVAwLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJdWRjX3dyaXRlYihiYXNlLCBTM0MyNDEwX1VEQ19FUDBfQ1NSX0RFLCBTM0MyNDEwX1VEQ19FUDBfQ1NSX1JFRyk7Cn0KCmlubGluZSB2b2lkIHMzYzI0MTBfdWRjX3NldF9lcDBfc3Modm9pZCBfX2lvbWVtICpiKQp7Cgl1ZGNfd3JpdGViKGIsIFMzQzI0MTBfVURDX0lOREVYX0VQMCwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCXVkY193cml0ZWIoYiwgUzNDMjQxMF9VRENfRVAwX0NTUl9TRU5EU1RMLCBTM0MyNDEwX1VEQ19FUDBfQ1NSX1JFRyk7Cn0KCnN0YXRpYyBpbmxpbmUgdm9pZCBzM2MyNDEwX3VkY19zZXRfZXAwX2RlX291dCh2b2lkIF9faW9tZW0gKmJhc2UpCnsKCXVkY193cml0ZWIoYmFzZSwgUzNDMjQxMF9VRENfSU5ERVhfRVAwLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoKCXVkY193cml0ZWIoYmFzZSwoUzNDMjQxMF9VRENfRVAwX0NTUl9TT1BLVFJEWQoJCQkJfCBTM0MyNDEwX1VEQ19FUDBfQ1NSX0RFKSwKCQkJUzNDMjQxMF9VRENfRVAwX0NTUl9SRUcpOwp9CgpzdGF0aWMgaW5saW5lIHZvaWQgczNjMjQxMF91ZGNfc2V0X2VwMF9zc2Vfb3V0KHZvaWQgX19pb21lbSAqYmFzZSkKewoJdWRjX3dyaXRlYihiYXNlLCBTM0MyNDEwX1VEQ19JTkRFWF9FUDAsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7Cgl1ZGNfd3JpdGViKGJhc2UsIChTM0MyNDEwX1VEQ19FUDBfQ1NSX1NPUEtUUkRZCgkJCQl8IFMzQzI0MTBfVURDX0VQMF9DU1JfU1NFKSwKCQkJUzNDMjQxMF9VRENfRVAwX0NTUl9SRUcpOwp9CgpzdGF0aWMgaW5saW5lIHZvaWQgczNjMjQxMF91ZGNfc2V0X2VwMF9kZV9pbih2b2lkIF9faW9tZW0gKmJhc2UpCnsKCXVkY193cml0ZWIoYmFzZSwgUzNDMjQxMF9VRENfSU5ERVhfRVAwLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJdWRjX3dyaXRlYihiYXNlLCAoUzNDMjQxMF9VRENfRVAwX0NTUl9JUEtSRFkKCQkJfCBTM0MyNDEwX1VEQ19FUDBfQ1NSX0RFKSwKCQlTM0MyNDEwX1VEQ19FUDBfQ1NSX1JFRyk7Cn0KCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSBJL08gLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCgovKgogKglzM2MyNDEwX3VkY19kb25lCiAqLwpzdGF0aWMgdm9pZCBzM2MyNDEwX3VkY19kb25lKHN0cnVjdCBzM2MyNDEwX2VwICplcCwKCQlzdHJ1Y3QgczNjMjQxMF9yZXF1ZXN0ICpyZXEsIGludCBzdGF0dXMpCnsKCXVuc2lnbmVkIGhhbHRlZCA9IGVwLT5oYWx0ZWQ7CgoJbGlzdF9kZWxfaW5pdCgmcmVxLT5xdWV1ZSk7CgoJaWYgKGxpa2VseSAocmVxLT5yZXEuc3RhdHVzID09IC1FSU5QUk9HUkVTUykpCgkJcmVxLT5yZXEuc3RhdHVzID0gc3RhdHVzOwoJZWxzZQoJCXN0YXR1cyA9IHJlcS0+cmVxLnN0YXR1czsKCgllcC0+aGFsdGVkID0gMTsKCXJlcS0+cmVxLmNvbXBsZXRlKCZlcC0+ZXAsICZyZXEtPnJlcSk7CgllcC0+aGFsdGVkID0gaGFsdGVkOwp9CgpzdGF0aWMgdm9pZCBzM2MyNDEwX3VkY19udWtlKHN0cnVjdCBzM2MyNDEwX3VkYyAqdWRjLAoJCXN0cnVjdCBzM2MyNDEwX2VwICplcCwgaW50IHN0YXR1cykKewoJLyogU2FuaXR5IGNoZWNrICovCglpZiAoJmVwLT5xdWV1ZSA9PSBOVUxMKQoJCXJldHVybjsKCgl3aGlsZSAoIWxpc3RfZW1wdHkgKCZlcC0+cXVldWUpKSB7CgkJc3RydWN0IHMzYzI0MTBfcmVxdWVzdCAqcmVxOwoJCXJlcSA9IGxpc3RfZW50cnkgKGVwLT5xdWV1ZS5uZXh0LCBzdHJ1Y3QgczNjMjQxMF9yZXF1ZXN0LAoJCQkJcXVldWUpOwoJCXMzYzI0MTBfdWRjX2RvbmUoZXAsIHJlcSwgc3RhdHVzKTsKCX0KfQoKc3RhdGljIGlubGluZSB2b2lkIHMzYzI0MTBfdWRjX2NsZWFyX2VwX3N0YXRlKHN0cnVjdCBzM2MyNDEwX3VkYyAqZGV2KQp7Cgl1bnNpZ25lZCBpOwoKCS8qIGhhcmR3YXJlIFNFVF97Q09ORklHVVJBVElPTixJTlRFUkZBQ0V9IGF1dG9tYWdpYyByZXNldHMgZW5kcG9pbnQKCSAqIGZpZm9zLCBhbmQgcGVuZGluZyB0cmFuc2FjdGlvbnMgbXVzdG4ndCBiZSBjb250aW51ZWQgaW4gYW55IGNhc2UuCgkgKi8KCglmb3IgKGkgPSAxOyBpIDwgUzNDMjQxMF9FTkRQT0lOVFM7IGkrKykKCQlzM2MyNDEwX3VkY19udWtlKGRldiwgJmRldi0+ZXBbaV0sIC1FQ09OTkFCT1JURUQpOwp9CgpzdGF0aWMgaW5saW5lIGludCBzM2MyNDEwX3VkY19maWZvX2NvdW50X291dCh2b2lkKQp7CglpbnQgdG1wOwoKCXRtcCA9IHVkY19yZWFkKFMzQzI0MTBfVURDX09VVF9GSUZPX0NOVDJfUkVHKSA8PCA4OwoJdG1wIHw9IHVkY19yZWFkKFMzQzI0MTBfVURDX09VVF9GSUZPX0NOVDFfUkVHKTsKCXJldHVybiB0bXA7Cn0KCi8qCiAqCXMzYzI0MTBfdWRjX3dyaXRlX3BhY2tldAogKi8Kc3RhdGljIGlubGluZSBpbnQgczNjMjQxMF91ZGNfd3JpdGVfcGFja2V0KGludCBmaWZvLAoJCXN0cnVjdCBzM2MyNDEwX3JlcXVlc3QgKnJlcSwKCQl1bnNpZ25lZCBtYXgpCnsKCXVuc2lnbmVkIGxlbiA9IG1pbihyZXEtPnJlcS5sZW5ndGggLSByZXEtPnJlcS5hY3R1YWwsIG1heCk7Cgl1OCAqYnVmID0gcmVxLT5yZXEuYnVmICsgcmVxLT5yZXEuYWN0dWFsOwoKCXByZWZldGNoKGJ1Zik7CgoJZHByaW50ayhERUJVR19WRVJCT1NFLCAiJXMgJWQgJWQgJWQgJWRcbiIsIF9fZnVuY19fLAoJCXJlcS0+cmVxLmFjdHVhbCwgcmVxLT5yZXEubGVuZ3RoLCBsZW4sIHJlcS0+cmVxLmFjdHVhbCArIGxlbik7CgoJcmVxLT5yZXEuYWN0dWFsICs9IGxlbjsKCgl1ZGVsYXkoNSk7Cgl3cml0ZXNiKGJhc2VfYWRkciArIGZpZm8sIGJ1ZiwgbGVuKTsKCXJldHVybiBsZW47Cn0KCi8qCiAqCXMzYzI0MTBfdWRjX3dyaXRlX2ZpZm8KICoKICogcmV0dXJuOiAgMCA9IHN0aWxsIHJ1bm5pbmcsIDEgPSBjb21wbGV0ZWQsIG5lZ2F0aXZlID0gZXJybm8KICovCnN0YXRpYyBpbnQgczNjMjQxMF91ZGNfd3JpdGVfZmlmbyhzdHJ1Y3QgczNjMjQxMF9lcCAqZXAsCgkJc3RydWN0IHMzYzI0MTBfcmVxdWVzdCAqcmVxKQp7Cgl1bnNpZ25lZAljb3VudDsKCWludAkJaXNfbGFzdDsKCXUzMgkJaWR4OwoJaW50CQlmaWZvX3JlZzsKCXUzMgkJZXBfY3NyOwoKCWlkeCA9IGVwLT5iRW5kcG9pbnRBZGRyZXNzICYgMHg3RjsKCXN3aXRjaCAoaWR4KSB7CglkZWZhdWx0OgoJCWlkeCA9IDA7CgljYXNlIDA6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDBfRklGT19SRUc7CgkJYnJlYWs7CgljYXNlIDE6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDFfRklGT19SRUc7CgkJYnJlYWs7CgljYXNlIDI6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDJfRklGT19SRUc7CgkJYnJlYWs7CgljYXNlIDM6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDNfRklGT19SRUc7CgkJYnJlYWs7CgljYXNlIDQ6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDRfRklGT19SRUc7CgkJYnJlYWs7Cgl9CgoJY291bnQgPSBzM2MyNDEwX3VkY193cml0ZV9wYWNrZXQoZmlmb19yZWcsIHJlcSwgZXAtPmVwLm1heHBhY2tldCk7CgoJLyogbGFzdCBwYWNrZXQgaXMgb2Z0ZW4gc2hvcnQgKHNvbWV0aW1lcyBhIHpscCkgKi8KCWlmIChjb3VudCAhPSBlcC0+ZXAubWF4cGFja2V0KQoJCWlzX2xhc3QgPSAxOwoJZWxzZSBpZiAocmVxLT5yZXEubGVuZ3RoICE9IHJlcS0+cmVxLmFjdHVhbCB8fCByZXEtPnJlcS56ZXJvKQoJCWlzX2xhc3QgPSAwOwoJZWxzZQoJCWlzX2xhc3QgPSAyOwoKCS8qIE9ubHkgZXAwIGRlYnVnIG1lc3NhZ2VzIGFyZSBpbnRlcmVzdGluZyAqLwoJaWYgKGlkeCA9PSAwKQoJCWRwcmludGsoREVCVUdfTk9STUFMLAoJCQkiV3JpdHRlbiBlcCVkICVkLiVkIG9mICVkIGIgW2xhc3QgJWQseiAlZF1cbiIsCgkJCWlkeCwgY291bnQsIHJlcS0+cmVxLmFjdHVhbCwgcmVxLT5yZXEubGVuZ3RoLAoJCQlpc19sYXN0LCByZXEtPnJlcS56ZXJvKTsKCglpZiAoaXNfbGFzdCkgewoJCS8qIFRoZSBvcmRlciBpcyBpbXBvcnRhbnQuIEl0IHByZXZlbnRzIHNlbmRpbmcgMiBwYWNrZXRzCgkJICogYXQgdGhlIHNhbWUgdGltZSAqLwoKCQlpZiAoaWR4ID09IDApIHsKCQkJLyogUmVzZXQgc2lnbmFsID0+IG5vIG5lZWQgdG8gc2F5ICdkYXRhIHNlbnQnICovCgkJCWlmICghICh1ZGNfcmVhZChTM0MyNDEwX1VEQ19VU0JfSU5UX1JFRykKCQkJCQkmIFMzQzI0MTBfVURDX1VTQklOVF9SRVNFVCkpCgkJCQlzM2MyNDEwX3VkY19zZXRfZXAwX2RlX2luKGJhc2VfYWRkcik7CgkJCWVwLT5kZXYtPmVwMHN0YXRlPUVQMF9JRExFOwoJCX0gZWxzZSB7CgkJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJCWVwX2NzciA9IHVkY19yZWFkKFMzQzI0MTBfVURDX0lOX0NTUjFfUkVHKTsKCQkJdWRjX3dyaXRlKGlkeCwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCQkJdWRjX3dyaXRlKGVwX2NzciB8IFMzQzI0MTBfVURDX0lDU1IxX1BLVFJEWSwKCQkJCQlTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyk7CgkJfQoKCQlzM2MyNDEwX3VkY19kb25lKGVwLCByZXEsIDApOwoJCWlzX2xhc3QgPSAxOwoJfSBlbHNlIHsKCQlpZiAoaWR4ID09IDApIHsKCQkJLyogUmVzZXQgc2lnbmFsID0+IG5vIG5lZWQgdG8gc2F5ICdkYXRhIHNlbnQnICovCgkJCWlmICghICh1ZGNfcmVhZChTM0MyNDEwX1VEQ19VU0JfSU5UX1JFRykKCQkJCQkmIFMzQzI0MTBfVURDX1VTQklOVF9SRVNFVCkpCgkJCQlzM2MyNDEwX3VkY19zZXRfZXAwX2lwcihiYXNlX2FkZHIpOwoJCX0gZWxzZSB7CgkJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJCWVwX2NzciA9IHVkY19yZWFkKFMzQzI0MTBfVURDX0lOX0NTUjFfUkVHKTsKCQkJdWRjX3dyaXRlKGlkeCwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCQkJdWRjX3dyaXRlKGVwX2NzciB8IFMzQzI0MTBfVURDX0lDU1IxX1BLVFJEWSwKCQkJCQlTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyk7CgkJfQoJfQoKCXJldHVybiBpc19sYXN0Owp9CgpzdGF0aWMgaW5saW5lIGludCBzM2MyNDEwX3VkY19yZWFkX3BhY2tldChpbnQgZmlmbywgdTggKmJ1ZiwKCQlzdHJ1Y3QgczNjMjQxMF9yZXF1ZXN0ICpyZXEsIHVuc2lnbmVkIGF2YWlsKQp7Cgl1bnNpZ25lZCBsZW47CgoJbGVuID0gbWluKHJlcS0+cmVxLmxlbmd0aCAtIHJlcS0+cmVxLmFjdHVhbCwgYXZhaWwpOwoJcmVxLT5yZXEuYWN0dWFsICs9IGxlbjsKCglyZWFkc2IoZmlmbyArIGJhc2VfYWRkciwgYnVmLCBsZW4pOwoJcmV0dXJuIGxlbjsKfQoKLyoKICogcmV0dXJuOiAgMCA9IHN0aWxsIHJ1bm5pbmcsIDEgPSBxdWV1ZSBlbXB0eSwgbmVnYXRpdmUgPSBlcnJubwogKi8Kc3RhdGljIGludCBzM2MyNDEwX3VkY19yZWFkX2ZpZm8oc3RydWN0IHMzYzI0MTBfZXAgKmVwLAoJCQkJIHN0cnVjdCBzM2MyNDEwX3JlcXVlc3QgKnJlcSkKewoJdTgJCSpidWY7Cgl1MzIJCWVwX2NzcjsKCXVuc2lnbmVkCWJ1ZmZlcnNwYWNlOwoJaW50CQlpc19sYXN0PTE7Cgl1bnNpZ25lZAlhdmFpbDsKCWludAkJZmlmb19jb3VudCA9IDA7Cgl1MzIJCWlkeDsKCWludAkJZmlmb19yZWc7CgoJaWR4ID0gZXAtPmJFbmRwb2ludEFkZHJlc3MgJiAweDdGOwoKCXN3aXRjaCAoaWR4KSB7CglkZWZhdWx0OgoJCWlkeCA9IDA7CgljYXNlIDA6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDBfRklGT19SRUc7CgkJYnJlYWs7CgljYXNlIDE6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDFfRklGT19SRUc7CgkJYnJlYWs7CgljYXNlIDI6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDJfRklGT19SRUc7CgkJYnJlYWs7CgljYXNlIDM6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDNfRklGT19SRUc7CgkJYnJlYWs7CgljYXNlIDQ6CgkJZmlmb19yZWcgPSBTM0MyNDEwX1VEQ19FUDRfRklGT19SRUc7CgkJYnJlYWs7Cgl9CgoJaWYgKCFyZXEtPnJlcS5sZW5ndGgpCgkJcmV0dXJuIDE7CgoJYnVmID0gcmVxLT5yZXEuYnVmICsgcmVxLT5yZXEuYWN0dWFsOwoJYnVmZmVyc3BhY2UgPSByZXEtPnJlcS5sZW5ndGggLSByZXEtPnJlcS5hY3R1YWw7CglpZiAoIWJ1ZmZlcnNwYWNlKSB7CgkJZHByaW50ayhERUJVR19OT1JNQUwsICIlczogYnVmZmVyIGZ1bGwhXG4iLCBfX2Z1bmNfXyk7CgkJcmV0dXJuIC0xOwoJfQoKCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgoJZmlmb19jb3VudCA9IHMzYzI0MTBfdWRjX2ZpZm9fY291bnRfb3V0KCk7CglkcHJpbnRrKERFQlVHX05PUk1BTCwgIiVzIGZpZm8gY291bnQgOiAlZFxuIiwgX19mdW5jX18sIGZpZm9fY291bnQpOwoKCWlmIChmaWZvX2NvdW50ID4gZXAtPmVwLm1heHBhY2tldCkKCQlhdmFpbCA9IGVwLT5lcC5tYXhwYWNrZXQ7CgllbHNlCgkJYXZhaWwgPSBmaWZvX2NvdW50OwoKCWZpZm9fY291bnQgPSBzM2MyNDEwX3VkY19yZWFkX3BhY2tldChmaWZvX3JlZywgYnVmLCByZXEsIGF2YWlsKTsKCgkvKiBjaGVja2luZyB0aGlzIHdpdGggZXAwIGlzIG5vdCBhY2N1cmF0ZSBhcyB3ZSBhbHJlYWR5CgkgKiByZWFkIGEgY29udHJvbCByZXF1ZXN0CgkgKiovCglpZiAoaWR4ICE9IDAgJiYgZmlmb19jb3VudCA8IGVwLT5lcC5tYXhwYWNrZXQpIHsKCQlpc19sYXN0ID0gMTsKCQkvKiBvdmVyZmxvd2VkIHRoaXMgcmVxdWVzdD8gIGZsdXNoIGV4dHJhIGRhdGEgKi8KCQlpZiAoZmlmb19jb3VudCAhPSBhdmFpbCkKCQkJcmVxLT5yZXEuc3RhdHVzID0gLUVPVkVSRkxPVzsKCX0gZWxzZSB7CgkJaXNfbGFzdCA9IChyZXEtPnJlcS5sZW5ndGggPD0gcmVxLT5yZXEuYWN0dWFsKSA/IDEgOiAwOwoJfQoKCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CglmaWZvX2NvdW50ID0gczNjMjQxMF91ZGNfZmlmb19jb3VudF9vdXQoKTsKCgkvKiBPbmx5IGVwMCBkZWJ1ZyBtZXNzYWdlcyBhcmUgaW50ZXJlc3RpbmcgKi8KCWlmIChpZHggPT0gMCkKCQlkcHJpbnRrKERFQlVHX1ZFUkJPU0UsICIlcyBmaWZvIGNvdW50IDogJWQgW2xhc3QgJWRdXG4iLAoJCQlfX2Z1bmNfXywgZmlmb19jb3VudCxpc19sYXN0KTsKCglpZiAoaXNfbGFzdCkgewoJCWlmIChpZHggPT0gMCkgewoJCQlzM2MyNDEwX3VkY19zZXRfZXAwX2RlX291dChiYXNlX2FkZHIpOwoJCQllcC0+ZGV2LT5lcDBzdGF0ZSA9IEVQMF9JRExFOwoJCX0gZWxzZSB7CgkJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJCWVwX2NzciA9IHVkY19yZWFkKFMzQzI0MTBfVURDX09VVF9DU1IxX1JFRyk7CgkJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJCXVkY193cml0ZShlcF9jc3IgJiB+UzNDMjQxMF9VRENfT0NTUjFfUEtUUkRZLAoJCQkJCVMzQzI0MTBfVURDX09VVF9DU1IxX1JFRyk7CgkJfQoKCQlzM2MyNDEwX3VkY19kb25lKGVwLCByZXEsIDApOwoJfSBlbHNlIHsKCQlpZiAoaWR4ID09IDApIHsKCQkJczNjMjQxMF91ZGNfY2xlYXJfZXAwX29wcihiYXNlX2FkZHIpOwoJCX0gZWxzZSB7CgkJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJCWVwX2NzciA9IHVkY19yZWFkKFMzQzI0MTBfVURDX09VVF9DU1IxX1JFRyk7CgkJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJCXVkY193cml0ZShlcF9jc3IgJiB+UzNDMjQxMF9VRENfT0NTUjFfUEtUUkRZLAoJCQkJCVMzQzI0MTBfVURDX09VVF9DU1IxX1JFRyk7CgkJfQoJfQoKCXJldHVybiBpc19sYXN0Owp9CgpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX3JlYWRfZmlmb19jcnEoc3RydWN0IHVzYl9jdHJscmVxdWVzdCAqY3JxKQp7Cgl1bnNpZ25lZCBjaGFyICpvdXRidWYgPSAodW5zaWduZWQgY2hhciopY3JxOwoJaW50IGJ5dGVzX3JlYWQgPSAwOwoKCXVkY193cml0ZSgwLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoKCWJ5dGVzX3JlYWQgPSBzM2MyNDEwX3VkY19maWZvX2NvdW50X291dCgpOwoKCWRwcmludGsoREVCVUdfTk9STUFMLCAiJXM6IGZpZm9fY291bnQ9JWRcbiIsIF9fZnVuY19fLCBieXRlc19yZWFkKTsKCglpZiAoYnl0ZXNfcmVhZCA+IHNpemVvZihzdHJ1Y3QgdXNiX2N0cmxyZXF1ZXN0KSkKCQlieXRlc19yZWFkID0gc2l6ZW9mKHN0cnVjdCB1c2JfY3RybHJlcXVlc3QpOwoKCXJlYWRzYihTM0MyNDEwX1VEQ19FUDBfRklGT19SRUcgKyBiYXNlX2FkZHIsIG91dGJ1ZiwgYnl0ZXNfcmVhZCk7CgoJZHByaW50ayhERUJVR19WRVJCT1NFLCAiJXM6IGxlbj0lZCAlMDJ4OiUwMnggeyV4LCV4LCV4fVxuIiwgX19mdW5jX18sCgkJYnl0ZXNfcmVhZCwgY3JxLT5iUmVxdWVzdCwgY3JxLT5iUmVxdWVzdFR5cGUsCgkJY3JxLT53VmFsdWUsIGNycS0+d0luZGV4LCBjcnEtPndMZW5ndGgpOwoKCXJldHVybiBieXRlc19yZWFkOwp9CgpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX2dldF9zdGF0dXMoc3RydWN0IHMzYzI0MTBfdWRjICpkZXYsCgkJc3RydWN0IHVzYl9jdHJscmVxdWVzdCAqY3JxKQp7Cgl1MTYgc3RhdHVzID0gMDsKCXU4IGVwX251bSA9IGNycS0+d0luZGV4ICYgMHg3RjsKCXU4IGlzX2luID0gY3JxLT53SW5kZXggJiBVU0JfRElSX0lOOwoKCXN3aXRjaCAoY3JxLT5iUmVxdWVzdFR5cGUgJiBVU0JfUkVDSVBfTUFTSykgewoJY2FzZSBVU0JfUkVDSVBfSU5URVJGQUNFOgoJCWJyZWFrOwoKCWNhc2UgVVNCX1JFQ0lQX0RFVklDRToKCQlzdGF0dXMgPSBkZXYtPmRldnN0YXR1czsKCQlicmVhazsKCgljYXNlIFVTQl9SRUNJUF9FTkRQT0lOVDoKCQlpZiAoZXBfbnVtID4gNCB8fCBjcnEtPndMZW5ndGggPiAyKQoJCQlyZXR1cm4gMTsKCgkJaWYgKGVwX251bSA9PSAwKSB7CgkJCXVkY193cml0ZSgwLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJCQlzdGF0dXMgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyk7CgkJCXN0YXR1cyA9IHN0YXR1cyAmIFMzQzI0MTBfVURDX0VQMF9DU1JfU0VORFNUTDsKCQl9IGVsc2UgewoJCQl1ZGNfd3JpdGUoZXBfbnVtLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJCQlpZiAoaXNfaW4pIHsKCQkJCXN0YXR1cyA9IHVkY19yZWFkKFMzQzI0MTBfVURDX0lOX0NTUjFfUkVHKTsKCQkJCXN0YXR1cyA9IHN0YXR1cyAmIFMzQzI0MTBfVURDX0lDU1IxX1NFTkRTVEw7CgkJCX0gZWxzZSB7CgkJCQlzdGF0dXMgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19PVVRfQ1NSMV9SRUcpOwoJCQkJc3RhdHVzID0gc3RhdHVzICYgUzNDMjQxMF9VRENfT0NTUjFfU0VORFNUTDsKCQkJfQoJCX0KCgkJc3RhdHVzID0gc3RhdHVzID8gMSA6IDA7CgkJYnJlYWs7CgoJZGVmYXVsdDoKCQlyZXR1cm4gMTsKCX0KCgkvKiBTZWVtcyB0byBiZSBuZWVkZWQgdG8gZ2V0IGl0IHdvcmtpbmcuIG91Y2ggOiggKi8KCXVkZWxheSg1KTsKCXVkY193cml0ZShzdGF0dXMgJiAweEZGLCBTM0MyNDEwX1VEQ19FUDBfRklGT19SRUcpOwoJdWRjX3dyaXRlKHN0YXR1cyA+PiA4LCBTM0MyNDEwX1VEQ19FUDBfRklGT19SRUcpOwoJczNjMjQxMF91ZGNfc2V0X2VwMF9kZV9pbihiYXNlX2FkZHIpOwoKCXJldHVybiAwOwp9Ci8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSB1c2Igc3RhdGUgbWFjaGluZSAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKi8Kc3RhdGljIGludCBzM2MyNDEwX3VkY19zZXRfaGFsdChzdHJ1Y3QgdXNiX2VwICpfZXAsIGludCB2YWx1ZSk7CgpzdGF0aWMgdm9pZCBzM2MyNDEwX3VkY19oYW5kbGVfZXAwX2lkbGUoc3RydWN0IHMzYzI0MTBfdWRjICpkZXYsCgkJCQkJc3RydWN0IHMzYzI0MTBfZXAgKmVwLAoJCQkJCXN0cnVjdCB1c2JfY3RybHJlcXVlc3QgKmNycSwKCQkJCQl1MzIgZXAwY3NyKQp7CglpbnQgbGVuLCByZXQsIHRtcDsKCgkvKiBzdGFydCBjb250cm9sIHJlcXVlc3Q/ICovCglpZiAoIShlcDBjc3IgJiBTM0MyNDEwX1VEQ19FUDBfQ1NSX09QS1JEWSkpCgkJcmV0dXJuOwoKCXMzYzI0MTBfdWRjX251a2UoZGV2LCBlcCwgLUVQUk9UTyk7CgoJbGVuID0gczNjMjQxMF91ZGNfcmVhZF9maWZvX2NycShjcnEpOwoJaWYgKGxlbiAhPSBzaXplb2YoKmNycSkpIHsKCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgInNldHVwIGJlZ2luOiBmaWZvIFJFQUQgRVJST1IiCgkJCSIgd2FudGVkICVkIGJ5dGVzIGdvdCAlZC4gU3RhbGxpbmcgb3V0Li4uXG4iLAoJCQlzaXplb2YoKmNycSksIGxlbik7CgkJczNjMjQxMF91ZGNfc2V0X2VwMF9zcyhiYXNlX2FkZHIpOwoJCXJldHVybjsKCX0KCglkcHJpbnRrKERFQlVHX05PUk1BTCwgImJSZXF1ZXN0ID0gJWQgYlJlcXVlc3RUeXBlICVkIHdMZW5ndGggPSAlZFxuIiwKCQljcnEtPmJSZXF1ZXN0LCBjcnEtPmJSZXF1ZXN0VHlwZSwgY3JxLT53TGVuZ3RoKTsKCgkvKiBjb3BlIHdpdGggYXV0b21hZ2ljIGZvciBzb21lIHN0YW5kYXJkIHJlcXVlc3RzLiAqLwoJZGV2LT5yZXFfc3RkID0gKGNycS0+YlJlcXVlc3RUeXBlICYgVVNCX1RZUEVfTUFTSykKCQk9PSBVU0JfVFlQRV9TVEFOREFSRDsKCWRldi0+cmVxX2NvbmZpZyA9IDA7CglkZXYtPnJlcV9wZW5kaW5nID0gMTsKCglzd2l0Y2ggKGNycS0+YlJlcXVlc3QpIHsKCWNhc2UgVVNCX1JFUV9TRVRfQ09ORklHVVJBVElPTjoKCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgIlVTQl9SRVFfU0VUX0NPTkZJR1VSQVRJT04gLi4uIFxuIik7CgoJCWlmIChjcnEtPmJSZXF1ZXN0VHlwZSA9PSBVU0JfUkVDSVBfREVWSUNFKSB7CgkJCWRldi0+cmVxX2NvbmZpZyA9IDE7CgkJCXMzYzI0MTBfdWRjX3NldF9lcDBfZGVfb3V0KGJhc2VfYWRkcik7CgkJfQoJCWJyZWFrOwoKCWNhc2UgVVNCX1JFUV9TRVRfSU5URVJGQUNFOgoJCWRwcmludGsoREVCVUdfTk9STUFMLCAiVVNCX1JFUV9TRVRfSU5URVJGQUNFIC4uLiBcbiIpOwoKCQlpZiAoY3JxLT5iUmVxdWVzdFR5cGUgPT0gVVNCX1JFQ0lQX0lOVEVSRkFDRSkgewoJCQlkZXYtPnJlcV9jb25maWcgPSAxOwoJCQlzM2MyNDEwX3VkY19zZXRfZXAwX2RlX291dChiYXNlX2FkZHIpOwoJCX0KCQlicmVhazsKCgljYXNlIFVTQl9SRVFfU0VUX0FERFJFU1M6CgkJZHByaW50ayhERUJVR19OT1JNQUwsICJVU0JfUkVRX1NFVF9BRERSRVNTIC4uLiBcbiIpOwoKCQlpZiAoY3JxLT5iUmVxdWVzdFR5cGUgPT0gVVNCX1JFQ0lQX0RFVklDRSkgewoJCQl0bXAgPSBjcnEtPndWYWx1ZSAmIDB4N0Y7CgkJCWRldi0+YWRkcmVzcyA9IHRtcDsKCQkJdWRjX3dyaXRlKCh0bXAgfCBTM0MyNDEwX1VEQ19GVU5DQUREUl9VUERBVEUpLAoJCQkJCVMzQzI0MTBfVURDX0ZVTkNfQUREUl9SRUcpOwoJCQlzM2MyNDEwX3VkY19zZXRfZXAwX2RlX291dChiYXNlX2FkZHIpOwoJCQlyZXR1cm47CgkJfQoJCWJyZWFrOwoKCWNhc2UgVVNCX1JFUV9HRVRfU1RBVFVTOgoJCWRwcmludGsoREVCVUdfTk9STUFMLCAiVVNCX1JFUV9HRVRfU1RBVFVTIC4uLiBcbiIpOwoJCXMzYzI0MTBfdWRjX2NsZWFyX2VwMF9vcHIoYmFzZV9hZGRyKTsKCgkJaWYgKGRldi0+cmVxX3N0ZCkgewoJCQlpZiAoIXMzYzI0MTBfdWRjX2dldF9zdGF0dXMoZGV2LCBjcnEpKSB7CgkJCQlyZXR1cm47CgkJCX0KCQl9CgkJYnJlYWs7CgoJY2FzZSBVU0JfUkVRX0NMRUFSX0ZFQVRVUkU6CgkJczNjMjQxMF91ZGNfY2xlYXJfZXAwX29wcihiYXNlX2FkZHIpOwoKCQlpZiAoY3JxLT5iUmVxdWVzdFR5cGUgIT0gVVNCX1JFQ0lQX0VORFBPSU5UKQoJCQlicmVhazsKCgkJaWYgKGNycS0+d1ZhbHVlICE9IFVTQl9FTkRQT0lOVF9IQUxUIHx8IGNycS0+d0xlbmd0aCAhPSAwKQoJCQlicmVhazsKCgkJczNjMjQxMF91ZGNfc2V0X2hhbHQoJmRldi0+ZXBbY3JxLT53SW5kZXggJiAweDdmXS5lcCwgMCk7CgkJczNjMjQxMF91ZGNfc2V0X2VwMF9kZV9vdXQoYmFzZV9hZGRyKTsKCQlyZXR1cm47CgoJY2FzZSBVU0JfUkVRX1NFVF9GRUFUVVJFOgoJCXMzYzI0MTBfdWRjX2NsZWFyX2VwMF9vcHIoYmFzZV9hZGRyKTsKCgkJaWYgKGNycS0+YlJlcXVlc3RUeXBlICE9IFVTQl9SRUNJUF9FTkRQT0lOVCkKCQkJYnJlYWs7CgoJCWlmIChjcnEtPndWYWx1ZSAhPSBVU0JfRU5EUE9JTlRfSEFMVCB8fCBjcnEtPndMZW5ndGggIT0gMCkKCQkJYnJlYWs7CgoJCXMzYzI0MTBfdWRjX3NldF9oYWx0KCZkZXYtPmVwW2NycS0+d0luZGV4ICYgMHg3Zl0uZXAsIDEpOwoJCXMzYzI0MTBfdWRjX3NldF9lcDBfZGVfb3V0KGJhc2VfYWRkcik7CgkJcmV0dXJuOwoKCWRlZmF1bHQ6CgkJczNjMjQxMF91ZGNfY2xlYXJfZXAwX29wcihiYXNlX2FkZHIpOwoJCWJyZWFrOwoJfQoKCWlmIChjcnEtPmJSZXF1ZXN0VHlwZSAmIFVTQl9ESVJfSU4pCgkJZGV2LT5lcDBzdGF0ZSA9IEVQMF9JTl9EQVRBX1BIQVNFOwoJZWxzZQoJCWRldi0+ZXAwc3RhdGUgPSBFUDBfT1VUX0RBVEFfUEhBU0U7CgoJaWYgKCFkZXYtPmRyaXZlcikKCQlyZXR1cm47CgoJLyogZGVsaXZlciB0aGUgcmVxdWVzdCB0byB0aGUgZ2FkZ2V0IGRyaXZlciAqLwoJcmV0ID0gZGV2LT5kcml2ZXItPnNldHVwKCZkZXYtPmdhZGdldCwgY3JxKTsKCWlmIChyZXQgPCAwKSB7CgkJaWYgKGRldi0+cmVxX2NvbmZpZykgewoJCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgImNvbmZpZyBjaGFuZ2UgJTAyeCBmYWlsICVkP1xuIiwKCQkJCWNycS0+YlJlcXVlc3QsIHJldCk7CgkJCXJldHVybjsKCQl9CgoJCWlmIChyZXQgPT0gLUVPUE5PVFNVUFApCgkJCWRwcmludGsoREVCVUdfTk9STUFMLCAiT3BlcmF0aW9uIG5vdCBzdXBwb3J0ZWRcbiIpOwoJCWVsc2UKCQkJZHByaW50ayhERUJVR19OT1JNQUwsCgkJCQkiZGV2LT5kcml2ZXItPnNldHVwIGZhaWxlZC4gKCVkKVxuIiwgcmV0KTsKCgkJdWRlbGF5KDUpOwoJCXMzYzI0MTBfdWRjX3NldF9lcDBfc3MoYmFzZV9hZGRyKTsKCQlzM2MyNDEwX3VkY19zZXRfZXAwX2RlX291dChiYXNlX2FkZHIpOwoJCWRldi0+ZXAwc3RhdGUgPSBFUDBfSURMRTsKCQkvKiBkZWZlcnJlZCBpL28gPT0gbm8gcmVzcG9uc2UgeWV0ICovCgl9IGVsc2UgaWYgKGRldi0+cmVxX3BlbmRpbmcpIHsKCQlkcHJpbnRrKERFQlVHX1ZFUkJPU0UsICJkZXYtPnJlcV9wZW5kaW5nLi4uIHdoYXQgbm93P1xuIik7CgkJZGV2LT5yZXFfcGVuZGluZz0wOwoJfQoKCWRwcmludGsoREVCVUdfVkVSQk9TRSwgImVwMHN0YXRlICVzXG4iLCBlcDBzdGF0ZXNbZGV2LT5lcDBzdGF0ZV0pOwp9CgpzdGF0aWMgdm9pZCBzM2MyNDEwX3VkY19oYW5kbGVfZXAwKHN0cnVjdCBzM2MyNDEwX3VkYyAqZGV2KQp7Cgl1MzIJCQllcDBjc3I7CglzdHJ1Y3QgczNjMjQxMF9lcAkqZXAgPSAmZGV2LT5lcFswXTsKCXN0cnVjdCBzM2MyNDEwX3JlcXVlc3QJKnJlcTsKCXN0cnVjdCB1c2JfY3RybHJlcXVlc3QJY3JxOwoKCWlmIChsaXN0X2VtcHR5KCZlcC0+cXVldWUpKQoJCXJlcSA9IE5VTEw7CgllbHNlCgkJcmVxID0gbGlzdF9lbnRyeShlcC0+cXVldWUubmV4dCwgc3RydWN0IHMzYzI0MTBfcmVxdWVzdCwgcXVldWUpOwoKCS8qIFdlIG1ha2UgdGhlIGFzc3VtcHRpb24gdGhhdCBTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyBlcXVhbCB0bwoJICogUzNDMjQxMF9VRENfRVAwX0NTUl9SRUcgd2hlbiBpbmRleCBpcyB6ZXJvICovCgoJdWRjX3dyaXRlKDAsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgllcDBjc3IgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyk7CgoJZHByaW50ayhERUJVR19OT1JNQUwsICJlcDBjc3IgJXggZXAwc3RhdGUgJXNcbiIsCgkJZXAwY3NyLCBlcDBzdGF0ZXNbZGV2LT5lcDBzdGF0ZV0pOwoKCS8qIGNsZWFyIHN0YWxsIHN0YXR1cyAqLwoJaWYgKGVwMGNzciAmIFMzQzI0MTBfVURDX0VQMF9DU1JfU0VOVFNUTCkgewoJCXMzYzI0MTBfdWRjX251a2UoZGV2LCBlcCwgLUVQSVBFKTsKCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgIi4uLiBjbGVhciBTRU5UX1NUQUxMIC4uLlxuIik7CgkJczNjMjQxMF91ZGNfY2xlYXJfZXAwX3NzdChiYXNlX2FkZHIpOwoJCWRldi0+ZXAwc3RhdGUgPSBFUDBfSURMRTsKCQlyZXR1cm47Cgl9CgoJLyogY2xlYXIgc2V0dXAgZW5kICovCglpZiAoZXAwY3NyICYgUzNDMjQxMF9VRENfRVAwX0NTUl9TRSkgewoJCWRwcmludGsoREVCVUdfTk9STUFMLCAiLi4uIHNlcnZpY2VkIFNFVFVQX0VORCAuLi5cbiIpOwoJCXMzYzI0MTBfdWRjX251a2UoZGV2LCBlcCwgMCk7CgkJczNjMjQxMF91ZGNfY2xlYXJfZXAwX3NlKGJhc2VfYWRkcik7CgkJZGV2LT5lcDBzdGF0ZSA9IEVQMF9JRExFOwoJfQoKCXN3aXRjaCAoZGV2LT5lcDBzdGF0ZSkgewoJY2FzZSBFUDBfSURMRToKCQlzM2MyNDEwX3VkY19oYW5kbGVfZXAwX2lkbGUoZGV2LCBlcCwgJmNycSwgZXAwY3NyKTsKCQlicmVhazsKCgljYXNlIEVQMF9JTl9EQVRBX1BIQVNFOgkJCS8qIEdFVF9ERVNDUklQVE9SIGV0YyAqLwoJCWRwcmludGsoREVCVUdfTk9STUFMLCAiRVAwX0lOX0RBVEFfUEhBU0UgLi4uIHdoYXQgbm93P1xuIik7CgkJaWYgKCEoZXAwY3NyICYgUzNDMjQxMF9VRENfRVAwX0NTUl9JUEtSRFkpICYmIHJlcSkgewoJCQlzM2MyNDEwX3VkY193cml0ZV9maWZvKGVwLCByZXEpOwoJCX0KCQlicmVhazsKCgljYXNlIEVQMF9PVVRfREFUQV9QSEFTRToJCS8qIFNFVF9ERVNDUklQVE9SIGV0YyAqLwoJCWRwcmludGsoREVCVUdfTk9STUFMLCAiRVAwX09VVF9EQVRBX1BIQVNFIC4uLiB3aGF0IG5vdz9cbiIpOwoJCWlmICgoZXAwY3NyICYgUzNDMjQxMF9VRENfRVAwX0NTUl9PUEtSRFkpICYmIHJlcSApIHsKCQkJczNjMjQxMF91ZGNfcmVhZF9maWZvKGVwLHJlcSk7CgkJfQoJCWJyZWFrOwoKCWNhc2UgRVAwX0VORF9YRkVSOgoJCWRwcmludGsoREVCVUdfTk9STUFMLCAiRVAwX0VORF9YRkVSIC4uLiB3aGF0IG5vdz9cbiIpOwoJCWRldi0+ZXAwc3RhdGUgPSBFUDBfSURMRTsKCQlicmVhazsKCgljYXNlIEVQMF9TVEFMTDoKCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgIkVQMF9TVEFMTCAuLi4gd2hhdCBub3c/XG4iKTsKCQlkZXYtPmVwMHN0YXRlID0gRVAwX0lETEU7CgkJYnJlYWs7Cgl9Cn0KCi8qCiAqCWhhbmRsZV9lcCAtIE1hbmFnZSBJL08gZW5kcG9pbnRzCiAqLwoKc3RhdGljIHZvaWQgczNjMjQxMF91ZGNfaGFuZGxlX2VwKHN0cnVjdCBzM2MyNDEwX2VwICplcCkKewoJc3RydWN0IHMzYzI0MTBfcmVxdWVzdAkqcmVxOwoJaW50CQkJaXNfaW4gPSBlcC0+YkVuZHBvaW50QWRkcmVzcyAmIFVTQl9ESVJfSU47Cgl1MzIJCQllcF9jc3IxOwoJdTMyCQkJaWR4OwoKCWlmIChsaWtlbHkgKCFsaXN0X2VtcHR5KCZlcC0+cXVldWUpKSkKCQlyZXEgPSBsaXN0X2VudHJ5KGVwLT5xdWV1ZS5uZXh0LAoJCQkJc3RydWN0IHMzYzI0MTBfcmVxdWVzdCwgcXVldWUpOwoJZWxzZQoJCXJlcSA9IE5VTEw7CgoJaWR4ID0gZXAtPmJFbmRwb2ludEFkZHJlc3MgJiAweDdGOwoKCWlmIChpc19pbikgewoJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJZXBfY3NyMSA9IHVkY19yZWFkKFMzQzI0MTBfVURDX0lOX0NTUjFfUkVHKTsKCQlkcHJpbnRrKERFQlVHX1ZFUkJPU0UsICJlcCUwMWQgd3JpdGUgY3NyOiUwMnggJWRcbiIsCgkJCWlkeCwgZXBfY3NyMSwgcmVxID8gMSA6IDApOwoKCQlpZiAoZXBfY3NyMSAmIFMzQzI0MTBfVURDX0lDU1IxX1NFTlRTVEwpIHsKCQkJZHByaW50ayhERUJVR19WRVJCT1NFLCAic3RcbiIpOwoJCQl1ZGNfd3JpdGUoaWR4LCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJCQl1ZGNfd3JpdGUoZXBfY3NyMSAmIH5TM0MyNDEwX1VEQ19JQ1NSMV9TRU5UU1RMLAoJCQkJCVMzQzI0MTBfVURDX0lOX0NTUjFfUkVHKTsKCQkJcmV0dXJuOwoJCX0KCgkJaWYgKCEoZXBfY3NyMSAmIFMzQzI0MTBfVURDX0lDU1IxX1BLVFJEWSkgJiYgcmVxKSB7CgkJCXMzYzI0MTBfdWRjX3dyaXRlX2ZpZm8oZXAscmVxKTsKCQl9Cgl9IGVsc2UgewoJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJZXBfY3NyMSA9IHVkY19yZWFkKFMzQzI0MTBfVURDX09VVF9DU1IxX1JFRyk7CgkJZHByaW50ayhERUJVR19WRVJCT1NFLCAiZXAlMDFkIHJkIGNzcjolMDJ4XG4iLCBpZHgsIGVwX2NzcjEpOwoKCQlpZiAoZXBfY3NyMSAmIFMzQzI0MTBfVURDX09DU1IxX1NFTlRTVEwpIHsKCQkJdWRjX3dyaXRlKGlkeCwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCQkJdWRjX3dyaXRlKGVwX2NzcjEgJiB+UzNDMjQxMF9VRENfT0NTUjFfU0VOVFNUTCwKCQkJCQlTM0MyNDEwX1VEQ19PVVRfQ1NSMV9SRUcpOwoJCQlyZXR1cm47CgkJfQoKCQlpZiAoKGVwX2NzcjEgJiBTM0MyNDEwX1VEQ19PQ1NSMV9QS1RSRFkpICYmIHJlcSkgewoJCQlzM2MyNDEwX3VkY19yZWFkX2ZpZm8oZXAscmVxKTsKCQl9Cgl9Cn0KCiNpbmNsdWRlIDxtYWNoL3JlZ3MtaXJxLmg+CgovKgogKglzM2MyNDEwX3VkY19pcnEgLSBpbnRlcnJ1cHQgaGFuZGxlcgogKi8Kc3RhdGljIGlycXJldHVybl90IHMzYzI0MTBfdWRjX2lycShpbnQgZHVtbXksIHZvaWQgKl9kZXYpCnsKCXN0cnVjdCBzM2MyNDEwX3VkYyAqZGV2ID0gX2RldjsKCWludCB1c2Jfc3RhdHVzOwoJaW50IHVzYmRfc3RhdHVzOwoJaW50IHB3cl9yZWc7CglpbnQgZXAwY3NyOwoJaW50IGk7Cgl1MzIgaWR4LCBpZHgyOwoJdW5zaWduZWQgbG9uZyBmbGFnczsKCglzcGluX2xvY2tfaXJxc2F2ZSgmZGV2LT5sb2NrLCBmbGFncyk7CgoJLyogRHJpdmVyIGNvbm5lY3RlZCA/ICovCglpZiAoIWRldi0+ZHJpdmVyKSB7CgkJLyogQ2xlYXIgaW50ZXJydXB0cyAqLwoJCXVkY193cml0ZSh1ZGNfcmVhZChTM0MyNDEwX1VEQ19VU0JfSU5UX1JFRyksCgkJCQlTM0MyNDEwX1VEQ19VU0JfSU5UX1JFRyk7CgkJdWRjX3dyaXRlKHVkY19yZWFkKFMzQzI0MTBfVURDX0VQX0lOVF9SRUcpLAoJCQkJUzNDMjQxMF9VRENfRVBfSU5UX1JFRyk7Cgl9CgoJLyogU2F2ZSBpbmRleCAqLwoJaWR4ID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCgkvKiBSZWFkIHN0YXR1cyByZWdpc3RlcnMgKi8KCXVzYl9zdGF0dXMgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19VU0JfSU5UX1JFRyk7Cgl1c2JkX3N0YXR1cyA9IHVkY19yZWFkKFMzQzI0MTBfVURDX0VQX0lOVF9SRUcpOwoJcHdyX3JlZyA9IHVkY19yZWFkKFMzQzI0MTBfVURDX1BXUl9SRUcpOwoKCXVkY193cml0ZWIoYmFzZV9hZGRyLCBTM0MyNDEwX1VEQ19JTkRFWF9FUDAsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgllcDBjc3IgPSB1ZGNfcmVhZChTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyk7CgoJZHByaW50ayhERUJVR19OT1JNQUwsICJ1c2JzPSUwMngsIHVzYmRzPSUwMngsIHB3cj0lMDJ4IGVwMGNzcj0lMDJ4XG4iLAoJCXVzYl9zdGF0dXMsIHVzYmRfc3RhdHVzLCBwd3JfcmVnLCBlcDBjc3IpOwoKCS8qCgkgKiBOb3csIGhhbmRsZSBpbnRlcnJ1cHRzLiBUaGVyZSdzIHR3byB0eXBlcyA6CgkgKiAtIFJlc2V0LCBSZXN1bWUsIFN1c3BlbmQgY29taW5nIC0+IHVzYl9pbnRfcmVnCgkgKiAtIEVQIC0+IGVwX2ludF9yZWcKCSAqLwoKCS8qIFJFU0VUICovCglpZiAodXNiX3N0YXR1cyAmIFMzQzI0MTBfVURDX1VTQklOVF9SRVNFVCkgewoJCS8qIHR3byBraW5kIG9mIHJlc2V0IDoKCQkgKiAtIHJlc2V0IHN0YXJ0IC0+IHB3ciByZWcgPSA4CgkJICogLSByZXNldCBlbmQgICAtPiBwd3IgcmVnID0gMAoJCSAqKi8KCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgIlVTQiByZXNldCBjc3IgJXggcHdyICV4XG4iLAoJCQllcDBjc3IsIHB3cl9yZWcpOwoKCQlkZXYtPmdhZGdldC5zcGVlZCA9IFVTQl9TUEVFRF9VTktOT1dOOwoJCXVkY193cml0ZSgweDAwLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJCXVkY193cml0ZSgoZGV2LT5lcFswXS5lcC5tYXhwYWNrZXQgJiAweDdmZikgPj4gMywKCQkJCVMzQzI0MTBfVURDX01BWFBfUkVHKTsKCQlkZXYtPmFkZHJlc3MgPSAwOwoKCQlkZXYtPmVwMHN0YXRlID0gRVAwX0lETEU7CgkJZGV2LT5nYWRnZXQuc3BlZWQgPSBVU0JfU1BFRURfRlVMTDsKCgkJLyogY2xlYXIgaW50ZXJydXB0ICovCgkJdWRjX3dyaXRlKFMzQzI0MTBfVURDX1VTQklOVF9SRVNFVCwKCQkJCVMzQzI0MTBfVURDX1VTQl9JTlRfUkVHKTsKCgkJdWRjX3dyaXRlKGlkeCwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZkZXYtPmxvY2ssIGZsYWdzKTsKCQlyZXR1cm4gSVJRX0hBTkRMRUQ7Cgl9CgoJLyogUkVTVU1FICovCglpZiAodXNiX3N0YXR1cyAmIFMzQzI0MTBfVURDX1VTQklOVF9SRVNVTUUpIHsKCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgIlVTQiByZXN1bWVcbiIpOwoKCQkvKiBjbGVhciBpbnRlcnJ1cHQgKi8KCQl1ZGNfd3JpdGUoUzNDMjQxMF9VRENfVVNCSU5UX1JFU1VNRSwKCQkJCVMzQzI0MTBfVURDX1VTQl9JTlRfUkVHKTsKCgkJaWYgKGRldi0+Z2FkZ2V0LnNwZWVkICE9IFVTQl9TUEVFRF9VTktOT1dOCgkJCQkmJiBkZXYtPmRyaXZlcgoJCQkJJiYgZGV2LT5kcml2ZXItPnJlc3VtZSkKCQkJZGV2LT5kcml2ZXItPnJlc3VtZSgmZGV2LT5nYWRnZXQpOwoJfQoKCS8qIFNVU1BFTkQgKi8KCWlmICh1c2Jfc3RhdHVzICYgUzNDMjQxMF9VRENfVVNCSU5UX1NVU1BFTkQpIHsKCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgIlVTQiBzdXNwZW5kXG4iKTsKCgkJLyogY2xlYXIgaW50ZXJydXB0ICovCgkJdWRjX3dyaXRlKFMzQzI0MTBfVURDX1VTQklOVF9TVVNQRU5ELAoJCQkJUzNDMjQxMF9VRENfVVNCX0lOVF9SRUcpOwoKCQlpZiAoZGV2LT5nYWRnZXQuc3BlZWQgIT0gVVNCX1NQRUVEX1VOS05PV04KCQkJCSYmIGRldi0+ZHJpdmVyCgkJCQkmJiBkZXYtPmRyaXZlci0+c3VzcGVuZCkKCQkJZGV2LT5kcml2ZXItPnN1c3BlbmQoJmRldi0+Z2FkZ2V0KTsKCgkJZGV2LT5lcDBzdGF0ZSA9IEVQMF9JRExFOwoJfQoKCS8qIEVQICovCgkvKiBjb250cm9sIHRyYWZmaWMgKi8KCS8qIGNoZWNrIG9uIGVwMGNzciAhPSAwIGlzIG5vdCBhIGdvb2QgaWRlYSBhcyBjbGVhcmluZyBpbl9wa3RfcmVhZHkKCSAqIGdlbmVyYXRlIGFuIGludGVycnVwdAoJICovCglpZiAodXNiZF9zdGF0dXMgJiBTM0MyNDEwX1VEQ19JTlRfRVAwKSB7CgkJZHByaW50ayhERUJVR19WRVJCT1NFLCAiVVNCIGVwMCBpcnFcbiIpOwoJCS8qIENsZWFyIHRoZSBpbnRlcnJ1cHQgYml0IGJ5IHNldHRpbmcgaXQgdG8gMSAqLwoJCXVkY193cml0ZShTM0MyNDEwX1VEQ19JTlRfRVAwLCBTM0MyNDEwX1VEQ19FUF9JTlRfUkVHKTsKCQlzM2MyNDEwX3VkY19oYW5kbGVfZXAwKGRldik7Cgl9CgoJLyogZW5kcG9pbnQgZGF0YSB0cmFuc2ZlcnMgKi8KCWZvciAoaSA9IDE7IGkgPCBTM0MyNDEwX0VORFBPSU5UUzsgaSsrKSB7CgkJdTMyIHRtcCA9IDEgPDwgaTsKCQlpZiAodXNiZF9zdGF0dXMgJiB0bXApIHsKCQkJZHByaW50ayhERUJVR19WRVJCT1NFLCAiVVNCIGVwJWQgaXJxXG4iLCBpKTsKCgkJCS8qIENsZWFyIHRoZSBpbnRlcnJ1cHQgYml0IGJ5IHNldHRpbmcgaXQgdG8gMSAqLwoJCQl1ZGNfd3JpdGUodG1wLCBTM0MyNDEwX1VEQ19FUF9JTlRfUkVHKTsKCQkJczNjMjQxMF91ZGNfaGFuZGxlX2VwKCZkZXYtPmVwW2ldKTsKCQl9Cgl9CgoJLyogd2hhdCBlbHNlIGNhdXNlcyB0aGlzIGludGVycnVwdD8gYSByZWNlaXZlISB3aG8gaXMgaXQ/ICovCglpZiAoIXVzYl9zdGF0dXMgJiYgIXVzYmRfc3RhdHVzICYmICFwd3JfcmVnICYmICFlcDBjc3IpIHsKCQlmb3IgKGkgPSAxOyBpIDwgUzNDMjQxMF9FTkRQT0lOVFM7IGkrKykgewoJCQlpZHgyID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCQkJdWRjX3dyaXRlKGksIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgoJCQlpZiAodWRjX3JlYWQoUzNDMjQxMF9VRENfT1VUX0NTUjFfUkVHKSAmIDB4MSkKCQkJCXMzYzI0MTBfdWRjX2hhbmRsZV9lcCgmZGV2LT5lcFtpXSk7CgoJCQkvKiByZXN0b3JlIGluZGV4ICovCgkJCXVkY193cml0ZShpZHgyLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJCX0KCX0KCglkcHJpbnRrKERFQlVHX1ZFUkJPU0UsICJpcnE6ICVkIHMzYzI0MTBfdWRjX2RvbmUuXG4iLCBJUlFfVVNCRCk7CgoJLyogUmVzdG9yZSBvbGQgaW5kZXggKi8KCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgoJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmZGV2LT5sb2NrLCBmbGFncyk7CgoJcmV0dXJuIElSUV9IQU5ETEVEOwp9Ci8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSBzM2MyNDEwX2VwX29wcyAtLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKi8KCnN0YXRpYyBpbmxpbmUgc3RydWN0IHMzYzI0MTBfZXAgKnRvX3MzYzI0MTBfZXAoc3RydWN0IHVzYl9lcCAqZXApCnsKCXJldHVybiBjb250YWluZXJfb2YoZXAsIHN0cnVjdCBzM2MyNDEwX2VwLCBlcCk7Cn0KCnN0YXRpYyBpbmxpbmUgc3RydWN0IHMzYzI0MTBfdWRjICp0b19zM2MyNDEwX3VkYyhzdHJ1Y3QgdXNiX2dhZGdldCAqZ2FkZ2V0KQp7CglyZXR1cm4gY29udGFpbmVyX29mKGdhZGdldCwgc3RydWN0IHMzYzI0MTBfdWRjLCBnYWRnZXQpOwp9CgpzdGF0aWMgaW5saW5lIHN0cnVjdCBzM2MyNDEwX3JlcXVlc3QgKnRvX3MzYzI0MTBfcmVxKHN0cnVjdCB1c2JfcmVxdWVzdCAqcmVxKQp7CglyZXR1cm4gY29udGFpbmVyX29mKHJlcSwgc3RydWN0IHMzYzI0MTBfcmVxdWVzdCwgcmVxKTsKfQoKLyoKICoJczNjMjQxMF91ZGNfZXBfZW5hYmxlCiAqLwpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX2VwX2VuYWJsZShzdHJ1Y3QgdXNiX2VwICpfZXAsCgkJCQkgY29uc3Qgc3RydWN0IHVzYl9lbmRwb2ludF9kZXNjcmlwdG9yICpkZXNjKQp7CglzdHJ1Y3QgczNjMjQxMF91ZGMJKmRldjsKCXN0cnVjdCBzM2MyNDEwX2VwCSplcDsKCXUzMgkJCW1heCwgdG1wOwoJdW5zaWduZWQgbG9uZwkJZmxhZ3M7Cgl1MzIJCQljc3IxLGNzcjI7Cgl1MzIJCQlpbnRfZW5fcmVnOwoKCWVwID0gdG9fczNjMjQxMF9lcChfZXApOwoKCWlmICghX2VwIHx8ICFkZXNjIHx8IGVwLT5kZXNjCgkJCXx8IF9lcC0+bmFtZSA9PSBlcDBuYW1lCgkJCXx8IGRlc2MtPmJEZXNjcmlwdG9yVHlwZSAhPSBVU0JfRFRfRU5EUE9JTlQpCgkJcmV0dXJuIC1FSU5WQUw7CgoJZGV2ID0gZXAtPmRldjsKCWlmICghZGV2LT5kcml2ZXIgfHwgZGV2LT5nYWRnZXQuc3BlZWQgPT0gVVNCX1NQRUVEX1VOS05PV04pCgkJcmV0dXJuIC1FU0hVVERPV047CgoJbWF4ID0gbGUxNl90b19jcHUoZGVzYy0+d01heFBhY2tldFNpemUpICYgMHgxZmZmOwoKCWxvY2FsX2lycV9zYXZlIChmbGFncyk7CglfZXAtPm1heHBhY2tldCA9IG1heCAmIDB4N2ZmOwoJZXAtPmRlc2MgPSBkZXNjOwoJZXAtPmhhbHRlZCA9IDA7CgllcC0+YkVuZHBvaW50QWRkcmVzcyA9IGRlc2MtPmJFbmRwb2ludEFkZHJlc3M7CgoJLyogc2V0IG1heCBwYWNrZXQgKi8KCXVkY193cml0ZShlcC0+bnVtLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJdWRjX3dyaXRlKG1heCA+PiAzLCBTM0MyNDEwX1VEQ19NQVhQX1JFRyk7CgoJLyogc2V0IHR5cGUsIGRpcmVjdGlvbiwgYWRkcmVzczsgcmVzZXQgZmlmbyBjb3VudGVycyAqLwoJaWYgKGRlc2MtPmJFbmRwb2ludEFkZHJlc3MgJiBVU0JfRElSX0lOKSB7CgkJY3NyMSA9IFMzQzI0MTBfVURDX0lDU1IxX0ZGTFVTSHxTM0MyNDEwX1VEQ19JQ1NSMV9DTFJEVDsKCQljc3IyID0gUzNDMjQxMF9VRENfSUNTUjJfTU9ERUlOfFMzQzI0MTBfVURDX0lDU1IyX0RNQUlFTjsKCgkJdWRjX3dyaXRlKGVwLT5udW0sIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJdWRjX3dyaXRlKGNzcjEsIFMzQzI0MTBfVURDX0lOX0NTUjFfUkVHKTsKCQl1ZGNfd3JpdGUoZXAtPm51bSwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCQl1ZGNfd3JpdGUoY3NyMiwgUzNDMjQxMF9VRENfSU5fQ1NSMl9SRUcpOwoJfSBlbHNlIHsKCQkvKiBkb24ndCBmbHVzaCBpbiBmaWZvIG9yIGl0IHdpbGwgY2F1c2UgZW5kcG9pbnQgaW50ZXJydXB0ICovCgkJY3NyMSA9IFMzQzI0MTBfVURDX0lDU1IxX0NMUkRUOwoJCWNzcjIgPSBTM0MyNDEwX1VEQ19JQ1NSMl9ETUFJRU47CgoJCXVkY193cml0ZShlcC0+bnVtLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJCXVkY193cml0ZShjc3IxLCBTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyk7CgkJdWRjX3dyaXRlKGVwLT5udW0sIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJdWRjX3dyaXRlKGNzcjIsIFMzQzI0MTBfVURDX0lOX0NTUjJfUkVHKTsKCgkJY3NyMSA9IFMzQzI0MTBfVURDX09DU1IxX0ZGTFVTSCB8IFMzQzI0MTBfVURDX09DU1IxX0NMUkRUOwoJCWNzcjIgPSBTM0MyNDEwX1VEQ19PQ1NSMl9ETUFJRU47CgoJCXVkY193cml0ZShlcC0+bnVtLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJCXVkY193cml0ZShjc3IxLCBTM0MyNDEwX1VEQ19PVVRfQ1NSMV9SRUcpOwoJCXVkY193cml0ZShlcC0+bnVtLCBTM0MyNDEwX1VEQ19JTkRFWF9SRUcpOwoJCXVkY193cml0ZShjc3IyLCBTM0MyNDEwX1VEQ19PVVRfQ1NSMl9SRUcpOwoJfQoKCS8qIGVuYWJsZSBpcnFzICovCglpbnRfZW5fcmVnID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfRVBfSU5UX0VOX1JFRyk7Cgl1ZGNfd3JpdGUoaW50X2VuX3JlZyB8ICgxIDw8IGVwLT5udW0pLCBTM0MyNDEwX1VEQ19FUF9JTlRfRU5fUkVHKTsKCgkvKiBwcmludCBzb21lIGRlYnVnIG1lc3NhZ2UgKi8KCXRtcCA9IGRlc2MtPmJFbmRwb2ludEFkZHJlc3M7CglkcHJpbnRrIChERUJVR19OT1JNQUwsICJlbmFibGUgJXMoJWQpIGVwJXglcy1ibGsgbWF4ICUwMnhcbiIsCgkJIF9lcC0+bmFtZSxlcC0+bnVtLCB0bXAsCgkJIGRlc2MtPmJFbmRwb2ludEFkZHJlc3MgJiBVU0JfRElSX0lOID8gImluIiA6ICJvdXQiLCBtYXgpOwoKCWxvY2FsX2lycV9yZXN0b3JlIChmbGFncyk7CglzM2MyNDEwX3VkY19zZXRfaGFsdChfZXAsIDApOwoKCXJldHVybiAwOwp9CgovKgogKiBzM2MyNDEwX3VkY19lcF9kaXNhYmxlCiAqLwpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX2VwX2Rpc2FibGUoc3RydWN0IHVzYl9lcCAqX2VwKQp7CglzdHJ1Y3QgczNjMjQxMF9lcCAqZXAgPSB0b19zM2MyNDEwX2VwKF9lcCk7Cgl1bnNpZ25lZCBsb25nIGZsYWdzOwoJdTMyIGludF9lbl9yZWc7CgoJaWYgKCFfZXAgfHwgIWVwLT5kZXNjKSB7CgkJZHByaW50ayhERUJVR19OT1JNQUwsICIlcyBub3QgZW5hYmxlZFxuIiwKCQkJX2VwID8gZXAtPmVwLm5hbWUgOiBOVUxMKTsKCQlyZXR1cm4gLUVJTlZBTDsKCX0KCglsb2NhbF9pcnFfc2F2ZShmbGFncyk7CgoJZHByaW50ayhERUJVR19OT1JNQUwsICJlcF9kaXNhYmxlOiAlc1xuIiwgX2VwLT5uYW1lKTsKCgllcC0+ZGVzYyA9IE5VTEw7CgllcC0+aGFsdGVkID0gMTsKCglzM2MyNDEwX3VkY19udWtlIChlcC0+ZGV2LCBlcCwgLUVTSFVURE9XTik7CgoJLyogZGlzYWJsZSBpcnFzICovCglpbnRfZW5fcmVnID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfRVBfSU5UX0VOX1JFRyk7Cgl1ZGNfd3JpdGUoaW50X2VuX3JlZyAmIH4oMTw8ZXAtPm51bSksIFMzQzI0MTBfVURDX0VQX0lOVF9FTl9SRUcpOwoKCWxvY2FsX2lycV9yZXN0b3JlKGZsYWdzKTsKCglkcHJpbnRrKERFQlVHX05PUk1BTCwgIiVzIGRpc2FibGVkXG4iLCBfZXAtPm5hbWUpOwoKCXJldHVybiAwOwp9CgovKgogKiBzM2MyNDEwX3VkY19hbGxvY19yZXF1ZXN0CiAqLwpzdGF0aWMgc3RydWN0IHVzYl9yZXF1ZXN0ICoKczNjMjQxMF91ZGNfYWxsb2NfcmVxdWVzdChzdHJ1Y3QgdXNiX2VwICpfZXAsIGdmcF90IG1lbV9mbGFncykKewoJc3RydWN0IHMzYzI0MTBfcmVxdWVzdCAqcmVxOwoKCWRwcmludGsoREVCVUdfVkVSQk9TRSwiJXMoJXAsJWQpXG4iLCBfX2Z1bmNfXywgX2VwLCBtZW1fZmxhZ3MpOwoKCWlmICghX2VwKQoJCXJldHVybiBOVUxMOwoKCXJlcSA9IGt6YWxsb2MgKHNpemVvZihzdHJ1Y3QgczNjMjQxMF9yZXF1ZXN0KSwgbWVtX2ZsYWdzKTsKCWlmICghcmVxKQoJCXJldHVybiBOVUxMOwoKCUlOSVRfTElTVF9IRUFEICgmcmVxLT5xdWV1ZSk7CglyZXR1cm4gJnJlcS0+cmVxOwp9CgovKgogKiBzM2MyNDEwX3VkY19mcmVlX3JlcXVlc3QKICovCnN0YXRpYyB2b2lkCnMzYzI0MTBfdWRjX2ZyZWVfcmVxdWVzdChzdHJ1Y3QgdXNiX2VwICpfZXAsIHN0cnVjdCB1c2JfcmVxdWVzdCAqX3JlcSkKewoJc3RydWN0IHMzYzI0MTBfZXAJKmVwID0gdG9fczNjMjQxMF9lcChfZXApOwoJc3RydWN0IHMzYzI0MTBfcmVxdWVzdAkqcmVxID0gdG9fczNjMjQxMF9yZXEoX3JlcSk7CgoJZHByaW50ayhERUJVR19WRVJCT1NFLCAiJXMoJXAsJXApXG4iLCBfX2Z1bmNfXywgX2VwLCBfcmVxKTsKCglpZiAoIWVwIHx8ICFfcmVxIHx8ICghZXAtPmRlc2MgJiYgX2VwLT5uYW1lICE9IGVwMG5hbWUpKQoJCXJldHVybjsKCglXQVJOX09OICghbGlzdF9lbXB0eSAoJnJlcS0+cXVldWUpKTsKCWtmcmVlKHJlcSk7Cn0KCi8qCiAqCXMzYzI0MTBfdWRjX3F1ZXVlCiAqLwpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX3F1ZXVlKHN0cnVjdCB1c2JfZXAgKl9lcCwgc3RydWN0IHVzYl9yZXF1ZXN0ICpfcmVxLAoJCWdmcF90IGdmcF9mbGFncykKewoJc3RydWN0IHMzYzI0MTBfcmVxdWVzdAkqcmVxID0gdG9fczNjMjQxMF9yZXEoX3JlcSk7CglzdHJ1Y3QgczNjMjQxMF9lcAkqZXAgPSB0b19zM2MyNDEwX2VwKF9lcCk7CglzdHJ1Y3QgczNjMjQxMF91ZGMJKmRldjsKCXUzMgkJCWVwX2NzciA9IDA7CglpbnQJCQlmaWZvX2NvdW50ID0gMDsKCXVuc2lnbmVkIGxvbmcJCWZsYWdzOwoKCWlmICh1bmxpa2VseSAoIV9lcCB8fCAoIWVwLT5kZXNjICYmIGVwLT5lcC5uYW1lICE9IGVwMG5hbWUpKSkgewoJCWRwcmludGsoREVCVUdfTk9STUFMLCAiJXM6IGludmFsaWQgYXJnc1xuIiwgX19mdW5jX18pOwoJCXJldHVybiAtRUlOVkFMOwoJfQoKCWRldiA9IGVwLT5kZXY7CglpZiAodW5saWtlbHkgKCFkZXYtPmRyaXZlcgoJCQl8fCBkZXYtPmdhZGdldC5zcGVlZCA9PSBVU0JfU1BFRURfVU5LTk9XTikpIHsKCQlyZXR1cm4gLUVTSFVURE9XTjsKCX0KCglsb2NhbF9pcnFfc2F2ZSAoZmxhZ3MpOwoKCWlmICh1bmxpa2VseSghX3JlcSB8fCAhX3JlcS0+Y29tcGxldGUKCQkJfHwgIV9yZXEtPmJ1ZiB8fCAhbGlzdF9lbXB0eSgmcmVxLT5xdWV1ZSkpKSB7CgkJaWYgKCFfcmVxKQoJCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgIiVzOiAxIFggWCBYXG4iLCBfX2Z1bmNfXyk7CgkJZWxzZSB7CgkJCWRwcmludGsoREVCVUdfTk9STUFMLCAiJXM6IDAgJTAxZCAlMDFkICUwMWRcbiIsCgkJCQlfX2Z1bmNfXywgIV9yZXEtPmNvbXBsZXRlLCFfcmVxLT5idWYsCgkJCQkhbGlzdF9lbXB0eSgmcmVxLT5xdWV1ZSkpOwoJCX0KCgkJbG9jYWxfaXJxX3Jlc3RvcmUoZmxhZ3MpOwoJCXJldHVybiAtRUlOVkFMOwoJfQoKCV9yZXEtPnN0YXR1cyA9IC1FSU5QUk9HUkVTUzsKCV9yZXEtPmFjdHVhbCA9IDA7CgoJZHByaW50ayhERUJVR19WRVJCT1NFLCAiJXM6IGVwJXggbGVuICVkXG4iLAoJCSBfX2Z1bmNfXywgZXAtPmJFbmRwb2ludEFkZHJlc3MsIF9yZXEtPmxlbmd0aCk7CgoJaWYgKGVwLT5iRW5kcG9pbnRBZGRyZXNzKSB7CgkJdWRjX3dyaXRlKGVwLT5iRW5kcG9pbnRBZGRyZXNzICYgMHg3RiwgUzNDMjQxMF9VRENfSU5ERVhfUkVHKTsKCgkJZXBfY3NyID0gdWRjX3JlYWQoKGVwLT5iRW5kcG9pbnRBZGRyZXNzICYgVVNCX0RJUl9JTikKCQkJCT8gUzNDMjQxMF9VRENfSU5fQ1NSMV9SRUcKCQkJCTogUzNDMjQxMF9VRENfT1VUX0NTUjFfUkVHKTsKCQlmaWZvX2NvdW50ID0gczNjMjQxMF91ZGNfZmlmb19jb3VudF9vdXQoKTsKCX0gZWxzZSB7CgkJdWRjX3dyaXRlKDAsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJZXBfY3NyID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfSU5fQ1NSMV9SRUcpOwoJCWZpZm9fY291bnQgPSBzM2MyNDEwX3VkY19maWZvX2NvdW50X291dCgpOwoJfQoKCS8qIGtpY2tzdGFydCB0aGlzIGkvbyBxdWV1ZT8gKi8KCWlmIChsaXN0X2VtcHR5KCZlcC0+cXVldWUpICYmICFlcC0+aGFsdGVkKSB7CgkJaWYgKGVwLT5iRW5kcG9pbnRBZGRyZXNzID09IDAgLyogZXAwICovKSB7CgkJCXN3aXRjaCAoZGV2LT5lcDBzdGF0ZSkgewoJCQljYXNlIEVQMF9JTl9EQVRBX1BIQVNFOgoJCQkJaWYgKCEoZXBfY3NyJlMzQzI0MTBfVURDX0VQMF9DU1JfSVBLUkRZKQoJCQkJCQkmJiBzM2MyNDEwX3VkY193cml0ZV9maWZvKGVwLAoJCQkJCQkJcmVxKSkgewoJCQkJCWRldi0+ZXAwc3RhdGUgPSBFUDBfSURMRTsKCQkJCQlyZXEgPSBOVUxMOwoJCQkJfQoJCQkJYnJlYWs7CgoJCQljYXNlIEVQMF9PVVRfREFUQV9QSEFTRToKCQkJCWlmICgoIV9yZXEtPmxlbmd0aCkKCQkJCQl8fCAoKGVwX2NzciAmIFMzQzI0MTBfVURDX09DU1IxX1BLVFJEWSkKCQkJCQkJJiYgczNjMjQxMF91ZGNfcmVhZF9maWZvKGVwLAoJCQkJCQkJcmVxKSkpIHsKCQkJCQlkZXYtPmVwMHN0YXRlID0gRVAwX0lETEU7CgkJCQkJcmVxID0gTlVMTDsKCQkJCX0KCQkJCWJyZWFrOwoKCQkJZGVmYXVsdDoKCQkJCWxvY2FsX2lycV9yZXN0b3JlKGZsYWdzKTsKCQkJCXJldHVybiAtRUwySExUOwoJCQl9CgkJfSBlbHNlIGlmICgoZXAtPmJFbmRwb2ludEFkZHJlc3MgJiBVU0JfRElSX0lOKSAhPSAwCgkJCQkmJiAoIShlcF9jc3ImUzNDMjQxMF9VRENfT0NTUjFfUEtUUkRZKSkKCQkJCSYmIHMzYzI0MTBfdWRjX3dyaXRlX2ZpZm8oZXAsIHJlcSkpIHsKCQkJcmVxID0gTlVMTDsKCQl9IGVsc2UgaWYgKChlcF9jc3IgJiBTM0MyNDEwX1VEQ19PQ1NSMV9QS1RSRFkpCgkJCQkmJiBmaWZvX2NvdW50CgkJCQkmJiBzM2MyNDEwX3VkY19yZWFkX2ZpZm8oZXAsIHJlcSkpIHsKCQkJcmVxID0gTlVMTDsKCQl9Cgl9CgoJLyogcGlvIG9yIGRtYSBpcnEgaGFuZGxlciBhZHZhbmNlcyB0aGUgcXVldWUuICovCglpZiAobGlrZWx5IChyZXEgIT0gMCkpCgkJbGlzdF9hZGRfdGFpbCgmcmVxLT5xdWV1ZSwgJmVwLT5xdWV1ZSk7CgoJbG9jYWxfaXJxX3Jlc3RvcmUoZmxhZ3MpOwoKCWRwcmludGsoREVCVUdfVkVSQk9TRSwgIiVzIG9rXG4iLCBfX2Z1bmNfXyk7CglyZXR1cm4gMDsKfQoKLyoKICoJczNjMjQxMF91ZGNfZGVxdWV1ZQogKi8Kc3RhdGljIGludCBzM2MyNDEwX3VkY19kZXF1ZXVlKHN0cnVjdCB1c2JfZXAgKl9lcCwgc3RydWN0IHVzYl9yZXF1ZXN0ICpfcmVxKQp7CglzdHJ1Y3QgczNjMjQxMF9lcAkqZXAgPSB0b19zM2MyNDEwX2VwKF9lcCk7CglzdHJ1Y3QgczNjMjQxMF91ZGMJKnVkYzsKCWludAkJCXJldHZhbCA9IC1FSU5WQUw7Cgl1bnNpZ25lZCBsb25nCQlmbGFnczsKCXN0cnVjdCBzM2MyNDEwX3JlcXVlc3QJKnJlcSA9IE5VTEw7CgoJZHByaW50ayhERUJVR19WRVJCT1NFLCAiJXMoJXAsJXApXG4iLCBfX2Z1bmNfXywgX2VwLCBfcmVxKTsKCglpZiAoIXRoZV9jb250cm9sbGVyLT5kcml2ZXIpCgkJcmV0dXJuIC1FU0hVVERPV047CgoJaWYgKCFfZXAgfHwgIV9yZXEpCgkJcmV0dXJuIHJldHZhbDsKCgl1ZGMgPSB0b19zM2MyNDEwX3VkYyhlcC0+Z2FkZ2V0KTsKCglsb2NhbF9pcnFfc2F2ZSAoZmxhZ3MpOwoKCWxpc3RfZm9yX2VhY2hfZW50cnkgKHJlcSwgJmVwLT5xdWV1ZSwgcXVldWUpIHsKCQlpZiAoJnJlcS0+cmVxID09IF9yZXEpIHsKCQkJbGlzdF9kZWxfaW5pdCAoJnJlcS0+cXVldWUpOwoJCQlfcmVxLT5zdGF0dXMgPSAtRUNPTk5SRVNFVDsKCQkJcmV0dmFsID0gMDsKCQkJYnJlYWs7CgkJfQoJfQoKCWlmIChyZXR2YWwgPT0gMCkgewoJCWRwcmludGsoREVCVUdfVkVSQk9TRSwKCQkJImRlcXVldWVkIHJlcSAlcCBmcm9tICVzLCBsZW4gJWQgYnVmICVwXG4iLAoJCQlyZXEsIF9lcC0+bmFtZSwgX3JlcS0+bGVuZ3RoLCBfcmVxLT5idWYpOwoKCQlzM2MyNDEwX3VkY19kb25lKGVwLCByZXEsIC1FQ09OTlJFU0VUKTsKCX0KCglsb2NhbF9pcnFfcmVzdG9yZSAoZmxhZ3MpOwoJcmV0dXJuIHJldHZhbDsKfQoKLyoKICogczNjMjQxMF91ZGNfc2V0X2hhbHQKICovCnN0YXRpYyBpbnQgczNjMjQxMF91ZGNfc2V0X2hhbHQoc3RydWN0IHVzYl9lcCAqX2VwLCBpbnQgdmFsdWUpCnsKCXN0cnVjdCBzM2MyNDEwX2VwCSplcCA9IHRvX3MzYzI0MTBfZXAoX2VwKTsKCXUzMgkJCWVwX2NzciA9IDA7Cgl1bnNpZ25lZCBsb25nCQlmbGFnczsKCXUzMgkJCWlkeDsKCglpZiAodW5saWtlbHkgKCFfZXAgfHwgKCFlcC0+ZGVzYyAmJiBlcC0+ZXAubmFtZSAhPSBlcDBuYW1lKSkpIHsKCQlkcHJpbnRrKERFQlVHX05PUk1BTCwgIiVzOiBpbnZhbCAyXG4iLCBfX2Z1bmNfXyk7CgkJcmV0dXJuIC1FSU5WQUw7Cgl9CgoJbG9jYWxfaXJxX3NhdmUgKGZsYWdzKTsKCglpZHggPSBlcC0+YkVuZHBvaW50QWRkcmVzcyAmIDB4N0Y7CgoJaWYgKGlkeCA9PSAwKSB7CgkJczNjMjQxMF91ZGNfc2V0X2VwMF9zcyhiYXNlX2FkZHIpOwoJCXMzYzI0MTBfdWRjX3NldF9lcDBfZGVfb3V0KGJhc2VfYWRkcik7Cgl9IGVsc2UgewoJCXVkY193cml0ZShpZHgsIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJZXBfY3NyID0gdWRjX3JlYWQoKGVwLT5iRW5kcG9pbnRBZGRyZXNzICZVU0JfRElSX0lOKQoJCQkJPyBTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRwoJCQkJOiBTM0MyNDEwX1VEQ19PVVRfQ1NSMV9SRUcpOwoKCQlpZiAoKGVwLT5iRW5kcG9pbnRBZGRyZXNzICYgVVNCX0RJUl9JTikgIT0gMCkgewoJCQlpZiAodmFsdWUpCgkJCQl1ZGNfd3JpdGUoZXBfY3NyIHwgUzNDMjQxMF9VRENfSUNTUjFfU0VORFNUTCwKCQkJCQlTM0MyNDEwX1VEQ19JTl9DU1IxX1JFRyk7CgkJCWVsc2UgewoJCQkJZXBfY3NyICY9IH5TM0MyNDEwX1VEQ19JQ1NSMV9TRU5EU1RMOwoJCQkJdWRjX3dyaXRlKGVwX2NzciwgUzNDMjQxMF9VRENfSU5fQ1NSMV9SRUcpOwoJCQkJZXBfY3NyIHw9IFMzQzI0MTBfVURDX0lDU1IxX0NMUkRUOwoJCQkJdWRjX3dyaXRlKGVwX2NzciwgUzNDMjQxMF9VRENfSU5fQ1NSMV9SRUcpOwoJCQl9CgkJfSBlbHNlIHsKCQkJaWYgKHZhbHVlKQoJCQkJdWRjX3dyaXRlKGVwX2NzciB8IFMzQzI0MTBfVURDX09DU1IxX1NFTkRTVEwsCgkJCQkJUzNDMjQxMF9VRENfT1VUX0NTUjFfUkVHKTsKCQkJZWxzZSB7CgkJCQllcF9jc3IgJj0gflMzQzI0MTBfVURDX09DU1IxX1NFTkRTVEw7CgkJCQl1ZGNfd3JpdGUoZXBfY3NyLCBTM0MyNDEwX1VEQ19PVVRfQ1NSMV9SRUcpOwoJCQkJZXBfY3NyIHw9IFMzQzI0MTBfVURDX09DU1IxX0NMUkRUOwoJCQkJdWRjX3dyaXRlKGVwX2NzciwgUzNDMjQxMF9VRENfT1VUX0NTUjFfUkVHKTsKCQkJfQoJCX0KCX0KCgllcC0+aGFsdGVkID0gdmFsdWUgPyAxIDogMDsKCWxvY2FsX2lycV9yZXN0b3JlIChmbGFncyk7CgoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBjb25zdCBzdHJ1Y3QgdXNiX2VwX29wcyBzM2MyNDEwX2VwX29wcyA9IHsKCS5lbmFibGUJCT0gczNjMjQxMF91ZGNfZXBfZW5hYmxlLAoJLmRpc2FibGUJPSBzM2MyNDEwX3VkY19lcF9kaXNhYmxlLAoKCS5hbGxvY19yZXF1ZXN0CT0gczNjMjQxMF91ZGNfYWxsb2NfcmVxdWVzdCwKCS5mcmVlX3JlcXVlc3QJPSBzM2MyNDEwX3VkY19mcmVlX3JlcXVlc3QsCgoJLnF1ZXVlCQk9IHMzYzI0MTBfdWRjX3F1ZXVlLAoJLmRlcXVldWUJPSBzM2MyNDEwX3VkY19kZXF1ZXVlLAoKCS5zZXRfaGFsdAk9IHMzYzI0MTBfdWRjX3NldF9oYWx0LAp9OwoKLyotLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tIHVzYl9nYWRnZXRfb3BzIC0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0qLwoKLyoKICoJczNjMjQxMF91ZGNfZ2V0X2ZyYW1lCiAqLwpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX2dldF9mcmFtZShzdHJ1Y3QgdXNiX2dhZGdldCAqX2dhZGdldCkKewoJaW50IHRtcDsKCglkcHJpbnRrKERFQlVHX1ZFUkJPU0UsICIlcygpXG4iLCBfX2Z1bmNfXyk7CgoJdG1wID0gdWRjX3JlYWQoUzNDMjQxMF9VRENfRlJBTUVfTlVNMl9SRUcpIDw8IDg7Cgl0bXAgfD0gdWRjX3JlYWQoUzNDMjQxMF9VRENfRlJBTUVfTlVNMV9SRUcpOwoJcmV0dXJuIHRtcDsKfQoKLyoKICoJczNjMjQxMF91ZGNfd2FrZXVwCiAqLwpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX3dha2V1cChzdHJ1Y3QgdXNiX2dhZGdldCAqX2dhZGdldCkKewoJZHByaW50ayhERUJVR19OT1JNQUwsICIlcygpXG4iLCBfX2Z1bmNfXyk7CglyZXR1cm4gMDsKfQoKLyoKICoJczNjMjQxMF91ZGNfc2V0X3NlbGZwb3dlcmVkCiAqLwpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX3NldF9zZWxmcG93ZXJlZChzdHJ1Y3QgdXNiX2dhZGdldCAqZ2FkZ2V0LCBpbnQgdmFsdWUpCnsKCXN0cnVjdCBzM2MyNDEwX3VkYyAqdWRjID0gdG9fczNjMjQxMF91ZGMoZ2FkZ2V0KTsKCglkcHJpbnRrKERFQlVHX05PUk1BTCwgIiVzKClcbiIsIF9fZnVuY19fKTsKCglpZiAodmFsdWUpCgkJdWRjLT5kZXZzdGF0dXMgfD0gKDEgPDwgVVNCX0RFVklDRV9TRUxGX1BPV0VSRUQpOwoJZWxzZQoJCXVkYy0+ZGV2c3RhdHVzICY9IH4oMSA8PCBVU0JfREVWSUNFX1NFTEZfUE9XRVJFRCk7CgoJcmV0dXJuIDA7Cn0KCnN0YXRpYyB2b2lkIHMzYzI0MTBfdWRjX2Rpc2FibGUoc3RydWN0IHMzYzI0MTBfdWRjICpkZXYpOwpzdGF0aWMgdm9pZCBzM2MyNDEwX3VkY19lbmFibGUoc3RydWN0IHMzYzI0MTBfdWRjICpkZXYpOwoKc3RhdGljIGludCBzM2MyNDEwX3VkY19zZXRfcHVsbHVwKHN0cnVjdCBzM2MyNDEwX3VkYyAqdWRjLCBpbnQgaXNfb24pCnsKCWRwcmludGsoREVCVUdfTk9STUFMLCAiJXMoKVxuIiwgX19mdW5jX18pOwoKCWlmICh1ZGNfaW5mbyAmJiAodWRjX2luZm8tPnVkY19jb21tYW5kIHx8CgkJZ3Bpb19pc192YWxpZCh1ZGNfaW5mby0+cHVsbHVwX3BpbikpKSB7CgoJCWlmIChpc19vbikKCQkJczNjMjQxMF91ZGNfZW5hYmxlKHVkYyk7CgkJZWxzZSB7CgkJCWlmICh1ZGMtPmdhZGdldC5zcGVlZCAhPSBVU0JfU1BFRURfVU5LTk9XTikgewoJCQkJaWYgKHVkYy0+ZHJpdmVyICYmIHVkYy0+ZHJpdmVyLT5kaXNjb25uZWN0KQoJCQkJCXVkYy0+ZHJpdmVyLT5kaXNjb25uZWN0KCZ1ZGMtPmdhZGdldCk7CgoJCQl9CgkJCXMzYzI0MTBfdWRjX2Rpc2FibGUodWRjKTsKCQl9Cgl9CgllbHNlCgkJcmV0dXJuIC1FT1BOT1RTVVBQOwoKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX3ZidXNfc2Vzc2lvbihzdHJ1Y3QgdXNiX2dhZGdldCAqZ2FkZ2V0LCBpbnQgaXNfYWN0aXZlKQp7CglzdHJ1Y3QgczNjMjQxMF91ZGMgKnVkYyA9IHRvX3MzYzI0MTBfdWRjKGdhZGdldCk7CgoJZHByaW50ayhERUJVR19OT1JNQUwsICIlcygpXG4iLCBfX2Z1bmNfXyk7CgoJdWRjLT52YnVzID0gKGlzX2FjdGl2ZSAhPSAwKTsKCXMzYzI0MTBfdWRjX3NldF9wdWxsdXAodWRjLCBpc19hY3RpdmUpOwoJcmV0dXJuIDA7Cn0KCnN0YXRpYyBpbnQgczNjMjQxMF91ZGNfcHVsbHVwKHN0cnVjdCB1c2JfZ2FkZ2V0ICpnYWRnZXQsIGludCBpc19vbikKewoJc3RydWN0IHMzYzI0MTBfdWRjICp1ZGMgPSB0b19zM2MyNDEwX3VkYyhnYWRnZXQpOwoKCWRwcmludGsoREVCVUdfTk9STUFMLCAiJXMoKVxuIiwgX19mdW5jX18pOwoKCXMzYzI0MTBfdWRjX3NldF9wdWxsdXAodWRjLCBpc19vbiA/IDAgOiAxKTsKCXJldHVybiAwOwp9CgpzdGF0aWMgaXJxcmV0dXJuX3QgczNjMjQxMF91ZGNfdmJ1c19pcnEoaW50IGlycSwgdm9pZCAqX2RldikKewoJc3RydWN0IHMzYzI0MTBfdWRjCSpkZXYgPSBfZGV2OwoJdW5zaWduZWQgaW50CQl2YWx1ZTsKCglkcHJpbnRrKERFQlVHX05PUk1BTCwgIiVzKClcbiIsIF9fZnVuY19fKTsKCgl2YWx1ZSA9IGdwaW9fZ2V0X3ZhbHVlKHVkY19pbmZvLT52YnVzX3BpbikgPyAxIDogMDsKCWlmICh1ZGNfaW5mby0+dmJ1c19waW5faW52ZXJ0ZWQpCgkJdmFsdWUgPSAhdmFsdWU7CgoJaWYgKHZhbHVlICE9IGRldi0+dmJ1cykKCQlzM2MyNDEwX3VkY192YnVzX3Nlc3Npb24oJmRldi0+Z2FkZ2V0LCB2YWx1ZSk7CgoJcmV0dXJuIElSUV9IQU5ETEVEOwp9CgpzdGF0aWMgaW50IHMzYzI0MTBfdmJ1c19kcmF3KHN0cnVjdCB1c2JfZ2FkZ2V0ICpfZ2FkZ2V0LCB1bnNpZ25lZCBtYSkKewoJZHByaW50ayhERUJVR19OT1JNQUwsICIlcygpXG4iLCBfX2Z1bmNfXyk7CgoJaWYgKHVkY19pbmZvICYmIHVkY19pbmZvLT52YnVzX2RyYXcpIHsKCQl1ZGNfaW5mby0+dmJ1c19kcmF3KG1hKTsKCQlyZXR1cm4gMDsKCX0KCglyZXR1cm4gLUVOT1RTVVBQOwp9CgpzdGF0aWMgY29uc3Qgc3RydWN0IHVzYl9nYWRnZXRfb3BzIHMzYzI0MTBfb3BzID0gewoJLmdldF9mcmFtZQkJPSBzM2MyNDEwX3VkY19nZXRfZnJhbWUsCgkud2FrZXVwCQkJPSBzM2MyNDEwX3VkY193YWtldXAsCgkuc2V0X3NlbGZwb3dlcmVkCT0gczNjMjQxMF91ZGNfc2V0X3NlbGZwb3dlcmVkLAoJLnB1bGx1cAkJCT0gczNjMjQxMF91ZGNfcHVsbHVwLAoJLnZidXNfc2Vzc2lvbgkJPSBzM2MyNDEwX3VkY192YnVzX3Nlc3Npb24sCgkudmJ1c19kcmF3CQk9IHMzYzI0MTBfdmJ1c19kcmF3LAp9OwoKc3RhdGljIHZvaWQgczNjMjQxMF91ZGNfY29tbWFuZChlbnVtIHMzYzI0MTBfdWRjX2NtZF9lIGNtZCkKewoJaWYgKCF1ZGNfaW5mbykKCQlyZXR1cm47CgoJaWYgKHVkY19pbmZvLT51ZGNfY29tbWFuZCkgewoJCXVkY19pbmZvLT51ZGNfY29tbWFuZChTM0MyNDEwX1VEQ19QX0RJU0FCTEUpOwoJfSBlbHNlIGlmIChncGlvX2lzX3ZhbGlkKHVkY19pbmZvLT5wdWxsdXBfcGluKSkgewoJCWludCB2YWx1ZTsKCgkJc3dpdGNoIChjbWQpIHsKCQljYXNlIFMzQzI0MTBfVURDX1BfRU5BQkxFOgoJCQl2YWx1ZSA9IDE7CgkJCWJyZWFrOwoJCWNhc2UgUzNDMjQxMF9VRENfUF9ESVNBQkxFOgoJCQl2YWx1ZSA9IDA7CgkJCWJyZWFrOwoJCWRlZmF1bHQ6CgkJCXJldHVybjsKCQl9CgkJdmFsdWUgXj0gdWRjX2luZm8tPnB1bGx1cF9waW5faW52ZXJ0ZWQ7CgoJCWdwaW9fc2V0X3ZhbHVlKHVkY19pbmZvLT5wdWxsdXBfcGluLCB2YWx1ZSk7Cgl9Cn0KCi8qLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSBnYWRnZXQgZHJpdmVyIGhhbmRsaW5nLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tKi8KLyoKICogczNjMjQxMF91ZGNfZGlzYWJsZQogKi8Kc3RhdGljIHZvaWQgczNjMjQxMF91ZGNfZGlzYWJsZShzdHJ1Y3QgczNjMjQxMF91ZGMgKmRldikKewoJZHByaW50ayhERUJVR19OT1JNQUwsICIlcygpXG4iLCBfX2Z1bmNfXyk7CgoJLyogRGlzYWJsZSBhbGwgaW50ZXJydXB0cyAqLwoJdWRjX3dyaXRlKDB4MDAsIFMzQzI0MTBfVURDX1VTQl9JTlRfRU5fUkVHKTsKCXVkY193cml0ZSgweDAwLCBTM0MyNDEwX1VEQ19FUF9JTlRfRU5fUkVHKTsKCgkvKiBDbGVhciB0aGUgaW50ZXJydXB0IHJlZ2lzdGVycyAqLwoJdWRjX3dyaXRlKFMzQzI0MTBfVURDX1VTQklOVF9SRVNFVAoJCQkJfCBTM0MyNDEwX1VEQ19VU0JJTlRfUkVTVU1FCgkJCQl8IFMzQzI0MTBfVURDX1VTQklOVF9TVVNQRU5ELAoJCQlTM0MyNDEwX1VEQ19VU0JfSU5UX1JFRyk7CgoJdWRjX3dyaXRlKDB4MUYsIFMzQzI0MTBfVURDX0VQX0lOVF9SRUcpOwoKCS8qIEdvb2QgYnllLCBjcnVlbCB3b3JsZCAqLwoJczNjMjQxMF91ZGNfY29tbWFuZChTM0MyNDEwX1VEQ19QX0RJU0FCTEUpOwoKCS8qIFNldCBzcGVlZCB0byB1bmtub3duICovCglkZXYtPmdhZGdldC5zcGVlZCA9IFVTQl9TUEVFRF9VTktOT1dOOwp9CgovKgogKiBzM2MyNDEwX3VkY19yZWluaXQKICovCnN0YXRpYyB2b2lkIHMzYzI0MTBfdWRjX3JlaW5pdChzdHJ1Y3QgczNjMjQxMF91ZGMgKmRldikKewoJdTMyIGk7CgoJLyogZGV2aWNlL2VwMCByZWNvcmRzIGluaXQgKi8KCUlOSVRfTElTVF9IRUFEICgmZGV2LT5nYWRnZXQuZXBfbGlzdCk7CglJTklUX0xJU1RfSEVBRCAoJmRldi0+Z2FkZ2V0LmVwMC0+ZXBfbGlzdCk7CglkZXYtPmVwMHN0YXRlID0gRVAwX0lETEU7CgoJZm9yIChpID0gMDsgaSA8IFMzQzI0MTBfRU5EUE9JTlRTOyBpKyspIHsKCQlzdHJ1Y3QgczNjMjQxMF9lcCAqZXAgPSAmZGV2LT5lcFtpXTsKCgkJaWYgKGkgIT0gMCkKCQkJbGlzdF9hZGRfdGFpbCAoJmVwLT5lcC5lcF9saXN0LCAmZGV2LT5nYWRnZXQuZXBfbGlzdCk7CgoJCWVwLT5kZXYgPSBkZXY7CgkJZXAtPmRlc2MgPSBOVUxMOwoJCWVwLT5oYWx0ZWQgPSAwOwoJCUlOSVRfTElTVF9IRUFEICgmZXAtPnF1ZXVlKTsKCX0KfQoKLyoKICogczNjMjQxMF91ZGNfZW5hYmxlCiAqLwpzdGF0aWMgdm9pZCBzM2MyNDEwX3VkY19lbmFibGUoc3RydWN0IHMzYzI0MTBfdWRjICpkZXYpCnsKCWludCBpOwoKCWRwcmludGsoREVCVUdfTk9STUFMLCAiczNjMjQxMF91ZGNfZW5hYmxlIGNhbGxlZFxuIik7CgoJLyogZGV2LT5nYWRnZXQuc3BlZWQgPSBVU0JfU1BFRURfVU5LTk9XTjsgKi8KCWRldi0+Z2FkZ2V0LnNwZWVkID0gVVNCX1NQRUVEX0ZVTEw7CgoJLyogU2V0IE1BWFAgZm9yIGFsbCBlbmRwb2ludHMgKi8KCWZvciAoaSA9IDA7IGkgPCBTM0MyNDEwX0VORFBPSU5UUzsgaSsrKSB7CgkJdWRjX3dyaXRlKGksIFMzQzI0MTBfVURDX0lOREVYX1JFRyk7CgkJdWRjX3dyaXRlKChkZXYtPmVwW2ldLmVwLm1heHBhY2tldCAmIDB4N2ZmKSA+PiAzLAoJCQkJUzNDMjQxMF9VRENfTUFYUF9SRUcpOwoJfQoKCS8qIFNldCBkZWZhdWx0IHBvd2VyIHN0YXRlICovCgl1ZGNfd3JpdGUoREVGQVVMVF9QT1dFUl9TVEFURSwgUzNDMjQxMF9VRENfUFdSX1JFRyk7CgoJLyogRW5hYmxlIHJlc2V0IGFuZCBzdXNwZW5kIGludGVycnVwdCBpbnRlcnJ1cHRzICovCgl1ZGNfd3JpdGUoUzNDMjQxMF9VRENfVVNCSU5UX1JFU0VUIHwgUzNDMjQxMF9VRENfVVNCSU5UX1NVU1BFTkQsCgkJCVMzQzI0MTBfVURDX1VTQl9JTlRfRU5fUkVHKTsKCgkvKiBFbmFibGUgZXAwIGludGVycnVwdCAqLwoJdWRjX3dyaXRlKFMzQzI0MTBfVURDX0lOVF9FUDAsIFMzQzI0MTBfVURDX0VQX0lOVF9FTl9SRUcpOwoKCS8qIHRpbWUgdG8gc2F5ICJoZWxsbywgd29ybGQiICovCglzM2MyNDEwX3VkY19jb21tYW5kKFMzQzI0MTBfVURDX1BfRU5BQkxFKTsKfQoKLyoKICoJdXNiX2dhZGdldF9wcm9iZV9kcml2ZXIKICovCmludCB1c2JfZ2FkZ2V0X3Byb2JlX2RyaXZlcihzdHJ1Y3QgdXNiX2dhZGdldF9kcml2ZXIgKmRyaXZlciwKCQlpbnQgKCpiaW5kKShzdHJ1Y3QgdXNiX2dhZGdldCAqKSkKewoJc3RydWN0IHMzYzI0MTBfdWRjICp1ZGMgPSB0aGVfY29udHJvbGxlcjsKCWludAkJcmV0dmFsOwoKCWRwcmludGsoREVCVUdfTk9STUFMLCAiJXMoKSAnJXMnXG4iLCBfX2Z1bmNfXywgZHJpdmVyLT5kcml2ZXIubmFtZSk7CgoJLyogU2FuaXR5IGNoZWNrcyAqLwoJaWYgKCF1ZGMpCgkJcmV0dXJuIC1FTk9ERVY7CgoJaWYgKHVkYy0+ZHJpdmVyKQoJCXJldHVybiAtRUJVU1k7CgoJaWYgKCFiaW5kIHx8ICFkcml2ZXItPnNldHVwIHx8IGRyaXZlci0+c3BlZWQgPCBVU0JfU1BFRURfRlVMTCkgewoJCXByaW50ayhLRVJOX0VSUiAiSW52YWxpZCBkcml2ZXI6IGJpbmQgJXAgc2V0dXAgJXAgc3BlZWQgJWRcbiIsCgkJCWJpbmQsIGRyaXZlci0+c2V0dXAsIGRyaXZlci0+c3BlZWQpOwoJCXJldHVybiAtRUlOVkFMOwoJfQojaWYgZGVmaW5lZChNT0RVTEUpCglpZiAoIWRyaXZlci0+dW5iaW5kKSB7CgkJcHJpbnRrKEtFUk5fRVJSICJJbnZhbGlkIGRyaXZlcjogbm8gdW5iaW5kIG1ldGhvZFxuIik7CgkJcmV0dXJuIC1FSU5WQUw7Cgl9CiNlbmRpZgoKCS8qIEhvb2sgdGhlIGRyaXZlciAqLwoJdWRjLT5kcml2ZXIgPSBkcml2ZXI7Cgl1ZGMtPmdhZGdldC5kZXYuZHJpdmVyID0gJmRyaXZlci0+ZHJpdmVyOwoKCS8qIEJpbmQgdGhlIGRyaXZlciAqLwoJaWYgKChyZXR2YWwgPSBkZXZpY2VfYWRkKCZ1ZGMtPmdhZGdldC5kZXYpKSAhPSAwKSB7CgkJcHJpbnRrKEtFUk5fRVJSICJFcnJvciBpbiBkZXZpY2VfYWRkKCkgOiAlZFxuIixyZXR2YWwpOwoJCWdvdG8gcmVnaXN0ZXJfZXJyb3I7Cgl9CgoJZHByaW50ayhERUJVR19OT1JNQUwsICJiaW5kaW5nIGdhZGdldCBkcml2ZXIgJyVzJ1xuIiwKCQlkcml2ZXItPmRyaXZlci5uYW1lKTsKCglpZiAoKHJldHZhbCA9IGJpbmQoJnVkYy0+Z2FkZ2V0KSkgIT0gMCkgewoJCWRldmljZV9kZWwoJnVkYy0+Z2FkZ2V0LmRldik7CgkJZ290byByZWdpc3Rlcl9lcnJvcjsKCX0KCgkvKiBFbmFibGUgdWRjICovCglzM2MyNDEwX3VkY19lbmFibGUodWRjKTsKCglyZXR1cm4gMDsKCnJlZ2lzdGVyX2Vycm9yOgoJdWRjLT5kcml2ZXIgPSBOVUxMOwoJdWRjLT5nYWRnZXQuZGV2LmRyaXZlciA9IE5VTEw7CglyZXR1cm4gcmV0dmFsOwp9CkVYUE9SVF9TWU1CT0wodXNiX2dhZGdldF9wcm9iZV9kcml2ZXIpOwoKLyoKICoJdXNiX2dhZGdldF91bnJlZ2lzdGVyX2RyaXZlcgogKi8KaW50IHVzYl9nYWRnZXRfdW5yZWdpc3Rlcl9kcml2ZXIoc3RydWN0IHVzYl9nYWRnZXRfZHJpdmVyICpkcml2ZXIpCnsKCXN0cnVjdCBzM2MyNDEwX3VkYyAqdWRjID0gdGhlX2NvbnRyb2xsZXI7CgoJaWYgKCF1ZGMpCgkJcmV0dXJuIC1FTk9ERVY7CgoJaWYgKCFkcml2ZXIgfHwgZHJpdmVyICE9IHVkYy0+ZHJpdmVyIHx8ICFkcml2ZXItPnVuYmluZCkKCQlyZXR1cm4gLUVJTlZBTDsKCglkcHJpbnRrKERFQlVHX05PUk1BTCwgInVzYl9nYWRnZXRfdW5yZWdpc3Rlcl9kcml2ZXIoKSAnJXMnXG4iLAoJCWRyaXZlci0+ZHJpdmVyLm5hbWUpOwoKCS8qIHJlcG9ydCBkaXNjb25uZWN0ICovCglpZiAoZHJpdmVyLT5kaXNjb25uZWN0KQoJCWRyaXZlci0+ZGlzY29ubmVjdCgmdWRjLT5nYWRnZXQpOwoKCWRyaXZlci0+dW5iaW5kKCZ1ZGMtPmdhZGdldCk7CgoJZGV2aWNlX2RlbCgmdWRjLT5nYWRnZXQuZGV2KTsKCXVkYy0+ZHJpdmVyID0gTlVMTDsKCgkvKiBEaXNhYmxlIHVkYyAqLwoJczNjMjQxMF91ZGNfZGlzYWJsZSh1ZGMpOwoKCXJldHVybiAwOwp9CgovKi0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLS0tLSovCnN0YXRpYyBzdHJ1Y3QgczNjMjQxMF91ZGMgbWVtb3J5ID0gewoJLmdhZGdldCA9IHsKCQkub3BzCQk9ICZzM2MyNDEwX29wcywKCQkuZXAwCQk9ICZtZW1vcnkuZXBbMF0uZXAsCgkJLm5hbWUJCT0gZ2FkZ2V0X25hbWUsCgkJLmRldiA9IHsKCQkJLmluaXRfbmFtZQk9ICJnYWRnZXQiLAoJCX0sCgl9LAoKCS8qIGNvbnRyb2wgZW5kcG9pbnQgKi8KCS5lcFswXSA9IHsKCQkubnVtCQk9IDAsCgkJLmVwID0gewoJCQkubmFtZQkJPSBlcDBuYW1lLAoJCQkub3BzCQk9ICZzM2MyNDEwX2VwX29wcywKCQkJLm1heHBhY2tldAk9IEVQMF9GSUZPX1NJWkUsCgkJfSwKCQkuZGV2CQk9ICZtZW1vcnksCgl9LAoKCS8qIGZpcnN0IGdyb3VwIG9mIGVuZHBvaW50cyAqLwoJLmVwWzFdID0gewoJCS5udW0JCT0gMSwKCQkuZXAgPSB7CgkJCS5uYW1lCQk9ICJlcDEtYnVsayIsCgkJCS5vcHMJCT0gJnMzYzI0MTBfZXBfb3BzLAoJCQkubWF4cGFja2V0CT0gRVBfRklGT19TSVpFLAoJCX0sCgkJLmRldgkJPSAmbWVtb3J5LAoJCS5maWZvX3NpemUJPSBFUF9GSUZPX1NJWkUsCgkJLmJFbmRwb2ludEFkZHJlc3MgPSAxLAoJCS5ibUF0dHJpYnV0ZXMJPSBVU0JfRU5EUE9JTlRfWEZFUl9CVUxLLAoJfSwKCS5lcFsyXSA9IHsKCQkubnVtCQk9IDIsCgkJLmVwID0gewoJCQkubmFtZQkJPSAiZXAyLWJ1bGsiLAoJCQkub3BzCQk9ICZzM2MyNDEwX2VwX29wcywKCQkJLm1heHBhY2tldAk9IEVQX0ZJRk9fU0laRSwKCQl9LAoJCS5kZXYJCT0gJm1lbW9yeSwKCQkuZmlmb19zaXplCT0gRVBfRklGT19TSVpFLAoJCS5iRW5kcG9pbnRBZGRyZXNzID0gMiwKCQkuYm1BdHRyaWJ1dGVzCT0gVVNCX0VORFBPSU5UX1hGRVJfQlVMSywKCX0sCgkuZXBbM10gPSB7CgkJLm51bQkJPSAzLAoJCS5lcCA9IHsKCQkJLm5hbWUJCT0gImVwMy1idWxrIiwKCQkJLm9wcwkJPSAmczNjMjQxMF9lcF9vcHMsCgkJCS5tYXhwYWNrZXQJPSBFUF9GSUZPX1NJWkUsCgkJfSwKCQkuZGV2CQk9ICZtZW1vcnksCgkJLmZpZm9fc2l6ZQk9IEVQX0ZJRk9fU0laRSwKCQkuYkVuZHBvaW50QWRkcmVzcyA9IDMsCgkJLmJtQXR0cmlidXRlcwk9IFVTQl9FTkRQT0lOVF9YRkVSX0JVTEssCgl9LAoJLmVwWzRdID0gewoJCS5udW0JCT0gNCwKCQkuZXAgPSB7CgkJCS5uYW1lCQk9ICJlcDQtYnVsayIsCgkJCS5vcHMJCT0gJnMzYzI0MTBfZXBfb3BzLAoJCQkubWF4cGFja2V0CT0gRVBfRklGT19TSVpFLAoJCX0sCgkJLmRldgkJPSAmbWVtb3J5LAoJCS5maWZvX3NpemUJPSBFUF9GSUZPX1NJWkUsCgkJLmJFbmRwb2ludEFkZHJlc3MgPSA0LAoJCS5ibUF0dHJpYnV0ZXMJPSBVU0JfRU5EUE9JTlRfWEZFUl9CVUxLLAoJfQoKfTsKCi8qCiAqCXByb2JlIC0gYmluZHMgdG8gdGhlIHBsYXRmb3JtIGRldmljZQogKi8Kc3RhdGljIGludCBzM2MyNDEwX3VkY19wcm9iZShzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2KQp7CglzdHJ1Y3QgczNjMjQxMF91ZGMgKnVkYyA9ICZtZW1vcnk7CglzdHJ1Y3QgZGV2aWNlICpkZXYgPSAmcGRldi0+ZGV2OwoJaW50IHJldHZhbDsKCWludCBpcnE7CgoJZGV2X2RiZyhkZXYsICIlcygpXG4iLCBfX2Z1bmNfXyk7CgoJdXNiX2J1c19jbG9jayA9IGNsa19nZXQoTlVMTCwgInVzYi1idXMtZ2FkZ2V0Iik7CglpZiAoSVNfRVJSKHVzYl9idXNfY2xvY2spKSB7CgkJZGV2X2VycihkZXYsICJmYWlsZWQgdG8gZ2V0IHVzYiBidXMgY2xvY2sgc291cmNlXG4iKTsKCQlyZXR1cm4gUFRSX0VSUih1c2JfYnVzX2Nsb2NrKTsKCX0KCgljbGtfZW5hYmxlKHVzYl9idXNfY2xvY2spOwoKCXVkY19jbG9jayA9IGNsa19nZXQoTlVMTCwgInVzYi1kZXZpY2UiKTsKCWlmIChJU19FUlIodWRjX2Nsb2NrKSkgewoJCWRldl9lcnIoZGV2LCAiZmFpbGVkIHRvIGdldCB1ZGMgY2xvY2sgc291cmNlXG4iKTsKCQlyZXR1cm4gUFRSX0VSUih1ZGNfY2xvY2spOwoJfQoKCWNsa19lbmFibGUodWRjX2Nsb2NrKTsKCgltZGVsYXkoMTApOwoKCWRldl9kYmcoZGV2LCAiZ290IGFuZCBlbmFibGVkIGNsb2Nrc1xuIik7CgoJaWYgKHN0cm5jbXAocGRldi0+bmFtZSwgInMzYzI0NDAiLCA3KSA9PSAwKSB7CgkJZGV2X2luZm8oZGV2LCAiUzNDMjQ0MDogaW5jcmVhc2luZyBGSUZPIHRvIDEyOCBieXRlc1xuIik7CgkJbWVtb3J5LmVwWzFdLmZpZm9fc2l6ZSA9IFMzQzI0NDBfRVBfRklGT19TSVpFOwoJCW1lbW9yeS5lcFsyXS5maWZvX3NpemUgPSBTM0MyNDQwX0VQX0ZJRk9fU0laRTsKCQltZW1vcnkuZXBbM10uZmlmb19zaXplID0gUzNDMjQ0MF9FUF9GSUZPX1NJWkU7CgkJbWVtb3J5LmVwWzRdLmZpZm9fc2l6ZSA9IFMzQzI0NDBfRVBfRklGT19TSVpFOwoJfQoKCXNwaW5fbG9ja19pbml0ICgmdWRjLT5sb2NrKTsKCXVkY19pbmZvID0gcGRldi0+ZGV2LnBsYXRmb3JtX2RhdGE7CgoJcnNyY19zdGFydCA9IFMzQzI0MTBfUEFfVVNCREVWOwoJcnNyY19sZW4gICA9IFMzQzI0WFhfU1pfVVNCREVWOwoKCWlmICghcmVxdWVzdF9tZW1fcmVnaW9uKHJzcmNfc3RhcnQsIHJzcmNfbGVuLCBnYWRnZXRfbmFtZSkpCgkJcmV0dXJuIC1FQlVTWTsKCgliYXNlX2FkZHIgPSBpb3JlbWFwKHJzcmNfc3RhcnQsIHJzcmNfbGVuKTsKCWlmICghYmFzZV9hZGRyKSB7CgkJcmV0dmFsID0gLUVOT01FTTsKCQlnb3RvIGVycl9tZW07Cgl9CgoJZGV2aWNlX2luaXRpYWxpemUoJnVkYy0+Z2FkZ2V0LmRldik7Cgl1ZGMtPmdhZGdldC5kZXYucGFyZW50ID0gJnBkZXYtPmRldjsKCXVkYy0+Z2FkZ2V0LmRldi5kbWFfbWFzayA9IHBkZXYtPmRldi5kbWFfbWFzazsKCgl0aGVfY29udHJvbGxlciA9IHVkYzsKCXBsYXRmb3JtX3NldF9kcnZkYXRhKHBkZXYsIHVkYyk7CgoJczNjMjQxMF91ZGNfZGlzYWJsZSh1ZGMpOwoJczNjMjQxMF91ZGNfcmVpbml0KHVkYyk7CgoJLyogaXJxIHNldHVwIGFmdGVyIG9sZCBoYXJkd2FyZSBzdGF0ZSBpcyBjbGVhbmVkIHVwICovCglyZXR2YWwgPSByZXF1ZXN0X2lycShJUlFfVVNCRCwgczNjMjQxMF91ZGNfaXJxLAoJCQkgICAgIElSUUZfRElTQUJMRUQsIGdhZGdldF9uYW1lLCB1ZGMpOwoKCWlmIChyZXR2YWwgIT0gMCkgewoJCWRldl9lcnIoZGV2LCAiY2Fubm90IGdldCBpcnEgJWksIGVyciAlZFxuIiwgSVJRX1VTQkQsIHJldHZhbCk7CgkJcmV0dmFsID0gLUVCVVNZOwoJCWdvdG8gZXJyX21hcDsKCX0KCglkZXZfZGJnKGRldiwgImdvdCBpcnEgJWlcbiIsIElSUV9VU0JEKTsKCglpZiAodWRjX2luZm8gJiYgdWRjX2luZm8tPnZidXNfcGluID4gMCkgewoJCXJldHZhbCA9IGdwaW9fcmVxdWVzdCh1ZGNfaW5mby0+dmJ1c19waW4sICJ1ZGMgdmJ1cyIpOwoJCWlmIChyZXR2YWwgPCAwKSB7CgkJCWRldl9lcnIoZGV2LCAiY2Fubm90IGNsYWltIHZidXMgcGluXG4iKTsKCQkJZ290byBlcnJfaW50OwoJCX0KCgkJaXJxID0gZ3Bpb190b19pcnEodWRjX2luZm8tPnZidXNfcGluKTsKCQlpZiAoaXJxIDwgMCkgewoJCQlkZXZfZXJyKGRldiwgIm5vIGlycSBmb3IgZ3BpbyB2YnVzIHBpblxuIik7CgkJCWdvdG8gZXJyX2dwaW9fY2xhaW07CgkJfQoKCQlyZXR2YWwgPSByZXF1ZXN0X2lycShpcnEsIHMzYzI0MTBfdWRjX3ZidXNfaXJxLAoJCQkJICAgICBJUlFGX0RJU0FCTEVEIHwgSVJRRl9UUklHR0VSX1JJU0lORwoJCQkJICAgICB8IElSUUZfVFJJR0dFUl9GQUxMSU5HIHwgSVJRRl9TSEFSRUQsCgkJCQkgICAgIGdhZGdldF9uYW1lLCB1ZGMpOwoKCQlpZiAocmV0dmFsICE9IDApIHsKCQkJZGV2X2VycihkZXYsICJjYW4ndCBnZXQgdmJ1cyBpcnEgJWQsIGVyciAlZFxuIiwKCQkJCWlycSwgcmV0dmFsKTsKCQkJcmV0dmFsID0gLUVCVVNZOwoJCQlnb3RvIGVycl9ncGlvX2NsYWltOwoJCX0KCgkJZGV2X2RiZyhkZXYsICJnb3QgaXJxICVpXG4iLCBpcnEpOwoJfSBlbHNlIHsKCQl1ZGMtPnZidXMgPSAxOwoJfQoKCWlmICh1ZGNfaW5mbyAmJiAhdWRjX2luZm8tPnVkY19jb21tYW5kICYmCgkJZ3Bpb19pc192YWxpZCh1ZGNfaW5mby0+cHVsbHVwX3BpbikpIHsKCgkJcmV0dmFsID0gZ3Bpb19yZXF1ZXN0X29uZSh1ZGNfaW5mby0+cHVsbHVwX3BpbiwKCQkJCXVkY19pbmZvLT52YnVzX3Bpbl9pbnZlcnRlZCA/CgkJCQlHUElPRl9PVVRfSU5JVF9ISUdIIDogR1BJT0ZfT1VUX0lOSVRfTE9XLAoJCQkJInVkYyBwdWxsdXAiKTsKCQlpZiAocmV0dmFsKQoJCQlnb3RvIGVycl92YnVzX2lycTsKCX0KCglpZiAoczNjMjQxMF91ZGNfZGVidWdmc19yb290KSB7CgkJdWRjLT5yZWdzX2luZm8gPSBkZWJ1Z2ZzX2NyZWF0ZV9maWxlKCJyZWdpc3RlcnMiLCBTX0lSVUdPLAoJCQkJczNjMjQxMF91ZGNfZGVidWdmc19yb290LAoJCQkJdWRjLCAmczNjMjQxMF91ZGNfZGVidWdmc19mb3BzKTsKCQlpZiAoIXVkYy0+cmVnc19pbmZvKQoJCQlkZXZfd2FybihkZXYsICJkZWJ1Z2ZzIGZpbGUgY3JlYXRpb24gZmFpbGVkXG4iKTsKCX0KCglkZXZfZGJnKGRldiwgInByb2JlIG9rXG4iKTsKCglyZXR1cm4gMDsKCmVycl92YnVzX2lycToKCWlmICh1ZGNfaW5mbyAmJiB1ZGNfaW5mby0+dmJ1c19waW4gPiAwKQoJCWZyZWVfaXJxKGdwaW9fdG9faXJxKHVkY19pbmZvLT52YnVzX3BpbiksIHVkYyk7CmVycl9ncGlvX2NsYWltOgoJaWYgKHVkY19pbmZvICYmIHVkY19pbmZvLT52YnVzX3BpbiA+IDApCgkJZ3Bpb19mcmVlKHVkY19pbmZvLT52YnVzX3Bpbik7CmVycl9pbnQ6CglmcmVlX2lycShJUlFfVVNCRCwgdWRjKTsKZXJyX21hcDoKCWlvdW5tYXAoYmFzZV9hZGRyKTsKZXJyX21lbToKCXJlbGVhc2VfbWVtX3JlZ2lvbihyc3JjX3N0YXJ0LCByc3JjX2xlbik7CgoJcmV0dXJuIHJldHZhbDsKfQoKLyoKICoJczNjMjQxMF91ZGNfcmVtb3ZlCiAqLwpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX3JlbW92ZShzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2KQp7CglzdHJ1Y3QgczNjMjQxMF91ZGMgKnVkYyA9IHBsYXRmb3JtX2dldF9kcnZkYXRhKHBkZXYpOwoJdW5zaWduZWQgaW50IGlycTsKCglkZXZfZGJnKCZwZGV2LT5kZXYsICIlcygpXG4iLCBfX2Z1bmNfXyk7CglpZiAodWRjLT5kcml2ZXIpCgkJcmV0dXJuIC1FQlVTWTsKCglkZWJ1Z2ZzX3JlbW92ZSh1ZGMtPnJlZ3NfaW5mbyk7CgoJaWYgKHVkY19pbmZvICYmICF1ZGNfaW5mby0+dWRjX2NvbW1hbmQgJiYKCQlncGlvX2lzX3ZhbGlkKHVkY19pbmZvLT5wdWxsdXBfcGluKSkKCQlncGlvX2ZyZWUodWRjX2luZm8tPnB1bGx1cF9waW4pOwoKCWlmICh1ZGNfaW5mbyAmJiB1ZGNfaW5mby0+dmJ1c19waW4gPiAwKSB7CgkJaXJxID0gZ3Bpb190b19pcnEodWRjX2luZm8tPnZidXNfcGluKTsKCQlmcmVlX2lycShpcnEsIHVkYyk7Cgl9CgoJZnJlZV9pcnEoSVJRX1VTQkQsIHVkYyk7CgoJaW91bm1hcChiYXNlX2FkZHIpOwoJcmVsZWFzZV9tZW1fcmVnaW9uKHJzcmNfc3RhcnQsIHJzcmNfbGVuKTsKCglwbGF0Zm9ybV9zZXRfZHJ2ZGF0YShwZGV2LCBOVUxMKTsKCglpZiAoIUlTX0VSUih1ZGNfY2xvY2spICYmIHVkY19jbG9jayAhPSBOVUxMKSB7CgkJY2xrX2Rpc2FibGUodWRjX2Nsb2NrKTsKCQljbGtfcHV0KHVkY19jbG9jayk7CgkJdWRjX2Nsb2NrID0gTlVMTDsKCX0KCglpZiAoIUlTX0VSUih1c2JfYnVzX2Nsb2NrKSAmJiB1c2JfYnVzX2Nsb2NrICE9IE5VTEwpIHsKCQljbGtfZGlzYWJsZSh1c2JfYnVzX2Nsb2NrKTsKCQljbGtfcHV0KHVzYl9idXNfY2xvY2spOwoJCXVzYl9idXNfY2xvY2sgPSBOVUxMOwoJfQoKCWRldl9kYmcoJnBkZXYtPmRldiwgIiVzOiByZW1vdmUgb2tcbiIsIF9fZnVuY19fKTsKCXJldHVybiAwOwp9CgojaWZkZWYgQ09ORklHX1BNCnN0YXRpYyBpbnQgczNjMjQxMF91ZGNfc3VzcGVuZChzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2LCBwbV9tZXNzYWdlX3QgbWVzc2FnZSkKewoJczNjMjQxMF91ZGNfY29tbWFuZChTM0MyNDEwX1VEQ19QX0RJU0FCTEUpOwoKCXJldHVybiAwOwp9CgpzdGF0aWMgaW50IHMzYzI0MTBfdWRjX3Jlc3VtZShzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2KQp7CglzM2MyNDEwX3VkY19jb21tYW5kKFMzQzI0MTBfVURDX1BfRU5BQkxFKTsKCglyZXR1cm4gMDsKfQojZWxzZQojZGVmaW5lIHMzYzI0MTBfdWRjX3N1c3BlbmQJTlVMTAojZGVmaW5lIHMzYzI0MTBfdWRjX3Jlc3VtZQlOVUxMCiNlbmRpZgoKc3RhdGljIHN0cnVjdCBwbGF0Zm9ybV9kcml2ZXIgdWRjX2RyaXZlcl8yNDEwID0gewoJLmRyaXZlcgkJPSB7CgkJLm5hbWUJPSAiczNjMjQxMC11c2JnYWRnZXQiLAoJCS5vd25lcgk9IFRISVNfTU9EVUxFLAoJfSwKCS5wcm9iZQkJPSBzM2MyNDEwX3VkY19wcm9iZSwKCS5yZW1vdmUJCT0gczNjMjQxMF91ZGNfcmVtb3ZlLAoJLnN1c3BlbmQJPSBzM2MyNDEwX3VkY19zdXNwZW5kLAoJLnJlc3VtZQkJPSBzM2MyNDEwX3VkY19yZXN1bWUsCn07CgpzdGF0aWMgc3RydWN0IHBsYXRmb3JtX2RyaXZlciB1ZGNfZHJpdmVyXzI0NDAgPSB7CgkuZHJpdmVyCQk9IHsKCQkubmFtZQk9ICJzM2MyNDQwLXVzYmdhZGdldCIsCgkJLm93bmVyCT0gVEhJU19NT0RVTEUsCgl9LAoJLnByb2JlCQk9IHMzYzI0MTBfdWRjX3Byb2JlLAoJLnJlbW92ZQkJPSBzM2MyNDEwX3VkY19yZW1vdmUsCgkuc3VzcGVuZAk9IHMzYzI0MTBfdWRjX3N1c3BlbmQsCgkucmVzdW1lCQk9IHMzYzI0MTBfdWRjX3Jlc3VtZSwKfTsKCnN0YXRpYyBpbnQgX19pbml0IHVkY19pbml0KHZvaWQpCnsKCWludCByZXR2YWw7CgoJZHByaW50ayhERUJVR19OT1JNQUwsICIlczogdmVyc2lvbiAlc1xuIiwgZ2FkZ2V0X25hbWUsIERSSVZFUl9WRVJTSU9OKTsKCglzM2MyNDEwX3VkY19kZWJ1Z2ZzX3Jvb3QgPSBkZWJ1Z2ZzX2NyZWF0ZV9kaXIoZ2FkZ2V0X25hbWUsIE5VTEwpOwoJaWYgKElTX0VSUihzM2MyNDEwX3VkY19kZWJ1Z2ZzX3Jvb3QpKSB7CgkJcHJpbnRrKEtFUk5fRVJSICIlczogZGVidWdmcyBkaXIgY3JlYXRpb24gZmFpbGVkICVsZFxuIiwKCQkJZ2FkZ2V0X25hbWUsIFBUUl9FUlIoczNjMjQxMF91ZGNfZGVidWdmc19yb290KSk7CgkJczNjMjQxMF91ZGNfZGVidWdmc19yb290ID0gTlVMTDsKCX0KCglyZXR2YWwgPSBwbGF0Zm9ybV9kcml2ZXJfcmVnaXN0ZXIoJnVkY19kcml2ZXJfMjQxMCk7CglpZiAocmV0dmFsKQoJCWdvdG8gZXJyOwoKCXJldHZhbCA9IHBsYXRmb3JtX2RyaXZlcl9yZWdpc3RlcigmdWRjX2RyaXZlcl8yNDQwKTsKCWlmIChyZXR2YWwpCgkJZ290byBlcnI7CgoJcmV0dXJuIDA7CgplcnI6CglkZWJ1Z2ZzX3JlbW92ZShzM2MyNDEwX3VkY19kZWJ1Z2ZzX3Jvb3QpOwoJcmV0dXJuIHJldHZhbDsKfQoKc3RhdGljIHZvaWQgX19leGl0IHVkY19leGl0KHZvaWQpCnsKCXBsYXRmb3JtX2RyaXZlcl91bnJlZ2lzdGVyKCZ1ZGNfZHJpdmVyXzI0MTApOwoJcGxhdGZvcm1fZHJpdmVyX3VucmVnaXN0ZXIoJnVkY19kcml2ZXJfMjQ0MCk7CglkZWJ1Z2ZzX3JlbW92ZShzM2MyNDEwX3VkY19kZWJ1Z2ZzX3Jvb3QpOwp9CgpFWFBPUlRfU1lNQk9MKHVzYl9nYWRnZXRfdW5yZWdpc3Rlcl9kcml2ZXIpOwoKbW9kdWxlX2luaXQodWRjX2luaXQpOwptb2R1bGVfZXhpdCh1ZGNfZXhpdCk7CgpNT0RVTEVfQVVUSE9SKERSSVZFUl9BVVRIT1IpOwpNT0RVTEVfREVTQ1JJUFRJT04oRFJJVkVSX0RFU0MpOwpNT0RVTEVfVkVSU0lPTihEUklWRVJfVkVSU0lPTik7Ck1PRFVMRV9MSUNFTlNFKCJHUEwiKTsKTU9EVUxFX0FMSUFTKCJwbGF0Zm9ybTpzM2MyNDEwLXVzYmdhZGdldCIpOwpNT0RVTEVfQUxJQVMoInBsYXRmb3JtOnMzYzI0NDAtdXNiZ2FkZ2V0Iik7Cg==