LyoKICoJRXhlY3V0aXZlIE9TTQogKgogKiAJQ29weXJpZ2h0IChDKSAxOTk5LTIwMDIJUmVkIEhhdCBTb2Z0d2FyZQogKgogKglXcml0dGVuIGJ5IEFsYW4gQ294LCBCdWlsZGluZyBOdW1iZXIgVGhyZWUgTHRkCiAqCiAqCVRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOyB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IgbW9kaWZ5IGl0CiAqCXVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5IHRoZQogKglGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVpdGhlciB2ZXJzaW9uIDIgb2YgdGhlIExpY2Vuc2UsIG9yIChhdCB5b3VyCiAqCW9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uCiAqCiAqCUEgbG90IG9mIHRoZSBJMk8gbWVzc2FnZSBzaWRlIGNvZGUgZnJvbSB0aGlzIGlzIHRha2VuIGZyb20gdGhlIFJlZAogKglDcmVlayBSQ1BDSTQ1IGFkYXB0ZXIgZHJpdmVyIGJ5IFJlZCBDcmVlayBDb21tdW5pY2F0aW9ucwogKgogKglGaXhlcy9hZGRpdGlvbnM6CiAqCQlQaGlsaXBwIFJ1bXBmCiAqCQlKdWhhIFNpZXbkbmVuIDxKdWhhLlNpZXZhbmVuQGNzLkhlbHNpbmtpLkZJPgogKgkJQXV2byBI5GtraW5lbiA8QXV2by5IYWtraW5lbkBjcy5IZWxzaW5raS5GST4KICoJCURlZXBhayBTYXhlbmEgPGRlZXBha0BwbGV4aXR5Lm5ldD4KICoJCUJvamkgVCBLYW5uYW50aGFuYW0gPGJvamkudC5rYW5uYW50aGFuYW1AaW50ZWwuY29tPgogKgkJQWxhbiBDb3ggPGFsYW5AcmVkaGF0LmNvbT46CiAqCQkJUG9ydGVkIHRvIExpbnV4IDIuNS4KICoJCU1hcmt1cyBMaWRlbCA8TWFya3VzLkxpZGVsQHNoYWRvd2Nvbm5lY3QuY29tPjoKICoJCQlNaW5vciBmaXhlcyBmb3IgMi42LgogKgkJTWFya3VzIExpZGVsIDxNYXJrdXMuTGlkZWxAc2hhZG93Y29ubmVjdC5jb20+OgogKgkJCVN1cHBvcnQgZm9yIHN5c2ZzIGluY2x1ZGVkLgogKi8KCiNpbmNsdWRlIDxsaW51eC9tb2R1bGUuaD4KI2luY2x1ZGUgPGxpbnV4L2kyby5oPgojaW5jbHVkZSA8bGludXgvZGVsYXkuaD4KI2luY2x1ZGUgPGxpbnV4L3dvcmtxdWV1ZS5oPgojaW5jbHVkZSA8bGludXgvc3RyaW5nLmg+CiNpbmNsdWRlIDxsaW51eC9zbGFiLmg+CiNpbmNsdWRlIDxsaW51eC9zY2hlZC5oPgkvKiB3YWl0X2V2ZW50X2ludGVycnVwdGlibGVfdGltZW91dCgpIG5lZWRzIHRoaXMgKi8KI2luY2x1ZGUgPGFzbS9wYXJhbS5oPgkJLyogSFogKi8KI2luY2x1ZGUgImNvcmUuaCIKCiNkZWZpbmUgT1NNX05BTUUgImV4ZWMtb3NtIgoKc3RydWN0IGkyb19kcml2ZXIgaTJvX2V4ZWNfZHJpdmVyOwoKc3RhdGljIGludCBpMm9fZXhlY19sY3Rfbm90aWZ5KHN0cnVjdCBpMm9fY29udHJvbGxlciAqYywgdTMyIGNoYW5nZV9pbmQpOwoKLyogZ2xvYmFsIHdhaXQgbGlzdCBmb3IgUE9TVCBXQUlUICovCnN0YXRpYyBMSVNUX0hFQUQoaTJvX2V4ZWNfd2FpdF9saXN0KTsKCi8qIFdhaXQgc3RydWN0IG5lZWRlZCBmb3IgUE9TVCBXQUlUICovCnN0cnVjdCBpMm9fZXhlY193YWl0IHsKCXdhaXRfcXVldWVfaGVhZF90ICp3cTsJLyogUG9pbnRlciB0byBXYWl0IHF1ZXVlICovCglzdHJ1Y3QgaTJvX2RtYSBkbWE7CS8qIERNQSBidWZmZXJzIHRvIGZyZWUgb24gZmFpbHVyZSAqLwoJdTMyIHRjbnR4dDsJCS8qIHRyYW5zYWN0aW9uIGNvbnRleHQgZnJvbSByZXBseSAqLwoJaW50IGNvbXBsZXRlOwkJLyogMSBpZiByZXBseSByZWNlaXZlZCBvdGhlcndpc2UgMCAqLwoJdTMyIG07CQkJLyogbWVzc2FnZSBpZCAqLwoJc3RydWN0IGkyb19tZXNzYWdlICptc2c7CS8qIHBvaW50ZXIgdG8gdGhlIHJlcGx5IG1lc3NhZ2UgKi8KCXN0cnVjdCBsaXN0X2hlYWQgbGlzdDsJLyogbm9kZSBpbiBnbG9iYWwgd2FpdCBsaXN0ICovCglzcGlubG9ja190IGxvY2s7CS8qIGxvY2sgYmVmb3JlIG1vZGlmeWluZyAqLwp9OwoKLyogV29yayBzdHJ1Y3QgbmVlZGVkIHRvIGhhbmRsZSBMQ1QgTk9USUZZIHJlcGxpZXMgKi8Kc3RydWN0IGkyb19leGVjX2xjdF9ub3RpZnlfd29yayB7CglzdHJ1Y3Qgd29ya19zdHJ1Y3Qgd29yazsJLyogd29yayBzdHJ1Y3QgKi8KCXN0cnVjdCBpMm9fY29udHJvbGxlciAqYzsJLyogY29udHJvbGxlciBvbiB3aGljaCB0aGUgTENUIE5PVElGWQoJCQkJCSAgIHdhcyByZWNlaXZlZCAqLwp9OwoKLyogRXhlYyBPU00gY2xhc3MgaGFuZGxpbmcgZGVmaW5pdGlvbiAqLwpzdGF0aWMgc3RydWN0IGkyb19jbGFzc19pZCBpMm9fZXhlY19jbGFzc19pZFtdID0gewoJe0kyT19DTEFTU19FWEVDVVRJVkV9LAoJe0kyT19DTEFTU19FTkR9Cn07CgovKioKICoJaTJvX2V4ZWNfd2FpdF9hbGxvYyAtIEFsbG9jYXRlIGEgaTJvX2V4ZWNfd2FpdCBzdHJ1Y3QgYW4gaW5pdGlhbGl6ZSBpdAogKgogKglBbGxvY2F0ZSB0aGUgaTJvX2V4ZWNfd2FpdCBzdHJ1Y3QgYW5kIGluaXRpYWxpemUgdGhlIHdhaXQuCiAqCiAqCVJldHVybnMgaTJvX2V4ZWNfd2FpdCBwb2ludGVyIG9uIHN1Y2Nlc3Mgb3IgbmVnYXRpdmUgZXJyb3IgY29kZSBvbgogKglmYWlsdXJlLgogKi8Kc3RhdGljIHN0cnVjdCBpMm9fZXhlY193YWl0ICppMm9fZXhlY193YWl0X2FsbG9jKHZvaWQpCnsKCXN0cnVjdCBpMm9fZXhlY193YWl0ICp3YWl0OwoKCXdhaXQgPSBremFsbG9jKHNpemVvZigqd2FpdCksIEdGUF9LRVJORUwpOwoJaWYgKCF3YWl0KQoJCXJldHVybiBOVUxMOwoKCUlOSVRfTElTVF9IRUFEKCZ3YWl0LT5saXN0KTsKCXNwaW5fbG9ja19pbml0KCZ3YWl0LT5sb2NrKTsKCglyZXR1cm4gd2FpdDsKfTsKCi8qKgogKglpMm9fZXhlY193YWl0X2ZyZWUgLSBGcmVlIGEgaTJvX2V4ZWNfd2FpdCBzdHJ1Y3QKICoJQGkyb19leGVjX3dhaXQ6IEkyTyB3YWl0IGRhdGEgd2hpY2ggc2hvdWxkIGJlIGNsZWFuZWQgdXAKICovCnN0YXRpYyB2b2lkIGkyb19leGVjX3dhaXRfZnJlZShzdHJ1Y3QgaTJvX2V4ZWNfd2FpdCAqd2FpdCkKewoJa2ZyZWUod2FpdCk7Cn07CgovKioKICogCWkyb19tc2dfcG9zdF93YWl0X21lbSAtIFBvc3QgYW5kIHdhaXQgYSBtZXNzYWdlIHdpdGggRE1BIGJ1ZmZlcnMKICoJQGM6IGNvbnRyb2xsZXIKICoJQG06IG1lc3NhZ2UgdG8gcG9zdAogKglAdGltZW91dDogdGltZSBpbiBzZWNvbmRzIHRvIHdhaXQKICoJQGRtYTogaTJvX2RtYSBzdHJ1Y3Qgb2YgdGhlIERNQSBidWZmZXIgdG8gZnJlZSBvbiBmYWlsdXJlCiAqCiAqIAlUaGlzIEFQSSBhbGxvd3MgYW4gT1NNIHRvIHBvc3QgYSBtZXNzYWdlIGFuZCB0aGVuIGJlIHRvbGQgd2hldGhlciBvcgogKglub3QgdGhlIHN5c3RlbSByZWNlaXZlZCBhIHN1Y2Nlc3NmdWwgcmVwbHkuIElmIHRoZSBtZXNzYWdlIHRpbWVzIG91dAogKgl0aGVuIHRoZSB2YWx1ZSAnLUVUSU1FRE9VVCcgaXMgcmV0dXJuZWQuIFRoaXMgaXMgYSBzcGVjaWFsIGNhc2UuIEluCiAqCXRoaXMgc2l0dWF0aW9uIHRoZSBtZXNzYWdlIG1heSAoc2hvdWxkKSBjb21wbGV0ZSBhdCBhbiBpbmRlZmluaXRlIHRpbWUKICoJaW4gdGhlIGZ1dHVyZS4gV2hlbiBpdCBjb21wbGV0ZXMgaXQgd2lsbCB1c2UgdGhlIG1lbW9yeSBidWZmZXIKICoJYXR0YWNoZWQgdG8gdGhlIHJlcXVlc3QuIElmIC1FVElNRURPVVQgaXMgcmV0dXJuZWQgdGhlbiB0aGUgbWVtb3J5CiAqCWJ1ZmZlciBtdXN0IG5vdCBiZSBmcmVlZC4gSW5zdGVhZCB0aGUgZXZlbnQgY29tcGxldGlvbiB3aWxsIGZyZWUgdGhlbQogKglmb3IgeW91LiBJbiBhbGwgb3RoZXIgY2FzZXMgdGhlIGJ1ZmZlciBhcmUgeW91ciBwcm9ibGVtLgogKgogKglSZXR1cm5zIDAgb24gc3VjY2VzcywgbmVnYXRpdmUgZXJyb3IgY29kZSBvbiB0aW1lb3V0IG9yIHBvc2l0aXZlIGVycm9yCiAqCWNvZGUgZnJvbSByZXBseS4KICovCmludCBpMm9fbXNnX3Bvc3Rfd2FpdF9tZW0oc3RydWN0IGkyb19jb250cm9sbGVyICpjLCBzdHJ1Y3QgaTJvX21lc3NhZ2UgKm1zZywKCQkJICB1bnNpZ25lZCBsb25nIHRpbWVvdXQsIHN0cnVjdCBpMm9fZG1hICpkbWEpCnsKCURFQ0xBUkVfV0FJVF9RVUVVRV9IRUFEKHdxKTsKCXN0cnVjdCBpMm9fZXhlY193YWl0ICp3YWl0OwoJc3RhdGljIHUzMiB0Y250eHQgPSAweDgwMDAwMDAwOwoJdW5zaWduZWQgbG9uZyBmbGFnczsKCWludCByYyA9IDA7CgoJd2FpdCA9IGkyb19leGVjX3dhaXRfYWxsb2MoKTsKCWlmICghd2FpdCkKCQlyZXR1cm4gLUVOT01FTTsKCglpZiAodGNudHh0ID09IDB4ZmZmZmZmZmYpCgkJdGNudHh0ID0gMHg4MDAwMDAwMDsKCglpZiAoZG1hKQoJCXdhaXQtPmRtYSA9ICpkbWE7CgoJLyoKCSAqIEZpbGwgaW4gdGhlIG1lc3NhZ2UgaW5pdGlhdG9yIGNvbnRleHQgYW5kIHRyYW5zYWN0aW9uIGNvbnRleHQuCgkgKiBXZSB3aWxsIG9ubHkgdXNlIHRyYW5zYWN0aW9uIGNvbnRleHRzID49IDB4ODAwMDAwMDAgZm9yIFBPU1QgV0FJVCwKCSAqIHNvIHdlIGNvdWxkIGZpbmQgYSBQT1NUIFdBSVQgcmVwbHkgZWFzaWVyIGluIHRoZSByZXBseSBoYW5kbGVyLgoJICovCgltc2ctPnUucy5pY250eHQgPSBjcHVfdG9fbGUzMihpMm9fZXhlY19kcml2ZXIuY29udGV4dCk7Cgl3YWl0LT50Y250eHQgPSB0Y250eHQrKzsKCW1zZy0+dS5zLnRjbnR4dCA9IGNwdV90b19sZTMyKHdhaXQtPnRjbnR4dCk7CgoJd2FpdC0+d3EgPSAmd3E7CgkvKgoJICogd2UgYWRkIGVsZW1lbnRzIHRvIHRoZSBoZWFkLCBiZWNhdXNlIGlmIGEgZW50cnkgaW4gdGhlIGxpc3Qgd2lsbAoJICogbmV2ZXIgYmUgcmVtb3ZlZCwgd2UgaGF2ZSB0byBpdGVyYXRlIG92ZXIgaXQgZXZlcnkgdGltZQoJICovCglsaXN0X2FkZCgmd2FpdC0+bGlzdCwgJmkyb19leGVjX3dhaXRfbGlzdCk7CgoJLyoKCSAqIFBvc3QgdGhlIG1lc3NhZ2UgdG8gdGhlIGNvbnRyb2xsZXIuIEF0IHNvbWUgcG9pbnQgbGF0ZXIgaXQgd2lsbAoJICogcmV0dXJuLiBJZiB3ZSB0aW1lIG91dCBiZWZvcmUgaXQgcmV0dXJucyB0aGVuIGNvbXBsZXRlIHdpbGwgYmUgemVyby4KCSAqLwoJaTJvX21zZ19wb3N0KGMsIG1zZyk7CgoJd2FpdF9ldmVudF9pbnRlcnJ1cHRpYmxlX3RpbWVvdXQod3EsIHdhaXQtPmNvbXBsZXRlLCB0aW1lb3V0ICogSFopOwoKCXNwaW5fbG9ja19pcnFzYXZlKCZ3YWl0LT5sb2NrLCBmbGFncyk7CgoJd2FpdC0+d3EgPSBOVUxMOwoKCWlmICh3YWl0LT5jb21wbGV0ZSkKCQlyYyA9IGxlMzJfdG9fY3B1KHdhaXQtPm1zZy0+Ym9keVswXSkgPj4gMjQ7CgllbHNlIHsKCQkvKgoJCSAqIFdlIGNhbm5vdCByZW1vdmUgaXQgbm93LiBUaGlzIGlzIGltcG9ydGFudC4gV2hlbiBpdCBkb2VzCgkJICogdGVybWluYXRlICh3aGljaCBpdCBtdXN0IGRvIGlmIHRoZSBjb250cm9sbGVyIGhhcyBub3QKCQkgKiBkaWVkLi4uKSB0aGVuIGl0IHdpbGwgb3RoZXJ3aXNlIHNjcmliYmxlIG9uIHN0dWZmLgoJCSAqCgkJICogRklYTUU6IHRyeSBhYm9ydCBtZXNzYWdlCgkJICovCgkJaWYgKGRtYSkKCQkJZG1hLT52aXJ0ID0gTlVMTDsKCgkJcmMgPSAtRVRJTUVET1VUOwoJfQoKCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJndhaXQtPmxvY2ssIGZsYWdzKTsKCglpZiAocmMgIT0gLUVUSU1FRE9VVCkgewoJCWkyb19mbHVzaF9yZXBseShjLCB3YWl0LT5tKTsKCQlpMm9fZXhlY193YWl0X2ZyZWUod2FpdCk7Cgl9CgoJcmV0dXJuIHJjOwp9OwoKLyoqCiAqCWkyb19tc2dfcG9zdF93YWl0X2NvbXBsZXRlIC0gUmVwbHkgdG8gYSBpMm9fbXNnX3Bvc3QgcmVxdWVzdCBmcm9tIElPUAogKglAYzogSTJPIGNvbnRyb2xsZXIgd2hpY2ggYW5zd2VycwogKglAbTogbWVzc2FnZSBpZAogKglAbXNnOiBwb2ludGVyIHRvIHRoZSBJMk8gcmVwbHkgbWVzc2FnZQogKglAY29udGV4dDogdHJhbnNhY3Rpb24gY29udGV4dCBvZiByZXF1ZXN0CiAqCiAqCVRoaXMgZnVuY3Rpb24gaXMgY2FsbGVkIGluIGludGVycnVwdCBjb250ZXh0IG9ubHkuIElmIHRoZSByZXBseSByZWFjaGVkCiAqCWJlZm9yZSB0aGUgdGltZW91dCwgdGhlIGkyb19leGVjX3dhaXQgc3RydWN0IGlzIGZpbGxlZCB3aXRoIHRoZSBtZXNzYWdlCiAqCWFuZCB0aGUgdGFzayB3aWxsIGJlIHdha2VkIHVwLiBUaGUgdGFzayBpcyBub3cgcmVzcG9uc2libGUgZm9yIHJldHVybmluZwogKgl0aGUgbWVzc2FnZSBtIGJhY2sgdG8gdGhlIGNvbnRyb2xsZXIhIElmIHRoZSBtZXNzYWdlIHJlYWNoZXMgdXMgYWZ0ZXIKICoJdGhlIHRpbWVvdXQgY2xlYW4gdXAgdGhlIGkyb19leGVjX3dhaXQgc3RydWN0IChpbmNsdWRpbmcgYWxsb2NhdGVkCiAqCURNQSBidWZmZXIpLgogKgogKglSZXR1cm4gMCBvbiBzdWNjZXNzIGFuZCBpZiB0aGUgbWVzc2FnZSBtIHNob3VsZCBub3QgYmUgZ2l2ZW4gYmFjayB0byB0aGUKICoJSTJPIGNvbnRyb2xsZXIsIG9yID4wIG9uIHN1Y2Nlc3MgYW5kIGlmIHRoZSBtZXNzYWdlIHNob3VsZCBiZSBnaXZlbiBiYWNrCiAqCWFmdGVyd29yZHMuIFJldHVybnMgbmVnYXRpdmUgZXJyb3IgY29kZSBvbiBmYWlsdXJlLiBJbiB0aGlzIGNhc2UgdGhlCiAqCW1lc3NhZ2UgbXVzdCBhbHNvIGJlIGdpdmVuIGJhY2sgdG8gdGhlIGNvbnRyb2xsZXIuCiAqLwpzdGF0aWMgaW50IGkyb19tc2dfcG9zdF93YWl0X2NvbXBsZXRlKHN0cnVjdCBpMm9fY29udHJvbGxlciAqYywgdTMyIG0sCgkJCQkgICAgICBzdHJ1Y3QgaTJvX21lc3NhZ2UgKm1zZywgdTMyIGNvbnRleHQpCnsKCXN0cnVjdCBpMm9fZXhlY193YWl0ICp3YWl0LCAqdG1wOwoJdW5zaWduZWQgbG9uZyBmbGFnczsKCWludCByYyA9IDE7CgoJLyoKCSAqIFdlIG5lZWQgdG8gc2VhcmNoIHRocm91Z2ggdGhlIGkyb19leGVjX3dhaXRfbGlzdCB0byBzZWUgaWYgdGhlIGdpdmVuCgkgKiBtZXNzYWdlIGlzIHN0aWxsIG91dHN0YW5kaW5nLiBJZiBub3QsIGl0IG1lYW5zIHRoYXQgdGhlIElPUCB0b29rCgkgKiBsb25nZXIgdG8gcmVzcG9uZCB0byB0aGUgbWVzc2FnZSB0aGFuIHdlIGhhZCBhbGxvd2VkIGFuZCB0aW1lciBoYXMKCSAqIGFscmVhZHkgZXhwaXJlZC4gTm90IG11Y2ggd2UgY2FuIGRvIGFib3V0IHRoYXQgZXhjZXB0IGxvZyBpdCBmb3IKCSAqIGRlYnVnIHB1cnBvc2VzLCBpbmNyZWFzZSB0aW1lb3V0LCBhbmQgcmVjb21waWxlLgoJICovCglsaXN0X2Zvcl9lYWNoX2VudHJ5X3NhZmUod2FpdCwgdG1wLCAmaTJvX2V4ZWNfd2FpdF9saXN0LCBsaXN0KSB7CgkJaWYgKHdhaXQtPnRjbnR4dCA9PSBjb250ZXh0KSB7CgkJCXNwaW5fbG9ja19pcnFzYXZlKCZ3YWl0LT5sb2NrLCBmbGFncyk7CgoJCQlsaXN0X2RlbCgmd2FpdC0+bGlzdCk7CgoJCQl3YWl0LT5tID0gbTsKCQkJd2FpdC0+bXNnID0gbXNnOwoJCQl3YWl0LT5jb21wbGV0ZSA9IDE7CgoJCQlpZiAod2FpdC0+d3EpCgkJCQlyYyA9IDA7CgkJCWVsc2UKCQkJCXJjID0gLTE7CgoJCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZ3YWl0LT5sb2NrLCBmbGFncyk7CgoJCQlpZiAocmMpIHsKCQkJCXN0cnVjdCBkZXZpY2UgKmRldjsKCgkJCQlkZXYgPSAmYy0+cGRldi0+ZGV2OwoKCQkJCXByX2RlYnVnKCIlczogdGltZWRvdXQgcmVwbHkgcmVjZWl2ZWQhXG4iLAoJCQkJCSBjLT5uYW1lKTsKCQkJCWkyb19kbWFfZnJlZShkZXYsICZ3YWl0LT5kbWEpOwoJCQkJaTJvX2V4ZWNfd2FpdF9mcmVlKHdhaXQpOwoJCQl9IGVsc2UKCQkJCXdha2VfdXBfaW50ZXJydXB0aWJsZSh3YWl0LT53cSk7CgoJCQlyZXR1cm4gcmM7CgkJfQoJfQoKCW9zbV93YXJuKCIlczogQm9ndXMgcmVwbHkgaW4gUE9TVCBXQUlUICh0ci1jb250ZXh0OiAlMDh4KSFcbiIsIGMtPm5hbWUsCgkJIGNvbnRleHQpOwoKCXJldHVybiAtMTsKfTsKCi8qKgogKglpMm9fZXhlY19zaG93X3ZlbmRvcl9pZCAtIERpc3BsYXlzIFZlbmRvciBJRCBvZiBjb250cm9sbGVyCiAqCUBkOiBkZXZpY2Ugb2Ygd2hpY2ggdGhlIFZlbmRvciBJRCBzaG91bGQgYmUgZGlzcGxheWVkCiAqCUBidWY6IGJ1ZmZlciBpbnRvIHdoaWNoIHRoZSBWZW5kb3IgSUQgc2hvdWxkIGJlIHByaW50ZWQKICoKICoJUmV0dXJucyBudW1iZXIgb2YgYnl0ZXMgcHJpbnRlZCBpbnRvIGJ1ZmZlci4KICovCnN0YXRpYyBzc2l6ZV90IGkyb19leGVjX3Nob3dfdmVuZG9yX2lkKHN0cnVjdCBkZXZpY2UgKmQsCgkJCQkgICAgICAgc3RydWN0IGRldmljZV9hdHRyaWJ1dGUgKmF0dHIsIGNoYXIgKmJ1ZikKewoJc3RydWN0IGkyb19kZXZpY2UgKmRldiA9IHRvX2kyb19kZXZpY2UoZCk7Cgl1MTYgaWQ7CgoJaWYgKCFpMm9fcGFybV9maWVsZF9nZXQoZGV2LCAweDAwMDAsIDAsICZpZCwgMikpIHsKCQlzcHJpbnRmKGJ1ZiwgIjB4JTA0eCIsIGxlMTZfdG9fY3B1KGlkKSk7CgkJcmV0dXJuIHN0cmxlbihidWYpICsgMTsKCX0KCglyZXR1cm4gMDsKfTsKCi8qKgogKglpMm9fZXhlY19zaG93X3Byb2R1Y3RfaWQgLSBEaXNwbGF5cyBQcm9kdWN0IElEIG9mIGNvbnRyb2xsZXIKICoJQGQ6IGRldmljZSBvZiB3aGljaCB0aGUgUHJvZHVjdCBJRCBzaG91bGQgYmUgZGlzcGxheWVkCiAqCUBidWY6IGJ1ZmZlciBpbnRvIHdoaWNoIHRoZSBQcm9kdWN0IElEIHNob3VsZCBiZSBwcmludGVkCiAqCiAqCVJldHVybnMgbnVtYmVyIG9mIGJ5dGVzIHByaW50ZWQgaW50byBidWZmZXIuCiAqLwpzdGF0aWMgc3NpemVfdCBpMm9fZXhlY19zaG93X3Byb2R1Y3RfaWQoc3RydWN0IGRldmljZSAqZCwKCQkJCQlzdHJ1Y3QgZGV2aWNlX2F0dHJpYnV0ZSAqYXR0ciwKCQkJCQljaGFyICpidWYpCnsKCXN0cnVjdCBpMm9fZGV2aWNlICpkZXYgPSB0b19pMm9fZGV2aWNlKGQpOwoJdTE2IGlkOwoKCWlmICghaTJvX3Bhcm1fZmllbGRfZ2V0KGRldiwgMHgwMDAwLCAxLCAmaWQsIDIpKSB7CgkJc3ByaW50ZihidWYsICIweCUwNHgiLCBsZTE2X3RvX2NwdShpZCkpOwoJCXJldHVybiBzdHJsZW4oYnVmKSArIDE7Cgl9CgoJcmV0dXJuIDA7Cn07CgovKiBFeGVjLU9TTSBkZXZpY2UgYXR0cmlidXRlcyAqLwpzdGF0aWMgREVWSUNFX0FUVFIodmVuZG9yX2lkLCBTX0lSVUdPLCBpMm9fZXhlY19zaG93X3ZlbmRvcl9pZCwgTlVMTCk7CnN0YXRpYyBERVZJQ0VfQVRUUihwcm9kdWN0X2lkLCBTX0lSVUdPLCBpMm9fZXhlY19zaG93X3Byb2R1Y3RfaWQsIE5VTEwpOwoKLyoqCiAqCWkyb19leGVjX3Byb2JlIC0gQ2FsbGVkIGlmIGEgbmV3IEkyTyBkZXZpY2UgKGV4ZWN1dGl2ZSBjbGFzcykgYXBwZWFycwogKglAZGV2OiBJMk8gZGV2aWNlIHdoaWNoIHNob3VsZCBiZSBwcm9iZWQKICoKICoJUmVnaXN0ZXJzIGV2ZW50IG5vdGlmaWNhdGlvbiBmb3IgZXZlcnkgZXZlbnQgZnJvbSBFeGVjdXRpdmUgZGV2aWNlLiBUaGUKICoJcmV0dXJuIGlzIGFsd2F5cyAwLCBiZWNhdXNlIHdlIHdhbnQgYWxsIGRldmljZXMgb2YgY2xhc3MgRXhlY3V0aXZlLgogKgogKglSZXR1cm5zIDAgb24gc3VjY2Vzcy4KICovCnN0YXRpYyBpbnQgaTJvX2V4ZWNfcHJvYmUoc3RydWN0IGRldmljZSAqZGV2KQp7CglzdHJ1Y3QgaTJvX2RldmljZSAqaTJvX2RldiA9IHRvX2kyb19kZXZpY2UoZGV2KTsKCWludCByYzsKCglyYyA9IGkyb19ldmVudF9yZWdpc3RlcihpMm9fZGV2LCAmaTJvX2V4ZWNfZHJpdmVyLCAwLCAweGZmZmZmZmZmKTsKCWlmIChyYykgZ290byBlcnJfb3V0OwoKCXJjID0gZGV2aWNlX2NyZWF0ZV9maWxlKGRldiwgJmRldl9hdHRyX3ZlbmRvcl9pZCk7CglpZiAocmMpIGdvdG8gZXJyX2V2dHJlZzsKCXJjID0gZGV2aWNlX2NyZWF0ZV9maWxlKGRldiwgJmRldl9hdHRyX3Byb2R1Y3RfaWQpOwoJaWYgKHJjKSBnb3RvIGVycl92aWQ7CgoJcmV0dXJuIDA7CgplcnJfdmlkOgoJZGV2aWNlX3JlbW92ZV9maWxlKGRldiwgJmRldl9hdHRyX3ZlbmRvcl9pZCk7CmVycl9ldnRyZWc6CglpMm9fZXZlbnRfcmVnaXN0ZXIodG9faTJvX2RldmljZShkZXYpLCAmaTJvX2V4ZWNfZHJpdmVyLCAwLCAwKTsKZXJyX291dDoKCXJldHVybiByYzsKfTsKCi8qKgogKglpMm9fZXhlY19yZW1vdmUgLSBDYWxsZWQgb24gSTJPIGRldmljZSByZW1vdmFsCiAqCUBkZXY6IEkyTyBkZXZpY2Ugd2hpY2ggd2FzIHJlbW92ZWQKICoKICoJVW5yZWdpc3RlcnMgZXZlbnQgbm90aWZpY2F0aW9uIGZyb20gRXhlY3V0aXZlIEkyTyBkZXZpY2UuCiAqCiAqCVJldHVybnMgMCBvbiBzdWNjZXNzLgogKi8Kc3RhdGljIGludCBpMm9fZXhlY19yZW1vdmUoc3RydWN0IGRldmljZSAqZGV2KQp7CglkZXZpY2VfcmVtb3ZlX2ZpbGUoZGV2LCAmZGV2X2F0dHJfcHJvZHVjdF9pZCk7CglkZXZpY2VfcmVtb3ZlX2ZpbGUoZGV2LCAmZGV2X2F0dHJfdmVuZG9yX2lkKTsKCglpMm9fZXZlbnRfcmVnaXN0ZXIodG9faTJvX2RldmljZShkZXYpLCAmaTJvX2V4ZWNfZHJpdmVyLCAwLCAwKTsKCglyZXR1cm4gMDsKfTsKCi8qKgogKglpMm9fZXhlY19sY3RfbW9kaWZpZWQgLSBDYWxsZWQgb24gTENUIE5PVElGWSByZXBseQogKglAYzogSTJPIGNvbnRyb2xsZXIgb24gd2hpY2ggdGhlIExDVCBoYXMgbW9kaWZpZWQKICoKICoJVGhpcyBmdW5jdGlvbiBoYW5kbGVzIGFzeW5jaHJvbnVzIExDVCBOT1RJRlkgcmVwbGllcy4gSXQgcGFyc2VzIHRoZQogKgluZXcgTENUIGFuZCBpZiB0aGUgYnVmZmVyIGZvciB0aGUgTENUIHdhcyB0byBzbWFsbCBzZW5kcyBhIExDVCBOT1RJRlkKICoJYWdhaW4sIG90aGVyd2lzZSBzZW5kIExDVCBOT1RJRlkgdG8gZ2V0IGluZm9ybWVkIG9uIG5leHQgTENUIGNoYW5nZS4KICovCnN0YXRpYyB2b2lkIGkyb19leGVjX2xjdF9tb2RpZmllZChzdHJ1Y3QgaTJvX2V4ZWNfbGN0X25vdGlmeV93b3JrICp3b3JrKQp7Cgl1MzIgY2hhbmdlX2luZCA9IDA7CglzdHJ1Y3QgaTJvX2NvbnRyb2xsZXIgKmMgPSB3b3JrLT5jOwoKCWtmcmVlKHdvcmspOwoKCWlmIChpMm9fZGV2aWNlX3BhcnNlX2xjdChjKSAhPSAtRUFHQUlOKQoJCWNoYW5nZV9pbmQgPSBjLT5sY3QtPmNoYW5nZV9pbmQgKyAxOwoKI2lmZGVmIENPTkZJR19JMk9fTENUX05PVElGWV9PTl9DSEFOR0VTCglpMm9fZXhlY19sY3Rfbm90aWZ5KGMsIGNoYW5nZV9pbmQpOwojZW5kaWYKfTsKCi8qKgogKglpMm9fZXhlY19yZXBseSAtICBJMk8gRXhlY3V0aXZlIHJlcGx5IGhhbmRsZXIKICoJQGM6IEkyTyBjb250cm9sbGVyIGZyb20gd2hpY2ggdGhlIHJlcGx5IGNvbWVzCiAqCUBtOiBtZXNzYWdlIGlkCiAqCUBtc2c6IHBvaW50ZXIgdG8gdGhlIEkyTyByZXBseSBtZXNzYWdlCiAqCiAqCVRoaXMgZnVuY3Rpb24gaXMgYWx3YXlzIGNhbGxlZCBmcm9tIGludGVycnVwdCBjb250ZXh0LiBJZiBhIFBPU1QgV0FJVAogKglyZXBseSB3YXMgcmVjZWl2ZWQsIHBhc3MgaXQgdG8gdGhlIGNvbXBsZXRlIGZ1bmN0aW9uLiBJZiBhIExDVCBOT1RJRlkKICoJcmVwbHkgd2FzIHJlY2VpdmVkLCBhIG5ldyBldmVudCBpcyBjcmVhdGVkIHRvIGhhbmRsZSB0aGUgdXBkYXRlLgogKgogKglSZXR1cm5zIDAgb24gc3VjY2VzcyBhbmQgaWYgdGhlIHJlcGx5IHNob3VsZCBub3QgYmUgZmx1c2hlZCBvciA+IDAKICoJb24gc3VjY2VzcyBhbmQgaWYgdGhlIHJlcGx5IHNob3VsZCBiZSBmbHVzaGVkLiBSZXR1cm5zIG5lZ2F0aXZlIGVycm9yCiAqCWNvZGUgb24gZmFpbHVyZSBhbmQgaWYgdGhlIHJlcGx5IHNob3VsZCBiZSBmbHVzaGVkLgogKi8Kc3RhdGljIGludCBpMm9fZXhlY19yZXBseShzdHJ1Y3QgaTJvX2NvbnRyb2xsZXIgKmMsIHUzMiBtLAoJCQkgIHN0cnVjdCBpMm9fbWVzc2FnZSAqbXNnKQp7Cgl1MzIgY29udGV4dDsKCglpZiAobGUzMl90b19jcHUobXNnLT51LmhlYWRbMF0pICYgTVNHX0ZBSUwpIHsKCQlzdHJ1Y3QgaTJvX21lc3NhZ2UgX19pb21lbSAqcG1zZzsKCQl1MzIgcG07CgoJCS8qCgkJICogSWYgRmFpbCBiaXQgaXMgc2V0IHdlIG11c3QgdGFrZSB0aGUgdHJhbnNhY3Rpb24gY29udGV4dCBvZgoJCSAqIHRoZSBwcmVzZXJ2ZWQgbWVzc2FnZSB0byBmaW5kIHRoZSByaWdodCByZXF1ZXN0IGFnYWluLgoJCSAqLwoKCQlwbSA9IGxlMzJfdG9fY3B1KG1zZy0+Ym9keVszXSk7CgkJcG1zZyA9IGkyb19tc2dfaW5fdG9fdmlydChjLCBwbSk7CgkJY29udGV4dCA9IHJlYWRsKCZwbXNnLT51LnMudGNudHh0KTsKCgkJaTJvX3JlcG9ydF9zdGF0dXMoS0VSTl9JTkZPLCAiaTJvX2NvcmUiLCBtc2cpOwoKCQkvKiBSZWxlYXNlIHRoZSBwcmVzZXJ2ZWQgbXNnICovCgkJaTJvX21zZ19ub3BfbWZhKGMsIHBtKTsKCX0gZWxzZQoJCWNvbnRleHQgPSBsZTMyX3RvX2NwdShtc2ctPnUucy50Y250eHQpOwoKCWlmIChjb250ZXh0ICYgMHg4MDAwMDAwMCkKCQlyZXR1cm4gaTJvX21zZ19wb3N0X3dhaXRfY29tcGxldGUoYywgbSwgbXNnLCBjb250ZXh0KTsKCglpZiAoKGxlMzJfdG9fY3B1KG1zZy0+dS5oZWFkWzFdKSA+PiAyNCkgPT0gSTJPX0NNRF9MQ1RfTk9USUZZKSB7CgkJc3RydWN0IGkyb19leGVjX2xjdF9ub3RpZnlfd29yayAqd29yazsKCgkJcHJfZGVidWcoIiVzOiBMQ1Qgbm90aWZ5IHJlY2VpdmVkXG4iLCBjLT5uYW1lKTsKCgkJd29yayA9IGttYWxsb2Moc2l6ZW9mKCp3b3JrKSwgR0ZQX0FUT01JQyk7CgkJaWYgKCF3b3JrKQoJCQlyZXR1cm4gLUVOT01FTTsKCgkJd29yay0+YyA9IGM7CgoJCUlOSVRfV09SSygmd29yay0+d29yaywgKHZvaWQgKCopKHZvaWQgKikpaTJvX2V4ZWNfbGN0X21vZGlmaWVkLAoJCQkgIHdvcmspOwoJCXF1ZXVlX3dvcmsoaTJvX2V4ZWNfZHJpdmVyLmV2ZW50X3F1ZXVlLCAmd29yay0+d29yayk7CgkJcmV0dXJuIDE7Cgl9CgoJLyoKCSAqIElmIHRoaXMgaGFwcGVucywgd2Ugd2FudCB0byBkdW1wIHRoZSBtZXNzYWdlIHRvIHRoZSBzeXNsb2cgc28KCSAqIGl0IGNhbiBiZSBzZW50IGJhY2sgdG8gdGhlIGNhcmQgbWFudWZhY3R1cmVyIGJ5IHRoZSBlbmQgdXNlcgoJICogdG8gYWlkIGluIGRlYnVnZ2luZy4KCSAqCgkgKi8KCXByaW50ayhLRVJOX1dBUk5JTkcgIiVzOiBVbnNvbGljaXRlZCBtZXNzYWdlIHJlcGx5IHNlbnQgdG8gY29yZSEiCgkgICAgICAgIk1lc3NhZ2UgZHVtcGVkIHRvIHN5c2xvZ1xuIiwgYy0+bmFtZSk7CglpMm9fZHVtcF9tZXNzYWdlKG1zZyk7CgoJcmV0dXJuIC1FRkFVTFQ7Cn0KCi8qKgogKglpMm9fZXhlY19ldmVudCAtIEV2ZW50IGhhbmRsaW5nIGZ1bmN0aW9uCiAqCUBldnQ6IEV2ZW50IHdoaWNoIG9jY3VycwogKgogKglIYW5kbGVzIGV2ZW50cyBzZW5kIGJ5IHRoZSBFeGVjdXRpdmUgZGV2aWNlLiBBdCB0aGUgbW9tZW50IGRvZXMgbm90IGRvCiAqCWFueXRoaW5nIHVzZWZ1bC4KICovCnN0YXRpYyB2b2lkIGkyb19leGVjX2V2ZW50KHN0cnVjdCBpMm9fZXZlbnQgKmV2dCkKewoJaWYgKGxpa2VseShldnQtPmkyb19kZXYpKQoJCW9zbV9kZWJ1ZygiRXZlbnQgcmVjZWl2ZWQgZnJvbSBkZXZpY2U6ICVkXG4iLAoJCQkgIGV2dC0+aTJvX2Rldi0+bGN0X2RhdGEudGlkKTsKCWtmcmVlKGV2dCk7Cn07CgovKioKICoJaTJvX2V4ZWNfbGN0X2dldCAtIEdldCB0aGUgSU9QJ3MgTG9naWNhbCBDb25maWd1cmF0aW9uIFRhYmxlCiAqCUBjOiBJMk8gY29udHJvbGxlciBmcm9tIHdoaWNoIHRoZSBMQ1Qgc2hvdWxkIGJlIGZldGNoZWQKICoKICoJU2VuZCBhIExDVCBOT1RJRlkgcmVxdWVzdCB0byB0aGUgY29udHJvbGxlciwgYW5kIHdhaXQKICoJSTJPX1RJTUVPVVRfTENUX0dFVCBzZWNvbmRzIHVudGlsIGFycml2YWwgb2YgcmVzcG9uc2UuIElmIHRoZSBMQ1QgaXMKICoJdG8gbGFyZ2UsIHJldHJ5IGl0LgogKgogKglSZXR1cm5zIDAgb24gc3VjY2VzcyBvciBuZWdhdGl2ZSBlcnJvciBjb2RlIG9uIGZhaWx1cmUuCiAqLwppbnQgaTJvX2V4ZWNfbGN0X2dldChzdHJ1Y3QgaTJvX2NvbnRyb2xsZXIgKmMpCnsKCXN0cnVjdCBpMm9fbWVzc2FnZSAqbXNnOwoJaW50IGkgPSAwOwoJaW50IHJjID0gLUVBR0FJTjsKCglmb3IgKGkgPSAxOyBpIDw9IEkyT19MQ1RfR0VUX1RSSUVTOyBpKyspIHsKCQltc2cgPSBpMm9fbXNnX2dldF93YWl0KGMsIEkyT19USU1FT1VUX01FU1NBR0VfR0VUKTsKCQlpZiAoSVNfRVJSKG1zZykpCgkJCXJldHVybiBQVFJfRVJSKG1zZyk7CgoJCW1zZy0+dS5oZWFkWzBdID0KCQkgICAgY3B1X3RvX2xlMzIoRUlHSFRfV09SRF9NU0dfU0laRSB8IFNHTF9PRkZTRVRfNik7CgkJbXNnLT51LmhlYWRbMV0gPQoJCSAgICBjcHVfdG9fbGUzMihJMk9fQ01EX0xDVF9OT1RJRlkgPDwgMjQgfCBIT1NUX1RJRCA8PCAxMiB8CgkJCQlBREFQVEVSX1RJRCk7CgkJbXNnLT5ib2R5WzBdID0gY3B1X3RvX2xlMzIoMHhmZmZmZmZmZik7CgkJbXNnLT5ib2R5WzFdID0gY3B1X3RvX2xlMzIoMHgwMDAwMDAwMCk7CgkJbXNnLT5ib2R5WzJdID0gY3B1X3RvX2xlMzIoMHhkMDAwMDAwMCB8IGMtPmRsY3QubGVuKTsKCQltc2ctPmJvZHlbM10gPSBjcHVfdG9fbGUzMihjLT5kbGN0LnBoeXMpOwoKCQlyYyA9IGkyb19tc2dfcG9zdF93YWl0KGMsIG1zZywgSTJPX1RJTUVPVVRfTENUX0dFVCk7CgkJaWYgKHJjIDwgMCkKCQkJYnJlYWs7CgoJCXJjID0gaTJvX2RldmljZV9wYXJzZV9sY3QoYyk7CgkJaWYgKHJjICE9IC1FQUdBSU4pCgkJCWJyZWFrOwoJfQoKCXJldHVybiByYzsKfQoKLyoqCiAqCWkyb19leGVjX2xjdF9ub3RpZnkgLSBTZW5kIGEgYXN5bmNocm9udXMgTENUIE5PVElGWSByZXF1ZXN0CiAqCUBjOiBJMk8gY29udHJvbGxlciB0byB3aGljaCB0aGUgcmVxdWVzdCBzaG91bGQgYmUgc2VuZAogKglAY2hhbmdlX2luZDogY2hhbmdlIGluZGljYXRvcgogKgogKglUaGlzIGZ1bmN0aW9uIHNlbmRzIGEgTENUIE5PVElGWSByZXF1ZXN0IHRvIHRoZSBJMk8gY29udHJvbGxlciB3aXRoCiAqCXRoZSBjaGFuZ2UgaW5kaWNhdG9yIGNoYW5nZV9pbmQuIElmIHRoZSBjaGFuZ2VfaW5kID09IDAgdGhlIGNvbnRyb2xsZXIKICoJcmVwbGllcyBpbW1lZGlhdGVseSBhZnRlciB0aGUgcmVxdWVzdC4gSWYgY2hhbmdlX2luZCA+IDAgdGhlIHJlcGx5IGlzCiAqCXNlbmQgYWZ0ZXIgY2hhbmdlIGluZGljYXRvciBvZiB0aGUgTENUIGlzID4gY2hhbmdlX2luZC4KICovCnN0YXRpYyBpbnQgaTJvX2V4ZWNfbGN0X25vdGlmeShzdHJ1Y3QgaTJvX2NvbnRyb2xsZXIgKmMsIHUzMiBjaGFuZ2VfaW5kKQp7CglpMm9fc3RhdHVzX2Jsb2NrICpzYiA9IGMtPnN0YXR1c19ibG9jay52aXJ0OwoJc3RydWN0IGRldmljZSAqZGV2OwoJc3RydWN0IGkyb19tZXNzYWdlICptc2c7CgoJZG93bigmYy0+bGN0X2xvY2spOwoKCWRldiA9ICZjLT5wZGV2LT5kZXY7CgoJaWYgKGkyb19kbWFfcmVhbGxvYwoJICAgIChkZXYsICZjLT5kbGN0LCBsZTMyX3RvX2NwdShzYi0+ZXhwZWN0ZWRfbGN0X3NpemUpLCBHRlBfS0VSTkVMKSkKCQlyZXR1cm4gLUVOT01FTTsKCgltc2cgPSBpMm9fbXNnX2dldF93YWl0KGMsIEkyT19USU1FT1VUX01FU1NBR0VfR0VUKTsKCWlmIChJU19FUlIobXNnKSkKCQlyZXR1cm4gUFRSX0VSUihtc2cpOwoKCW1zZy0+dS5oZWFkWzBdID0gY3B1X3RvX2xlMzIoRUlHSFRfV09SRF9NU0dfU0laRSB8IFNHTF9PRkZTRVRfNik7Cgltc2ctPnUuaGVhZFsxXSA9IGNwdV90b19sZTMyKEkyT19DTURfTENUX05PVElGWSA8PCAyNCB8IEhPU1RfVElEIDw8IDEyIHwKCQkJCSAgICAgQURBUFRFUl9USUQpOwoJbXNnLT51LnMuaWNudHh0ID0gY3B1X3RvX2xlMzIoaTJvX2V4ZWNfZHJpdmVyLmNvbnRleHQpOwoJbXNnLT51LnMudGNudHh0ID0gY3B1X3RvX2xlMzIoMHgwMDAwMDAwMCk7Cgltc2ctPmJvZHlbMF0gPSBjcHVfdG9fbGUzMigweGZmZmZmZmZmKTsKCW1zZy0+Ym9keVsxXSA9IGNwdV90b19sZTMyKGNoYW5nZV9pbmQpOwoJbXNnLT5ib2R5WzJdID0gY3B1X3RvX2xlMzIoMHhkMDAwMDAwMCB8IGMtPmRsY3QubGVuKTsKCW1zZy0+Ym9keVszXSA9IGNwdV90b19sZTMyKGMtPmRsY3QucGh5cyk7CgoJaTJvX21zZ19wb3N0KGMsIG1zZyk7CgoJdXAoJmMtPmxjdF9sb2NrKTsKCglyZXR1cm4gMDsKfTsKCi8qIEV4ZWMgT1NNIGRyaXZlciBzdHJ1Y3QgKi8Kc3RydWN0IGkyb19kcml2ZXIgaTJvX2V4ZWNfZHJpdmVyID0gewoJLm5hbWUgPSBPU01fTkFNRSwKCS5yZXBseSA9IGkyb19leGVjX3JlcGx5LAoJLmV2ZW50ID0gaTJvX2V4ZWNfZXZlbnQsCgkuY2xhc3NlcyA9IGkyb19leGVjX2NsYXNzX2lkLAoJLmRyaXZlciA9IHsKCQkgICAucHJvYmUgPSBpMm9fZXhlY19wcm9iZSwKCQkgICAucmVtb3ZlID0gaTJvX2V4ZWNfcmVtb3ZlLAoJCSAgIH0sCn07CgovKioKICoJaTJvX2V4ZWNfaW5pdCAtIFJlZ2lzdGVycyB0aGUgRXhlYyBPU00KICoKICoJUmVnaXN0ZXJzIHRoZSBFeGVjIE9TTSBpbiB0aGUgSTJPIGNvcmUuCiAqCiAqCVJldHVybnMgMCBvbiBzdWNjZXNzIG9yIG5lZ2F0aXZlIGVycm9yIGNvZGUgb24gZmFpbHVyZS4KICovCmludCBfX2luaXQgaTJvX2V4ZWNfaW5pdCh2b2lkKQp7CglyZXR1cm4gaTJvX2RyaXZlcl9yZWdpc3RlcigmaTJvX2V4ZWNfZHJpdmVyKTsKfTsKCi8qKgogKglpMm9fZXhlY19leGl0IC0gUmVtb3ZlcyB0aGUgRXhlYyBPU00KICoKICoJVW5yZWdpc3RlcnMgdGhlIEV4ZWMgT1NNIGZyb20gdGhlIEkyTyBjb3JlLgogKi8Kdm9pZCBfX2V4aXQgaTJvX2V4ZWNfZXhpdCh2b2lkKQp7CglpMm9fZHJpdmVyX3VucmVnaXN0ZXIoJmkyb19leGVjX2RyaXZlcik7Cn07CgpFWFBPUlRfU1lNQk9MKGkyb19tc2dfcG9zdF93YWl0X21lbSk7CkVYUE9SVF9TWU1CT0woaTJvX2V4ZWNfbGN0X2dldCk7Cg==