LyoKICogYSBHVUkgYXBwbGljYXRpb24gZm9yIGRpc3BsYXlpbmcgYSBjb25zb2xlCiAqCVVTRVIzMiBiYWNrIGVuZAogKiBDb3B5cmlnaHQgMjAwMSBFcmljIFBvdWVjaAogKgogKiBUaGlzIGxpYnJhcnkgaXMgZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yCiAqIG1vZGlmeSBpdCB1bmRlciB0aGUgdGVybXMgb2YgdGhlIEdOVSBMZXNzZXIgR2VuZXJhbCBQdWJsaWMKICogTGljZW5zZSBhcyBwdWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyCiAqIHZlcnNpb24gMi4xIG9mIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLgogKgogKiBUaGlzIGxpYnJhcnkgaXMgZGlzdHJpYnV0ZWQgaW4gdGhlIGhvcGUgdGhhdCBpdCB3aWxsIGJlIHVzZWZ1bCwKICogYnV0IFdJVEhPVVQgQU5ZIFdBUlJBTlRZOyB3aXRob3V0IGV2ZW4gdGhlIGltcGxpZWQgd2FycmFudHkgb2YKICogTUVSQ0hBTlRBQklMSVRZIG9yIEZJVE5FU1MgRk9SIEEgUEFSVElDVUxBUiBQVVJQT1NFLiAgU2VlIHRoZSBHTlUKICogTGVzc2VyIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgZm9yIG1vcmUgZGV0YWlscy4KICoKICogWW91IHNob3VsZCBoYXZlIHJlY2VpdmVkIGEgY29weSBvZiB0aGUgR05VIExlc3NlciBHZW5lcmFsIFB1YmxpYwogKiBMaWNlbnNlIGFsb25nIHdpdGggdGhpcyBsaWJyYXJ5OyBpZiBub3QsIHdyaXRlIHRvIHRoZSBGcmVlIFNvZnR3YXJlCiAqIEZvdW5kYXRpb24sIEluYy4sIDU5IFRlbXBsZSBQbGFjZSwgU3VpdGUgMzMwLCBCb3N0b24sIE1BICAwMjExMS0xMzA3ICBVU0EKICovCgojaW5jbHVkZSA8c3RkaW8uaD4KI2luY2x1ZGUgPHN0ZGxpYi5oPgojaW5jbHVkZSAid2luZWNvbl91c2VyLmgiCgovKiBtYXBwaW5nIGNvbnNvbGUgY29sb3JzIHRvIFJHQiB2YWx1ZXMgKi8KQ09MT1JSRUYJV0NVU0VSX0NvbG9yTWFwWzE2XSA9IAp7CiAgICBSR0IoMHgwMCwgMHgwMCwgMHgwMCksIFJHQigweDAwLCAweDAwLCAweDgwKSwgUkdCKDB4MDAsIDB4ODAsIDB4MDApLCBSR0IoMHgwMCwgMHg4MCwgMHg4MCksCiAgICBSR0IoMHg4MCwgMHgwMCwgMHgwMCksIFJHQigweDgwLCAweDAwLCAweDgwKSwgUkdCKDB4ODAsIDB4ODAsIDB4MDApLCBSR0IoMHg4MCwgMHg4MCwgMHg4MCksCiAgICBSR0IoMHhDMCwgMHhDMCwgMHhDMCksIFJHQigweDAwLCAweDAwLCAweEZGKSwgUkdCKDB4MDAsIDB4RkYsIDB4MDApLCBSR0IoMHgwMCwgMHhGRiwgMHhGRiksCiAgICBSR0IoMHhGRiwgMHgwMCwgMHgwMCksIFJHQigweEZGLCAweDAwLCAweEZGKSwgUkdCKDB4RkYsIDB4RkYsIDB4MDApLCBSR0IoMHhGRiwgMHhGRiwgMHhGRiksCn07CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfRmlsbE1lbURDCiAqCiAqIEZpbGxzIHRoZSBNZW0gREMgd2l0aCBjdXJyZW50IGNlbGxzIHZhbHVlcwogKi8Kc3RhdGljIHZvaWQgV0NVU0VSX0ZpbGxNZW1EQyhjb25zdCBzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSwgaW50IHVwZF90cCwgaW50IHVwZF9ibSkKewogICAgdW5zaWduZWQJCWksIGosIGs7CiAgICBDSEFSX0lORk8qCQljZWxsOwogICAgSEZPTlQJCWhPbGRGb250OwogICAgV09SRAkJYXR0cjsKICAgIFdDSEFSKgkJbGluZTsKCiAgICBpZiAoIShsaW5lID0gSGVhcEFsbG9jKEdldFByb2Nlc3NIZWFwKCksIDAsIGRhdGEtPmN1cmNmZy5zYl93aWR0aCAqIHNpemVvZihXQ0hBUikpKSkKICAgIHtUcmFjZSgwLCAiT09NXG4iKTsgcmV0dXJuO30KCiAgICBoT2xkRm9udCA9IFNlbGVjdE9iamVjdChQUklWQVRFKGRhdGEpLT5oTWVtREMsIFBSSVZBVEUoZGF0YSktPmhGb250KTsKICAgIGZvciAoaiA9IHVwZF90cDsgaiA8PSB1cGRfYm07IGorKykKICAgIHsKCWNlbGwgPSAmZGF0YS0+Y2VsbHNbaiAqIGRhdGEtPmN1cmNmZy5zYl93aWR0aF07Cglmb3IgKGkgPSAwOyBpIDwgZGF0YS0+Y3VyY2ZnLndpbl93aWR0aDsgaSsrKQoJewoJICAgIGF0dHIgPSBjZWxsW2ldLkF0dHJpYnV0ZXM7CgkgICAgU2V0QmtDb2xvcihQUklWQVRFKGRhdGEpLT5oTWVtREMsV0NVU0VSX0NvbG9yTWFwWyhhdHRyPj40KSYweDBGXSk7CgkgICAgU2V0VGV4dENvbG9yKFBSSVZBVEUoZGF0YSktPmhNZW1EQywgV0NVU0VSX0NvbG9yTWFwW2F0dHImMHgwRl0pOwoJICAgIGZvciAoayA9IGk7IGsgPCBkYXRhLT5jdXJjZmcud2luX3dpZHRoICYmIGNlbGxba10uQXR0cmlidXRlcyA9PSBhdHRyOyBrKyspCgkgICAgewoJCWxpbmVbayAtIGldID0gY2VsbFtrXS5DaGFyLlVuaWNvZGVDaGFyOwoJICAgIH0KCSAgICBUZXh0T3V0KFBSSVZBVEUoZGF0YSktPmhNZW1EQywgaSAqIGRhdGEtPmN1cmNmZy5jZWxsX3dpZHRoLCBqICogZGF0YS0+Y3VyY2ZnLmNlbGxfaGVpZ2h0LCAKCQkgICAgbGluZSwgayAtIGkpOwoJICAgIGkgPSBrIC0gMTsKCX0KICAgIH0KICAgIFNlbGVjdE9iamVjdChQUklWQVRFKGRhdGEpLT5oTWVtREMsIGhPbGRGb250KTsKICAgIEhlYXBGcmVlKEdldFByb2Nlc3NIZWFwKCksIDAsIGxpbmUpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfTmV3Qml0bWFwCiAqCiAqIEVpdGhlciB0aGUgZm9udCBnZW9tZXRyeSBvciB0aGUgc2IgZ2VvbWV0cnkgaGFzIGNoYW5nZWQuIHdlIG5lZWQgdG8gcmVjcmVhdGUgdGhlCiAqIGJpdG1hcCBnZW9tZXRyeQogKi8Kc3RhdGljIHZvaWQgV0NVU0VSX05ld0JpdG1hcChzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSwgQk9PTCBmaWxsKQp7CiAgICBIREMgICAgICAgICBoREM7CiAgICBIQklUTUFQCWhuZXcsIGhvbGQ7CgogICAgaWYgKCFkYXRhLT5jdXJjZmcuc2Jfd2lkdGggfHwgIWRhdGEtPmN1cmNmZy5zYl9oZWlnaHQgfHwgIShoREMgPSBHZXREQyhQUklWQVRFKGRhdGEpLT5oV25kKSkpIAogICAgICAgIHJldHVybjsKICAgIGhuZXcgPSBDcmVhdGVDb21wYXRpYmxlQml0bWFwKGhEQywgCgkJCQkgIGRhdGEtPmN1cmNmZy5zYl93aWR0aCAgKiBkYXRhLT5jdXJjZmcuY2VsbF93aWR0aCwgCgkJCQkgIGRhdGEtPmN1cmNmZy5zYl9oZWlnaHQgKiBkYXRhLT5jdXJjZmcuY2VsbF9oZWlnaHQpOwogICAgUmVsZWFzZURDKFBSSVZBVEUoZGF0YSktPmhXbmQsIGhEQyk7CiAgICBob2xkID0gU2VsZWN0T2JqZWN0KFBSSVZBVEUoZGF0YSktPmhNZW1EQywgaG5ldyk7CgogICAgaWYgKFBSSVZBVEUoZGF0YSktPmhCaXRtYXApCiAgICB7CglpZiAoaG9sZCA9PSBQUklWQVRFKGRhdGEpLT5oQml0bWFwKQoJICAgIERlbGV0ZU9iamVjdChQUklWQVRFKGRhdGEpLT5oQml0bWFwKTsKCWVsc2UKCSAgICBUcmFjZSgwLCAibGVha1xuIik7CiAgICB9CiAgICBQUklWQVRFKGRhdGEpLT5oQml0bWFwID0gaG5ldzsKICAgIGlmIChmaWxsKQoJV0NVU0VSX0ZpbGxNZW1EQyhkYXRhLCAwLCBkYXRhLT5jdXJjZmcuc2JfaGVpZ2h0IC0gMSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9SZXNpemVTY3JlZW5CdWZmZXIKICoKICoKICovCnN0YXRpYyB2b2lkIFdDVVNFUl9SZXNpemVTY3JlZW5CdWZmZXIoc3RydWN0IGlubmVyX2RhdGEqIGRhdGEpCnsKICAgIFdDVVNFUl9OZXdCaXRtYXAoZGF0YSwgRkFMU0UpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfUG9zQ3Vyc29yCiAqCiAqIFNldCBhIG5ldyBwb3NpdGlvbiBmb3IgdGhlIGN1cnNvcgogKi8Kc3RhdGljIHZvaWQJV0NVU0VSX1Bvc0N1cnNvcihjb25zdCBzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSkKewogICAgaWYgKFBSSVZBVEUoZGF0YSktPmhXbmQgIT0gR2V0Rm9jdXMoKSB8fCAhZGF0YS0+Y3VyY2ZnLmN1cnNvcl92aXNpYmxlKSByZXR1cm47CgogICAgU2V0Q2FyZXRQb3MoKGRhdGEtPmN1cnNvci5YIC0gZGF0YS0+Y3VyY2ZnLndpbl9wb3MuWCkgKiBkYXRhLT5jdXJjZmcuY2VsbF93aWR0aCwgCgkJKGRhdGEtPmN1cnNvci5ZIC0gZGF0YS0+Y3VyY2ZnLndpbl9wb3MuWSkgKiBkYXRhLT5jdXJjZmcuY2VsbF9oZWlnaHQpOwogICAgU2hvd0NhcmV0KFBSSVZBVEUoZGF0YSktPmhXbmQpOyAKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX1NoYXBlQ3Vyc29yCiAqCiAqIFNldHMgYSBuZXcgc2hhcGUgZm9yIHRoZSBjdXJzb3IKICovCnZvaWQJV0NVU0VSX1NoYXBlQ3Vyc29yKHN0cnVjdCBpbm5lcl9kYXRhKiBkYXRhLCBpbnQgc2l6ZSwgaW50IHZpcywgQk9PTCBmb3JjZSkKewogICAgaWYgKGZvcmNlIHx8IHNpemUgIT0gZGF0YS0+Y3VyY2ZnLmN1cnNvcl9zaXplKQogICAgewoJaWYgKGRhdGEtPmN1cmNmZy5jdXJzb3JfdmlzaWJsZSAmJiBQUklWQVRFKGRhdGEpLT5oV25kID09IEdldEZvY3VzKCkpIERlc3Ryb3lDYXJldCgpOwoJaWYgKFBSSVZBVEUoZGF0YSktPmN1cnNvcl9iaXRtYXApIERlbGV0ZU9iamVjdChQUklWQVRFKGRhdGEpLT5jdXJzb3JfYml0bWFwKTsKCVBSSVZBVEUoZGF0YSktPmN1cnNvcl9iaXRtYXAgPSAoSEJJVE1BUCkwOwoJaWYgKHNpemUgIT0gMTAwKQoJewoJICAgIGludAkJdzE2YjsgLyogbnVtYmVyIG9mIGJ5ZXRzIHBlciByb3csIGFsaWduZWQgb24gd29yZCBzaXplICovCgkgICAgQllURSoJcHRyOwoJICAgIGludAkJaSwgaiwgbmJsOwoKCSAgICB3MTZiID0gKChkYXRhLT5jdXJjZmcuY2VsbF93aWR0aCArIDE1KSAmIH4xNSkgLyA4OwoJICAgIHB0ciA9IEhlYXBBbGxvYyhHZXRQcm9jZXNzSGVhcCgpLCBIRUFQX1pFUk9fTUVNT1JZLCB3MTZiICogZGF0YS0+Y3VyY2ZnLmNlbGxfaGVpZ2h0KTsKCSAgICBpZiAoIXB0cikge1RyYWNlKDAsICJPT01cbiIpOyByZXR1cm47fQoJICAgIG5ibCA9IG1heCgoZGF0YS0+Y3VyY2ZnLmNlbGxfaGVpZ2h0ICogc2l6ZSkgLyAxMDAsIDEpOwoJICAgIGZvciAoaiA9IGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodCAtIG5ibDsgaiA8IGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodDsgaisrKQoJICAgIHsKCQlmb3IgKGkgPSAwOyBpIDwgZGF0YS0+Y3VyY2ZnLmNlbGxfd2lkdGg7IGkrKykKCQl7CgkJICAgIHB0clt3MTZiICogaiArIChpIC8gOCldIHw9IDB4ODAgPj4gKGkgJiA3KTsKCQl9CgkgICAgfQoJICAgIFBSSVZBVEUoZGF0YSktPmN1cnNvcl9iaXRtYXAgPSBDcmVhdGVCaXRtYXAoZGF0YS0+Y3VyY2ZnLmNlbGxfd2lkdGgsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodCwgMSwgMSwgcHRyKTsKCSAgICBIZWFwRnJlZShHZXRQcm9jZXNzSGVhcCgpLCAwLCBwdHIpOwoJfQoJZGF0YS0+Y3VyY2ZnLmN1cnNvcl9zaXplID0gc2l6ZTsKCWRhdGEtPmN1cmNmZy5jdXJzb3JfdmlzaWJsZSA9IC0xOwogICAgfQoKICAgIHZpcyA9ICh2aXMpID8gVFJVRSA6IEZBTFNFOwogICAgaWYgKGZvcmNlIHx8IHZpcyAhPSBkYXRhLT5jdXJjZmcuY3Vyc29yX3Zpc2libGUpCiAgICB7CglkYXRhLT5jdXJjZmcuY3Vyc29yX3Zpc2libGUgPSB2aXM7CglpZiAoUFJJVkFURShkYXRhKS0+aFduZCA9PSBHZXRGb2N1cygpKQoJewoJICAgIGlmICh2aXMpCgkgICAgewoJCUNyZWF0ZUNhcmV0KFBSSVZBVEUoZGF0YSktPmhXbmQsIFBSSVZBVEUoZGF0YSktPmN1cnNvcl9iaXRtYXAsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgZGF0YS0+Y3VyY2ZnLmNlbGxfd2lkdGgsIGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodCk7CgkJV0NVU0VSX1Bvc0N1cnNvcihkYXRhKTsKCSAgICB9CgkgICAgZWxzZQoJICAgIHsKCQlEZXN0cm95Q2FyZXQoKTsKCSAgICB9Cgl9CiAgICB9Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCUlORUNPTl9Db21wdXRlUG9zaXRpb25zCiAqCiAqIFJlY29tcHV0ZXMgYWxsIHRoZSBjb21wb25lbnRzIChtYWlubHkgc2Nyb2xsIGJhcnMpIHBvc2l0aW9ucwogKi8Kdm9pZAlXQ1VTRVJfQ29tcHV0ZVBvc2l0aW9ucyhzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSkKewogICAgUkVDVAkJcjsKICAgIGludAkJCWR4LCBkeTsKCiAgICAvKiBjb21wdXRlIHdpbmRvdyBzaXplIGZyb20gZGVzaXJlZCBjbGllbnQgc2l6ZSAqLwogICAgci5sZWZ0ID0gci50b3AgPSAwOwogICAgci5yaWdodCA9IGRhdGEtPmN1cmNmZy53aW5fd2lkdGggKiBkYXRhLT5jdXJjZmcuY2VsbF93aWR0aDsKICAgIHIuYm90dG9tID0gZGF0YS0+Y3VyY2ZnLndpbl9oZWlnaHQgKiBkYXRhLT5jdXJjZmcuY2VsbF9oZWlnaHQ7CgogICAgaWYgKElzUmVjdEVtcHR5KCZyKSkKICAgIHsKCVNob3dXaW5kb3coUFJJVkFURShkYXRhKS0+aFduZCwgU1dfSElERSk7CglyZXR1cm47CiAgICB9CgogICAgQWRqdXN0V2luZG93UmVjdCgmciwgR2V0V2luZG93TG9uZyhQUklWQVRFKGRhdGEpLT5oV25kLCBHV0xfU1RZTEUpLCBGQUxTRSk7CgogICAgZHggPSBkeSA9IDA7CiAgICBpZiAoZGF0YS0+Y3VyY2ZnLnNiX3dpZHRoID4gZGF0YS0+Y3VyY2ZnLndpbl93aWR0aCkKICAgIHsKCWR5ID0gR2V0U3lzdGVtTWV0cmljcyhTTV9DWUhTQ1JPTEwpOwoJU2V0U2Nyb2xsUmFuZ2UoUFJJVkFURShkYXRhKS0+aFduZCwgU0JfSE9SWiwgMCwgCiAgICAgICAgICAgICAgICAgICAgICAgZGF0YS0+Y3VyY2ZnLnNiX3dpZHRoIC0gZGF0YS0+Y3VyY2ZnLndpbl93aWR0aCwgRkFMU0UpOwoJU2V0U2Nyb2xsUG9zKFBSSVZBVEUoZGF0YSktPmhXbmQsIFNCX0hPUlosIDAsIEZBTFNFKTsgLyogRklYTUUgKi8KCVNob3dTY3JvbGxCYXIoUFJJVkFURShkYXRhKS0+aFduZCwgU0JfSE9SWiwgVFJVRSk7CiAgICB9CiAgICBlbHNlCiAgICB7CglTaG93U2Nyb2xsQmFyKFBSSVZBVEUoZGF0YSktPmhXbmQsIFNCX0hPUlosIEZBTFNFKTsKICAgIH0KCiAgICBpZiAoZGF0YS0+Y3VyY2ZnLnNiX2hlaWdodCA+IGRhdGEtPmN1cmNmZy53aW5faGVpZ2h0KQogICAgewoJZHggPSBHZXRTeXN0ZW1NZXRyaWNzKFNNX0NYVlNDUk9MTCk7CglTZXRTY3JvbGxSYW5nZShQUklWQVRFKGRhdGEpLT5oV25kLCBTQl9WRVJULCAwLCAKICAgICAgICAgICAgICAgICAgICAgICBkYXRhLT5jdXJjZmcuc2JfaGVpZ2h0IC0gZGF0YS0+Y3VyY2ZnLndpbl9oZWlnaHQsIEZBTFNFKTsKCVNldFNjcm9sbFBvcyhQUklWQVRFKGRhdGEpLT5oV25kLCBTQl9WRVJULCAwLCBGQUxTRSk7IC8qIEZJWE1FICovCglTaG93U2Nyb2xsQmFyKFBSSVZBVEUoZGF0YSktPmhXbmQsIFNCX1ZFUlQsIFRSVUUpOwogICAgfQkKICAgIGVsc2UKICAgIHsKCVNob3dTY3JvbGxCYXIoUFJJVkFURShkYXRhKS0+aFduZCwgU0JfVkVSVCwgRkFMU0UpOwogICAgfQoKICAgIFNldFdpbmRvd1BvcyhQUklWQVRFKGRhdGEpLT5oV25kLCAwLCAwLCAwLCByLnJpZ2h0IC0gci5sZWZ0ICsgZHgsIHIuYm90dG9tIC0gci50b3AgKyBkeSwKCQkgU1dQX05PTU9WRXxTV1BfTk9aT1JERVJ8U1dQX1NIT1dXSU5ET1cpOwogICAgV0NVU0VSX1NoYXBlQ3Vyc29yKGRhdGEsIGRhdGEtPmN1cmNmZy5jdXJzb3Jfc2l6ZSwgZGF0YS0+Y3VyY2ZnLmN1cnNvcl92aXNpYmxlLCBUUlVFKTsKICAgIFdDVVNFUl9Qb3NDdXJzb3IoZGF0YSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9TZXRUaXRsZQogKgogKiBTZXRzIHRoZSB0aXRsZSB0byB0aGUgd2luZSBjb25zb2xlCiAqLwpzdGF0aWMgdm9pZAlXQ1VTRVJfU2V0VGl0bGUoY29uc3Qgc3RydWN0IGlubmVyX2RhdGEqIGRhdGEpCnsKICAgIFdDSEFSCWJ1ZmZlclsyNTZdOwkKCiAgICBpZiAoV0lORUNPTl9HZXRDb25zb2xlVGl0bGUoZGF0YS0+aENvbkluLCBidWZmZXIsIHNpemVvZihidWZmZXIpKSkKCVNldFdpbmRvd1RleHQoUFJJVkFURShkYXRhKS0+aFduZCwgYnVmZmVyKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJRm9udEVxdWFsCiAqCiAqCiAqLwpCT09MIFdDVVNFUl9BcmVGb250c0VxdWFsKGNvbnN0IHN0cnVjdCBjb25maWdfZGF0YSogY29uZmlnLCBjb25zdCBMT0dGT05UKiBsZikKewogICAgcmV0dXJuIGxmLT5sZkhlaWdodCA9PSBjb25maWctPmNlbGxfaGVpZ2h0ICYmCiAgICAgICAgbGYtPmxmV2VpZ2h0ID09IGNvbmZpZy0+Zm9udF93ZWlnaHQgJiYKICAgICAgICAhbGYtPmxmSXRhbGljICYmICFsZi0+bGZVbmRlcmxpbmUgJiYgIWxmLT5sZlN0cmlrZU91dCAmJgogICAgICAgICFsc3RyY21wKGxmLT5sZkZhY2VOYW1lLCBjb25maWctPmZhY2VfbmFtZSk7Cn0KCnN0cnVjdCBmb250X2Nob29zZXIgewogICAgc3RydWN0IGlubmVyX2RhdGEqCWRhdGE7CiAgICBpbnQJCQlkb25lOwp9OwoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX1ZhbGlkYXRlRm9udE1ldHJpYwogKgogKiBSZXR1cm5zIHRydWUgaWYgdGhlIGZvbnQgZGVzY3JpYmVkIGluIHRtIGlzIHVzYWJsZSBhcyBhIGZvbnQgZm9yIHRoZSByZW5kZXJlcgogKi8KQk9PTAlXQ1VTRVJfVmFsaWRhdGVGb250TWV0cmljKGNvbnN0IHN0cnVjdCBpbm5lcl9kYXRhKiBkYXRhLCBjb25zdCBURVhUTUVUUklDKiB0bSwgRFdPUkQgZm9udFR5cGUpCnsKICAgIEJPT0wgICAgICAgIHJldCA9IFRSVUU7CgogICAgaWYgKGZvbnRUeXBlICYgUkFTVEVSX0ZPTlRUWVBFKQogICAgICAgIHJldCA9ICh0bS0+dG1NYXhDaGFyV2lkdGggKiBkYXRhLT5jdXJjZmcud2luX3dpZHRoIDwgR2V0U3lzdGVtTWV0cmljcyhTTV9DWFNDUkVFTikgJiYKICAgICAgICAgICAgICAgdG0tPnRtSGVpZ2h0ICogZGF0YS0+Y3VyY2ZnLndpbl9oZWlnaHQgPCBHZXRTeXN0ZW1NZXRyaWNzKFNNX0NZU0NSRUVOKSk7CiAgICByZXR1cm4gcmV0ICYmICF0bS0+dG1JdGFsaWMgJiYgIXRtLT50bVVuZGVybGluZWQgJiYgIXRtLT50bVN0cnVja091dCAmJgogICAgICAgICh0bS0+dG1DaGFyU2V0ID09IERFRkFVTFRfQ0hBUlNFVCAvKnx8IHRtLT50bUNoYXJTZXQgPT0gQU5TSV9DSEFSU0VUKi8pOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfVmFsaWRhdGVGb250CiAqCiAqIFJldHVybnMgdHJ1ZSBpZiB0aGUgZm9udCBmYW1pbHkgZGVzY3JpYmVkIGluIGxmIGlzIHVzYWJsZSBhcyBhIGZvbnQgZm9yIHRoZSByZW5kZXJlcgogKi8KQk9PTAlXQ1VTRVJfVmFsaWRhdGVGb250KGNvbnN0IHN0cnVjdCBpbm5lcl9kYXRhKiBkYXRhLCBjb25zdCBMT0dGT05UKiBsZikKewogICAgcmV0dXJuIChsZi0+bGZQaXRjaEFuZEZhbWlseSAmIDMpID09IEZJWEVEX1BJVENIICYmIAogICAgICAgIC8qIChsZi0+bGZQaXRjaEFuZEZhbWlseSAmIDB4RjApID09IEZGX01PREVSTiAmJiAqLwogICAgICAgIChsZi0+bGZDaGFyU2V0ID09IERFRkFVTFRfQ0hBUlNFVCB8fCBsZi0+bGZDaGFyU2V0ID09IEFOU0lfQ0hBUlNFVCk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCWdldF9maXJzdF9mb250X2VudW1fMgogKgkJZ2V0X2ZpcnN0X2ZvbnRfZW51bQogKgogKiBIZWxwZXIgZnVuY3Rpb25zIHRvIGdldCBhIGRlY2VudCBmb250IGZvciB0aGUgcmVuZGVyZXIKICovCnN0YXRpYyBpbnQgQ0FMTEJBQ0sgZ2V0X2ZpcnN0X2ZvbnRfZW51bV8yKGNvbnN0IExPR0ZPTlQqIGxmLCBjb25zdCBURVhUTUVUUklDKiB0bSwgCgkJCQkJICBEV09SRCBGb250VHlwZSwgTFBBUkFNIGxQYXJhbSkKewogICAgc3RydWN0IGZvbnRfY2hvb3NlcioJZmMgPSAoc3RydWN0IGZvbnRfY2hvb3NlciopbFBhcmFtOwoKICAgIGlmIChXQ1VTRVJfVmFsaWRhdGVGb250TWV0cmljKGZjLT5kYXRhLCB0bSwgRm9udFR5cGUpKQogICAgewoJV0NVU0VSX1NldEZvbnQoZmMtPmRhdGEsIGxmKTsKCWZjLT5kb25lID0gMTsKCXJldHVybiAwOwogICAgfQogICAgcmV0dXJuIDE7Cn0KCnN0YXRpYyBpbnQgQ0FMTEJBQ0sgZ2V0X2ZpcnN0X2ZvbnRfZW51bShjb25zdCBMT0dGT05UKiBsZiwgY29uc3QgVEVYVE1FVFJJQyogdG0sIAoJCQkJCURXT1JEIEZvbnRUeXBlLCBMUEFSQU0gbFBhcmFtKQp7CiAgICBzdHJ1Y3QgZm9udF9jaG9vc2VyKglmYyA9IChzdHJ1Y3QgZm9udF9jaG9vc2VyKilsUGFyYW07CgogICAgaWYgKFdDVVNFUl9WYWxpZGF0ZUZvbnQoZmMtPmRhdGEsIGxmKSkKICAgIHsKCUVudW1Gb250RmFtaWxpZXMoUFJJVkFURShmYy0+ZGF0YSktPmhNZW1EQywgbGYtPmxmRmFjZU5hbWUsIGdldF9maXJzdF9mb250X2VudW1fMiwgbFBhcmFtKTsKCXJldHVybiAhZmMtPmRvbmU7IC8qIHdlIGp1c3QgbmVlZCB0aGUgZmlyc3QgbWF0Y2hpbmcgb25lLi4uICovCiAgICB9CiAgICByZXR1cm4gMTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJQ29weUZvbnQKICoKICogZ2V0IHRoZSByZWxldmFudCBpbmZvcm1hdGlvbiBmcm9tIHRoZSBmb250IGRlc2NyaWJlZCBpbiBsZiBhbmQgc3RvcmUgdGhlbQogKiBpbiBjb25maWcKICovCkhGT05UIFdDVVNFUl9Db3B5Rm9udChzdHJ1Y3QgY29uZmlnX2RhdGEqIGNvbmZpZywgSFdORCBoV25kLCBjb25zdCBMT0dGT05UKiBsZikKewogICAgVEVYVE1FVFJJQyAgdG07CiAgICBIREMgICAgICAgICBoREM7CiAgICBIRk9OVCAgICAgICBoRm9udCwgaE9sZEZvbnQ7CiAgICBpbnQgICAgICAgICB3LCBpLCBidWZbMjU2XTsKCiAgICBpZiAoIShoREMgPSBHZXREQyhoV25kKSkpIHJldHVybiAoSEZPTlQpMDsKICAgIGlmICghKGhGb250ID0gQ3JlYXRlRm9udEluZGlyZWN0KGxmKSkpIGdvdG8gZXJyMTsKCiAgICBoT2xkRm9udCA9IFNlbGVjdE9iamVjdChoREMsIGhGb250KTsKICAgIEdldFRleHRNZXRyaWNzKGhEQywgJnRtKTsKCiAgICAvKiBGSVhNRToKICAgICAqIHRoZSBjdXJyZW50IGZyZWV0eXBlIGVuZ2luZSAoYXQgbGVhc3QgMi4wLnggd2l0aCB4IDw9IDgpIGFuZCBpdHMgaW1wbGVtZW50YXRpb24KICAgICAqIGluIFdpbmUgZG9uJ3QgcmV0dXJuIGFkZXF1YXRlIHZhbHVlcyBmb3IgZml4ZWQgZm9udHMKICAgICAqIEluIFdpbmRvd3MsIHRob3NlIGZvbnRzIGFyZSBleHBlY3RlcyB0byByZXR1cm4gdGhlIHNhbWUgdmFsdWUgZm9yCiAgICAgKiAgLSB0aGUgYXZlcmFnZSB3aWR0aAogICAgICogIC0gdGhlIGxhcmdlc3Qgd2lkdGgKICAgICAqICAtIHRoZSB3aWR0aCBvZiBhbGwgY2hhcmFjdGVycyBpbiB0aGUgZm9udAogICAgICogVGhpcyBpc24ndCB0cnVlIGluIFdpbmUuIEFzIGEgdGVtcG9yYXJ5IHdvcmthb3VuZCwgd2UgZ2V0IGFzIHRoZSB3aWR0aCBvZiB0aGUgCiAgICAgKiBjZWxsLCB0aGUgd2lkdGggb2YgdGhlIGZpcnN0IGNoYXJhY3RlciBpbiB0aGUgZm9udCwgYWZ0ZXIgY2hlY2tpbmcgdGhhdCBhbGwKICAgICAqIGNoYXJhY3RlcnMgaW4gdGhlIGZvbnQgaGF2ZSB0aGUgc2FtZSB3aWR0aCAoSSBoZWFyIHBhcmFub+9hIGNvbWluZykKICAgICAqIHdoZW4gdGhpcyBnZXRzIGZpeGVkLCB0aGUgc2hvdWxkIGJlIHVzaW5nIHRtLnRtQXZlQ2hhcldpZHRoIG9yIHRtLnRtTWF4Q2hhcldpZHRoCiAgICAgKiBhcyB0aGUgY2VsbCB3aWR0aC4KICAgICAqLwogICAgR2V0Q2hhcldpZHRoMzIoaERDLCB0bS50bUZpcnN0Q2hhciwgdG0udG1GaXJzdENoYXIsICZ3KTsKICAgIGZvciAoaSA9IHRtLnRtRmlyc3RDaGFyICsgMTsgaSA8PSB0bS50bUxhc3RDaGFyOyBpICs9IHNpemVvZihidWYpIC8gc2l6ZW9mKGJ1ZlswXSkpCiAgICB7CiAgICAgICAgaW50IGosIGw7CiAgICAgICAgICAgIAogICAgICAgIGwgPSBtaW4odG0udG1MYXN0Q2hhciAtIGksIHNpemVvZihidWYpIC8gc2l6ZW9mKGJ1ZlswXSkgLSAxKTsKICAgICAgICBHZXRDaGFyV2lkdGgzMihoREMsIGksIGkgKyBsLCBidWYpOwogICAgICAgIGZvciAoaiA9IDA7IGogPD0gbDsgaisrKSAKICAgICAgICB7CiAgICAgICAgICAgIGlmIChidWZbal0gIT0gdykKICAgICAgICAgICAgewogICAgICAgICAgICAgICAgVHJhY2UoMCwgIk5vbiB1bmlmb3JtIGNlbGwgd2lkdGg6IFslZF09JWQgWyVkXT0lZFxuIiwgCiAgICAgICAgICAgICAgICAgICAgICBpICsgaiwgYnVmW2pdLCB0bS50bUZpcnN0Q2hhciwgdyk7CiAgICAgICAgICAgICAgICBnb3RvIGVycjsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgIH0KCiAgICBTZWxlY3RPYmplY3QoaERDLCBoT2xkRm9udCk7CiAgICBSZWxlYXNlREMoaFduZCwgaERDKTsKCiAgICBjb25maWctPmNlbGxfd2lkdGggID0gdzsKICAgIGNvbmZpZy0+Y2VsbF9oZWlnaHQgPSB0bS50bUhlaWdodDsKICAgIGNvbmZpZy0+Zm9udF93ZWlnaHQgPSB0bS50bVdlaWdodDsKICAgIGxzdHJjcHkoY29uZmlnLT5mYWNlX25hbWUsIGxmLT5sZkZhY2VOYW1lKTsKCiAgICByZXR1cm4gaEZvbnQ7CiBlcnI6CiAgICBpZiAoaERDICYmIGhPbGRGb250KSBTZWxlY3RPYmplY3QoaERDLCBoT2xkRm9udCk7CiAgICBpZiAoaEZvbnQpIERlbGV0ZU9iamVjdChoRm9udCk7CiBlcnIxOgogICAgaWYgKGhEQykgUmVsZWFzZURDKGhXbmQsIGhEQyk7CgogICAgcmV0dXJuIChIRk9OVCkwOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfRmlsbExvZ0ZvbnQKICoKICoKICovCnZvaWQgICAgV0NVU0VSX0ZpbGxMb2dGb250KExPR0ZPTlQqIGxmLCBjb25zdCBXQ0hBUiogbmFtZSwgVUlOVCBoZWlnaHQsIFVJTlQgd2VpZ2h0KQp7CiAgICBsZi0+bGZIZWlnaHQgICAgICAgID0gaGVpZ2h0OwogICAgbGYtPmxmV2lkdGggICAgICAgICA9IDA7CiAgICBsZi0+bGZFc2NhcGVtZW50ICAgID0gMDsKICAgIGxmLT5sZk9yaWVudGF0aW9uICAgPSAwOwogICAgbGYtPmxmV2VpZ2h0ICAgICAgICA9IHdlaWdodDsKICAgIGxmLT5sZkl0YWxpYyAgICAgICAgPSBGQUxTRTsKICAgIGxmLT5sZlVuZGVybGluZSAgICAgPSBGQUxTRTsKICAgIGxmLT5sZlN0cmlrZU91dCAgICAgPSBGQUxTRTsKICAgIGxmLT5sZkNoYXJTZXQgICAgICAgPSBERUZBVUxUX0NIQVJTRVQ7CiAgICBsZi0+bGZPdXRQcmVjaXNpb24gID0gT1VUX0RFRkFVTFRfUFJFQ0lTOwogICAgbGYtPmxmQ2xpcFByZWNpc2lvbiA9IENMSVBfREVGQVVMVF9QUkVDSVM7IAogICAgbGYtPmxmUXVhbGl0eSAgICAgICA9IERFRkFVTFRfUVVBTElUWTsKICAgIGxmLT5sZlBpdGNoQW5kRmFtaWx5ID0gRklYRURfUElUQ0ggfCBGRl9ET05UQ0FSRTsKICAgIGxzdHJjcHkobGYtPmxmRmFjZU5hbWUsIG5hbWUpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfU2V0Rm9udAogKgogKiBzZXRzIGxvZ2ZvbnQgYXMgdGhlIG5ldyBmb250IGZvciB0aGUgY29uc29sZQogKi8KQk9PTAlXQ1VTRVJfU2V0Rm9udChzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSwgY29uc3QgTE9HRk9OVCogbG9nZm9udCkKewogICAgaWYgKFdDVVNFUl9BcmVGb250c0VxdWFsKCZkYXRhLT5jdXJjZmcsIGxvZ2ZvbnQpKSByZXR1cm4gVFJVRTsKICAgIGlmIChQUklWQVRFKGRhdGEpLT5oRm9udCkgRGVsZXRlT2JqZWN0KFBSSVZBVEUoZGF0YSktPmhGb250KTsKCiAgICBQUklWQVRFKGRhdGEpLT5oRm9udCA9IFdDVVNFUl9Db3B5Rm9udCgmZGF0YS0+Y3VyY2ZnLCBQUklWQVRFKGRhdGEpLT5oV25kLCBsb2dmb250KTsKICAgIGlmICghUFJJVkFURShkYXRhKS0+aEZvbnQpIHtUcmFjZSgwLCAid3JvbmcgZm9udFxuIik7cmV0dXJuIEZBTFNFO30KCiAgICBXQ1VTRVJfQ29tcHV0ZVBvc2l0aW9ucyhkYXRhKTsKICAgIFdDVVNFUl9OZXdCaXRtYXAoZGF0YSwgVFJVRSk7CiAgICBJbnZhbGlkYXRlUmVjdChQUklWQVRFKGRhdGEpLT5oV25kLCBOVUxMLCBGQUxTRSk7CiAgICBVcGRhdGVXaW5kb3coUFJJVkFURShkYXRhKS0+aFduZCk7CgogICAgcmV0dXJuIFRSVUU7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9Jbml0Rm9udAogKgogKiBjcmVhdGUgYSBoRm9udCBmcm9tIHRoZSBzZXR0aW5ncyBzYXZlZCBpbiByZWdpc3RyeS4uLgogKiAoY2FsbGVkIG9uIGluaXQsIGFzc3VtaW5nIG5vIGZvbnQgaGFzIGJlZW4gY3JlYXRlZCBiZWZvcmUpCiAqLwpzdGF0aWMgQk9PTAlXQ1VTRVJfSW5pdEZvbnQoc3RydWN0IGlubmVyX2RhdGEqIGRhdGEpCnsKICAgIExPR0ZPTlQgICAgICAgICAgICAgbGY7CiAgICBzdHJ1Y3QgZm9udF9jaG9vc2VyIGZjOwoKICAgIFdDVVNFUl9GaWxsTG9nRm9udCgmbGYsIGRhdGEtPmN1cmNmZy5mYWNlX25hbWUsIAogICAgICAgICAgICAgICAgICAgICAgIGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodCwgZGF0YS0+Y3VyY2ZnLmZvbnRfd2VpZ2h0KTsKICAgIGRhdGEtPmN1cmNmZy5mYWNlX25hbWVbMF0gPSAwOwogICAgZGF0YS0+Y3VyY2ZnLmNlbGxfaGVpZ2h0ID0gZGF0YS0+Y3VyY2ZnLmZvbnRfd2VpZ2h0ID0gMDsKCiAgICBpZiAoV0NVU0VSX1NldEZvbnQoZGF0YSwgJmxmKSkgcmV0dXJuIFRSVUU7CgogICAgLyogdHJ5IHRvIGZpbmQgYW4gYWNjZXB0YWJsZSBmb250ICovCiAgICBUcmFjZSgwLCAiQ291bGRuJ3QgbWF0Y2ggdGhlIGZvbnQgZnJvbSByZWdpc3RyeS4uLiB0cnlpbmcgdG8gZmluZCBvbmVcbiIpOwogICAgZmMuZGF0YSA9IGRhdGE7CiAgICBmYy5kb25lID0gMDsKICAgIEVudW1Gb250RmFtaWxpZXMoUFJJVkFURShkYXRhKS0+aE1lbURDLCBOVUxMLCBnZXRfZmlyc3RfZm9udF9lbnVtLCAoTFBBUkFNKSZmYyk7CiAgICByZXR1cm4gZmMuZG9uZTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX0dldENlbGwKICoKICogR2V0IGEgY2VsbCBmcm9tIHRoZSBhIHJlbGF0aXZlIGNvb3JkaW5hdGUgaW4gd2luZG93ICh0YWtlcyBpbnRvCiAqIGFjY291bnQgdGhlIHNjcm9sbGluZykKICovCnN0YXRpYyBDT09SRAlXQ1VTRVJfR2V0Q2VsbChjb25zdCBzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSwgTFBBUkFNIGxQYXJhbSkKewogICAgQ09PUkQJYzsKCiAgICBjLlggPSBkYXRhLT5jdXJjZmcud2luX3Bvcy5YICsgKHNob3J0KUxPV09SRChsUGFyYW0pIC8gZGF0YS0+Y3VyY2ZnLmNlbGxfd2lkdGg7CiAgICBjLlkgPSBkYXRhLT5jdXJjZmcud2luX3Bvcy5ZICsgKHNob3J0KUhJV09SRChsUGFyYW0pIC8gZGF0YS0+Y3VyY2ZnLmNlbGxfaGVpZ2h0OwoKICAgIHJldHVybiBjOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfR2V0U2VsZWN0aW9uUmVjdAogKgogKiBHZXQgdGhlIHNlbGVjdGlvbiByZWN0YW5nbGUKICovCnN0YXRpYyB2b2lkCVdDVVNFUl9HZXRTZWxlY3Rpb25SZWN0KGNvbnN0IHN0cnVjdCBpbm5lcl9kYXRhKiBkYXRhLCBMUFJFQ1QgcikKewogICAgci0+bGVmdCAgID0gKG1pbihQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDEuWCwgUFJJVkFURShkYXRhKS0+c2VsZWN0UHQyLlgpICAgICkgKiBkYXRhLT5jdXJjZmcuY2VsbF93aWR0aDsKICAgIHItPnRvcCAgICA9IChtaW4oUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxLlksIFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0Mi5ZKSAgICApICogZGF0YS0+Y3VyY2ZnLmNlbGxfaGVpZ2h0OwogICAgci0+cmlnaHQgID0gKG1heChQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDEuWCwgUFJJVkFURShkYXRhKS0+c2VsZWN0UHQyLlgpICsgMSkgKiBkYXRhLT5jdXJjZmcuY2VsbF93aWR0aDsKICAgIHItPmJvdHRvbSA9IChtYXgoUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxLlksIFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0Mi5ZKSArIDEpICogZGF0YS0+Y3VyY2ZnLmNlbGxfaGVpZ2h0Owp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfU2V0U2VsZWN0aW9uCiAqCiAqCiAqLwpzdGF0aWMgdm9pZAlXQ1VTRVJfU2V0U2VsZWN0aW9uKGNvbnN0IHN0cnVjdCBpbm5lcl9kYXRhKiBkYXRhLCBIREMgaFJlZkRDKQp7CiAgICBIREMJCWhEQzsKICAgIFJFQ1QJcjsKCiAgICBXQ1VTRVJfR2V0U2VsZWN0aW9uUmVjdChkYXRhLCAmcik7CiAgICBoREMgPSBoUmVmREMgPyBoUmVmREMgOiBHZXREQyhQUklWQVRFKGRhdGEpLT5oV25kKTsKICAgIGlmIChoREMpCiAgICB7CglpZiAoUFJJVkFURShkYXRhKS0+aFduZCA9PSBHZXRGb2N1cygpICYmIGRhdGEtPmN1cmNmZy5jdXJzb3JfdmlzaWJsZSkKCSAgICBIaWRlQ2FyZXQoUFJJVkFURShkYXRhKS0+aFduZCk7CglJbnZlcnRSZWN0KGhEQywgJnIpOwoJaWYgKGhEQyAhPSBoUmVmREMpCgkgICAgUmVsZWFzZURDKFBSSVZBVEUoZGF0YSktPmhXbmQsIGhEQyk7CglpZiAoUFJJVkFURShkYXRhKS0+aFduZCA9PSBHZXRGb2N1cygpICYmIGRhdGEtPmN1cmNmZy5jdXJzb3JfdmlzaWJsZSkKCSAgICBTaG93Q2FyZXQoUFJJVkFURShkYXRhKS0+aFduZCk7CiAgICB9Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9Nb3ZlU2VsZWN0aW9uCiAqCiAqCiAqLwpzdGF0aWMgdm9pZAlXQ1VTRVJfTW92ZVNlbGVjdGlvbihzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSwgQ09PUkQgYzEsIENPT1JEIGMyLCBCT09MIGZpbmFsKQp7CiAgICBSRUNUCXI7CiAgICBIREMJCWhEQzsKCiAgICBXQ1VTRVJfR2V0U2VsZWN0aW9uUmVjdChkYXRhLCAmcik7CiAgICBoREMgPSBHZXREQyhQUklWQVRFKGRhdGEpLT5oV25kKTsKICAgIGlmIChoREMpCiAgICB7CglpZiAoUFJJVkFURShkYXRhKS0+aFduZCA9PSBHZXRGb2N1cygpICYmIGRhdGEtPmN1cmNmZy5jdXJzb3JfdmlzaWJsZSkKCSAgICBIaWRlQ2FyZXQoUFJJVkFURShkYXRhKS0+aFduZCk7CglJbnZlcnRSZWN0KGhEQywgJnIpOwogICAgfQogICAgUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxID0gYzE7CiAgICBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDIgPSBjMjsKICAgIGlmIChoREMpCiAgICB7CglXQ1VTRVJfR2V0U2VsZWN0aW9uUmVjdChkYXRhLCAmcik7CglJbnZlcnRSZWN0KGhEQywgJnIpOwoJUmVsZWFzZURDKFBSSVZBVEUoZGF0YSktPmhXbmQsIGhEQyk7CglpZiAoUFJJVkFURShkYXRhKS0+aFduZCA9PSBHZXRGb2N1cygpICYmIGRhdGEtPmN1cmNmZy5jdXJzb3JfdmlzaWJsZSkKCSAgICBTaG93Q2FyZXQoUFJJVkFURShkYXRhKS0+aFduZCk7CiAgICB9CiAgICBpZiAoZmluYWwpCiAgICB7CglSZWxlYXNlQ2FwdHVyZSgpOwoJUFJJVkFURShkYXRhKS0+aGFzX3NlbGVjdGlvbiA9IFRSVUU7CiAgICB9Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9Db3B5U2VsZWN0aW9uVG9DbGlwYm9hcmQKICoKICogQ29waWVzIHRoZSBjdXJyZW50IHNlbGVjdGlvbiBpbnRvIHRoZSBjbGlwYm9hcmQKICovCnN0YXRpYyB2b2lkCVdDVVNFUl9Db3B5U2VsZWN0aW9uVG9DbGlwYm9hcmQoY29uc3Qgc3RydWN0IGlubmVyX2RhdGEqIGRhdGEpCnsKICAgIEhBTkRMRQloTWVtOwogICAgTFBXU1RSCXA7CiAgICB1bnNpZ25lZAl3LCBoOwoKICAgIHcgPSBhYnMoUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxLlggLSBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDIuWCkgKyAyOwogICAgaCA9IGFicyhQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDEuWSAtIFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0Mi5ZKSArIDE7CgogICAgaWYgKCFPcGVuQ2xpcGJvYXJkKFBSSVZBVEUoZGF0YSktPmhXbmQpKSByZXR1cm47CiAgICBFbXB0eUNsaXBib2FyZCgpOwoKICAgIGhNZW0gPSBHbG9iYWxBbGxvYyhHTUVNX01PVkVBQkxFLCAodyAqIGggLSAxKSAqIHNpemVvZihXQ0hBUikpOwogICAgaWYgKGhNZW0gJiYgKHAgPSBHbG9iYWxMb2NrKGhNZW0pKSkKICAgIHsKCUNPT1JECWM7CglpbnQJeTsKCgljLlggPSBkYXRhLT5jdXJjZmcud2luX3Bvcy5YICsgbWluKFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MS5YLCBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDIuWCk7CgljLlkgPSBkYXRhLT5jdXJjZmcud2luX3Bvcy5ZICsgbWluKFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MS5ZLCBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDIuWSk7CgkKCWZvciAoeSA9IDA7IHkgPCBoOyB5KyssIGMuWSsrKQoJewoJICAgIFJlYWRDb25zb2xlT3V0cHV0Q2hhcmFjdGVyKGRhdGEtPmhDb25PdXQsICZwW3kgKiB3XSwgdyAtIDEsIGMsIE5VTEwpOwoJICAgIGlmICh5IDwgaCAtIDEpIHBbeSAqIHcgKyB3IC0gMV0gPSAnXG4nOwoJfQoJR2xvYmFsVW5sb2NrKGhNZW0pOwoJU2V0Q2xpcGJvYXJkRGF0YShDRl9VTklDT0RFVEVYVCwgaE1lbSk7CiAgICB9CiAgICBDbG9zZUNsaXBib2FyZCgpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlXQ1VTRVJfUGFzdGVGcm9tQ2xpcGJvYXJkCiAqCiAqCiAqLwpzdGF0aWMgdm9pZAlXQ1VTRVJfUGFzdGVGcm9tQ2xpcGJvYXJkKHN0cnVjdCBpbm5lcl9kYXRhKiBkYXRhKQp7CiAgICBIQU5ETEUJaDsKICAgIFdDSEFSKglwdHI7CgogICAgaWYgKCFPcGVuQ2xpcGJvYXJkKFBSSVZBVEUoZGF0YSktPmhXbmQpKSByZXR1cm47CiAgICBoID0gR2V0Q2xpcGJvYXJkRGF0YShDRl9VTklDT0RFVEVYVCk7CiAgICBpZiAoaCAmJiAocHRyID0gR2xvYmFsTG9jayhoKSkpCiAgICB7CglpbnQJCWksIGxlbiA9IEdsb2JhbFNpemUoaCkgLyBzaXplb2YoV0NIQVIpOwoJSU5QVVRfUkVDT1JECWlyWzJdOwoJRFdPUkQJCW47CglTSE9SVAkJc2g7CgoJaXJbMF0uRXZlbnRUeXBlID0gS0VZX0VWRU5UOwoJaXJbMF0uRXZlbnQuS2V5RXZlbnQud1JlcGVhdENvdW50ID0gMDsKCWlyWzBdLkV2ZW50LktleUV2ZW50LmR3Q29udHJvbEtleVN0YXRlID0gMDsKCWlyWzBdLkV2ZW50LktleUV2ZW50LmJLZXlEb3duID0gVFJVRTsKCgkvKiBnZW5lcmF0ZSB0aGUgY29ycmVzcG9uZGluZyBpbnB1dCByZWNvcmRzICovCglmb3IgKGkgPSAwOyBpIDwgbGVuOyBpKyspCgl7CgkgICAgLyogRklYTUU6IHRoZSBtb2RpZnlpbmcga2V5cyBhcmUgbm90IGdlbmVyYXRlZCAoc2hpZnQsIGN0cmwuLi4pICovCgkgICAgc2ggPSBWa0tleVNjYW4ocHRyW2ldKTsKCSAgICBpclswXS5FdmVudC5LZXlFdmVudC53VmlydHVhbEtleUNvZGUgPSBMT0JZVEUoc2gpOwoJICAgIGlyWzBdLkV2ZW50LktleUV2ZW50LndWaXJ0dWFsU2NhbkNvZGUgPSBNYXBWaXJ0dWFsS2V5KExPQllURShzaCksIDApOwoJICAgIGlyWzBdLkV2ZW50LktleUV2ZW50LnVDaGFyLlVuaWNvZGVDaGFyID0gcHRyW2ldOwoJICAgIAoJICAgIGlyWzFdID0gaXJbMF07CgkgICAgaXJbMV0uRXZlbnQuS2V5RXZlbnQuYktleURvd24gPSBGQUxTRTsKCSAgICAKCSAgICBXcml0ZUNvbnNvbGVJbnB1dChkYXRhLT5oQ29uSW4sIGlyLCAyLCAmbik7Cgl9CglHbG9iYWxVbmxvY2soaCk7CiAgICB9CiAgICBDbG9zZUNsaXBib2FyZCgpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlSZWZyZXNoCiAqCiAqCiAqLwpzdGF0aWMgdm9pZCBXQ1VTRVJfUmVmcmVzaChjb25zdCBzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSwgaW50IHRwLCBpbnQgYm0pCnsKICAgIGlmIChkYXRhLT5jdXJjZmcud2luX3Bvcy5ZIDw9IGJtICYmIGRhdGEtPmN1cmNmZy53aW5fcG9zLlkgKyBkYXRhLT5jdXJjZmcud2luX2hlaWdodCA+PSB0cCkKICAgIHsKCVJFQ1QJcjsKCglyLmxlZnQgICA9IDA7CglyLnJpZ2h0ICA9IGRhdGEtPmN1cmNmZy53aW5fd2lkdGggKiBkYXRhLT5jdXJjZmcuY2VsbF93aWR0aDsKCXIudG9wICAgID0gKHRwIC0gZGF0YS0+Y3VyY2ZnLndpbl9wb3MuWSkgKiBkYXRhLT5jdXJjZmcuY2VsbF9oZWlnaHQ7CglyLmJvdHRvbSA9IChibSAtIGRhdGEtPmN1cmNmZy53aW5fcG9zLlkgKyAxKSAqIGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodDsKCUludmFsaWRhdGVSZWN0KFBSSVZBVEUoZGF0YSktPmhXbmQsICZyLCBGQUxTRSk7CglXQ1VTRVJfRmlsbE1lbURDKGRhdGEsIHRwLCBibSk7CglVcGRhdGVXaW5kb3coUFJJVkFURShkYXRhKS0+aFduZCk7CiAgICB9Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9QYWludAogKgogKgogKi8Kc3RhdGljIHZvaWQJV0NVU0VSX1BhaW50KGNvbnN0IHN0cnVjdCBpbm5lcl9kYXRhKiBkYXRhKQp7CiAgICBQQUlOVFNUUlVDVAkJcHM7CgogICAgQmVnaW5QYWludChQUklWQVRFKGRhdGEpLT5oV25kLCAmcHMpOwogICAgQml0Qmx0KHBzLmhkYywgMCwgMCwgCiAgICAgICAgICAgZGF0YS0+Y3VyY2ZnLndpbl93aWR0aCAqIGRhdGEtPmN1cmNmZy5jZWxsX3dpZHRoLCAKICAgICAgICAgICBkYXRhLT5jdXJjZmcud2luX2hlaWdodCAqIGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodCwKCSAgIFBSSVZBVEUoZGF0YSktPmhNZW1EQywgCiAgICAgICAgICAgZGF0YS0+Y3VyY2ZnLndpbl9wb3MuWCAqIGRhdGEtPmN1cmNmZy5jZWxsX3dpZHRoLCAKICAgICAgICAgICBkYXRhLT5jdXJjZmcud2luX3Bvcy5ZICogZGF0YS0+Y3VyY2ZnLmNlbGxfaGVpZ2h0LAoJICAgU1JDQ09QWSk7CiAgICBpZiAoUFJJVkFURShkYXRhKS0+aGFzX3NlbGVjdGlvbikKCVdDVVNFUl9TZXRTZWxlY3Rpb24oZGF0YSwgcHMuaGRjKTsKICAgIEVuZFBhaW50KFBSSVZBVEUoZGF0YSktPmhXbmQsICZwcyk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9TY3JvbGwKICoKICoKICovCnN0YXRpYyB2b2lkIFdDVVNFUl9TY3JvbGwoc3RydWN0IGlubmVyX2RhdGEqIGRhdGEsIGludCBwb3MsIEJPT0wgaG9yeikKewogICAgaWYgKGhvcnopCiAgICB7CglTZXRTY3JvbGxQb3MoUFJJVkFURShkYXRhKS0+aFduZCwgU0JfSE9SWiwgcG9zLCBUUlVFKTsKCWRhdGEtPmN1cmNmZy53aW5fcG9zLlggPSBwb3M7CglJbnZhbGlkYXRlUmVjdChQUklWQVRFKGRhdGEpLT5oV25kLCBOVUxMLCBGQUxTRSk7CiAgICB9CiAgICBlbHNlCiAgICB7CglTZXRTY3JvbGxQb3MoUFJJVkFURShkYXRhKS0+aFduZCwgU0JfVkVSVCwgcG9zLCBUUlVFKTsKCWRhdGEtPmN1cmNmZy53aW5fcG9zLlkgPSBwb3M7CiAgICB9CiAgICBJbnZhbGlkYXRlUmVjdChQUklWQVRFKGRhdGEpLT5oV25kLCBOVUxMLCBGQUxTRSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9GaWxsTWVudQogKgogKgogKi8Kc3RhdGljIEJPT0wgV0NVU0VSX0ZpbGxNZW51KEhNRU5VIGhNZW51LCBCT09MIHNlcCkKewogICAgSE1FTlUJCWhTdWJNZW51OwogICAgSElOU1RBTkNFCQloSW5zdGFuY2UgPSBHZXRNb2R1bGVIYW5kbGUoTlVMTCk7CiAgICBXQ0hBUgkJYnVmZlsyNTZdOwoKICAgIGlmICghaE1lbnUpIHJldHVybiBGQUxTRTsKCiAgICAvKiBGSVhNRTogZXJyb3IgaGFuZGxpbmcgJiBtZW1vcnkgY2xlYW51cCAqLwogICAgaFN1Yk1lbnUgPSBDcmVhdGVNZW51KCk7CiAgICBpZiAoIWhTdWJNZW51KSByZXR1cm4gRkFMU0U7CgogICAgTG9hZFN0cmluZyhoSW5zdGFuY2UsIElEU19NQVJLLCBidWZmLCBzaXplb2YoYnVmZikgLyBzaXplb2YoV0NIQVIpKTsKICAgIEluc2VydE1lbnUoaFN1Yk1lbnUsIC0xLCBNRl9CWVBPU0lUSU9OfE1GX1NUUklORywgSURTX01BUkssIGJ1ZmYpOwogICAgTG9hZFN0cmluZyhoSW5zdGFuY2UsIElEU19DT1BZLCBidWZmLCBzaXplb2YoYnVmZikgLyBzaXplb2YoV0NIQVIpKTsKICAgIEluc2VydE1lbnUoaFN1Yk1lbnUsIC0xLCBNRl9CWVBPU0lUSU9OfE1GX1NUUklORywgSURTX0NPUFksIGJ1ZmYpOwogICAgTG9hZFN0cmluZyhoSW5zdGFuY2UsIElEU19QQVNURSwgYnVmZiwgc2l6ZW9mKGJ1ZmYpIC8gc2l6ZW9mKFdDSEFSKSk7CiAgICBJbnNlcnRNZW51KGhTdWJNZW51LCAtMSwgTUZfQllQT1NJVElPTnxNRl9TVFJJTkcsIElEU19QQVNURSwgYnVmZik7CiAgICBMb2FkU3RyaW5nKGhJbnN0YW5jZSwgSURTX1NFTEVDVEFMTCwgYnVmZiwgc2l6ZW9mKGJ1ZmYpIC8gc2l6ZW9mKFdDSEFSKSk7CiAgICBJbnNlcnRNZW51KGhTdWJNZW51LCAtMSwgTUZfQllQT1NJVElPTnxNRl9TVFJJTkcsIElEU19TRUxFQ1RBTEwsIGJ1ZmYpOwogICAgTG9hZFN0cmluZyhoSW5zdGFuY2UsIElEU19TQ1JPTEwsIGJ1ZmYsIHNpemVvZihidWZmKSAvIHNpemVvZihXQ0hBUikpOwogICAgSW5zZXJ0TWVudShoU3ViTWVudSwgLTEsIE1GX0JZUE9TSVRJT058TUZfU1RSSU5HLCBJRFNfU0NST0xMLCBidWZmKTsKICAgIExvYWRTdHJpbmcoaEluc3RhbmNlLCBJRFNfU0VBUkNILCBidWZmLCBzaXplb2YoYnVmZikgLyBzaXplb2YoV0NIQVIpKTsKICAgIEluc2VydE1lbnUoaFN1Yk1lbnUsIC0xLCBNRl9CWVBPU0lUSU9OfE1GX1NUUklORywgSURTX1NFQVJDSCwgYnVmZik7CgogICAgaWYgKHNlcCkgSW5zZXJ0TWVudShoTWVudSwgLTEsIE1GX0JZUE9TSVRJT058TUZfU0VQQVJBVE9SLCAwLCBOVUxMKTsKICAgIExvYWRTdHJpbmcoaEluc3RhbmNlLCBJRFNfRURJVCwgYnVmZiwgc2l6ZW9mKGJ1ZmYpIC8gc2l6ZW9mKFdDSEFSKSk7CiAgICBJbnNlcnRNZW51KGhNZW51LCAtMSwgTUZfQllQT1NJVElPTnxNRl9TVFJJTkd8TUZfUE9QVVAsIChVSU5UX1BUUiloU3ViTWVudSwgYnVmZik7CiAgICBMb2FkU3RyaW5nKGhJbnN0YW5jZSwgSURTX0RFRkFVTFQsIGJ1ZmYsIHNpemVvZihidWZmKSAvIHNpemVvZihXQ0hBUikpOwogICAgSW5zZXJ0TWVudShoTWVudSwgLTEsIE1GX0JZUE9TSVRJT058TUZfU1RSSU5HLCBJRFNfREVGQVVMVCwgYnVmZik7CiAgICBMb2FkU3RyaW5nKGhJbnN0YW5jZSwgSURTX1BST1BFUlRZLCBidWZmLCBzaXplb2YoYnVmZikgLyBzaXplb2YoV0NIQVIpKTsKICAgIEluc2VydE1lbnUoaE1lbnUsIC0xLCBNRl9CWVBPU0lUSU9OfE1GX1NUUklORywgSURTX1BST1BFUlRZLCBidWZmKTsKCiAgICByZXR1cm4gVFJVRTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX0NyZWF0ZQogKgogKiBDcmVhdGVzIHRoZSB3aW5kb3cgZm9yIHRoZSByZW5kZXJpbmcKICovCnN0YXRpYyBMUkVTVUxUIFdDVVNFUl9DcmVhdGUoSFdORCBoV25kLCBMUENSRUFURVNUUlVDVCBscGNzKQp7CiAgICBzdHJ1Y3QgaW5uZXJfZGF0YSoJZGF0YTsKICAgIEhNRU5VCQloU3lzTWVudTsKCiAgICBkYXRhID0gbHBjcy0+bHBDcmVhdGVQYXJhbXM7CiAgICBTZXRXaW5kb3dMb25nKGhXbmQsIDBMLCAoRFdPUkQpZGF0YSk7CiAgICBQUklWQVRFKGRhdGEpLT5oV25kID0gaFduZDsKCiAgICBkYXRhLT5jdXJjZmcuY3Vyc29yX3NpemUgPSAxMDE7IC8qIGludmFsaWQgdmFsdWUsIHdpbGwgdHJpZ2dlciBhIGNvbXBsZXRlIGNsZWFudXAgKi8KCiAgICBoU3lzTWVudSA9IEdldFN5c3RlbU1lbnUoaFduZCwgRkFMU0UpOwogICAgaWYgKCFoU3lzTWVudSkgcmV0dXJuIDA7CiAgICBQUklWQVRFKGRhdGEpLT5oUG9wTWVudSA9IENyZWF0ZVBvcHVwTWVudSgpOwogICAgaWYgKCFQUklWQVRFKGRhdGEpLT5oUG9wTWVudSkgcmV0dXJuIDA7CgogICAgV0NVU0VSX0ZpbGxNZW51KGhTeXNNZW51LCBUUlVFKTsKICAgIFdDVVNFUl9GaWxsTWVudShQUklWQVRFKGRhdGEpLT5oUG9wTWVudSwgRkFMU0UpOwoKICAgIFBSSVZBVEUoZGF0YSktPmhNZW1EQyA9IENyZWF0ZUNvbXBhdGlibGVEQygwKTsKICAgIGlmICghUFJJVkFURShkYXRhKS0+aE1lbURDKSB7VHJhY2UoMCwgIm5vIG1lbSBkY1xuIik7cmV0dXJuIDA7fQoKICAgIGRhdGEtPmN1cmNmZy5xdWlja19lZGl0ID0gRkFMU0U7CiAgICByZXR1cm4gMDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX1NldE1lbnVEZXRhaWxzCiAqCiAqIEdyYXlzIC8gdW5ncmF5cyB0aGUgbWVudSBpdGVtcyBhY2NvcmRpbmcgdG8gdGhlaXIgc3RhdGUKICovCnN0YXRpYyB2b2lkCVdDVVNFUl9TZXRNZW51RGV0YWlscyhjb25zdCBzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSwgSE1FTlUgaE1lbnUpCnsKICAgIGlmICghaE1lbnUpIHtUcmFjZSgwLCAiSXNzdWUgaW4gZ2V0dGluZyBtZW51IGJpdHNcbiIpO3JldHVybjt9CgogICAgRW5hYmxlTWVudUl0ZW0oaE1lbnUsIElEU19DT1BZLCAKICAgICAgICAgICAgICAgICAgIE1GX0JZQ09NTUFORHwoUFJJVkFURShkYXRhKS0+aGFzX3NlbGVjdGlvbiA/IE1GX0VOQUJMRUQgOiBNRl9HUkFZRUQpKTsKICAgIEVuYWJsZU1lbnVJdGVtKGhNZW51LCBJRFNfUEFTVEUsIAoJCSAgIE1GX0JZQ09NTUFORHwoSXNDbGlwYm9hcmRGb3JtYXRBdmFpbGFibGUoQ0ZfVU5JQ09ERVRFWFQpIAoJCQkJID8gTUZfRU5BQkxFRCA6IE1GX0dSQVlFRCkpOwogICAgRW5hYmxlTWVudUl0ZW0oaE1lbnUsIElEU19TQ1JPTEwsIE1GX0JZQ09NTUFORHxNRl9HUkFZRUQpOwogICAgRW5hYmxlTWVudUl0ZW0oaE1lbnUsIElEU19TRUFSQ0gsIE1GX0JZQ09NTUFORHxNRl9HUkFZRUQpOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqCiAqCQlDVVNFUl9HZXRDdHJsS2V5U3RhdGUKICoKICogR2V0IHRoZSBjb25zb2xlIGJpdCBtYXNrIGVxdWl2YWxlbnQgdG8gdGhlIFZLXyBzdGF0dXMgaW4ga2V5U3RhdGUKICovCnN0YXRpYyBEV09SRCAgICBXQ1VTRVJfR2V0Q3RybEtleVN0YXRlKEJZVEUqIGtleVN0YXRlKQp7CiAgICBEV09SRCAgICAgICAgICAgICAgIHJldCA9IDA7CgogICAgR2V0S2V5Ym9hcmRTdGF0ZShrZXlTdGF0ZSk7CiAgICBpZiAoa2V5U3RhdGVbVktfU0hJRlRdICAgICYgMHg4MCkJcmV0IHw9IFNISUZUX1BSRVNTRUQ7CiAgICBpZiAoa2V5U3RhdGVbVktfQ09OVFJPTF0gICYgMHg4MCkJcmV0IHw9IExFRlRfQ1RSTF9QUkVTU0VEOyAvKiBGSVhNRTogZ290dGEgY2hvb3NlIG9uZSAqLwogICAgaWYgKGtleVN0YXRlW1ZLX0xDT05UUk9MXSAmIDB4ODApCXJldCB8PSBMRUZUX0NUUkxfUFJFU1NFRDsKICAgIGlmIChrZXlTdGF0ZVtWS19SQ09OVFJPTF0gJiAweDgwKQlyZXQgfD0gUklHSFRfQ1RSTF9QUkVTU0VEOwogICAgaWYgKGtleVN0YXRlW1ZLX0xNRU5VXSAgICAmIDB4ODApCXJldCB8PSBMRUZUX0FMVF9QUkVTU0VEOwogICAgaWYgKGtleVN0YXRlW1ZLX1JNRU5VXSAgICAmIDB4ODApCXJldCB8PSBSSUdIVF9BTFRfUFJFU1NFRDsKICAgIGlmIChrZXlTdGF0ZVtWS19DQVBJVEFMXSAgJiAweDAxKQlyZXQgfD0gQ0FQU0xPQ0tfT047CSAgICAKICAgIGlmIChrZXlTdGF0ZVtWS19OVU1MT0NLXSAgJiAweDAxKQlyZXQgfD0gTlVNTE9DS19PTjsKICAgIGlmIChrZXlTdGF0ZVtWS19TQ1JPTExdICAgJiAweDAxKQlyZXQgfD0gU0NST0xMTE9DS19PTjsKICAgIAogICAgcmV0dXJuIHJldDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX0hhbmRsZVNlbGVjdGlvbktleQogKgogKiBIYW5kbGVzIGtleXMgd2hpbGUgc2VsZWN0aW5nIGFuIGFyZWEKICovCnN0YXRpYyB2b2lkIFdDVVNFUl9IYW5kbGVTZWxlY3Rpb25LZXkoc3RydWN0IGlubmVyX2RhdGEqIGRhdGEsIEJPT0wgZG93biwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgV1BBUkFNIHdQYXJhbSwgTFBBUkFNIGxQYXJhbSkKewogICAgQllURQlrZXlTdGF0ZVsyNTZdOwogICAgRFdPUkQgICAgICAgc3RhdGUgPSBXQ1VTRVJfR2V0Q3RybEtleVN0YXRlKGtleVN0YXRlKSAmIH4oQ0FQU0xPQ0tfT058TlVNTE9DS19PTnxTQ1JPTExMT0NLX09OKTsKICAgIENPT1JEICAgICAgIGMxLCBjMjsKCiAgICBpZiAoZG93bikgcmV0dXJuOwoKICAgIHN3aXRjaCAoc3RhdGUpCiAgICB7CiAgICBjYXNlIDA6CiAgICAgICAgc3dpdGNoICh3UGFyYW0pCiAgICAgICAgewogICAgICAgIGNhc2UgVktfUkVUVVJOOgogICAgICAgICAgICBQUklWQVRFKGRhdGEpLT5oYXNfc2VsZWN0aW9uID0gRkFMU0U7CiAgICAgICAgICAgIFdDVVNFUl9TZXRTZWxlY3Rpb24oZGF0YSwgMCk7CiAgICAgICAgICAgIFdDVVNFUl9Db3B5U2VsZWN0aW9uVG9DbGlwYm9hcmQoZGF0YSk7CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgVktfUklHSFQ6CiAgICAgICAgICAgIGMxID0gUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxOwogICAgICAgICAgICBjMiA9IFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MjsKICAgICAgICAgICAgYzEuWCsrOyBjMi5YKys7CiAgICAgICAgICAgIGlmIChjMS5YIDwgZGF0YS0+Y3VyY2ZnLnNiX3dpZHRoICYmIGMyLlggPCBkYXRhLT5jdXJjZmcuc2Jfd2lkdGgpCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFdDVVNFUl9Nb3ZlU2VsZWN0aW9uKGRhdGEsIGMxLCBjMiwgRkFMU0UpOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgVktfTEVGVDoKICAgICAgICAgICAgYzEgPSBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDE7CiAgICAgICAgICAgIGMyID0gUFJJVkFURShkYXRhKS0+c2VsZWN0UHQyOwogICAgICAgICAgICBjMS5YLS07IGMyLlgtLTsKICAgICAgICAgICAgaWYgKGMxLlggPj0gMCAmJiBjMi5YID49IDApCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFdDVVNFUl9Nb3ZlU2VsZWN0aW9uKGRhdGEsIGMxLCBjMiwgRkFMU0UpOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgVktfVVA6CiAgICAgICAgICAgIGMxID0gUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxOwogICAgICAgICAgICBjMiA9IFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MjsKICAgICAgICAgICAgYzEuWS0tOyBjMi5ZLS07CiAgICAgICAgICAgIGlmIChjMS5ZID49IDAgJiYgYzIuWSA+PSAwKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBXQ1VTRVJfTW92ZVNlbGVjdGlvbihkYXRhLCBjMSwgYzIsIEZBTFNFKTsKICAgICAgICAgICAgfQogICAgICAgICAgICBicmVhazsKICAgICAgICBjYXNlIFZLX0RPV046CiAgICAgICAgICAgIGMxID0gUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxOwogICAgICAgICAgICBjMiA9IFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MjsKICAgICAgICAgICAgYzEuWSsrOyBjMi5ZKys7CiAgICAgICAgICAgIGlmIChjMS5YIDwgZGF0YS0+Y3VyY2ZnLnNiX2hlaWdodCAmJiBjMi5YIDwgZGF0YS0+Y3VyY2ZnLnNiX2hlaWdodCkKICAgICAgICAgICAgewogICAgICAgICAgICAgICAgV0NVU0VSX01vdmVTZWxlY3Rpb24oZGF0YSwgYzEsIGMyLCBGQUxTRSk7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgYnJlYWs7CiAgICAgICAgfQogICAgICAgIGJyZWFrOwogICAgY2FzZSBTSElGVF9QUkVTU0VEOgogICAgICAgIHN3aXRjaCAod1BhcmFtKQogICAgICAgIHsKICAgICAgICBjYXNlIFZLX1JJR0hUOgogICAgICAgICAgICBjMSA9IFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MTsKICAgICAgICAgICAgYzIgPSBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDI7CiAgICAgICAgICAgIGMyLlgrKzsKICAgICAgICAgICAgaWYgKGMyLlggPCBkYXRhLT5jdXJjZmcuc2Jfd2lkdGgpCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFdDVVNFUl9Nb3ZlU2VsZWN0aW9uKGRhdGEsIGMxLCBjMiwgRkFMU0UpOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgVktfTEVGVDoKICAgICAgICAgICAgYzEgPSBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDE7CiAgICAgICAgICAgIGMyID0gUFJJVkFURShkYXRhKS0+c2VsZWN0UHQyOwogICAgICAgICAgICBjMi5YLS07CiAgICAgICAgICAgIGlmIChjMi5YID49IGMxLlgpCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFdDVVNFUl9Nb3ZlU2VsZWN0aW9uKGRhdGEsIGMxLCBjMiwgRkFMU0UpOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIGNhc2UgVktfVVA6CiAgICAgICAgICAgIGMxID0gUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxOwogICAgICAgICAgICBjMiA9IFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MjsKICAgICAgICAgICAgYzIuWS0tOwogICAgICAgICAgICBpZiAoYzIuWSA+PSBjMS5ZKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBXQ1VTRVJfTW92ZVNlbGVjdGlvbihkYXRhLCBjMSwgYzIsIEZBTFNFKTsKICAgICAgICAgICAgfQogICAgICAgICAgICBicmVhazsKICAgICAgICBjYXNlIFZLX0RPV046CiAgICAgICAgICAgIGMxID0gUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxOwogICAgICAgICAgICBjMiA9IFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MjsKICAgICAgICAgICAgYzIuWSsrOwogICAgICAgICAgICBpZiAoYzIuWCA8IGRhdGEtPmN1cmNmZy5zYl9oZWlnaHQpCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFdDVVNFUl9Nb3ZlU2VsZWN0aW9uKGRhdGEsIGMxLCBjMiwgRkFMU0UpOwogICAgICAgICAgICB9CiAgICAgICAgICAgIGJyZWFrOwogICAgICAgIH0KICAgICAgICBicmVhazsKICAgIH0KfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX0dlbmVyYXRlS2V5SW5wdXRSZWNvcmQKICoKICogZ2VuZXJhdGVzIGlucHV0X3JlY29yZCBmcm9tIHdpbmRvd3MgV01fS0VZVVAvV01fS0VZRE9XTiBtZXNzYWdlcwogKi8Kc3RhdGljIHZvaWQgICAgV0NVU0VSX0dlbmVyYXRlS2V5SW5wdXRSZWNvcmQoc3RydWN0IGlubmVyX2RhdGEqIGRhdGEsIEJPT0wgZG93biwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFdQQVJBTSB3UGFyYW0sIExQQVJBTSBsUGFyYW0sIEJPT0wgc3lzKQp7CiAgICBJTlBVVF9SRUNPUkQJaXI7CiAgICBEV09SRAkJbjsKICAgIFdDSEFSCQlidWZbMl07CiAgICBzdGF0aWMJV0NIQVIJbGFzdDsgLyoga2VlcCBsYXN0IGNoYXIgc2VlbiBhcyBmZWVkIGZvciBrZXkgdXAgbWVzc2FnZSAqLwogICAgQllURQkJa2V5U3RhdGVbMjU2XTsKCiAgICBpci5FdmVudFR5cGUgPSBLRVlfRVZFTlQ7CiAgICBpci5FdmVudC5LZXlFdmVudC5iS2V5RG93biA9IGRvd247CiAgICBpci5FdmVudC5LZXlFdmVudC53UmVwZWF0Q291bnQgPSBMT1dPUkQobFBhcmFtKTsKICAgIGlyLkV2ZW50LktleUV2ZW50LndWaXJ0dWFsS2V5Q29kZSA9IHdQYXJhbTsKICAgIAogICAgaXIuRXZlbnQuS2V5RXZlbnQud1ZpcnR1YWxTY2FuQ29kZSA9IEhJV09SRChsUGFyYW0pICYgMHhGRjsKICAgIAogICAgaXIuRXZlbnQuS2V5RXZlbnQudUNoYXIuVW5pY29kZUNoYXIgPSAwOwogICAgaXIuRXZlbnQuS2V5RXZlbnQuZHdDb250cm9sS2V5U3RhdGUgPSBXQ1VTRVJfR2V0Q3RybEtleVN0YXRlKGtleVN0YXRlKTsKICAgIGlmIChsUGFyYW0gJiAoMUwgPDwgMjQpKQkJaXIuRXZlbnQuS2V5RXZlbnQuZHdDb250cm9sS2V5U3RhdGUgfD0gRU5IQU5DRURfS0VZOwogICAgaWYgKHN5cykJCQkJaXIuRXZlbnQuS2V5RXZlbnQuZHdDb250cm9sS2V5U3RhdGUgfD0gTEVGVF9BTFRfUFJFU1NFRDsgLyogRklYTUU6IGdvdHRhIGNob29zZSBvbmUgKi8KCiAgICBpZiAoIShpci5FdmVudC5LZXlFdmVudC5kd0NvbnRyb2xLZXlTdGF0ZSAmIEVOSEFOQ0VEX0tFWSkpCiAgICB7CglpZiAoZG93bikKCXsKCSAgICBzd2l0Y2ggKFRvVW5pY29kZSh3UGFyYW0sIEhJV09SRChsUGFyYW0pLCBrZXlTdGF0ZSwgYnVmLCAyLCAwKSkKCSAgICB7CgkgICAgY2FzZSAyOgoJCS8qIEZJWE1FLi4uIHNob3VsZCBnZW5lcmF0ZSB0d28gZXZlbnRzLi4uICovCgkJLyogZmFsbCB0aHJ1ICovCgkgICAgY2FzZSAxOgkKCQlsYXN0ID0gYnVmWzBdOwoJCWJyZWFrOwoJICAgIGRlZmF1bHQ6CgkJbGFzdCA9IDA7CgkJYnJlYWs7CgkgICAgfQoJfQoJaXIuRXZlbnQuS2V5RXZlbnQudUNoYXIuVW5pY29kZUNoYXIgPSBsYXN0OyAvKiBGSVhNRSBIQUNLWS4uLiBhbmQgYnVnZ3kgJ2NveiBpdCBzaG91bGQgYmUgYSBzdGFjaywgbm90IGEgc2luZ2xlIHZhbHVlICovCglpZiAoIWRvd24pIGxhc3QgPSAwOwogICAgfQoKICAgIFdyaXRlQ29uc29sZUlucHV0KGRhdGEtPmhDb25JbiwgJmlyLCAxLCAmbik7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9HZW5lcmF0ZU1vdXNlSW5wdXRSZWNvcmQKICoKICoKICovCnN0YXRpYyB2b2lkICAgIFdDVVNFUl9HZW5lcmF0ZU1vdXNlSW5wdXRSZWNvcmQoc3RydWN0IGlubmVyX2RhdGEqIGRhdGEsIENPT1JEIGMsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIFdQQVJBTSB3UGFyYW0sIERXT1JEIGV2ZW50KQp7CiAgICBJTlBVVF9SRUNPUkQJaXI7CiAgICBCWVRFCQlrZXlTdGF0ZVsyNTZdOwogICAgRFdPUkQgICAgICAgICAgICAgICBtb2RlLCBuOwoKICAgIC8qIE1PVVNFX0VWRU5UcyBzaG91bGRuJ3QgYmUgc2VudCB1bmxlc3MgRU5BQkxFX01PVVNFX0lOUFVUIGlzIGFjdGl2ZSAqLwogICAgaWYgKCFHZXRDb25zb2xlTW9kZShkYXRhLT5oQ29uSW4sICZtb2RlKSB8fCAhKG1vZGUgJiBFTkFCTEVfTU9VU0VfSU5QVVQpKQogICAgICAgIHJldHVybjsKCiAgICBpci5FdmVudFR5cGUgPSBNT1VTRV9FVkVOVDsKICAgIGlyLkV2ZW50Lk1vdXNlRXZlbnQuZHdNb3VzZVBvc2l0aW9uID0gYzsKICAgIGlyLkV2ZW50Lk1vdXNlRXZlbnQuZHdCdXR0b25TdGF0ZSA9IDA7CiAgICBpZiAod1BhcmFtICYgTUtfTEJVVFRPTikgaXIuRXZlbnQuTW91c2VFdmVudC5kd0J1dHRvblN0YXRlIHw9IEZST01fTEVGVF8xU1RfQlVUVE9OX1BSRVNTRUQ7CiAgICBpZiAod1BhcmFtICYgTUtfTUJVVFRPTikgaXIuRXZlbnQuTW91c2VFdmVudC5kd0J1dHRvblN0YXRlIHw9IEZST01fTEVGVF8yTkRfQlVUVE9OX1BSRVNTRUQ7CiAgICBpZiAod1BhcmFtICYgTUtfUkJVVFRPTikgaXIuRXZlbnQuTW91c2VFdmVudC5kd0J1dHRvblN0YXRlIHw9IFJJR0hUTU9TVF9CVVRUT05fUFJFU1NFRDsKICAgIGlyLkV2ZW50Lk1vdXNlRXZlbnQuZHdDb250cm9sS2V5U3RhdGUgPSBXQ1VTRVJfR2V0Q3RybEtleVN0YXRlKGtleVN0YXRlKTsKICAgIGlyLkV2ZW50Lk1vdXNlRXZlbnQuZHdFdmVudEZsYWdzID0gZXZlbnQ7CgogICAgV3JpdGVDb25zb2xlSW5wdXQoZGF0YS0+aENvbkluLCAmaXIsIDEsICZuKTsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX1Byb2MKICoKICoKICovCnN0YXRpYyBMUkVTVUxUIENBTExCQUNLIFdDVVNFUl9Qcm9jKEhXTkQgaFduZCwgVUlOVCB1TXNnLCBXUEFSQU0gd1BhcmFtLCBMUEFSQU0gbFBhcmFtKQp7CiAgICBzdHJ1Y3QgaW5uZXJfZGF0YSoJZGF0YSA9IChzdHJ1Y3QgaW5uZXJfZGF0YSopR2V0V2luZG93TG9uZyhoV25kLCAwKTsKCiAgICBzd2l0Y2ggKHVNc2cpCiAgICB7CiAgICBjYXNlIFdNX0NSRUFURToKICAgICAgICByZXR1cm4gV0NVU0VSX0NyZWF0ZShoV25kLCAoTFBDUkVBVEVTVFJVQ1QpbFBhcmFtKTsKICAgIGNhc2UgV01fREVTVFJPWToKCVBSSVZBVEUoZGF0YSktPmhXbmQgPSAwOwoJUG9zdFF1aXRNZXNzYWdlKDApOwoJYnJlYWs7CiAgICBjYXNlIFdNX1BBSU5UOgoJV0NVU0VSX1BhaW50KGRhdGEpOwoJYnJlYWs7CiAgICBjYXNlIFdNX0tFWURPV046CiAgICBjYXNlIFdNX0tFWVVQOgogICAgICAgIGlmIChQUklWQVRFKGRhdGEpLT5oYXNfc2VsZWN0aW9uKQogICAgICAgICAgICBXQ1VTRVJfSGFuZGxlU2VsZWN0aW9uS2V5KGRhdGEsIHVNc2cgPT0gV01fS0VZRE9XTiwgd1BhcmFtLCBsUGFyYW0pOwogICAgICAgIGVsc2UKICAgICAgICAgICAgV0NVU0VSX0dlbmVyYXRlS2V5SW5wdXRSZWNvcmQoZGF0YSwgdU1zZyA9PSBXTV9LRVlET1dOLCB3UGFyYW0sIGxQYXJhbSwgRkFMU0UpOwoJYnJlYWs7CiAgICBjYXNlIFdNX1NZU0tFWURPV046CiAgICBjYXNlIFdNX1NZU0tFWVVQOgoJV0NVU0VSX0dlbmVyYXRlS2V5SW5wdXRSZWNvcmQoZGF0YSwgdU1zZyA9PSBXTV9TWVNLRVlET1dOLCB3UGFyYW0sIGxQYXJhbSwgVFJVRSk7CglicmVhazsKICAgIGNhc2UgV01fTEJVVFRPTkRPV046CiAgICAgICAgaWYgKGRhdGEtPmN1cmNmZy5xdWlja19lZGl0KQogICAgICAgIHsKICAgICAgICAgICAgaWYgKFBSSVZBVEUoZGF0YSktPmhhc19zZWxlY3Rpb24pCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFBSSVZBVEUoZGF0YSktPmhhc19zZWxlY3Rpb24gPSBGQUxTRTsKICAgICAgICAgICAgICAgIFdDVVNFUl9TZXRTZWxlY3Rpb24oZGF0YSwgMCk7CiAgICAgICAgICAgIH0KICAgICAgICAgICAgZWxzZQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDEgPSBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDIgPSBXQ1VTRVJfR2V0Q2VsbChkYXRhLCBsUGFyYW0pOwogICAgICAgICAgICAgICAgU2V0Q2FwdHVyZShQUklWQVRFKGRhdGEpLT5oV25kKTsKICAgICAgICAgICAgICAgIFdDVVNFUl9TZXRTZWxlY3Rpb24oZGF0YSwgMCk7CiAgICAgICAgICAgICAgICBQUklWQVRFKGRhdGEpLT5oYXNfc2VsZWN0aW9uID0gVFJVRTsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgICAgICBlbHNlIAogICAgICAgIHsKICAgICAgICAgICAgV0NVU0VSX0dlbmVyYXRlTW91c2VJbnB1dFJlY29yZChkYXRhLCBXQ1VTRVJfR2V0Q2VsbChkYXRhLCBsUGFyYW0pLCB3UGFyYW0sIDApOwogICAgICAgIH0KCWJyZWFrOwogICAgY2FzZSBXTV9NT1VTRU1PVkU6CiAgICAgICAgaWYgKGRhdGEtPmN1cmNmZy5xdWlja19lZGl0KQogICAgICAgIHsKICAgICAgICAgICAgaWYgKEdldENhcHR1cmUoKSA9PSBQUklWQVRFKGRhdGEpLT5oV25kICYmIFBSSVZBVEUoZGF0YSktPmhhc19zZWxlY3Rpb24gJiYKICAgICAgICAgICAgICAgICh3UGFyYW0gJiBNS19MQlVUVE9OKSkKICAgICAgICAgICAgewogICAgICAgICAgICAgICAgV0NVU0VSX01vdmVTZWxlY3Rpb24oZGF0YSwgUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxLCBXQ1VTRVJfR2V0Q2VsbChkYXRhLCBsUGFyYW0pLCBGQUxTRSk7CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICAgICAgZWxzZQogICAgICAgIHsKICAgICAgICAgICAgV0NVU0VSX0dlbmVyYXRlTW91c2VJbnB1dFJlY29yZChkYXRhLCBXQ1VTRVJfR2V0Q2VsbChkYXRhLCBsUGFyYW0pLCB3UGFyYW0sIE1PVVNFX01PVkVEKTsKICAgICAgICB9CglicmVhazsKICAgIGNhc2UgV01fTEJVVFRPTlVQOgogICAgICAgIGlmIChkYXRhLT5jdXJjZmcucXVpY2tfZWRpdCkKICAgICAgICB7CiAgICAgICAgICAgIGlmIChHZXRDYXB0dXJlKCkgPT0gUFJJVkFURShkYXRhKS0+aFduZCAmJiBQUklWQVRFKGRhdGEpLT5oYXNfc2VsZWN0aW9uICYmIAogICAgICAgICAgICAgICAgKHdQYXJhbSYgTUtfTEJVVFRPTikpCiAgICAgICAgICAgIHsKICAgICAgICAgICAgICAgIFdDVVNFUl9Nb3ZlU2VsZWN0aW9uKGRhdGEsIFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0MSwgV0NVU0VSX0dldENlbGwoZGF0YSwgbFBhcmFtKSwgVFJVRSk7CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICAgICAgZWxzZQogICAgICAgIHsKICAgICAgICAgICAgV0NVU0VSX0dlbmVyYXRlTW91c2VJbnB1dFJlY29yZChkYXRhLCBXQ1VTRVJfR2V0Q2VsbChkYXRhLCBsUGFyYW0pLCB3UGFyYW0sIDApOwogICAgICAgIH0KCWJyZWFrOwogICAgY2FzZSBXTV9SQlVUVE9ORE9XTjoKICAgICAgICBpZiAoKHdQYXJhbSAmIChNS19DT05UUk9MfE1LX1NISUZUKSkgPT0gZGF0YS0+Y3VyY2ZnLm1lbnVfbWFzaykKICAgICAgICB7CiAgICAgICAgICAgIFJFQ1QgICAgICAgIHI7CgogICAgICAgICAgICBHZXRXaW5kb3dSZWN0KGhXbmQsICZyKTsKICAgICAgICAgICAgV0NVU0VSX1NldE1lbnVEZXRhaWxzKGRhdGEsIFBSSVZBVEUoZGF0YSktPmhQb3BNZW51KTsKICAgICAgICAgICAgVHJhY2tQb3B1cE1lbnUoUFJJVkFURShkYXRhKS0+aFBvcE1lbnUsIFRQTV9MRUZUQUxJR058VFBNX1RPUEFMSUdOLCAKICAgICAgICAgICAgICAgICAgICAgICAgICAgci5sZWZ0ICsgTE9XT1JEKGxQYXJhbSksIHIudG9wICsgSElXT1JEKGxQYXJhbSksIDAsIGhXbmQsIE5VTEwpOwogICAgICAgIH0KICAgICAgICBlbHNlCiAgICAgICAgewogICAgICAgICAgICBXQ1VTRVJfR2VuZXJhdGVNb3VzZUlucHV0UmVjb3JkKGRhdGEsIFdDVVNFUl9HZXRDZWxsKGRhdGEsIGxQYXJhbSksIHdQYXJhbSwgMCk7CiAgICAgICAgfQoJYnJlYWs7ICAgIAogICAgY2FzZSBXTV9SQlVUVE9OVVA6CiAgICAgICAgLyogbm8gbmVlZCB0byB0cmFjayBmb3IgcmJ1dHRvbiB1cCB3aGVuIG9wZW5pbmcgdGhlIHBvcHVwLi4uIHRoZSBldmVudCB3aWxsIGJlCiAgICAgICAgICogc3dhbGxvd2VkIGJ5IFRyYWNrUG9wdXBNZW51ICovCiAgICAgICAgV0NVU0VSX0dlbmVyYXRlTW91c2VJbnB1dFJlY29yZChkYXRhLCBXQ1VTRVJfR2V0Q2VsbChkYXRhLCBsUGFyYW0pLCB3UGFyYW0sIDApOwoJYnJlYWs7ICAgIAogICAgY2FzZSBXTV9NT1VTRVdIRUVMOgogICAgICAgIC8qIEZJWE1FOiBzaG91bGQgd2Ugc2Nyb2xsIHRvbyA/ICovCiAgICAgICAgV0NVU0VSX0dlbmVyYXRlTW91c2VJbnB1dFJlY29yZChkYXRhLCBXQ1VTRVJfR2V0Q2VsbChkYXRhLCBsUGFyYW0pLCB3UGFyYW0sIE1PVVNFX1dIRUVMRUQpOwoJYnJlYWs7ICAgIAogICAgY2FzZSBXTV9TRVRGT0NVUzoKCWlmIChkYXRhLT5jdXJjZmcuY3Vyc29yX3Zpc2libGUpCgl7CgkgICAgQ3JlYXRlQ2FyZXQoUFJJVkFURShkYXRhKS0+aFduZCwgUFJJVkFURShkYXRhKS0+Y3Vyc29yX2JpdG1hcCwgCiAgICAgICAgICAgICAgICAgICAgICAgIGRhdGEtPmN1cmNmZy5jZWxsX3dpZHRoLCBkYXRhLT5jdXJjZmcuY2VsbF9oZWlnaHQpOyAKCSAgICBXQ1VTRVJfUG9zQ3Vyc29yKGRhdGEpOwoJfQogICAgICAgIGJyZWFrOyAKICAgIGNhc2UgV01fS0lMTEZPQ1VTOiAKCWlmIChkYXRhLT5jdXJjZmcuY3Vyc29yX3Zpc2libGUpCgkgICAgRGVzdHJveUNhcmV0KCk7IAoJYnJlYWs7CiAgICBjYXNlIFdNX0hTQ1JPTEw6IAogICAgICAgIHsKICAgICAgICAgICAgaW50CXBvcyA9IGRhdGEtPmN1cmNmZy53aW5fcG9zLlg7CgogICAgICAgICAgICBzd2l0Y2ggKExPV09SRCh3UGFyYW0pKSAKICAgICAgICAgICAgeyAKICAgICAgICAgICAgY2FzZSBTQl9QQUdFVVA6IAlwb3MgLT0gODsgCQlicmVhazsgCiAgICAgICAgICAgIGNhc2UgU0JfUEFHRURPV046IAlwb3MgKz0gODsgCQlicmVhazsgCiAgICAgICAgICAgIGNhc2UgU0JfTElORVVQOiAJcG9zLS07CQkJYnJlYWs7CiAgICAgICAgICAgIGNhc2UgU0JfTElORURPV046IAlwb3MrKzsJIAkJYnJlYWs7CiAgICAgICAgICAgIGNhc2UgU0JfVEhVTUJUUkFDSzogcG9zID0gSElXT1JEKHdQYXJhbSk7CWJyZWFrOwogICAgICAgICAgICBkZWZhdWx0OiAJCQkJCWJyZWFrOwogICAgICAgICAgICB9IAogICAgICAgICAgICBpZiAocG9zIDwgMCkgcG9zID0gMDsKICAgICAgICAgICAgaWYgKHBvcyA+IGRhdGEtPmN1cmNmZy5zYl93aWR0aCAtIGRhdGEtPmN1cmNmZy53aW5fd2lkdGgpIAogICAgICAgICAgICAgICAgcG9zID0gZGF0YS0+Y3VyY2ZnLnNiX3dpZHRoIC0gZGF0YS0+Y3VyY2ZnLndpbl93aWR0aDsKICAgICAgICAgICAgaWYgKHBvcyAhPSBkYXRhLT5jdXJjZmcud2luX3Bvcy5YKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBTY3JvbGxXaW5kb3coaFduZCwgKGRhdGEtPmN1cmNmZy53aW5fcG9zLlggLSBwb3MpICogZGF0YS0+Y3VyY2ZnLmNlbGxfd2lkdGgsIDAsIAogICAgICAgICAgICAgICAgICAgICAgICAgICAgIE5VTEwsIE5VTEwpOwogICAgICAgICAgICAgICAgZGF0YS0+Y3VyY2ZnLndpbl9wb3MuWCA9IHBvczsKICAgICAgICAgICAgICAgIFNldFNjcm9sbFBvcyhoV25kLCBTQl9IT1JaLCBwb3MsIFRSVUUpOyAKICAgICAgICAgICAgICAgIFVwZGF0ZVdpbmRvdyhoV25kKTsgCiAgICAgICAgICAgICAgICBXQ1VTRVJfUG9zQ3Vyc29yKGRhdGEpOwogICAgICAgICAgICAgICAgV0lORUNPTl9Ob3RpZnlXaW5kb3dDaGFuZ2UoZGF0YSk7CiAgICAgICAgICAgIH0KICAgICAgICB9CglicmVhazsKICAgIGNhc2UgV01fVlNDUk9MTDogCiAgICAgICAgewoJICAgIGludAlwb3MgPSBkYXRhLT5jdXJjZmcud2luX3Bvcy5ZOwoKCSAgICBzd2l0Y2ggKExPV09SRCh3UGFyYW0pKSAKCSAgICB7IAogICAgICAgICAgICBjYXNlIFNCX1BBR0VVUDogCXBvcyAtPSA4OyAJCWJyZWFrOyAKICAgICAgICAgICAgY2FzZSBTQl9QQUdFRE9XTjogCXBvcyArPSA4OyAJCWJyZWFrOyAKICAgICAgICAgICAgY2FzZSBTQl9MSU5FVVA6IAlwb3MtLTsJCQlicmVhazsKCSAgICBjYXNlIFNCX0xJTkVET1dOOiAJcG9zKys7CSAJCWJyZWFrOwogICAgICAgICAgICBjYXNlIFNCX1RIVU1CVFJBQ0s6IHBvcyA9IEhJV09SRCh3UGFyYW0pOwlicmVhazsKICAgICAgICAgICAgZGVmYXVsdDogCQkJCQlicmVhazsKCSAgICB9IAoJICAgIGlmIChwb3MgPCAwKSBwb3MgPSAwOwoJICAgIGlmIChwb3MgPiBkYXRhLT5jdXJjZmcuc2JfaGVpZ2h0IC0gZGF0YS0+Y3VyY2ZnLndpbl9oZWlnaHQpIAogICAgICAgICAgICAgICAgcG9zID0gZGF0YS0+Y3VyY2ZnLnNiX2hlaWdodCAtIGRhdGEtPmN1cmNmZy53aW5faGVpZ2h0OwoJICAgIGlmIChwb3MgIT0gZGF0YS0+Y3VyY2ZnLndpbl9wb3MuWSkKCSAgICB7CgkJU2Nyb2xsV2luZG93KGhXbmQsIDAsIChkYXRhLT5jdXJjZmcud2luX3Bvcy5ZIC0gcG9zKSAqIGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodCwgCiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgTlVMTCwgTlVMTCk7CgkJZGF0YS0+Y3VyY2ZnLndpbl9wb3MuWSA9IHBvczsKCQlTZXRTY3JvbGxQb3MoaFduZCwgU0JfVkVSVCwgcG9zLCBUUlVFKTsgCgkJVXBkYXRlV2luZG93KGhXbmQpOyAKCQlXQ1VTRVJfUG9zQ3Vyc29yKGRhdGEpOwoJCVdJTkVDT05fTm90aWZ5V2luZG93Q2hhbmdlKGRhdGEpOwoJICAgIH0KCiAgICAgICAgfSAKICAgIGNhc2UgV01fU1lTQ09NTUFORDoKCXN3aXRjaCAod1BhcmFtKQoJewoJY2FzZSBJRFNfREVGQVVMVDoKCSAgICBXQ1VTRVJfR2V0UHJvcGVydGllcyhkYXRhLCBGQUxTRSk7CgkgICAgYnJlYWs7CgljYXNlIElEU19QUk9QRVJUWToKCSAgICBXQ1VTRVJfR2V0UHJvcGVydGllcyhkYXRhLCBUUlVFKTsKCSAgICBicmVhazsKCWRlZmF1bHQ6IAoJICAgIHJldHVybiBEZWZXaW5kb3dQcm9jKGhXbmQsIHVNc2csIHdQYXJhbSwgbFBhcmFtKTsKCX0KCWJyZWFrOwogICAgY2FzZSBXTV9DT01NQU5EOgoJc3dpdGNoICh3UGFyYW0pCgl7CgljYXNlIElEU19ERUZBVUxUOgoJICAgIFdDVVNFUl9HZXRQcm9wZXJ0aWVzKGRhdGEsIEZBTFNFKTsKCSAgICBicmVhazsKCWNhc2UgSURTX1BST1BFUlRZOgoJICAgIFdDVVNFUl9HZXRQcm9wZXJ0aWVzKGRhdGEsIFRSVUUpOwoJICAgIGJyZWFrOwoJY2FzZSBJRFNfTUFSSzoKICAgICAgICAgICAgUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxLlggPSBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDEuWSA9IDA7CiAgICAgICAgICAgIFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0Mi5YID0gUFJJVkFURShkYXRhKS0+c2VsZWN0UHQyLlkgPSAwOwogICAgICAgICAgICBXQ1VTRVJfU2V0U2VsZWN0aW9uKGRhdGEsIDApOwogICAgICAgICAgICBQUklWQVRFKGRhdGEpLT5oYXNfc2VsZWN0aW9uID0gVFJVRTsKCSAgICBicmVhazsKCWNhc2UgSURTX0NPUFk6CiAgICAgICAgICAgIGlmIChQUklWQVRFKGRhdGEpLT5oYXNfc2VsZWN0aW9uKQogICAgICAgICAgICB7CiAgICAgICAgICAgICAgICBQUklWQVRFKGRhdGEpLT5oYXNfc2VsZWN0aW9uID0gRkFMU0U7CiAgICAgICAgICAgICAgICBXQ1VTRVJfU2V0U2VsZWN0aW9uKGRhdGEsIDApOwogICAgICAgICAgICAgICAgV0NVU0VSX0NvcHlTZWxlY3Rpb25Ub0NsaXBib2FyZChkYXRhKTsKICAgICAgICAgICAgfQoJICAgIGJyZWFrOwoJY2FzZSBJRFNfUEFTVEU6CgkgICAgV0NVU0VSX1Bhc3RlRnJvbUNsaXBib2FyZChkYXRhKTsKCSAgICBicmVhazsKCWNhc2UgSURTX1NFTEVDVEFMTDoKICAgICAgICAgICAgUFJJVkFURShkYXRhKS0+c2VsZWN0UHQxLlggPSBQUklWQVRFKGRhdGEpLT5zZWxlY3RQdDEuWSA9IDA7CiAgICAgICAgICAgIFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0Mi5YID0gKGRhdGEtPmN1cmNmZy5zYl93aWR0aCAtIDEpICogZGF0YS0+Y3VyY2ZnLmNlbGxfd2lkdGg7CiAgICAgICAgICAgIFBSSVZBVEUoZGF0YSktPnNlbGVjdFB0Mi5ZID0gKGRhdGEtPmN1cmNmZy5zYl9oZWlnaHQgLSAxKSAqIGRhdGEtPmN1cmNmZy5jZWxsX2hlaWdodDsKICAgICAgICAgICAgV0NVU0VSX1NldFNlbGVjdGlvbihkYXRhLCAwKTsKICAgICAgICAgICAgUFJJVkFURShkYXRhKS0+aGFzX3NlbGVjdGlvbiA9IFRSVUU7CgkgICAgYnJlYWs7CgljYXNlIElEU19TQ1JPTEw6CgljYXNlIElEU19TRUFSQ0g6CgkgICAgVHJhY2UoMCwgInVuaGFuZGxlZCB5ZXQgY29tbWFuZDogJXhcbiIsIHdQYXJhbSk7CgkgICAgYnJlYWs7CglkZWZhdWx0OiAKCSAgICByZXR1cm4gRGVmV2luZG93UHJvYyhoV25kLCB1TXNnLCB3UGFyYW0sIGxQYXJhbSk7Cgl9CglicmVhazsKICAgIGNhc2UgV01fSU5JVE1FTlVQT1BVUDoKCWlmICghSElXT1JEKGxQYXJhbSkpCXJldHVybiBEZWZXaW5kb3dQcm9jKGhXbmQsIHVNc2csIHdQYXJhbSwgbFBhcmFtKTsKCVdDVVNFUl9TZXRNZW51RGV0YWlscyhkYXRhLCBHZXRTeXN0ZW1NZW51KFBSSVZBVEUoZGF0YSktPmhXbmQsIEZBTFNFKSk7CglicmVhazsKICAgIGRlZmF1bHQ6CglyZXR1cm4gRGVmV2luZG93UHJvYyhoV25kLCB1TXNnLCB3UGFyYW0sIGxQYXJhbSk7CiAgICB9CiAgICByZXR1cm4gMDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgkJV0NVU0VSX0RlbGV0ZUJhY2tlbmQKICoKICoKICovCnZvaWQgV0NVU0VSX0RlbGV0ZUJhY2tlbmQoc3RydWN0IGlubmVyX2RhdGEqIGRhdGEpCnsKICAgIGlmICghUFJJVkFURShkYXRhKSkgcmV0dXJuOwogICAgaWYgKFBSSVZBVEUoZGF0YSktPmhXbmQpCQlEZXN0cm95V2luZG93KFBSSVZBVEUoZGF0YSktPmhXbmQpOwogICAgaWYgKFBSSVZBVEUoZGF0YSktPmhGb250KQkJRGVsZXRlT2JqZWN0KFBSSVZBVEUoZGF0YSktPmhGb250KTsKICAgIGlmIChQUklWQVRFKGRhdGEpLT5jdXJzb3JfYml0bWFwKQlEZWxldGVPYmplY3QoUFJJVkFURShkYXRhKS0+Y3Vyc29yX2JpdG1hcCk7CiAgICBpZiAoUFJJVkFURShkYXRhKS0+aE1lbURDKQkJRGVsZXRlREMoUFJJVkFURShkYXRhKS0+aE1lbURDKTsKICAgIGlmIChQUklWQVRFKGRhdGEpLT5oQml0bWFwKQkJRGVsZXRlT2JqZWN0KFBSSVZBVEUoZGF0YSktPmhCaXRtYXApOwogICAgSGVhcEZyZWUoR2V0UHJvY2Vzc0hlYXAoKSwgMCwgUFJJVkFURShkYXRhKSk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9NYWluTG9vcAogKgogKgogKi8Kc3RhdGljIGludCBXQ1VTRVJfTWFpbkxvb3Aoc3RydWN0IGlubmVyX2RhdGEqIGRhdGEpCnsKICAgIE1TRwkJbXNnOwoKICAgIGZvciAoOzspIAogICAgewoJc3dpdGNoIChNc2dXYWl0Rm9yTXVsdGlwbGVPYmplY3RzKDEsICZkYXRhLT5oU3luY2hybywgRkFMU0UsIElORklOSVRFLCBRU19BTExJTlBVVCkpCgl7CgljYXNlIFdBSVRfT0JKRUNUXzA6CgkgICAgaWYgKCFXSU5FQ09OX0dyYWJDaGFuZ2VzKGRhdGEpKQoJCVBvc3RRdWl0TWVzc2FnZSgwKTsKCSAgICBicmVhazsKCWNhc2UgV0FJVF9PQkpFQ1RfMCsxOgoJICAgIHN3aXRjaCAoR2V0TWVzc2FnZSgmbXNnLCAwLCAwLCAwKSkKCSAgICB7CgkgICAgY2FzZSAtMTogLyogdGhlIGV2ZW50IGhhbmRsZSBiZWNhbWUgaW52YWxpZCwgc28gZXhpdCAqLwoJCXJldHVybiAtMTsKCSAgICBjYXNlIDA6IC8qIFdNX1FVSVQgaGFzIGJlZW4gcG9zdGVkICovCgkJcmV0dXJuIDA7CgkgICAgZGVmYXVsdDoKCQlEaXNwYXRjaE1lc3NhZ2UoJm1zZyk7CgkJYnJlYWs7CgkgICAgfQoJICAgIGJyZWFrOwoJZGVmYXVsdDoKCSAgICBUcmFjZSgwLCAiZ290IHBiXG4iKTsKCSAgICAvKiBlcnIgKi8KCSAgICBicmVhazsKCX0KICAgIH0JCn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioKICoJCVdDVVNFUl9Jbml0QmFja2VuZAogKgogKiBJbml0aWFsaXNhdGlvbiBwYXJ0IElJOiBjcmVhdGlvbiBvZiB3aW5kb3cuCiAqCiAqLwpCT09MIFdDVVNFUl9Jbml0QmFja2VuZChzdHJ1Y3QgaW5uZXJfZGF0YSogZGF0YSkKewogICAgc3RhdGljIFdDSEFSIHdDbGFzc05hbWVbXSA9IHsnVycsJ2knLCduJywnZScsJ0MnLCdvJywnbicsJ3MnLCdvJywnbCcsJ2UnLCdDJywnbCcsJ2EnLCdzJywncycsMH07CgogICAgV05EQ0xBU1MJCXduZGNsYXNzOwoKICAgIGRhdGEtPnByaXZhdGUgPSBIZWFwQWxsb2MoR2V0UHJvY2Vzc0hlYXAoKSwgSEVBUF9aRVJPX01FTU9SWSwgc2l6ZW9mKHN0cnVjdCBpbm5lcl9kYXRhX3VzZXIpKTsKICAgIGlmICghZGF0YS0+cHJpdmF0ZSkgcmV0dXJuIEZBTFNFOwoKICAgIGRhdGEtPmZuTWFpbkxvb3AgPSBXQ1VTRVJfTWFpbkxvb3A7CiAgICBkYXRhLT5mblBvc0N1cnNvciA9IFdDVVNFUl9Qb3NDdXJzb3I7CiAgICBkYXRhLT5mblNoYXBlQ3Vyc29yID0gV0NVU0VSX1NoYXBlQ3Vyc29yOwogICAgZGF0YS0+Zm5Db21wdXRlUG9zaXRpb25zID0gV0NVU0VSX0NvbXB1dGVQb3NpdGlvbnM7CiAgICBkYXRhLT5mblJlZnJlc2ggPSBXQ1VTRVJfUmVmcmVzaDsKICAgIGRhdGEtPmZuUmVzaXplU2NyZWVuQnVmZmVyID0gV0NVU0VSX1Jlc2l6ZVNjcmVlbkJ1ZmZlcjsKICAgIGRhdGEtPmZuU2V0VGl0bGUgPSBXQ1VTRVJfU2V0VGl0bGU7CiAgICBkYXRhLT5mblNjcm9sbCA9IFdDVVNFUl9TY3JvbGw7CiAgICBkYXRhLT5mbkRlbGV0ZUJhY2tlbmQgPSBXQ1VTRVJfRGVsZXRlQmFja2VuZDsKCiAgICB3bmRjbGFzcy5zdHlsZSAgICAgICAgID0gMDsKICAgIHduZGNsYXNzLmxwZm5XbmRQcm9jICAgPSBXQ1VTRVJfUHJvYzsKICAgIHduZGNsYXNzLmNiQ2xzRXh0cmEgICAgPSAwOwogICAgd25kY2xhc3MuY2JXbmRFeHRyYSAgICA9IHNpemVvZihEV09SRCk7CiAgICB3bmRjbGFzcy5oSW5zdGFuY2UgICAgID0gR2V0TW9kdWxlSGFuZGxlKE5VTEwpOwogICAgd25kY2xhc3MuaEljb24gICAgICAgICA9IExvYWRJY29uKDAsIElESV9XSU5MT0dPKTsKICAgIHduZGNsYXNzLmhDdXJzb3IgICAgICAgPSBMb2FkQ3Vyc29yKDAsIElEQ19BUlJPVyk7CiAgICB3bmRjbGFzcy5oYnJCYWNrZ3JvdW5kID0gR2V0U3RvY2tPYmplY3QoQkxBQ0tfQlJVU0gpOwogICAgd25kY2xhc3MubHBzek1lbnVOYW1lICA9IE5VTEw7CiAgICB3bmRjbGFzcy5scHN6Q2xhc3NOYW1lID0gd0NsYXNzTmFtZTsKICAKICAgIFJlZ2lzdGVyQ2xhc3MoJnduZGNsYXNzKTsKCiAgICBDcmVhdGVXaW5kb3cod25kY2xhc3MubHBzekNsYXNzTmFtZSwgTlVMTCwKCQkgV1NfT1ZFUkxBUFBFRHxXU19DQVBUSU9OfFdTX1NZU01FTlV8V1NfVEhJQ0tGUkFNRXxXU19NSU5JTUlaRUJPWHxXU19IU0NST0xMfFdTX1ZTQ1JPTEwsIAoJCSBDV19VU0VERUZBVUxULCBDV19VU0VERUZBVUxULCAwLCAwLCAwLCAwLCB3bmRjbGFzcy5oSW5zdGFuY2UsIGRhdGEpOyAgIAogICAgaWYgKCFQUklWQVRFKGRhdGEpLT5oV25kKSByZXR1cm4gRkFMU0U7CgogICAgLyogZm9yY2UgdXBkYXRlIG9mIGN1cnJlbnQgZGF0YSAqLwogICAgaWYgKCFXSU5FQ09OX0dyYWJDaGFuZ2VzKGRhdGEpKSByZXR1cm4gRkFMU0U7CgogICAgaWYgKCFXQ1VTRVJfSW5pdEZvbnQoZGF0YSkpIHJldHVybiBGQUxTRTsKCiAgICByZXR1cm4gVFJVRTsKfQoK