From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: From: Scott Bauer To: linux-nvme@lists.infradead.org Subject: [PATCH v2 2/4] block: Add Sed-opal library Date: Tue, 29 Nov 2016 14:52:00 -0700 Message-Id: <1480456322-27339-3-git-send-email-scott.bauer@intel.com> In-Reply-To: <1480456322-27339-1-git-send-email-scott.bauer@intel.com> References: <1480456322-27339-1-git-send-email-scott.bauer@intel.com> MIME-Version: 1.0 List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: keith.busch@intel.com, sagi@grimberg.me, hch@infradead.org, Rafael.Antognolli@intel.com, axboe@fb.com, linux-block@vger.kernel.org, Scott Bauer , jonathan.derrick@intel.com, j.naumann@fu-berlin.de Content-Type: text/plain; charset="utf-8" Sender: "Linux-nvme" Errors-To: linux-nvme-bounces+axboe=kernel.dk@lists.infradead.org List-ID: VGhpcyBwYXRjaCBpbXBsZW1lbnRzIHRoZSBuZWNlc3NhcnkgbG9naWMgdG8gYnJpbmcgYW4gT3Bh bAplbmFibGVkIGRyaXZlIG91dCBvZiBhIGZhY3RvcnktZW5hYmxlZCBpbnRvIGEgd29ya2luZwpP cGFsIHN0YXRlLgoKVGhpcyBwYXRjaCBzZXQgYWxzbyBlbmFibGVzIGxvZ2ljIHRvIHNhdmUgYSBw YXNzd29yZCB0bwpiZSByZXBsYXllZCBkdXJpbmcgYSByZXN1bWUgZnJvbSBzdXNwZW5kLiBUaGUg a2V5IGNhbiBiZQpzYXZlZCBpbiB0aGUgZHJpdmVyIG9yIGluIHRoZSBLZXJuZWwncyBLZXkgbWFu YWdtZW50LgoKU2lnbmVkLW9mZi1ieTogU2NvdHQgQmF1ZXIgPHNjb3R0LmJhdWVyQGludGVsLmNv bT4KU2lnbmVkLW9mZi1ieTogUmFmYWVsIEFudG9nbm9sbGkgPFJhZmFlbC5BbnRvZ25vbGxpQGlu dGVsLmNvbT4KLS0tCiBibG9jay9NYWtlZmlsZSAgICAgICAgICAgIHwgICAgMiArLQogYmxvY2sv c2VkLW9wYWwuYyAgICAgICAgICB8IDMxNTcgKysrKysrKysrKysrKysrKysrKysrKysrKysrKysr KysrKysrKysrKysrKysrCiBibG9jay9zZWQtb3BhbF9pbnRlcm5hbC5oIHwgIDYwMSArKysrKysr KysKIGJsb2NrL3NlZC5jICAgICAgICAgICAgICAgfCAgMjA3ICsrKwogNCBmaWxlcyBjaGFuZ2Vk LCAzOTY2IGluc2VydGlvbnMoKyksIDEgZGVsZXRpb24oLSkKIGNyZWF0ZSBtb2RlIDEwMDY0NCBi bG9jay9zZWQtb3BhbC5jCiBjcmVhdGUgbW9kZSAxMDA2NDQgYmxvY2svc2VkLW9wYWxfaW50ZXJu YWwuaAogY3JlYXRlIG1vZGUgMTAwNjQ0IGJsb2NrL3NlZC5jCgpkaWZmIC0tZ2l0IGEvYmxvY2sv TWFrZWZpbGUgYi9ibG9jay9NYWtlZmlsZQppbmRleCAzNmFjZGQ3Li42NjMyZDQyIDEwMDY0NAot LS0gYS9ibG9jay9NYWtlZmlsZQorKysgYi9ibG9jay9NYWtlZmlsZQpAQCAtOCw3ICs4LDcgQEAg b2JqLSQoQ09ORklHX0JMT0NLKSA6PSBiaW8ubyBlbGV2YXRvci5vIGJsay1jb3JlLm8gYmxrLXRh Zy5vIGJsay1zeXNmcy5vIFwKIAkJCWJsay1saWIubyBibGstbXEubyBibGstbXEtdGFnLm8gXAog CQkJYmxrLW1xLXN5c2ZzLm8gYmxrLW1xLWNwdW1hcC5vIGlvY3RsLm8gXAogCQkJZ2VuaGQubyBz Y3NpX2lvY3RsLm8gcGFydGl0aW9uLWdlbmVyaWMubyBpb3ByaW8ubyBcCi0JCQliYWRibG9ja3Mu byBwYXJ0aXRpb25zLworCQkJYmFkYmxvY2tzLm8gc2VkLm8gc2VkLW9wYWwubyBwYXJ0aXRpb25z LwogCiBvYmotJChDT05GSUdfQk9VTkNFKQkrPSBib3VuY2Uubwogb2JqLSQoQ09ORklHX0JMS19E RVZfQlNHKQkrPSBic2cubwpkaWZmIC0tZ2l0IGEvYmxvY2svc2VkLW9wYWwuYyBiL2Jsb2NrL3Nl ZC1vcGFsLmMKbmV3IGZpbGUgbW9kZSAxMDA2NDQKaW5kZXggMDAwMDAwMC4uNTM2MDJhYQotLS0g L2Rldi9udWxsCisrKyBiL2Jsb2NrL3NlZC1vcGFsLmMKQEAgLTAsMCArMSwzMTU3IEBACisvKgor ICogQ29weXJpZ2h0IMKpIDIwMTYgSW50ZWwgQ29ycG9yYXRpb24KKyAqCisgKiBBdXRob3JzOgor ICogICAgUmFmYWVsIEFudG9nbm9sbGkgPHJhZmFlbC5hbnRvZ25vbGxpQGludGVsLmNvbT4KKyAq ICAgIFNjb3R0ICBCYXVlciAgICAgIDxzY290dC5iYXVlckBpbnRlbC5jb20+CisgKgorICogVGhp cyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0IGFuZC9v ciBtb2RpZnkgaXQKKyAqIHVuZGVyIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB0aGUgR05V IEdlbmVyYWwgUHVibGljIExpY2Vuc2UsCisgKiB2ZXJzaW9uIDIsIGFzIHB1Ymxpc2hlZCBieSB0 aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uLgorICoKKyAqIFRoaXMgcHJvZ3JhbSBpcyBkaXN0 cmlidXRlZCBpbiB0aGUgaG9wZSBpdCB3aWxsIGJlIHVzZWZ1bCwgYnV0IFdJVEhPVVQKKyAqIEFO WSBXQVJSQU5UWTsgd2l0aG91dCBldmVuIHRoZSBpbXBsaWVkIHdhcnJhbnR5IG9mIE1FUkNIQU5U QUJJTElUWSBvcgorICogRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuICBTZWUgdGhl IEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvcgorICogbW9yZSBkZXRhaWxzLgorICovCisK KyNkZWZpbmUgcHJfZm10KGZtdCkgS0JVSUxEX01PRE5BTUUgIjpPUEFMOiAiIGZtdAorCisjaW5j bHVkZSA8bGludXgvZGVsYXkuaD4KKyNpbmNsdWRlIDxsaW51eC9kZXZpY2UuaD4KKyNpbmNsdWRl IDxsaW51eC9rZXJuZWwuaD4KKyNpbmNsdWRlIDxsaW51eC9saXN0Lmg+CisjaW5jbHVkZSA8bGlu dXgvZ2VuaGQuaD4KKyNpbmNsdWRlIDxsaW51eC9zbGFiLmg+CisjaW5jbHVkZSA8bGludXgvdWFj Y2Vzcy5oPgorI2luY2x1ZGUgPHVhcGkvbGludXgvc2VkLW9wYWwuaD4KKyNpbmNsdWRlIDxsaW51 eC9zZWQuaD4KKyNpbmNsdWRlIDxsaW51eC9zZWQtb3BhbC5oPgorI2luY2x1ZGUgPGxpbnV4L3N0 cmluZy5oPgorI2luY2x1ZGUgPGxpbnV4L2tkZXZfdC5oPgorI2luY2x1ZGUgPGxpbnV4L2tleS5o PgorCisjaW5jbHVkZSAic2VkLW9wYWxfaW50ZXJuYWwuaCIKKworI2RlZmluZSBJT19CVUZGRVJf TEVOR1RIIDIwNDgKKworI2RlZmluZSBNQVhfVE9LUyA2NAorCit0eXBlZGVmIGludCAoY29udF9m bikodm9pZCAqZGF0YSk7CisKK3N0cnVjdCBvcGFsX2NtZCB7CisJc3RydWN0IGJsb2NrX2Rldmlj ZSAqYmRldjsKKwljb250X2ZuICpjYjsKKwl2b2lkICpjYl9kYXRhOworCisJc2l6ZV90IHBvczsK Kwl1OCBjbWRfYnVmW0lPX0JVRkZFUl9MRU5HVEggKiAyXTsKKwl1OCByZXNwX2J1ZltJT19CVUZG RVJfTEVOR1RIICogMl07CisJdTggKmNtZDsKKwl1OCAqcmVzcDsKK307CisKKy8qCisgKiBPbiB0 aGUgcGFyc2VkIHJlc3BvbnNlLCB3ZSBkb24ndCBzdG9yZSBhZ2FpbiB0aGUgdG9rcyB0aGF0IGFy ZSBhbHJlYWR5CisgKiBzdG9yZWQgaW4gdGhlIHJlc3BvbnNlIGJ1ZmZlci4gSW5zdGVhZCwgZm9y IGVhY2ggdG9rZW4sIHdlIGp1c3Qgc3RvcmUgYQorICogcG9pbnRlciB0byB0aGUgcG9zaXRpb24g aW4gdGhlIGJ1ZmZlciB3aGVyZSB0aGUgdG9rZW4gc3RhcnRzLCBhbmQgdGhlIHNpemUKKyAqIG9m IHRoZSB0b2tlbiBpbiBieXRlcy4KKyAqLworc3RydWN0IG9wYWxfcmVzcF90b2sgeworCWNvbnN0 IHU4ICpwb3M7CisJc2l6ZV90IGxlbjsKKwllbnVtIE9QQUxfUkVTUE9OU0VfVE9LRU4gdHlwZTsK KwllbnVtIE9QQUxfQVRPTV9XSURUSCB3aWR0aDsKKwl1bmlvbiB7CisJCXU2NCB1OworCQlzNjQg czsKKwl9IHN0b3JlZDsKK307CisKKy8qCisgKiBGcm9tIHRoZSByZXNwb25zZSBoZWFkZXIgaXQn cyBub3QgcG9zc2libGUgdG8ga25vdyBob3cgbWFueSB0b2tlbnMgdGhlcmUgYXJlCisgKiBvbiB0 aGUgcGF5bG9hZC4gU28gd2UgaGFyZGNvZGUgdGhhdCB0aGUgbWF4aW11bSB3aWxsIGJlIE1BWF9U T0tTLCBhbmQgbGF0ZXIKKyAqIGlmIHdlIHN0YXJ0IGRlYWxpbmcgd2l0aCBtZXNzYWdlcyB0aGF0 IGhhdmUgbW9yZSB0aGFuIHRoYXQsIHdlIGNhbiBpbmNyZWFzZQorICogdGhpcyBudW1iZXIuIFRo aXMgaXMgZG9uZSB0byBhdm9pZCBoYXZpbmcgdG8gbWFrZSB0d28gcGFzc2VzIHRocm91Z2ggdGhl CisgKiByZXNwb25zZSwgdGhlIGZpcnN0IG9uZSBjb3VudGluZyBob3cgbWFueSB0b2tlbnMgd2Ug aGF2ZSBhbmQgdGhlIHNlY29uZCBvbmUKKyAqIGFjdHVhbGx5IHN0b3JpbmcgdGhlIHBvc2l0aW9u cy4KKyAqLworc3RydWN0IHBhcnNlZF9yZXNwIHsKKwlpbnQgbnVtOworCXN0cnVjdCBvcGFsX3Jl c3BfdG9rIHRva3NbTUFYX1RPS1NdOworfTsKKworc3RydWN0IG9wYWxfZGV2OworCit0eXBlZGVm IGludCAoKm9wYWxfc3RlcCkoc3RydWN0IG9wYWxfZGV2ICpkZXYpOworCitzdHJ1Y3Qgb3BhbF9k ZXYgeworCWRldl90IG1ham1pbjsKKwlzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2ZuOworCXZvaWQg KnN1Ym1pdF9kYXRhOworCXN0cnVjdCBvcGFsX2xvY2tfdW5sb2NrIGxrdWw7CisJY29uc3Qgb3Bh bF9zdGVwICpmdW5jczsKKwl2b2lkICoqZnVuY19kYXRhOworCWJvb2wgcmVzdW1lX2Zyb21fc3Vz cGVuZDsKKwlzdHJ1Y3Qgb3BhbF9zdXNwZW5kX3VubGsgKnJlc3VtZV9kYXRhOworCXNpemVfdCBu dW1fZnVuY19kYXRhOworCWF0b21pY190IGluX3VzZTsKKwlzZWN0b3JfdCBzdGFydDsKKwlzZWN0 b3JfdCBsZW5ndGg7CisJdTggbHI7CisJdTgga2V5X3R5cGU7CisJdTgga2V5X25hbWVbT1BBTF9L RVlfTUFYXTsKKwlzaXplX3Qga2V5X25hbWVfbGVuOworCXU4IGtleVtPUEFMX0tFWV9NQVhdOwor CXNpemVfdCBrZXlfbGVuOworCXUxNiBjb21JRDsKKwl1MzIgSFNOOworCXUzMiBUU047CisJdTY0 IGFsaWduOworCXU2NCBsb3dlc3RfbGJhOworCXN0cnVjdCBsaXN0X2hlYWQgbm9kZTsKKwljaGFy IGRpc2tfbmFtZVtESVNLX05BTUVfTEVOXTsKKwlpbnQgc3RhdGU7CisKKwlzdHJ1Y3Qgb3BhbF9j bWQgY21kOworCXN0cnVjdCBwYXJzZWRfcmVzcCBwYXJzZWQ7CisKKwlzaXplX3QgcHJldl9kX2xl bjsKKwl2b2lkICpwcmV2X2RhdGE7CisKKwlvcGFsX3N0ZXAgZXJyb3JfY2I7CisJdm9pZCAqZXJy b3JfY2JfZGF0YTsKK307CisKK0xJU1RfSEVBRChvcGFsX2xpc3QpOworREVGSU5FX1NQSU5MT0NL KGxpc3Rfc3BpbmxvY2spOworCitzdGF0aWMgdm9pZCBwcmludF9idWZmZXIoY29uc3QgdTggKnB0 ciwgdTMyIGxlbmd0aCkKK3sKKyNpZmRlZiBERUJVRworCXByaW50X2hleF9kdW1wX2J5dGVzKCJP UEFMOiAiLCBEVU1QX1BSRUZJWF9PRkZTRVQsIHB0ciwgbGVuZ3RoKTsKKwlwcl9kZWJ1ZygiXG4i KTsKKyNlbmRpZgorfQorCisjZGVmaW5lIFRQRVJfU1lOQ19TVVBQT1JURUQgQklUKDApCisKK3N0 YXRpYyBib29sIGNoZWNrX3RwZXIoY29uc3Qgdm9pZCAqZGF0YSkKK3sKKwljb25zdCBzdHJ1Y3Qg ZDBfdHBlcl9mZWF0dXJlcyAqdHBlciA9IGRhdGE7CisJdTggZmxhZ3MgPSB0cGVyLT5zdXBwb3J0 ZWRfZmVhdHVyZXM7CisKKwlpZiAoIShmbGFncyAmIFRQRVJfU1lOQ19TVVBQT1JURUQpKSB7CisJ CXByX2VycigiVFBlciBzeW5jIG5vdCBzdXBwb3J0ZWQuIGZsYWdzID0gJWRcbiIsCisJCSAgICAg ICB0cGVyLT5zdXBwb3J0ZWRfZmVhdHVyZXMpOworCQlyZXR1cm4gZmFsc2U7CisJfQorCisJcmV0 dXJuIHRydWU7Cit9CisKK3N0YXRpYyBib29sIGNoZWNrX1NVTShjb25zdCB2b2lkICpkYXRhKQor eworCWNvbnN0IHN0cnVjdCBkMF9zaW5nbGVfdXNlcl9tb2RlICpzdW0gPSBkYXRhOworCXUzMiBu bG8gPSBiZTMyX3RvX2NwdShzdW0tPm51bV9sb2NraW5nX29iamVjdHMpOworCisJaWYgKG5sbyA9 PSAwKSB7CisJCXByX2VycigiTmVlZCBhdCBsZWFzdCBvbmUgbG9ja2luZyBvYmplY3QuXG4iKTsK KwkJcmV0dXJuIGZhbHNlOworCX0KKworCXByX2RlYnVnKCJOdW1iZXIgb2YgbG9ja2luZyBvYmpl Y3RzOiAlZFxuIiwgbmxvKTsKKworCXJldHVybiB0cnVlOworfQorCitzdGF0aWMgdTE2IGdldF9j b21JRF92MTAwKGNvbnN0IHZvaWQgKmRhdGEpCit7CisJY29uc3Qgc3RydWN0IGQwX29wYWxfdjEw MCAqdjEwMCA9IGRhdGE7CisKKwlyZXR1cm4gYmUxNl90b19jcHUodjEwMC0+YmFzZUNvbUlEKTsK K30KKworc3RhdGljIHUxNiBnZXRfY29tSURfdjIwMChjb25zdCB2b2lkICpkYXRhKQoreworCWNv bnN0IHN0cnVjdCBkMF9vcGFsX3YyMDAgKnYyMDAgPSBkYXRhOworCisJcmV0dXJuIGJlMTZfdG9f Y3B1KHYyMDAtPmJhc2VDb21JRCk7Cit9CisKK3N0YXRpYyBpbnQgb3BhbF9zZW5kX2NtZChzdHJ1 Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwlyZXR1cm4gZGV2LT5zdWJtaXRfZm4oZGV2LT5zdWJtaXRf ZGF0YSwgZGV2LT5jb21JRCwgVENHX1NFQ1BfMDEsCisJCQkgICAgICBkZXYtPmNtZC5jbWQsIElP X0JVRkZFUl9MRU5HVEgsIHRydWUpOworfQorCitzdGF0aWMgaW50IG9wYWxfcmVjdl9jbWQoc3Ry dWN0IG9wYWxfZGV2ICpkZXYpCit7CisJcmV0dXJuIGRldi0+c3VibWl0X2ZuKGRldi0+c3VibWl0 X2RhdGEsIGRldi0+Y29tSUQsIFRDR19TRUNQXzAxLAorCQkJICAgICAgZGV2LT5jbWQucmVzcCwg SU9fQlVGRkVSX0xFTkdUSCwgZmFsc2UpOworfQorCitzdGF0aWMgaW50IG9wYWxfcmVjdl9jaGVj ayhzdHJ1Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwlzaXplX3QgYnVmbGVuID0gSU9fQlVGRkVSX0xF TkdUSDsKKwl2b2lkICpidWZmZXIgPSBkZXYtPmNtZC5yZXNwOworCXN0cnVjdCBvcGFsX2hlYWRl ciAqaGRyID0gYnVmZmVyOworCWludCByZXQ7CisKKwlkbyB7CisJCXByX2RlYnVnKCIlczogU2Vu dCBPUEFMIGNvbW1hbmQ6IG91dHN0YW5kaW5nPSVkLCBtaW5UcmFuc2Zlcj0lZFxuIiwKKwkJCSBk ZXYtPmRpc2tfbmFtZSwgaGRyLT5jcC5vdXRzdGFuZGluZ0RhdGEsCisJCQkgaGRyLT5jcC5taW5U cmFuc2Zlcik7CisKKwkJaWYgKGhkci0+Y3Aub3V0c3RhbmRpbmdEYXRhID09IDAgfHwKKwkJICAg IGhkci0+Y3AubWluVHJhbnNmZXIgIT0gMCkKKwkJCXJldHVybiAwOworCisJCW1lbXNldChidWZm ZXIsIDAsIGJ1Zmxlbik7CisJCXJldCA9IG9wYWxfcmVjdl9jbWQoZGV2KTsKKwl9IHdoaWxlICgh cmV0KTsKKworCXJldHVybiByZXQ7Cit9CisKK3N0YXRpYyBpbnQgb3BhbF9zZW5kX3JlY3Yoc3Ry dWN0IG9wYWxfZGV2ICpkZXYsIGNvbnRfZm4gKmNvbnQpCit7CisJaW50IHJldDsKKworCXJldCA9 IG9wYWxfc2VuZF9jbWQoZGV2KTsKKwlpZiAocmV0KQorCQlyZXR1cm4gcmV0OworCXJldCA9IG9w YWxfcmVjdl9jbWQoZGV2KTsKKwlpZiAocmV0KQorCQlyZXR1cm4gcmV0OworCXJldCA9IG9wYWxf cmVjdl9jaGVjayhkZXYpOworCWlmIChyZXQpCisJCXJldHVybiByZXQ7CisKKwlyZXR1cm4gY29u dChkZXYpOworfQorCitzdGF0aWMgdm9pZCBjaGVja19nZW9tZXRyeShzdHJ1Y3Qgb3BhbF9kZXYg KmRldiwgY29uc3Qgdm9pZCAqZGF0YSkKK3sKKwljb25zdCBzdHJ1Y3QgZDBfZ2VvbWV0cnlfZmVh dHVyZXMgKmdlbyA9IGRhdGE7CisKKwlkZXYtPmFsaWduID0gZ2VvLT5hbGlnbm1lbnRfZ3JhbnVs YXJpdHk7CisJZGV2LT5sb3dlc3RfbGJhID0gZ2VvLT5sb3dlc3RfYWxpZ25lZF9sYmE7Cit9CisK K3N0YXRpYyBpbnQgbmV4dChzdHJ1Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwlvcGFsX3N0ZXAgZnVu YzsKKwlpbnQgZXJyb3IgPSAwOworCisJZG8geworCisJCWZ1bmMgPSBkZXYtPmZ1bmNzW2Rldi0+ c3RhdGVdOworCQlpZiAoIWZ1bmMpCisJCQlicmVhazsKKworCQlkZXYtPnN0YXRlKys7CisJCWVy cm9yID0gZnVuYyhkZXYpOworCisJCWlmIChlcnJvcikgeworCQkJcHJfZXJyKCIlczogRXJyb3Ig b24gc3RlcCBmdW5jdGlvbjogJWQgd2l0aCBlcnJvciAlZDogJXNcbiIsCisJCQkgICAgICAgZGV2 LT5kaXNrX25hbWUsIGRldi0+c3RhdGUsIGVycm9yLAorCQkJICAgICAgIG9wYWxfZXJyb3JfdG9f aHVtYW4oZXJyb3IpKTsKKworCQkJLyoKKwkJCSAqIFdlIGNoZWNrIGZvciBzdGF0ZSA+IDIgYmVj YXVzZSBlcnJvcl9jYiBpcworCQkJICogYW4gZW5kIHNlc3Npb24gY2FsbC4gV2UgbmV2ZXIgc3Rh cnQgYSBzZXNzaW9uIHVudGlsCisJCQkgKiBhZnRlciBzdGF0ZSAyLiBTbyBJZiB3ZSBmYWlsZWQg b24gc3RhdGUgMiBvciBsb3dlcgorCQkJICogdGhhdCBtZWFucyB3ZSBmYWlsZWQgdG8gc3RhcnQg YSBzZXNzaW9uCisJCQkgKiBkdWUgdG8gYSBiYWQgcHcgb3Igc29tZXRoaW5nLiBUaGVyZWZvcmUg aXMgbm8gcmVhc29uCisJCQkgKiB0byBlbmQgYSBub24gZXhpc3RhbnQgc2Vzc2lvbi4KKwkJCSAq LworCQkJaWYgKGRldi0+ZXJyb3JfY2IgJiYgZGV2LT5zdGF0ZSA+IDIpCisJCQkJZGV2LT5lcnJv cl9jYihkZXYtPmVycm9yX2NiX2RhdGEpOworCQl9CisJfSB3aGlsZSAoIWVycm9yKTsKKworCXJl dHVybiBlcnJvcjsKK30KKworc3RhdGljIGludCBvcGFsX2Rpc2NvdmVyeTBfZW5kKHN0cnVjdCBv cGFsX2RldiAqZGV2KQoreworCWJvb2wgZm91bmRDb21JRCA9IGZhbHNlLCBzdXBwb3J0ZWQgPSB0 cnVlLCBzaW5nbGVfdXNlciA9IGZhbHNlOworCWNvbnN0IHN0cnVjdCBkMF9oZWFkZXIgKmhkcjsK Kwljb25zdCB1OCAqZXBvcywgKmNwb3M7CisJdTE2IGNvbUlEID0gMDsKKwlpbnQgZXJyb3IgPSAw OworCisJZXBvcyA9IGRldi0+Y21kLnJlc3A7CisJY3BvcyA9IGRldi0+Y21kLnJlc3A7CisJaGRy ID0gKHN0cnVjdCBkMF9oZWFkZXIgKilkZXYtPmNtZC5yZXNwOworCisJcHJpbnRfYnVmZmVyKGRl di0+Y21kLnJlc3AsIGJlMzJfdG9fY3B1KGhkci0+bGVuZ3RoKSk7CisKKwllcG9zICs9IGJlMzJf dG9fY3B1KGhkci0+bGVuZ3RoKTsgLyogZW5kIG9mIGJ1ZmZlciAqLworCWNwb3MgKz0gc2l6ZW9m KCpoZHIpOyAvKiBjdXJyZW50IHBvc2l0aW9uIG9uIGJ1ZmZlciAqLworCisJd2hpbGUgKGNwb3Mg PCBlcG9zICYmIHN1cHBvcnRlZCkgeworCQljb25zdCBzdHJ1Y3QgZDBfZmVhdHVyZXMgKmJvZHkg PQorCQkJKGNvbnN0IHN0cnVjdCBkMF9mZWF0dXJlcyAqKWNwb3M7CisKKwkJc3dpdGNoIChiZTE2 X3RvX2NwdShib2R5LT5jb2RlKSkgeworCQljYXNlIEZDX1RQRVI6CisJCQlzdXBwb3J0ZWQgPSBj aGVja190cGVyKGJvZHktPmZlYXR1cmVzKTsKKwkJCWJyZWFrOworCQljYXNlIEZDX1NJTkdMRVVT RVI6CisJCQlzaW5nbGVfdXNlciA9IGNoZWNrX1NVTShib2R5LT5mZWF0dXJlcyk7CisJCQlicmVh azsKKwkJY2FzZSBGQ19HRU9NRVRSWToKKwkJCWNoZWNrX2dlb21ldHJ5KGRldiwgYm9keSk7CisJ CQlicmVhazsKKwkJY2FzZSBGQ19MT0NLSU5HOgorCQljYXNlIEZDX0VOVEVSUFJJU0U6CisJCWNh c2UgRkNfREFUQVNUT1JFOgorCQkJLyogc29tZSBpZ25vcmVkIHByb3BlcnRpZXMgKi8KKwkJCXBy X2RlYnVnKCIlczogRm91bmQgT1BBTCBmZWF0dXJlIGRlc2NyaXB0aW9uOiAlZFxuIiwKKwkJCQkg ZGV2LT5kaXNrX25hbWUsIGJlMTZfdG9fY3B1KGJvZHktPmNvZGUpKTsKKwkJCWJyZWFrOworCQlj YXNlIEZDX09QQUxWMTAwOgorCQkJY29tSUQgPSBnZXRfY29tSURfdjEwMChib2R5LT5mZWF0dXJl cyk7CisJCQlmb3VuZENvbUlEID0gdHJ1ZTsKKwkJCWJyZWFrOworCQljYXNlIEZDX09QQUxWMjAw OgorCQkJY29tSUQgPSBnZXRfY29tSURfdjIwMChib2R5LT5mZWF0dXJlcyk7CisJCQlmb3VuZENv bUlEID0gdHJ1ZTsKKwkJCWJyZWFrOworCQljYXNlIDB4YmZmZiAuLi4gMHhmZmZmOgorCQkJLyog dmVuZG9yIHNwZWNpZmljLCBqdXN0IGlnbm9yZSAqLworCQkJYnJlYWs7CisJCWRlZmF1bHQ6CisJ CQlwcl93YXJuKCIlczogT1BBTCBVbmtub3duIGZlYXR1cmU6ICVkXG4iLAorCQkJCWRldi0+ZGlz a19uYW1lLCBiZTE2X3RvX2NwdShib2R5LT5jb2RlKSk7CisKKwkJfQorCQljcG9zICs9IGJvZHkt Pmxlbmd0aCArIDQ7CisJfQorCisJaWYgKCFzdXBwb3J0ZWQpIHsKKwkJcHJfZXJyKCIlczogRGV2 aWNlIG5vdCBzdXBwb3J0ZWRcbiIsIGRldi0+ZGlza19uYW1lKTsKKwkJZXJyb3IgPSAxOworCQln b3RvIGVycl9jYWxsYmFjazsKKwl9CisKKwlpZiAoIXNpbmdsZV91c2VyKQorCQlwcl93YXJuKCIl czogRGV2aWNlIGRvZXNuJ3Qgc3VwcG9ydCBzaW5nbGUgdXNlciBtb2RlXG4iLAorCQkJZGV2LT5k aXNrX25hbWUpOworCisJaWYgKCFmb3VuZENvbUlEKSB7CisJCXByX3dhcm4oIiVzOiBDb3VsZCBu b3QgZmluZCBPUEFMIGNvbUlEIGZvciBkZXZpY2UuIE9QQUwga2VybmVsIHVubG9ja2luZyB3aWxs IGJlIGRpc2FibGVkXG4iLAorCQkJZGV2LT5kaXNrX25hbWUpOworCQllcnJvciA9IDE7CisJCWdv dG8gZXJyX2NhbGxiYWNrOworCX0KKworCWRldi0+Y29tSUQgPSBjb21JRDsKKworZXJyX2NhbGxi YWNrOgorCXJldHVybiBlcnJvcjsKK30KKworc3RhdGljIGludCBvcGFsX2Rpc2NvdmVyeTAoc3Ry dWN0IG9wYWxfZGV2ICpkZXYpCit7CisJaW50IHJldDsKKworCW1lbXNldChkZXYtPmNtZC5yZXNw LCAwLCBJT19CVUZGRVJfTEVOR1RIKTsKKwlkZXYtPmNvbUlEID0gMHgwMDAxOworCXJldCA9IG9w YWxfcmVjdl9jbWQoZGV2KTsKKwlpZiAocmV0KQorCQlyZXR1cm4gcmV0OworCXJldHVybiBvcGFs X2Rpc2NvdmVyeTBfZW5kKGRldik7Cit9CisKK3N0YXRpYyB2b2lkIGFkZF90b2tlbl91OChzdHJ1 Y3Qgb3BhbF9jbWQgKmNtZCwgdTggdG9rKQoreworCWNtZC0+Y21kW2NtZC0+cG9zKytdID0gdG9r OworfQorCitzdGF0aWMgc3NpemVfdCB0ZXN0X2FuZF9hZGRfdG9rZW5fdTgoc3RydWN0IG9wYWxf Y21kICpjbWQsIHU4IHRvaykKK3sKKwlCVUlMRF9CVUdfT04oSU9fQlVGRkVSX0xFTkdUSCA+PSBT SVpFX01BWCk7CisKKwlpZiAoY21kLT5wb3MgPj0gSU9fQlVGRkVSX0xFTkdUSCAtIDEpIHsKKwkJ cHJfZXJyKCJFcnJvciBhZGRpbmcgdTg6IGVuZCBvZiBidWZmZXIuXG4iKTsKKwkJcmV0dXJuIC1F UkFOR0U7CisJfQorCisJYWRkX3Rva2VuX3U4KGNtZCwgdG9rKTsKKworCXJldHVybiAxOworfQor CisjZGVmaW5lIFRJTllfQVRPTV9EQVRBX01BU0sgR0VOTUFTSyg1LCAwKQorI2RlZmluZSBUSU5Z X0FUT01fU0lHTkVEIEJJVCg2KQorCisjZGVmaW5lIFNIT1JUX0FUT01fSUQgQklUKDcpCisjZGVm aW5lIFNIT1JUX0FUT01fQllURVNUUklORyBCSVQoNSkKKyNkZWZpbmUgU0hPUlRfQVRPTV9TSUdO RUQgQklUKDQpCisjZGVmaW5lIFNIT1JUX0FUT01fTEVOX01BU0sgR0VOTUFTSygzLCAwKQorCitz dGF0aWMgdm9pZCBhZGRfc2hvcnRfYXRvbV9oZWFkZXIoc3RydWN0IG9wYWxfY21kICpjbWQsIGJv b2wgYnl0ZXN0cmluZywKKwkJCQkgIGJvb2wgaGFzX3NpZ24sIGludCBsZW4pCit7CisJdTggYXRv bTsKKworCWF0b20gPSBTSE9SVF9BVE9NX0lEOworCWF0b20gfD0gYnl0ZXN0cmluZyA/IFNIT1JU X0FUT01fQllURVNUUklORyA6IDA7CisJYXRvbSB8PSBoYXNfc2lnbiA/IFNIT1JUX0FUT01fU0lH TkVEIDogMDsKKwlhdG9tIHw9IGxlbiAmIFNIT1JUX0FUT01fTEVOX01BU0s7CisKKwlhZGRfdG9r ZW5fdTgoY21kLCBhdG9tKTsKK30KKworI2RlZmluZSBNRURJVU1fQVRPTV9JRCAoQklUKDcpIHwg QklUKDYpKQorI2RlZmluZSBNRURJVU1fQVRPTV9CWVRFU1RSSU5HIEJJVCg0KQorI2RlZmluZSBN RURJVU1fQVRPTV9TSUdORUQgQklUKDMpCisjZGVmaW5lIE1FRElVTV9BVE9NX0xFTl9NQVNLIEdF Tk1BU0soMiwgMCkKKworc3RhdGljIHZvaWQgYWRkX21lZGl1bV9hdG9tX2hlYWRlcihzdHJ1Y3Qg b3BhbF9jbWQgKmNtZCwgYm9vbCBieXRlc3RyaW5nLAorCQkJCSAgIGJvb2wgaGFzX3NpZ24sIGlu dCBsZW4pCit7CisJdTggaGVhZGVyMDsKKworCWhlYWRlcjAgPSBNRURJVU1fQVRPTV9JRDsKKwlo ZWFkZXIwIHw9IGJ5dGVzdHJpbmcgPyBNRURJVU1fQVRPTV9CWVRFU1RSSU5HIDogMDsKKwloZWFk ZXIwIHw9IGhhc19zaWduID8gTUVESVVNX0FUT01fU0lHTkVEIDogMDsKKwloZWFkZXIwIHw9IChs ZW4gPj4gOCkgJiBNRURJVU1fQVRPTV9MRU5fTUFTSzsKKwljbWQtPmNtZFtjbWQtPnBvcysrXSA9 IGhlYWRlcjA7CisJY21kLT5jbWRbY21kLT5wb3MrK10gPSBsZW47Cit9CisKK3N0YXRpYyB2b2lk IGFkZF90b2tlbl91NjQoc3RydWN0IG9wYWxfY21kICpjbWQsIHU2NCBudW1iZXIsIHNpemVfdCBs ZW4pCit7CisJYWRkX3Nob3J0X2F0b21faGVhZGVyKGNtZCwgZmFsc2UsIGZhbHNlLCBsZW4pOwor CisJd2hpbGUgKGxlbi0tKSB7CisJCXU4IG4gPSBudW1iZXIgPj4gKGxlbiAqIDgpOworCisJCWFk ZF90b2tlbl91OChjbWQsIG4pOworCX0KK30KKworc3RhdGljIHNzaXplX3QgdGVzdF9hbmRfYWRk X3Rva2VuX3U2NChzdHJ1Y3Qgb3BhbF9jbWQgKmNtZCwgdTY0IG51bWJlcikKK3sKKwlpbnQgbGVu OworCWludCBtc2I7CisKKwlpZiAoIShudW1iZXIgJiB+VElOWV9BVE9NX0RBVEFfTUFTSykpCisJ CXJldHVybiB0ZXN0X2FuZF9hZGRfdG9rZW5fdTgoY21kLCBudW1iZXIpOworCisJbXNiID0gZmxz KG51bWJlcik7CisJbGVuID0gRElWX1JPVU5EX1VQKG1zYiwgNCk7CisKKwlpZiAoY21kLT5wb3Mg Pj0gSU9fQlVGRkVSX0xFTkdUSCAtIGxlbiAtIDEpIHsKKwkJcHJfZXJyKCJFcnJvciBhZGRpbmcg dTY0OiBlbmQgb2YgYnVmZmVyLlxuIik7CisJCXJldHVybiAtRVJBTkdFOworCX0KKworCWFkZF90 b2tlbl91NjQoY21kLCBudW1iZXIsIGxlbik7CisKKwkvKiByZXR1cm4gbGVuZ3RoIG9mIHRva2Vu IHBsdXMgYXRvbSAqLworCXJldHVybiBsZW4gKyAxOworfQorCitzdGF0aWMgdm9pZCBhZGRfdG9r ZW5fYnl0ZXN0cmluZyhzdHJ1Y3Qgb3BhbF9jbWQgKmNtZCwKKwkJCQkgY29uc3QgdTggKmJ5dGVz dHJpbmcsIHNpemVfdCBsZW4pCit7CisJbWVtY3B5KCZjbWQtPmNtZFtjbWQtPnBvc10sIGJ5dGVz dHJpbmcsIGxlbik7CisJY21kLT5wb3MgKz0gbGVuOworfQorCitzdGF0aWMgc3NpemVfdCB0ZXN0 X2FuZF9hZGRfdG9rZW5fYnl0ZXN0cmluZyhzdHJ1Y3Qgb3BhbF9jbWQgKmNtZCwKKwkJCQkJICAg ICBjb25zdCB1OCAqYnl0ZXN0cmluZywgc2l6ZV90IGxlbikKK3sKKwlzaXplX3QgaGVhZGVyX2xl biA9IDE7CisJYm9vbCBpc19zaG9ydF9hdG9tID0gdHJ1ZTsKKworCWlmIChsZW4gJiB+U0hPUlRf QVRPTV9MRU5fTUFTSykgeworCQloZWFkZXJfbGVuID0gMjsKKwkJaXNfc2hvcnRfYXRvbSA9IGZh bHNlOworCX0KKworCWlmIChjbWQtPnBvcyA+PSBJT19CVUZGRVJfTEVOR1RIIC0gbGVuIC0gaGVh ZGVyX2xlbikgeworCQlwcl9lcnIoIkVycm9yIGFkZGluZyBieXRlc3RyaW5nOiBlbmQgb2YgYnVm ZmVyLlxuIik7CisJCXJldHVybiAtRVJBTkdFOworCX0KKworCWlmIChpc19zaG9ydF9hdG9tKQor CQlhZGRfc2hvcnRfYXRvbV9oZWFkZXIoY21kLCB0cnVlLCBmYWxzZSwgbGVuKTsKKwllbHNlCisJ CWFkZF9tZWRpdW1fYXRvbV9oZWFkZXIoY21kLCB0cnVlLCBmYWxzZSwgbGVuKTsKKworCWFkZF90 b2tlbl9ieXRlc3RyaW5nKGNtZCwgYnl0ZXN0cmluZywgbGVuKTsKKworCXJldHVybiBoZWFkZXJf bGVuICsgbGVuOworfQorCisjZGVmaW5lIExPQ0tJTkdfUkFOR0VfTk9OX0dMT0JBTCAweDAzCisK K3N0YXRpYyBpbnQgYnVpbGRfbG9ja2luZ19yYW5nZSh1OCAqYnVmZmVyLCBzaXplX3QgbGVuZ3Ro LCB1OCBscikKK3sKKwlpZiAobGVuZ3RoIDwgT1BBTF9VSURfTEVOR1RIKQorCQlyZXR1cm4gLUVS QU5HRTsKKworCW1lbWNweShidWZmZXIsIE9QQUxVSURbT1BBTF9MT0NLSU5HUkFOR0VfR0xPQkFM XSwgT1BBTF9VSURfTEVOR1RIKTsKKworCWlmIChsciA9PSAwKQorCQlyZXR1cm4gMDsKKwlidWZm ZXJbNV0gPSBMT0NLSU5HX1JBTkdFX05PTl9HTE9CQUw7CisJYnVmZmVyWzddID0gbHI7CisKKwly ZXR1cm4gMDsKK30KKworc3RhdGljIGludCBidWlsZF9sb2NraW5nX3VzZXIodTggKmJ1ZmZlciwg c2l6ZV90IGxlbmd0aCwgdTggbHIpCit7CisJaWYgKGxlbmd0aCA8IE9QQUxfVUlEX0xFTkdUSCkK KwkJcmV0dXJuIC1FUkFOR0U7CisKKwltZW1jcHkoYnVmZmVyLCBPUEFMVUlEW09QQUxfVVNFUjFf VUlEXSwgT1BBTF9VSURfTEVOR1RIKTsKKworCWJ1ZmZlcls3XSA9IGxyICsgMTsKKworCXJldHVy biAwOworfQorCisvKgorICogTiA9IG51bWJlciBvZiBmb3JtYXQgc3BlY2lmaWVycyAoMS05OTkp IHRvIGJlIHJlcGxpY2F0ZWQKKyAqIGMgPSB1OAorICogdSA9IHU2NAorICogcyA9IGJ5dGVzdHJp bmcsIGxlbmd0aAorICoKKyAqIHJldCA9IHRlc3RfYW5kX2FkZF90b2tlbl92YShjbWQsICJjIiwK KyAqCQkJICAgICAgIHU4X3ZhbDEpOworICoKKyAqIHJldCA9IHRlc3RfYW5kX2FkZF90b2tlbl92 YShjbWQsICIyYzJ1IiwKKyAqCQkJICAgICAgIHU4X3ZhbDEsIHU4X3ZhbDIsIHU2NF92YWwxLCB1 NjRfdmFsMik7CisgKgorICogcmV0ID0gdGVzdF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwgIjNzIiwK KyAqCQkJICAgICAgIGJ5dGVzdHJpbmcxLCBsZW5ndGgxLAorICoJCQkgICAgICAgYnl0ZXN0cmlu ZzIsIGxlbmd0aDIsCisgKgkJCSAgICAgICBieXRlc3RyaW5nMywgbGVuZ3RoMyk7CisgKi8KK3N0 YXRpYyBpbnQgdGVzdF9hbmRfYWRkX3Rva2VuX3ZhKHN0cnVjdCBvcGFsX2NtZCAqY21kLAorCQkJ CSBjb25zdCBjaGFyICpmbXQsIC4uLikKK3sKKwljb25zdCB1OCAqaXQgPSBmbXQsICp0bXA7CisJ aW50IHJldCwgbnVtID0gMSwgc3VtID0gMDsKKwl2YV9saXN0IGFwOworCisJdmFfc3RhcnQoYXAs IGZtdCk7CisKKwl3aGlsZSAoKml0ICE9ICdcMCcpIHsKKwkJdTY0IHRvazY0ID0gMDsKKwkJdTgg dG9rLCAqYnN0cjsKKwkJc2l6ZV90IGxlbjsKKworCQlyZXQgPSAwOworCisJCXN3aXRjaCAoKml0 KSB7CisJCWNhc2UgJzEnIC4uLiAnOSc6CisJCQl0bXAgPSBpdDsKKwkJCW51bSA9IDA7CisJCQl3 aGlsZSAoKnRtcCA+PSAnMCcgJiYgKnRtcCA8PSAnOScpCisJCQkJbnVtID0gbnVtICogMTAgKyAo KnRtcCsrIC0gJzAnKTsKKwkJCWl0ID0gdG1wOworCQkJY29udGludWU7CisJCWNhc2UgJ2MnOgor CQkJd2hpbGUgKG51bS0tKSB7CisJCQkJdG9rID0gdmFfYXJnKGFwLCB1bnNpZ25lZCBpbnQpOwor CQkJCXJldCA9IHRlc3RfYW5kX2FkZF90b2tlbl91OChjbWQsIHRvayk7CisJCQkJaWYgKHJldCA8 IDApCisJCQkJCWdvdG8gZXJyOworCQkJfQorCQkJbnVtID0gMTsKKwkJCWJyZWFrOworCQljYXNl ICd1JzoKKwkJCXdoaWxlIChudW0tLSkgeworCQkJCXRvazY0ID0gdmFfYXJnKGFwLCB1NjQpOwor CQkJCXJldCA9IHRlc3RfYW5kX2FkZF90b2tlbl91NjQoY21kLCB0b2s2NCk7CisJCQkJaWYgKHJl dCA8IDApCisJCQkJCWdvdG8gZXJyOworCQkJfQorCQkJbnVtID0gMTsKKwkJCWJyZWFrOworCQlj YXNlICdzJzoKKwkJCXdoaWxlIChudW0tLSkgeworCQkJCWJzdHIgPSB2YV9hcmcoYXAsIHU4ICop OworCQkJCWxlbiA9IHZhX2FyZyhhcCwgc2l6ZV90KTsKKwkJCQlyZXQgPSB0ZXN0X2FuZF9hZGRf dG9rZW5fYnl0ZXN0cmluZyhjbWQsIGJzdHIsCisJCQkJCQkJCSAgICBsZW4pOworCQkJCWlmIChy ZXQgPCAwKQorCQkJCQlnb3RvIGVycjsKKwkJCX0KKwkJCW51bSA9IDE7CisJCQlicmVhazsKKwkJ Y2FzZSAnICc6CisJCWNhc2UgJ1x0JzoKKwkJCS8qIGlnbm9yZWQgKi8KKwkJCWJyZWFrOworCQlk ZWZhdWx0OgorCQkJcHJfd2FybigiVW5yZWNvZ25pemVkIHR5cGUuXG4iKTsKKwkJfQorCisJCWl0 Kys7CisJCXN1bSArPSByZXQ7CisJfQorCisJdmFfZW5kKGFwKTsKKworCXJldHVybiBzdW07CisK KyBlcnI6CisJcHJfZXJyKCJUb2tlbiBmYWlsZWQgdG8gYmUgYWRkZWQuXG4iKTsKKwlyZXR1cm4g cmV0OworfQorCitzdGF0aWMgdm9pZCBzZXRfY29tSUQoc3RydWN0IG9wYWxfY21kICpjbWQsIHUx NiBjb21JRCkKK3sKKwlzdHJ1Y3Qgb3BhbF9oZWFkZXIgKmhkciA9IChzdHJ1Y3Qgb3BhbF9oZWFk ZXIgKiljbWQtPmNtZDsKKworCWhkci0+Y3AuZXh0ZW5kZWRDb21JRFswXSA9IGNvbUlEID4+IDg7 CisJaGRyLT5jcC5leHRlbmRlZENvbUlEWzFdID0gY29tSUQ7CisJaGRyLT5jcC5leHRlbmRlZENv bUlEWzJdID0gMDsKKwloZHItPmNwLmV4dGVuZGVkQ29tSURbM10gPSAwOworfQorCitzdGF0aWMg aW50IGNtZF9maW5hbGl6ZShzdHJ1Y3Qgb3BhbF9jbWQgKmNtZCwgdTMyIGhzbiwgdTMyIHRzbikK K3sKKwlzdHJ1Y3Qgb3BhbF9oZWFkZXIgKmhkcjsKKwlpbnQgcmV0OworCisJcmV0ID0gdGVzdF9h bmRfYWRkX3Rva2VuX3ZhKGNtZCwgIjZjIiwKKwkJCQkgICAgT1BBTF9FTkRPRkRBVEEsIE9QQUxf U1RBUlRMSVNULAorCQkJCSAgICAwLCAwLCAwLCBPUEFMX0VORExJU1QpOworCisJaWYgKHJldCA8 IDApIHsKKwkJcHJfZXJyKCJFcnJvciBmaW5hbGl6aW5nIGNvbW1hbmQuXG4iKTsKKwkJcmV0dXJu IC1FRkFVTFQ7CisJfQorCisJaGRyID0gKHN0cnVjdCBvcGFsX2hlYWRlciAqKSBjbWQtPmNtZDsK KworCWhkci0+cGt0LlRTTiA9IGNwdV90b19iZTMyKHRzbik7CisJaGRyLT5wa3QuSFNOID0gY3B1 X3RvX2JlMzIoaHNuKTsKKworCWhkci0+c3VicGt0Lmxlbmd0aCA9IGNwdV90b19iZTMyKGNtZC0+ cG9zIC0gc2l6ZW9mKCpoZHIpKTsKKwl3aGlsZSAoY21kLT5wb3MgJSA0KSB7CisJCWlmIChjbWQt PnBvcyA+PSBJT19CVUZGRVJfTEVOR1RIKSB7CisJCQlwcl9lcnIoIkVycm9yOiBCdWZmZXIgb3Zl cnJ1blxuIik7CisJCQlyZXR1cm4gLUVSQU5HRTsKKwkJfQorCQljbWQtPmNtZFtjbWQtPnBvcysr XSA9IDA7CisJfQorCWhkci0+cGt0Lmxlbmd0aCA9IGNwdV90b19iZTMyKGNtZC0+cG9zIC0gc2l6 ZW9mKGhkci0+Y3ApIC0KKwkJCQkgICAgICBzaXplb2YoaGRyLT5wa3QpKTsKKwloZHItPmNwLmxl bmd0aCA9IGNwdV90b19iZTMyKGNtZC0+cG9zIC0gc2l6ZW9mKGhkci0+Y3ApKTsKKworCXJldHVy biAwOworfQorCitzdGF0aWMgZW51bSBPUEFMX1JFU1BPTlNFX1RPS0VOIHRva2VuX3R5cGUoY29u c3Qgc3RydWN0IHBhcnNlZF9yZXNwICpyZXNwLAorCQkJCQkgICBpbnQgbikKK3sKKwljb25zdCBz dHJ1Y3Qgb3BhbF9yZXNwX3RvayAqdG9rOworCisJaWYgKG4gPj0gcmVzcC0+bnVtKSB7CisJCXBy X2VycigiVG9rZW4gbnVtYmVyIGRvZXNuJ3QgZXhpc3Q6ICVkLCByZXNwOiAlZFxuIiwKKwkJICAg ICAgIG4sIHJlc3AtPm51bSk7CisJCXJldHVybiBPUEFMX0RUQV9UT0tFTklEX0lOVkFMSUQ7CisJ fQorCisJdG9rID0gJnJlc3AtPnRva3Nbbl07CisJaWYgKHRvay0+bGVuID09IDApIHsKKwkJcHJf ZXJyKCJUb2tlbiBsZW5ndGggbXVzdCBiZSBub24temVyb1xuIik7CisJCXJldHVybiBPUEFMX0RU QV9UT0tFTklEX0lOVkFMSUQ7CisJfQorCisJcmV0dXJuIHRvay0+dHlwZTsKK30KKworLyoKKyAq IFRoaXMgZnVuY3Rpb24gcmV0dXJucyAwIGluIGNhc2Ugb2YgaW52YWxpZCB0b2tlbi4gT25lIHNo b3VsZCBjYWxsCisgKiB0b2tlbl90eXBlKCkgZmlyc3QgdG8gZmluZCBvdXQgaWYgdGhlIHRva2Vu IGlzIHZhbGlkIG9yIG5vdC4KKyAqLworc3RhdGljIGVudW0gT1BBTF9UT0tFTiByZXNwb25zZV9n ZXRfdG9rZW4oY29uc3Qgc3RydWN0IHBhcnNlZF9yZXNwICpyZXNwLAorCQkJCQkgIGludCBuKQor eworCWNvbnN0IHN0cnVjdCBvcGFsX3Jlc3BfdG9rICp0b2s7CisKKwlpZiAobiA+PSByZXNwLT5u dW0pIHsKKwkJcHJfZXJyKCJUb2tlbiBudW1iZXIgZG9lc24ndCBleGlzdDogJWQsIHJlc3A6ICVk XG4iLAorCQkgICAgICAgbiwgcmVzcC0+bnVtKTsKKwkJcmV0dXJuIDA7CisJfQorCisJdG9rID0g JnJlc3AtPnRva3Nbbl07CisJaWYgKHRvay0+bGVuID09IDApIHsKKwkJcHJfZXJyKCJUb2tlbiBs ZW5ndGggbXVzdCBiZSBub24temVyb1xuIik7CisJCXJldHVybiAwOworCX0KKworCXJldHVybiB0 b2stPnBvc1swXTsKK30KKworc3RhdGljIHNpemVfdCByZXNwb25zZV9wYXJzZV90aW55KHN0cnVj dCBvcGFsX3Jlc3BfdG9rICp0b2ssCisJCQkJICBjb25zdCB1OCAqcG9zKQoreworCXRvay0+cG9z ID0gcG9zOworCXRvay0+bGVuID0gMTsKKwl0b2stPndpZHRoID0gT1BBTF9XSURUSF9USU5ZOwor CisJaWYgKHBvc1swXSAmIFRJTllfQVRPTV9TSUdORUQpIHsKKwkJdG9rLT50eXBlID0gT1BBTF9E VEFfVE9LRU5JRF9TSU5UOworCX0gZWxzZSB7CisJCXRvay0+dHlwZSA9IE9QQUxfRFRBX1RPS0VO SURfVUlOVDsKKwkJdG9rLT5zdG9yZWQudSA9IHBvc1swXSAmIDB4M2Y7CisJfQorCisJcmV0dXJu IHRvay0+bGVuOworfQorCitzdGF0aWMgc2l6ZV90IHJlc3BvbnNlX3BhcnNlX3Nob3J0KHN0cnVj dCBvcGFsX3Jlc3BfdG9rICp0b2ssCisJCQkJICAgY29uc3QgdTggKnBvcykKK3sKKwl0b2stPnBv cyA9IHBvczsKKwl0b2stPmxlbiA9IChwb3NbMF0gJiBTSE9SVF9BVE9NX0xFTl9NQVNLKSArIDE7 CisJdG9rLT53aWR0aCA9IE9QQUxfV0lEVEhfU0hPUlQ7CisKKwlpZiAocG9zWzBdICYgU0hPUlRf QVRPTV9CWVRFU1RSSU5HKSB7CisJCXRvay0+dHlwZSA9IE9QQUxfRFRBX1RPS0VOSURfQllURVNU UklORzsKKwl9IGVsc2UgaWYgKHBvc1swXSAmIFNIT1JUX0FUT01fU0lHTkVEKSB7CisJCXRvay0+ dHlwZSA9IE9QQUxfRFRBX1RPS0VOSURfU0lOVDsKKwl9IGVsc2UgeworCQl1NjQgdV9pbnRlZ2Vy ID0gMDsKKwkJaW50IGksIGIgPSAwOworCisJCXRvay0+dHlwZSA9IE9QQUxfRFRBX1RPS0VOSURf VUlOVDsKKwkJaWYgKHRvay0+bGVuID4gOSkgeworCQkJcHJfd2FybigidWludDY0IHdpdGggbW9y ZSB0aGFuIDggYnl0ZXNcbiIpOworCQkJcmV0dXJuIC1FSU5WQUw7CisJCX0KKwkJZm9yIChpID0g dG9rLT5sZW4gLSAxOyBpID4gMDsgaS0tKSB7CisJCQl1X2ludGVnZXIgfD0gKCh1NjQpcG9zW2ld IDw8ICg4ICogYikpOworCQkJYisrOworCQl9CisJCXRvay0+c3RvcmVkLnUgPSB1X2ludGVnZXI7 CisJfQorCisJcmV0dXJuIHRvay0+bGVuOworfQorCitzdGF0aWMgc2l6ZV90IHJlc3BvbnNlX3Bh cnNlX21lZGl1bShzdHJ1Y3Qgb3BhbF9yZXNwX3RvayAqdG9rLAorCQkJCSAgICBjb25zdCB1OCAq cG9zKQoreworCXRvay0+cG9zID0gcG9zOworCXRvay0+bGVuID0gKCgocG9zWzBdICYgTUVESVVN X0FUT01fTEVOX01BU0spIDw8IDgpIHwgcG9zWzFdKSArIDI7CisJdG9rLT53aWR0aCA9IE9QQUxf V0lEVEhfTUVESVVNOworCisJaWYgKHBvc1swXSAmIE1FRElVTV9BVE9NX0JZVEVTVFJJTkcpCisJ CXRvay0+dHlwZSA9IE9QQUxfRFRBX1RPS0VOSURfQllURVNUUklORzsKKwllbHNlIGlmIChwb3Nb MF0gJiBNRURJVU1fQVRPTV9TSUdORUQpCisJCXRvay0+dHlwZSA9IE9QQUxfRFRBX1RPS0VOSURf U0lOVDsKKwllbHNlCisJCXRvay0+dHlwZSA9IE9QQUxfRFRBX1RPS0VOSURfVUlOVDsKKworCXJl dHVybiB0b2stPmxlbjsKK30KKworI2RlZmluZSBMT05HX0FUT01fSUQgKEJJVCg3KSB8IEJJVCg2 KSB8IEJJVCg1KSkKKyNkZWZpbmUgTE9OR19BVE9NX0JZVEVTVFJJTkcgQklUKDEpCisjZGVmaW5l IExPTkdfQVRPTV9TSUdORUQgQklUKDApCitzdGF0aWMgc2l6ZV90IHJlc3BvbnNlX3BhcnNlX2xv bmcoc3RydWN0IG9wYWxfcmVzcF90b2sgKnRvaywKKwkJCQkgIGNvbnN0IHU4ICpwb3MpCit7CisJ dG9rLT5wb3MgPSBwb3M7CisJdG9rLT5sZW4gPSAoKHBvc1sxXSA8PCAxNikgfCAocG9zWzJdIDw8 IDgpIHwgcG9zWzNdKSArIDQ7CisJdG9rLT53aWR0aCA9IE9QQUxfV0lEVEhfTE9ORzsKKworCWlm IChwb3NbMF0gJiBMT05HX0FUT01fQllURVNUUklORykKKwkJdG9rLT50eXBlID0gT1BBTF9EVEFf VE9LRU5JRF9CWVRFU1RSSU5HOworCWVsc2UgaWYgKHBvc1swXSAmIExPTkdfQVRPTV9TSUdORUQp CisJCXRvay0+dHlwZSA9IE9QQUxfRFRBX1RPS0VOSURfU0lOVDsKKwllbHNlCisJCXRvay0+dHlw ZSA9IE9QQUxfRFRBX1RPS0VOSURfVUlOVDsKKworCXJldHVybiB0b2stPmxlbjsKK30KKworc3Rh dGljIHNpemVfdCByZXNwb25zZV9wYXJzZV90b2tlbihzdHJ1Y3Qgb3BhbF9yZXNwX3RvayAqdG9r LAorCQkJCSAgIGNvbnN0IHU4ICpwb3MpCit7CisJdG9rLT5wb3MgPSBwb3M7CisJdG9rLT5sZW4g PSAxOworCXRvay0+dHlwZSA9IE9QQUxfRFRBX1RPS0VOSURfVE9LRU47CisJdG9rLT53aWR0aCA9 IE9QQUxfV0lEVEhfVE9LRU47CisKKwlyZXR1cm4gdG9rLT5sZW47Cit9CisKK3N0YXRpYyBpbnQg cmVzcG9uc2VfcGFyc2UoY29uc3QgdTggKmJ1Ziwgc2l6ZV90IGxlbmd0aCwKKwkJCSAgc3RydWN0 IHBhcnNlZF9yZXNwICpyZXNwKQoreworCWNvbnN0IHN0cnVjdCBvcGFsX2hlYWRlciAqaGRyOwor CXN0cnVjdCBvcGFsX3Jlc3BfdG9rICppdGVyOworCWludCByZXQsIG51bV9lbnRyaWVzID0gMDsK Kwl1MzIgY3BvcyA9IDAsIHRvdGFsOworCXNpemVfdCB0b2tlbl9sZW5ndGg7CisJY29uc3QgdTgg KnBvczsKKworCWlmICghYnVmKQorCQlyZXR1cm4gLUVGQVVMVDsKKworCWlmICghcmVzcCkKKwkJ cmV0dXJuIC1FRkFVTFQ7CisKKwloZHIgPSAoc3RydWN0IG9wYWxfaGVhZGVyICopYnVmOworCXBv cyA9IGJ1ZjsKKwlwb3MgKz0gc2l6ZW9mKCpoZHIpOworCisJcHJfZGVidWcoIlJlc3BvbnNlIHNp emU6IGNwOiAlZCwgcGt0OiAlZCwgc3VicGt0OiAlZFxuIiwKKwkJIGJlMzJfdG9fY3B1KGhkci0+ Y3AubGVuZ3RoKSwKKwkJIGJlMzJfdG9fY3B1KGhkci0+cGt0Lmxlbmd0aCksCisJCSBiZTMyX3Rv X2NwdShoZHItPnN1YnBrdC5sZW5ndGgpKTsKKworCWlmICgoaGRyLT5jcC5sZW5ndGggPT0gMCkK KwkgICAgfHwgKGhkci0+cGt0Lmxlbmd0aCA9PSAwKQorCSAgICB8fCAoaGRyLT5zdWJwa3QubGVu Z3RoID09IDApKSB7CisJCXByX2VycigiQmFkIGhlYWRlciBsZW5ndGguIGNwOiAlZCwgcGt0OiAl ZCwgc3VicGt0OiAlZFxuIiwKKwkJICAgICAgIGJlMzJfdG9fY3B1KGhkci0+Y3AubGVuZ3RoKSwK KwkJICAgICAgIGJlMzJfdG9fY3B1KGhkci0+cGt0Lmxlbmd0aCksCisJCSAgICAgICBiZTMyX3Rv X2NwdShoZHItPnN1YnBrdC5sZW5ndGgpKTsKKwkJcHJpbnRfYnVmZmVyKHBvcywgc2l6ZW9mKCpo ZHIpKTsKKwkJcmV0ID0gLUVJTlZBTDsKKwkJZ290byBlcnI7CisJfQorCisJaWYgKHBvcyA+IGJ1 ZiArIGxlbmd0aCkgeworCQlyZXQgPSAtRUZBVUxUOworCQlnb3RvIGVycjsKKwl9CisKKwlpdGVy ID0gcmVzcC0+dG9rczsKKwl0b3RhbCA9IGJlMzJfdG9fY3B1KGhkci0+c3VicGt0Lmxlbmd0aCk7 CisJcHJpbnRfYnVmZmVyKHBvcywgdG90YWwpOworCXdoaWxlIChjcG9zIDwgdG90YWwpIHsKKwkJ aWYgKCEocG9zWzBdICYgMHg4MCkpIC8qIHRpbnkgYXRvbSAqLworCQkJdG9rZW5fbGVuZ3RoID0g cmVzcG9uc2VfcGFyc2VfdGlueShpdGVyLCBwb3MpOworCQllbHNlIGlmICghKHBvc1swXSAmIDB4 NDApKSAvKiBzaG9ydCBhdG9tICovCisJCQl0b2tlbl9sZW5ndGggPSByZXNwb25zZV9wYXJzZV9z aG9ydChpdGVyLCBwb3MpOworCQllbHNlIGlmICghKHBvc1swXSAmIDB4MjApKSAvKiBtZWRpdW0g YXRvbSAqLworCQkJdG9rZW5fbGVuZ3RoID0gcmVzcG9uc2VfcGFyc2VfbWVkaXVtKGl0ZXIsIHBv cyk7CisJCWVsc2UgaWYgKCEocG9zWzBdICYgMHgxMCkpIC8qIGxvbmcgYXRvbSAqLworCQkJdG9r ZW5fbGVuZ3RoID0gcmVzcG9uc2VfcGFyc2VfbG9uZyhpdGVyLCBwb3MpOworCQllbHNlIC8qIFRP S0VOICovCisJCQl0b2tlbl9sZW5ndGggPSByZXNwb25zZV9wYXJzZV90b2tlbihpdGVyLCBwb3Mp OworCisJCWlmICh0b2tlbl9sZW5ndGggPT0gLUVJTlZBTCkgeworCQkJcmV0ID0gLUVJTlZBTDsK KwkJCWdvdG8gZXJyOworCQl9CisKKwkJcG9zICs9IHRva2VuX2xlbmd0aDsKKwkJY3BvcyArPSB0 b2tlbl9sZW5ndGg7CisJCWl0ZXIrKzsKKwkJbnVtX2VudHJpZXMrKzsKKwl9CisKKwlpZiAobnVt X2VudHJpZXMgPT0gMCkgeworCQlwcl9lcnIoIkNvdWxkbid0IHBhcnNlIHJlc3BvbnNlLlxuIik7 CisJCXJldCA9IC1FSU5WQUw7CisJCWdvdG8gZXJyOworCX0KKwlyZXNwLT5udW0gPSBudW1fZW50 cmllczsKKworCXJldHVybiAwOworZXJyOgorCXJldHVybiByZXQ7Cit9CisKK3N0YXRpYyBzaXpl X3QgcmVzcG9uc2VfZ2V0X3N0cmluZyhjb25zdCBzdHJ1Y3QgcGFyc2VkX3Jlc3AgKnJlc3AsIGlu dCBuLAorCQkJCSAgY29uc3QgY2hhciAqKnN0b3JlKQoreworCSpzdG9yZSA9IE5VTEw7CisJaWYg KCFyZXNwKSB7CisJCXByX2VycigiUmVzcG9uc2UgaXMgTlVMTFxuIik7CisJCXJldHVybiAwOwor CX0KKworCWlmIChuID4gcmVzcC0+bnVtKSB7CisJCXByX2VycigiUmVzcG9uc2UgaGFzICVkIHRv a2Vucy4gQ2FuJ3QgYWNjZXNzICVkXG4iLAorCQkgICAgICAgcmVzcC0+bnVtLCBuKTsKKwkJcmV0 dXJuIDA7CisJfQorCisJaWYgKHJlc3AtPnRva3Nbbl0udHlwZSAhPSBPUEFMX0RUQV9UT0tFTklE X0JZVEVTVFJJTkcpIHsKKwkJcHJfZXJyKCJUb2tlbiBpcyBub3QgYSBieXRlIHN0cmluZyFcbiIp OworCQlyZXR1cm4gMDsKKwl9CisKKwkqc3RvcmUgPSByZXNwLT50b2tzW25dLnBvcyArIDE7CisJ cmV0dXJuIHJlc3AtPnRva3Nbbl0ubGVuIC0gMTsKK30KKworc3RhdGljIHU2NCByZXNwb25zZV9n ZXRfdTY0KGNvbnN0IHN0cnVjdCBwYXJzZWRfcmVzcCAqcmVzcCwgaW50IG4pCit7CisJaWYgKCFy ZXNwKSB7CisJCXByX2VycigiUmVzcG9uc2UgaXMgTlVMTFxuIik7CisJCXJldHVybiAwOworCX0K KworCWlmIChuID4gcmVzcC0+bnVtKSB7CisJCXByX2VycigiUmVzcG9uc2UgaGFzICVkIHRva2Vu cy4gQ2FuJ3QgYWNjZXNzICVkXG4iLAorCQkgICAgICAgcmVzcC0+bnVtLCBuKTsKKwkJcmV0dXJu IDA7CisJfQorCisJaWYgKHJlc3AtPnRva3Nbbl0udHlwZSAhPSBPUEFMX0RUQV9UT0tFTklEX1VJ TlQpIHsKKwkJcHJfZXJyKCJUb2tlbiBpcyBub3QgdW5zaWduZWQgaXQ6ICVkXG4iLAorCQkgICAg ICAgcmVzcC0+dG9rc1tuXS50eXBlKTsKKwkJcmV0dXJuIDA7CisJfQorCisJaWYgKCEoKHJlc3At PnRva3Nbbl0ud2lkdGggPT0gT1BBTF9XSURUSF9USU5ZKSB8fAorCSAgICAgIChyZXNwLT50b2tz W25dLndpZHRoID09IE9QQUxfV0lEVEhfU0hPUlQpKSkgeworCQlwcl9lcnIoIkF0b20gaXMgbm90 IHNob3J0IG9yIHRpbnk6ICVkXG4iLAorCQkgICAgICAgcmVzcC0+dG9rc1tuXS53aWR0aCk7CisJ CXJldHVybiAwOworCX0KKworCXJldHVybiByZXNwLT50b2tzW25dLnN0b3JlZC51OworfQorCitz dGF0aWMgdTggcmVzcG9uc2Vfc3RhdHVzKGNvbnN0IHN0cnVjdCBwYXJzZWRfcmVzcCAqcmVzcCkK K3sKKwlpZiAoKHRva2VuX3R5cGUocmVzcCwgMCkgPT0gT1BBTF9EVEFfVE9LRU5JRF9UT0tFTikK KwkgICAgJiYgKHJlc3BvbnNlX2dldF90b2tlbihyZXNwLCAwKSA9PSBPUEFMX0VORE9GU0VTU0lP TikpIHsKKwkJcmV0dXJuIDA7CisJfQorCisJaWYgKHJlc3AtPm51bSA8IDUpCisJCXJldHVybiBE VEFFUlJPUl9OT19NRVRIT0RfU1RBVFVTOworCisJaWYgKCh0b2tlbl90eXBlKHJlc3AsIHJlc3At Pm51bSAtIDEpICE9IE9QQUxfRFRBX1RPS0VOSURfVE9LRU4pIHx8CisJICAgICh0b2tlbl90eXBl KHJlc3AsIHJlc3AtPm51bSAtIDUpICE9IE9QQUxfRFRBX1RPS0VOSURfVE9LRU4pIHx8CisJICAg IChyZXNwb25zZV9nZXRfdG9rZW4ocmVzcCwgcmVzcC0+bnVtIC0gMSkgIT0gT1BBTF9FTkRMSVNU KSB8fAorCSAgICAocmVzcG9uc2VfZ2V0X3Rva2VuKHJlc3AsIHJlc3AtPm51bSAtIDUpICE9IE9Q QUxfU1RBUlRMSVNUKSkKKwkJcmV0dXJuIERUQUVSUk9SX05PX01FVEhPRF9TVEFUVVM7CisKKwly ZXR1cm4gcmVzcG9uc2VfZ2V0X3U2NChyZXNwLCByZXNwLT5udW0gLSA0KTsKK30KKworLyogUGFy c2VzIGFuZCBjaGVja3MgZm9yIGVycm9ycyAqLworc3RhdGljIGludCBwYXJzZV9hbmRfY2hlY2tf c3RhdHVzKHN0cnVjdCBvcGFsX2RldiAqZGV2KQoreworCXN0cnVjdCBvcGFsX2NtZCAqY21kOwor CWludCBlcnJvcjsKKworCWNtZCA9ICZkZXYtPmNtZDsKKwlwcmludF9idWZmZXIoY21kLT5jbWQs IGNtZC0+cG9zKTsKKworCWVycm9yID0gcmVzcG9uc2VfcGFyc2UoY21kLT5yZXNwLCBJT19CVUZG RVJfTEVOR1RILCAmZGV2LT5wYXJzZWQpOworCWlmIChlcnJvcikgeworCQlwcl9lcnIoIiVzOiBD b3VsZG4ndCBwYXJzZSByZXNwb25zZS5cbiIsIGRldi0+ZGlza19uYW1lKTsKKwkJZ290byBlcnJf cmV0dXJuOworCX0KKworCWVycm9yID0gcmVzcG9uc2Vfc3RhdHVzKCZkZXYtPnBhcnNlZCk7CisJ aWYgKGVycm9yKQorCQlwcl9lcnIoIiVzOiBSZXNwb25zZSBTdGF0dXM6ICVkXG4iLCBkZXYtPmRp c2tfbmFtZSwKKwkJICAgICAgIGVycm9yKTsKKworIGVycl9yZXR1cm46CisJcmV0dXJuIGVycm9y OworfQorCitzdGF0aWMgdm9pZCBjbGVhcl9vcGFsX2NtZChzdHJ1Y3Qgb3BhbF9jbWQgKmNtZCkK K3sKKwljbWQtPnBvcyA9IHNpemVvZihzdHJ1Y3Qgb3BhbF9oZWFkZXIpOworCW1lbXNldChjbWQt PmNtZCwgMCwgSU9fQlVGRkVSX0xFTkdUSCk7CisJY21kLT5jYiA9IE5VTEw7CisJY21kLT5jYl9k YXRhID0gTlVMTDsKK30KKworc3RhdGljIGludCBzdGFydF9vcGFsX3Nlc3Npb25fY29udCh2b2lk ICpkYXRhKQoreworCXN0cnVjdCBvcGFsX2RldiAqZGV2ID0gZGF0YTsKKwl1MzIgSFNOLCBUU047 CisJaW50IGVycm9yID0gMDsKKworCWVycm9yID0gcGFyc2VfYW5kX2NoZWNrX3N0YXR1cyhkZXYp OworCWlmIChlcnJvcikKKwkJZ290byBlcnJfcmV0dXJuOworCisJSFNOID0gcmVzcG9uc2VfZ2V0 X3U2NCgmZGV2LT5wYXJzZWQsIDQpOworCVRTTiA9IHJlc3BvbnNlX2dldF91NjQoJmRldi0+cGFy c2VkLCA1KTsKKworCWlmIChIU04gPT0gMCAmJiBUU04gPT0gMCkgeworCQlwcl9lcnIoIiVzOiBD b3VsZG4ndCBhdXRoZW50aWNhdGUgc2Vzc2lvblxuIiwgZGV2LT5kaXNrX25hbWUpOworCQllcnJv ciA9IC1FUEVSTTsKKwkJZ290byBlcnJfcmV0dXJuOworCX0KKworCWRldi0+SFNOID0gSFNOOwor CWRldi0+VFNOID0gVFNOOworCitlcnJfcmV0dXJuOgorCXJldHVybiBlcnJvcjsKK30KKworc3Ry dWN0IGtleSAqcmVxdWVzdF91c2VyX2tleShjb25zdCBjaGFyICptYXN0ZXJfZGVzYywgY29uc3Qg dTggKiptYXN0ZXJfa2V5LAorCQkJICAgICBzaXplX3QgKm1hc3Rlcl9rZXlsZW4pCit7CisJY29u c3Qgc3RydWN0IHVzZXJfa2V5X3BheWxvYWQgKnVwYXlsb2FkOworCXN0cnVjdCBrZXkgKnVrZXk7 CisKKwl1a2V5ID0gcmVxdWVzdF9rZXkoJmtleV90eXBlX3VzZXIsIG1hc3Rlcl9kZXNjLCBOVUxM KTsKKwlpZiAoSVNfRVJSKHVrZXkpKQorCQlnb3RvIGVycm9yOworCisJZG93bl9yZWFkKCZ1a2V5 LT5zZW0pOworCXVwYXlsb2FkID0gdXNlcl9rZXlfcGF5bG9hZCh1a2V5KTsKKwkqbWFzdGVyX2tl eSA9IHVwYXlsb2FkLT5kYXRhOworCSptYXN0ZXJfa2V5bGVuID0gdXBheWxvYWQtPmRhdGFsZW47 CitlcnJvcjoKKwlyZXR1cm4gdWtleTsKK30KKworc3RhdGljIGludCBnZXRfb3BhbF9rZXkoc3Ry dWN0IG9wYWxfZGV2ICpkZXYpCit7CisJc3RydWN0IGtleSAqdWtleSA9IE5VTEw7CisJY29uc3Qg dTggKnRtcGtleSA9IE5VTEw7CisJc2l6ZV90IHRtcGxlbjsKKwlpbnQgcmV0ID0gMDsKKworCWlm IChkZXYtPmtleV90eXBlID09IE9QQUxfS0VZX1BMQUlOKSB7CisJCXRtcGtleSA9IGRldi0+a2V5 X25hbWU7CisJCXRtcGxlbiA9IGRldi0+a2V5X25hbWVfbGVuOworCX0gZWxzZSBpZiAoZGV2LT5r ZXlfdHlwZSA9PSBPUEFMX0tFWV9LRVlSSU5HKSB7CisJCXVrZXkgPSByZXF1ZXN0X3VzZXJfa2V5 KGRldi0+a2V5X25hbWUsICZ0bXBrZXksICZ0bXBsZW4pOworCQlpZiAoSVNfRVJSKHVrZXkpKSB7 CisJCQlwcl9lcnIoIiVzOiBDYW4ndCByZXRyaWV2ZSBrZXk6ICVsZFxuIiwgZGV2LT5kaXNrX25h bWUsCisJCQkgICAgICAgUFRSX0VSUih1a2V5KSk7CisJCQlyZXR1cm4gUFRSX0VSUih1a2V5KTsK KwkJfQorCX0gZWxzZSB7CisJCXByX2VycigiUmVxdWVzdGVkIGludmFsaWQga2V5IHR5cGU6ICVk XG4iLCBkZXYtPmtleV90eXBlKTsKKwkJcmV0dXJuIC1FSU5WQUw7CisJfQorCisJaWYgKHRtcGxl biA+IE9QQUxfS0VZX01BWCkgeworCQlwcl9lcnIoIlJlcXVlc3RlZCBrZXkgd2l0aCBpbnZhbGlk IHNpemU6ICV6ZFxuIiwgdG1wbGVuKTsKKwkJcmV0ID0gLUVJTlZBTDsKKwkJZ290byBlcnJfZXhp dDsKKwl9CisKKwlkZXYtPmtleV9sZW4gPSB0bXBsZW47CisJaWYgKCFtZW1jcHkoZGV2LT5rZXks IHRtcGtleSwgdG1wbGVuKSkgeworCQlwcl9lcnIoIkVycm9yIHdoZW4gY29weWluZyBrZXkiKTsK KwkJcmV0ID0gLUVGQVVMVDsKKwkJZ290byBlcnJfZXhpdDsKKwl9CisKK2Vycl9leGl0OgorCWtl eV9wdXQodWtleSk7CisKKwlyZXR1cm4gMDsKK30KKworc3RhdGljIHZvaWQgY2xlYW5fb3BhbF9r ZXkoc3RydWN0IG9wYWxfZGV2ICpkZXYpCit7CisJbWVtc2V0KGRldi0+a2V5LCAwLCBPUEFMX0tF WV9NQVgpOworCWRldi0+a2V5X2xlbiA9IDA7Cit9CisKK3N0YXRpYyBpbmxpbmUgdm9pZCBjbGVh bl9mdW5jdGlvbl9kYXRhKHN0cnVjdCBvcGFsX2RldiAqZGV2KQoreworCWRldi0+ZnVuY19kYXRh ID0gTlVMTDsKKwlkZXYtPm51bV9mdW5jX2RhdGEgPSAwOworfQorCisvKiBUaGlzIGlzIGEgZ2Vu ZXJpYyBjb250aW51YXRpb24uCisgKiBXZSB1c2UgdGhpcyB3aGVuIHdlIGRvbid0IGNhcmUgYWJv dXQgdGhlIHJlc3BvbnNlIGRhdGEKKyAqIGFuZCBzaW1wbHkgd2FudCB0byBjaGVjayB0aGUgc3Rh dHVzIGFuZCBjb250aW51ZS4KKyAqLworc3RhdGljIGludCBnZW5lcmljX2NvbnQodm9pZCAqZGF0 YSkKK3sKKwlzdHJ1Y3Qgb3BhbF9kZXYgKmRldiA9IGRhdGE7CisKKwlyZXR1cm4gcGFyc2VfYW5k X2NoZWNrX3N0YXR1cyhkZXYpOworfQorCitzdGF0aWMgaW50IGVuZF9zZXNzaW9uX2NvbnQodm9p ZCAqZGF0YSkKK3sKKwlzdHJ1Y3Qgb3BhbF9kZXYgKmRldiA9IGRhdGE7CisKKwlkZXYtPkhTTiA9 IDA7CisJZGV2LT5UU04gPSAwOworCXJldHVybiBnZW5lcmljX2NvbnQoZGF0YSk7Cit9CisKK3N0 YXRpYyBpbnQgZmluYWxpemVfYW5kX3NlbmQoc3RydWN0IG9wYWxfZGV2ICpkZXYsIHN0cnVjdCBv cGFsX2NtZCAqY21kLAorCQkJICAgICBjb250X2ZuIGNvbnQpCit7CisJaW50IHJldDsKKworCXJl dCA9IGNtZF9maW5hbGl6ZShjbWQsIGRldi0+SFNOLCBkZXYtPlRTTik7CisJaWYgKHJldCkgewor CQlwcl9lcnIoIiVzOiBFcnJvciBmaW5hbGl6aW5nIGNvbW1hbmQgYnVmZmVyOiAlZFxuIiwKKwkJ ICAgICAgIGRldi0+ZGlza19uYW1lLCByZXQpOworCQlyZXR1cm4gcmV0OworCX0KKworCXByaW50 X2J1ZmZlcihjbWQtPmNtZCwgY21kLT5wb3MpOworCisJcmV0dXJuIG9wYWxfc2VuZF9yZWN2KGRl diwgY29udCk7Cit9CisKK3N0YXRpYyBpbnQgZ2VuX2tleShzdHJ1Y3Qgb3BhbF9kZXYgKmRldikK K3sKKwljb25zdCB1OCAqbWV0aG9kOworCXU4IHVpZFtPUEFMX1VJRF9MRU5HVEhdOworCXN0cnVj dCBvcGFsX2NtZCAqY21kOworCWludCByZXQ7CisKKwljbWQgPSAmZGV2LT5jbWQ7CisJY2xlYXJf b3BhbF9jbWQoY21kKTsKKwlzZXRfY29tSUQoY21kLCBkZXYtPmNvbUlEKTsKKworCW1lbWNweSh1 aWQsIGRldi0+cHJldl9kYXRhLCBtaW4oc2l6ZW9mKHVpZCksIGRldi0+cHJldl9kX2xlbikpOwor CW1ldGhvZCA9IE9QQUxNRVRIT0RbT1BBTF9HRU5LRVldOworCWtmcmVlKGRldi0+cHJldl9kYXRh KTsKKwlkZXYtPnByZXZfZGF0YSA9IE5VTEw7CisKKwlyZXQgPSB0ZXN0X2FuZF9hZGRfdG9rZW5f dmEoY21kLCAiYzJzIDJjIiwKKwkJCQkgICAgT1BBTF9DQUxMLAorCQkJCSAgICB1aWQsIE9QQUxf VUlEX0xFTkdUSCwKKwkJCQkgICAgbWV0aG9kLCBPUEFMX01FVEhPRF9MRU5HVEgsCisKKwkJCQkg ICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAgIE9QQUxfRU5ETElTVCk7CisJaWYgKHJldCA8IDAp IHsKKwkJcHJfZXJyKCIlczogRXJyb3IgYnVpbGRpbmcgZ2VuIGtleSBjb21tYW5kXG4iLAorCQkg ICAgICAgZGV2LT5kaXNrX25hbWUpOworCQlyZXR1cm4gcmV0OworCX0KKworCXJldHVybiBmaW5h bGl6ZV9hbmRfc2VuZChkZXYsIGNtZCwgZ2VuZXJpY19jb250KTsKK30KKworc3RhdGljIGludCBn ZXRfYWN0aXZlX2tleV9jb250KHZvaWQgKmRhdGEpCit7CisJc3RydWN0IG9wYWxfZGV2ICpkZXYg PSBkYXRhOworCWNvbnN0IGNoYXIgKmFjdGl2ZWtleTsKKwlzaXplX3Qga2V5bGVuOworCWludCBl cnJvciA9IDA7CisKKwllcnJvciA9IHBhcnNlX2FuZF9jaGVja19zdGF0dXMoZGV2KTsKKwlpZiAo ZXJyb3IpCisJCWdvdG8gZXJyX3JldHVybjsKKwlrZXlsZW4gPSByZXNwb25zZV9nZXRfc3RyaW5n KCZkZXYtPnBhcnNlZCwgNCwgJmFjdGl2ZWtleSk7CisJaWYgKCFhY3RpdmVrZXkpIHsKKwkJcHJf ZXJyKCIlczogQ291bGRuJ3QgZXh0cmFjdCB0aGUgQWN0aXZla2V5IGZyb20gdGhlIHJlc3BvbnNl XG4iLAorCQkgICAgICAgX19mdW5jX18pOworCQllcnJvciA9IDB4MEE7CisJCWdvdG8gZXJyX3Jl dHVybjsKKwl9CisJZGV2LT5wcmV2X2RhdGEgPSBrbWVtZHVwKGFjdGl2ZWtleSwga2V5bGVuLCBH RlBfS0VSTkVMKTsKKworCWlmICghZGV2LT5wcmV2X2RhdGEpIHsKKwkJZXJyb3IgPSAtRU5PTUVN OworCQlnb3RvIGVycl9yZXR1cm47CisJfQorCisJZGV2LT5wcmV2X2RfbGVuID0ga2V5bGVuOwor CisgZXJyX3JldHVybjoKKwlyZXR1cm4gZXJyb3I7Cit9CisKK3N0YXRpYyBpbnQgZ2V0X2FjdGl2 ZV9rZXkoc3RydWN0IG9wYWxfZGV2ICpkZXYpCit7CisJY29uc3QgdTggKm1ldGhvZDsKKwl1OCB1 aWRbT1BBTF9VSURfTEVOR1RIXTsKKwlzdHJ1Y3Qgb3BhbF9jbWQgKmNtZDsKKwlpbnQgcmV0Owor CisJY21kID0gJmRldi0+Y21kOworCWNsZWFyX29wYWxfY21kKGNtZCk7CisJc2V0X2NvbUlEKGNt ZCwgZGV2LT5jb21JRCk7CisKKwltZXRob2QgPSBPUEFMTUVUSE9EW09QQUxfR0VUXTsKKworCXJl dCA9IGJ1aWxkX2xvY2tpbmdfcmFuZ2UodWlkLCBzaXplb2YodWlkKSwgZGV2LT5scik7CisJaWYg KHJldCA8IDApIHsKKwkJcHJfZXJyKCIlczogQ2FuJ3QgYnVpbGQgbG9ja2luZyByYW5nZVxuIiwg ZGV2LT5kaXNrX25hbWUpOworCQlyZXR1cm4gLUVJTlZBTDsKKwl9CisKKwlyZXQgPSB0ZXN0X2Fu ZF9hZGRfdG9rZW5fdmEoY21kLCAiYzJzIDZjIDRjIDJjIiwKKwkJCQkgICAgT1BBTF9DQUxMLAor CQkJCSAgICB1aWQsIE9QQUxfVUlEX0xFTkdUSCwKKwkJCQkgICAgbWV0aG9kLCBPUEFMX01FVEhP RF9MRU5HVEgsCisKKwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAgIE9QQUxfU1RBUlRM SVNULAorCQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9USU5ZX1VJTlRfMDMs IC8qIHN0YXJ0Q2xvdW1uICovCisJCQkJICAgIE9QQUxfVElOWV9VSU5UXzEwLCAvKiBBY3RpdmVL ZXkgKi8KKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCisJCQkJICAgIE9QQUxfU1RBUlROQU1FLAor CQkJCSAgICBPUEFMX1RJTllfVUlOVF8wNCwgLyogZW5kQ29sdW1uICovCisJCQkJICAgIE9QQUxf VElOWV9VSU5UXzEwLCAvKiBBY3RpdmVLZXkgKi8KKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCisJ CQkJICAgIE9QQUxfRU5ETElTVCwKKwkJCQkgICAgT1BBTF9FTkRMSVNUKTsKKwlpZiAocmV0IDwg MCkgeworCQlwcl9lcnIoIiVzOiBFcnJvciBidWlsZGluZyBnZXQgYWN0aXZlIGtleSBjb21tYW5k XG4iLAorCQkgICAgICAgZGV2LT5kaXNrX25hbWUpOworCQlyZXR1cm4gcmV0OworCX0KKworCXJl dHVybiBmaW5hbGl6ZV9hbmRfc2VuZChkZXYsIGNtZCwgZ2V0X2FjdGl2ZV9rZXlfY29udCk7Cit9 CisKK3N0YXRpYyBpbmxpbmUgaW50IGVuYWJsZV9nbG9iYWxfbHIoc3RydWN0IG9wYWxfY21kICpj bWQsIHU4ICp1aWQsCisJCQkJICAgc3RydWN0IG9wYWxfdXNlcl9scl9zZXR1cCAqc2V0dXApCit7 CisJY29uc3QgdTggKm1ldGhvZDsKKworCW1ldGhvZCA9IE9QQUxNRVRIT0RbT1BBTF9TRVRdOwor CXJldHVybiB0ZXN0X2FuZF9hZGRfdG9rZW5fdmEoY21kLCAiYzJzIDRjIDJjdWMgMmN1YyA0YyA0 YyAzYyIsCisJCQkJICAgICBPUEFMX0NBTEwsCisJCQkJICAgICB1aWQsIE9QQUxfVUlEX0xFTkdU SCwKKwkJCQkgICAgIG1ldGhvZCwgT1BBTF9NRVRIT0RfTEVOR1RILAorCisJCQkJICAgICBPUEFM X1NUQVJUTElTVCwKKwkJCQkgICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICAgT1BBTF9WQUxV RVMsCisJCQkJICAgICBPUEFMX1NUQVJUTElTVCwKKworCQkJCSAgICAgT1BBTF9TVEFSVE5BTUUs CisJCQkJICAgICBPUEFMX1RJTllfVUlOVF8wNSwgLyogUmVhZExvY2tFbmFibGVkICovCisJCQkJ ICAgICAhIXNldHVwLT5STEUsCisJCQkJICAgICBPUEFMX0VORE5BTUUsCisKKwkJCQkgICAgIE9Q QUxfU1RBUlROQU1FLAorCQkJCSAgICAgT1BBTF9USU5ZX1VJTlRfMDYsIC8qIFdyaXRlTG9ja0Vu YWJsZWQgKi8KKwkJCQkgICAgICEhc2V0dXAtPldMRSwKKwkJCQkgICAgIE9QQUxfRU5ETkFNRSwK KworCQkJCSAgICAgT1BBTF9TVEFSVE5BTUUsCisJCQkJICAgICBPUEFMX1JFQURMT0NLRUQsCisJ CQkJICAgICBPUEFMX0ZBTFNFLAorCQkJCSAgICAgT1BBTF9FTkROQU1FLAorCisJCQkJICAgICBP UEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgIE9QQUxfV1JJVEVMT0NLRUQsCisJCQkJICAgICBPUEFM X0ZBTFNFLAorCQkJCSAgICAgT1BBTF9FTkROQU1FLAorCisJCQkJICAgICBPUEFMX0VORExJU1Qs CisJCQkJICAgICBPUEFMX0VORE5BTUUsCisJCQkJICAgICBPUEFMX0VORExJU1QpOworfQorCitz dGF0aWMgaW50IHNldHVwX2xvY2tpbmdfcmFuZ2Uoc3RydWN0IG9wYWxfZGV2ICpkZXYpCit7CisJ Y29uc3QgdTggKm1ldGhvZDsKKwl1OCB1aWRbT1BBTF9VSURfTEVOR1RIXTsKKwlzdHJ1Y3Qgb3Bh bF9jbWQgKmNtZDsKKwlzdHJ1Y3Qgb3BhbF91c2VyX2xyX3NldHVwICpzZXR1cDsKKwlpbnQgcmV0 OworCisJY21kID0gJmRldi0+Y21kOworCWNsZWFyX29wYWxfY21kKGNtZCk7CisJc2V0X2NvbUlE KGNtZCwgZGV2LT5jb21JRCk7CisKKwltZXRob2QgPSBPUEFMTUVUSE9EW09QQUxfU0VUXTsKKwly ZXQgPSBidWlsZF9sb2NraW5nX3JhbmdlKHVpZCwgc2l6ZW9mKHVpZCksIGRldi0+bHIpOworCWlm IChyZXQgPCAwKSB7CisJCXByX2VycigiJXM6IENhbid0IGJ1aWxkIGxvY2tpbmcgcmFuZ2VcbiIs IGRldi0+ZGlza19uYW1lKTsKKwkJcmV0dXJuIC1FSU5WQUw7CisJfQorCXNldHVwID0gZGV2LT5m dW5jX2RhdGFbZGV2LT5zdGF0ZSAtIDFdOworCWlmIChkZXYtPmxyID09IDApCisJCXJldCA9IGVu YWJsZV9nbG9iYWxfbHIoY21kLCB1aWQsIHNldHVwKTsKKwllbHNlCisJCXJldCA9IHRlc3RfYW5k X2FkZF90b2tlbl92YShjbWQsICJjMnMgIDRjIDJjdWMgMmN1YyAyY3VjIDJjdSA0YyIsCisJCQkJ ICAgIE9QQUxfQ0FMTCwKKwkJCQkgICAgdWlkLCBPUEFMX1VJRF9MRU5HVEgsCisJCQkJICAgIG1l dGhvZCwgT1BBTF9NRVRIT0RfTEVOR1RILAorCisJCQkJICAgIE9QQUxfU1RBUlRMSVNULAorCQkJ CSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9WQUxVRVMsCisJCQkJICAgIE9QQUxf U1RBUlRMSVNULAorCisJCQkJICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1RJTllf VUlOVF8wMywgLyogUmFuZ2UgU3RhcnQgKi8KKwkJCQkgICAgc2V0dXAtPnJhbmdlX3N0YXJ0LAor CQkJCSAgICBPUEFMX0VORE5BTUUsCisKKwkJCQkgICAgT1BBTF9TVEFSVE5BTUUsCisJCQkJICAg IE9QQUxfVElOWV9VSU5UXzA0LCAvKiBSYW5nZSBMZW5ndGggKi8KKwkJCQkgICAgc2V0dXAtPnJh bmdlX2xlbmd0aCwKKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCisJCQkJICAgIE9QQUxfU1RBUlRO QU1FLAorCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wNSwgLyogUmVhZExvY2tFbmFibGVkICovCisJ CQkJICAgICEhc2V0dXAtPlJMRSwKKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCisJCQkJICAgIE9Q QUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wNiwgLyogV3JpdGVMb2NrRW5h YmxlZCAqLworCQkJCSAgICAhIXNldHVwLT5XTEUsCisKKwkJCQkgICAgT1BBTF9FTkROQU1FLAor CQkJCSAgICBPUEFMX0VORExJU1QsCisJCQkJICAgIE9QQUxfRU5ETkFNRSwKKwkJCQkgICAgT1BB TF9FTkRMSVNUKTsKKwlpZiAocmV0IDwgMCkgeworCQlwcl9lcnIoIiVzOiBFcnJvciBidWlsZGlu ZyBTZXR1cCBMb2NraW5nIHJhbmdlIGNvbW1hbmQuXG4iLAorCQkgICAgICAgZGV2LT5kaXNrX25h bWUpOworCQlyZXR1cm4gcmV0OworCisJfQorCisJcmV0dXJuIGZpbmFsaXplX2FuZF9zZW5kKGRl diwgY21kLCBnZW5lcmljX2NvbnQpOworfQorCitzdGF0aWMgaW50IHN0YXJ0X2FkbWluc3Bfb3Bh bF9zZXNzaW9uKHN0cnVjdCBvcGFsX2RldiAqZGV2LAorCQkJCSAgICAgIGVudW0gT1BBTF9VSUQg YXV0aCwKKwkJCQkgICAgICBjb25zdCBjaGFyICprZXksCisJCQkJICAgICAgdTgga2V5X2xlbikK K3sKKwljb25zdCB1OCAqbWV0aG9kLCAqc211aWQsICphZG1pbl9zcCwgKmhzYTsKKwlzdHJ1Y3Qg b3BhbF9jbWQgKmNtZDsKKwl1MzIgSFNOOworCWludCByZXQ7CisKKwlpZiAoa2V5ID09IE5VTEwg JiYgYXV0aCAhPSBPUEFMX0FOWUJPRFlfVUlEKSB7CisJCXByX2VycigiJXM6IEF0dGVtcHRlZCB0 byBvcGVuIEFETUlOX1NQIFNlc3Npb24gd2l0aG91dCBhIEhvc3QiIFwKKwkJICAgICAgICJDaGFs bGVuZ2UsIGFuZCBub3QgYXMgdGhlIEFueWJvZHkgVUlEXG4iLCBfX2Z1bmNfXyk7CisJCXJldHVy biAxOworCX0KKworCWNtZCA9ICZkZXYtPmNtZDsKKwljbGVhcl9vcGFsX2NtZChjbWQpOworCisJ c2V0X2NvbUlEKGNtZCwgZGV2LT5jb21JRCk7CisJSFNOID0gR0VORVJJQ19IT1NUX1NFU1NJT05f TlVNOworCisJc211aWQgPSBPUEFMVUlEW09QQUxfU01VSURfVUlEXTsKKwltZXRob2QgPSBPUEFM TUVUSE9EW09QQUxfU1RBUlRTRVNTSU9OXTsKKwlhZG1pbl9zcCA9IE9QQUxVSURbT1BBTF9BRE1J TlNQX1VJRF07CisKKwlyZXQgPSB0ZXN0X2FuZF9hZGRfdG9rZW5fdmEoY21kLCAiYzJzIGN1c2Mi LAorCQkJCSAgICBPUEFMX0NBTEwsCisJCQkJICAgIHNtdWlkLCBPUEFMX1VJRF9MRU5HVEgsCisJ CQkJICAgIG1ldGhvZCwgT1BBTF9NRVRIT0RfTEVOR1RILAorCQkJCSAgICBPUEFMX1NUQVJUTElT VCwKKwkJCQkgICAgSFNOLAorCQkJCSAgICBhZG1pbl9zcCwgT1BBTF9VSURfTEVOR1RILAorCQkJ CSAgICBPUEFMX1RJTllfVUlOVF8wMSk7CisJaWYgKHJldCA8IDApIHsKKwkJcHJfZXJyKCIlczog RXJyb3IgYnVpbGRpbmcgc3RhcnQgYWRtaW5zcCBzZXNzaW9uIGNvbW1hbmQuXG4iLAorCQkgICAg ICAgZGV2LT5kaXNrX25hbWUpOworCQlyZXR1cm4gcmV0OworCX0KKworCXN3aXRjaCAoYXV0aCkg eworCWNhc2UgT1BBTF9BTllCT0RZX1VJRDoKKwkJLyogbm90aGluZyBsZWZ0IHRvIGRvIGZvciBh bnlib2R5LCBqdXN0IGVuZCBhbmQgZmluYWxpemUgKi8KKwkJcmV0ID0gdGVzdF9hbmRfYWRkX3Rv a2VuX3ZhKGNtZCwgImMiLAorCQkJCQkgICAgT1BBTF9FTkRMSVNUKTsKKwkJYnJlYWs7CisJY2Fz ZSBPUEFMX1NJRF9VSUQ6CisJCWhzYSA9IE9QQUxVSURbT1BBTF9TSURfVUlEXTsKKwkJcmV0ID0g dGVzdF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwgIjJjIHMgM2MgcyAyYyIsCisJCQkJCSAgICBPUEFM X1NUQVJUTkFNRSwKKwkJCQkJICAgIE9QQUxfVElOWV9VSU5UXzAwLCAvKiBIb3N0Q2hhbGxlbmdl ICovCisJCQkJCSAgICBrZXksIGtleV9sZW4sCisJCQkJCSAgICBPUEFMX0VORE5BTUUsCisJCQkJ CSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkJICAgIE9QQUxfVElOWV9VSU5UXzAzLCAvKiBIb3N0 U2lnbkF1dGggKi8KKwkJCQkJICAgIGhzYSwgT1BBTF9VSURfTEVOR1RILAorCQkJCQkgICAgT1BB TF9FTkROQU1FLAorCQkJCQkgICAgT1BBTF9FTkRMSVNUKTsKKwkJYnJlYWs7CisJZGVmYXVsdDoK KwkJcHJfZXJyKCJDYW5ub3Qgc3RhcnQgQWRtaW4gU1Agc2Vzc2lvbiB3aXRoIGF1dGggJWRcbiIs IGF1dGgpOworCQlyZXR1cm4gMTsKKwl9CisKKwlpZiAocmV0IDwgMCkgeworCQlwcl9lcnIoIiVz OiBFcnJvciBidWlsZGluZyBzdGFydCBhZG1pbnNwIHNlc3Npb24gY29tbWFuZC5cbiIsCisJCSAg ICAgICBkZXYtPmRpc2tfbmFtZSk7CisJCXJldHVybiByZXQ7CisJfQorCisJcmV0dXJuIGZpbmFs aXplX2FuZF9zZW5kKGRldiwgY21kLCBzdGFydF9vcGFsX3Nlc3Npb25fY29udCk7Cit9CisKK3N0 YXRpYyBpbnQgc3RhcnRfYW55Ym9keUFTUF9vcGFsX3Nlc3Npb24oc3RydWN0IG9wYWxfZGV2ICpk ZXYpCit7CisJcmV0dXJuIHN0YXJ0X2FkbWluc3Bfb3BhbF9zZXNzaW9uKGRldiwgT1BBTF9BTllC T0RZX1VJRCwgTlVMTCwgMCk7Cit9CisKK3N0YXRpYyBpbnQgc3RhcnRfU0lEQVNQX29wYWxfc2Vz c2lvbihzdHJ1Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwlpbnQgcmV0OworCWNvbnN0IHU4ICprZXkg PSBkZXYtPnByZXZfZGF0YTsKKworCWlmICgha2V5KQorCQlyZXQgPSBzdGFydF9hZG1pbnNwX29w YWxfc2Vzc2lvbihkZXYsIE9QQUxfU0lEX1VJRCwgZGV2LT5rZXksCisJCQkJCQkgZGV2LT5rZXlf bGVuKTsKKwllbHNlIHsKKwkJcmV0ID0gc3RhcnRfYWRtaW5zcF9vcGFsX3Nlc3Npb24oZGV2LCBP UEFMX1NJRF9VSUQsIGtleSwKKwkJCQkJCSBkZXYtPnByZXZfZF9sZW4pOworCQlrZnJlZShrZXkp OworCQlkZXYtPnByZXZfZGF0YSA9IE5VTEw7CisJfQorCXJldHVybiByZXQ7Cit9CisKK3N0YXRp YyBpbnQgc3RhcnRfbG9ja2luZ3NwX29wYWxfc2Vzc2lvbihzdHJ1Y3Qgb3BhbF9kZXYgKmRldiwK KwkJCQkJZW51bSBPUEFMX1VJRCBhdXRoLCBjb25zdCB1OCAqa2V5LAorCQkJCQl1OCBrZXlfbGVu KQoreworCisJY29uc3QgdTggKm1ldGhvZCwgKnNtdWlkLCAqbG9ja2luZ19zcCwgKmhzYTsKKwlz dHJ1Y3Qgb3BhbF9jbWQgKmNtZDsKKwlzaXplX3Qga2xlbiA9IGtleV9sZW47CisJdTMyIEhTTjsK KwlpbnQgcmV0OworCisJaWYgKGtleSA9PSBOVUxMKSB7CisJCXByX2VycigiQ2Fubm90IHN0YXJ0 IExvY2tpbmcgU1Agc2Vzc2lvbiB3aXRob3V0IGEga2V5XG4iKTsKKwkJcmV0dXJuIC1FSU5WQUw7 CisJfQorCisJY21kID0gJmRldi0+Y21kOworCWNsZWFyX29wYWxfY21kKGNtZCk7CisKKwlzZXRf Y29tSUQoY21kLCBkZXYtPmNvbUlEKTsKKwlIU04gPSBHRU5FUklDX0hPU1RfU0VTU0lPTl9OVU07 CisKKwlzbXVpZCA9IE9QQUxVSURbT1BBTF9TTVVJRF9VSURdOworCW1ldGhvZCA9IE9QQUxNRVRI T0RbT1BBTF9TVEFSVFNFU1NJT05dOworCWxvY2tpbmdfc3AgPSBPUEFMVUlEW09QQUxfTE9DS0lO R1NQX1VJRF07CisJaHNhID0gT1BBTFVJRFthdXRoXTsKKworCXJldCA9IHRlc3RfYW5kX2FkZF90 b2tlbl92YShjbWQsICJjMnMgY3VzYyAyY3NjIDJjc2MgYyIsCisJCQkJICAgIE9QQUxfQ0FMTCwK KwkJCQkgICAgc211aWQsIE9QQUxfVUlEX0xFTkdUSCwKKwkJCQkgICAgbWV0aG9kLCBPUEFMX01F VEhPRF9MRU5HVEgsCisKKwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAgIEhTTiwKKwkJ CQkgICAgbG9ja2luZ19zcCwgT1BBTF9VSURfTEVOR1RILAorCQkJCSAgICBPUEFMX1RJTllfVUlO VF8wMSwKKworCQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9USU5ZX1VJTlRf MDAsIC8qIEhvc3RDaGFsbGVuZ2UgKi8KKwkJCQkgICAga2V5LCBrbGVuLAorCQkJCSAgICBPUEFM X0VORE5BTUUsCisKKwkJCQkgICAgT1BBTF9TVEFSVE5BTUUsCisJCQkJICAgIE9QQUxfVElOWV9V SU5UXzAzLCAvKiBIb3N0IFNpZ24gQXV0aG9yaXR5ICovCisJCQkJICAgIGhzYSwgT1BBTF9VSURf TEVOR1RILAorCQkJCSAgICBPUEFMX0VORE5BTUUsCisKKwkJCQkgICAgT1BBTF9FTkRMSVNUKTsK KworCWlmIChyZXQgPCAwKSB7CisJCXByX2VycigiJXM6IEVycm9yIGJ1aWxkaW5nIHN0YXJ0IGFk bWluc3Agc2Vzc2lvbiBjb21tYW5kLlxuIiwKKwkJICAgICAgIGRldi0+ZGlza19uYW1lKTsKKwkJ cmV0dXJuIHJldDsKKwl9CisJcmV0dXJuIGZpbmFsaXplX2FuZF9zZW5kKGRldiwgY21kLCBzdGFy dF9vcGFsX3Nlc3Npb25fY29udCk7Cit9CisKK3N0YXRpYyBpbmxpbmUgaW50IHN0YXJ0X2FkbWlu MUxTUF9vcGFsX3Nlc3Npb24oc3RydWN0IG9wYWxfZGV2ICpkZXYpCit7CisJcmV0dXJuIHN0YXJ0 X2xvY2tpbmdzcF9vcGFsX3Nlc3Npb24oZGV2LCBPUEFMX0FETUlOMV9VSUQsCisJCQkJCSAgICBk ZXYtPmtleSwgZGV2LT5rZXlfbGVuKTsKK30KKworc3RhdGljIGludCBzdGFydF9hdXRoX29wYWxf c2Vzc2lvbihzdHJ1Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwljb25zdCB1OCAqbWV0aG9kLCAqc211 aWQsICpsb2NraW5nX3NwOworCXU4IGxrX3VsX3VzZXJbT1BBTF9VSURfTEVOR1RIXTsKKwlzdHJ1 Y3Qgb3BhbF9jbWQgKmNtZDsKKwl1MzIgSFNOOworCWludCByZXQ7CisJc3RydWN0IG9wYWxfdXNl cl9pbmZvICp1aW5mbzsKKworCWNtZCA9ICZkZXYtPmNtZDsKKwljbGVhcl9vcGFsX2NtZChjbWQp OworCisJc2V0X2NvbUlEKGNtZCwgZGV2LT5jb21JRCk7CisKKwlIU04gPSBHRU5FUklDX0hPU1Rf U0VTU0lPTl9OVU07CisKKwl1aW5mbyA9IGRldi0+ZnVuY19kYXRhW2Rldi0+c3RhdGUgLSAxXTsK KworCXNtdWlkID0gT1BBTFVJRFtPUEFMX1NNVUlEX1VJRF07CisJbWV0aG9kID0gT1BBTE1FVEhP RFtPUEFMX1NUQVJUU0VTU0lPTl07CisJbG9ja2luZ19zcCA9IE9QQUxVSURbT1BBTF9MT0NLSU5H U1BfVUlEXTsKKworCWlmICh1aW5mby0+U1VNKSB7CisJCXJldCA9IGJ1aWxkX2xvY2tpbmdfdXNl cihsa191bF91c2VyLCBzaXplb2YobGtfdWxfdXNlciksCisJCQkJCSBkZXYtPmxyKTsKKwkJaWYg KHJldCA8IDApIHsKKwkJCXByX2VycigiJXM6IENhbid0IGJ1aWxkIGxvY2tpbmcgdXNlclxuIiwK KwkJCSAgICAgICBkZXYtPmRpc2tfbmFtZSk7CisJCQlyZXR1cm4gcmV0OworCQl9CisJfSBlbHNl IGlmICh1aW5mby0+d2hvICE9IE9QQUxfQURNSU4xICYmICF1aW5mby0+U1VNKSB7CisJCXJldCA9 IGJ1aWxkX2xvY2tpbmdfdXNlcihsa191bF91c2VyLCBzaXplb2YobGtfdWxfdXNlciksCisJCQkJ CSB1aW5mby0+d2hvIC0gMSk7CisJCWlmIChyZXQgPCAwKSB7CisJCQlwcl9lcnIoIiVzOiBDYW4n dCBidWlsZCBsb2NraW5nIHVzZXJcbiIsCisJCQkgICAgICAgZGV2LT5kaXNrX25hbWUpOworCQkJ cmV0dXJuIHJldDsKKwkJfQorCX0gZWxzZQorCQltZW1jcHkobGtfdWxfdXNlciwgT1BBTFVJRFtP UEFMX0FETUlOMV9VSURdLCBPUEFMX1VJRF9MRU5HVEgpOworCisKKwlyZXQgPSB0ZXN0X2FuZF9h ZGRfdG9rZW5fdmEoY21kLCAiYzJzIGN1czNjczNjIHMgMmMiLAorCQkJCSAgICBPUEFMX0NBTEws CisJCQkJICAgIHNtdWlkLCBPUEFMX1VJRF9MRU5HVEgsCisJCQkJICAgIG1ldGhvZCwgT1BBTF9N RVRIT0RfTEVOR1RILAorCisJCQkJICAgIE9QQUxfU1RBUlRMSVNULAorCQkJCSAgICBIU04sCisJ CQkJICAgIGxvY2tpbmdfc3AsIE9QQUxfVUlEX0xFTkdUSCwKKwkJCQkgICAgT1BBTF9USU5ZX1VJ TlRfMDEsCisJCQkJICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1RJTllfVUlOVF8w MCwKKwkJCQkgICAgZGV2LT5rZXksIGRldi0+a2V5X2xlbiwKKwkJCQkgICAgT1BBTF9FTkROQU1F LAorCQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9USU5ZX1VJTlRfMDMsCisK KwkJCQkgICAgbGtfdWxfdXNlciwgT1BBTF9VSURfTEVOR1RILAorCisJCQkJICAgIE9QQUxfRU5E TkFNRSwKKwkJCQkgICAgT1BBTF9FTkRMSVNUKTsKKworCWlmIChyZXQgPCAwKSB7CisJCXByX2Vy cigiJXM6IEVycm9yIGJ1aWxkaW5nIFNUQVJUU0VTU0lPTiBjb21tYW5kLlxuIiwKKwkJICAgICAg IGRldi0+ZGlza19uYW1lKTsKKwkJcmV0dXJuIHJldDsKKwl9CisKKwlyZXR1cm4gZmluYWxpemVf YW5kX3NlbmQoZGV2LCBjbWQsIHN0YXJ0X29wYWxfc2Vzc2lvbl9jb250KTsKK30KKworc3RhdGlj IGludCByZXZlcnRfdHBlcihzdHJ1Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwljb25zdCB1OCAqbWV0 aG9kLCAqc211aWQ7CisJc3RydWN0IG9wYWxfY21kICpjbWQ7CisJaW50IHJldDsKKworCWNtZCA9 ICZkZXYtPmNtZDsKKwljbGVhcl9vcGFsX2NtZChjbWQpOworCisJc2V0X2NvbUlEKGNtZCwgZGV2 LT5jb21JRCk7CisKKwlzbXVpZCA9IE9QQUxVSURbT1BBTF9BRE1JTlNQX1VJRF07CisJbWV0aG9k ID0gT1BBTE1FVEhPRFtPUEFMX1JFVkVSVF07CisKKwlyZXQgPSB0ZXN0X2FuZF9hZGRfdG9rZW5f dmEoY21kLCAiYzJzIDJjIiwKKwkJCQkgICAgT1BBTF9DQUxMLAorCQkJCSAgICBzbXVpZCwgT1BB TF9VSURfTEVOR1RILAorCQkJCSAgICBtZXRob2QsIE9QQUxfTUVUSE9EX0xFTkdUSCwKKwkJCQkg ICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAgIE9QQUxfRU5ETElTVCk7CisJaWYgKHJldCA8IDAp IHsKKwkJcHJfZXJyKCIlczogRXJyb3IgYnVpbGRpbmcgUkVWRVJUIFRQRVIgY29tbWFuZC5cbiIs CisJCSAgICAgICBkZXYtPmRpc2tfbmFtZSk7CisJCXJldHVybiByZXQ7CisJfQorCisJcmV0dXJu IGZpbmFsaXplX2FuZF9zZW5kKGRldiwgY21kLCBnZW5lcmljX2NvbnQpOworfQorCitzdGF0aWMg aW50IGludGVybmFsX2FjdGl2YXRlX3VzZXIoc3RydWN0IG9wYWxfZGV2ICpkZXYpCit7CisJY29u c3QgdTggKm1ldGhvZDsKKwl1OCB1aWRbT1BBTF9VSURfTEVOR1RIXTsKKwlzdHJ1Y3Qgb3BhbF9j bWQgKmNtZDsKKwlpbnQgcmV0OworCXN0cnVjdCBvcGFsX2tleV9hbmRfdXNlciAqYWN0OworCisJ Y21kID0gJmRldi0+Y21kOworCWNsZWFyX29wYWxfY21kKGNtZCk7CisJc2V0X2NvbUlEKGNtZCwg ZGV2LT5jb21JRCk7CisKKwlhY3QgPSBkZXYtPmZ1bmNfZGF0YVtkZXYtPnN0YXRlIC0gMV07CisK KwltZW1jcHkodWlkLCBPUEFMVUlEW09QQUxfVVNFUjFfVUlEXSwgT1BBTF9VSURfTEVOR1RIKTsK Kwl1aWRbN10gPSBhY3QtPndoby53aG87CisKKwltZXRob2QgPSBPUEFMTUVUSE9EW09QQUxfU0VU XTsKKworCXJldCA9IHRlc3RfYW5kX2FkZF90b2tlbl92YShjbWQsICJjMnMgM2MgYyA0YyAzYyIs CisJCQkJICAgIE9QQUxfQ0FMTCwKKwkJCQkgICAgdWlkLCBPUEFMX1VJRF9MRU5HVEgsCisJCQkJ ICAgIG1ldGhvZCwgT1BBTF9NRVRIT0RfTEVOR1RILAorCisJCQkJICAgIE9QQUxfU1RBUlRMSVNU LAorCQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9USU5ZX1VJTlRfMDEsIC8q IFZhbHVlcyAqLworCisJCQkJICAgIE9QQUxfU1RBUlRMSVNULAorCisJCQkJICAgIE9QQUxfU1RB UlROQU1FLAorCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wNSwgLyogRW5hYmxlZCAqLworCQkJCSAg ICBPUEFMX1RJTllfVUlOVF8wMSwgLyogVHJ1ZSAqLworCQkJCSAgICBPUEFMX0VORE5BTUUsCisK KwkJCQkgICAgT1BBTF9FTkRMSVNULAorCQkJCSAgICBPUEFMX0VORE5BTUUsCisJCQkJICAgIE9Q QUxfRU5ETElTVCk7CisKKwlpZiAocmV0IDwgMCkgeworCQlwcl9lcnIoIiVzOiBFcnJvciBidWls ZGluZyBBY3RpdmF0ZSBVc2VyTiBjb21tYW5kLlxuIiwKKwkJICAgICAgIGRldi0+ZGlza19uYW1l KTsKKwkJcmV0dXJuIHJldDsKKwl9CisKKwlyZXR1cm4gZmluYWxpemVfYW5kX3NlbmQoZGV2LCBj bWQsIGdlbmVyaWNfY29udCk7Cit9CisKK3N0YXRpYyBpbnQgZXJhc2VfbG9ja2luZ19yYW5nZShz dHJ1Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwljb25zdCB1OCAqbWV0aG9kOworCXU4IHVpZFtPUEFM X1VJRF9MRU5HVEhdOworCXN0cnVjdCBvcGFsX2NtZCAqY21kOworCWludCByZXQ7CisKKwljbWQg PSAmZGV2LT5jbWQ7CisJY2xlYXJfb3BhbF9jbWQoY21kKTsKKwlzZXRfY29tSUQoY21kLCBkZXYt PmNvbUlEKTsKKworCW1ldGhvZCA9IE9QQUxNRVRIT0RbT1BBTF9FUkFTRV07CisKKwlpZiAoYnVp bGRfbG9ja2luZ19yYW5nZSh1aWQsIHNpemVvZih1aWQpLCBkZXYtPmxyKSA8IDApIHsKKwkJcHJf ZXJyKCIlczogQ2FuJ3QgYnVpbGQgbG9ja2luZyByYW5nZVxuIiwgZGV2LT5kaXNrX25hbWUpOwor CQlyZXR1cm4gLUVJTlZBTDsKKwl9CisKKwlyZXQgPSB0ZXN0X2FuZF9hZGRfdG9rZW5fdmEoY21k LCAiYzJzIDJjIiwKKwkJCQkgICAgT1BBTF9DQUxMLAorCQkJCSAgICB1aWQsIE9QQUxfVUlEX0xF TkdUSCwKKwkJCQkgICAgbWV0aG9kLCBPUEFMX01FVEhPRF9MRU5HVEgsCisKKwkJCQkgICAgT1BB TF9TVEFSVExJU1QsCisJCQkJICAgIE9QQUxfRU5ETElTVCk7CisKKwlpZiAocmV0IDwgMCkgewor CQlwcl9lcnIoIiVzOiBFcnJvciBidWlsZGluZyBFcmFzZSBMb2NraW5nIFJhbmdlIENtbWFuZC5c biIsCisJCSAgICAgICBkZXYtPmRpc2tfbmFtZSk7CisJCXJldHVybiByZXQ7CisJfQorCXJldHVy biBmaW5hbGl6ZV9hbmRfc2VuZChkZXYsIGNtZCwgZ2VuZXJpY19jb250KTsKK30KKworc3RhdGlj IGludCBzZXRfbWJyX2RvbmUoc3RydWN0IG9wYWxfZGV2ICpkZXYpCit7CisJY29uc3QgdTggKm1l dGhvZCwgKnVpZDsKKwlzdHJ1Y3Qgb3BhbF9jbWQgKmNtZDsKKwlpbnQgcmV0OworCXU4IG1icl9k b25lX3RmID0gKih1OCAqKWRldi0+ZnVuY19kYXRhW2Rldi0+c3RhdGUgLSAxXTsKKworCWNtZCA9 ICZkZXYtPmNtZDsKKwljbGVhcl9vcGFsX2NtZChjbWQpOworCXNldF9jb21JRChjbWQsIGRldi0+ Y29tSUQpOworCisJbWV0aG9kID0gT1BBTE1FVEhPRFtPUEFMX1NFVF07CisJdWlkID0gT1BBTFVJ RFtPUEFMX01CUkNPTlRST0xdOworCisJcmV0ID0gdGVzdF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwg ImMycyAzYyA2YyAyYyIsCisJCQkJICAgIE9QQUxfQ0FMTCwKKwkJCQkgICAgdWlkLCBPUEFMX1VJ RF9MRU5HVEgsCisJCQkJICAgIG1ldGhvZCwgT1BBTF9NRVRIT0RfTEVOR1RILAorCisJCQkJICAg IE9QQUxfU1RBUlRMSVNULAorCQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9W QUxVRVMsCisKKwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAgIE9QQUxfU1RBUlROQU1F LAorCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wMiwgLyogRG9uZSAqLworCQkJCSAgICBtYnJfZG9u ZV90ZiwgICAgICAgLyogRG9uZSBUIG9yIEYgKi8KKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCQkJ CSAgICBPUEFMX0VORExJU1QsCisKKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCQkJCSAgICBPUEFM X0VORExJU1QpOworCWlmIChyZXQgPCAwKSB7CisJCXByX2VycigiJXM6IEVycm9yIEJ1aWxkaW5n IHNldCBNQlIgRG9uZSBjb21tYW5kXG4iLAorCQkgICAgICAgZGV2LT5kaXNrX25hbWUpOworCQly ZXR1cm4gcmV0OworCX0KKworCXJldHVybiBmaW5hbGl6ZV9hbmRfc2VuZChkZXYsIGNtZCwgZ2Vu ZXJpY19jb250KTsKK30KKworc3RhdGljIGludCBzZXRfbWJyX2VuYWJsZV9kaXNhYmxlKHN0cnVj dCBvcGFsX2RldiAqZGV2KQoreworCWNvbnN0IHU4ICptZXRob2QsICp1aWQ7CisJc3RydWN0IG9w YWxfY21kICpjbWQ7CisJaW50IHJldDsKKwl1OCBtYnJfZW5fZGlzID0gKih1OCAqKWRldi0+ZnVu Y19kYXRhW2Rldi0+c3RhdGUgLSAxXTsKKworCWNtZCA9ICZkZXYtPmNtZDsKKwljbGVhcl9vcGFs X2NtZChjbWQpOworCXNldF9jb21JRChjbWQsIGRldi0+Y29tSUQpOworCisJbWV0aG9kID0gT1BB TE1FVEhPRFtPUEFMX1NFVF07CisJdWlkID0gT1BBTFVJRFtPUEFMX01CUkNPTlRST0xdOworCisJ cmV0ID0gdGVzdF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwgImMycyAzYyA2YyAyYyIsCisJCQkJICAg IE9QQUxfQ0FMTCwKKwkJCQkgICAgdWlkLCBPUEFMX1VJRF9MRU5HVEgsCisJCQkJICAgIG1ldGhv ZCwgT1BBTF9NRVRIT0RfTEVOR1RILAorCisJCQkJICAgIE9QQUxfU1RBUlRMSVNULAorCQkJCSAg ICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9WQUxVRVMsCisKKwkJCQkgICAgT1BBTF9T VEFSVExJU1QsCisJCQkJICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1RJTllfVUlO VF8wMSwgLyogRW5hYmxlICovCisJCQkJICAgIG1icl9lbl9kaXMsICAgICAgICAvKiBFbmFibGUg b3IgRGlzYWJsZSAqLworCQkJCSAgICBPUEFMX0VORE5BTUUsCisJCQkJICAgIE9QQUxfRU5ETElT VCwKKworCQkJCSAgICBPUEFMX0VORE5BTUUsCisJCQkJICAgIE9QQUxfRU5ETElTVCk7CisJaWYg KHJldCA8IDApIHsKKwkJcHJfZXJyKCIlczogRXJyb3IgQnVpbGRpbmcgc2V0IE1CUiBkb25lIGNv bW1hbmRcbiIsCisJCSAgICAgICBkZXYtPmRpc2tfbmFtZSk7CisJCXJldHVybiByZXQ7CisJfQor CisJcmV0dXJuIGZpbmFsaXplX2FuZF9zZW5kKGRldiwgY21kLCBnZW5lcmljX2NvbnQpOworfQor CitzdGF0aWMgaW50IHNldF9uZXdfcHcoc3RydWN0IG9wYWxfZGV2ICpkZXYpCit7CisJY29uc3Qg dTggKm1ldGhvZDsKKwl1OCBjcGluX3VpZFtPUEFMX1VJRF9MRU5HVEhdOworCXN0cnVjdCBvcGFs X2NtZCAqY21kOworCWludCByZXQ7CisJc3RydWN0IG9wYWxfbmV3X3B3ICpwdzsKKwlzaXplX3Qg a2V5X2xlbjsKKwl1OCAqa2V5OworCisJY21kID0gJmRldi0+Y21kOworCWNsZWFyX29wYWxfY21k KGNtZCk7CisJc2V0X2NvbUlEKGNtZCwgZGV2LT5jb21JRCk7CisKKwlwdyA9IGRldi0+ZnVuY19k YXRhW2Rldi0+c3RhdGUgLSAxXTsKKwlrZXkgPSBwdy0+bmV3X3Bpbi5rZXk7CisJa2V5X2xlbiA9 IHB3LT5uZXdfcGluLmtleV9sZW47CisJbWVtY3B5KGNwaW5fdWlkLCBPUEFMVUlEW09QQUxfQ19Q SU5fQURNSU4xXSwgT1BBTF9VSURfTEVOR1RIKTsKKworCWlmIChwdy0+dXNlcl9mb3JfcHcgIT0g T1BBTF9BRE1JTjEpIHsKKwkJY3Bpbl91aWRbNV0gPSAweDAzOworCQlpZiAocHctPndoby5TVU0p CisJCQljcGluX3VpZFs3XSA9IHB3LT5uZXdfcGluLmxyICsgMTsKKwkJZWxzZQorCQkJY3Bpbl91 aWRbN10gPSBwdy0+dXNlcl9mb3JfcHc7CisJfQorCisJbWV0aG9kID0gT1BBTE1FVEhPRFtPUEFM X1NFVF07CisKKwlyZXQgPSB0ZXN0X2FuZF9hZGRfdG9rZW5fdmEoY21kLCAiYzJzIDNjIDNjczJj IDJjIiwKKwkJCQkgICAgT1BBTF9DQUxMLAorCQkJCSAgICBjcGluX3VpZCwgT1BBTF9VSURfTEVO R1RILAorCQkJCSAgICBtZXRob2QsIE9QQUxfTUVUSE9EX0xFTkdUSCwKKworCQkJCSAgICBPUEFM X1NUQVJUTElTVCwKKwkJCQkgICAgT1BBTF9TVEFSVE5BTUUsCisJCQkJICAgIE9QQUxfVElOWV9V SU5UXzAxLCAvKiBWYWx1ZXMgKi8KKworCQkJCSAgICBPUEFMX1NUQVJUTElTVCwKKwkJCQkgICAg T1BBTF9TVEFSVE5BTUUsCisJCQkJICAgIE9QQUxfVElOWV9VSU5UXzAzLCAvKiBQSU4gKi8KKwkJ CQkgICAga2V5LCBrZXlfbGVuLAorCQkJCSAgICBPUEFMX0VORE5BTUUsCisJCQkJICAgIE9QQUxf RU5ETElTVCwKKworCQkJCSAgICBPUEFMX0VORE5BTUUsCisJCQkJICAgIE9QQUxfRU5ETElTVCk7 CisKKwlpZiAocmV0IDwgMCkgeworCQlwcl9lcnIoIiVzOiBFcnJvciBidWlsZGluZyBTRVQgQU1J TjEgUElOIGNvbW1hbmQuXG4iLAorCQkgICAgICAgZGV2LT5kaXNrX25hbWUpOworCQlyZXR1cm4g cmV0OworCX0KKworCXJldHVybiBmaW5hbGl6ZV9hbmRfc2VuZChkZXYsIGNtZCwgZ2VuZXJpY19j b250KTsKK30KKworc3RhdGljIGludCBzZXRfc2lkX2NwaW5fcGluKHN0cnVjdCBvcGFsX2RldiAq ZGV2KQoreworCWNvbnN0IHU4ICptZXRob2QsICpjcGluX3VpZDsKKwlzdHJ1Y3Qgb3BhbF9jbWQg KmNtZDsKKwlpbnQgcmV0OworCisJY21kID0gJmRldi0+Y21kOworCWNsZWFyX29wYWxfY21kKGNt ZCk7CisJc2V0X2NvbUlEKGNtZCwgZGV2LT5jb21JRCk7CisKKwljcGluX3VpZCA9IE9QQUxVSURb T1BBTF9DX1BJTl9TSURdOworCW1ldGhvZCA9IE9QQUxNRVRIT0RbT1BBTF9TRVRdOworCisJcmV0 ID0gdGVzdF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwgImMycyAyYyA0Y3MyYyAyYyIsCisJCQkJICAg IE9QQUxfQ0FMTCwKKwkJCQkgICAgY3Bpbl91aWQsIE9QQUxfVUlEX0xFTkdUSCwKKwkJCQkgICAg bWV0aG9kLCBPUEFMX01FVEhPRF9MRU5HVEgsCisKKwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisJ CQkJICAgIE9QQUxfU1RBUlROQU1FLAorCisJCQkJICAgIE9QQUxfVElOWV9VSU5UXzAxLCAvKiBW YWx1ZXMgKi8KKwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAgIE9QQUxfU1RBUlROQU1F LAorCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wMywgLyogUElOICovCisJCQkJICAgIGRldi0+a2V5 LCBkZXYtPmtleV9sZW4sCisJCQkJICAgIE9QQUxfRU5ETkFNRSwKKwkJCQkgICAgT1BBTF9FTkRM SVNULAorCisJCQkJICAgIE9QQUxfRU5ETkFNRSwKKwkJCQkgICAgT1BBTF9FTkRMSVNUKTsKKwor CWlmIChyZXQgPCAwKSB7CisJCXByX2VycigiJXM6IEVycm9yIGJ1aWxkaW5nIFNFVCBDUElOIFBJ TiBjb21tYW5kLlxuIiwKKwkJICAgICAgIGRldi0+ZGlza19uYW1lKTsKKwkJcmV0dXJuIHJldDsK Kwl9CisKKwlyZXR1cm4gZmluYWxpemVfYW5kX3NlbmQoZGV2LCBjbWQsIGdlbmVyaWNfY29udCk7 Cit9CisKK3N0YXRpYyBpbnQgcXVlcnlfbG9ja2luZ19yYW5nZV9jb250KHZvaWQgKmRhdGEpCit7 CisJc3RydWN0IG9wYWxfZGV2ICpkZXYgPSBkYXRhOworCWludCBlcnJvcjsKKworCWVycm9yID0g cGFyc2VfYW5kX2NoZWNrX3N0YXR1cyhkZXYpOworCWlmIChlcnJvcikKKwkJZ290byBlcnJfcmV0 dXJuOworCisJZGV2LT5zdGFydCA9IHJlc3BvbnNlX2dldF91NjQoJmRldi0+cGFyc2VkLCA0KTsK KwlkZXYtPmxlbmd0aCA9IHJlc3BvbnNlX2dldF91NjQoJmRldi0+cGFyc2VkLCA4KTsKKworZXJy X3JldHVybjoKKwlyZXR1cm4gZXJyb3I7Cit9CisKK3N0YXRpYyBpbnQgcXVlcnlfbG9ja2luZ19y YW5nZShzdHJ1Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwl1OCBscl9idWZmZXJbT1BBTF9VSURfTEVO R1RIXTsKKwlzdHJ1Y3Qgb3BhbF9jbWQgKmNtZDsKKwljb25zdCB1OCAqbWV0aG9kOworCWludCBy ZXQ7CisKKwljbWQgPSAmZGV2LT5jbWQ7CisJY2xlYXJfb3BhbF9jbWQoY21kKTsKKworCW1ldGhv ZCA9IE9QQUxNRVRIT0RbT1BBTF9HRVRdOworCisJaWYgKGJ1aWxkX2xvY2tpbmdfcmFuZ2UobHJf YnVmZmVyLCBzaXplb2YobHJfYnVmZmVyKSwgZGV2LT5scikgPCAwKSB7CisJCXByX2VycigiJXM6 IENhbid0IGJ1aWxkIGxvY2tpbmcgcmFuZ2VcbiIsIGRldi0+ZGlza19uYW1lKTsKKwkJcmV0dXJu IC1FSU5WQUw7CisJfQorCisJc2V0X2NvbUlEKGNtZCwgZGV2LT5jb21JRCk7CisKKwlyZXQgPSB0 ZXN0X2FuZF9hZGRfdG9rZW5fdmEoY21kLCAiYzJzIDEyYyIsCisJCQkJICAgIE9QQUxfQ0FMTCwK KwkJCQkgICAgbHJfYnVmZmVyLCBPUEFMX1VJRF9MRU5HVEgsCisJCQkJICAgIG1ldGhvZCwgT1BB TF9NRVRIT0RfTEVOR1RILAorCisJCQkJICAgIE9QQUxfU1RBUlRMSVNULAorCQkJCSAgICBPUEFM X1NUQVJUTElTVCwKKwkJCQkgICAgT1BBTF9TVEFSVE5BTUUsCisJCQkJICAgIE9QQUxfU1RBUlRD T0xVTU4sCisJCQkJICAgIE9QQUxfUkFOR0VTVEFSVCwKKwkJCQkgICAgT1BBTF9FTkROQU1FLAor CQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9FTkRDT0xVTU4sCisJCQkJICAg IE9QQUxfUkFOR0VMRU5HVEgsCisJCQkJICAgIE9QQUxfRU5ETkFNRSwKKwkJCQkgICAgT1BBTF9F TkRMSVNULAorCQkJCSAgICBPUEFMX0VORExJU1QpOworCisJaWYgKHJldCA8IDApIHsKKwkJcHJf ZXJyKCIlczogRXJyb3IgYnVpbGRpbmcgR0VUIExvY2tpbmcgUmFuZ2UgY29tbWFuZC5cbiIsCisJ CSAgICAgICBkZXYtPmRpc2tfbmFtZSk7CisJCXJldHVybiByZXQ7CisJfQorCisJcmV0dXJuIGZp bmFsaXplX2FuZF9zZW5kKGRldiwgY21kLCBxdWVyeV9sb2NraW5nX3JhbmdlX2NvbnQpOworfQor CitzdGF0aWMgaW50IGFkZF91c2VyX3RvX2xyKHN0cnVjdCBvcGFsX2RldiAqZGV2KQoreworCXU4 IGxyX2J1ZmZlcltPUEFMX1VJRF9MRU5HVEhdOworCXU4IHVzZXJfdWlkW09QQUxfVUlEX0xFTkdU SF07CisJc3RydWN0IG9wYWxfY21kICpjbWQ7CisJY29uc3QgdTggKm1ldGhvZDsKKwlzdHJ1Y3Qg b3BhbF9sb2NrX3VubG9jayAqbGt1bDsKKwlpbnQgcmV0OworCisJY21kID0gJmRldi0+Y21kOwor CWNsZWFyX29wYWxfY21kKGNtZCk7CisJc2V0X2NvbUlEKGNtZCwgZGV2LT5jb21JRCk7CisKKwlt ZXRob2QgPSBPUEFMTUVUSE9EW09QQUxfU0VUXTsKKworCWxrdWwgPSBkZXYtPmZ1bmNfZGF0YVtk ZXYtPnN0YXRlIC0gMV07CisKKwltZW1jcHkobHJfYnVmZmVyLCBPUEFMVUlEW09QQUxfTE9DS0lO R1JBTkdFX0FDRV9SRExPQ0tFRF0sCisJICAgICAgIE9QQUxfVUlEX0xFTkdUSCk7CisKKwlpZiAo bGt1bC0+bF9zdGF0ZSA9PSBPUEFMX1JXKQorCQltZW1jcHkobHJfYnVmZmVyLCBPUEFMVUlEW09Q QUxfTE9DS0lOR1JBTkdFX0FDRV9XUkxPQ0tFRF0sCisJCSAgICAgICBPUEFMX1VJRF9MRU5HVEgp OworCisJbHJfYnVmZmVyWzddID0gZGV2LT5scjsKKworCW1lbWNweSh1c2VyX3VpZCwgT1BBTFVJ RFtPUEFMX1VTRVIxX1VJRF0sIE9QQUxfVUlEX0xFTkdUSCk7CisJdXNlcl91aWRbN10gPSBsa3Vs LT5hdXRob3JpdHkud2hvOworCisJcmV0ID0gdGVzdF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwgImMy cyAzYyAzYyAyYyAyc2MgYzJzYyBjczJjIDVjIiwKKwkJCQkgICAgT1BBTF9DQUxMLAorCQkJCSAg ICBscl9idWZmZXIsIE9QQUxfVUlEX0xFTkdUSCwKKwkJCQkgICAgbWV0aG9kLCBPUEFMX01FVEhP RF9MRU5HVEgsCisKKwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAgIE9QQUxfU1RBUlRO QU1FLAorCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wMSwgLyogVmFsdWVzICovCisKKwkJCQkgICAg T1BBTF9TVEFSVExJU1QsCisJCQkJICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1RJ TllfVUlOVF8wMywgLyogQm9vbGVhbkV4cHIgKi8KKworCQkJCSAgICBPUEFMX1NUQVJUTElTVCwK KwkJCQkgICAgT1BBTF9TVEFSVE5BTUUsCisKKwkJCQkgICAgT1BBTFVJRFtPUEFMX0hBTEZfVUlE X0FVVEhPUklUWV9PQkpfUkVGXSwKKwkJCQkgICAgT1BBTF9VSURfTEVOR1RIX0hBTEYsCisJCQkJ ICAgIHVzZXJfdWlkLCBPUEFMX1VJRF9MRU5HVEgsCisJCQkJICAgIE9QQUxfRU5ETkFNRSwKKwor CQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTFVJRFtPUEFMX0hBTEZfVUlEX0FV VEhPUklUWV9PQkpfUkVGXSwKKwkJCQkgICAgT1BBTF9VSURfTEVOR1RIX0hBTEYsCisJCQkJICAg IHVzZXJfdWlkLCBPUEFMX1VJRF9MRU5HVEgsCisJCQkJICAgIE9QQUxfRU5ETkFNRSwKKworCQkJ CSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTFVJRFtPUEFMX0hBTEZfVUlEX0JPT0xF QU5fQUNFXSwKKwkJCQkgICAgT1BBTF9VSURfTEVOR1RIX0hBTEYsCisJCQkJICAgIE9QQUxfVElO WV9VSU5UXzAxLAorCQkJCSAgICBPUEFMX0VORE5BTUUsCisKKwkJCQkgICAgT1BBTF9FTkRMSVNU LAorCQkJCSAgICBPUEFMX0VORE5BTUUsCisJCQkJICAgIE9QQUxfRU5ETElTVCwKKwkJCQkgICAg T1BBTF9FTkROQU1FLAorCQkJCSAgICBPUEFMX0VORExJU1QpOworCWlmIChyZXQgPCAwKSB7CisJ CXByX2VycigiJXM6IEVycm9yIGJ1aWxkaW5nIGFkZCB1c2VyIHRvIGxvY2tpbmcgcmFuZ2UgY29t bWFuZC5cbiIsCisJCSAgICAgICBkZXYtPmRpc2tfbmFtZSk7CisJCXJldHVybiByZXQ7CisJfQor CisJcmV0dXJuIGZpbmFsaXplX2FuZF9zZW5kKGRldiwgY21kLCBnZW5lcmljX2NvbnQpOworfQor CitzdGF0aWMgaW50IGxvY2tfdW5sb2NrX2xvY2tpbmdfcmFuZ2Uoc3RydWN0IG9wYWxfZGV2ICpk ZXYpCit7CisJdTggbHJfYnVmZmVyW09QQUxfVUlEX0xFTkdUSF07CisJc3RydWN0IG9wYWxfY21k ICpjbWQ7CisJY29uc3QgdTggKm1ldGhvZDsKKwlzdHJ1Y3Qgb3BhbF9sb2NrX3VubG9jayAqbGt1 bDsKKwlpbnQgcmV0OworCXU4IHJlYWRfbG9ja2VkID0gMSwgd3JpdGVfbG9ja2VkID0gMTsKKwor CWNtZCA9ICZkZXYtPmNtZDsKKwljbGVhcl9vcGFsX2NtZChjbWQpOworCXNldF9jb21JRChjbWQs IGRldi0+Y29tSUQpOworCisJbWV0aG9kID0gT1BBTE1FVEhPRFtPUEFMX1NFVF07CisJbGt1bCA9 IGRldi0+ZnVuY19kYXRhW2Rldi0+c3RhdGUgLSAxXTsKKwlpZiAoYnVpbGRfbG9ja2luZ19yYW5n ZShscl9idWZmZXIsIHNpemVvZihscl9idWZmZXIpLCBkZXYtPmxyKSA8IDApIHsKKwkJcHJfZXJy KCIlczogQ2FuJ3QgYnVpbGQgbG9ja2luZyByYW5nZVxuIiwgZGV2LT5kaXNrX25hbWUpOworCQly ZXR1cm4gLUVJTlZBTDsKKwl9CisKKwlzd2l0Y2ggKGxrdWwtPmxfc3RhdGUpIHsKKwljYXNlIE9Q QUxfUk86CisJCXJlYWRfbG9ja2VkID0gMDsKKwkJd3JpdGVfbG9ja2VkID0gMTsKKwkJYnJlYWs7 CisJY2FzZSBPUEFMX1JXOgorCQlyZWFkX2xvY2tlZCA9IDA7CisJCXdyaXRlX2xvY2tlZCA9IDA7 CisJCWJyZWFrOworCWNhc2UgT1BBTF9MSzoKKwkJLyogdmFycyBhcmUgaW5pdGFsaXplZCB0byBs b2NrZWQgKi8KKwkJYnJlYWs7CisJZGVmYXVsdDoKKwkJcHJfZXJyKCJUcmllZCB0byBzZXQgYW4g aW52YWxpZCBsb2NraW5nIHN0YXRlLi4uIHJldHVybmluZyB0byB1bGFuZFxuIik7CisJCXJldHVy biAxOworCX0KKworCXJldCA9IHRlc3RfYW5kX2FkZF90b2tlbl92YShjbWQsICJjMnNjIDNjIDRj IDRjIDNjIiwKKwkJCQkgICAgT1BBTF9DQUxMLAorCQkJCSAgICBscl9idWZmZXIsIE9QQUxfVUlE X0xFTkdUSCwKKwkJCQkgICAgbWV0aG9kLCBPUEFMX01FVEhPRF9MRU5HVEgsCisJCQkJICAgIE9Q QUxfU1RBUlRMSVNULAorCisJCQkJICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1ZB TFVFUywKKwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisKKwkJCQkgICAgT1BBTF9TVEFSVE5BTUUs CisJCQkJICAgIE9QQUxfUkVBRExPQ0tFRCwKKwkJCQkgICAgcmVhZF9sb2NrZWQsCisJCQkJICAg IE9QQUxfRU5ETkFNRSwKKworCQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9X UklURUxPQ0tFRCwKKwkJCQkgICAgd3JpdGVfbG9ja2VkLAorCQkJCSAgICBPUEFMX0VORE5BTUUs CisKKwkJCQkgICAgT1BBTF9FTkRMSVNULAorCQkJCSAgICBPUEFMX0VORE5BTUUsCisJCQkJICAg IE9QQUxfRU5ETElTVCk7CisKKwlpZiAocmV0IDwgMCkgeworCQlwcl9lcnIoIiVzOiBFcnJvciBi dWlsZGluZyBTRVQgY29tbWFuZC5cbiIsIGRldi0+ZGlza19uYW1lKTsKKwkJcmV0dXJuIHJldDsK Kwl9CisJcmV0dXJuIGZpbmFsaXplX2FuZF9zZW5kKGRldiwgY21kLCBnZW5lcmljX2NvbnQpOwor fQorCisKK3N0YXRpYyBpbnQgbG9ja191bmxvY2tfbG9ja2luZ19yYW5nZV9TVU0oc3RydWN0IG9w YWxfZGV2ICpkZXYpCit7CisJdTggbHJfYnVmZmVyW09QQUxfVUlEX0xFTkdUSF07CisJc3RydWN0 IG9wYWxfY21kICpjbWQ7CisJY29uc3QgdTggKm1ldGhvZDsKKwlzdHJ1Y3Qgb3BhbF9sb2NrX3Vu bG9jayAqbGt1bDsKKwlpbnQgcmV0OworCXU4IHJlYWRfbG9ja2VkID0gMSwgd3JpdGVfbG9ja2Vk ID0gMTsKKworCWNtZCA9ICZkZXYtPmNtZDsKKwljbGVhcl9vcGFsX2NtZChjbWQpOworCXNldF9j b21JRChjbWQsIGRldi0+Y29tSUQpOworCisJbWV0aG9kID0gT1BBTE1FVEhPRFtPUEFMX1NFVF07 CisJbGt1bCA9IGRldi0+ZnVuY19kYXRhW2Rldi0+c3RhdGUgLSAxXTsKKwlpZiAoYnVpbGRfbG9j a2luZ19yYW5nZShscl9idWZmZXIsIHNpemVvZihscl9idWZmZXIpLCBkZXYtPmxyKSA8IDApIHsK KwkJcHJfZXJyKCIlczogQ2FuJ3QgYnVpbGQgbG9ja2luZyByYW5nZVxuIiwgZGV2LT5kaXNrX25h bWUpOworCQlyZXR1cm4gLUVJTlZBTDsKKwl9CisKKwlzd2l0Y2ggKGxrdWwtPmxfc3RhdGUpIHsK KwljYXNlIE9QQUxfUk86CisJCXJlYWRfbG9ja2VkID0gMDsKKwkJd3JpdGVfbG9ja2VkID0gMTsK KwkJYnJlYWs7CisJY2FzZSBPUEFMX1JXOgorCQlyZWFkX2xvY2tlZCA9IDA7CisJCXdyaXRlX2xv Y2tlZCA9IDA7CisJCWJyZWFrOworCWNhc2UgT1BBTF9MSzoKKwkJLyogdmFycyBhcmUgaW5pdGFs aXplZCB0byBsb2NrZWQgKi8KKwkJYnJlYWs7CisJZGVmYXVsdDoKKwkJcHJfZXJyKCJUcmllZCB0 byBzZXQgYW4gaW52YWxpZCBsb2NraW5nIHN0YXRlLlxuIik7CisJCXJldHVybiAxOworCX0KKwor CXJldCA9IHRlc3RfYW5kX2FkZF90b2tlbl92YShjbWQsICJjMnNjIDNjIDRjIDRjIDRjIDRjIDNj IiwKKwkJCQkgICAgT1BBTF9DQUxMLAorCQkJCSAgICBscl9idWZmZXIsIE9QQUxfVUlEX0xFTkdU SCwKKwkJCQkgICAgbWV0aG9kLCBPUEFMX01FVEhPRF9MRU5HVEgsCisJCQkJICAgIE9QQUxfU1RB UlRMSVNULAorCisJCQkJICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1ZBTFVFUywK KwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisKKwkJCQkgICAgT1BBTF9TVEFSVE5BTUUsCisJCQkJ ICAgIE9QQUxfUkVBRExPQ0tFTkFCTEVELAorCQkJCSAgICBPUEFMX1RSVUUsCisJCQkJICAgIE9Q QUxfRU5ETkFNRSwKKworCQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9XUklU RUxPQ0tFTkFCTEVELAorCQkJCSAgICBPUEFMX1RSVUUsCisJCQkJICAgIE9QQUxfRU5ETkFNRSwK KworCQkJCSAgICBPUEFMX1NUQVJUTkFNRSwKKwkJCQkgICAgT1BBTF9SRUFETE9DS0VELAorCQkJ CSAgICByZWFkX2xvY2tlZCwKKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCisJCQkJICAgIE9QQUxf U1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1dSSVRFTE9DS0VELAorCQkJCSAgICB3cml0ZV9sb2Nr ZWQsCisJCQkJICAgIE9QQUxfRU5ETkFNRSwKKworCQkJCSAgICBPUEFMX0VORExJU1QsCisJCQkJ ICAgIE9QQUxfRU5ETkFNRSwKKwkJCQkgICAgT1BBTF9FTkRMSVNUKTsKKwlpZiAocmV0IDwgMCkg eworCQlwcl9lcnIoIiVzOiBFcnJvciBidWlsZGluZyBTRVQgY29tbWFuZC5cbiIsIGRldi0+ZGlz a19uYW1lKTsKKwkJcmV0dXJuIHJldDsKKwl9CisJcmV0dXJuIGZpbmFsaXplX2FuZF9zZW5kKGRl diwgY21kLCBnZW5lcmljX2NvbnQpOworfQorCitpbnQgYWN0aXZhdGVfbHNwKHN0cnVjdCBvcGFs X2RldiAqZGV2KQoreworCXU4IHVzZXJfbHJbT1BBTF9VSURfTEVOR1RIXTsKKwljb25zdCB1OCAq bWV0aG9kLCAqdWlkOworCXN0cnVjdCBvcGFsX2NtZCAqY21kOworCWludCByZXQ7CisJc2l6ZV90 IHVpbnRfMyA9IDB4ODM7CisKKwljbWQgPSAmZGV2LT5jbWQ7CisKKwljbGVhcl9vcGFsX2NtZChj bWQpOworCXNldF9jb21JRChjbWQsIGRldi0+Y29tSUQpOworCisJdWlkID0gT1BBTFVJRFtPUEFM X0xPQ0tJTkdTUF9VSURdOworCW1ldGhvZCA9IE9QQUxNRVRIT0RbT1BBTF9BQ1RJVkFURV07CisK KwlyZXQgPSB0ZXN0X2FuZF9hZGRfdG9rZW5fdmEoY21kLCAiYzJzIiwKKwkJCQkgICAgT1BBTF9D QUxMLAorCQkJCSAgICB1aWQsIE9QQUxfVUlEX0xFTkdUSCwKKwkJCQkgICAgbWV0aG9kLCBPUEFM X01FVEhPRF9MRU5HVEgpOworCWlmIChyZXQgPCAwKSB7CisJCXByX2VycigiJXM6IEVycm9yIGJ1 aWxkaW5nIEFjdGl2YXRlIExvY2tpbmdTUCBjb21tYW5kLlxuIiwKKwkJICAgICAgIGRldi0+ZGlz a19uYW1lKTsKKwkJcmV0dXJuIHJldDsKKwl9CisJLyogQWN0aXZhdGluZyBhcyBTVU0gKi8KKwlp ZiAoZGV2LT5sciA+IDApIHsKKwkJcmV0ID0gYnVpbGRfbG9ja2luZ19yYW5nZSh1c2VyX2xyLCBz aXplb2YodXNlcl9sciksIGRldi0+bHIpOworCQlpZiAocmV0IDwgMCkgeworCQkJcHJfZXJyKCIl czogQ2FuJ3QgYnVpbGQgbG9ja2luZyB1c2VyXG4iLAorCQkJICAgICAgIGRldi0+ZGlza19uYW1l KTsKKwkJCXJldHVybiByZXQ7CisJCX0KKwkJdGVzdF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwgIjJj IDRjIGNzYyAyYyIsCisJCQkJICAgICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAgICAgT1BBTF9T VEFSVE5BTUUsCisKKwkJCQkgICAgICB1aW50XzMsCisJCQkJICAgICAgT1BBTF9USU5ZX1VJTlRf MDYsCisJCQkJICAgICAgT1BBTF9USU5ZX1VJTlRfMDAsCisJCQkJICAgICAgT1BBTF9USU5ZX1VJ TlRfMDAsCisKKwkJCQkgICAgICBPUEFMX1NUQVJUTElTVCwKKwkJCQkgICAgICB1c2VyX2xyLCBP UEFMX1VJRF9MRU5HVEgsCisJCQkJICAgICAgT1BBTF9FTkRMSVNULAorCisJCQkJICAgICAgT1BB TF9FTkROQU1FLAorCQkJCSAgICAgIE9QQUxfRU5ETElTVCk7CisJfSBlbHNlIC8qIEFjdGlhdmUg Tm9ybWFsIE1vZGUgKi8KKwkJcmV0ID0gdGVzdF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwgIjJjIiwK KwkJCQkJICAgIE9QQUxfU1RBUlRMSVNULAorCQkJCQkgICAgT1BBTF9FTkRMSVNUKTsKKworCWlm IChyZXQgPCAwKSB7CisJCXByX2VycigiJXM6IEVycm9yIGJ1aWxkaW5nIEFjdGl2YXRlIExvY2tp bmdTUCBjb21tYW5kLlxuIiwKKwkJICAgICAgIGRldi0+ZGlza19uYW1lKTsKKwkJcmV0dXJuIHJl dDsKKwl9CisKKwlyZXR1cm4gZmluYWxpemVfYW5kX3NlbmQoZGV2LCBjbWQsIGdlbmVyaWNfY29u dCk7Cit9CisKK3N0YXRpYyBpbnQgZ2V0X2xzcF9saWZlY3ljbGVfY29udCh2b2lkICpkYXRhKQor eworCXN0cnVjdCBvcGFsX2RldiAqZGV2ID0gZGF0YTsKKwl1OCBsY19zdGF0dXM7CisJaW50IGVy cm9yID0gMDsKKworCWVycm9yID0gcGFyc2VfYW5kX2NoZWNrX3N0YXR1cyhkZXYpOworCWlmIChl cnJvcikKKwkJZ290byBlcnJfcmV0dXJuOworCisJbGNfc3RhdHVzID0gcmVzcG9uc2VfZ2V0X3U2 NCgmZGV2LT5wYXJzZWQsIDQpOworCS8qIDB4MDggaXMgTWFudWZhY3VyZWQgSW5hY3RpdmUgKi8K KwkvKiAweDA5IGlzIE1hbnVmYWN0dXJlZCAqLworCWlmIChsY19zdGF0dXMgIT0gMHgwOCkgewor CQlwcl9lcnIoIiVzOiBDb3VsZG4ndCBkZXRlcm1pbmUgdGhlIHN0YXR1cyBvZiB0aGUgTGlmY3lj bGUgc3RhdGVcbiIsCisJCSAgICAgICBkZXYtPmRpc2tfbmFtZSk7CisJCWVycm9yID0gLUVOT0RF VjsKKwkJZ290byBlcnJfcmV0dXJuOworCX0KKworZXJyX3JldHVybjoKKwlyZXR1cm4gZXJyb3I7 Cit9CisKKy8qIERldGVybWluZSBpZiB3ZSdyZSBpbiB0aGUgTWFudWZhY3R1cmVkIEluYWN0aXZl IG9yIEFjdGl2ZSBzdGF0ZSAqLworaW50IGdldF9sc3BfbGlmZWN5Y2xlKHN0cnVjdCBvcGFsX2Rl diAqZGV2KQoreworCXN0cnVjdCBvcGFsX2NtZCAqY21kOworCWNvbnN0IHU4ICptZXRob2QsICp1 aWQ7CisJaW50IHJldDsKKworCWNtZCA9ICZkZXYtPmNtZDsKKworCWNsZWFyX29wYWxfY21kKGNt ZCk7CisJc2V0X2NvbUlEKGNtZCwgZGV2LT5jb21JRCk7CisKKwl1aWQgPSBPUEFMVUlEW09QQUxf TE9DS0lOR1NQX1VJRF07CisJbWV0aG9kID0gT1BBTE1FVEhPRFtPUEFMX0dFVF07CisKKwlyZXQg PSB0ZXN0X2FuZF9hZGRfdG9rZW5fdmEoY21kLCAiYzJzIDJjIDRjIDRjIDJjIiwKKwkJCQkgICAg T1BBTF9DQUxMLAorCQkJCSAgICB1aWQsIE9QQUxfVUlEX0xFTkdUSCwKKwkJCQkgICAgbWV0aG9k LCBPUEFMX01FVEhPRF9MRU5HVEgsCisKKwkJCQkgICAgT1BBTF9TVEFSVExJU1QsCisJCQkJICAg IE9QQUxfU1RBUlRMSVNULAorCisJCQkJICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFM X1RJTllfVUlOVF8wMywgLyogU3RhcnQgQ29sdW1uICovCisJCQkJICAgIE9QQUxfVElOWV9VSU5U XzA2LCAvKiBMaWZjeWNsZSBDb2x1bW4gKi8KKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCisJCQkJ ICAgIE9QQUxfU1RBUlROQU1FLAorCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wNCwgLyogRW5kIENv bHVtbiAqLworCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wNiwgLyogTGlmZWN5Y2xlIENvbHVtbiAq LworCQkJCSAgICBPUEFMX0VORE5BTUUsCisKKwkJCQkgICAgT1BBTF9FTkRMSVNULAorCQkJCSAg ICBPUEFMX0VORExJU1QpOworCisJaWYgKHJldCA8IDApIHsKKwkJcHJfZXJyKCIlczogRXJyb3Ig QnVpbGRpbmcgR0VUIExpZmVjeWNsZSBTdGF0dXMgY29tbWFuZFxuIiwKKwkJICAgICAgIGRldi0+ ZGlza19uYW1lKTsKKwkJcmV0dXJuIHJldDsKKwl9CisKKwlyZXR1cm4gZmluYWxpemVfYW5kX3Nl bmQoZGV2LCBjbWQsIGdldF9sc3BfbGlmZWN5Y2xlX2NvbnQpOworfQorCitzdGF0aWMgaW50IGdl dF9tc2lkX2NwaW5fcGluX2NvbnQodm9pZCAqZGF0YSkKK3sKKwljb25zdCBjaGFyICptc2lkX3Bp bjsKKwlzdHJ1Y3Qgb3BhbF9kZXYgKmRldiA9IGRhdGE7CisJc2l6ZV90IHN0cmxlbjsKKwlpbnQg ZXJyb3IgPSAwOworCisJZXJyb3IgPSBwYXJzZV9hbmRfY2hlY2tfc3RhdHVzKGRldik7CisJaWYg KGVycm9yKQorCQlnb3RvIGVycl9yZXR1cm47CisKKwlzdHJsZW4gPSByZXNwb25zZV9nZXRfc3Ry aW5nKCZkZXYtPnBhcnNlZCwgNCwgJm1zaWRfcGluKTsKKwlpZiAoIW1zaWRfcGluKSB7CisJCXBy X2VycigiJXM6IENvdWxkbid0IGV4dHJhY3QgUElOIGZyb20gcmVzcG9uc2VcbiIsIF9fZnVuY19f KTsKKwkJZXJyb3IgPSAxOworCQlnb3RvIGVycl9yZXR1cm47CisJfQorCisJZGV2LT5wcmV2X2Rh dGEgPSBrbWVtZHVwKG1zaWRfcGluLCBzdHJsZW4sIEdGUF9LRVJORUwpOworCWlmICghZGV2LT5w cmV2X2RhdGEpIHsKKwkJZXJyb3IgPSAtRU5PTUVNOworCQlnb3RvIGVycl9yZXR1cm47CisJfQor CisJZGV2LT5wcmV2X2RfbGVuID0gc3RybGVuOworCisgZXJyX3JldHVybjoKKwlyZXR1cm4gZXJy b3I7Cit9CisKK3N0YXRpYyBpbnQgZ2V0X21zaWRfY3Bpbl9waW4oc3RydWN0IG9wYWxfZGV2ICpk ZXYpCit7CisJY29uc3QgdTggKm1ldGhvZCwgKnNtdWlkOworCWludCByZXQ7CisJc3RydWN0IG9w YWxfY21kICpjbWQ7CisKKwljbWQgPSAmZGV2LT5jbWQ7CisJY2xlYXJfb3BhbF9jbWQoY21kKTsK KwlzZXRfY29tSUQoY21kLCBkZXYtPmNvbUlEKTsKKworCXNtdWlkID0gT1BBTFVJRFtPUEFMX0Nf UElOX01TSURdOworCW1ldGhvZCA9IE9QQUxNRVRIT0RbT1BBTF9HRVRdOworCisJcmV0ID0gdGVz dF9hbmRfYWRkX3Rva2VuX3ZhKGNtZCwgImMgMnMgMTJjIiwKKwkJCQkgICAgT1BBTF9DQUxMLAor CisJCQkJICAgIHNtdWlkLCBPUEFMX1VJRF9MRU5HVEgsCisJCQkJICAgIG1ldGhvZCwgT1BBTF9N RVRIT0RfTEVOR1RILAorCisJCQkJICAgIE9QQUxfU1RBUlRMSVNULAorCQkJCSAgICBPUEFMX1NU QVJUTElTVCwKKwkJCQkgICAgT1BBTF9TVEFSVE5BTUUsCisJCQkJICAgIE9QQUxfVElOWV9VSU5U XzAzLCAvKiBTYXJ0IENvbHVtbiAqLworCQkJCSAgICBPUEFMX1RJTllfVUlOVF8wMywgLyogUElO ICovCisJCQkJICAgIE9QQUxfRU5ETkFNRSwKKwkJCQkgICAgT1BBTF9TVEFSVE5BTUUsCisJCQkJ ICAgIE9QQUxfVElOWV9VSU5UXzA0LCAvKiBFbmQgQ29sdW1uICovCisJCQkJICAgIE9QQUxfVElO WV9VSU5UXzAzLCAvKiBQSU4gKi8KKwkJCQkgICAgT1BBTF9FTkROQU1FLAorCQkJCSAgICBPUEFM X0VORExJU1QsCisJCQkJICAgIE9QQUxfRU5ETElTVCk7CisKKwlpZiAocmV0IDwgMCkgeworCQlw cl9lcnIoIiVzOiBFcnJvciBidWlsZGluZyBHZXQgTVNJRCBDUElOIFBJTiBjb21tYW5kLlxuIiwK KwkJICAgICAgIGRldi0+ZGlza19uYW1lKTsKKwkJcmV0dXJuIHJldDsKKwl9CisKKwlyZXR1cm4g ZmluYWxpemVfYW5kX3NlbmQoZGV2LCBjbWQsIGdldF9tc2lkX2NwaW5fcGluX2NvbnQpOworfQor CitzdGF0aWMgdm9pZCB1bmxvY2tfc3VzcGVuZF9maW5hbChzdHJ1Y3Qgb3BhbF9kZXYgKmRldikK K3sKKwlkZXYtPnJlc3VtZV9mcm9tX3N1c3BlbmQgPSBmYWxzZTsKKwlkZXYtPnJlc3VtZV9kYXRh ID0gTlVMTDsKKwlkZXYtPmZ1bmNfZGF0YSA9IE5VTEw7Cit9CisKK3N0YXRpYyBpbnQgYnVpbGRf ZW5kX29wYWxfc2Vzc2lvbihzdHJ1Y3Qgb3BhbF9kZXYgKmRldikKK3sKKwlzdHJ1Y3Qgb3BhbF9j bWQgKmNtZDsKKworCWNtZCA9ICZkZXYtPmNtZDsKKwljbGVhcl9vcGFsX2NtZChjbWQpOworCisJ c2V0X2NvbUlEKGNtZCwgZGV2LT5jb21JRCk7CisJcmV0dXJuIHRlc3RfYW5kX2FkZF90b2tlbl91 OChjbWQsIE9QQUxfRU5ET0ZTRVNTSU9OKTsKK30KKworc3RhdGljIGludCBlbmRfb3BhbF9zZXNz aW9uKHN0cnVjdCBvcGFsX2RldiAqZGV2KQoreworCWludCByZXQgPSBidWlsZF9lbmRfb3BhbF9z ZXNzaW9uKGRldik7CisKKwlpZiAocmV0IDwgMCkKKwkJcmV0dXJuIHJldDsKKwlyZXR1cm4gZmlu YWxpemVfYW5kX3NlbmQoZGV2LCAmZGV2LT5jbWQsIGVuZF9zZXNzaW9uX2NvbnQpOworfQorCitz dGF0aWMgc3RydWN0IG9wYWxfZGV2ICpmaW5kX29wYWxfZGV2KGRldl90IG1ham1pbiwgdTggbHIp Cit7CisJc3RydWN0IG9wYWxfZGV2ICppdGVyLCAqb3BhbF9kZXYgPSBOVUxMOworCisJbGlzdF9m b3JfZWFjaF9lbnRyeShpdGVyLCAmb3BhbF9saXN0LCBub2RlKSB7CisJCWlmIChNQUpPUihpdGVy LT5tYWptaW4pICE9IE1BSk9SKG1ham1pbikgfHwKKwkJICAgIE1JTk9SKGl0ZXItPm1ham1pbikg IT0gTUlOT1IobWFqbWluKSkKKwkJCWNvbnRpbnVlOworCisJCWlmIChpdGVyLT5sciA9PSBscikg eworCQkJb3BhbF9kZXYgPSBpdGVyOworCQkJYnJlYWs7CisJCX0KKwl9CisJcmV0dXJuIG9wYWxf ZGV2OworfQorCitzdGF0aWMgaW50IHVwZGF0ZV9vcGFsX2RldihzdHJ1Y3Qgb3BhbF9kZXYgKm9s ZF9kZXYsIHN0cnVjdCBvcGFsX2RldiAqbmV3X2RldikKK3sKKwlpZiAoIWF0b21pY19hZGRfdW5s ZXNzKCZvbGRfZGV2LT5pbl91c2UsIDEsIDEpKSB7CisJCXByX2VycigiJXM6IGRldiB3YXMgaW4g dXNlXG4iLCBfX2Z1bmNfXyk7CisJCXJldHVybiAtRUJVU1k7CisJfQorCisJb2xkX2Rldi0+a2V5 X25hbWVfbGVuID0gbmV3X2Rldi0+a2V5X25hbWVfbGVuOworCWlmICghbWVtY3B5KG9sZF9kZXYt PmtleV9uYW1lLCBuZXdfZGV2LT5rZXlfbmFtZSwgb2xkX2Rldi0+a2V5X25hbWVfbGVuKSkgewor CQlwcl9lcnIoIiVzOiBFcnJvciB1cGRhdGluZyBkZXZpY2U6XG4iLCBvbGRfZGV2LT5kaXNrX25h bWUpOworCQlyZXR1cm4gLUVGQVVMVDsKKwl9CisKKwlpZiAoIXN0cm5jcHkob2xkX2Rldi0+ZGlz a19uYW1lLCBuZXdfZGV2LT5kaXNrX25hbWUsIERJU0tfTkFNRV9MRU4pKSB7CisJCXByX2Vycigi JXM6IEVycm9yIHJlZ2lzdGVyaW5nIGRldmljZTogY29weWluZyBkaXNrIG5hbWVcbiIsCisJCSAg ICAgICBvbGRfZGV2LT5kaXNrX25hbWUpOworCQlyZXR1cm4gLUVGQVVMVDsKKwl9CisKKwlvbGRf ZGV2LT5jb21JRCA9IG5ld19kZXYtPmNvbUlEOworCW9sZF9kZXYtPnN0YXJ0ID0gbmV3X2Rldi0+ c3RhcnQ7CisJb2xkX2Rldi0+bGVuZ3RoID0gbmV3X2Rldi0+bGVuZ3RoOworCW9sZF9kZXYtPmFs aWduID0gbmV3X2Rldi0+YWxpZ247CisJb2xkX2Rldi0+bG93ZXN0X2xiYSA9IG5ld19kZXYtPmxv d2VzdF9sYmE7CisJb2xkX2Rldi0+c3RhdGUgPSBuZXdfZGV2LT5zdGF0ZTsKKwlvbGRfZGV2LT5m dW5jcyA9IG5ld19kZXYtPmZ1bmNzOworCW9sZF9kZXYtPm1ham1pbiA9IG5ld19kZXYtPm1ham1p bjsKKwlvbGRfZGV2LT5zdWJtaXRfZm4gPSBuZXdfZGV2LT5zdWJtaXRfZm47CisJb2xkX2Rldi0+ c3VibWl0X2RhdGEgPSBuZXdfZGV2LT5zdWJtaXRfZGF0YTsKKworCWNsZWFuX2Z1bmN0aW9uX2Rh dGEob2xkX2Rldik7CisKKwkvKgorCSAqIFdvbid0IGJlIGFibGUgdG8gYXV0byB1bmxvY2sgdGhp cyBsb2NraW5nIHJhbmdlIGJhc2VkIG9uIGJsb2NrCisJICogcmVxdWVzdGVzLgorCSAqLworCWlm IChvbGRfZGV2LT5sZW5ndGggPT0gMCkKKwkJcHJfd2FybigiJXM6IE1pc3NpbmcgYmxvY2sgaW5m b3JtYXRpb24gZm9yIGxvY2tpbmcgcmFuZ2UgJWRcbiIsCisJCQlvbGRfZGV2LT5kaXNrX25hbWUs IG9sZF9kZXYtPmxyKTsKKworCXJldHVybiAwOworfQorCitpbnQgb3BhbF9yZWdpc3Rlcl9jb250 KHN0cnVjdCBvcGFsX2RldiAqbmV3X2RldikKK3sKKwlzdHJ1Y3Qgb3BhbF9kZXYgKm9sZF9kZXY7 CisJdW5zaWduZWQgbG9uZyBmbGFnczsKKwlpbnQgZXJyb3IgPSAwOworCisJc3Bpbl9sb2NrX2ly cXNhdmUoJmxpc3Rfc3BpbmxvY2ssIGZsYWdzKTsKKworCW9sZF9kZXYgPSBmaW5kX29wYWxfZGV2 KG5ld19kZXYtPm1ham1pbiwgbmV3X2Rldi0+bHIpOworCWlmICghb2xkX2RldikgeworCQlsaXN0 X2FkZF90YWlsKCZuZXdfZGV2LT5ub2RlLCAmb3BhbF9saXN0KTsKKwkJb2xkX2RldiA9IG5ld19k ZXY7CisJfSBlbHNlIHsKKwkJaWYgKG9sZF9kZXYgPT0gbmV3X2RldikKKwkJCWVycm9yID0gMDsK KwkJZWxzZSB7CisJCQllcnJvciA9IHVwZGF0ZV9vcGFsX2RldihvbGRfZGV2LCBuZXdfZGV2KTsK KwkJCWNsZWFuX29wYWxfa2V5KG5ld19kZXYpOworCQkJa2ZyZWUobmV3X2Rldik7CisJCX0KKwl9 CisKKwlpZiAoZXJyb3IpCisJCWxpc3RfZGVsKCZvbGRfZGV2LT5ub2RlKTsKKworCXNwaW5fdW5s b2NrX2lycXJlc3RvcmUoJmxpc3Rfc3BpbmxvY2ssIGZsYWdzKTsKKworCWlmICghZXJyb3IpCisJ CXByX2luZm8oIiVzOiBSZWdpc3RlcmVkIGtleSBmb3IgbG9ja2luZyByYW5nZTogJWRcbiIsCisJ CQlvbGRfZGV2LT5kaXNrX25hbWUsIG9sZF9kZXYtPmxyKTsKKworCXJldHVybiBlcnJvcjsKK30K KworY29uc3Qgb3BhbF9zdGVwIGVycm9yX2VuZF9zZXNzaW9uW10gPSB7CisJZW5kX29wYWxfc2Vz c2lvbiwKKwlOVUxMLAorfTsKK3N0YXRpYyBpbnQgZW5kX29wYWxfc2Vzc2lvbl9lcnJvcihzdHJ1 Y3Qgb3BhbF9kZXYgKmRldikKK3sKKworCWRldi0+ZnVuY3MgPSBlcnJvcl9lbmRfc2Vzc2lvbjsK KwlkZXYtPnN0YXRlID0gMDsKKwlkZXYtPmVycm9yX2NiID0gTlVMTDsKKwlyZXR1cm4gbmV4dChk ZXYpOworfQorCitzdGF0aWMgc3RydWN0IG9wYWxfZGV2ICphbGxvY19vcGFsX2RldihzdHJ1Y3Qg YmxvY2tfZGV2aWNlICpiZGV2LCB1OCBscikKK3sKKwlzdHJ1Y3Qgb3BhbF9kZXYgKm9wYWxfZGV2 OworCXN0cnVjdCByZXF1ZXN0X3F1ZXVlICpxOworCXVuc2lnbmVkIGxvbmcgZG1hX2FsaWduOwor CWNvbnN0IGNoYXIgKmRpc2tfbmFtZTsKKwlzdHJ1Y3Qgb3BhbF9jbWQgKmNtZDsKKwlpbnQgcmV0 OworCisJb3BhbF9kZXYgPSBremFsbG9jKHNpemVvZigqb3BhbF9kZXYpLCBHRlBfS0VSTkVMKTsK KwlpZiAoIW9wYWxfZGV2KQorCQlyZXR1cm4gRVJSX1BUUigtRU5PTUVNKTsKKworCW9wYWxfZGV2 LT5tYWptaW4gPSBiZGV2LT5iZF9kZXY7CisJb3BhbF9kZXYtPmxyID0gbHI7CisJY21kID0gJm9w YWxfZGV2LT5jbWQ7CisJY21kLT5jbWQgPSBjbWQtPmNtZF9idWY7CisJY21kLT5yZXNwID0gY21k LT5yZXNwX2J1ZjsKKworCWRpc2tfbmFtZSA9IGJkZXYtPmJkX2Rpc2stPmRpc2tfbmFtZTsKKwlp ZiAoIXN0cm5jcHkob3BhbF9kZXYtPmRpc2tfbmFtZSwgZGlza19uYW1lLCBESVNLX05BTUVfTEVO KSkgeworCQlwcl9lcnIoIiVzOiBFcnJvciByZWdpc3RlcmluZyBkZXZpY2U6IGNvcHlpbmcgZGlz ayBuYW1lXG4iLAorCQkgICAgICAgZGlza19uYW1lKTsKKwkJcmV0ID0gLUVGQVVMVDsKKwkJZ290 byBlcnJfZnJlZV9kZXY7CisJfQorCisJcSA9IGJkZXYtPmJkX3F1ZXVlOworCWRtYV9hbGlnbiA9 IChxdWV1ZV9kbWFfYWxpZ25tZW50KHEpIHwgcS0+ZG1hX3BhZF9tYXNrKSArIDE7CisJY21kLT5j bWQgPSAodTggKilyb3VuZF91cCgodWludHB0cl90KWNtZC0+Y21kLCBkbWFfYWxpZ24pOworCWNt ZC0+cmVzcCA9ICh1OCAqKXJvdW5kX3VwKCh1aW50cHRyX3QpY21kLT5yZXNwLCBkbWFfYWxpZ24p OworCisJSU5JVF9MSVNUX0hFQUQoJm9wYWxfZGV2LT5ub2RlKTsKKwlhdG9taWNfc2V0KCZvcGFs X2Rldi0+aW5fdXNlLCAxKTsKKworCW9wYWxfZGV2LT5zdGF0ZSA9IDA7CisKKwlyZXR1cm4gb3Bh bF9kZXY7CisKK2Vycl9mcmVlX2RldjoKKwlrZnJlZShvcGFsX2Rldik7CisJcmV0dXJuIEVSUl9Q VFIocmV0KTsKK30KKworaW50IG9wYWxfcmVnaXN0ZXIoc3RydWN0IGJsb2NrX2RldmljZSAqYmRl diwgc3RydWN0IG9wYWxfa2V5ICprZXlfY21kLAorCQkgIGNvbnN0IG9wYWxfc3RlcCAqZnVuY3Ms IHZvaWQgKnNibXRfZGF0YSwKKwkJICBzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2ZuKQoreworCXN0 cnVjdCBvcGFsX2RldiAqbmV3X2RldiA9IE5VTEw7CisJdTgga2V5X2xlbiA9IGtleV9jbWQtPmtl eV9sZW47CisJdTggbHIgPSBrZXlfY21kLT5scjsKKwlpbnQgcmV0OworCisJbmV3X2RldiA9IGFs bG9jX29wYWxfZGV2KGJkZXYsIGxyKTsKKwlpZiAoSVNfRVJSKG5ld19kZXYpKSB7CisJCXByX2Vy cigiJXM6IEVycm9yIHJlZ2lzdGVyaW5nIGRldmljZTogYWxsb2NhdGlvblxuIiwKKwkJICAgICAg IGJkZXYtPmJkX2Rpc2stPmRpc2tfbmFtZSk7CisJCXJldHVybiBQVFJfRVJSKG5ld19kZXYpOwor CX0KKworCWlmICghbWVtY3B5KG5ld19kZXYtPmtleV9uYW1lLCBrZXlfY21kLT5rZXksIGtleV9s ZW4pKSB7CisJCXByX2VycigiJXM6IEVycm9yIHJlZ2lzdGVyaW5nIGtleTogY291bGRuJ3QgY29w eSBrZXlcbiIsCisJCSAgICAgICBuZXdfZGV2LT5kaXNrX25hbWUpOworCQlyZXR1cm4gLUVGQVVM VDsKKwl9CisKKwluZXdfZGV2LT5rZXlfbmFtZV9sZW4gPSBrZXlfbGVuOworCW5ld19kZXYtPmtl eV90eXBlID0ga2V5X2NtZC0+a2V5X3R5cGU7CisJcmV0ID0gZ2V0X29wYWxfa2V5KG5ld19kZXYp OworCWlmIChyZXQpIHsKKwkJcHJfZXJyKCIlczogQ291bGRuJ3QgZ2V0IGtleTogJWRcbiIsIG5l d19kZXYtPmRpc2tfbmFtZSwgcmV0KTsKKwkJcmV0dXJuIHJldDsKKwl9CisKKwluZXdfZGV2LT5m dW5jcyA9IGZ1bmNzOworCW5ld19kZXYtPnN1Ym1pdF9kYXRhID0gc2JtdF9kYXRhOworCW5ld19k ZXYtPnN1Ym1pdF9mbiA9IHN1Ym1pdF9mbjsKKworCW5ld19kZXYtPnN0YXRlID0gMDsKKwlyZXR1 cm4gbmV4dChuZXdfZGV2KTsKK30KKworc3RhdGljIHN0cnVjdCBvcGFsX2RldiAqZ2V0X3JlZ2lz dGVyZWRfb3BhbF9kZXYoZGV2X3QgbWFqbWluLCB1OCBscikKK3sKKwlzdHJ1Y3Qgb3BhbF9kZXYg Kml0ZXIsICpkZXYgPSBOVUxMOworCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CisJYm9vbCBpbl91c2Ug PSBmYWxzZTsKKworCXNwaW5fbG9ja19pcnFzYXZlKCZsaXN0X3NwaW5sb2NrLCBmbGFncyk7CisJ bGlzdF9mb3JfZWFjaF9lbnRyeShpdGVyLCAmb3BhbF9saXN0LCBub2RlKSB7CisJCWlmIChNQUpP UihpdGVyLT5tYWptaW4pICE9IE1BSk9SKG1ham1pbikgfHwKKwkJICAgIE1JTk9SKGl0ZXItPm1h am1pbikgIT0gTUlOT1IobWFqbWluKSkKKwkJCWNvbnRpbnVlOworCQlpZiAoaXRlci0+bHIgPT0g bHIpIHsKKwkJCWRldiA9IGl0ZXI7CisJCQlpZiAoIWF0b21pY19hZGRfdW5sZXNzKCZpdGVyLT5p bl91c2UsIDEsIDEpKSB7CisJCQkJZGV2ID0gTlVMTDsKKwkJCQlpbl91c2UgPSB0cnVlOworCQkJ fQorCQkJYnJlYWs7CisJCX0KKwl9CisKKwlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZsaXN0X3Nw aW5sb2NrLCBmbGFncyk7CisKKwlpZiAoIWRldikKKwkJcmV0dXJuIE5VTEw7CisKKwlyZXR1cm4g ZGV2OworfQorCisvKiBGcmVlIHVwIHRoZSBPcGFsIGRldiBhbmQgaXRzIGtleXMgZHVyaW5nIHR3 byBzY2VuYXJpb3M6CisgKgorICogMSkgV2hlbiBhIGNvbW1hbmQgaXMgY29tcGxldGUgdGhhdCBu byBsb25nZXIgcmVxdWlyZXMKKyAqICAgIHRoZSBvcGFsIGRldiB0byBiZSBhcm91bmQuCisgKiAy KSBXaGVuIGEgY29tbWFuZCwgaW5jbHVkaW5nIE9wYWwgU2F2ZSBmYWlscyB3ZSBjbGVhbgorICog ICAgYW5kIGZyZWUgdGhlIG9wYWwgZGV2LgorICoKKyAqICAgIElmIHdlIGZpbmQgdGhlIG9wYWwg ZGV2IHN0cnVjdHVyZSBpbiB0aGUgbGlzdCBvZgorICogICAgc2F2ZWQgcGFzc3dvcmRzIHdlIHdp bGwgKm5vdCogcmVtb3ZlIGl0LgorICovCitzdGF0aWMgdm9pZCByZW1vdmVfYW5kX2NsZWFuX29w YWxfZGV2KHN0cnVjdCBvcGFsX2RldiAqZGV2KQoreworCXN0cnVjdCBvcGFsX2RldiAqaXRlcjsK Kwlib29sIGZvdW5kID0gZmFsc2U7CisKKwlhdG9taWNfZGVjKCZkZXYtPmluX3VzZSk7CisJc3Bp bl9sb2NrKCZsaXN0X3NwaW5sb2NrKTsKKwlsaXN0X2Zvcl9lYWNoX2VudHJ5KGl0ZXIsICZvcGFs X2xpc3QsIG5vZGUpIHsKKwkJaWYgKGl0ZXIgPT0gZGV2KSB7CisJCQlmb3VuZCA9IHRydWU7CisJ CQlicmVhazsKKwkJfQorCX0KKworCXNwaW5fdW5sb2NrKCZsaXN0X3NwaW5sb2NrKTsKKwlpZiAo IWZvdW5kKSB7CisJCWNsZWFuX29wYWxfa2V5KGRldik7CisJCWNsZWFuX2Z1bmN0aW9uX2RhdGEo ZGV2KTsKKwkJa2ZyZWUoZGV2KTsKKwl9Cit9CisKK3N0YXRpYyBzdHJ1Y3Qgb3BhbF9kZXYgKmdl dF9vcl9jcmVhdGVfb3BhbF9kZXYoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwKKwkJCQkJICAg ICAgIHU4IGxyLCBib29sIHVzZV9uZXcpCit7CisJc3RydWN0IG9wYWxfZGV2ICpkZXYgPSBOVUxM OworCisJaWYgKCF1c2VfbmV3KQorCQlkZXYgPSBnZXRfcmVnaXN0ZXJlZF9vcGFsX2RldihiZGV2 LT5iZF9kZXYsIGxyKTsKKworCWlmICghZGV2KQorCQlkZXYgPSBhbGxvY19vcGFsX2RldihiZGV2 LCBscik7CisKKwlyZXR1cm4gZGV2OworfQorCitzdGF0aWMgaW50IHNldHVwX29wYWxfZGV2KHN0 cnVjdCBibG9ja19kZXZpY2UgKmJkZXYsICBzdHJ1Y3Qgb3BhbF9kZXYgKmRldiwKKwkJCSAgY29u c3Qgb3BhbF9zdGVwICpmdW5jcywgIHN0cnVjdCBvcGFsX2tleSAqa2V5LAorCQkJICB2b2lkICpz Ym10X2RhdGEsICBzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2ZuKQoreworCWludCByZXQ7CisKKwlk ZXYtPnN0YXRlID0gMDsKKwlkZXYtPmZ1bmNzID0gZnVuY3M7CisJZGV2LT5UU04gPSAwOworCWRl di0+SFNOID0gMDsKKwlkZXYtPmxyID0ga2V5LT5scjsKKwlkZXYtPmVycm9yX2NiID0gZW5kX29w YWxfc2Vzc2lvbl9lcnJvcjsKKwlkZXYtPmVycm9yX2NiX2RhdGEgPSBkZXY7CisJZGV2LT5zdWJt aXRfZm4gPSBzdWJtaXRfZm47CisJZGV2LT5zdWJtaXRfZGF0YSA9IHNibXRfZGF0YTsKKworCWlm IChrZXkpIHsKKwkJbWVtY3B5KGRldi0+a2V5X25hbWUsIGtleS0+a2V5LCBrZXktPmtleV9sZW4p OworCQlkZXYtPmtleV9uYW1lX2xlbiA9IGtleS0+a2V5X2xlbjsKKwkJZGV2LT5rZXlfdHlwZSA9 IGtleS0+a2V5X3R5cGU7CisKKwkJcmV0ID0gZ2V0X29wYWxfa2V5KGRldik7CisJCWlmIChyZXQp IHsKKwkJCXByX2VycigiJXM6IENvdWxkbid0IGdldCBrZXk6ICVkXG4iLAorCQkJICAgICAgIGRl di0+ZGlza19uYW1lLCByZXQpOworCQkJcmV0dXJuIHJldDsKKwkJfQorCX0KKwlkZXYtPmZ1bmNf ZGF0YSA9IE5VTEw7CisJcmV0dXJuIDA7Cit9CisKK2ludCBvcGFsX3NlY3VyZV9lcmFzZV9sb2Nr aW5nX3JhbmdlKHN0cnVjdCBibG9ja19kZXZpY2UgKmJkZXYsIHN0cnVjdCBzZWRfa2V5ICprZXks CisJCQkJICAgIHZvaWQgKnNibXRfZGF0YSwgc2VkX3NlY19zdWJtaXQgKnN1Ym1pdF9mbikKK3sK KwlzdHJ1Y3Qgb3BhbF9kZXYgKmRldjsKKwl2b2lkICpkYXRhWzNdID0geyBOVUxMIH07CisJY29u c3Qgb3BhbF9zdGVwIGVyYXNlX2Z1bmNzW10gPSB7CisJCW9wYWxfZGlzY292ZXJ5MCwKKwkJc3Rh cnRfYXV0aF9vcGFsX3Nlc3Npb24sCisJCWdldF9hY3RpdmVfa2V5LAorCQlnZW5fa2V5LAorCQll bmRfb3BhbF9zZXNzaW9uLAorCQlOVUxMLAorCX07CisJaW50IHJldDsKKworCWRldiA9IGdldF9v cl9jcmVhdGVfb3BhbF9kZXYoYmRldiwga2V5LT5vcGFsX2FjdC5rZXkubHIsIHRydWUpOworCWlm ICghZGV2KQorCQlyZXR1cm4gLUVOT01FTTsKKworCXJldCA9IHNldHVwX29wYWxfZGV2KGJkZXYs IGRldiwgZXJhc2VfZnVuY3MsICZrZXktPm9wYWxfYWN0LmtleSwKKwkJCSAgICAgc2JtdF9kYXRh LCBzdWJtaXRfZm4pOworCWRldi0+ZnVuY19kYXRhID0gZGF0YTsKKwlkZXYtPmZ1bmNfZGF0YVsx XSA9ICZrZXktPm9wYWxfYWN0LndobzsKKwlpZiAocmV0KQorCQlnb3RvIGVycm9yX3JldHVybjsK KworCXJldCA9IG5leHQoZGV2KTsKKworIGVycm9yX3JldHVybjoKKwlyZW1vdmVfYW5kX2NsZWFu X29wYWxfZGV2KGRldik7CisJcmV0dXJuIHJldDsKK30KK0VYUE9SVF9TWU1CT0wob3BhbF9zZWN1 cmVfZXJhc2VfbG9ja2luZ19yYW5nZSk7CisKK2ludCBvcGFsX2VyYXNlX2xvY2tpbmdfcmFuZ2Uo c3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3RydWN0IHNlZF9rZXkgKmtleSwKKwkJCSAgICAg dm9pZCAqc2JtdF9kYXRhLCBzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2ZuKQoreworCXN0cnVjdCBv cGFsX2RldiAqZGV2OworCWNvbnN0IG9wYWxfc3RlcCBlcmFzZV9mdW5jc1tdID0geworCQlvcGFs X2Rpc2NvdmVyeTAsCisJCXN0YXJ0X2F1dGhfb3BhbF9zZXNzaW9uLAorCQllcmFzZV9sb2NraW5n X3JhbmdlLAorCQllbmRfb3BhbF9zZXNzaW9uLAorCQlOVUxMLAorCX07CisJaW50IHJldDsKKwor CWRldiA9IGdldF9vcl9jcmVhdGVfb3BhbF9kZXYoYmRldiwga2V5LT5vcGFsX2xycy5rZXkubHIs IHRydWUpOworCWlmICghZGV2KQorCQlyZXR1cm4gLUVOT01FTTsKKworCXJldCA9IHNldHVwX29w YWxfZGV2KGJkZXYsIGRldiwgZXJhc2VfZnVuY3MsICZrZXktPm9wYWxfbHJzLmtleSwKKwkJCSAg ICAgc2JtdF9kYXRhLCBzdWJtaXRfZm4pOworCWlmIChyZXQpCisJCWdvdG8gZXJyb3JfcmV0dXJu OworCisJcmV0ID0gbmV4dChkZXYpOworCisgZXJyb3JfcmV0dXJuOgorCXJlbW92ZV9hbmRfY2xl YW5fb3BhbF9kZXYoZGV2KTsKKwlyZXR1cm4gcmV0OworfQorRVhQT1JUX1NZTUJPTChvcGFsX2Vy YXNlX2xvY2tpbmdfcmFuZ2UpOworCitpbnQgb3BhbF9lbmFibGVfZGlzYWJsZV9zaGFkb3dfbWJy KHN0cnVjdCBibG9ja19kZXZpY2UgKmJkZXYsCisJCQkJICAgc3RydWN0IHNlZF9rZXkgKmtleSwg dm9pZCAqc2JtdF9kYXRhLAorCQkJCSAgIHNlZF9zZWNfc3VibWl0ICpzdWJtaXRfZm4pCit7CisJ dm9pZCAqZnVuY19kYXRhWzZdID0geyBOVUxMIH07CisJc3RydWN0IG9wYWxfZGV2ICpkZXY7CisJ Y29uc3Qgb3BhbF9zdGVwIG1icl9mdW5jc1tdID0geworCQlvcGFsX2Rpc2NvdmVyeTAsCisJCXN0 YXJ0X2FkbWluMUxTUF9vcGFsX3Nlc3Npb24sCisJCXNldF9tYnJfZG9uZSwKKwkJZW5kX29wYWxf c2Vzc2lvbiwKKwkJc3RhcnRfYWRtaW4xTFNQX29wYWxfc2Vzc2lvbiwKKwkJc2V0X21icl9lbmFi bGVfZGlzYWJsZSwKKwkJZW5kX29wYWxfc2Vzc2lvbiwKKwkJTlVMTCwKKwl9OworCWludCByZXQ7 CisKKwlpZiAoa2V5LT5vcGFsX21ici5lbmFibGVfZGlzYWJsZSAhPSBPUEFMX01CUl9FTkFCTEUg JiYKKwkgICAga2V5LT5vcGFsX21ici5lbmFibGVfZGlzYWJsZSAhPSBPUEFMX01CUl9ESVNBQkxF KQorCQlyZXR1cm4gLUVJTlZBTDsKKworCWRldiA9IGdldF9vcl9jcmVhdGVfb3BhbF9kZXYoYmRl diwga2V5LT5vcGFsX21ici5rZXkubHIsIHRydWUpOworCWlmICghZGV2KQorCQlyZXR1cm4gLUVO T01FTTsKKworCXJldCA9IHNldHVwX29wYWxfZGV2KGJkZXYsIGRldiwgbWJyX2Z1bmNzLCAma2V5 LT5vcGFsX21ici5rZXksCisJCQkgICAgIHNibXRfZGF0YSwgc3VibWl0X2ZuKTsKKwlpZiAocmV0 KQorCQlnb3RvIGVycm9yX3JldHVybjsKKworCWRldi0+bnVtX2Z1bmNfZGF0YSA9IDY7CisJZGV2 LT5mdW5jX2RhdGEgPSBmdW5jX2RhdGE7CisJZGV2LT5mdW5jX2RhdGFbMl0gPSAma2V5LT5vcGFs X21ici5lbmFibGVfZGlzYWJsZTsKKwlkZXYtPmZ1bmNfZGF0YVs1XSA9ICZrZXktPm9wYWxfbWJy LmVuYWJsZV9kaXNhYmxlOworCisJcmV0ID0gbmV4dChkZXYpOworCisgZXJyb3JfcmV0dXJuOgor CXJlbW92ZV9hbmRfY2xlYW5fb3BhbF9kZXYoZGV2KTsKKwlyZXR1cm4gcmV0OworCit9CitFWFBP UlRfU1lNQk9MKG9wYWxfZW5hYmxlX2Rpc2FibGVfc2hhZG93X21icik7CisKK2ludCBvcGFsX3Nh dmUoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3RydWN0IHNlZF9rZXkgKmtleSwKKwkgICAg ICB2b2lkICpzYm10X2RhdGEsIHNlZF9zZWNfc3VibWl0ICpzdWJtaXRfZm4pCit7CisJdm9pZCAq ZnVuY19kYXRhWzNdID0geyBOVUxMIH07CisJc3RydWN0IG9wYWxfZGV2ICpkZXY7CisJCWNvbnN0 IG9wYWxfc3RlcCBfYXV0aF9mdW5jc1tdID0geworCQlvcGFsX2Rpc2NvdmVyeTAsCisJCXN0YXJ0 X2F1dGhfb3BhbF9zZXNzaW9uLAorCQlxdWVyeV9sb2NraW5nX3JhbmdlLAorCQllbmRfb3BhbF9z ZXNzaW9uLAorCQlvcGFsX3JlZ2lzdGVyX2NvbnQsCisJCU5VTEwKKwl9OworCWludCByZXQ7CisK KwlkZXYgPSBnZXRfb3JfY3JlYXRlX29wYWxfZGV2KGJkZXYsIGtleS0+b3BhbF9sa191bmxrLmtl eS5sciwgZmFsc2UpOworCWlmICghZGV2KQorCQlyZXR1cm4gLUVOT01FTTsKKwlyZXQgPSBzZXR1 cF9vcGFsX2RldihiZGV2LCBkZXYsIF9hdXRoX2Z1bmNzLCAma2V5LT5vcGFsX2xrX3VubGsua2V5 LAorCQkJICAgICBzYm10X2RhdGEsIHN1Ym1pdF9mbik7CisJaWYgKHJldCkKKwkJZ290byBlcnJv cl9yZXR1cm47CisKKwlkZXYtPm51bV9mdW5jX2RhdGEgPSAzOworCWRldi0+ZnVuY19kYXRhID0g ZnVuY19kYXRhOworCWRldi0+ZnVuY19kYXRhWzFdID0gJmtleS0+b3BhbF9sa191bmxrLmF1dGhv cml0eTsKKwlkZXYtPmxrdWwgPSBrZXktPm9wYWxfbGtfdW5sazsKKworCXJldCA9IG5leHQoZGV2 KTsKKworIGVycm9yX3JldHVybjoKKwlyZW1vdmVfYW5kX2NsZWFuX29wYWxfZGV2KGRldik7CisJ cmV0dXJuIHJldDsKK30KK0VYUE9SVF9TWU1CT0wob3BhbF9zYXZlKTsKKworaW50IG9wYWxfYWRk X3VzZXJfdG9fbHIoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3RydWN0IHNlZF9rZXkgKmtl eSwKKwkJCXZvaWQgKnNibXRfZGF0YSwgc2VkX3NlY19zdWJtaXQgKnN1Ym1pdF9mbikKK3sKKwl2 b2lkICpmdW5jX2RhdGFbM10gPSB7IE5VTEwgfTsKKwlzdHJ1Y3Qgb3BhbF9kZXYgKmRldjsKKwkJ Y29uc3Qgb3BhbF9zdGVwIGZ1bmNzW10gPSB7CisJCW9wYWxfZGlzY292ZXJ5MCwKKwkJc3RhcnRf YWRtaW4xTFNQX29wYWxfc2Vzc2lvbiwKKwkJYWRkX3VzZXJfdG9fbHIsCisJCWVuZF9vcGFsX3Nl c3Npb24sCisJCU5VTEwKKwl9OworCWludCByZXQ7CisKKwlpZiAoIWJkZXYgfHwgIWJkZXYtPmJk X2Rpc2spIHsKKwkJcHJfZXJyKCJDYW4ndCBhc3NpZ24gdXNlciB0byBMUiB3aXRob3V0IGJhY2tp bmcgZGlza1xuIik7CisJCXJldHVybiAtRUZBVUxUOworCX0KKwlpZiAoa2V5LT5vcGFsX2xrX3Vu bGsubF9zdGF0ZSAhPSBPUEFMX1JPICYmCisJICAgIGtleS0+b3BhbF9sa191bmxrLmxfc3RhdGUg IT0gT1BBTF9SVykgeworCQlwcl9lcnIoIkxvY2tpbmcgc3RhdGUgd2FzIG5vdCBSTyBvciBSV1xu Iik7CisJCXJldHVybiAtRUlOVkFMOworCX0KKwlpZiAoa2V5LT5vcGFsX2xrX3VubGsuYXV0aG9y aXR5LndobyA8IE9QQUxfVVNFUjEgJiYKKwkgICAga2V5LT5vcGFsX2xrX3VubGsuYXV0aG9yaXR5 LndobyA+IE9QQUxfVVNFUjkpIHsKKwkJcHJfZXJyKCJBdXRob3JpdHkgd2FzIG5vdCB3aXRoaW4g dGhlIHJhbmdlIG9mIHVzZXJzOiAlZFxuIiwKKwkJICAgICAgIGtleS0+b3BhbF9sa191bmxrLmF1 dGhvcml0eS53aG8pOworCQlyZXR1cm4gLUVJTlZBTDsKKwl9CisJaWYgKGtleS0+b3BhbF9sa191 bmxrLmF1dGhvcml0eS5TVU0pIHsKKwkJcHJfZXJyKCIlcyBub3Qgc3VwcG9ydGVkIGluIFNVTS4g VXNlIHNldHVwIGxvY2tpbmcgcmFuZ2VcbiIsCisJCSAgICAgICBfX2Z1bmNfXyk7CisJCXJldHVy biAtRUlOVkFMOworCX0KKworCWRldiA9IGdldF9vcl9jcmVhdGVfb3BhbF9kZXYoYmRldiwga2V5 LT5vcGFsX2xrX3VubGsua2V5LmxyLCB0cnVlKTsKKwlpZiAoIWRldikKKwkJcmV0dXJuIC1FTk9N RU07CisJcmV0ID0gc2V0dXBfb3BhbF9kZXYoYmRldiwgZGV2LCBmdW5jcywgJmtleS0+b3BhbF9s a191bmxrLmtleSwKKwkJCQkgICAgc2JtdF9kYXRhLCBzdWJtaXRfZm4pOworCWlmIChyZXQpCisJ CWdvdG8gZXJyb3JfcmV0dXJuOworCisJZGV2LT5udW1fZnVuY19kYXRhID0gMzsKKwlkZXYtPmZ1 bmNfZGF0YSA9IGZ1bmNfZGF0YTsKKwlkZXYtPmZ1bmNfZGF0YVsyXSA9ICZrZXktPm9wYWxfbGtf dW5sazsKKworCXJldCA9IG5leHQoZGV2KTsKKworIGVycm9yX3JldHVybjoKKwlyZW1vdmVfYW5k X2NsZWFuX29wYWxfZGV2KGRldik7CisJcmV0dXJuIHJldDsKKworfQorRVhQT1JUX1NZTUJPTChv cGFsX2FkZF91c2VyX3RvX2xyKTsKKworaW50IG9wYWxfcmV2ZXJ0dHBlcihzdHJ1Y3QgYmxvY2tf ZGV2aWNlICpiZGV2LCBzdHJ1Y3Qgc2VkX2tleSAqa2V5LAorCQkgICAgdm9pZCAqc2JtdF9kYXRh LCBzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2ZuKQoreworCWNvbnN0IG9wYWxfc3RlcCByZXZlcnRf ZnVuY3NbXSA9IHsKKwkJb3BhbF9kaXNjb3ZlcnkwLAorCQlzdGFydF9TSURBU1Bfb3BhbF9zZXNz aW9uLAorCQlyZXZlcnRfdHBlciwgLyogY29udHJvbGxlciB3aWxsIHRlcm1pbmF0ZSBzZXNzaW9u ICovCisJCU5VTEwsCisJfTsKKworCXJldHVybiBvcGFsX3JlZ2lzdGVyKGJkZXYsICZrZXktPm9w YWwsIHJldmVydF9mdW5jcywKKwkJCSAgICAgc2JtdF9kYXRhLCBzdWJtaXRfZm4pOworfQorRVhQ T1JUX1NZTUJPTChvcGFsX3JldmVydHRwZXIpOworCisvKiBUaGVzZSBhcmUgZ2xvYmFsJ2QgYmVj YXVzZSBib3RoIGxvY2tfdW5sb2NrX2ludGVybmFsCisgKiBhbmQgb3BhbF91bmxvY2tfZnJvbV9z dXNwZW5kIG5lZWQgdGhlbS4KKyAqLworY29uc3Qgb3BhbF9zdGVwIHVsa19mdW5jc19TVU1bXSA9 IHsKKwlvcGFsX2Rpc2NvdmVyeTAsCisJc3RhcnRfYXV0aF9vcGFsX3Nlc3Npb24sCisJbG9ja191 bmxvY2tfbG9ja2luZ19yYW5nZV9TVU0sCisJZW5kX29wYWxfc2Vzc2lvbiwKKwlOVUxMCit9Owor Y29uc3Qgb3BhbF9zdGVwIF91bmxvY2tfZnVuY3NbXSA9IHsKKwlvcGFsX2Rpc2NvdmVyeTAsCisJ c3RhcnRfYXV0aF9vcGFsX3Nlc3Npb24sCisJbG9ja191bmxvY2tfbG9ja2luZ19yYW5nZSwKKwll bmRfb3BhbF9zZXNzaW9uLAorCU5VTEwKK307CitpbnQgb3BhbF9sb2NrX3VubG9jayhzdHJ1Y3Qg YmxvY2tfZGV2aWNlICpiZGV2LCBzdHJ1Y3Qgc2VkX2tleSAqa2V5LAorICAgICAgICAgICAgICAg ICAgICAgdm9pZCAqc2JtdF9kYXRhLCBzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2ZuKQoreworCXZv aWQgKmZ1bmNfZGF0YVszXSA9IHsgTlVMTCB9OworCXN0cnVjdCBvcGFsX2RldiAqZGV2OworCWlu dCByZXQ7CisKKwlpZiAoa2V5LT5vcGFsX2xrX3VubGsuYXV0aG9yaXR5LndobyA8IE9QQUxfQURN SU4xIHx8CisJICAgIGtleS0+b3BhbF9sa191bmxrLmF1dGhvcml0eS53aG8gPiBPUEFMX1VTRVI5 KQorCQlyZXR1cm4gLUVJTlZBTDsKKworCWRldiA9IGdldF9vcl9jcmVhdGVfb3BhbF9kZXYoYmRl diwga2V5LT5vcGFsX2xrX3VubGsua2V5LmxyLCB0cnVlKTsKKwlpZiAoIWRldikKKwkJcmV0dXJu IC1FTk9NRU07CisKKwlpZiAoa2V5LT5vcGFsX2xrX3VubGsuYXV0aG9yaXR5LlNVTSkKKwkJcmV0 ID0gc2V0dXBfb3BhbF9kZXYoYmRldiwgZGV2LCB1bGtfZnVuY3NfU1VNLAorCQkJCSAgICAgJmtl eS0+b3BhbF9sa191bmxrLmtleSwKKwkJCQkgICAgIHNibXRfZGF0YSwgc3VibWl0X2ZuKTsKKwll bHNlCisJCXJldCA9IHNldHVwX29wYWxfZGV2KGJkZXYsIGRldiwgX3VubG9ja19mdW5jcywKKwkJ CQkgICAgICZrZXktPm9wYWxfbGtfdW5say5rZXksCisJCQkJICAgICBzYm10X2RhdGEsIHN1Ym1p dF9mbik7CisJaWYgKHJldCkKKwkJZ290byBlcnJvcl9yZXR1cm47CisKKwlkZXYtPm51bV9mdW5j X2RhdGEgPSAzOworCWRldi0+ZnVuY19kYXRhID0gZnVuY19kYXRhOworCWRldi0+ZnVuY19kYXRh WzFdID0gJmtleS0+b3BhbF9sa191bmxrLmF1dGhvcml0eTsKKwlkZXYtPmZ1bmNfZGF0YVsyXSA9 ICZrZXktPm9wYWxfbGtfdW5sazsKKworCXJldCA9IG5leHQoZGV2KTsKKworIGVycm9yX3JldHVy bjoKKwlyZW1vdmVfYW5kX2NsZWFuX29wYWxfZGV2KGRldik7CisJcmV0dXJuIHJldDsKK30KK0VY UE9SVF9TWU1CT0wob3BhbF9sb2NrX3VubG9jayk7CisKK2ludCBvcGFsX3Rha2Vfb3duZXJzaGlw KHN0cnVjdCBibG9ja19kZXZpY2UgKmJkZXYsIHN0cnVjdCBzZWRfa2V5ICprZXksCisJCQl2b2lk ICpzYm10X2RhdGEsIHNlZF9zZWNfc3VibWl0ICpzdWJtaXRfZm4pCit7CisJY29uc3Qgb3BhbF9z dGVwIG93bmVyX2Z1bmNzW10gPSB7CisJCW9wYWxfZGlzY292ZXJ5MCwKKwkJc3RhcnRfYW55Ym9k eUFTUF9vcGFsX3Nlc3Npb24sCisJCWdldF9tc2lkX2NwaW5fcGluLAorCQllbmRfb3BhbF9zZXNz aW9uLAorCQlzdGFydF9TSURBU1Bfb3BhbF9zZXNzaW9uLAorCQlzZXRfc2lkX2NwaW5fcGluLAor CQllbmRfb3BhbF9zZXNzaW9uLAorCQlOVUxMCisJfTsKKworCXJldHVybiBvcGFsX3JlZ2lzdGVy KGJkZXYsICZrZXktPm9wYWwsIG93bmVyX2Z1bmNzLCBzYm10X2RhdGEsCisJCQkgICAgIHN1Ym1p dF9mbik7Cit9CitFWFBPUlRfU1lNQk9MKG9wYWxfdGFrZV9vd25lcnNoaXApOworCitpbnQgb3Bh bF9hY3RpdmF0ZV9sc3Aoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3RydWN0IHNlZF9rZXkg KmtleSwKKwkJICAgICAgdm9pZCAqc2JtdF9kYXRhLCBzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2Zu KQoreworCWNvbnN0IG9wYWxfc3RlcCBhY3RpdmVfZnVuY3NbXSA9IHsKKwkJb3BhbF9kaXNjb3Zl cnkwLAorCQlzdGFydF9TSURBU1Bfb3BhbF9zZXNzaW9uLCAvKiBPcGVuIHNlc3Npb24gYXMgU0lE IGF1dGggKi8KKwkJZ2V0X2xzcF9saWZlY3ljbGUsCisJCWFjdGl2YXRlX2xzcCwKKwkJZW5kX29w YWxfc2Vzc2lvbiwKKwkJTlVMTAorCX07CisJc3RydWN0IG9wYWxfZGV2ICpkZXY7CisJaW50IHJl dDsKKworCWRldiA9IGdldF9vcl9jcmVhdGVfb3BhbF9kZXYoYmRldiwga2V5LT5vcGFsLmxyLCB0 cnVlKTsKKwlpZiAoIWRldikKKwkJcmV0dXJuIC1FTk9NRU07CisJcmV0ID0gc2V0dXBfb3BhbF9k ZXYoYmRldiwgZGV2LCBhY3RpdmVfZnVuY3MsICZrZXktPm9wYWwsCisJCQkgICAgIHNibXRfZGF0 YSwgc3VibWl0X2ZuKTsKKwlpZiAocmV0KQorCQlnb3RvIGVycm9yX3JldHVybjsKKworCXJldCA9 IG5leHQoZGV2KTsKKworIGVycm9yX3JldHVybjoKKwlyZW1vdmVfYW5kX2NsZWFuX29wYWxfZGV2 KGRldik7CisJcmV0dXJuIHJldDsKK30KK0VYUE9SVF9TWU1CT0wob3BhbF9hY3RpdmF0ZV9sc3Ap OworCitpbnQgb3BhbF9zZXR1cF9sb2NraW5nX3JhbmdlKHN0cnVjdCBibG9ja19kZXZpY2UgKmJk ZXYsIHN0cnVjdCBzZWRfa2V5ICpwdywKKwkJCSAgICAgdm9pZCAqc2JtdF9kYXRhLCBzZWRfc2Vj X3N1Ym1pdCAqc3VibWl0X2ZuKQoreworCXN0cnVjdCBvcGFsX2RldiAqZGV2OworCXZvaWQgKmRh dGFbM10gPSB7IE5VTEwgfTsKKwljb25zdCBvcGFsX3N0ZXAgbHJfZnVuY3NbXSA9IHsKKwkJb3Bh bF9kaXNjb3ZlcnkwLAorCQlzdGFydF9hdXRoX29wYWxfc2Vzc2lvbiwKKwkJc2V0dXBfbG9ja2lu Z19yYW5nZSwKKwkJZW5kX29wYWxfc2Vzc2lvbiwKKwkJTlVMTCwKKwl9OworCWludCByZXQ7CisK KwlkZXYgPSBnZXRfb3JfY3JlYXRlX29wYWxfZGV2KGJkZXYsIHB3LT5vcGFsX2xycy5rZXkubHIs IHRydWUpOworCWlmICghZGV2KQorCQlyZXR1cm4gLUVOT01FTTsKKworCXJldCA9IHNldHVwX29w YWxfZGV2KGJkZXYsIGRldiwgbHJfZnVuY3MsICZwdy0+b3BhbF9scnMua2V5LAorCQkJICAgICBz Ym10X2RhdGEsIHN1Ym1pdF9mbik7CisJaWYgKHJldCkKKwkJZ290byBlcnJvcl9yZXR1cm47CisK KwlkZXYtPmZ1bmNfZGF0YSA9IGRhdGE7CisJZGV2LT5udW1fZnVuY19kYXRhID0gMzsKKwlkZXYt PmZ1bmNfZGF0YVsxXSA9ICZwdy0+b3BhbF9scnMud2hvOworCWRldi0+ZnVuY19kYXRhWzJdID0g JnB3LT5vcGFsX2xyczsKKworCXJldCA9IG5leHQoZGV2KTsKKworIGVycm9yX3JldHVybjoKKwly ZW1vdmVfYW5kX2NsZWFuX29wYWxfZGV2KGRldik7CisJcmV0dXJuIHJldDsKK30KK0VYUE9SVF9T WU1CT0wob3BhbF9zZXR1cF9sb2NraW5nX3JhbmdlKTsKKworaW50IG9wYWxfc2V0X25ld19wdyhz dHJ1Y3QgYmxvY2tfZGV2aWNlICpiZGV2LCBzdHJ1Y3Qgc2VkX2tleSAqcHcsCisJCSAgICB2b2lk ICpzYm10X2RhdGEsIHNlZF9zZWNfc3VibWl0ICpzdWJtaXRfZm4pCit7CisJY29uc3Qgb3BhbF9z dGVwIHB3X2Z1bmNzW10gPSB7CisJCW9wYWxfZGlzY292ZXJ5MCwKKwkJc3RhcnRfYXV0aF9vcGFs X3Nlc3Npb24sCisJCXNldF9uZXdfcHcsCisJCWVuZF9vcGFsX3Nlc3Npb24sCisJCU5VTEwKKwl9 OworCXN0cnVjdCBvcGFsX2RldiAqZGV2OworCXZvaWQgKmRhdGFbM10gPSB7IE5VTEwgfTsKKwlp bnQgcmV0OworCisJaWYgKHB3LT5zZWRfdHlwZSAhPSBPUEFMX1BXKQorCQlyZXR1cm4gLUVJTlZB TDsKKworCWlmIChwdy0+b3BhbF9wdy53aG8ud2hvIDwgT1BBTF9BRE1JTjEgfHwKKwkgICAgcHct Pm9wYWxfcHcud2hvLndobyA+IE9QQUxfVVNFUjkpCisJCXJldHVybiAtRUlOVkFMOworCisJZGV2 ID0gZ2V0X29yX2NyZWF0ZV9vcGFsX2RldihiZGV2LCBwdy0+b3BhbF9wdy5jdXJyZW50X3Bpbi5s ciwgdHJ1ZSk7CisJaWYgKCFkZXYpCisJCXJldHVybiAtRU5PTUVNOworCisJcmV0ID0gc2V0dXBf b3BhbF9kZXYoYmRldiwgZGV2LCBwd19mdW5jcywKKwkJCSAgICAgJnB3LT5vcGFsX3B3LmN1cnJl bnRfcGluLAorCQkJICAgICBzYm10X2RhdGEsIHN1Ym1pdF9mbik7CisJaWYgKHJldCkKKwkJZ290 byBlcnJvcl9yZXR1cm47CisKKwlkZXYtPm51bV9mdW5jX2RhdGEgPSAzOworCWRldi0+ZnVuY19k YXRhID0gZGF0YTsKKwlkZXYtPmZ1bmNfZGF0YVsxXSA9ICh2b2lkICopICZwdy0+b3BhbF9wdy53 aG87CisJZGV2LT5mdW5jX2RhdGFbMl0gPSAodm9pZCAqKSAmcHctPm9wYWxfcHc7CisKKwlyZXQg PSBuZXh0KGRldik7CisKKyBlcnJvcl9yZXR1cm46CisJcmVtb3ZlX2FuZF9jbGVhbl9vcGFsX2Rl dihkZXYpOworCXJldHVybiByZXQ7Cit9CitFWFBPUlRfU1lNQk9MKG9wYWxfc2V0X25ld19wdyk7 CisKK2ludCBvcGFsX2FjdGl2YXRlX3VzZXIoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3Ry dWN0IHNlZF9rZXkgKnB3LAorCQkgICAgICAgdm9pZCAqc2JtdF9kYXRhLCBzZWRfc2VjX3N1Ym1p dCAqc3VibWl0X2ZuKQoreworCWNvbnN0IG9wYWxfc3RlcCBhY3RfZnVuY3NbXSA9IHsKKwkJb3Bh bF9kaXNjb3ZlcnkwLAorCQlzdGFydF9hZG1pbjFMU1Bfb3BhbF9zZXNzaW9uLAorCQlpbnRlcm5h bF9hY3RpdmF0ZV91c2VyLAorCQllbmRfb3BhbF9zZXNzaW9uLAorCQlOVUxMCisJfTsKKwlzdHJ1 Y3Qgb3BhbF9kZXYgKmRldjsKKwl2b2lkICpkYXRhWzNdID0geyBOVUxMIH07CisJaW50IHJldDsK KworCWlmIChwdy0+c2VkX3R5cGUgIT0gT1BBTF9BQ1RfVVNSKSB7CisJCXByX2VycigiU2VkIHR5 cGUgd2FzIG5vdCBhY3QgdXNlclxuIik7CisJCXJldHVybiAtRUlOVkFMOworCX0KKworCS8qIFdl IGNhbid0IGFjdGl2YXRlIEFkbWluMSBpdCdzIGFjdGl2ZSBhcyBtYW51ZmFjdHVyZWQgKi8KKwlp ZiAocHctPm9wYWxfYWN0Lndoby53aG8gPCBPUEFMX1VTRVIxICYmCisJICAgIHB3LT5vcGFsX2Fj dC53aG8ud2hvID4gT1BBTF9VU0VSOSkgeworCQlwcl9lcnIoIldobyB3YXMgbm90IGEgdmFsaWQg dXNlcjogJWQgXG4iLCBwdy0+b3BhbF9hY3Qud2hvLndobyk7CisJCXJldHVybiAtRUlOVkFMOwor CX0KKworCWRldiA9IGdldF9vcl9jcmVhdGVfb3BhbF9kZXYoYmRldiwgcHctPm9wYWxfYWN0Lmtl eS5sciwgdHJ1ZSk7CisJaWYgKCFkZXYpCisJCXJldHVybiAtRU5PTUVNOworCisJcmV0ID0gc2V0 dXBfb3BhbF9kZXYoYmRldiwgZGV2LCBhY3RfZnVuY3MsICZwdy0+b3BhbF9hY3Qua2V5LAorCQkJ ICAgICBzYm10X2RhdGEsIHN1Ym1pdF9mbik7CisJaWYgKHJldCkKKwkJZ290byBlcnJvcl9yZXR1 cm47CisKKwlkZXYtPm51bV9mdW5jX2RhdGEgPSAzOworCWRldi0+ZnVuY19kYXRhID0gZGF0YTsK KwlkZXYtPmZ1bmNfZGF0YVsxXSA9ICZwdy0+b3BhbF9hY3Q7CisJZGV2LT5mdW5jX2RhdGFbMl0g PSAmcHctPm9wYWxfYWN0OworCisJcmV0ID0gbmV4dChkZXYpOworCisgZXJyb3JfcmV0dXJuOgor CXJlbW92ZV9hbmRfY2xlYW5fb3BhbF9kZXYoZGV2KTsKKwlyZXR1cm4gcmV0OworCit9CitFWFBP UlRfU1lNQk9MKG9wYWxfYWN0aXZhdGVfdXNlcik7CisKK2ludCBvcGFsX3VubG9ja19mcm9tX3N1 c3BlbmQoc3RydWN0IG9wYWxfc3VzcGVuZF91bmxrICpkYXRhKQoreworCWludCBtYWptaW4gPSBk YXRhLT5kZXY7CisJc3RydWN0IG9wYWxfZGV2ICppdGVyLCAqZGV2ID0gTlVMTDsKKwl2b2lkICpm dW5jX2RhdGFbM10gPSB7IE5VTEwgfTsKKwl1OCBjb3VudCA9IDA7CisJc3RydWN0IG9wYWxfZGV2 ICp0b2RvWzY0XSA9IHsgTlVMTCB9OworCWludCByZXQgPSAwOworCWJvb2wgd2FzX2ZhaWx1cmUg PSBmYWxzZTsKKworCXNwaW5fbG9jaygmbGlzdF9zcGlubG9jayk7CisJbGlzdF9mb3JfZWFjaF9l bnRyeShpdGVyLCAmb3BhbF9saXN0LCBub2RlKSB7CisJCWlmIChNQUpPUihpdGVyLT5tYWptaW4p ICE9IE1BSk9SKG1ham1pbikgfHwKKwkJICAgIE1JTk9SKGl0ZXItPm1ham1pbikgIT0gTUlOT1Io bWFqbWluKSkKKwkJCWNvbnRpbnVlOworCisJCWlmIChhdG9taWNfYWRkX3VubGVzcygmaXRlci0+ aW5fdXNlLCAxLCAxKSkgeworCQkJaWYgKGNvdW50IDwgNjQpCisJCQkJdG9kb1tjb3VudCsrXSA9 IGl0ZXI7CisJCQllbHNlCisJCQkJYnJlYWs7CisJCX0KKwl9CisJc3Bpbl91bmxvY2soJmxpc3Rf c3BpbmxvY2spOworCisJd2hpbGUgKGNvdW50KSB7CisJCWRldiA9IHRvZG9bLS1jb3VudF07CisJ CWRldi0+ZnVuY19kYXRhID0gZnVuY19kYXRhOworCQlkZXYtPnJlc3VtZV9mcm9tX3N1c3BlbmQg PSB0cnVlOworCQlkZXYtPnJlc3VtZV9kYXRhID0gZGF0YTsKKwkJZGV2LT5lcnJvcl9jYiA9IGVu ZF9vcGFsX3Nlc3Npb25fZXJyb3I7CisJCWRldi0+ZXJyb3JfY2JfZGF0YSA9IGRldjsKKwkJZGV2 LT5zdGF0ZSA9IDA7CisJCWlmIChkZXYtPmxrdWwuYXV0aG9yaXR5LlNVTSkKKwkJCWRldi0+ZnVu Y3MgPSB1bGtfZnVuY3NfU1VNOworCQllbHNlCisJCQlkZXYtPmZ1bmNzID0gX3VubG9ja19mdW5j czsKKwkJZGV2LT5UU04gPSAwOworCQlkZXYtPkhTTiA9IDA7CisJCWRldi0+ZnVuY19kYXRhWzJd ID0gJmRldi0+bGt1bDsKKwkJZGV2LT5mdW5jX2RhdGFbMV0gPSAmZGV2LT5sa3VsLmF1dGhvcml0 eTsKKwkJcmV0ID0gbmV4dChkZXYpOworCQlpZiAocmV0KQorCQkJd2FzX2ZhaWx1cmUgPSB0cnVl OworCQl1bmxvY2tfc3VzcGVuZF9maW5hbChkZXYpOworCX0KKwlyZXR1cm4gd2FzX2ZhaWx1cmUg PyAxIDogMDsKK30KK0VYUE9SVF9TWU1CT0wob3BhbF91bmxvY2tfZnJvbV9zdXNwZW5kKTsKZGlm ZiAtLWdpdCBhL2Jsb2NrL3NlZC1vcGFsX2ludGVybmFsLmggYi9ibG9jay9zZWQtb3BhbF9pbnRl cm5hbC5oCm5ldyBmaWxlIG1vZGUgMTAwNjQ0CmluZGV4IDAwMDAwMDAuLjEyMzY5ZWIKLS0tIC9k ZXYvbnVsbAorKysgYi9ibG9jay9zZWQtb3BhbF9pbnRlcm5hbC5oCkBAIC0wLDAgKzEsNjAxIEBA CisvKgorICogQ29weXJpZ2h0IMKpIDIwMTYgSW50ZWwgQ29ycG9yYXRpb24KKyAqCisgKiBBdXRo b3JzOgorICogICAgUmFmYWVsIEFudG9nbm9sbGkgPHJhZmFlbC5hbnRvZ25vbGxpQGludGVsLmNv bT4KKyAqICAgIFNjb3R0ICBCYXVlciAgICAgIDxzY290dC5iYXVlckBpbnRlbC5jb20+CisgKgor ICogVGhpcyBwcm9ncmFtIGlzIGZyZWUgc29mdHdhcmU7IHlvdSBjYW4gcmVkaXN0cmlidXRlIGl0 IGFuZC9vciBtb2RpZnkgaXQKKyAqIHVuZGVyIHRoZSB0ZXJtcyBhbmQgY29uZGl0aW9ucyBvZiB0 aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UsCisgKiB2ZXJzaW9uIDIsIGFzIHB1Ymxpc2hl ZCBieSB0aGUgRnJlZSBTb2Z0d2FyZSBGb3VuZGF0aW9uLgorICoKKyAqIFRoaXMgcHJvZ3JhbSBp cyBkaXN0cmlidXRlZCBpbiB0aGUgaG9wZSBpdCB3aWxsIGJlIHVzZWZ1bCwgYnV0IFdJVEhPVVQK KyAqIEFOWSBXQVJSQU5UWTsgd2l0aG91dCBldmVuIHRoZSBpbXBsaWVkIHdhcnJhbnR5IG9mIE1F UkNIQU5UQUJJTElUWSBvcgorICogRklUTkVTUyBGT1IgQSBQQVJUSUNVTEFSIFBVUlBPU0UuICBT ZWUgdGhlIEdOVSBHZW5lcmFsIFB1YmxpYyBMaWNlbnNlIGZvcgorICogbW9yZSBkZXRhaWxzLgor ICovCisKKyNpZm5kZWYgX05WTUVfT1BBTF9JTlRFUk5BTF9ICisjZGVmaW5lIF9OVk1FX09QQUxf SU5URVJOQUxfSAorCisjaW5jbHVkZSA8bGludXgva2V5LXR5cGUuaD4KKyNpbmNsdWRlIDxrZXlz L3VzZXItdHlwZS5oPgorCisjZGVmaW5lIERUQUVSUk9SX05PX01FVEhPRF9TVEFUVVMgMHg4OQor I2RlZmluZSBHRU5FUklDX0hPU1RfU0VTU0lPTl9OVU0gMHg0MQorCisKKworLyoKKyAqIERlcml2 ZWQgZnJvbToKKyAqIFRDR19TdG9yYWdlX0FyY2hpdGVjdHVyZV9Db3JlX1NwZWNfdjIuMDFfcjEu MDAKKyAqIFNlY3Rpb246IDUuMS41IE1ldGhvZCBTdGF0dXMgQ29kZXMKKyAqLworc3RhdGljIGNv bnN0IGNoYXIgKm9wYWxfZXJyb3JzW10gPSB7CisJIlN1Y2Nlc3MiLAorCSJOb3QgQXV0aG9yaXpl ZCIsCisJIlVua25vd24gRXJyb3IiLAorCSJTUCBCdXN5IiwKKwkiU1AgRmFpbGVkIiwKKwkiU1Ag RGlzYWJsZWQiLAorCSJTUCBGcm96ZW4iLAorCSJObyBTZXNzaW9ucyBBdmFpbGFibGUiLAorCSJV bmlxdWVuZXNzIENvbmZsaWN0IiwKKwkiSW5zdWZmaWNpZW50IFNwYWNlIiwKKwkiSW5zdWZmaWNp ZW50IFJvd3MiLAorCSJJbnZhbGlkIEZ1bmN0aW9uIiwKKwkiSW52YWxpZCBQYXJhbWV0ZXIiLAor CSJJbnZhbGlkIFJlZmVyZW5jZSIsCisJIlVua25vd24gRXJyb3IiLAorCSJUUEVSIE1hbGZ1bmN0 aW9uIiwKKwkiVHJhbnNhY3Rpb24gRmFpbHVyZSIsCisJIlJlc3BvbnNlIE92ZXJmbG93IiwKKwki QXV0aG9yaXR5IExvY2tlZCBPdXQiLAorfTsKKworc3RhdGljIGNvbnN0IGNoYXIgKm9wYWxfZXJy b3JfdG9faHVtYW4oaW50IGVycm9yKQoreworCWlmIChlcnJvciA9PSAweDNmKQorCQlyZXR1cm4g IkZhaWxlZCI7CisKKwlpZiAoZXJyb3IgPj0gQVJSQVlfU0laRShvcGFsX2Vycm9ycykgfHwgZXJy b3IgPCAwKQorCQlyZXR1cm4gIlVua25vd24gRXJyb3IiOworCisJcmV0dXJuIG9wYWxfZXJyb3Jz W2Vycm9yXTsKK30KKworLyoKKyAqIFVzZXIgSURzIHVzZWQgaW4gdGhlIFRDRyBzdG9yYWdlIFNT Q3MKKyAqIERlcml2ZWQgZnJvbTogVENHX1N0b3JhZ2VfQXJjaGl0ZWN0dXJlX0NvcmVfU3BlY192 Mi4wMV9yMS4wMAorICogU2VjdGlvbjogNi4zIEFzc2lnbmVkIFVJRHMKKyAqLworc3RhdGljIGNv bnN0IHU4IE9QQUxVSURbXVs4XSA9IHsKKwkvKiB1c2VycyAqLworCisJLyogc2Vzc2lvbiBtYW5h Z2VtZW50ICAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwg MHhmZn0sCisJLyogc3BlY2lhbCAidGhpc1NQIiBzeW50YXggKi8KKwl7IDB4MDAsIDB4MDAsIDB4 MDAsIDB4MDAsIDB4MDAsIDB4MDAsIDB4MDAsIDB4MDEgfSwKKwkvKiBBZG1pbmlzdHJhdGl2ZSBT UCAqLworCXsgMHgwMCwgMHgwMCwgMHgwMiwgMHgwNSwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMSB9 LAorCS8qIExvY2tpbmcgU1AgKi8KKwl7IDB4MDAsIDB4MDAsIDB4MDIsIDB4MDUsIDB4MDAsIDB4 MDAsIDB4MDAsIDB4MDIgfSwKKwkvKiBFTlRFUlBSSVNFIExvY2tpbmcgU1AgICovCisJeyAweDAw LCAweDAwLCAweDAyLCAweDA1LCAweDAwLCAweDAxLCAweDAwLCAweDAxIH0sCisJLyogYW55Ym9k eSAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwOSwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMSB9 LAorCS8qIFNJRCAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwOSwgMHgwMCwgMHgwMCwgMHgw MCwgMHgwNiB9LAorCS8qIEFETUlOMSAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwOSwgMHgw MCwgMHgwMSwgMHgwMCwgMHgwMSB9LAorCS8qIFVTRVIxICovCisJeyAweDAwLCAweDAwLCAweDAw LCAweDA5LCAweDAwLCAweDAzLCAweDAwLCAweDAxIH0sCisJLyogVVNFUjIgKi8KKwl7IDB4MDAs IDB4MDAsIDB4MDAsIDB4MDksIDB4MDAsIDB4MDMsIDB4MDAsIDB4MDIgfSwKKwkvKiBQU0lEIHVz ZXIgKi8KKwl7IDB4MDAsIDB4MDAsIDB4MDAsIDB4MDksIDB4MDAsIDB4MDEsIDB4ZmYsIDB4MDEg fSwKKwkvKiBCYW5kTWFzdGVyIDAgKi8KKwl7IDB4MDAsIDB4MDAsIDB4MDAsIDB4MDksIDB4MDAs IDB4MDAsIDB4ODAsIDB4MDEgfSwKKwkgLyogRXJhc2VNYXN0ZXIgKi8KKwl7IDB4MDAsIDB4MDAs IDB4MDAsIDB4MDksIDB4MDAsIDB4MDAsIDB4ODQsIDB4MDEgfSwKKworCS8qIHRhYmxlcyAqLwor CisJLyogTG9ja2luZ19HbG9iYWxSYW5nZSAqLworCXsgMHgwMCwgMHgwMCwgMHgwOCwgMHgwMiwg MHgwMCwgMHgwMCwgMHgwMCwgMHgwMSB9LAorCS8qIEFDRV9Mb2NraW5nX1JhbmdlX1NldF9SZExv Y2tlZCBVSUQgKi8KKwl7IDB4MDAsIDB4MDAsIDB4MDAsIDB4MDgsIDB4MDAsIDB4MDMsIDB4RTAs IDB4MDEgfSwKKwkvKiBBQ0VfTG9ja2luZ19SYW5nZV9TZXRfV3JMb2NrZWQgVUlEICovCisJeyAw eDAwLCAweDAwLCAweDAwLCAweDA4LCAweDAwLCAweDAzLCAweEU4LCAweDAxIH0sCisJLyogTUJS IENvbnRyb2wgKi8KKwl7IDB4MDAsIDB4MDAsIDB4MDgsIDB4MDMsIDB4MDAsIDB4MDAsIDB4MDAs IDB4MDEgfSwKKwkvKiBTaGFkb3cgTUJSICovCisJeyAweDAwLCAweDAwLCAweDA4LCAweDA0LCAw eDAwLCAweDAwLCAweDAwLCAweDAwIH0sCisJLyogQVVUSE9SSVRZX1RBQkxFICovCisJeyAweDAw LCAweDAwLCAweDAwLCAweDA5LCAweDAwLCAweDAwLCAweDAwLCAweDAwfSwKKwkvKiBDX1BJTl9U QUJMRSAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwQiwgMHgwMCwgMHgwMCwgMHgwMCwgMHgw MH0sCisJLyogT1BBTCBMb2NraW5nIEluZm8gKi8KKwl7IDB4MDAsIDB4MDAsIDB4MDgsIDB4MDEs IDB4MDAsIDB4MDAsIDB4MDAsIDB4MDEgfSwKKwkvKiBFbnRlcnByaXNlIExvY2tpbmcgSW5mbyAq LworCXsgMHgwMCwgMHgwMCwgMHgwOCwgMHgwMSwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCB9LAor CisJLyogQ19QSU5fVEFCTEUgb2JqZWN0IElEJ3MgKi8KKworCS8qIENfUElOX01TSUQgKi8KKwl7 IDB4MDAsIDB4MDAsIDB4MDAsIDB4MEIsIDB4MDAsIDB4MDAsIDB4ODQsIDB4MDJ9LAorCS8qIENf UElOX1NJRCAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwQiwgMHgwMCwgMHgwMCwgMHgwMCwg MHgwMX0sCisJIC8qIENfUElOX0FETUlOMSAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwQiwg MHgwMCwgMHgwMSwgMHgwMCwgMHgwMX0sCisKKwkvKiBoYWxmIFVJRCdzIChvbmx5IGZpcnN0IDQg Ynl0ZXMgdXNlZCkgKi8KKworCS8qIEhhbGYtVUlEIOKAkyBBdXRob3JpdHlfb2JqZWN0X3JlZiAq LworCXsgMHgwMCwgMHgwMCwgMHgwQywgMHgwNSwgMHhmZiwgMHhmZiwgMHhmZiwgMHhmZiB9LAor CS8qIEhhbGYtVUlEIOKAkyBCb29sZWFuIEFDRSAqLworCXsgMHgwMCwgMHgwMCwgMHgwNCwgMHgw RSwgMHhmZiwgMHhmZiwgMHhmZiwgMHhmZiB9LAorCisJLyogc3BlY2lhbCB2YWx1ZSBmb3Igb21p dHRlZCBvcHRpb25hbCBwYXJhbWV0ZXIgKi8KKworCS8qIEhFWEZGIGZvciBvbWl0dGVkICovCisJ eyAweGZmLCAweGZmLCAweGZmLCAweGZmLCAweGZmLCAweGZmLCAweGZmLCAweGZmfSwKK307Citz dGF0aWMgY29uc3Qgc2l6ZV90IE9QQUxfVUlEX0xFTkdUSCA9IDg7CitzdGF0aWMgY29uc3Qgc2l6 ZV90IE9QQUxfTVNJRF9LRVlMRU4gPSAxNTsKK3N0YXRpYyBjb25zdCBzaXplX3QgT1BBTF9VSURf TEVOR1RIX0hBTEYgPSA0OworCisKKy8qIEVudW0gdG8gaW5kZXggT1BBTFVJRCBhcnJheSAqLwor ZW51bSBPUEFMX1VJRCB7CisJLyogdXNlcnMgKi8KKwlPUEFMX1NNVUlEX1VJRCwKKwlPUEFMX1RI SVNTUF9VSUQsCisJT1BBTF9BRE1JTlNQX1VJRCwKKwlPUEFMX0xPQ0tJTkdTUF9VSUQsCisJT1BB TF9FTlRFUlBSSVNFX0xPQ0tJTkdTUF9VSUQsCisJT1BBTF9BTllCT0RZX1VJRCwKKwlPUEFMX1NJ RF9VSUQsCisJT1BBTF9BRE1JTjFfVUlELAorCU9QQUxfVVNFUjFfVUlELAorCU9QQUxfVVNFUjJf VUlELAorCU9QQUxfUFNJRF9VSUQsCisJT1BBTF9FTlRFUlBSSVNFX0JBTkRNQVNURVIwX1VJRCwK KwlPUEFMX0VOVEVSUFJJU0VfRVJBU0VNQVNURVJfVUlELAorCS8qIHRhYmxlcyAqLworCU9QQUxf TE9DS0lOR1JBTkdFX0dMT0JBTCwKKwlPUEFMX0xPQ0tJTkdSQU5HRV9BQ0VfUkRMT0NLRUQsCisJ T1BBTF9MT0NLSU5HUkFOR0VfQUNFX1dSTE9DS0VELAorCU9QQUxfTUJSQ09OVFJPTCwKKwlPUEFM X01CUiwKKwlPUEFMX0FVVEhPUklUWV9UQUJMRSwKKwlPUEFMX0NfUElOX1RBQkxFLAorCU9QQUxf TE9DS0lOR19JTkZPX1RBQkxFLAorCU9QQUxfRU5URVJQUklTRV9MT0NLSU5HX0lORk9fVEFCTEUs CisJLyogQ19QSU5fVEFCTEUgb2JqZWN0IElEJ3MgKi8KKwlPUEFMX0NfUElOX01TSUQsCisJT1BB TF9DX1BJTl9TSUQsCisJT1BBTF9DX1BJTl9BRE1JTjEsCisJLyogaGFsZiBVSUQncyAob25seSBm aXJzdCA0IGJ5dGVzIHVzZWQpICovCisJT1BBTF9IQUxGX1VJRF9BVVRIT1JJVFlfT0JKX1JFRiwK KwlPUEFMX0hBTEZfVUlEX0JPT0xFQU5fQUNFLAorCS8qIG9taXR0ZWQgb3B0aW9uYWwgcGFyYW1l dGVyICovCisJT1BBTF9VSURfSEVYRkYsCit9OworCisvKgorICogVENHIFN0b3JhZ2UgU1NDIE1l dGhvZHMuCisgKiBEZXJpdmVkIGZyb206IFRDR19TdG9yYWdlX0FyY2hpdGVjdHVyZV9Db3JlX1Nw ZWNfdjIuMDFfcjEuMDAKKyAqIFNlY3Rpb246IDYuMyBBc3NpZ25lZCBVSURzCisgKi8KK3N0YXRp YyBjb25zdCB1OCBPUEFMTUVUSE9EW11bOF0gPSB7CisJLyogUHJvcGVydGllcyAqLworCXsgMHgw MCwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwgMHhmZiwgMHgwMSB9LAorCS8qIFNUQVJU U0VTU0lPTiAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwMCwgMHhmZiwg MHgwMiB9LAorCS8qIFJldmVydCAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwNiwgMHgwMCwg MHgwMCwgMHgwMiwgMHgwMiB9LAorCS8qIEFjdGl2YXRlICovCisJeyAweDAwLCAweDAwLCAweDAw LCAweDA2LCAweDAwLCAweDAwLCAweDAyLCAweDAzIH0sCisJLyogRW50ZXJwcmlzZSBHZXQgKi8K Kwl7IDB4MDAsIDB4MDAsIDB4MDAsIDB4MDYsIDB4MDAsIDB4MDAsIDB4MDAsIDB4MDYgfSwKKwkv KiBFbnRlcnByaXNlIFNldCAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwNiwgMHgwMCwgMHgw MCwgMHgwMCwgMHgwNyB9LAorCS8qIE5FWFQgKi8KKwl7IDB4MDAsIDB4MDAsIDB4MDAsIDB4MDYs IDB4MDAsIDB4MDAsIDB4MDAsIDB4MDggfSwKKwkvKiBFbnRlcnByaXNlIEF1dGhlbnRpY2F0ZSAq LworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwNiwgMHgwMCwgMHgwMCwgMHgwMCwgMHgwYyB9LAor CS8qIEdldEFDTCAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwNiwgMHgwMCwgMHgwMCwgMHgw MCwgMHgwZCB9LAorCS8qIEdlbktleSAqLworCXsgMHgwMCwgMHgwMCwgMHgwMCwgMHgwNiwgMHgw MCwgMHgwMCwgMHgwMCwgMHgxMCB9LAorCS8qIHJldmVydFNQICovCisJeyAweDAwLCAweDAwLCAw eDAwLCAweDA2LCAweDAwLCAweDAwLCAweDAwLCAweDExIH0sCisJLyogR2V0ICovCisJeyAweDAw LCAweDAwLCAweDAwLCAweDA2LCAweDAwLCAweDAwLCAweDAwLCAweDE2IH0sCisJLyogU2V0ICov CisJeyAweDAwLCAweDAwLCAweDAwLCAweDA2LCAweDAwLCAweDAwLCAweDAwLCAweDE3IH0sCisJ LyogQXV0aGVudGljYXRlICovCisJeyAweDAwLCAweDAwLCAweDAwLCAweDA2LCAweDAwLCAweDAw LCAweDAwLCAweDFjIH0sCisJLyogUmFuZG9tICovCisJeyAweDAwLCAweDAwLCAweDAwLCAweDA2 LCAweDAwLCAweDAwLCAweDA2LCAweDAxIH0sCisJLyogRXJhc2UgKi8KKwl7IDB4MDAsIDB4MDAs IDB4MDAsIDB4MDYsIDB4MDAsIDB4MDAsIDB4MDgsIDB4MDMgfSwKK307CitzdGF0aWMgY29uc3Qg c2l6ZV90IE9QQUxfTUVUSE9EX0xFTkdUSCA9IDg7CisKKy8qIEVudW0gZm9yIGluZGV4aW5nIHRo ZSBPUEFMTUVUSE9EIGFycmF5ICovCitlbnVtIE9QQUxfTUVUSE9EIHsKKwlPUEFMX1BST1BFUlRJ RVMsCisJT1BBTF9TVEFSVFNFU1NJT04sCisJT1BBTF9SRVZFUlQsCisJT1BBTF9BQ1RJVkFURSwK KwlPUEFMX0VHRVQsCisJT1BBTF9FU0VULAorCU9QQUxfTkVYVCwKKwlPUEFMX0VBVVRIRU5USUNB VEUsCisJT1BBTF9HRVRBQ0wsCisJT1BBTF9HRU5LRVksCisJT1BBTF9SRVZFUlRTUCwKKwlPUEFM X0dFVCwKKwlPUEFMX1NFVCwKKwlPUEFMX0FVVEhFTlRJQ0FURSwKKwlPUEFMX1JBTkRPTSwKKwlP UEFMX0VSQVNFLAorfTsKKworLyoKKyAqIFRva2VuIGRlZnMgZGVyaXZlZCBmcm9tOgorICogVENH X1N0b3JhZ2VfQXJjaGl0ZWN0dXJlX0NvcmVfU3BlY192Mi4wMV9yMS4wMAorICogMy4yLjIgRGF0 YSBTdHJlYW0gRW5jb2RpbmcKKyAqLworZW51bSBPUEFMX1JFU1BPTlNFX1RPS0VOIHsKKwlPUEFM X0RUQV9UT0tFTklEX0JZVEVTVFJJTkcgPSAweGUwLAorCU9QQUxfRFRBX1RPS0VOSURfU0lOVCA9 IDB4ZTEsCisJT1BBTF9EVEFfVE9LRU5JRF9VSU5UID0gMHhlMiwKKwlPUEFMX0RUQV9UT0tFTklE X1RPS0VOID0gMHhlMywgLyogYWN0dWFsIHRva2VuIGlzIHJldHVybmVkICovCisJT1BBTF9EVEFf VE9LRU5JRF9JTlZBTElEID0gMFgwCit9OworCitlbnVtIE9QQUxfVE9LRU4geworCS8qIEJvb2xl YW4gKi8KKwlPUEFMX1RSVUUgPSAweDAxLAorCU9QQUxfRkFMU0UgPSAweDAwLAorCU9QQUxfQk9P TEVBTl9FWFBSID0gMHgwMywKKwkvKiBjZWxsYmxvY2tzICovCisJT1BBTF9UQUJMRSA9IDB4MDAs CisJT1BBTF9TVEFSVFJPVyA9IDB4MDEsCisJT1BBTF9FTkRST1cgPSAweDAyLAorCU9QQUxfU1RB UlRDT0xVTU4gPSAweDAzLAorCU9QQUxfRU5EQ09MVU1OID0gMHgwNCwKKwlPUEFMX1ZBTFVFUyA9 IDB4MDEsCisJLyogYXV0aG9yaXR5IHRhYmxlICovCisJT1BBTF9QSU4gPSAweDAzLAorCS8qIGxv Y2tpbmcgdG9rZW5zICovCisJT1BBTF9SQU5HRVNUQVJUID0gMHgwMywKKwlPUEFMX1JBTkdFTEVO R1RIID0gMHgwNCwKKwlPUEFMX1JFQURMT0NLRU5BQkxFRCA9IDB4MDUsCisJT1BBTF9XUklURUxP Q0tFTkFCTEVEID0gMHgwNiwKKwlPUEFMX1JFQURMT0NLRUQgPSAweDA3LAorCU9QQUxfV1JJVEVM T0NLRUQgPSAweDA4LAorCU9QQUxfQUNUSVZFS0VZID0gMHgwQSwKKwkvKiBsb2NraW5nIGluZm8g dGFibGUgKi8KKwlPUEFMX01BWFJBTkdFUyA9IDB4MDQsCisJIC8qIG1iciBjb250cm9sICovCisJ T1BBTF9NQlJFTkFCTEUgPSAweDAxLAorCU9QQUxfTUJSRE9ORSA9IDB4MDIsCisJLyogcHJvcGVy dGllcyAqLworCU9QQUxfSE9TVFBST1BFUlRJRVMgPSAweDAwLAorCS8qIGF0b21zICovCisJT1BB TF9TVEFSVExJU1QgPSAweGYwLAorCU9QQUxfRU5ETElTVCA9IDB4ZjEsCisJT1BBTF9TVEFSVE5B TUUgPSAweGYyLAorCU9QQUxfRU5ETkFNRSA9IDB4ZjMsCisJT1BBTF9DQUxMID0gMHhmOCwKKwlP UEFMX0VORE9GREFUQSA9IDB4ZjksCisJT1BBTF9FTkRPRlNFU1NJT04gPSAweGZhLAorCU9QQUxf U1RBUlRUUkFOU0FDVE9OID0gMHhmYiwKKwlPUEFMX0VORFRSQU5TQUNUT04gPSAweGZDLAorCU9Q QUxfRU1QVFlBVE9NID0gMHhmZiwKKwlPUEFMX1dIRVJFID0gMHgwMCwKK307CisKKy8qIFVzZWZ1 bCB0aW55IGF0b21zLgorICogVXNlZnVsIGZvciB0YWJsZSBjb2x1bW5zIGV0YworICovCitlbnVt IE9QQUxfVElOWV9BVE9NIHsKKwlPUEFMX1RJTllfVUlOVF8wMCA9IDB4MDAsCisJT1BBTF9USU5Z X1VJTlRfMDEgPSAweDAxLAorCU9QQUxfVElOWV9VSU5UXzAyID0gMHgwMiwKKwlPUEFMX1RJTllf VUlOVF8wMyA9IDB4MDMsCisJT1BBTF9USU5ZX1VJTlRfMDQgPSAweDA0LAorCU9QQUxfVElOWV9V SU5UXzA1ID0gMHgwNSwKKwlPUEFMX1RJTllfVUlOVF8wNiA9IDB4MDYsCisJT1BBTF9USU5ZX1VJ TlRfMDcgPSAweDA3LAorCU9QQUxfVElOWV9VSU5UXzA4ID0gMHgwOCwKKwlPUEFMX1RJTllfVUlO VF8wOSA9IDB4MDksCisJT1BBTF9USU5ZX1VJTlRfMTAgPSAweDBhLAorCU9QQUxfVElOWV9VSU5U XzExID0gMHgwYiwKKwlPUEFMX1RJTllfVUlOVF8xMiA9IDB4MGMsCisJT1BBTF9USU5ZX1VJTlRf MTMgPSAweDBkLAorCU9QQUxfVElOWV9VSU5UXzE0ID0gMHgwZSwKKwlPUEFMX1RJTllfVUlOVF8x NSA9IDB4MGYsCit9OworCitlbnVtIE9QQUxfQVRPTV9XSURUSCB7CisJT1BBTF9XSURUSF9USU5Z LAorCU9QQUxfV0lEVEhfU0hPUlQsCisJT1BBTF9XSURUSF9NRURJVU0sCisJT1BBTF9XSURUSF9M T05HLAorCU9QQUxfV0lEVEhfVE9LRU4KK307CisKKy8qIExvY2tpbmcgc3RhdGUgZm9yIGEgbG9j a2luZyByYW5nZSAqLworZW51bSBPUEFMX0xPQ0tJTkdTVEFURSB7CisJT1BBTF9MT0NLSU5HX1JF QURXUklURSA9IDB4MDEsCisJT1BBTF9MT0NLSU5HX1JFQURPTkxZID0gMHgwMiwKKwlPUEFMX0xP Q0tJTkdfTE9DS0VEID0gMHgwMywKK307CisKKy8qCisgKiBTdHJ1Y3R1cmVzIHRvIGJ1aWxkIGFu ZCBkZWNvZGUgdGhlIE9wYWwgU1NDIG1lc3NhZ2VzCisgKiBmaWVsZHMgdGhhdCBhcmUgTk9UIHJl YWxseSBudW1lcmljIGFyZSBkZWZpbmVkIGFzIHU4W10gdG8KKyAqIGhlbHAgcmVkdWNlIHRoZSBl bmRpYW5uZXNzIGlzc3VlcworICovCisKKy8qIFBhY2tldHMgZGVyaXZlZCBmcm9tOgorICogVENH X1N0b3JhZ2VfQXJjaGl0ZWN0dXJlX0NvcmVfU3BlY192Mi4wMV9yMS4wMAorICogU2VjaW9uOiAz LjIuMyBDb21QYWNrZXRzLCBQYWNrZXRzICYgU3VicGFja2V0cworICovCisKKy8qIENvbW0gUGFj a2V0IChoZWFkZXIpIGZvciB0cmFuc21pc3Npb25zLiAqLworc3RydWN0IG9wYWxfY29tcGFja2V0 IHsKKwl1MzIgcmVzZXJ2ZWQwOworCXU4IGV4dGVuZGVkQ29tSURbNF07CisJdTMyIG91dHN0YW5k aW5nRGF0YTsKKwl1MzIgbWluVHJhbnNmZXI7CisJdTMyIGxlbmd0aDsKK307CisKKy8qIFBhY2tl dCBzdHJ1Y3R1cmUuICovCitzdHJ1Y3Qgb3BhbF9wYWNrZXQgeworCXUzMiBUU047CisJdTMyIEhT TjsKKwl1MzIgc2VxX251bWJlcjsKKwl1MTYgcmVzZXJ2ZWQwOworCXUxNiBhY2tfdHlwZTsKKwl1 MzIgYWNrbm93bGVkZ21lbnQ7CisJdTMyIGxlbmd0aDsKK307CisKKy8qIERhdGEgc3ViIHBhY2tl dCBoZWFkZXIgKi8KK3N0cnVjdCBvcGFsX2RhdGFfc3VicGFja2V0IHsKKwl1OCByZXNlcnZlZDBb Nl07CisJdTE2IGtpbmQ7CisJdTMyIGxlbmd0aDsKK307CisKKy8qIGhlYWRlciBvZiBhIHJlc3Bv bnNlICovCitzdHJ1Y3Qgb3BhbF9oZWFkZXIgeworCXN0cnVjdCBvcGFsX2NvbXBhY2tldCBjcDsK KwlzdHJ1Y3Qgb3BhbF9wYWNrZXQgcGt0OworCXN0cnVjdCBvcGFsX2RhdGFfc3VicGFja2V0IHN1 YnBrdDsKK307CisKKyNkZWZpbmUgRkNfVFBFUiAgICAgICAweDAwMDEKKyNkZWZpbmUgRkNfTE9D S0lORyAgICAweDAwMDIKKyNkZWZpbmUgRkNfR0VPTUVUUlkgICAweDAwMDMKKyNkZWZpbmUgRkNf RU5URVJQUklTRSAweDAxMDAKKyNkZWZpbmUgRkNfREFUQVNUT1JFICAweDAyMDIKKyNkZWZpbmUg RkNfU0lOR0xFVVNFUiAweDAyMDEKKyNkZWZpbmUgRkNfT1BBTFYxMDAgICAweDAyMDAKKyNkZWZp bmUgRkNfT1BBTFYyMDAgICAweDAyMDMKKworLyoKKyAqIFRoZSBEaXNjb3ZlcnkgMCBIZWFkZXIu IEFzIGRlZmluZWQgaW4KKyAqIE9wYWwgU1NDIERvY3VtZW50YXRpb24KKyAqIFNlY3Rpb246IDMu My41IENhcGFiaWxpdHkgRGlzY292ZXJ5CisgKi8KK3N0cnVjdCBkMF9oZWFkZXIgeworCXUzMiBs ZW5ndGg7IC8qIHRoZSBsZW5ndGggb2YgdGhlIGhlYWRlciA0OCBpbiAyLjAwLjEwMCAqLworCXUz MiByZXZpc2lvbjsgLyoqPCByZXZpc2lvbiBvZiB0aGUgaGVhZGVyIDEgaW4gMi4wMC4xMDAgKi8K Kwl1MzIgcmVzZXJ2ZWQwMTsKKwl1MzIgcmVzZXJ2ZWQwMjsKKwkvKgorCSAqIHRoZSByZW1haW5k ZXIgb2YgdGhlIHN0cnVjdHVyZSBpcyB2ZW5kb3Igc3BlY2lmaWMgYW5kIHdpbGwgbm90IGJlCisJ ICogYWRkcmVzc2VkIG5vdworCSAqLworCXU4IGlnbm9yZWRbMzJdOworfTsKKworLyoKKyAqIFRQ ZXIgRmVhdHVyZSBEZXNjcmlwdG9yLiBDb250YWlucyBmbGFncyBpbmRpY2F0aW5nIHN1cHBvcnQg Zm9yIHRoZQorICogVFBlciBmZWF0dXJlcyBkZXNjcmliZWQgaW4gdGhlIE9QQUwgc3BlY2lmaWNh dGlvbi4gVGhlIG5hbWVzIG1hdGNoIHRoZQorICogT1BBTCB0ZXJtaW5vbG9neQorICoKKyAqIGNv ZGUgPT0gMHgwMDEgaW4gMi4wMC4xMDAKKyAqLworc3RydWN0IGQwX3RwZXJfZmVhdHVyZXMgewor CS8qCisJICogc3VwcG9ydGVkX2ZlYXR1cmVzIGJpdHM6CisJICogYml0IDc6IHJlc2VydmVkCisJ ICogYml0IDY6IGNvbSBJRCBtYW5hZ2VtZW50CisJICogYml0IDU6IHJlc2VydmVkCisJICogYml0 IDQ6IHN0cmVhbWluZyBzdXBwb3J0CisJICogYml0IDM6IGJ1ZmZlciBtYW5hZ2VtZW50CisJICog Yml0IDI6IEFDSy9OQUNLCisJICogYml0IDE6IGFzeW5jCisJICogYml0IDA6IHN5bmMKKwkgKi8K Kwl1OCBzdXBwb3J0ZWRfZmVhdHVyZXM7CisJLyoKKwkgKiBieXRlcyA1IHRocm91Z2ggMTUgYXJl IHJlc2VydmVkLCBidXQgd2UgcmVwcmVzZW50IHRoZSBmaXJzdCAzIGFzCisJICogdTggdG8ga2Vl cCB0aGUgb3RoZXIgdHdvIDMyYml0cyBpbnRlZ2VycyBhbGlnbmVkLgorCSAqLworCXU4IHJlc2Vy dmVkMDFbM107CisJdTMyIHJlc2VydmVkMDI7CisJdTMyIHJlc2VydmVkMDM7Cit9OworCisvKgor ICogTG9ja2luZyBGZWF0dXJlIERlc2NyaXB0b3IuIENvbnRhaW5zIGZsYWdzIGluZGljYXRpbmcg c3VwcG9ydCBmb3IgdGhlCisgKiBsb2NraW5nIGZlYXR1cmVzIGRlc2NyaWJlZCBpbiB0aGUgT1BB TCBzcGVjaWZpY2F0aW9uLiBUaGUgbmFtZXMgbWF0Y2ggdGhlCisgKiBPUEFMIHRlcm1pbm9sb2d5 CisgKgorICogY29kZSA9PSAweDAwMDIgaW4gMi4wMC4xMDAKKyAqLworc3RydWN0IGQwX2xvY2tp bmdfZmVhdHVyZXMgeworCS8qCisJICogc3VwcG9ydGVkX2ZlYXR1cmVzIGJpdHM6CisJICogYml0 cyA2LTc6IHJlc2VydmVkCisJICogYml0IDU6IE1CUiBkb25lCisJICogYml0IDQ6IE1CUiBlbmFi bGVkCisJICogYml0IDM6IG1lZGlhIGVuY3J5cHRpb24KKwkgKiBiaXQgMjogbG9ja2VkCisJICog Yml0IDE6IGxvY2tpbmcgZW5hYmxlZAorCSAqIGJpdCAwOiBsb2NraW5nIHN1cHBvcnRlZAorCSAq LworCXU4IHN1cHBvcnRlZF9mZWF0dXJlczsKKwkvKgorCSAqIGJ5dGVzIDUgdGhyb3VnaCAxNSBh cmUgcmVzZXJ2ZWQsIGJ1dCB3ZSByZXByZXNlbnQgdGhlIGZpcnN0IDMgYXMKKwkgKiB1OCB0byBr ZWVwIHRoZSBvdGhlciB0d28gMzJiaXRzIGludGVnZXJzIGFsaWduZWQuCisJICovCisJdTggcmVz ZXJ2ZWQwMVszXTsKKwl1MzIgcmVzZXJ2ZWQwMjsKKwl1MzIgcmVzZXJ2ZWQwMzsKK307CisKKy8q CisgKiBHZW9tZXRyeSBGZWF0dXJlIERlc2NyaXB0b3IuIENvbnRhaW5zIGZsYWdzIGluZGljYXRp bmcgc3VwcG9ydCBmb3IgdGhlCisgKiBnZW9tZXRyeSBmZWF0dXJlcyBkZXNjcmliZWQgaW4gdGhl IE9QQUwgc3BlY2lmaWNhdGlvbi4gVGhlIG5hbWVzIG1hdGNoIHRoZQorICogT1BBTCB0ZXJtaW5v bG9neQorICoKKyAqIGNvZGUgPT0gMHgwMDAzIGluIDIuMDAuMTAwCisgKi8KK3N0cnVjdCBkMF9n ZW9tZXRyeV9mZWF0dXJlcyB7CisJLyoKKwkgKiBza2lwIDMyIGJpdHMgZnJvbSBoZWFkZXIsIG5l ZWRlZCB0byBhbGlnbiB0aGUgc3RydWN0IHRvIDY0IGJpdHMuCisJICovCisJdTggaGVhZGVyWzRd OworCS8qCisJICogcmVzZXJ2ZWQwMToKKwkgKiBiaXRzIDEtNjogcmVzZXJ2ZWQKKwkgKiBiaXQg MDogYWxpZ24KKwkgKi8KKwl1OCByZXNlcnZlZDAxOworCXU4IHJlc2VydmVkMDJbN107CisJdTMy IGxvZ2ljYWxfYmxvY2tfc2l6ZTsKKwl1NjQgYWxpZ25tZW50X2dyYW51bGFyaXR5OworCXU2NCBs b3dlc3RfYWxpZ25lZF9sYmE7Cit9OworCisvKgorICogRW50ZXJwcmlzZSBTU0MgRmVhdHVyZQor ICoKKyAqIGNvZGUgPT0gMHgwMTAwCisgKi8KK3N0cnVjdCBkMF9lbnRlcnByaXNlX3NzYyB7CisJ dTE2IGJhc2VDb21JRDsKKwl1MTYgbnVtQ29tSURzOworCS8qIHJhbmdlX2Nyb3NzaW5nOgorCSAq IGJpdHMgMS02OiByZXNlcnZlZAorCSAqIGJpdCAwOiByYW5nZSBjcm9zc2luZworCSAqLworCXU4 IHJhbmdlX2Nyb3NzaW5nOworCXU4IHJlc2VydmVkMDE7CisJdTE2IHJlc2VydmVkMDI7CisJdTMy IHJlc2VydmVkMDM7CisJdTMyIHJlc2VydmVkMDQ7Cit9OworCisvKgorICogT3BhbCBWMSBmZWF0 dXJlCisgKgorICogY29kZSA9PSAweDAyMDAKKyAqLworc3RydWN0IGQwX29wYWxfdjEwMCB7CisJ dTE2IGJhc2VDb21JRDsKKwl1MTYgbnVtQ29tSURzOworfTsKKworLyoKKyAqIFNpbmdsZSBVc2Vy IE1vZGUgZmVhdHVyZQorICoKKyAqIGNvZGUgPT0gMHgwMjAxCisgKi8KK3N0cnVjdCBkMF9zaW5n bGVfdXNlcl9tb2RlIHsKKwl1MzIgbnVtX2xvY2tpbmdfb2JqZWN0czsKKwkvKiByZXNlcnZlZDAx OgorCSAqIGJpdCAwOiBhbnkKKwkgKiBiaXQgMTogYWxsCisJICogYml0IDI6IHBvbGljeQorCSAq IGJpdHMgMy03OiByZXNlcnZlZAorCSAqLworCXU4IHJlc2VydmVkMDE7CisJdTggcmVzZXJ2ZWQw MjsKKwl1MTYgcmVzZXJ2ZWQwMzsKKwl1MzIgcmVzZXJ2ZWQwNDsKK307CisKKy8qCisgKiBBZGRp dG9uYWwgRGF0YXN0b3JlcyBmZWF0dXJlCisgKgorICogY29kZSA9PSAweDAyMDIKKyAqLworc3Ry dWN0IGQwX2RhdGFzdG9yZV90YWJsZSB7CisJdTE2IHJlc2VydmVkMDE7CisJdTE2IG1heF90YWJs ZXM7CisJdTMyIG1heF9zaXplX3RhYmxlczsKKwl1MzIgdGFibGVfc2l6ZV9hbGlnbm1lbnQ7Cit9 OworCisvKgorICogT1BBTCAyLjAgZmVhdHVyZQorICoKKyAqIGNvZGUgPT0gMHgwMjAzCisgKi8K K3N0cnVjdCBkMF9vcGFsX3YyMDAgeworCXUxNiBiYXNlQ29tSUQ7CisJdTE2IG51bUNvbUlEczsK KwkvKiByYW5nZV9jcm9zc2luZzoKKwkgKiBiaXRzIDEtNjogcmVzZXJ2ZWQKKwkgKiBiaXQgMDog cmFuZ2UgY3Jvc3NpbmcKKwkgKi8KKwl1OCByYW5nZV9jcm9zc2luZzsKKwkvKiBudW1fbG9ja2lu Z19hZG1pbl9hdXRoOgorCSAqIG5vdCBhbGlnbmVkIHRvIDE2IGJpdHMsIHNvIHVzZSB0d28gdTgu CisJICogc3RvcmVkIGluIGJpZyBlbmRpYW46CisJICogMDogTVNCCisJICogMTogTFNCCisJICov CisJdTggbnVtX2xvY2tpbmdfYWRtaW5fYXV0aFsyXTsKKwkvKiBudW1fbG9ja2luZ191c2VyX2F1 dGg6CisJICogbm90IGFsaWduZWQgdG8gMTYgYml0cywgc28gdXNlIHR3byB1OC4KKwkgKiBzdG9y ZWQgaW4gYmlnIGVuZGlhbjoKKwkgKiAwOiBNU0IKKwkgKiAxOiBMU0IKKwkgKi8KKwl1OCBudW1f bG9ja2luZ191c2VyX2F1dGhbMl07CisJdTggaW5pdGlhbFBJTjsKKwl1OCByZXZlcnRlZFBJTjsK Kwl1OCByZXNlcnZlZDAxOworCXUzMiByZXNlcnZlZDAyOworfTsKKworLyogVW5pb24gb2YgZmVh dHVyZXMgdXNlZCB0byBwYXJzZSB0aGUgZGlzY292ZXJ5IDAgcmVzcG9uc2UgKi8KK3N0cnVjdCBk MF9mZWF0dXJlcyB7CisJdTE2IGNvZGU7CisJLyoKKwkgKiByX3ZlcnNpb24gYml0czoKKwkgKiBi aXRzIDQtNzogdmVyc2lvbgorCSAqIGJpdHMgMC0zOiByZXNlcnZlZAorCSAqLworCXU4IHJfdmVy c2lvbjsKKwl1OCBsZW5ndGg7CisJdTggZmVhdHVyZXNbXTsKK307CisKK3N0cnVjdCBrZXkgKnJl cXVlc3RfdXNlcl9rZXkoY29uc3QgY2hhciAqbWFzdGVyX2Rlc2MsIGNvbnN0IHU4ICoqbWFzdGVy X2tleSwKKwkJCSAgICAgc2l6ZV90ICptYXN0ZXJfa2V5bGVuKTsKKworI2VuZGlmIC8qIF9OVk1F X09QQUxfSU5URVJOQUxfSCAqLwpkaWZmIC0tZ2l0IGEvYmxvY2svc2VkLmMgYi9ibG9jay9zZWQu YwpuZXcgZmlsZSBtb2RlIDEwMDY0NAppbmRleCAwMDAwMDAwLi4yNDFiMWRjCi0tLSAvZGV2L251 bGwKKysrIGIvYmxvY2svc2VkLmMKQEAgLTAsMCArMSwyMDcgQEAKKy8qCisgKiBDb3B5cmlnaHQg wqkgMjAxNiBJbnRlbCBDb3Jwb3JhdGlvbgorICoKKyAqIEF1dGhvcnM6CisgKiAgICBSYWZhZWwg QW50b2dub2xsaSA8cmFmYWVsLmFudG9nbm9sbGlAaW50ZWwuY29tPgorICogICAgU2NvdHQgIEJh dWVyICAgICAgPHNjb3R0LmJhdWVyQGludGVsLmNvbT4KKyAqCisgKiBUaGlzIHByb2dyYW0gaXMg ZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIG1vZGlmeSBpdAor ICogdW5kZXIgdGhlIHRlcm1zIGFuZCBjb25kaXRpb25zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJs aWMgTGljZW5zZSwKKyAqIHZlcnNpb24gMiwgYXMgcHVibGlzaGVkIGJ5IHRoZSBGcmVlIFNvZnR3 YXJlIEZvdW5kYXRpb24uCisgKgorICogVGhpcyBwcm9ncmFtIGlzIGRpc3RyaWJ1dGVkIGluIHRo ZSBob3BlIGl0IHdpbGwgYmUgdXNlZnVsLCBidXQgV0lUSE9VVAorICogQU5ZIFdBUlJBTlRZOyB3 aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YgTUVSQ0hBTlRBQklMSVRZIG9yCisg KiBGSVRORVNTIEZPUiBBIFBBUlRJQ1VMQVIgUFVSUE9TRS4gIFNlZSB0aGUgR05VIEdlbmVyYWwg UHVibGljIExpY2Vuc2UgZm9yCisgKiBtb3JlIGRldGFpbHMuCisgKi8KKworI2luY2x1ZGUgPGxp bnV4L2Jsa2Rldi5oPgorI2luY2x1ZGUgPGxpbnV4L3NlZC5oPgorI2luY2x1ZGUgPGxpbnV4L3Nl ZC1vcGFsLmg+CisjaW5jbHVkZSA8YXNtL3VhY2Nlc3MuaD4KKworCitpbnQgc2VkX3NhdmUoc3Ry dWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3RydWN0IHNlZF9rZXkgKmtleSwKKwkgICAgIHZvaWQg KnNibXRfZGF0YSwgc2VkX3NlY19zdWJtaXQgKnN1Ym1pdF9mbikKK3sKKwlzd2l0Y2ggKGtleS0+ c2VkX3R5cGUpIHsKKwljYXNlIE9QQUxfTE9DS19VTkxPQ0s6CisJCXJldHVybiBvcGFsX3NhdmUo YmRldiwga2V5LCBzYm10X2RhdGEsIHN1Ym1pdF9mbik7CisJfQorCisJcmV0dXJuIC1FT1BOT1RT VVBQOworfQorCitpbnQgc2VkX2xvY2tfdW5sb2NrKHN0cnVjdCBibG9ja19kZXZpY2UgKmJkZXYs IHN0cnVjdCBzZWRfa2V5ICprZXksCisJCSAgICB2b2lkICpzYm10X2RhdGEsIHNlZF9zZWNfc3Vi bWl0ICpzdWJtaXRfZm4pCit7CisJc3dpdGNoIChrZXktPnNlZF90eXBlKSB7CisJY2FzZSBPUEFM X0xPQ0tfVU5MT0NLOgorCQlyZXR1cm4gb3BhbF9sb2NrX3VubG9jayhiZGV2LCBrZXksIHNibXRf ZGF0YSwgc3VibWl0X2ZuKTsKKwl9CisKKwlyZXR1cm4gLUVPUE5PVFNVUFA7Cit9CisKK2ludCBz ZWRfdGFrZV9vd25lcnNoaXAoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3RydWN0IHNlZF9r ZXkgKmtleSwKKwkJICAgICAgIHZvaWQgKnNibXRfZGF0YSwgc2VkX3NlY19zdWJtaXQgKnN1Ym1p dF9mbikKK3sKKworCXN3aXRjaCAoa2V5LT5zZWRfdHlwZSkgeworCWNhc2UgT1BBTDoKKwkJcmV0 dXJuIG9wYWxfdGFrZV9vd25lcnNoaXAoYmRldiwga2V5LCBzYm10X2RhdGEsIHN1Ym1pdF9mbik7 CisJfQorCisJcmV0dXJuIC1FT1BOT1RTVVBQOworfQorCitpbnQgc2VkX2FjdGl2YXRlX2xzcChz dHJ1Y3QgYmxvY2tfZGV2aWNlICpiZGV2LCBzdHJ1Y3Qgc2VkX2tleSAqa2V5LAorCQkgICAgIHZv aWQgKnNibXRfZGF0YSwgc2VkX3NlY19zdWJtaXQgKnN1Ym1pdF9mbikKK3sKKworCXN3aXRjaCAo a2V5LT5zZWRfdHlwZSkgeworCWNhc2UgT1BBTDoKKwkJcmV0dXJuIG9wYWxfYWN0aXZhdGVfbHNw KGJkZXYsIGtleSwgc2JtdF9kYXRhLCBzdWJtaXRfZm4pOworCX0KKworCXJldHVybiAtRU9QTk9U U1VQUDsKK30KKworaW50IHNlZF9zZXRfcHcoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3Ry dWN0IHNlZF9rZXkgKmtleSwKKwkgICAgICAgdm9pZCAqc2JtdF9kYXRhLCBzZWRfc2VjX3N1Ym1p dCAqc3VibWl0X2ZuKQoreworCisJc3dpdGNoIChrZXktPnNlZF90eXBlKSB7CisJY2FzZSBPUEFM X1BXOgorCQlyZXR1cm4gb3BhbF9zZXRfbmV3X3B3KGJkZXYsIGtleSwgc2JtdF9kYXRhLCBzdWJt aXRfZm4pOworCX0KKworCXJldHVybiAtRU9QTk9UU1VQUDsKK30KKworaW50IHNlZF9hY3RpdmF0 ZV91c2VyKHN0cnVjdCBibG9ja19kZXZpY2UgKmJkZXYsIHN0cnVjdCBzZWRfa2V5ICprZXksCisJ CSAgICAgIHZvaWQgKnNibXRfZGF0YSwgc2VkX3NlY19zdWJtaXQgKnN1Ym1pdF9mbikKK3sKKwor CXN3aXRjaCAoa2V5LT5zZWRfdHlwZSkgeworCWNhc2UgT1BBTF9BQ1RfVVNSOgorCQlyZXR1cm4g b3BhbF9hY3RpdmF0ZV91c2VyKGJkZXYsIGtleSwgc2JtdF9kYXRhLCBzdWJtaXRfZm4pOworCX0K KworCXJldHVybiAtRU9QTk9UU1VQUDsKK30KKworaW50IHNlZF9yZXZlcnR0cGVyKHN0cnVjdCBi bG9ja19kZXZpY2UgKmJkZXYsIHN0cnVjdCBzZWRfa2V5ICprZXksCisJCSAgIHZvaWQgKnNibXRf ZGF0YSwgc2VkX3NlY19zdWJtaXQgKnN1Ym1pdF9mbikKK3sKKworCXN3aXRjaCAoa2V5LT5zZWRf dHlwZSkgeworCWNhc2UgT1BBTDoKKwkJcmV0dXJuIG9wYWxfcmV2ZXJ0dHBlcihiZGV2LCBrZXks IHNibXRfZGF0YSwgc3VibWl0X2ZuKTsKKwl9CisKKwlyZXR1cm4gLUVPUE5PVFNVUFA7Cit9CisK K2ludCBzZWRfc2V0dXBfbG9ja2luZ19yYW5nZShzdHJ1Y3QgYmxvY2tfZGV2aWNlICpiZGV2LCBz dHJ1Y3Qgc2VkX2tleSAqa2V5LAorCQkJICAgIHZvaWQgKnNibXRfZGF0YSwgc2VkX3NlY19zdWJt aXQgKnN1Ym1pdF9mbikKK3sKKworCXN3aXRjaCAoa2V5LT5zZWRfdHlwZSkgeworCWNhc2UgT1BB TF9MUl9TRVRVUDoKKwkJcmV0dXJuIG9wYWxfc2V0dXBfbG9ja2luZ19yYW5nZShiZGV2LCBrZXks IHNibXRfZGF0YSwgc3VibWl0X2ZuKTsKKwl9CisKKwlyZXR1cm4gLUVPUE5PVFNVUFA7Cit9CisK K2ludCBzZWRfYWRkdXNlcl90b19scihzdHJ1Y3QgYmxvY2tfZGV2aWNlICpiZGV2LCBzdHJ1Y3Qg c2VkX2tleSAqa2V5LAorCQkgICAgICB2b2lkICpzYm10X2RhdGEsIHNlZF9zZWNfc3VibWl0ICpz dWJtaXRfZm4pCit7CisKKwlzd2l0Y2ggKGtleS0+c2VkX3R5cGUpIHsKKwljYXNlIE9QQUxfTE9D S19VTkxPQ0s6CisJCXJldHVybiBvcGFsX2FkZF91c2VyX3RvX2xyKGJkZXYsIGtleSwgc2JtdF9k YXRhLCBzdWJtaXRfZm4pOworCX0KKworCXJldHVybiAtRU9QTk9UU1VQUDsKK30KKworaW50IHNl ZF9kb19tYnIoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3RydWN0IHNlZF9rZXkgKmtleSwK KwkgICAgICAgdm9pZCAqc2JtdF9kYXRhLCBzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2ZuKQorewor CisJc3dpdGNoIChrZXktPnNlZF90eXBlKSB7CisJY2FzZSBPUEFMX01CUl9EQVRBOgorCQlyZXR1 cm4gb3BhbF9lbmFibGVfZGlzYWJsZV9zaGFkb3dfbWJyKGJkZXYsIGtleSwgc2JtdF9kYXRhLAor CQkJCQkJICAgICAgc3VibWl0X2ZuKTsKKwl9CisKKwlyZXR1cm4gLUVPUE5PVFNVUFA7Cit9CisK K2ludCBzZWRfZXJhc2VfbHIoc3RydWN0IGJsb2NrX2RldmljZSAqYmRldiwgc3RydWN0IHNlZF9r ZXkgKmtleSwKKwkJIHZvaWQgKnNibXRfZGF0YSwgc2VkX3NlY19zdWJtaXQgKnN1Ym1pdF9mbikK K3sKKworCXN3aXRjaCAoa2V5LT5zZWRfdHlwZSkgeworCWNhc2UgT1BBTDoKKwkJcmV0dXJuIG9w YWxfZXJhc2VfbG9ja2luZ19yYW5nZShiZGV2LCBrZXksIHNibXRfZGF0YSwgc3VibWl0X2ZuKTsK Kwl9CisKKwlyZXR1cm4gLUVPUE5PVFNVUFA7Cit9CisKK2ludCBzZWRfc2VjdXJlX2VyYXNlX2xy KHN0cnVjdCBibG9ja19kZXZpY2UgKmJkZXYsIHN0cnVjdCBzZWRfa2V5ICprZXksCisJCQl2b2lk ICpzYm10X2RhdGEsIHNlZF9zZWNfc3VibWl0ICpzdWJtaXRfZm4pCit7CisJc3dpdGNoIChrZXkt PnNlZF90eXBlKSB7CisJY2FzZSBPUEFMX0FDVF9VU1I6CisJCXJldHVybiBvcGFsX3NlY3VyZV9l cmFzZV9sb2NraW5nX3JhbmdlKGJkZXYsIGtleSwKKwkJCQkJCSAgICAgICBzYm10X2RhdGEsIHN1 Ym1pdF9mbik7CisKKwl9CisJcmV0dXJuIC1FT1BOT1RTVVBQOworfQorCisKKyNkZWZpbmUgQ01E X1RPX0ZOX0lORFgoY21kKSBcCisJKGNtZCkgLSBJT0NfU0VEX1NBVkUKKworaW50ICgqc2VkX2Zu W10pKHN0cnVjdCBibG9ja19kZXZpY2UgKmJkZXYsIHN0cnVjdCBzZWRfa2V5ICprZXksCisJCSAg dm9pZCAqc2JtdF9kYXRhLCBzZWRfc2VjX3N1Ym1pdCAqc3VibWl0X2ZuKSA9Cit7CisJc2VkX3Nh dmUsCisJc2VkX2xvY2tfdW5sb2NrLAorCXNlZF90YWtlX293bmVyc2hpcCwKKwlzZWRfYWN0aXZh dGVfbHNwLAorCXNlZF9zZXRfcHcsCisJc2VkX2FjdGl2YXRlX3VzZXIsCisJc2VkX3JldmVydHRw ZXIsCisJc2VkX3NldHVwX2xvY2tpbmdfcmFuZ2UsCisJc2VkX2FkZHVzZXJfdG9fbHIsCisJc2Vk X2RvX21iciwKKwlzZWRfZXJhc2VfbHIsCisJc2VkX3NlY3VyZV9lcmFzZV9scgorfTsKKworLyog VGhlIHNibXRfY3RybF9kYXRhIGlzIGEgb3BhcXVlIHBvaW50ZXIgdG8gc29tZSBzdHJ1Y3R1cmUg d2hpY2ggd2lsbCBiZSB1c2VkCisgKiBieSB0aGUgc3VibWl0X2ZuIHRvIHByb3Blcmx5IHN1Ym1p dCB0aGUgb3BhbCBjb21tYW5kIHRvIHRoZSBjb250cm9sbGVyLgorICogVGhlIHN1Ym1pdF9mbiBt dXN0IGJlIGEgYmxvY2tpbmcgY2FsbC4KKyAqLworaW50IGJsa2Rldl9zZWRfaW9jdGwoc3RydWN0 IGJsb2NrX2RldmljZSAqYmRldiwgZm1vZGVfdCBmbW9kZSwgdW5zaWduZWQgaW50IGNtZCwKKwkJ ICAgICB1bnNpZ25lZCBsb25nIGFyZywgdm9pZCAqc2JtdF9jdHJsX2RhdGEsCisJCSAgICAgc2Vk X3NlY19zdWJtaXQgKnN1Ym1pdF9mbikKK3sKKwlzdHJ1Y3Qgc2VkX2tleSBrZXk7CisKKwkgLyog Q2FsbGVyIHNob3VsZCBkbyB0aGlzIGJ1dCBzaW5jZSB3ZSdyZSBnb2luZyB0byB1c2UgY21kIGFz IGFuIGluZGV4CisJICogbGV0cyAndHJ1c3QgYnV0IHZlcmlmeScuCisJICovCisJaWYgKCFpc19z ZWRfaW9jdGwoY21kKSkKKwkJcmV0dXJuIC1FSU5WQUw7CisJaWYgKGNvcHlfZnJvbV91c2VyKCZr ZXksICh2b2lkIF9fdXNlciAqKWFyZywgc2l6ZW9mKGtleSkpKQorCQlyZXR1cm4gLUVGQVVMVDsK KwlyZXR1cm4gc2VkX2ZuW0NNRF9UT19GTl9JTkRYKGNtZCldKGJkZXYsICZrZXksIHNibXRfY3Ry bF9kYXRhLCBzdWJtaXRfZm4pOworfQorRVhQT1JUX1NZTUJPTF9HUEwoYmxrZGV2X3NlZF9pb2N0 bCk7Ci0tIAoyLjcuNAoKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fCkxpbnV4LW52bWUgbWFpbGluZyBsaXN0CkxpbnV4LW52bWVAbGlzdHMuaW5mcmFkZWFk Lm9yZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LW52 bWUK