LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKiAgICAgICAgICAgICAgICAKICogRmlsZW5hbWU6ICAgICAgaXJ0dHAuYwogKiBWZXJzaW9uOiAgICAgICAxLjIKICogRGVzY3JpcHRpb246ICAgVGlueSBUcmFuc3BvcnQgUHJvdG9jb2wgKFRUUCkgaW1wbGVtZW50YXRpb24KICogU3RhdHVzOiAgICAgICAgU3RhYmxlCiAqIEF1dGhvcjogICAgICAgIERhZyBCcmF0dGxpIDxkYWdiQGNzLnVpdC5ubz4KICogQ3JlYXRlZCBhdDogICAgU3VuIEF1ZyAzMSAyMDoxNDozMSAxOTk3CiAqIE1vZGlmaWVkIGF0OiAgIFdlZCBKYW4gIDUgMTE6MzE6MjcgMjAwMAogKiBNb2RpZmllZCBieTogICBEYWcgQnJhdHRsaSA8ZGFnYkBjcy51aXQubm8+CiAqIAogKiAgICAgQ29weXJpZ2h0IChjKSAxOTk4LTIwMDAgRGFnIEJyYXR0bGkgPGRhZ2JAY3MudWl0Lm5vPiwgCiAqICAgICBBbGwgUmlnaHRzIFJlc2VydmVkLgogKiAgICAgQ29weXJpZ2h0IChjKSAyMDAwLTIwMDMgSmVhbiBUb3VycmlsaGVzIDxqdEBocGwuaHAuY29tPgogKiAgICAgCiAqICAgICBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yIAogKiAgICAgbW9kaWZ5IGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgCiAqICAgICBwdWJsaXNoZWQgYnkgdGhlIEZyZWUgU29mdHdhcmUgRm91bmRhdGlvbjsgZWl0aGVyIHZlcnNpb24gMiBvZiAKICogICAgIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLgogKgogKiAgICAgTmVpdGhlciBEYWcgQnJhdHRsaSBub3IgVW5pdmVyc2l0eSBvZiBUcm9tc/ggYWRtaXQgbGlhYmlsaXR5IG5vcgogKiAgICAgcHJvdmlkZSB3YXJyYW50eSBmb3IgYW55IG9mIHRoaXMgc29mdHdhcmUuIFRoaXMgbWF0ZXJpYWwgaXMgCiAqICAgICBwcm92aWRlZCAiQVMtSVMiIGFuZCBhdCBubyBjaGFyZ2UuCiAqCiAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi8KCiNpbmNsdWRlIDxsaW51eC9za2J1ZmYuaD4KI2luY2x1ZGUgPGxpbnV4L2luaXQuaD4KI2luY2x1ZGUgPGxpbnV4L3NlcV9maWxlLmg+CgojaW5jbHVkZSA8YXNtL2J5dGVvcmRlci5oPgojaW5jbHVkZSA8YXNtL3VuYWxpZ25lZC5oPgoKI2luY2x1ZGUgPG5ldC9pcmRhL2lyZGEuaD4KI2luY2x1ZGUgPG5ldC9pcmRhL2lybGFwLmg+CiNpbmNsdWRlIDxuZXQvaXJkYS9pcmxtcC5oPgojaW5jbHVkZSA8bmV0L2lyZGEvcGFyYW1ldGVycy5oPgojaW5jbHVkZSA8bmV0L2lyZGEvaXJ0dHAuaD4KCnN0YXRpYyBzdHJ1Y3QgaXJ0dHBfY2IgKmlydHRwOwoKc3RhdGljIHZvaWQgX19pcnR0cF9jbG9zZV90c2FwKHN0cnVjdCB0c2FwX2NiICpzZWxmKTsKCnN0YXRpYyBpbnQgaXJ0dHBfZGF0YV9pbmRpY2F0aW9uKHZvaWQgKmluc3RhbmNlLCB2b2lkICpzYXAsIAoJCQkJIHN0cnVjdCBza19idWZmICpza2IpOwpzdGF0aWMgaW50IGlydHRwX3VkYXRhX2luZGljYXRpb24odm9pZCAqaW5zdGFuY2UsIHZvaWQgKnNhcCwgCgkJCQkgIHN0cnVjdCBza19idWZmICpza2IpOwpzdGF0aWMgdm9pZCBpcnR0cF9kaXNjb25uZWN0X2luZGljYXRpb24odm9pZCAqaW5zdGFuY2UsIHZvaWQgKnNhcCwgIAoJCQkJCUxNX1JFQVNPTiByZWFzb24sIHN0cnVjdCBza19idWZmICopOwpzdGF0aWMgdm9pZCBpcnR0cF9jb25uZWN0X2luZGljYXRpb24odm9pZCAqaW5zdGFuY2UsIHZvaWQgKnNhcCwgCgkJCQkgICAgIHN0cnVjdCBxb3NfaW5mbyAqcW9zLCBfX3UzMiBtYXhfc2R1X3NpemUsCgkJCQkgICAgIF9fdTggaGVhZGVyX3NpemUsIHN0cnVjdCBza19idWZmICpza2IpOwpzdGF0aWMgdm9pZCBpcnR0cF9jb25uZWN0X2NvbmZpcm0odm9pZCAqaW5zdGFuY2UsIHZvaWQgKnNhcCwgCgkJCQkgIHN0cnVjdCBxb3NfaW5mbyAqcW9zLCBfX3UzMiBtYXhfc2R1X3NpemUsIAoJCQkJICBfX3U4IGhlYWRlcl9zaXplLCBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKTsKc3RhdGljIHZvaWQgaXJ0dHBfcnVuX3R4X3F1ZXVlKHN0cnVjdCB0c2FwX2NiICpzZWxmKTsKc3RhdGljIHZvaWQgaXJ0dHBfcnVuX3J4X3F1ZXVlKHN0cnVjdCB0c2FwX2NiICpzZWxmKTsKCnN0YXRpYyB2b2lkIGlydHRwX2ZsdXNoX3F1ZXVlcyhzdHJ1Y3QgdHNhcF9jYiAqc2VsZik7CnN0YXRpYyB2b2lkIGlydHRwX2ZyYWdtZW50X3NrYihzdHJ1Y3QgdHNhcF9jYiAqc2VsZiwgc3RydWN0IHNrX2J1ZmYgKnNrYik7CnN0YXRpYyBzdHJ1Y3Qgc2tfYnVmZiAqaXJ0dHBfcmVhc3NlbWJsZV9za2Ioc3RydWN0IHRzYXBfY2IgKnNlbGYpOwpzdGF0aWMgdm9pZCBpcnR0cF90b2RvX2V4cGlyZWQodW5zaWduZWQgbG9uZyBkYXRhKTsKc3RhdGljIGludCBpcnR0cF9wYXJhbV9tYXhfc2R1X3NpemUodm9pZCAqaW5zdGFuY2UsIGlyZGFfcGFyYW1fdCAqcGFyYW0sIAoJCQkJICAgIGludCBnZXQpOwoKc3RhdGljIHZvaWQgaXJ0dHBfZmxvd19pbmRpY2F0aW9uKHZvaWQgKmluc3RhbmNlLCB2b2lkICpzYXAsIExPQ0FMX0ZMT1cgZmxvdyk7CnN0YXRpYyB2b2lkIGlydHRwX3N0YXR1c19pbmRpY2F0aW9uKHZvaWQgKmluc3RhbmNlLAoJCQkJICAgIExJTktfU1RBVFVTIGxpbmssIExPQ0tfU1RBVFVTIGxvY2spOwoKLyogSW5mb3JtYXRpb24gZm9yIHBhcnNpbmcgcGFyYW1ldGVycyBpbiBJclRUUCAqLwpzdGF0aWMgcGlfbWlub3JfaW5mb190IHBpX21pbm9yX2NhbGxfdGFibGVbXSA9IHsKCXsgTlVMTCwgMCB9LCAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIC8qIDB4MDAgKi8KCXsgaXJ0dHBfcGFyYW1fbWF4X3NkdV9zaXplLCBQVl9JTlRFR0VSIHwgUFZfQklHX0VORElBTiB9IC8qIDB4MDEgKi8KfTsKc3RhdGljIHBpX21ham9yX2luZm9fdCBwaV9tYWpvcl9jYWxsX3RhYmxlW10gPSB7eyBwaV9taW5vcl9jYWxsX3RhYmxlLCAyIH19OwpzdGF0aWMgcGlfcGFyYW1faW5mb190IHBhcmFtX2luZm8gPSB7IHBpX21ham9yX2NhbGxfdGFibGUsIDEsIDB4MGYsIDQgfTsKCi8qKioqKioqKioqKioqKioqKioqKioqKiogR0xPQkFMIFBST0NFRFVSRVMgKioqKioqKioqKioqKioqKioqKioqKioqLwoKLyoKICogRnVuY3Rpb24gaXJ0dHBfaW5pdCAodm9pZCkKICoKICogICAgSW5pdGlhbGl6ZSB0aGUgSXJUVFAgbGF5ZXIuIENhbGxlZCBieSBtb2R1bGUgaW5pdGlhbGl6YXRpb24gY29kZQogKgogKi8KaW50IF9faW5pdCBpcnR0cF9pbml0KHZvaWQpCnsKCWlydHRwID0ga3phbGxvYyhzaXplb2Yoc3RydWN0IGlydHRwX2NiKSwgR0ZQX0tFUk5FTCk7CglpZiAoaXJ0dHAgPT0gTlVMTCkKCQlyZXR1cm4gLUVOT01FTTsKCglpcnR0cC0+bWFnaWMgPSBUVFBfTUFHSUM7CgoJaXJ0dHAtPnRzYXBzID0gaGFzaGJpbl9uZXcoSEJfTE9DSyk7CglpZiAoIWlydHRwLT50c2FwcykgewoJCUlSREFfRVJST1IoIiVzOiBjYW4ndCBhbGxvY2F0ZSBJclRUUCBoYXNoYmluIVxuIiwKCQkJICAgX19GVU5DVElPTl9fKTsKCQlrZnJlZShpcnR0cCk7CgkJcmV0dXJuIC1FTk9NRU07Cgl9CgoJcmV0dXJuIDA7Cn0KCi8qCiAqIEZ1bmN0aW9uIGlydHRwX2NsZWFudXAgKHZvaWQpCiAqCiAqICAgIENhbGxlZCBieSBtb2R1bGUgZGVzdHJ1Y3Rpb24vY2xlYW51cCBjb2RlCiAqCiAqLwp2b2lkIF9fZXhpdCBpcnR0cF9jbGVhbnVwKHZvaWQpIAp7CgkvKiBDaGVjayBmb3IgbWFpbiBzdHJ1Y3R1cmUgKi8KCUlSREFfQVNTRVJUKGlydHRwLT5tYWdpYyA9PSBUVFBfTUFHSUMsIHJldHVybjspOwoKCS8qCgkgKiAgRGVsZXRlIGhhc2hiaW4gYW5kIGNsb3NlIGFsbCBUU0FQIGluc3RhbmNlcyBpbiBpdAoJICovCgloYXNoYmluX2RlbGV0ZShpcnR0cC0+dHNhcHMsIChGUkVFX0ZVTkMpIF9faXJ0dHBfY2xvc2VfdHNhcCk7CgoJaXJ0dHAtPm1hZ2ljID0gMDsKCgkvKiBEZS1hbGxvY2F0ZSBtYWluIHN0cnVjdHVyZSAqLwoJa2ZyZWUoaXJ0dHApOwoKCWlydHRwID0gTlVMTDsKfQoKLyoqKioqKioqKioqKioqKioqKioqKioqKioqKiBTVUJST1VUSU5FUyAqKioqKioqKioqKioqKioqKioqKioqKioqKiovCgovKgogKiBGdW5jdGlvbiBpcnR0cF9zdGFydF90b2RvX3RpbWVyIChzZWxmLCB0aW1lb3V0KQogKgogKiAgICBTdGFydCB0b2RvIHRpbWVyLgogKgogKiBNYWRlIGl0IG1vcmUgZWZmaWVudCBhbmQgdW5zZW5zaXRpdmUgdG8gcmFjZSBjb25kaXRpb25zIC0gSmVhbiBJSQogKi8Kc3RhdGljIGlubGluZSB2b2lkIGlydHRwX3N0YXJ0X3RvZG9fdGltZXIoc3RydWN0IHRzYXBfY2IgKnNlbGYsIGludCB0aW1lb3V0KQp7CgkvKiBTZXQgbmV3IHZhbHVlIGZvciB0aW1lciAqLwoJbW9kX3RpbWVyKCZzZWxmLT50b2RvX3RpbWVyLCBqaWZmaWVzICsgdGltZW91dCk7Cn0KCi8qCiAqIEZ1bmN0aW9uIGlydHRwX3RvZG9fZXhwaXJlZCAoZGF0YSkKICoKICogICAgVG9kbyB0aW1lciBoYXMgZXhwaXJlZCEKICoKICogT25lIG9mIHRoZSByZXN0cmljdGlvbiBvZiB0aGUgdGltZXIgaXMgdGhhdCBpdCBpcyBydW4gb25seSBvbiB0aGUgdGltZXIKICogaW50ZXJydXB0IHdoaWNoIHJ1biBldmVyeSAxMG1zLiBUaGlzIG1lYW4gdGhhdCBldmVuIGlmIHlvdSBzZXQgdGhlIHRpbWVyCiAqIHdpdGggYSBkZWxheSBvZiAwLCBpdCBtYXkgdGFrZSB1cCB0byAxMG1zIGJlZm9yZSBpdCdzIHJ1bi4KICogU28sIHRvIG1pbmltaXNlIGxhdGVuY3kgYW5kIGtlZXAgY2FjaGUgZnJlc2gsIHdlIHRyeSB0byBhdm9pZCB1c2luZwogKiBpdCBhcyBtdWNoIGFzIHBvc3NpYmxlLgogKiBOb3RlIDogd2UgY2FuJ3QgdXNlIHRhc2tsZXRzLCBiZWNhdXNlIHRoZXkgY2FuJ3QgYmUgYXN5bmNocm9ub3VzbHkKICoga2lsbGVkIChuZWVkIHVzZXIgY29udGV4dCksIGFuZCB3ZSBjYW4ndCBndWFyYW50ZWUgdGhhdCBoZXJlLi4uCiAqIEplYW4gSUkKICovCnN0YXRpYyB2b2lkIGlydHRwX3RvZG9fZXhwaXJlZCh1bnNpZ25lZCBsb25nIGRhdGEpCnsKCXN0cnVjdCB0c2FwX2NiICpzZWxmID0gKHN0cnVjdCB0c2FwX2NiICopIGRhdGE7CgoJLyogQ2hlY2sgdGhhdCB3ZSBzdGlsbCBleGlzdCAqLwoJaWYgKCFzZWxmIHx8IHNlbGYtPm1hZ2ljICE9IFRUUF9UU0FQX01BR0lDKQoJCXJldHVybjsKCglJUkRBX0RFQlVHKDQsICIlcyhpbnN0YW5jZT0lcClcbiIsIF9fRlVOQ1RJT05fXywgc2VsZik7CgoJLyogVHJ5IHRvIG1ha2Ugc29tZSBwcm9ncmVzcywgZXNwZWNpYWxseSBvbiBUeCBzaWRlIC0gSmVhbiBJSSAqLwoJaXJ0dHBfcnVuX3J4X3F1ZXVlKHNlbGYpOwoJaXJ0dHBfcnVuX3R4X3F1ZXVlKHNlbGYpOwoKCS8qIENoZWNrIGlmIHRpbWUgZm9yIGRpc2Nvbm5lY3QgKi8KCWlmICh0ZXN0X2JpdCgwLCAmc2VsZi0+ZGlzY29ubmVjdF9wZW5kKSkgewoJCS8qIENoZWNrIGlmIGl0J3MgcG9zc2libGUgdG8gZGlzY29ubmVjdCB5ZXQgKi8KCQlpZiAoc2tiX3F1ZXVlX2VtcHR5KCZzZWxmLT50eF9xdWV1ZSkpIHsKCQkJLyogTWFrZSBzdXJlIGRpc2Nvbm5lY3QgaXMgbm90IHBlbmRpbmcgYW55bW9yZSAqLwoJCQljbGVhcl9iaXQoMCwgJnNlbGYtPmRpc2Nvbm5lY3RfcGVuZCk7CS8qIEZBTFNFICovCgoJCQkvKiBOb3RlIDogc2VsZi0+ZGlzY29ubmVjdF9za2IgbWF5IGJlIE5VTEwgKi8KCQkJaXJ0dHBfZGlzY29ubmVjdF9yZXF1ZXN0KHNlbGYsIHNlbGYtPmRpc2Nvbm5lY3Rfc2tiLAoJCQkJCQkgUF9OT1JNQUwpOwoJCQlzZWxmLT5kaXNjb25uZWN0X3NrYiA9IE5VTEw7CgkJfSBlbHNlIHsKCQkJLyogVHJ5IGFnYWluIGxhdGVyICovCgkJCWlydHRwX3N0YXJ0X3RvZG9fdGltZXIoc2VsZiwgSFovMTApOwoKCQkJLyogTm8gcmVhc29uIHRvIHRyeSBhbmQgY2xvc2Ugbm93ICovCgkJCXJldHVybjsKCQl9Cgl9CgoJLyogQ2hlY2sgaWYgaXQncyBjbG9zaW5nIHRpbWUgKi8KCWlmIChzZWxmLT5jbG9zZV9wZW5kKQoJCS8qIEZpbmlzaCBjbGVhbnVwICovCgkJaXJ0dHBfY2xvc2VfdHNhcChzZWxmKTsKfQoKLyoKICogRnVuY3Rpb24gaXJ0dHBfZmx1c2hfcXVldWVzIChzZWxmKQogKgogKiAgICAgRmx1c2hlcyAocmVtb3ZlcyBhbGwgZnJhbWVzKSBpbiB0cmFuc2l0dC1idWZmZXIgKHR4X2xpc3QpCiAqLwp2b2lkIGlydHRwX2ZsdXNoX3F1ZXVlcyhzdHJ1Y3QgdHNhcF9jYiAqc2VsZikKewoJc3RydWN0IHNrX2J1ZmYqIHNrYjsKCglJUkRBX0RFQlVHKDQsICIlcygpXG4iLCBfX0ZVTkNUSU9OX18pOwoKCUlSREFfQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuOyk7CgoJLyogRGVhbGxvY2F0ZSBmcmFtZXMgd2FpdGluZyB0byBiZSBzZW50ICovCgl3aGlsZSAoKHNrYiA9IHNrYl9kZXF1ZXVlKCZzZWxmLT50eF9xdWV1ZSkpICE9IE5VTEwpCgkJZGV2X2tmcmVlX3NrYihza2IpOwoKCS8qIERlYWxsb2NhdGUgcmVjZWl2ZWQgZnJhbWVzICovCgl3aGlsZSAoKHNrYiA9IHNrYl9kZXF1ZXVlKCZzZWxmLT5yeF9xdWV1ZSkpICE9IE5VTEwpCgkJZGV2X2tmcmVlX3NrYihza2IpOwoKCS8qIERlYWxsb2NhdGUgcmVjZWl2ZWQgZnJhZ21lbnRzICovCgl3aGlsZSAoKHNrYiA9IHNrYl9kZXF1ZXVlKCZzZWxmLT5yeF9mcmFnbWVudHMpKSAhPSBOVUxMKQoJCWRldl9rZnJlZV9za2Ioc2tiKTsKfQoKLyoKICogRnVuY3Rpb24gaXJ0dHBfcmVhc3NlbWJsZSAoc2VsZikKICoKICogICAgTWFrZXMgYSBuZXcgKGNvbnRpbnVvdXMpIHNrYiBvZiBhbGwgdGhlIGZyYWdtZW50cyBpbiB0aGUgZnJhZ21lbnQKICogICAgcXVldWUKICoKICovCnN0YXRpYyBzdHJ1Y3Qgc2tfYnVmZiAqaXJ0dHBfcmVhc3NlbWJsZV9za2Ioc3RydWN0IHRzYXBfY2IgKnNlbGYpCnsKCXN0cnVjdCBza19idWZmICpza2IsICpmcmFnOwoJaW50IG4gPSAwOyAgLyogRnJhZ21lbnQgaW5kZXggKi8KCglJUkRBX0FTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybiBOVUxMOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuIE5VTEw7KTsKCglJUkRBX0RFQlVHKDIsICIlcygpLCBzZWxmLT5yeF9zZHVfc2l6ZT0lZFxuIiwgX19GVU5DVElPTl9fLAoJCSAgIHNlbGYtPnJ4X3NkdV9zaXplKTsKCglza2IgPSBkZXZfYWxsb2Nfc2tiKFRUUF9IRUFERVIgKyBzZWxmLT5yeF9zZHVfc2l6ZSk7CglpZiAoIXNrYikKCQlyZXR1cm4gTlVMTDsKCgkvKgoJICogTmVlZCB0byByZXNlcnZlIHNwYWNlIGZvciBUVFAgaGVhZGVyIGluIGNhc2UgdGhpcyBza2IgbmVlZHMgdG8KCSAqIGJlIHJlcXVldWVkIGluIGNhc2UgZGVsaXZlcnkgZmFpbGVzCgkgKi8KCXNrYl9yZXNlcnZlKHNrYiwgVFRQX0hFQURFUik7Cglza2JfcHV0KHNrYiwgc2VsZi0+cnhfc2R1X3NpemUpOwoKCS8qCgkgKiAgQ29weSBhbGwgZnJhZ21lbnRzIHRvIGEgbmV3IGJ1ZmZlcgoJICovCgl3aGlsZSAoKGZyYWcgPSBza2JfZGVxdWV1ZSgmc2VsZi0+cnhfZnJhZ21lbnRzKSkgIT0gTlVMTCkgewoJCW1lbWNweShza2ItPmRhdGErbiwgZnJhZy0+ZGF0YSwgZnJhZy0+bGVuKTsKCQluICs9IGZyYWctPmxlbjsKCgkJZGV2X2tmcmVlX3NrYihmcmFnKTsKCX0KCglJUkRBX0RFQlVHKDIsCgkJICAgIiVzKCksIGZyYW1lIGxlbj0lZCwgcnhfc2R1X3NpemU9JWQsIHJ4X21heF9zZHVfc2l6ZT0lZFxuIiwKCQkgICBfX0ZVTkNUSU9OX18sIG4sIHNlbGYtPnJ4X3NkdV9zaXplLCBzZWxmLT5yeF9tYXhfc2R1X3NpemUpOwoJLyogTm90ZSA6IGlydHRwX3J1bl9yeF9xdWV1ZSgpIGNhbGN1bGF0ZSBzZWxmLT5yeF9zZHVfc2l6ZQoJICogYnkgc3VtbWluZyB0aGUgc2l6ZSBvZiBhbGwgZnJhZ21lbnRzLCBzbyB3ZSBzaG91bGQgYWx3YXlzCgkgKiBoYXZlIG4gPT0gc2VsZi0+cnhfc2R1X3NpemUsIGV4Y2VwdCBpbiBjYXNlcyB3aGVyZSB3ZQoJICogZHJvcGVkIHRoZSBsYXN0IGZyYWdtZW50ICh3aGVuIHNlbGYtPnJ4X3NkdV9zaXplIGV4Y2VlZAoJICogc2VsZi0+cnhfbWF4X3NkdV9zaXplKSwgd2hlcmUgbiA8IHNlbGYtPnJ4X3NkdV9zaXplLgoJICogSmVhbiBJSSAqLwoJSVJEQV9BU1NFUlQobiA8PSBzZWxmLT5yeF9zZHVfc2l6ZSwgbiA9IHNlbGYtPnJ4X3NkdV9zaXplOyk7CgoJLyogU2V0IHRoZSBuZXcgbGVuZ3RoICovCglza2JfdHJpbShza2IsIG4pOwoKCXNlbGYtPnJ4X3NkdV9zaXplID0gMDsKCglyZXR1cm4gc2tiOwp9CgovKgogKiBGdW5jdGlvbiBpcnR0cF9mcmFnbWVudF9za2IgKHNrYikKICoKICogICAgRnJhZ21lbnRzIGEgZnJhbWUgYW5kIHF1ZXVlcyBhbGwgdGhlIGZyYWdtZW50cyBmb3IgdHJhbnNtaXNzaW9uCiAqCiAqLwpzdGF0aWMgaW5saW5lIHZvaWQgaXJ0dHBfZnJhZ21lbnRfc2tiKHN0cnVjdCB0c2FwX2NiICpzZWxmLAoJCQkJICAgICAgc3RydWN0IHNrX2J1ZmYgKnNrYikKewoJc3RydWN0IHNrX2J1ZmYgKmZyYWc7CglfX3U4ICpmcmFtZTsKCglJUkRBX0RFQlVHKDIsICIlcygpXG4iLCBfX0ZVTkNUSU9OX18pOwoKCUlSREFfQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuOyk7CglJUkRBX0FTU0VSVChza2IgIT0gTlVMTCwgcmV0dXJuOyk7CgoJLyoKCSAqICBTcGxpdCBmcmFtZSBpbnRvIGEgbnVtYmVyIG9mIHNlZ21lbnRzCgkgKi8KCXdoaWxlIChza2ItPmxlbiA+IHNlbGYtPm1heF9zZWdfc2l6ZSkgewoJCUlSREFfREVCVUcoMiwgIiVzKCksIGZyYWdtZW50aW5nIC4uLlxuIiwgX19GVU5DVElPTl9fKTsKCgkJLyogTWFrZSBuZXcgc2VnbWVudCAqLwoJCWZyYWcgPSBhbGxvY19za2Ioc2VsZi0+bWF4X3NlZ19zaXplK3NlbGYtPm1heF9oZWFkZXJfc2l6ZSwKCQkJCSBHRlBfQVRPTUlDKTsKCQlpZiAoIWZyYWcpCgkJCXJldHVybjsKCgkJc2tiX3Jlc2VydmUoZnJhZywgc2VsZi0+bWF4X2hlYWRlcl9zaXplKTsKCgkJLyogQ29weSBkYXRhIGZyb20gdGhlIG9yaWdpbmFsIHNrYiBpbnRvIHRoaXMgZnJhZ21lbnQuICovCgkJbWVtY3B5KHNrYl9wdXQoZnJhZywgc2VsZi0+bWF4X3NlZ19zaXplKSwgc2tiLT5kYXRhLAoJCSAgICAgICBzZWxmLT5tYXhfc2VnX3NpemUpOwoKCQkvKiBJbnNlcnQgVFRQIGhlYWRlciwgd2l0aCB0aGUgbW9yZSBiaXQgc2V0ICovCgkJZnJhbWUgPSBza2JfcHVzaChmcmFnLCBUVFBfSEVBREVSKTsKCQlmcmFtZVswXSA9IFRUUF9NT1JFOwoKCQkvKiBIaWRlIHRoZSBjb3BpZWQgZGF0YSBmcm9tIHRoZSBvcmlnaW5hbCBza2IgKi8KCQlza2JfcHVsbChza2IsIHNlbGYtPm1heF9zZWdfc2l6ZSk7CgoJCS8qIFF1ZXVlIGZyYWdtZW50ICovCgkJc2tiX3F1ZXVlX3RhaWwoJnNlbGYtPnR4X3F1ZXVlLCBmcmFnKTsKCX0KCS8qIFF1ZXVlIHdoYXQgaXMgbGVmdCBvZiB0aGUgb3JpZ2luYWwgc2tiICovCglJUkRBX0RFQlVHKDIsICIlcygpLCBxdWV1aW5nIGxhc3Qgc2VnbWVudFxuIiwgX19GVU5DVElPTl9fKTsKCglmcmFtZSA9IHNrYl9wdXNoKHNrYiwgVFRQX0hFQURFUik7CglmcmFtZVswXSA9IDB4MDA7IC8qIENsZWFyIG1vcmUgYml0ICovCgoJLyogUXVldWUgZnJhZ21lbnQgKi8KCXNrYl9xdWV1ZV90YWlsKCZzZWxmLT50eF9xdWV1ZSwgc2tiKTsKfQoKLyoKICogRnVuY3Rpb24gaXJ0dHBfcGFyYW1fbWF4X3NkdV9zaXplIChzZWxmLCBwYXJhbSkKICoKICogICAgSGFuZGxlIHRoZSBNYXhTZHVTaXplIHBhcmFtZXRlciBpbiB0aGUgY29ubmVjdCBmcmFtZXMsIHRoaXMgZnVuY3Rpb24KICogICAgd2lsbCBiZSBjYWxsZWQgYm90aCB3aGVuIHRoaXMgcGFyYW1ldGVyIG5lZWRzIHRvIGJlIGluc2VydGVkIGludG8sIGFuZAogKiAgICBleHRyYWN0ZWQgZnJvbSB0aGUgY29ubmVjdCBmcmFtZXMKICovCnN0YXRpYyBpbnQgaXJ0dHBfcGFyYW1fbWF4X3NkdV9zaXplKHZvaWQgKmluc3RhbmNlLCBpcmRhX3BhcmFtX3QgKnBhcmFtLAoJCQkJICAgIGludCBnZXQpCnsKCXN0cnVjdCB0c2FwX2NiICpzZWxmOwoKCXNlbGYgPSAoc3RydWN0IHRzYXBfY2IgKikgaW5zdGFuY2U7CgoJSVJEQV9BU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm4gLTE7KTsKCUlSREFfQVNTRVJUKHNlbGYtPm1hZ2ljID09IFRUUF9UU0FQX01BR0lDLCByZXR1cm4gLTE7KTsKCglpZiAoZ2V0KQoJCXBhcmFtLT5wdi5pID0gc2VsZi0+dHhfbWF4X3NkdV9zaXplOwoJZWxzZQoJCXNlbGYtPnR4X21heF9zZHVfc2l6ZSA9IHBhcmFtLT5wdi5pOwoKCUlSREFfREVCVUcoMSwgIiVzKCksIE1heFNkdVNpemU9JWRcbiIsIF9fRlVOQ1RJT05fXywgcGFyYW0tPnB2LmkpOwoKCXJldHVybiAwOwp9CgovKioqKioqKioqKioqKioqKioqKioqKioqKioqIENMSUVOVCBDQUxMUyAqKioqKioqKioqKioqKioqKioqKioqKioqKiovCi8qKioqKioqKioqKioqKioqKioqKioqKioqKiBMTVAgQ0FMTEJBQ0tTICoqKioqKioqKioqKioqKioqKioqKioqKioqLwovKiBFdmVyeXRoaW5nIGlzIGhhcHBpbHkgbWl4ZWQgdXAuIFdhaXRpbmcgZm9yIG5leHQgY2xlYW4gdXAgLSBKZWFuIElJICovCgovKgogKiBGdW5jdGlvbiBpcnR0cF9vcGVuX3RzYXAgKHN0c2FwLCBub3RpZnkpCiAqCiAqICAgIENyZWF0ZSBUU0FQIGNvbm5lY3Rpb24gZW5kcG9pbnQsCiAqLwpzdHJ1Y3QgdHNhcF9jYiAqaXJ0dHBfb3Blbl90c2FwKF9fdTggc3RzYXBfc2VsLCBpbnQgY3JlZGl0LCBub3RpZnlfdCAqbm90aWZ5KQp7CglzdHJ1Y3QgdHNhcF9jYiAqc2VsZjsKCXN0cnVjdCBsc2FwX2NiICpsc2FwOwoJbm90aWZ5X3QgdHRwX25vdGlmeTsKCglJUkRBX0FTU0VSVChpcnR0cC0+bWFnaWMgPT0gVFRQX01BR0lDLCByZXR1cm4gTlVMTDspOwoKCS8qIFRoZSBJckxNUCBzcGVjIChJckxNUCAxLjEgcDEwKSBzYXlzIHRoYXQgd2UgaGF2ZSB0aGUgcmlnaHQgdG8KCSAqIHVzZSBvbmx5IDB4MDEtMHg2Ri4gT2YgY291cnNlLCB3ZSBjYW4gdXNlIExTQVBfQU5ZIGFzIHdlbGwuCgkgKiBKZWFuSUkgKi8KCWlmKChzdHNhcF9zZWwgIT0gTFNBUF9BTlkpICYmCgkgICAoKHN0c2FwX3NlbCA8IDB4MDEpIHx8IChzdHNhcF9zZWwgPj0gMHg3MCkpKSB7CgkJSVJEQV9ERUJVRygwLCAiJXMoKSwgaW52YWxpZCB0c2FwIVxuIiwgX19GVU5DVElPTl9fKTsKCQlyZXR1cm4gTlVMTDsKCX0KCglzZWxmID0ga3phbGxvYyhzaXplb2Yoc3RydWN0IHRzYXBfY2IpLCBHRlBfQVRPTUlDKTsKCWlmIChzZWxmID09IE5VTEwpIHsKCQlJUkRBX0RFQlVHKDAsICIlcygpLCB1bmFibGUgdG8ga21hbGxvYyFcbiIsIF9fRlVOQ1RJT05fXyk7CgkJcmV0dXJuIE5VTEw7Cgl9CglzcGluX2xvY2tfaW5pdCgmc2VsZi0+bG9jayk7CgoJLyogSW5pdGlhbGlzZSB0b2RvIHRpbWVyICovCglpbml0X3RpbWVyKCZzZWxmLT50b2RvX3RpbWVyKTsKCXNlbGYtPnRvZG9fdGltZXIuZGF0YSAgICAgPSAodW5zaWduZWQgbG9uZykgc2VsZjsKCXNlbGYtPnRvZG9fdGltZXIuZnVuY3Rpb24gPSAmaXJ0dHBfdG9kb19leHBpcmVkOwoKCS8qIEluaXRpYWxpemUgY2FsbGJhY2tzIGZvciBJckxNUCB0byB1c2UgKi8KCWlyZGFfbm90aWZ5X2luaXQoJnR0cF9ub3RpZnkpOwoJdHRwX25vdGlmeS5jb25uZWN0X2NvbmZpcm0gPSBpcnR0cF9jb25uZWN0X2NvbmZpcm07Cgl0dHBfbm90aWZ5LmNvbm5lY3RfaW5kaWNhdGlvbiA9IGlydHRwX2Nvbm5lY3RfaW5kaWNhdGlvbjsKCXR0cF9ub3RpZnkuZGlzY29ubmVjdF9pbmRpY2F0aW9uID0gaXJ0dHBfZGlzY29ubmVjdF9pbmRpY2F0aW9uOwoJdHRwX25vdGlmeS5kYXRhX2luZGljYXRpb24gPSBpcnR0cF9kYXRhX2luZGljYXRpb247Cgl0dHBfbm90aWZ5LnVkYXRhX2luZGljYXRpb24gPSBpcnR0cF91ZGF0YV9pbmRpY2F0aW9uOwoJdHRwX25vdGlmeS5mbG93X2luZGljYXRpb24gPSBpcnR0cF9mbG93X2luZGljYXRpb247CglpZihub3RpZnktPnN0YXR1c19pbmRpY2F0aW9uICE9IE5VTEwpCgkJdHRwX25vdGlmeS5zdGF0dXNfaW5kaWNhdGlvbiA9IGlydHRwX3N0YXR1c19pbmRpY2F0aW9uOwoJdHRwX25vdGlmeS5pbnN0YW5jZSA9IHNlbGY7CglzdHJuY3B5KHR0cF9ub3RpZnkubmFtZSwgbm90aWZ5LT5uYW1lLCBOT1RJRllfTUFYX05BTUUpOwoKCXNlbGYtPm1hZ2ljID0gVFRQX1RTQVBfTUFHSUM7CglzZWxmLT5jb25uZWN0ZWQgPSBGQUxTRTsKCglza2JfcXVldWVfaGVhZF9pbml0KCZzZWxmLT5yeF9xdWV1ZSk7Cglza2JfcXVldWVfaGVhZF9pbml0KCZzZWxmLT50eF9xdWV1ZSk7Cglza2JfcXVldWVfaGVhZF9pbml0KCZzZWxmLT5yeF9mcmFnbWVudHMpOwoJLyoKCSAqICBDcmVhdGUgTFNBUCBhdCBJckxNUCBsYXllcgoJICovCglsc2FwID0gaXJsbXBfb3Blbl9sc2FwKHN0c2FwX3NlbCwgJnR0cF9ub3RpZnksIDApOwoJaWYgKGxzYXAgPT0gTlVMTCkgewoJCUlSREFfV0FSTklORygiJXM6IHVuYWJsZSB0byBhbGxvY2F0ZSBMU0FQISFcbiIsIF9fRlVOQ1RJT05fXyk7CgkJcmV0dXJuIE5VTEw7Cgl9CgoJLyoKCSAqICBJZiB1c2VyIHNwZWNpZmllZCBMU0FQX0FOWSBhcyBzb3VyY2UgVFNBUCBzZWxlY3RvciwgdGhlbiBJckxNUAoJICogIHdpbGwgcmVwbGFjZSBpdCB3aXRoIHdoYXRldmVyIHNvdXJjZSBzZWxlY3RvciB3aGljaCBpcyBmcmVlLCBzbwoJICogIHRoZSBzdHNhcF9zZWwgd2UgaGF2ZSBtaWdodCBub3QgYmUgdmFsaWQgYW55bW9yZQoJICovCglzZWxmLT5zdHNhcF9zZWwgPSBsc2FwLT5zbHNhcF9zZWw7CglJUkRBX0RFQlVHKDQsICIlcygpLCBzdHNhcF9zZWw9JTAyeFxuIiwgX19GVU5DVElPTl9fLCBzZWxmLT5zdHNhcF9zZWwpOwoKCXNlbGYtPm5vdGlmeSA9ICpub3RpZnk7CglzZWxmLT5sc2FwID0gbHNhcDsKCgloYXNoYmluX2luc2VydChpcnR0cC0+dHNhcHMsIChpcmRhX3F1ZXVlX3QgKikgc2VsZiwgKGxvbmcpIHNlbGYsIE5VTEwpOwoKCWlmIChjcmVkaXQgPiBUVFBfUlhfTUFYX0NSRURJVCkKCQlzZWxmLT5pbml0aWFsX2NyZWRpdCA9IFRUUF9SWF9NQVhfQ1JFRElUOwoJZWxzZQoJCXNlbGYtPmluaXRpYWxfY3JlZGl0ID0gY3JlZGl0OwoKCXJldHVybiBzZWxmOwp9CkVYUE9SVF9TWU1CT0woaXJ0dHBfb3Blbl90c2FwKTsKCi8qCiAqIEZ1bmN0aW9uIGlydHRwX2Nsb3NlIChoYW5kbGUpCiAqCiAqICAgIFJlbW92ZSBhbiBpbnN0YW5jZSBvZiBhIFRTQVAuIFRoaXMgZnVuY3Rpb24gc2hvdWxkIG9ubHkgZGVhbCB3aXRoIHRoZQogKiAgICBkZWFsbG9jYXRpb24gb2YgdGhlIFRTQVAsIGFuZCByZXNldHRpbmcgb2YgdGhlIFRTQVBzIHZhbHVlczsKICoKICovCnN0YXRpYyB2b2lkIF9faXJ0dHBfY2xvc2VfdHNhcChzdHJ1Y3QgdHNhcF9jYiAqc2VsZikKewoJLyogRmlyc3QgbWFrZSBzdXJlIHdlJ3JlIGNvbm5lY3RlZC4gKi8KCUlSREFfQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuOyk7CgoJaXJ0dHBfZmx1c2hfcXVldWVzKHNlbGYpOwoKCWRlbF90aW1lcigmc2VsZi0+dG9kb190aW1lcik7CgoJLyogVGhpcyBvbmUgd29uJ3QgYmUgY2xlYW5lZCB1cCBpZiB3ZSBhcmUgZGlzY29ubmVjdF9wZW5kICsgY2xvc2VfcGVuZAoJICogYW5kIHdlIHJlY2VpdmUgYSBkaXNjb25uZWN0X2luZGljYXRpb24gKi8KCWlmIChzZWxmLT5kaXNjb25uZWN0X3NrYikKCQlkZXZfa2ZyZWVfc2tiKHNlbGYtPmRpc2Nvbm5lY3Rfc2tiKTsKCglzZWxmLT5jb25uZWN0ZWQgPSBGQUxTRTsKCXNlbGYtPm1hZ2ljID0gflRUUF9UU0FQX01BR0lDOwoKCWtmcmVlKHNlbGYpOwp9CgovKgogKiBGdW5jdGlvbiBpcnR0cF9jbG9zZSAoc2VsZikKICoKICogICAgUmVtb3ZlIFRTQVAgZnJvbSBsaXN0IG9mIGFsbCBUU0FQcyBhbmQgdGhlbiBkZWFsbG9jYXRlIGFsbCByZXNvdXJjZXMKICogICAgYXNzb2NpYXRlZCB3aXRoIHRoaXMgVFNBUAogKgogKiBOb3RlIDogYmVjYXVzZSB3ZSAqZnJlZSogdGhlIHRzYXAgc3RydWN0dXJlLCBpdCBpcyB0aGUgcmVzcG9uc2liaWxpdHkKICogb2YgdGhlIGNhbGxlciB0byBtYWtlIHN1cmUgd2UgYXJlIGNhbGxlZCBvbmx5IG9uY2UgYW5kIHRvIGRlYWwgd2l0aAogKiBwb3NzaWJsZSByYWNlIGNvbmRpdGlvbnMuIC0gSmVhbiBJSQogKi8KaW50IGlydHRwX2Nsb3NlX3RzYXAoc3RydWN0IHRzYXBfY2IgKnNlbGYpCnsKCXN0cnVjdCB0c2FwX2NiICp0c2FwOwoKCUlSREFfREVCVUcoNCwgIiVzKClcbiIsIF9fRlVOQ1RJT05fXyk7CgoJSVJEQV9BU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm4gLTE7KTsKCUlSREFfQVNTRVJUKHNlbGYtPm1hZ2ljID09IFRUUF9UU0FQX01BR0lDLCByZXR1cm4gLTE7KTsKCgkvKiBNYWtlIHN1cmUgdHNhcCBoYXMgYmVlbiBkaXNjb25uZWN0ZWQgKi8KCWlmIChzZWxmLT5jb25uZWN0ZWQpIHsKCQkvKiBDaGVjayBpZiBkaXNjb25uZWN0IGlzIG5vdCBwZW5kaW5nICovCgkJaWYgKCF0ZXN0X2JpdCgwLCAmc2VsZi0+ZGlzY29ubmVjdF9wZW5kKSkgewoJCQlJUkRBX1dBUk5JTkcoIiVzOiBUU0FQIHN0aWxsIGNvbm5lY3RlZCFcbiIsCgkJCQkgICAgIF9fRlVOQ1RJT05fXyk7CgkJCWlydHRwX2Rpc2Nvbm5lY3RfcmVxdWVzdChzZWxmLCBOVUxMLCBQX05PUk1BTCk7CgkJfQoJCXNlbGYtPmNsb3NlX3BlbmQgPSBUUlVFOwoJCWlydHRwX3N0YXJ0X3RvZG9fdGltZXIoc2VsZiwgSFovMTApOwoKCQlyZXR1cm4gMDsgLyogV2lsbCBiZSBiYWNrISAqLwoJfQoKCXRzYXAgPSBoYXNoYmluX3JlbW92ZShpcnR0cC0+dHNhcHMsIChsb25nKSBzZWxmLCBOVUxMKTsKCglJUkRBX0FTU0VSVCh0c2FwID09IHNlbGYsIHJldHVybiAtMTspOwoKCS8qIENsb3NlIGNvcnJlc3BvbmRpbmcgTFNBUCAqLwoJaWYgKHNlbGYtPmxzYXApIHsKCQlpcmxtcF9jbG9zZV9sc2FwKHNlbGYtPmxzYXApOwoJCXNlbGYtPmxzYXAgPSBOVUxMOwoJfQoKCV9faXJ0dHBfY2xvc2VfdHNhcChzZWxmKTsKCglyZXR1cm4gMDsKfQpFWFBPUlRfU1lNQk9MKGlydHRwX2Nsb3NlX3RzYXApOwoKLyoKICogRnVuY3Rpb24gaXJ0dHBfdWRhdGFfcmVxdWVzdCAoc2VsZiwgc2tiKQogKgogKiAgICBTZW5kIHVucmVsaWFibGUgZGF0YSBvbiB0aGlzIFRTQVAKICoKICovCmludCBpcnR0cF91ZGF0YV9yZXF1ZXN0KHN0cnVjdCB0c2FwX2NiICpzZWxmLCBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglJUkRBX0FTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybiAtMTspOwoJSVJEQV9BU1NFUlQoc2VsZi0+bWFnaWMgPT0gVFRQX1RTQVBfTUFHSUMsIHJldHVybiAtMTspOwoJSVJEQV9BU1NFUlQoc2tiICE9IE5VTEwsIHJldHVybiAtMTspOwoKCUlSREFfREVCVUcoNCwgIiVzKClcbiIsIF9fRlVOQ1RJT05fXyk7CgoJLyogQ2hlY2sgdGhhdCBub3RoaW5nIGJhZCBoYXBwZW5zICovCglpZiAoKHNrYi0+bGVuID09IDApIHx8ICghc2VsZi0+Y29ubmVjdGVkKSkgewoJCUlSREFfREVCVUcoMSwgIiVzKCksIE5vIGRhdGEsIG9yIG5vdCBjb25uZWN0ZWRcbiIsCgkJCSAgIF9fRlVOQ1RJT05fXyk7CgkJZ290byBlcnI7Cgl9CgoJaWYgKHNrYi0+bGVuID4gc2VsZi0+bWF4X3NlZ19zaXplKSB7CgkJSVJEQV9ERUJVRygxLCAiJXMoKSwgVURhdGEgaXMgdG8gbGFyZ2UgZm9yIElyTEFQIVxuIiwKCQkJICAgX19GVU5DVElPTl9fKTsKCQlnb3RvIGVycjsKCX0KCglpcmxtcF91ZGF0YV9yZXF1ZXN0KHNlbGYtPmxzYXAsIHNrYik7CglzZWxmLT5zdGF0cy50eF9wYWNrZXRzKys7CgoJcmV0dXJuIDA7CgplcnI6CglkZXZfa2ZyZWVfc2tiKHNrYik7CglyZXR1cm4gLTE7Cn0KRVhQT1JUX1NZTUJPTChpcnR0cF91ZGF0YV9yZXF1ZXN0KTsKCgovKgogKiBGdW5jdGlvbiBpcnR0cF9kYXRhX3JlcXVlc3QgKGhhbmRsZSwgc2tiKQogKgogKiAgICBRdWV1ZSBmcmFtZSBmb3IgdHJhbnNtaXNzaW9uLiBJZiBTQVIgaXMgZW5hYmxlZCwgZnJhZ2VtZW50IHRoZSBmcmFtZQogKiAgICBhbmQgcXVldWUgdGhlIGZyYWdtZW50cyBmb3IgdHJhbnNtaXNzaW9uCiAqLwppbnQgaXJ0dHBfZGF0YV9yZXF1ZXN0KHN0cnVjdCB0c2FwX2NiICpzZWxmLCBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglfX3U4ICpmcmFtZTsKCWludCByZXQ7CgoJSVJEQV9BU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm4gLTE7KTsKCUlSREFfQVNTRVJUKHNlbGYtPm1hZ2ljID09IFRUUF9UU0FQX01BR0lDLCByZXR1cm4gLTE7KTsKCUlSREFfQVNTRVJUKHNrYiAhPSBOVUxMLCByZXR1cm4gLTE7KTsKCglJUkRBX0RFQlVHKDIsICIlcygpIDogcXVldWUgbGVuID0gJWRcbiIsIF9fRlVOQ1RJT05fXywKCQkgICBza2JfcXVldWVfbGVuKCZzZWxmLT50eF9xdWV1ZSkpOwoKCS8qIENoZWNrIHRoYXQgbm90aGluZyBiYWQgaGFwcGVucyAqLwoJaWYgKChza2ItPmxlbiA9PSAwKSB8fCAoIXNlbGYtPmNvbm5lY3RlZCkpIHsKCQlJUkRBX1dBUk5JTkcoIiVzOiBObyBkYXRhLCBvciBub3QgY29ubmVjdGVkXG4iLCBfX0ZVTkNUSU9OX18pOwoJCXJldCA9IC1FTk9UQ09OTjsKCQlnb3RvIGVycjsKCX0KCgkvKgoJICogIENoZWNrIGlmIFNBUiBpcyBkaXNhYmxlZCwgYW5kIHRoZSBmcmFtZSBpcyBsYXJnZXIgdGhhbiB3aGF0IGZpdHMKCSAqICBpbnNpZGUgYW4gSXJMQVAgZnJhbWUKCSAqLwoJaWYgKChzZWxmLT50eF9tYXhfc2R1X3NpemUgPT0gMCkgJiYgKHNrYi0+bGVuID4gc2VsZi0+bWF4X3NlZ19zaXplKSkgewoJCUlSREFfRVJST1IoIiVzOiBTQVIgZGlzYWJsZWQsIGFuZCBkYXRhIGlzIHRvIGxhcmdlIGZvciBJckxBUCFcbiIsCgkJCSAgIF9fRlVOQ1RJT05fXyk7CgkJcmV0ID0gLUVNU0dTSVpFOwoJCWdvdG8gZXJyOwoJfQoKCS8qCgkgKiAgQ2hlY2sgaWYgU0FSIGlzIGVuYWJsZWQsIGFuZCB0aGUgZnJhbWUgaXMgbGFyZ2VyIHRoYW4gdGhlCgkgKiAgVHhNYXhTZHVTaXplCgkgKi8KCWlmICgoc2VsZi0+dHhfbWF4X3NkdV9zaXplICE9IDApICYmCgkgICAgKHNlbGYtPnR4X21heF9zZHVfc2l6ZSAhPSBUVFBfU0FSX1VOQk9VTkQpICYmCgkgICAgKHNrYi0+bGVuID4gc2VsZi0+dHhfbWF4X3NkdV9zaXplKSkKCXsKCQlJUkRBX0VSUk9SKCIlczogU0FSIGVuYWJsZWQsIGJ1dCBkYXRhIGlzIGxhcmdlciB0aGFuIFR4TWF4U2R1U2l6ZSFcbiIsCgkJCSAgIF9fRlVOQ1RJT05fXyk7CgkJcmV0ID0gLUVNU0dTSVpFOwoJCWdvdG8gZXJyOwoJfQoJLyoKCSAqICBDaGVjayBpZiB0cmFuc21pdCBxdWV1ZSBpcyBmdWxsCgkgKi8KCWlmIChza2JfcXVldWVfbGVuKCZzZWxmLT50eF9xdWV1ZSkgPj0gVFRQX1RYX01BWF9RVUVVRSkgewoJCS8qCgkJICogIEdpdmUgaXQgYSBjaGFuY2UgdG8gZW1wdHkgaXRzZWxmCgkJICovCgkJaXJ0dHBfcnVuX3R4X3F1ZXVlKHNlbGYpOwoKCQkvKiBEcm9wIHBhY2tldC4gVGhpcyBlcnJvciBjb2RlIHNob3VsZCB0cmlnZ2VyIHRoZSBjYWxsZXIKCQkgKiB0byByZXNlbmQgdGhlIGRhdGEgaW4gdGhlIGNsaWVudCBjb2RlIC0gSmVhbiBJSSAqLwoJCXJldCA9IC1FTk9CVUZTOwoJCWdvdG8gZXJyOwoJfQoKCS8qIFF1ZXVlIGZyYW1lLCBvciBxdWV1ZSBmcmFtZSBzZWdtZW50cyAqLwoJaWYgKChzZWxmLT50eF9tYXhfc2R1X3NpemUgPT0gMCkgfHwgKHNrYi0+bGVuIDwgc2VsZi0+bWF4X3NlZ19zaXplKSkgewoJCS8qIFF1ZXVlIGZyYW1lICovCgkJSVJEQV9BU1NFUlQoc2tiX2hlYWRyb29tKHNrYikgPj0gVFRQX0hFQURFUiwgcmV0dXJuIC0xOyk7CgkJZnJhbWUgPSBza2JfcHVzaChza2IsIFRUUF9IRUFERVIpOwoJCWZyYW1lWzBdID0gMHgwMDsgLyogQ2xlYXIgbW9yZSBiaXQgKi8KCgkJc2tiX3F1ZXVlX3RhaWwoJnNlbGYtPnR4X3F1ZXVlLCBza2IpOwoJfSBlbHNlIHsKCQkvKgoJCSAqICBGcmFnbWVudCB0aGUgZnJhbWUsIHRoaXMgZnVuY3Rpb24gd2lsbCBhbHNvIHF1ZXVlIHRoZQoJCSAqICBmcmFnbWVudHMsIHdlIGRvbid0IGNhcmUgYWJvdXQgdGhlIGZhY3QgdGhlIHRyYW5zbWl0CgkJICogIHF1ZXVlIG1heSBiZSBvdmVyZmlsbGVkIGJ5IGFsbCB0aGUgc2VnbWVudHMgZm9yIGEgbGl0dGxlCgkJICogIHdoaWxlCgkJICovCgkJaXJ0dHBfZnJhZ21lbnRfc2tiKHNlbGYsIHNrYik7Cgl9CgoJLyogQ2hlY2sgaWYgd2UgY2FuIGFjY2VwdCBtb3JlIGRhdGEgZnJvbSBjbGllbnQgKi8KCWlmICgoIXNlbGYtPnR4X3NkdV9idXN5KSAmJgoJICAgIChza2JfcXVldWVfbGVuKCZzZWxmLT50eF9xdWV1ZSkgPiBUVFBfVFhfSElHSF9USFJFU0hPTEQpKSB7CgkJLyogVHggcXVldWUgZmlsbGluZyB1cCwgc28gc3RvcCBjbGllbnQuICovCgkJaWYgKHNlbGYtPm5vdGlmeS5mbG93X2luZGljYXRpb24pIHsKCQkJc2VsZi0+bm90aWZ5LmZsb3dfaW5kaWNhdGlvbihzZWxmLT5ub3RpZnkuaW5zdGFuY2UsCgkJCQkJCSAgICAgc2VsZiwgRkxPV19TVE9QKTsKCQl9CgkJLyogc2VsZi0+dHhfc2R1X2J1c3kgaXMgdGhlIHN0YXRlIG9mIHRoZSBjbGllbnQuCgkJICogVXBkYXRlIHN0YXRlIGFmdGVyIG5vdGlmeWluZyBjbGllbnQgdG8gYXZvaWQKCQkgKiByYWNlIGNvbmRpdGlvbiB3aXRoIGlydHRwX2Zsb3dfaW5kaWNhdGlvbigpLgoJCSAqIElmIHRoZSBxdWV1ZSBlbXB0eSBpdHNlbGYgYWZ0ZXIgb3VyIHRlc3QgYnV0IGJlZm9yZQoJCSAqIHdlIHNldCB0aGUgZmxhZywgd2Ugd2lsbCBmaXggb3Vyc2VsdmVzIGJlbG93IGluCgkJICogaXJ0dHBfcnVuX3R4X3F1ZXVlKCkuCgkJICogSmVhbiBJSSAqLwoJCXNlbGYtPnR4X3NkdV9idXN5ID0gVFJVRTsKCX0KCgkvKiBUcnkgdG8gbWFrZSBzb21lIHByb2dyZXNzICovCglpcnR0cF9ydW5fdHhfcXVldWUoc2VsZik7CgoJcmV0dXJuIDA7CgplcnI6CglkZXZfa2ZyZWVfc2tiKHNrYik7CglyZXR1cm4gcmV0Owp9CkVYUE9SVF9TWU1CT0woaXJ0dHBfZGF0YV9yZXF1ZXN0KTsKCi8qCiAqIEZ1bmN0aW9uIGlydHRwX3J1bl90eF9xdWV1ZSAoc2VsZikKICoKICogICAgVHJhbnNtaXQgcGFja2V0cyBxdWV1ZWQgZm9yIHRyYW5zbWlzc2lvbiAoaWYgcG9zc2libGUpCiAqCiAqLwpzdGF0aWMgdm9pZCBpcnR0cF9ydW5fdHhfcXVldWUoc3RydWN0IHRzYXBfY2IgKnNlbGYpCnsKCXN0cnVjdCBza19idWZmICpza2I7Cgl1bnNpZ25lZCBsb25nIGZsYWdzOwoJaW50IG47CgoJSVJEQV9ERUJVRygyLCAiJXMoKSA6IHNlbmRfY3JlZGl0ID0gJWQsIHF1ZXVlX2xlbiA9ICVkXG4iLAoJCSAgIF9fRlVOQ1RJT05fXywKCQkgICBzZWxmLT5zZW5kX2NyZWRpdCwgc2tiX3F1ZXVlX2xlbigmc2VsZi0+dHhfcXVldWUpKTsKCgkvKiBHZXQgZXhjbHVzaXZlIGFjY2VzcyB0byB0aGUgdHggcXVldWUsIG90aGVyd2lzZSBkb24ndCB0b3VjaCBpdCAqLwoJaWYgKGlyZGFfbG9jaygmc2VsZi0+dHhfcXVldWVfbG9jaykgPT0gRkFMU0UpCgkJcmV0dXJuOwoKCS8qIFRyeSB0byBzZW5kIG91dCBmcmFtZXMgYXMgbG9uZyBhcyB3ZSBoYXZlIGNyZWRpdHMKCSAqIGFuZCBhcyBsb25nIGFzIExBUCBpcyBub3QgZnVsbC4gSWYgTEFQIGlzIGZ1bGwsIGl0IHdpbGwKCSAqIHBvbGwgdXMgdGhyb3VnaCBpcnR0cF9mbG93X2luZGljYXRpb24oKSAtIEplYW4gSUkgKi8KCXdoaWxlICgoc2VsZi0+c2VuZF9jcmVkaXQgPiAwKSAmJgoJICAgICAgICghaXJsbXBfbGFwX3R4X3F1ZXVlX2Z1bGwoc2VsZi0+bHNhcCkpICYmCgkgICAgICAgKHNrYiA9IHNrYl9kZXF1ZXVlKCZzZWxmLT50eF9xdWV1ZSkpKQoJewoJCS8qCgkJICogIFNpbmNlIHdlIGNhbiB0cmFuc21pdCBhbmQgcmVjZWl2ZSBmcmFtZXMgY29uY3VycmVudGx5LAoJCSAqICB0aGUgY29kZSBiZWxvdyBpcyBhIGNyaXRpY2FsIHJlZ2lvbiBhbmQgd2UgbXVzdCBhc3N1cmUgdGhhdAoJCSAqICBub2JvZHkgbWVzc2VzIHdpdGggdGhlIGNyZWRpdHMgd2hpbGUgd2UgdXBkYXRlIHRoZW0uCgkJICovCgkJc3Bpbl9sb2NrX2lycXNhdmUoJnNlbGYtPmxvY2ssIGZsYWdzKTsKCgkJbiA9IHNlbGYtPmF2YWlsX2NyZWRpdDsKCQlzZWxmLT5hdmFpbF9jcmVkaXQgPSAwOwoKCQkvKiBPbmx5IHJvb20gZm9yIDEyNyBjcmVkaXRzIGluIGZyYW1lICovCgkJaWYgKG4gPiAxMjcpIHsKCQkJc2VsZi0+YXZhaWxfY3JlZGl0ID0gbi0xMjc7CgkJCW4gPSAxMjc7CgkJfQoJCXNlbGYtPnJlbW90ZV9jcmVkaXQgKz0gbjsKCQlzZWxmLT5zZW5kX2NyZWRpdC0tOwoKCQlzcGluX3VubG9ja19pcnFyZXN0b3JlKCZzZWxmLT5sb2NrLCBmbGFncyk7CgoJCS8qCgkJICogIE1vcmUgYml0IG11c3QgYmUgc2V0IGJ5IHRoZSBkYXRhX3JlcXVlc3QoKSBvciBmcmFnbWVudCgpCgkJICogIGZ1bmN0aW9ucwoJCSAqLwoJCXNrYi0+ZGF0YVswXSB8PSAobiAmIDB4N2YpOwoKCQkvKiBEZXRhY2ggZnJvbSBzb2NrZXQuCgkJICogVGhlIGN1cnJlbnQgc2tiIGhhcyBhIHJlZmVyZW5jZSB0byB0aGUgc29ja2V0IHRoYXQgc2VudAoJCSAqIGl0IChza2ItPnNrKS4gV2hlbiB3ZSBwYXNzIGl0IHRvIElyTE1QLCB0aGUgc2tiIHdpbGwgYmUKCQkgKiBzdG9yZWQgaW4gaW4gSXJMQVAgKHNlbGYtPnd4X2xpc3QpLiBXaGVuIHdlIGFyZSB3aXRoaW4KCQkgKiBJckxBUCwgd2UgbG9zZSB0aGUgbm90aW9uIG9mIHNvY2tldCwgc28gd2Ugc2hvdWxkIG5vdAoJCSAqIGhhdmUgYSByZWZlcmVuY2UgdG8gYSBzb2NrZXQuIFNvLCB3ZSBkcm9wIGl0IGhlcmUuCgkJICoKCQkgKiBXaHkgZG9lcyBpdCBtYXR0ZXIgPwoJCSAqIFdoZW4gdGhlIHNrYiBpcyBmcmVlZCAoa2ZyZWVfc2tiKSwgaWYgaXQgaXMgYXNzb2NpYXRlZAoJCSAqIHdpdGggYSBzb2NrZXQsIGl0IHJlbGVhc2UgYnVmZmVyIHNwYWNlIG9uIHRoZSBzb2NrZXQKCQkgKiAodGhyb3VnaCBzb2NrX3dmcmVlKCkgYW5kIHNvY2tfZGVmX3dyaXRlX3NwYWNlKCkpLgoJCSAqIElmIHRoZSBzb2NrZXQgbm8gbG9uZ2VyIGV4aXN0LCB3ZSBtYXkgY3Jhc2guIEhhcmQuCgkJICogV2hlbiB3ZSBjbG9zZSBhIHNvY2tldCwgd2UgbWFrZSBzdXJlIHRoYXQgYXNzb2NpYXRlZCBwYWNrZXRzCgkJICogaW4gSXJUVFAgYXJlIGZyZWVkLiBIb3dldmVyLCB3ZSBoYXZlIG5vIHdheSB0byBjYW5jZWwKCQkgKiB0aGUgcGFja2V0IHRoYXQgd2UgaGF2ZSBwYXNzZWQgdG8gSXJMQVAuIFNvLCBpZiBhIHBhY2tldAoJCSAqIHJlbWFpbnMgaW4gSXJMQVAgKHJldHJ5IG9uIHRoZSBsaW5rIG9yIGVsc2UpIGFmdGVyIHdlCgkJICogY2xvc2UgdGhlIHNvY2tldCwgd2UgYXJlIGRlYWQgIQoJCSAqIEplYW4gSUkgKi8KCQlpZiAoc2tiLT5zayAhPSBOVUxMKSB7CgkJCS8qIElyU09DSyBhcHBsaWNhdGlvbiwgSXJPQkVYLCAuLi4gKi8KCQkJc2tiX29ycGhhbihza2IpOwoJCX0KCQkJLyogSXJDT01NIG92ZXIgSXJUVFAsIElyTEFOLCAuLi4gKi8KCgkJLyogUGFzcyB0aGUgc2tiIHRvIElyTE1QIC0gZG9uZSAqLwoJCWlybG1wX2RhdGFfcmVxdWVzdChzZWxmLT5sc2FwLCBza2IpOwoJCXNlbGYtPnN0YXRzLnR4X3BhY2tldHMrKzsKCX0KCgkvKiBDaGVjayBpZiB3ZSBjYW4gYWNjZXB0IG1vcmUgZnJhbWVzIGZyb20gY2xpZW50LgoJICogV2UgZG9uJ3Qgd2FudCB0byB3YWl0IHVudGlsIHRoZSB0b2RvIHRpbWVyIHRvIGRvIHRoYXQsIGFuZCB3ZQoJICogY2FuJ3QgdXNlIHRhc2tsZXRzIChncnIuLi4pLCBzbyB3ZSBhcmUgb2JsaWdlZCB0byBnaXZlIGNvbnRyb2wKCSAqIHRvIGNsaWVudC4gVGhhdCdzIG9rLCB0aGlzIHRlc3Qgd2lsbCBiZSB0cnVlIG5vdCB0b28gb2Z0ZW4KCSAqIChtYXggb25jZSBwZXIgTEFQIHdpbmRvdykgYW5kIHdlIGFyZSBjYWxsZWQgZnJvbSBwbGFjZXMKCSAqIHdoZXJlIHdlIGNhbiBzcGVuZCBhIGJpdCBvZiB0aW1lIGRvaW5nIHN0dWZmLiAtIEplYW4gSUkgKi8KCWlmICgoc2VsZi0+dHhfc2R1X2J1c3kpICYmCgkgICAgKHNrYl9xdWV1ZV9sZW4oJnNlbGYtPnR4X3F1ZXVlKSA8IFRUUF9UWF9MT1dfVEhSRVNIT0xEKSAmJgoJICAgICghc2VsZi0+Y2xvc2VfcGVuZCkpCgl7CgkJaWYgKHNlbGYtPm5vdGlmeS5mbG93X2luZGljYXRpb24pCgkJCXNlbGYtPm5vdGlmeS5mbG93X2luZGljYXRpb24oc2VsZi0+bm90aWZ5Lmluc3RhbmNlLAoJCQkJCQkgICAgIHNlbGYsIEZMT1dfU1RBUlQpOwoKCQkvKiBzZWxmLT50eF9zZHVfYnVzeSBpcyB0aGUgc3RhdGUgb2YgdGhlIGNsaWVudC4KCQkgKiBXZSBkb24ndCByZWFsbHkgaGF2ZSBhIHJhY2UgaGVyZSwgYnV0IGl0J3MgYWx3YXlzIHNhZmVyCgkJICogdG8gdXBkYXRlIG91ciBzdGF0ZSBhZnRlciB0aGUgY2xpZW50IC0gSmVhbiBJSSAqLwoJCXNlbGYtPnR4X3NkdV9idXN5ID0gRkFMU0U7Cgl9CgoJLyogUmVzZXQgbG9jayAqLwoJc2VsZi0+dHhfcXVldWVfbG9jayA9IDA7Cn0KCi8qCiAqIEZ1bmN0aW9uIGlydHRwX2dpdmVfY3JlZGl0IChzZWxmKQogKgogKiAgICBTZW5kIGEgZGF0YWxlc3MgZmxvd2RhdGEgVFRQLVBEVSBhbmQgZ2l2ZSBhdmFpbGFibGUgY3JlZGl0IHRvIHBlZXIKICogICAgVFNBUAogKi8Kc3RhdGljIGlubGluZSB2b2lkIGlydHRwX2dpdmVfY3JlZGl0KHN0cnVjdCB0c2FwX2NiICpzZWxmKQp7CglzdHJ1Y3Qgc2tfYnVmZiAqdHhfc2tiID0gTlVMTDsKCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CglpbnQgbjsKCglJUkRBX0FTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybjspOwoJSVJEQV9BU1NFUlQoc2VsZi0+bWFnaWMgPT0gVFRQX1RTQVBfTUFHSUMsIHJldHVybjspOwoKCUlSREFfREVCVUcoNCwgIiVzKCkgc2VuZD0lZCxhdmFpbD0lZCxyZW1vdGU9JWRcbiIsCgkJICAgX19GVU5DVElPTl9fLAoJCSAgIHNlbGYtPnNlbmRfY3JlZGl0LCBzZWxmLT5hdmFpbF9jcmVkaXQsIHNlbGYtPnJlbW90ZV9jcmVkaXQpOwoKCS8qIEdpdmUgY3JlZGl0IHRvIHBlZXIgKi8KCXR4X3NrYiA9IGFsbG9jX3NrYihUVFBfTUFYX0hFQURFUiwgR0ZQX0FUT01JQyk7CglpZiAoIXR4X3NrYikKCQlyZXR1cm47CgoJLyogUmVzZXJ2ZSBzcGFjZSBmb3IgTE1QLCBhbmQgTEFQIGhlYWRlciAqLwoJc2tiX3Jlc2VydmUodHhfc2tiLCBMTVBfTUFYX0hFQURFUik7CgoJLyoKCSAqICBTaW5jZSB3ZSBjYW4gdHJhbnNtaXQgYW5kIHJlY2VpdmUgZnJhbWVzIGNvbmN1cnJlbnRseSwKCSAqICB0aGUgY29kZSBiZWxvdyBpcyBhIGNyaXRpY2FsIHJlZ2lvbiBhbmQgd2UgbXVzdCBhc3N1cmUgdGhhdAoJICogIG5vYm9keSBtZXNzZXMgd2l0aCB0aGUgY3JlZGl0cyB3aGlsZSB3ZSB1cGRhdGUgdGhlbS4KCSAqLwoJc3Bpbl9sb2NrX2lycXNhdmUoJnNlbGYtPmxvY2ssIGZsYWdzKTsKCgluID0gc2VsZi0+YXZhaWxfY3JlZGl0OwoJc2VsZi0+YXZhaWxfY3JlZGl0ID0gMDsKCgkvKiBPbmx5IHNwYWNlIGZvciAxMjcgY3JlZGl0cyBpbiBmcmFtZSAqLwoJaWYgKG4gPiAxMjcpIHsKCQlzZWxmLT5hdmFpbF9jcmVkaXQgPSBuIC0gMTI3OwoJCW4gPSAxMjc7Cgl9CglzZWxmLT5yZW1vdGVfY3JlZGl0ICs9IG47CgoJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmc2VsZi0+bG9jaywgZmxhZ3MpOwoKCXNrYl9wdXQodHhfc2tiLCAxKTsKCXR4X3NrYi0+ZGF0YVswXSA9IChfX3U4KSAobiAmIDB4N2YpOwoKCWlybG1wX2RhdGFfcmVxdWVzdChzZWxmLT5sc2FwLCB0eF9za2IpOwoJc2VsZi0+c3RhdHMudHhfcGFja2V0cysrOwp9CgovKgogKiBGdW5jdGlvbiBpcnR0cF91ZGF0YV9pbmRpY2F0aW9uIChpbnN0YW5jZSwgc2FwLCBza2IpCiAqCiAqICAgIFJlY2VpdmVkIHNvbWUgdW5pdC1kYXRhICh1bnJlbGlhYmxlKQogKgogKi8Kc3RhdGljIGludCBpcnR0cF91ZGF0YV9pbmRpY2F0aW9uKHZvaWQgKmluc3RhbmNlLCB2b2lkICpzYXAsCgkJCQkgIHN0cnVjdCBza19idWZmICpza2IpCnsKCXN0cnVjdCB0c2FwX2NiICpzZWxmOwoJaW50IGVycjsKCglJUkRBX0RFQlVHKDQsICIlcygpXG4iLCBfX0ZVTkNUSU9OX18pOwoKCXNlbGYgPSAoc3RydWN0IHRzYXBfY2IgKikgaW5zdGFuY2U7CgoJSVJEQV9BU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm4gLTE7KTsKCUlSREFfQVNTRVJUKHNlbGYtPm1hZ2ljID09IFRUUF9UU0FQX01BR0lDLCByZXR1cm4gLTE7KTsKCUlSREFfQVNTRVJUKHNrYiAhPSBOVUxMLCByZXR1cm4gLTE7KTsKCglzZWxmLT5zdGF0cy5yeF9wYWNrZXRzKys7CgoJLyogSnVzdCBwYXNzIGRhdGEgdG8gbGF5ZXIgYWJvdmUgKi8KCWlmIChzZWxmLT5ub3RpZnkudWRhdGFfaW5kaWNhdGlvbikgewoJCWVyciA9IHNlbGYtPm5vdGlmeS51ZGF0YV9pbmRpY2F0aW9uKHNlbGYtPm5vdGlmeS5pbnN0YW5jZSwKCQkJCQkJICAgIHNlbGYsc2tiKTsKCQkvKiBTYW1lIGNvbW1lbnQgYXMgaW4gaXJ0dHBfZG9fZGF0YV9pbmRpY2F0aW9uKCkgKi8KCQlpZiAoIWVycikgCgkJCXJldHVybiAwOwoJfQoJLyogRWl0aGVyIG5vIGhhbmRsZXIsIG9yIGhhbmRsZXIgcmV0dXJucyBhbiBlcnJvciAqLwoJZGV2X2tmcmVlX3NrYihza2IpOwoKCXJldHVybiAwOwp9CgovKgogKiBGdW5jdGlvbiBpcnR0cF9kYXRhX2luZGljYXRpb24gKGluc3RhbmNlLCBzYXAsIHNrYikKICoKICogICAgUmVjZWl2ZSBzZWdtZW50IGZyb20gSXJMTVAuCiAqCiAqLwpzdGF0aWMgaW50IGlydHRwX2RhdGFfaW5kaWNhdGlvbih2b2lkICppbnN0YW5jZSwgdm9pZCAqc2FwLAoJCQkJIHN0cnVjdCBza19idWZmICpza2IpCnsKCXN0cnVjdCB0c2FwX2NiICpzZWxmOwoJdW5zaWduZWQgbG9uZyBmbGFnczsKCWludCBuOwoKCXNlbGYgPSAoc3RydWN0IHRzYXBfY2IgKikgaW5zdGFuY2U7CgoJbiA9IHNrYi0+ZGF0YVswXSAmIDB4N2Y7ICAgICAvKiBFeHRyYWN0IHRoZSBjcmVkaXRzICovCgoJc2VsZi0+c3RhdHMucnhfcGFja2V0cysrOwoKCS8qICBEZWFsIHdpdGggaW5ib3VuZCBjcmVkaXQKCSAqICBTaW5jZSB3ZSBjYW4gdHJhbnNtaXQgYW5kIHJlY2VpdmUgZnJhbWVzIGNvbmN1cnJlbnRseSwKCSAqICB0aGUgY29kZSBiZWxvdyBpcyBhIGNyaXRpY2FsIHJlZ2lvbiBhbmQgd2UgbXVzdCBhc3N1cmUgdGhhdAoJICogIG5vYm9keSBtZXNzZXMgd2l0aCB0aGUgY3JlZGl0cyB3aGlsZSB3ZSB1cGRhdGUgdGhlbS4KCSAqLwoJc3Bpbl9sb2NrX2lycXNhdmUoJnNlbGYtPmxvY2ssIGZsYWdzKTsKCXNlbGYtPnNlbmRfY3JlZGl0ICs9IG47CglpZiAoc2tiLT5sZW4gPiAxKQoJCXNlbGYtPnJlbW90ZV9jcmVkaXQtLTsKCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJnNlbGYtPmxvY2ssIGZsYWdzKTsKCgkvKgoJICogIERhdGEgb3IgZGF0YWxlc3MgcGFja2V0PyBEYXRhbGVzcyBmcmFtZXMgY29udGFpbnMgb25seSB0aGUKCSAqICBUVFBfSEVBREVSLgoJICovCglpZiAoc2tiLT5sZW4gPiAxKSB7CgkJLyoKCQkgKiAgV2UgZG9uJ3QgcmVtb3ZlIHRoZSBUVFAgaGVhZGVyLCBzaW5jZSB3ZSBtdXN0IHByZXNlcnZlIHRoZQoJCSAqICBtb3JlIGJpdCwgc28gdGhlIGRlZnJhZ21lbnQgcm91dGluZyBrbm93cyB3aGF0IHRvIGRvCgkJICovCgkJc2tiX3F1ZXVlX3RhaWwoJnNlbGYtPnJ4X3F1ZXVlLCBza2IpOwoJfSBlbHNlIHsKCQkvKiBEYXRhbGVzcyBmbG93ZGF0YSBUVFAtUERVICovCgkJZGV2X2tmcmVlX3NrYihza2IpOwoJfQoKCgkvKiBQdXNoIGRhdGEgdG8gdGhlIGhpZ2hlciBsYXllci4KCSAqIFdlIGRvIGl0IHN5bmNocm9ub3VzbHkgYmVjYXVzZSBydW5uaW5nIHRoZSB0b2RvIHRpbWVyIGZvciBlYWNoCgkgKiByZWNlaXZlIHBhY2tldCB3b3VsZCBiZSB0b28gbXVjaCBvdmVyaGVhZCBhbmQgbGF0ZW5jeS4KCSAqIEJ5IHBhc3NpbmcgY29udHJvbCB0byB0aGUgaGlnaGVyIGxheWVyLCB3ZSBydW4gdGhlIHJpc2sgdGhhdAoJICogaXQgbWF5IHRha2UgdGltZSBvciBncmFiIGEgbG9jay4gTW9zdCBvZnRlbiwgdGhlIGhpZ2hlciBsYXllcgoJICogd2lsbCBvbmx5IHB1dCBwYWNrZXQgaW4gYSBxdWV1ZS4KCSAqIEFueXdheSwgcGFja2V0cyBhcmUgb25seSBkcmlwcGluZyB0aHJvdWdoIHRoZSBJckRBLCBzbyB3ZSBjYW4KCSAqIGhhdmUgdGltZSBiZWZvcmUgdGhlIG5leHQgcGFja2V0LgoJICogRnVydGhlciwgd2UgYXJlIHJ1biBmcm9tIE5FVF9CSCwgc28gdGhlIHdvcnNlIHRoYXQgY2FuIGhhcHBlbiBpcwoJICogdXMgbWlzc2luZyB0aGUgb3B0aW1hbCB0aW1lIHRvIHNlbmQgYmFjayB0aGUgUEYgYml0IGluIExBUC4KCSAqIEplYW4gSUkgKi8KCWlydHRwX3J1bl9yeF9xdWV1ZShzZWxmKTsKCgkvKiBXZSBub3cgZ2l2ZSBjcmVkaXRzIHRvIHBlZXIgaW4gaXJ0dHBfcnVuX3J4X3F1ZXVlKCkuCgkgKiBXZSBuZWVkIHRvIHNlbmQgY3JlZGl0ICpOT1cqLCBvdGhlcndpc2Ugd2UgYXJlIGdvaW5nCgkgKiB0byBtaXNzIHRoZSBuZXh0IFR4IHdpbmRvdy4gVGhlIHRvZG8gdGltZXIgbWF5IHRha2UKCSAqIGEgd2hpbGUgYmVmb3JlIGl0J3MgcnVuLi4uIC0gSmVhbiBJSSAqLwoKCS8qCgkgKiBJZiB0aGUgcGVlciBkZXZpY2UgaGFzIGdpdmVuIHVzIHNvbWUgY3JlZGl0cyBhbmQgd2UgZGlkbid0IGhhdmUKICAgICAgICAgKiBhbnlvbmUgZnJvbSBiZWZvcmUsIHRoZW4gd2UgbmVlZCB0byBzaGVkdWxlIHRoZSB0eCBxdWV1ZS4KCSAqIFdlIG5lZWQgdG8gZG8gdGhhdCBiZWNhdXNlIG91ciBUeCBoYXZlIHN0b3BwZWQgKHNvIHdlIG1heSBub3QKCSAqIGdldCBhbnkgTEFQIGZsb3cgaW5kaWNhdGlvbikgYW5kIHRoZSB1c2VyIG1heSBiZSBzdG9wcGVkIGFzCgkgKiB3ZWxsLiAtIEplYW4gSUkKCSAqLwoJaWYgKHNlbGYtPnNlbmRfY3JlZGl0ID09IG4pIHsKCQkvKiBSZXN0YXJ0IHB1c2hpbmcgc3R1ZmYgdG8gTEFQICovCgkJaXJ0dHBfcnVuX3R4X3F1ZXVlKHNlbGYpOwoJCS8qIE5vdGUgOiB3ZSBkb24ndCB3YW50IHRvIHNjaGVkdWxlIHRoZSB0b2RvIHRpbWVyCgkJICogYmVjYXVzZSBpdCBoYXMgaG9ycmlibGUgbGF0ZW5jeS4gTm8gdGFza2xldHMKCQkgKiBiZWNhdXNlIHRoZSB0YXNrbGV0IEFQSSBpcyBicm9rZW4uIC0gSmVhbiBJSSAqLwoJfQoKCXJldHVybiAwOwp9CgovKgogKiBGdW5jdGlvbiBpcnR0cF9zdGF0dXNfaW5kaWNhdGlvbiAoc2VsZiwgcmVhc29uKQogKgogKiAgICBTdGF0dXNfaW5kaWNhdGlvbiwganVzdCBwYXNzIHRvIHRoZSBoaWdoZXIgbGF5ZXIuLi4KICoKICovCnN0YXRpYyB2b2lkIGlydHRwX3N0YXR1c19pbmRpY2F0aW9uKHZvaWQgKmluc3RhbmNlLAoJCQkJICAgIExJTktfU1RBVFVTIGxpbmssIExPQ0tfU1RBVFVTIGxvY2spCnsKCXN0cnVjdCB0c2FwX2NiICpzZWxmOwoKCUlSREFfREVCVUcoNCwgIiVzKClcbiIsIF9fRlVOQ1RJT05fXyk7CgoJc2VsZiA9IChzdHJ1Y3QgdHNhcF9jYiAqKSBpbnN0YW5jZTsKCglJUkRBX0FTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybjspOwoJSVJEQV9BU1NFUlQoc2VsZi0+bWFnaWMgPT0gVFRQX1RTQVBfTUFHSUMsIHJldHVybjspOwoKCS8qIENoZWNrIGlmIGNsaWVudCBoYXMgYWxyZWFkeSBjbG9zZWQgdGhlIFRTQVAgYW5kIGdvbmUgYXdheSAqLwoJaWYgKHNlbGYtPmNsb3NlX3BlbmQpCgkJcmV0dXJuOwoKCS8qCgkgKiAgSW5mb3JtIHNlcnZpY2UgdXNlciBpZiBoZSBoYXMgcmVxdWVzdGVkIGl0CgkgKi8KCWlmIChzZWxmLT5ub3RpZnkuc3RhdHVzX2luZGljYXRpb24gIT0gTlVMTCkKCQlzZWxmLT5ub3RpZnkuc3RhdHVzX2luZGljYXRpb24oc2VsZi0+bm90aWZ5Lmluc3RhbmNlLAoJCQkJCSAgICAgICBsaW5rLCBsb2NrKTsKCWVsc2UKCQlJUkRBX0RFQlVHKDIsICIlcygpLCBubyBoYW5kbGVyXG4iLCBfX0ZVTkNUSU9OX18pOwp9CgovKgogKiBGdW5jdGlvbiBpcnR0cF9mbG93X2luZGljYXRpb24gKHNlbGYsIHJlYXNvbikKICoKICogICAgRmxvd19pbmRpY2F0aW9uIDogSXJMQVAgdGVsbHMgdXMgdG8gc2VuZCBtb3JlIGRhdGEuCiAqCiAqLwpzdGF0aWMgdm9pZCBpcnR0cF9mbG93X2luZGljYXRpb24odm9pZCAqaW5zdGFuY2UsIHZvaWQgKnNhcCwgTE9DQUxfRkxPVyBmbG93KQp7CglzdHJ1Y3QgdHNhcF9jYiAqc2VsZjsKCglzZWxmID0gKHN0cnVjdCB0c2FwX2NiICopIGluc3RhbmNlOwoKCUlSREFfQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuOyk7CgoJSVJEQV9ERUJVRyg0LCAiJXMoaW5zdGFuY2U9JXApXG4iLCBfX0ZVTkNUSU9OX18sIHNlbGYpOwoKCS8qIFdlIGFyZSAicG9sbGVkIiBkaXJlY3RseSBmcm9tIExBUCwgYW5kIHRoZSBMQVAgd2FudCB0byBmaWxsCgkgKiBpdHMgVHggd2luZG93LiBXZSB3YW50IHRvIGRvIG91ciBiZXN0IHRvIHNlbmQgaXQgZGF0YSwgc28gdGhhdAoJICogd2UgbWF4aW1pc2UgdGhlIHdpbmRvdy4gT24gdGhlIG90aGVyIGhhbmQsIHdlIHdhbnQgdG8gbGltaXQgdGhlCgkgKiBhbW91bnQgb2Ygd29yayBoZXJlIHNvIHRoYXQgTEFQIGRvZXNuJ3QgaGFuZyBmb3JldmVyIHdhaXRpbmcKCSAqIGZvciBwYWNrZXRzLiAtIEplYW4gSUkgKi8KCgkvKiBUcnkgdG8gc2VuZCBzb21lIHBhY2tldHMuIEN1cnJlbnRseSwgTEFQIGNhbGxzIHVzIGV2ZXJ5IHRpbWUKCSAqIHRoZXJlIGlzIG9uZSBmcmVlIHNsb3QsIHNvIHdlIHdpbGwgc2VuZCBvbmx5IG9uZSBwYWNrZXQuCgkgKiBUaGlzIGFsbG93IHRoZSBzY2hlZHVsZXIgdG8gZG8gaXRzIHJvdW5kIHJvYmluIC0gSmVhbiBJSSAqLwoJaXJ0dHBfcnVuX3R4X3F1ZXVlKHNlbGYpOwoKCS8qIE5vdGUgcmVnYXJkaW5nIHRoZSBpbnRlcnJhY3Rpb24gd2l0aCBoaWdoZXIgbGF5ZXIuCgkgKiBpcnR0cF9ydW5fdHhfcXVldWUoKSBtYXkgY2FsbCB0aGUgY2xpZW50IHdoZW4gaXRzIHF1ZXVlCgkgKiBzdGFydCB0byBlbXB0eSwgdmlhIG5vdGlmeS5mbG93X2luZGljYXRpb24oKS4gSW5pdGlhbGx5LgoJICogSSB3YW50ZWQgdGhpcyB0byBoYXBwZW4gaW4gYSB0YXNrbGV0LCB0byBhdm9pZCBjbGllbnQKCSAqIGdyYWJiaW5nIHRoZSBDUFUsIGJ1dCB3ZSBjYW4ndCB1c2UgdGFza2xldHMgc2FmZWx5LiBBbmQgdGltZXIKCSAqIGlzIGRlZmluaXRlbHkgdG9vIHNsb3cuCgkgKiBUaGlzIHdpbGwgaGFwcGVuIG9ubHkgb25jZSBwZXIgTEFQIHdpbmRvdywgYW5kIHVzdWFsbHkgYXQKCSAqIHRoZSB0aGlyZCBwYWNrZXQgKHVubGVzcyB3aW5kb3cgaXMgc21hbGxlcikuIExBUCBpcyBzdGlsbAoJICogZG9pbmcgbXR0IGFuZCBzZW5kaW5nIGZpcnN0IHBhY2tldCBzbyBpdCdzIHNvcnQgb2YgT0sKCSAqIHRvIGRvIHRoYXQuIEplYW4gSUkgKi8KCgkvKiBJZiB3ZSBuZWVkIHRvIHNlbmQgZGlzY29ubmVjdC4gdHJ5IHRvIGRvIGl0IG5vdyAqLwoJaWYoc2VsZi0+ZGlzY29ubmVjdF9wZW5kKQoJCWlydHRwX3N0YXJ0X3RvZG9fdGltZXIoc2VsZiwgMCk7Cn0KCi8qCiAqIEZ1bmN0aW9uIGlydHRwX2Zsb3dfcmVxdWVzdCAoc2VsZiwgY29tbWFuZCkKICoKICogICAgVGhpcyBmdW5jdGlvbiBjb3VsZCBiZSB1c2VkIGJ5IHRoZSB1cHBlciBsYXllcnMgdG8gdGVsbCBJclRUUCB0byBzdG9wCiAqICAgIGRlbGl2ZXJpbmcgZnJhbWVzIGlmIHRoZSByZWNlaXZlIHF1ZXVlcyBhcmUgc3RhcnRpbmcgdG8gZ2V0IGZ1bGwsIG9yCiAqICAgIHRvIHRlbGwgSXJUVFAgdG8gc3RhcnQgZGVsaXZlcmluZyBmcmFtZXMgYWdhaW4uCiAqLwp2b2lkIGlydHRwX2Zsb3dfcmVxdWVzdChzdHJ1Y3QgdHNhcF9jYiAqc2VsZiwgTE9DQUxfRkxPVyBmbG93KQp7CglJUkRBX0RFQlVHKDEsICIlcygpXG4iLCBfX0ZVTkNUSU9OX18pOwoKCUlSREFfQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuOyk7CgoJc3dpdGNoIChmbG93KSB7CgljYXNlIEZMT1dfU1RPUDoKCQlJUkRBX0RFQlVHKDEsICIlcygpLCBmbG93IHN0b3BcbiIsIF9fRlVOQ1RJT05fXyk7CgkJc2VsZi0+cnhfc2R1X2J1c3kgPSBUUlVFOwoJCWJyZWFrOwoJY2FzZSBGTE9XX1NUQVJUOgoJCUlSREFfREVCVUcoMSwgIiVzKCksIGZsb3cgc3RhcnRcbiIsIF9fRlVOQ1RJT05fXyk7CgkJc2VsZi0+cnhfc2R1X2J1c3kgPSBGQUxTRTsKCgkJLyogQ2xpZW50IHNheSBoZSBjYW4gYWNjZXB0IG1vcmUgZGF0YSwgdHJ5IHRvIGZyZWUgb3VyCgkJICogcXVldWVzIEFTQVAgLSBKZWFuIElJICovCgkJaXJ0dHBfcnVuX3J4X3F1ZXVlKHNlbGYpOwoKCQlicmVhazsKCWRlZmF1bHQ6CgkJSVJEQV9ERUJVRygxLCAiJXMoKSwgVW5rbm93biBmbG93IGNvbW1hbmQhXG4iLCBfX0ZVTkNUSU9OX18pOwoJfQp9CkVYUE9SVF9TWU1CT0woaXJ0dHBfZmxvd19yZXF1ZXN0KTsKCi8qCiAqIEZ1bmN0aW9uIGlydHRwX2Nvbm5lY3RfcmVxdWVzdCAoc2VsZiwgZHRzYXBfc2VsLCBkYWRkciwgcW9zKQogKgogKiAgICBUcnkgdG8gY29ubmVjdCB0byByZW1vdGUgZGVzdGluYXRpb24gVFNBUCBzZWxlY3RvcgogKgogKi8KaW50IGlydHRwX2Nvbm5lY3RfcmVxdWVzdChzdHJ1Y3QgdHNhcF9jYiAqc2VsZiwgX191OCBkdHNhcF9zZWwsCgkJCSAgX191MzIgc2FkZHIsIF9fdTMyIGRhZGRyLAoJCQkgIHN0cnVjdCBxb3NfaW5mbyAqcW9zLCBfX3UzMiBtYXhfc2R1X3NpemUsCgkJCSAgc3RydWN0IHNrX2J1ZmYgKnVzZXJkYXRhKQp7CglzdHJ1Y3Qgc2tfYnVmZiAqdHhfc2tiOwoJX191OCAqZnJhbWU7CglfX3U4IG47CgoJSVJEQV9ERUJVRyg0LCAiJXMoKSwgbWF4X3NkdV9zaXplPSVkXG4iLCBfX0ZVTkNUSU9OX18sIG1heF9zZHVfc2l6ZSk7CgoJSVJEQV9BU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm4gLUVCQURSOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuIC1FQkFEUjspOwoKCWlmIChzZWxmLT5jb25uZWN0ZWQpIHsKCQlpZih1c2VyZGF0YSkKCQkJZGV2X2tmcmVlX3NrYih1c2VyZGF0YSk7CgkJcmV0dXJuIC1FSVNDT05OOwoJfQoKCS8qIEFueSB1c2VyZGF0YSBzdXBwbGllZD8gKi8KCWlmICh1c2VyZGF0YSA9PSBOVUxMKSB7CgkJdHhfc2tiID0gYWxsb2Nfc2tiKFRUUF9NQVhfSEVBREVSICsgVFRQX1NBUl9IRUFERVIsCgkJCQkgICBHRlBfQVRPTUlDKTsKCQlpZiAoIXR4X3NrYikKCQkJcmV0dXJuIC1FTk9NRU07CgoJCS8qIFJlc2VydmUgc3BhY2UgZm9yIE1VWF9DT05UUk9MIGFuZCBMQVAgaGVhZGVyICovCgkJc2tiX3Jlc2VydmUodHhfc2tiLCBUVFBfTUFYX0hFQURFUik7Cgl9IGVsc2UgewoJCXR4X3NrYiA9IHVzZXJkYXRhOwoJCS8qCgkJICogIENoZWNrIHRoYXQgdGhlIGNsaWVudCBoYXMgcmVzZXJ2ZWQgZW5vdWdoIHNwYWNlIGZvcgoJCSAqICBoZWFkZXJzCgkJICovCgkJSVJEQV9BU1NFUlQoc2tiX2hlYWRyb29tKHVzZXJkYXRhKSA+PSBUVFBfTUFYX0hFQURFUiwKCQkJeyBkZXZfa2ZyZWVfc2tiKHVzZXJkYXRhKTsgcmV0dXJuIC0xOyB9ICk7Cgl9CgoJLyogSW5pdGlhbGl6ZSBjb25uZWN0aW9uIHBhcmFtZXRlcnMgKi8KCXNlbGYtPmNvbm5lY3RlZCA9IEZBTFNFOwoJc2VsZi0+YXZhaWxfY3JlZGl0ID0gMDsKCXNlbGYtPnJ4X21heF9zZHVfc2l6ZSA9IG1heF9zZHVfc2l6ZTsKCXNlbGYtPnJ4X3NkdV9zaXplID0gMDsKCXNlbGYtPnJ4X3NkdV9idXN5ID0gRkFMU0U7CglzZWxmLT5kdHNhcF9zZWwgPSBkdHNhcF9zZWw7CgoJbiA9IHNlbGYtPmluaXRpYWxfY3JlZGl0OwoKCXNlbGYtPnJlbW90ZV9jcmVkaXQgPSAwOwoJc2VsZi0+c2VuZF9jcmVkaXQgPSAwOwoKCS8qCgkgKiAgR2l2ZSBhd2F5IG1heCAxMjcgY3JlZGl0cyBmb3Igbm93CgkgKi8KCWlmIChuID4gMTI3KSB7CgkJc2VsZi0+YXZhaWxfY3JlZGl0PW4tMTI3OwoJCW4gPSAxMjc7Cgl9CgoJc2VsZi0+cmVtb3RlX2NyZWRpdCA9IG47CgoJLyogU0FSIGVuYWJsZWQ/ICovCglpZiAobWF4X3NkdV9zaXplID4gMCkgewoJCUlSREFfQVNTRVJUKHNrYl9oZWFkcm9vbSh0eF9za2IpID49IChUVFBfTUFYX0hFQURFUiArIFRUUF9TQVJfSEVBREVSKSwKCQkJeyBkZXZfa2ZyZWVfc2tiKHR4X3NrYik7IHJldHVybiAtMTsgfSApOwoKCQkvKiBJbnNlcnQgU0FSIHBhcmFtZXRlcnMgKi8KCQlmcmFtZSA9IHNrYl9wdXNoKHR4X3NrYiwgVFRQX0hFQURFUitUVFBfU0FSX0hFQURFUik7CgoJCWZyYW1lWzBdID0gVFRQX1BBUkFNRVRFUlMgfCBuOwoJCWZyYW1lWzFdID0gMHgwNDsgLyogTGVuZ3RoICovCgkJZnJhbWVbMl0gPSAweDAxOyAvKiBNYXhTZHVTaXplICovCgkJZnJhbWVbM10gPSAweDAyOyAvKiBWYWx1ZSBsZW5ndGggKi8KCgkJcHV0X3VuYWxpZ25lZChjcHVfdG9fYmUxNigoX191MTYpIG1heF9zZHVfc2l6ZSksCgkJCSAgICAgIChfX3UxNiAqKShmcmFtZSs0KSk7Cgl9IGVsc2UgewoJCS8qIEluc2VydCBwbGFpbiBUVFAgaGVhZGVyICovCgkJZnJhbWUgPSBza2JfcHVzaCh0eF9za2IsIFRUUF9IRUFERVIpOwoKCQkvKiBJbnNlcnQgaW5pdGlhbCBjcmVkaXQgaW4gZnJhbWUgKi8KCQlmcmFtZVswXSA9IG4gJiAweDdmOwoJfQoKCS8qIENvbm5lY3Qgd2l0aCBJckxNUC4gTm8gUW9TIHBhcmFtZXRlcnMgZm9yIG5vdyAqLwoJcmV0dXJuIGlybG1wX2Nvbm5lY3RfcmVxdWVzdChzZWxmLT5sc2FwLCBkdHNhcF9zZWwsIHNhZGRyLCBkYWRkciwgcW9zLAoJCQkJICAgICB0eF9za2IpOwp9CkVYUE9SVF9TWU1CT0woaXJ0dHBfY29ubmVjdF9yZXF1ZXN0KTsKCi8qCiAqIEZ1bmN0aW9uIGlydHRwX2Nvbm5lY3RfY29uZmlybSAoaGFuZGxlLCBxb3MsIHNrYikKICoKICogICAgU2V2aWNlIHVzZXIgY29uZmlybXMgVFNBUCBjb25uZWN0aW9uIHdpdGggcGVlci4KICoKICovCnN0YXRpYyB2b2lkIGlydHRwX2Nvbm5lY3RfY29uZmlybSh2b2lkICppbnN0YW5jZSwgdm9pZCAqc2FwLAoJCQkJICBzdHJ1Y3QgcW9zX2luZm8gKnFvcywgX191MzIgbWF4X3NlZ19zaXplLAoJCQkJICBfX3U4IG1heF9oZWFkZXJfc2l6ZSwgc3RydWN0IHNrX2J1ZmYgKnNrYikKewoJc3RydWN0IHRzYXBfY2IgKnNlbGY7CglpbnQgcGFyYW1ldGVyczsKCWludCByZXQ7CglfX3U4IHBsZW47CglfX3U4IG47CgoJSVJEQV9ERUJVRyg0LCAiJXMoKVxuIiwgX19GVU5DVElPTl9fKTsKCglzZWxmID0gKHN0cnVjdCB0c2FwX2NiICopIGluc3RhbmNlOwoKCUlSREFfQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuOyk7CglJUkRBX0FTU0VSVChza2IgIT0gTlVMTCwgcmV0dXJuOyk7CgoJc2VsZi0+bWF4X3NlZ19zaXplID0gbWF4X3NlZ19zaXplIC0gVFRQX0hFQURFUjsKCXNlbGYtPm1heF9oZWFkZXJfc2l6ZSA9IG1heF9oZWFkZXJfc2l6ZSArIFRUUF9IRUFERVI7CgoJLyoKCSAqICBDaGVjayBpZiB3ZSBoYXZlIGdvdCBzb21lIFFvUyBwYXJhbWV0ZXJzIGJhY2shIFRoaXMgc2hvdWxkIGJlIHRoZQoJICogIG5lZ290aWF0ZWQgUW9TIGZvciB0aGUgbGluay4KCSAqLwoJaWYgKHFvcykgewoJCUlSREFfREVCVUcoNCwgIklyVFRQLCBOZWdvdGlhdGVkIEJBVURfUkFURTogJTAyeFxuIiwKCQkgICAgICAgcW9zLT5iYXVkX3JhdGUuYml0cyk7CgkJSVJEQV9ERUJVRyg0LCAiSXJUVFAsIE5lZ290aWF0ZWQgQkFVRF9SQVRFOiAlZCBicHMuXG4iLAoJCSAgICAgICBxb3MtPmJhdWRfcmF0ZS52YWx1ZSk7Cgl9CgoJbiA9IHNrYi0+ZGF0YVswXSAmIDB4N2Y7CgoJSVJEQV9ERUJVRyg0LCAiJXMoKSwgSW5pdGlhbCBzZW5kX2NyZWRpdD0lZFxuIiwgX19GVU5DVElPTl9fLCBuKTsKCglzZWxmLT5zZW5kX2NyZWRpdCA9IG47CglzZWxmLT50eF9tYXhfc2R1X3NpemUgPSAwOwoJc2VsZi0+Y29ubmVjdGVkID0gVFJVRTsKCglwYXJhbWV0ZXJzID0gc2tiLT5kYXRhWzBdICYgMHg4MDsKCglJUkRBX0FTU0VSVChza2ItPmxlbiA+PSBUVFBfSEVBREVSLCByZXR1cm47KTsKCXNrYl9wdWxsKHNrYiwgVFRQX0hFQURFUik7CgoJaWYgKHBhcmFtZXRlcnMpIHsKCQlwbGVuID0gc2tiLT5kYXRhWzBdOwoKCQlyZXQgPSBpcmRhX3BhcmFtX2V4dHJhY3RfYWxsKHNlbGYsIHNrYi0+ZGF0YSsxLAoJCQkJCSAgICAgSVJEQV9NSU4oc2tiLT5sZW4tMSwgcGxlbiksCgkJCQkJICAgICAmcGFyYW1faW5mbyk7CgoJCS8qIEFueSBlcnJvcnMgaW4gdGhlIHBhcmFtZXRlciBsaXN0PyAqLwoJCWlmIChyZXQgPCAwKSB7CgkJCUlSREFfV0FSTklORygiJXM6IGVycm9yIGV4dHJhY3RpbmcgcGFyYW1ldGVyc1xuIiwKCQkJCSAgICAgX19GVU5DVElPTl9fKTsKCQkJZGV2X2tmcmVlX3NrYihza2IpOwoKCQkJLyogRG8gbm90IGFjY2VwdCB0aGlzIGNvbm5lY3Rpb24gYXR0ZW1wdCAqLwoJCQlyZXR1cm47CgkJfQoJCS8qIFJlbW92ZSBwYXJhbWV0ZXJzICovCgkJc2tiX3B1bGwoc2tiLCBJUkRBX01JTihza2ItPmxlbiwgcGxlbisxKSk7Cgl9CgoJSVJEQV9ERUJVRyg0LCAiJXMoKSBzZW5kPSVkLGF2YWlsPSVkLHJlbW90ZT0lZFxuIiwgX19GVU5DVElPTl9fLAoJICAgICAgc2VsZi0+c2VuZF9jcmVkaXQsIHNlbGYtPmF2YWlsX2NyZWRpdCwgc2VsZi0+cmVtb3RlX2NyZWRpdCk7CgoJSVJEQV9ERUJVRygyLCAiJXMoKSwgTWF4U2R1U2l6ZT0lZFxuIiwgX19GVU5DVElPTl9fLAoJCSAgIHNlbGYtPnR4X21heF9zZHVfc2l6ZSk7CgoJaWYgKHNlbGYtPm5vdGlmeS5jb25uZWN0X2NvbmZpcm0pIHsKCQlzZWxmLT5ub3RpZnkuY29ubmVjdF9jb25maXJtKHNlbGYtPm5vdGlmeS5pbnN0YW5jZSwgc2VsZiwgcW9zLAoJCQkJCSAgICAgc2VsZi0+dHhfbWF4X3NkdV9zaXplLAoJCQkJCSAgICAgc2VsZi0+bWF4X2hlYWRlcl9zaXplLCBza2IpOwoJfSBlbHNlCgkJZGV2X2tmcmVlX3NrYihza2IpOwp9CgovKgogKiBGdW5jdGlvbiBpcnR0cF9jb25uZWN0X2luZGljYXRpb24gKGhhbmRsZSwgc2tiKQogKgogKiAgICBTb21lIG90aGVyIGRldmljZSBpcyBjb25uZWN0aW5nIHRvIHRoaXMgVFNBUAogKgogKi8Kdm9pZCBpcnR0cF9jb25uZWN0X2luZGljYXRpb24odm9pZCAqaW5zdGFuY2UsIHZvaWQgKnNhcCwgc3RydWN0IHFvc19pbmZvICpxb3MsCgkJCSAgICAgIF9fdTMyIG1heF9zZWdfc2l6ZSwgX191OCBtYXhfaGVhZGVyX3NpemUsCgkJCSAgICAgIHN0cnVjdCBza19idWZmICpza2IpCnsKCXN0cnVjdCB0c2FwX2NiICpzZWxmOwoJc3RydWN0IGxzYXBfY2IgKmxzYXA7CglpbnQgcGFyYW1ldGVyczsKCWludCByZXQ7CglfX3U4IHBsZW47CglfX3U4IG47CgoJc2VsZiA9IChzdHJ1Y3QgdHNhcF9jYiAqKSBpbnN0YW5jZTsKCglJUkRBX0FTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybjspOwoJSVJEQV9BU1NFUlQoc2VsZi0+bWFnaWMgPT0gVFRQX1RTQVBfTUFHSUMsIHJldHVybjspOwoJSVJEQV9BU1NFUlQoc2tiICE9IE5VTEwsIHJldHVybjspOwoKCWxzYXAgPSAoc3RydWN0IGxzYXBfY2IgKikgc2FwOwoKCXNlbGYtPm1heF9zZWdfc2l6ZSA9IG1heF9zZWdfc2l6ZSAtIFRUUF9IRUFERVI7CglzZWxmLT5tYXhfaGVhZGVyX3NpemUgPSBtYXhfaGVhZGVyX3NpemUrVFRQX0hFQURFUjsKCglJUkRBX0RFQlVHKDQsICIlcygpLCBUU0FQIHNlbD0lMDJ4XG4iLCBfX0ZVTkNUSU9OX18sIHNlbGYtPnN0c2FwX3NlbCk7CgoJLyogTmVlZCB0byB1cGRhdGUgZHRzYXBfc2VsIGlmIGl0cyBlcXVhbCB0byBMU0FQX0FOWSAqLwoJc2VsZi0+ZHRzYXBfc2VsID0gbHNhcC0+ZGxzYXBfc2VsOwoKCW4gPSBza2ItPmRhdGFbMF0gJiAweDdmOwoKCXNlbGYtPnNlbmRfY3JlZGl0ID0gbjsKCXNlbGYtPnR4X21heF9zZHVfc2l6ZSA9IDA7CgoJcGFyYW1ldGVycyA9IHNrYi0+ZGF0YVswXSAmIDB4ODA7CgoJSVJEQV9BU1NFUlQoc2tiLT5sZW4gPj0gVFRQX0hFQURFUiwgcmV0dXJuOyk7Cglza2JfcHVsbChza2IsIFRUUF9IRUFERVIpOwoKCWlmIChwYXJhbWV0ZXJzKSB7CgkJcGxlbiA9IHNrYi0+ZGF0YVswXTsKCgkJcmV0ID0gaXJkYV9wYXJhbV9leHRyYWN0X2FsbChzZWxmLCBza2ItPmRhdGErMSwKCQkJCQkgICAgIElSREFfTUlOKHNrYi0+bGVuLTEsIHBsZW4pLAoJCQkJCSAgICAgJnBhcmFtX2luZm8pOwoKCQkvKiBBbnkgZXJyb3JzIGluIHRoZSBwYXJhbWV0ZXIgbGlzdD8gKi8KCQlpZiAocmV0IDwgMCkgewoJCQlJUkRBX1dBUk5JTkcoIiVzOiBlcnJvciBleHRyYWN0aW5nIHBhcmFtZXRlcnNcbiIsCgkJCQkgICAgIF9fRlVOQ1RJT05fXyk7CgkJCWRldl9rZnJlZV9za2Ioc2tiKTsKCgkJCS8qIERvIG5vdCBhY2NlcHQgdGhpcyBjb25uZWN0aW9uIGF0dGVtcHQgKi8KCQkJcmV0dXJuOwoJCX0KCgkJLyogUmVtb3ZlIHBhcmFtZXRlcnMgKi8KCQlza2JfcHVsbChza2IsIElSREFfTUlOKHNrYi0+bGVuLCBwbGVuKzEpKTsKCX0KCglpZiAoc2VsZi0+bm90aWZ5LmNvbm5lY3RfaW5kaWNhdGlvbikgewoJCXNlbGYtPm5vdGlmeS5jb25uZWN0X2luZGljYXRpb24oc2VsZi0+bm90aWZ5Lmluc3RhbmNlLCBzZWxmLAoJCQkJCQlxb3MsIHNlbGYtPnR4X21heF9zZHVfc2l6ZSwKCQkJCQkJc2VsZi0+bWF4X2hlYWRlcl9zaXplLCBza2IpOwoJfSBlbHNlCgkJZGV2X2tmcmVlX3NrYihza2IpOwp9CgovKgogKiBGdW5jdGlvbiBpcnR0cF9jb25uZWN0X3Jlc3BvbnNlIChoYW5kbGUsIHVzZXJkYXRhKQogKgogKiAgICBTZXJ2aWNlIHVzZXIgaXMgYWNjZXB0aW5nIHRoZSBjb25uZWN0aW9uLCBqdXN0IHBhc3MgaXQgZG93biB0bwogKiAgICBJckxNUCEKICoKICovCmludCBpcnR0cF9jb25uZWN0X3Jlc3BvbnNlKHN0cnVjdCB0c2FwX2NiICpzZWxmLCBfX3UzMiBtYXhfc2R1X3NpemUsCgkJCSAgIHN0cnVjdCBza19idWZmICp1c2VyZGF0YSkKewoJc3RydWN0IHNrX2J1ZmYgKnR4X3NrYjsKCV9fdTggKmZyYW1lOwoJaW50IHJldDsKCV9fdTggbjsKCglJUkRBX0FTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybiAtMTspOwoJSVJEQV9BU1NFUlQoc2VsZi0+bWFnaWMgPT0gVFRQX1RTQVBfTUFHSUMsIHJldHVybiAtMTspOwoKCUlSREFfREVCVUcoNCwgIiVzKCksIFNvdXJjZSBUU0FQIHNlbGVjdG9yPSUwMnhcbiIsIF9fRlVOQ1RJT05fXywKCQkgICBzZWxmLT5zdHNhcF9zZWwpOwoKCS8qIEFueSB1c2VyZGF0YSBzdXBwbGllZD8gKi8KCWlmICh1c2VyZGF0YSA9PSBOVUxMKSB7CgkJdHhfc2tiID0gYWxsb2Nfc2tiKFRUUF9NQVhfSEVBREVSICsgVFRQX1NBUl9IRUFERVIsCgkJCQkgICBHRlBfQVRPTUlDKTsKCQlpZiAoIXR4X3NrYikKCQkJcmV0dXJuIC1FTk9NRU07CgoJCS8qIFJlc2VydmUgc3BhY2UgZm9yIE1VWF9DT05UUk9MIGFuZCBMQVAgaGVhZGVyICovCgkJc2tiX3Jlc2VydmUodHhfc2tiLCBUVFBfTUFYX0hFQURFUik7Cgl9IGVsc2UgewoJCXR4X3NrYiA9IHVzZXJkYXRhOwoJCS8qCgkJICogIENoZWNrIHRoYXQgdGhlIGNsaWVudCBoYXMgcmVzZXJ2ZWQgZW5vdWdoIHNwYWNlIGZvcgoJCSAqICBoZWFkZXJzCgkJICovCgkJSVJEQV9BU1NFUlQoc2tiX2hlYWRyb29tKHVzZXJkYXRhKSA+PSBUVFBfTUFYX0hFQURFUiwKCQkJeyBkZXZfa2ZyZWVfc2tiKHVzZXJkYXRhKTsgcmV0dXJuIC0xOyB9ICk7Cgl9CgoJc2VsZi0+YXZhaWxfY3JlZGl0ID0gMDsKCXNlbGYtPnJlbW90ZV9jcmVkaXQgPSAwOwoJc2VsZi0+cnhfbWF4X3NkdV9zaXplID0gbWF4X3NkdV9zaXplOwoJc2VsZi0+cnhfc2R1X3NpemUgPSAwOwoJc2VsZi0+cnhfc2R1X2J1c3kgPSBGQUxTRTsKCgluID0gc2VsZi0+aW5pdGlhbF9jcmVkaXQ7CgoJLyogRnJhbWUgaGFzIG9ubHkgc3BhY2UgZm9yIG1heCAxMjcgY3JlZGl0cyAoNyBiaXRzKSAqLwoJaWYgKG4gPiAxMjcpIHsKCQlzZWxmLT5hdmFpbF9jcmVkaXQgPSBuIC0gMTI3OwoJCW4gPSAxMjc7Cgl9CgoJc2VsZi0+cmVtb3RlX2NyZWRpdCA9IG47CglzZWxmLT5jb25uZWN0ZWQgPSBUUlVFOwoKCS8qIFNBUiBlbmFibGVkPyAqLwoJaWYgKG1heF9zZHVfc2l6ZSA+IDApIHsKCQlJUkRBX0FTU0VSVChza2JfaGVhZHJvb20odHhfc2tiKSA+PSAoVFRQX01BWF9IRUFERVIgKyBUVFBfU0FSX0hFQURFUiksCgkJCXsgZGV2X2tmcmVlX3NrYih0eF9za2IpOyByZXR1cm4gLTE7IH0gKTsKCgkJLyogSW5zZXJ0IFRUUCBoZWFkZXIgd2l0aCBTQVIgcGFyYW1ldGVycyAqLwoJCWZyYW1lID0gc2tiX3B1c2godHhfc2tiLCBUVFBfSEVBREVSK1RUUF9TQVJfSEVBREVSKTsKCgkJZnJhbWVbMF0gPSBUVFBfUEFSQU1FVEVSUyB8IG47CgkJZnJhbWVbMV0gPSAweDA0OyAvKiBMZW5ndGggKi8KCgkJLyogaXJkYV9wYXJhbV9pbnNlcnQoc2VsZiwgSVJUVFBfTUFYX1NEVV9TSVpFLCBmcmFtZSsxLCAgKi8KLyoJCQkJICBUVFBfU0FSX0hFQURFUiwgJnBhcmFtX2luZm8pICovCgoJCWZyYW1lWzJdID0gMHgwMTsgLyogTWF4U2R1U2l6ZSAqLwoJCWZyYW1lWzNdID0gMHgwMjsgLyogVmFsdWUgbGVuZ3RoICovCgoJCXB1dF91bmFsaWduZWQoY3B1X3RvX2JlMTYoKF9fdTE2KSBtYXhfc2R1X3NpemUpLAoJCQkgICAgICAoX191MTYgKikoZnJhbWUrNCkpOwoJfSBlbHNlIHsKCQkvKiBJbnNlcnQgVFRQIGhlYWRlciAqLwoJCWZyYW1lID0gc2tiX3B1c2godHhfc2tiLCBUVFBfSEVBREVSKTsKCgkJZnJhbWVbMF0gPSBuICYgMHg3ZjsKCX0KCglyZXQgPSBpcmxtcF9jb25uZWN0X3Jlc3BvbnNlKHNlbGYtPmxzYXAsIHR4X3NrYik7CgoJcmV0dXJuIHJldDsKfQpFWFBPUlRfU1lNQk9MKGlydHRwX2Nvbm5lY3RfcmVzcG9uc2UpOwoKLyoKICogRnVuY3Rpb24gaXJ0dHBfZHVwIChzZWxmLCBpbnN0YW5jZSkKICoKICogICAgRHVwbGljYXRlIFRTQVAsIGNhbiBiZSB1c2VkIGJ5IHNlcnZlcnMgdG8gY29uZmlybSBhIGNvbm5lY3Rpb24gb24gYQogKiAgICBuZXcgVFNBUCBzbyBpdCBjYW4ga2VlcCBsaXN0ZW5pbmcgb24gdGhlIG9sZCBvbmUuCiAqLwpzdHJ1Y3QgdHNhcF9jYiAqaXJ0dHBfZHVwKHN0cnVjdCB0c2FwX2NiICpvcmlnLCB2b2lkICppbnN0YW5jZSkKewoJc3RydWN0IHRzYXBfY2IgKm5ldzsKCXVuc2lnbmVkIGxvbmcgZmxhZ3M7CgoJSVJEQV9ERUJVRygxLCAiJXMoKVxuIiwgX19GVU5DVElPTl9fKTsKCgkvKiBQcm90ZWN0IG91ciBhY2Nlc3MgdG8gdGhlIG9sZCB0c2FwIGluc3RhbmNlICovCglzcGluX2xvY2tfaXJxc2F2ZSgmaXJ0dHAtPnRzYXBzLT5oYl9zcGlubG9jaywgZmxhZ3MpOwoKCS8qIEZpbmQgdGhlIG9sZCBpbnN0YW5jZSAqLwoJaWYgKCFoYXNoYmluX2ZpbmQoaXJ0dHAtPnRzYXBzLCAobG9uZykgb3JpZywgTlVMTCkpIHsKCQlJUkRBX0RFQlVHKDAsICIlcygpLCB1bmFibGUgdG8gZmluZCBUU0FQXG4iLCBfX0ZVTkNUSU9OX18pOwoJCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmlydHRwLT50c2Fwcy0+aGJfc3BpbmxvY2ssIGZsYWdzKTsKCQlyZXR1cm4gTlVMTDsKCX0KCgkvKiBBbGxvY2F0ZSBhIG5ldyBpbnN0YW5jZSAqLwoJbmV3ID0ga21hbGxvYyhzaXplb2Yoc3RydWN0IHRzYXBfY2IpLCBHRlBfQVRPTUlDKTsKCWlmICghbmV3KSB7CgkJSVJEQV9ERUJVRygwLCAiJXMoKSwgdW5hYmxlIHRvIGttYWxsb2NcbiIsIF9fRlVOQ1RJT05fXyk7CgkJc3Bpbl91bmxvY2tfaXJxcmVzdG9yZSgmaXJ0dHAtPnRzYXBzLT5oYl9zcGlubG9jaywgZmxhZ3MpOwoJCXJldHVybiBOVUxMOwoJfQoJLyogRHVwICovCgltZW1jcHkobmV3LCBvcmlnLCBzaXplb2Yoc3RydWN0IHRzYXBfY2IpKTsKCgkvKiBXZSBkb24ndCBuZWVkIHRoZSBvbGQgaW5zdGFuY2UgYW55IG1vcmUgKi8KCXNwaW5fdW5sb2NrX2lycXJlc3RvcmUoJmlydHRwLT50c2Fwcy0+aGJfc3BpbmxvY2ssIGZsYWdzKTsKCgkvKiBUcnkgdG8gZHVwIHRoZSBMU0FQIChtYXkgZmFpbCBpZiB3ZSB3ZXJlIHRvbyBzbG93KSAqLwoJbmV3LT5sc2FwID0gaXJsbXBfZHVwKG9yaWctPmxzYXAsIG5ldyk7CglpZiAoIW5ldy0+bHNhcCkgewoJCUlSREFfREVCVUcoMCwgIiVzKCksIGR1cCBmYWlsZWQhXG4iLCBfX0ZVTkNUSU9OX18pOwoJCWtmcmVlKG5ldyk7CgkJcmV0dXJuIE5VTEw7Cgl9CgoJLyogTm90IGV2ZXJ5dGhpbmcgc2hvdWxkIGJlIGNvcGllZCAqLwoJbmV3LT5ub3RpZnkuaW5zdGFuY2UgPSBpbnN0YW5jZTsKCWluaXRfdGltZXIoJm5ldy0+dG9kb190aW1lcik7CgoJc2tiX3F1ZXVlX2hlYWRfaW5pdCgmbmV3LT5yeF9xdWV1ZSk7Cglza2JfcXVldWVfaGVhZF9pbml0KCZuZXctPnR4X3F1ZXVlKTsKCXNrYl9xdWV1ZV9oZWFkX2luaXQoJm5ldy0+cnhfZnJhZ21lbnRzKTsKCgkvKiBUaGlzIGlzIGxvY2tlZCAqLwoJaGFzaGJpbl9pbnNlcnQoaXJ0dHAtPnRzYXBzLCAoaXJkYV9xdWV1ZV90ICopIG5ldywgKGxvbmcpIG5ldywgTlVMTCk7CgoJcmV0dXJuIG5ldzsKfQpFWFBPUlRfU1lNQk9MKGlydHRwX2R1cCk7CgovKgogKiBGdW5jdGlvbiBpcnR0cF9kaXNjb25uZWN0X3JlcXVlc3QgKHNlbGYpCiAqCiAqICAgIENsb3NlIHRoaXMgY29ubmVjdGlvbiBwbGVhc2UhIElmIHByaW9yaXR5IGlzIGhpZ2gsIHRoZSBxdWV1ZWQgZGF0YQogKiAgICBzZWdtZW50cywgaWYgYW55LCB3aWxsIGJlIGRlYWxsb2NhdGVkIGZpcnN0CiAqCiAqLwppbnQgaXJ0dHBfZGlzY29ubmVjdF9yZXF1ZXN0KHN0cnVjdCB0c2FwX2NiICpzZWxmLCBzdHJ1Y3Qgc2tfYnVmZiAqdXNlcmRhdGEsCgkJCSAgICAgaW50IHByaW9yaXR5KQp7CglpbnQgcmV0OwoKCUlSREFfQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuIC0xOyk7CglJUkRBX0FTU0VSVChzZWxmLT5tYWdpYyA9PSBUVFBfVFNBUF9NQUdJQywgcmV0dXJuIC0xOyk7CgoJLyogQWxyZWFkeSBkaXNjb25uZWN0ZWQ/ICovCglpZiAoIXNlbGYtPmNvbm5lY3RlZCkgewoJCUlSREFfREVCVUcoNCwgIiVzKCksIGFscmVhZHkgZGlzY29ubmVjdGVkIVxuIiwgX19GVU5DVElPTl9fKTsKCQlpZiAodXNlcmRhdGEpCgkJCWRldl9rZnJlZV9za2IodXNlcmRhdGEpOwoJCXJldHVybiAtMTsKCX0KCgkvKiBEaXNjb25uZWN0IGFscmVhZHkgcGVuZGluZyA/CgkgKiBXZSBuZWVkIHRvIHVzZSBhbiBhdG9taWMgb3BlcmF0aW9uIHRvIHByZXZlbnQgcmVlbnRyeS4gVGhpcwoJICogZnVuY3Rpb24gbWF5IGJlIGNhbGxlZCBmcm9tIHZhcmlvdXMgY29udGV4dCwgbGlrZSB1c2VyLCB0aW1lcgoJICogZm9yIGZvbGxvd2luZyBhIGRpc2Nvbm5lY3RfaW5kaWNhdGlvbigpIChpLmUuIG5ldF9iaCkuCgkgKiBKZWFuIElJICovCglpZih0ZXN0X2FuZF9zZXRfYml0KDAsICZzZWxmLT5kaXNjb25uZWN0X3BlbmQpKSB7CgkJSVJEQV9ERUJVRygwLCAiJXMoKSwgZGlzY29ubmVjdCBhbHJlYWR5IHBlbmRpbmdcbiIsCgkJCSAgIF9fRlVOQ1RJT05fXyk7CgkJaWYgKHVzZXJkYXRhKQoJCQlkZXZfa2ZyZWVfc2tiKHVzZXJkYXRhKTsKCgkJLyogVHJ5IHRvIG1ha2Ugc29tZSBwcm9ncmVzcyAqLwoJCWlydHRwX3J1bl90eF9xdWV1ZShzZWxmKTsKCQlyZXR1cm4gLTE7Cgl9CgoJLyoKCSAqICBDaGVjayBpZiB0aGVyZSBpcyBzdGlsbCBkYXRhIHNlZ21lbnRzIGluIHRoZSB0cmFuc21pdCBxdWV1ZQoJICovCglpZiAoIXNrYl9xdWV1ZV9lbXB0eSgmc2VsZi0+dHhfcXVldWUpKSB7CgkJaWYgKHByaW9yaXR5ID09IFBfSElHSCkgewoJCQkvKgoJCQkgKiAgTm8gbmVlZCB0byBzZW5kIHRoZSBxdWV1ZWQgZGF0YSwgaWYgd2UgYXJlCgkJCSAqICBkaXNjb25uZWN0aW5nIHJpZ2h0IG5vdyBzaW5jZSB0aGUgZGF0YSB3aWxsCgkJCSAqICBub3QgaGF2ZSBhbnkgdXNhYmxlIGNvbm5lY3Rpb24gdG8gYmUgc2VudCBvbgoJCQkgKi8KCQkJSVJEQV9ERUJVRygxLCAiJXMoKTogSGlnaCBwcmlvcml0eSEhKClcbiIsIF9fRlVOQ1RJT05fXyk7CgkJCWlydHRwX2ZsdXNoX3F1ZXVlcyhzZWxmKTsKCQl9IGVsc2UgaWYgKHByaW9yaXR5ID09IFBfTk9STUFMKSB7CgkJCS8qCgkJCSAqICBNdXN0IGRlbGF5IGRpc2Nvbm5lY3QgdW50aWwgYWZ0ZXIgYWxsIGRhdGEgc2VnbWVudHMKCQkJICogIGhhdmUgYmVlbiBzZW50IGFuZCB0aGUgdHhfcXVldWUgaXMgZW1wdHkKCQkJICovCgkJCS8qIFdlJ2xsIHJldXNlIHRoaXMgb25lIGxhdGVyIGZvciB0aGUgZGlzY29ubmVjdCAqLwoJCQlzZWxmLT5kaXNjb25uZWN0X3NrYiA9IHVzZXJkYXRhOyAgLyogTWF5IGJlIE5VTEwgKi8KCgkJCWlydHRwX3J1bl90eF9xdWV1ZShzZWxmKTsKCgkJCWlydHRwX3N0YXJ0X3RvZG9fdGltZXIoc2VsZiwgSFovMTApOwoJCQlyZXR1cm4gLTE7CgkJfQoJfQoJLyogTm90ZSA6IHdlIGRvbid0IG5lZWQgdG8gY2hlY2sgaWYgc2VsZi0+cnhfcXVldWUgaXMgZnVsbCBhbmQgdGhlCgkgKiBzdGF0ZSBvZiBzZWxmLT5yeF9zZHVfYnVzeSBiZWNhdXNlIHRoZSBkaXNjb25uZWN0IHJlc3BvbnNlIHdpbGwKCSAqIGJlIHNlbnQgYXQgdGhlIExNUCBsZXZlbCAoc28gZXZlbiBpZiB0aGUgcGVlciBoYXMgaXRzIFR4IHF1ZXVlCgkgKiBmdWxsIG9mIGRhdGEpLiAtIEplYW4gSUkgKi8KCglJUkRBX0RFQlVHKDEsICIlcygpLCBEaXNjb25uZWN0aW5nIC4uLlxuIiwgX19GVU5DVElPTl9fKTsKCXNlbGYtPmNvbm5lY3RlZCA9IEZBTFNFOwoKCWlmICghdXNlcmRhdGEpIHsKCQlzdHJ1Y3Qgc2tfYnVmZiAqdHhfc2tiOwoJCXR4X3NrYiA9IGFsbG9jX3NrYihMTVBfTUFYX0hFQURFUiwgR0ZQX0FUT01JQyk7CgkJaWYgKCF0eF9za2IpCgkJCXJldHVybiAtRU5PTUVNOwoKCQkvKgoJCSAqICBSZXNlcnZlIHNwYWNlIGZvciBNVVggYW5kIExBUCBoZWFkZXIKCQkgKi8KCQlza2JfcmVzZXJ2ZSh0eF9za2IsIExNUF9NQVhfSEVBREVSKTsKCgkJdXNlcmRhdGEgPSB0eF9za2I7Cgl9CglyZXQgPSBpcmxtcF9kaXNjb25uZWN0X3JlcXVlc3Qoc2VsZi0+bHNhcCwgdXNlcmRhdGEpOwoKCS8qIFRoZSBkaXNjb25uZWN0IGlzIG5vIGxvbmdlciBwZW5kaW5nICovCgljbGVhcl9iaXQoMCwgJnNlbGYtPmRpc2Nvbm5lY3RfcGVuZCk7CS8qIEZBTFNFICovCgoJcmV0dXJuIHJldDsKfQpFWFBPUlRfU1lNQk9MKGlydHRwX2Rpc2Nvbm5lY3RfcmVxdWVzdCk7CgovKgogKiBGdW5jdGlvbiBpcnR0cF9kaXNjb25uZWN0X2luZGljYXRpb24gKHNlbGYsIHJlYXNvbikKICoKICogICAgRGlzY29ubmVjdCBpbmRpY2F0aW9uLCBUU0FQIGRpc2Nvbm5lY3RlZCBieSBwZWVyPwogKgogKi8Kdm9pZCBpcnR0cF9kaXNjb25uZWN0X2luZGljYXRpb24odm9pZCAqaW5zdGFuY2UsIHZvaWQgKnNhcCwgTE1fUkVBU09OIHJlYXNvbiwKCQkJCSBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglzdHJ1Y3QgdHNhcF9jYiAqc2VsZjsKCglJUkRBX0RFQlVHKDQsICIlcygpXG4iLCBfX0ZVTkNUSU9OX18pOwoKCXNlbGYgPSAoc3RydWN0IHRzYXBfY2IgKikgaW5zdGFuY2U7CgoJSVJEQV9BU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm47KTsKCUlSREFfQVNTRVJUKHNlbGYtPm1hZ2ljID09IFRUUF9UU0FQX01BR0lDLCByZXR1cm47KTsKCgkvKiBQcmV2ZW50IGhpZ2hlciBsYXllciB0byBzZW5kIG1vcmUgZGF0YSAqLwoJc2VsZi0+Y29ubmVjdGVkID0gRkFMU0U7CgoJLyogQ2hlY2sgaWYgY2xpZW50IGhhcyBhbHJlYWR5IHRyaWVkIHRvIGNsb3NlIHRoZSBUU0FQICovCglpZiAoc2VsZi0+Y2xvc2VfcGVuZCkgewoJCS8qIEluIHRoaXMgY2FzZSwgdGhlIGhpZ2hlciBsYXllciBpcyBwcm9iYWJseSBnb25lLiBEb24ndAoJCSAqIGJvdGhlciBpdCBhbmQgY2xlYW4gdXAgdGhlIHJlbWFpbnMgLSBKZWFuIElJICovCgkJaWYgKHNrYikKCQkJZGV2X2tmcmVlX3NrYihza2IpOwoJCWlydHRwX2Nsb3NlX3RzYXAoc2VsZik7CgkJcmV0dXJuOwoJfQoKCS8qIElmIHdlIGFyZSBoZXJlLCB3ZSBhc3N1bWUgdGhhdCBpcyB0aGUgaGlnaGVyIGxheWVyIGlzIHN0aWxsCgkgKiB3YWl0aW5nIGZvciB0aGUgZGlzY29ubmVjdCBub3RpZmljYXRpb24gYW5kIGFibGUgdG8gcHJvY2VzcyBpdCwKCSAqIGV2ZW4gaWYgaGUgdHJpZWQgdG8gZGlzY29ubmVjdC4gT3RoZXJ3aXNlLCBpdCB3b3VsZCBoYXZlIGFscmVhZHkKCSAqIGF0dGVtcHRlZCB0byBjbG9zZSB0aGUgdHNhcCBhbmQgc2VsZi0+Y2xvc2VfcGVuZCB3b3VsZCBiZSBUUlVFLgoJICogSmVhbiBJSSAqLwoKCS8qIE5vIG5lZWQgdG8gbm90aWZ5IHRoZSBjbGllbnQgaWYgaGFzIGFscmVhZHkgdHJpZWQgdG8gZGlzY29ubmVjdCAqLwoJaWYoc2VsZi0+bm90aWZ5LmRpc2Nvbm5lY3RfaW5kaWNhdGlvbikKCQlzZWxmLT5ub3RpZnkuZGlzY29ubmVjdF9pbmRpY2F0aW9uKHNlbGYtPm5vdGlmeS5pbnN0YW5jZSwgc2VsZiwKCQkJCQkJICAgcmVhc29uLCBza2IpOwoJZWxzZQoJCWlmIChza2IpCgkJCWRldl9rZnJlZV9za2Ioc2tiKTsKfQoKLyoKICogRnVuY3Rpb24gaXJ0dHBfZG9fZGF0YV9pbmRpY2F0aW9uIChzZWxmLCBza2IpCiAqCiAqICAgIFRyeSB0byBkZWxpdmVyIHJlYXNzZW1ibGVkIHNrYiB0byBsYXllciBhYm92ZSwgYW5kIHJlcXVldWUgaXQgaWYgdGhhdAogKiAgICBmb3Igc29tZSByZWFzb24gc2hvdWxkIGZhaWwuIFdlIG1hcmsgcnggc2R1IGFzIGJ1c3kgdG8gYXBwbHkgYmFjawogKiAgICBwcmVzc3VyZSBpcyBuZWNlc3NhcnkuCiAqLwpzdGF0aWMgdm9pZCBpcnR0cF9kb19kYXRhX2luZGljYXRpb24oc3RydWN0IHRzYXBfY2IgKnNlbGYsIHN0cnVjdCBza19idWZmICpza2IpCnsKCWludCBlcnI7CgoJLyogQ2hlY2sgaWYgY2xpZW50IGhhcyBhbHJlYWR5IGNsb3NlZCB0aGUgVFNBUCBhbmQgZ29uZSBhd2F5ICovCglpZiAoc2VsZi0+Y2xvc2VfcGVuZCkgewoJCWRldl9rZnJlZV9za2Ioc2tiKTsKCQlyZXR1cm47Cgl9CgoJZXJyID0gc2VsZi0+bm90aWZ5LmRhdGFfaW5kaWNhdGlvbihzZWxmLT5ub3RpZnkuaW5zdGFuY2UsIHNlbGYsIHNrYik7CgoJLyogVXN1YWxseSB0aGUgbGF5ZXIgYWJvdmUgd2lsbCBub3RpZnkgdGhhdCBpdCdzIGlucHV0IHF1ZXVlIGlzCgkgKiBzdGFydGluZyB0byBnZXQgZmlsbGVkIGJ5IHVzaW5nIHRoZSBmbG93IHJlcXVlc3QsIGJ1dCB0aGlzIG1heQoJICogYmUgZGlmZmljdWx0LCBzbyBpdCBjYW4gaW5zdGVhZCBqdXN0IHJlZnVzZSB0byBlYXQgaXQgYW5kIGp1c3QKCSAqIGdpdmUgYW4gZXJyb3IgYmFjawoJICovCglpZiAoZXJyKSB7CgkJSVJEQV9ERUJVRygwLCAiJXMoKSByZXF1ZXVlaW5nIHNrYiFcbiIsIF9fRlVOQ1RJT05fXyk7CgoJCS8qIE1ha2Ugc3VyZSB3ZSB0YWtlIGEgYnJlYWsgKi8KCQlzZWxmLT5yeF9zZHVfYnVzeSA9IFRSVUU7CgoJCS8qIE5lZWQgdG8gcHVzaCB0aGUgaGVhZGVyIGluIGFnYWluICovCgkJc2tiX3B1c2goc2tiLCBUVFBfSEVBREVSKTsKCQlza2ItPmRhdGFbMF0gPSAweDAwOyAvKiBNYWtlIHN1cmUgTU9SRSBiaXQgaXMgY2xlYXJlZCAqLwoKCQkvKiBQdXQgc2tiIGJhY2sgb24gcXVldWUgKi8KCQlza2JfcXVldWVfaGVhZCgmc2VsZi0+cnhfcXVldWUsIHNrYik7Cgl9Cn0KCi8qCiAqIEZ1bmN0aW9uIGlydHRwX3J1bl9yeF9xdWV1ZSAoc2VsZikKICoKICogICAgIENoZWNrIGlmIHdlIGhhdmUgYW55IGZyYW1lcyB0byBiZSB0cmFuc21pdHRlZCwgb3IgaWYgd2UgaGF2ZSBhbnkKICogICAgIGF2YWlsYWJsZSBjcmVkaXQgdG8gZ2l2ZSBhd2F5LgogKi8Kdm9pZCBpcnR0cF9ydW5fcnhfcXVldWUoc3RydWN0IHRzYXBfY2IgKnNlbGYpCnsKCXN0cnVjdCBza19idWZmICpza2I7CglpbnQgbW9yZSA9IDA7CgoJSVJEQV9ERUJVRygyLCAiJXMoKSBzZW5kPSVkLGF2YWlsPSVkLHJlbW90ZT0lZFxuIiwgX19GVU5DVElPTl9fLAoJCSAgIHNlbGYtPnNlbmRfY3JlZGl0LCBzZWxmLT5hdmFpbF9jcmVkaXQsIHNlbGYtPnJlbW90ZV9jcmVkaXQpOwoKCS8qIEdldCBleGNsdXNpdmUgYWNjZXNzIHRvIHRoZSByeCBxdWV1ZSwgb3RoZXJ3aXNlIGRvbid0IHRvdWNoIGl0ICovCglpZiAoaXJkYV9sb2NrKCZzZWxmLT5yeF9xdWV1ZV9sb2NrKSA9PSBGQUxTRSkKCQlyZXR1cm47CgoJLyoKCSAqICBSZWFzc2VtYmxlIGFsbCBmcmFtZXMgaW4gcmVjZWl2ZSBxdWV1ZSBhbmQgZGVsaXZlciB0aGVtCgkgKi8KCXdoaWxlICghc2VsZi0+cnhfc2R1X2J1c3kgJiYgKHNrYiA9IHNrYl9kZXF1ZXVlKCZzZWxmLT5yeF9xdWV1ZSkpKSB7CgkJLyogVGhpcyBiaXQgd2lsbCB0ZWxsIHVzIGlmIGl0J3MgdGhlIGxhc3QgZnJhZ21lbnQgb3Igbm90ICovCgkJbW9yZSA9IHNrYi0+ZGF0YVswXSAmIDB4ODA7CgoJCS8qIFJlbW92ZSBUVFAgaGVhZGVyICovCgkJc2tiX3B1bGwoc2tiLCBUVFBfSEVBREVSKTsKCgkJLyogQWRkIHRoZSBsZW5ndGggb2YgdGhlIHJlbWFpbmluZyBkYXRhICovCgkJc2VsZi0+cnhfc2R1X3NpemUgKz0gc2tiLT5sZW47CgoJCS8qCgkJICogSWYgU0FSIGlzIGRpc2FibGVkLCBvciB1c2VyIGhhcyByZXF1ZXN0ZWQgbm8gcmVhc3NlbWJseQoJCSAqIG9mIHJlY2VpdmVkIGZyYWdtZW50cyB0aGVuIHdlIGp1c3QgZGVsaXZlciB0aGVtCgkJICogaW1tZWRpYXRlbHkuIFRoaXMgY2FuIGJlIHJlcXVlc3RlZCBieSBjbGllbnRzIHRoYXQKCQkgKiBpbXBsZW1lbnRzIGJ5dGUgc3RyZWFtcyB3aXRob3V0IGFueSBtZXNzYWdlIGJvdW5kYXJpZXMKCQkgKi8KCQlpZiAoc2VsZi0+cnhfbWF4X3NkdV9zaXplID09IFRUUF9TQVJfRElTQUJMRSkgewoJCQlpcnR0cF9kb19kYXRhX2luZGljYXRpb24oc2VsZiwgc2tiKTsKCQkJc2VsZi0+cnhfc2R1X3NpemUgPSAwOwoKCQkJY29udGludWU7CgkJfQoKCQkvKiBDaGVjayBpZiB0aGlzIGlzIGEgZnJhZ21lbnQsIGFuZCBub3QgdGhlIGxhc3QgZnJhZ21lbnQgKi8KCQlpZiAobW9yZSkgewoJCQkvKgoJCQkgKiAgUXVldWUgdGhlIGZyYWdtZW50IGlmIHdlIHN0aWxsIGFyZSB3aXRoaW4gdGhlCgkJCSAqICBsaW1pdHMgb2YgdGhlIG1heGltdW0gc2l6ZSBvZiB0aGUgcnhfc2R1CgkJCSAqLwoJCQlpZiAoc2VsZi0+cnhfc2R1X3NpemUgPD0gc2VsZi0+cnhfbWF4X3NkdV9zaXplKSB7CgkJCQlJUkRBX0RFQlVHKDQsICIlcygpLCBxdWV1ZWluZyBmcmFnXG4iLAoJCQkJCSAgIF9fRlVOQ1RJT05fXyk7CgkJCQlza2JfcXVldWVfdGFpbCgmc2VsZi0+cnhfZnJhZ21lbnRzLCBza2IpOwoJCQl9IGVsc2UgewoJCQkJLyogRnJlZSB0aGUgcGFydCBvZiB0aGUgU0RVIHRoYXQgaXMgdG9vIGJpZyAqLwoJCQkJZGV2X2tmcmVlX3NrYihza2IpOwoJCQl9CgkJCWNvbnRpbnVlOwoJCX0KCQkvKgoJCSAqICBUaGlzIGlzIHRoZSBsYXN0IGZyYWdtZW50LCBzbyB0aW1lIHRvIHJlYXNzZW1ibGUhCgkJICovCgkJaWYgKChzZWxmLT5yeF9zZHVfc2l6ZSA8PSBzZWxmLT5yeF9tYXhfc2R1X3NpemUpIHx8CgkJICAgIChzZWxmLT5yeF9tYXhfc2R1X3NpemUgPT0gVFRQX1NBUl9VTkJPVU5EKSkKCQl7CgkJCS8qCgkJCSAqIEEgbGl0dGxlIG9wdGltaXppbmcuIE9ubHkgcXVldWUgdGhlIGZyYWdtZW50IGlmCgkJCSAqIHRoZXJlIGFyZSBvdGhlciBmcmFnbWVudHMuIFNpbmNlIGlmIHRoaXMgaXMgdGhlCgkJCSAqIGxhc3QgYW5kIG9ubHkgZnJhZ21lbnQsIHRoZXJlIGlzIG5vIG5lZWQgdG8KCQkJICogcmVhc3NlbWJsZSA6LSkKCQkJICovCgkJCWlmICghc2tiX3F1ZXVlX2VtcHR5KCZzZWxmLT5yeF9mcmFnbWVudHMpKSB7CgkJCQlza2JfcXVldWVfdGFpbCgmc2VsZi0+cnhfZnJhZ21lbnRzLAoJCQkJCSAgICAgICBza2IpOwoKCQkJCXNrYiA9IGlydHRwX3JlYXNzZW1ibGVfc2tiKHNlbGYpOwoJCQl9CgoJCQkvKiBOb3cgd2UgY2FuIGRlbGl2ZXIgdGhlIHJlYXNzZW1ibGVkIHNrYiAqLwoJCQlpcnR0cF9kb19kYXRhX2luZGljYXRpb24oc2VsZiwgc2tiKTsKCQl9IGVsc2UgewoJCQlJUkRBX0RFQlVHKDEsICIlcygpLCBUcnVuY2F0ZWQgZnJhbWVcbiIsIF9fRlVOQ1RJT05fXyk7CgoJCQkvKiBGcmVlIHRoZSBwYXJ0IG9mIHRoZSBTRFUgdGhhdCBpcyB0b28gYmlnICovCgkJCWRldl9rZnJlZV9za2Ioc2tiKTsKCgkJCS8qIERlbGl2ZXIgb25seSB0aGUgdmFsaWQgYnV0IHRydW5jYXRlZCBwYXJ0IG9mIFNEVSAqLwoJCQlza2IgPSBpcnR0cF9yZWFzc2VtYmxlX3NrYihzZWxmKTsKCgkJCWlydHRwX2RvX2RhdGFfaW5kaWNhdGlvbihzZWxmLCBza2IpOwoJCX0KCQlzZWxmLT5yeF9zZHVfc2l6ZSA9IDA7Cgl9CgoJLyoKCSAqIEl0J3Mgbm90IHRyaXZpYWwgdG8ga2VlcCB0cmFjayBvZiBob3cgbWFueSBjcmVkaXRzIGFyZSBhdmFpbGFibGUKCSAqIGJ5IGluY3JlbWVudGluZyBhdCBlYWNoIHBhY2tldCwgYmVjYXVzZSBkZWxpdmVyeSBtYXkgZmFpbAoJICogKGlydHRwX2RvX2RhdGFfaW5kaWNhdGlvbigpIG1heSByZXF1ZXVlIHRoZSBmcmFtZSkgYW5kIGJlY2F1c2UKCSAqIHdlIG5lZWQgdG8gdGFrZSBjYXJlIG9mIGZyYWdtZW50YXRpb24uCgkgKiBXZSB3YW50IHRoZSBvdGhlciBzaWRlIHRvIHNlbmQgdXAgdG8gaW5pdGlhbF9jcmVkaXQgcGFja2V0cy4KCSAqIFdlIGhhdmUgc29tZSBmcmFtZXMgaW4gb3VyIHF1ZXVlcywgYW5kIHdlIGhhdmUgYWxyZWFkeSBhbGxvd2VkIGl0CgkgKiB0byBzZW5kIHJlbW90ZV9jcmVkaXQuCgkgKiBObyBuZWVkIHRvIHNwaW5sb2NrLCB3cml0ZSBpcyBhdG9taWMgYW5kIHNlbGYgY29ycmVjdGluZy4uLgoJICogSmVhbiBJSQoJICovCglzZWxmLT5hdmFpbF9jcmVkaXQgPSAoc2VsZi0+aW5pdGlhbF9jcmVkaXQgLQoJCQkgICAgICAoc2VsZi0+cmVtb3RlX2NyZWRpdCArCgkJCSAgICAgICBza2JfcXVldWVfbGVuKCZzZWxmLT5yeF9xdWV1ZSkgKwoJCQkgICAgICAgc2tiX3F1ZXVlX2xlbigmc2VsZi0+cnhfZnJhZ21lbnRzKSkpOwoKCS8qIERvIHdlIGhhdmUgdG9vIG11Y2ggY3JlZGl0cyB0byBzZW5kIHRvIHBlZXIgPyAqLwoJaWYgKChzZWxmLT5yZW1vdGVfY3JlZGl0IDw9IFRUUF9SWF9NSU5fQ1JFRElUKSAmJgoJICAgIChzZWxmLT5hdmFpbF9jcmVkaXQgPiAwKSkgewoJCS8qIFNlbmQgZXhwbGljaXQgY3JlZGl0IGZyYW1lICovCgkJaXJ0dHBfZ2l2ZV9jcmVkaXQoc2VsZik7CgkJLyogTm90ZSA6IGRvICpOT1QqIGNoZWNrIGlmIHR4X3F1ZXVlIGlzIG5vbi1lbXB0eSwgdGhhdAoJCSAqIHdpbGwgcHJvZHVjZSBkZWFkbG9ja3MuIEkgcmVwZWF0IDogc2VuZCBhIGNyZWRpdCBmcmFtZQoJCSAqIGV2ZW4gaWYgd2UgaGF2ZSBzb21ldGhpbmcgdG8gc2VuZCBpbiBvdXIgVHggcXVldWUuCgkJICogSWYgd2UgaGF2ZSBjcmVkaXRzLCBpdCBtZWFucyB0aGF0IG91ciBUeCBxdWV1ZSBpcyBibG9ja2VkLgoJCSAqCgkJICogTGV0J3Mgc3VwcG9zZSB0aGUgcGVlciBjYW4ndCBrZWVwIHVwIHdpdGggb3VyIFR4LiBIZSB3aWxsCgkJICogZmxvdyBjb250cm9sIHVzIGJ5IG5vdCBzZW5kaW5nIHVzIGFueSBjcmVkaXRzLCBhbmQgd2UKCQkgKiB3aWxsIHN0b3AgVHggYW5kIHN0YXJ0IGFjY3VtdWxhdGluZyBjcmVkaXRzIGhlcmUuCgkJICogVXAgdG8gdGhlIHBvaW50IHdoZXJlIHRoZSBwZWVyIHdpbGwgc3RvcCBpdHMgVHggcXVldWUsCgkJICogZm9yIGxhY2sgb2YgY3JlZGl0cy4KCQkgKiBMZXQncyBhc3N1bWUgdGhlIHBlZXIgYXBwbGljYXRpb24gaXMgc2luZ2xlIHRocmVhZGVkLgoJCSAqIEl0IHdpbGwgYmxvY2sgb24gVHggYW5kIG5ldmVyIGNvbnN1bWUgYW55IFJ4IGJ1ZmZlci4KCQkgKiBEZWFkbG9jay4gR3VhcmFudGVlZC4gLSBKZWFuIElJCgkJICovCgl9CgoJLyogUmVzZXQgbG9jayAqLwoJc2VsZi0+cnhfcXVldWVfbG9jayA9IDA7Cn0KCiNpZmRlZiBDT05GSUdfUFJPQ19GUwpzdHJ1Y3QgaXJ0dHBfaXRlcl9zdGF0ZSB7CglpbnQgaWQ7Cn07CgpzdGF0aWMgdm9pZCAqaXJ0dHBfc2VxX3N0YXJ0KHN0cnVjdCBzZXFfZmlsZSAqc2VxLCBsb2ZmX3QgKnBvcykKewoJc3RydWN0IGlydHRwX2l0ZXJfc3RhdGUgKml0ZXIgPSBzZXEtPnByaXZhdGU7CglzdHJ1Y3QgdHNhcF9jYiAqc2VsZjsKCgkvKiBQcm90ZWN0IG91ciBhY2Nlc3MgdG8gdGhlIHRzYXAgbGlzdCAqLwoJc3Bpbl9sb2NrX2lycSgmaXJ0dHAtPnRzYXBzLT5oYl9zcGlubG9jayk7CglpdGVyLT5pZCA9IDA7CgoJZm9yIChzZWxmID0gKHN0cnVjdCB0c2FwX2NiICopIGhhc2hiaW5fZ2V0X2ZpcnN0KGlydHRwLT50c2Fwcyk7IAoJICAgICBzZWxmICE9IE5VTEw7CgkgICAgIHNlbGYgPSAoc3RydWN0IHRzYXBfY2IgKikgaGFzaGJpbl9nZXRfbmV4dChpcnR0cC0+dHNhcHMpKSB7CgkJaWYgKGl0ZXItPmlkID09ICpwb3MpCgkJCWJyZWFrOwoJCSsraXRlci0+aWQ7Cgl9CgkJCglyZXR1cm4gc2VsZjsKfQoKc3RhdGljIHZvaWQgKmlydHRwX3NlcV9uZXh0KHN0cnVjdCBzZXFfZmlsZSAqc2VxLCB2b2lkICp2LCBsb2ZmX3QgKnBvcykKewoJc3RydWN0IGlydHRwX2l0ZXJfc3RhdGUgKml0ZXIgPSBzZXEtPnByaXZhdGU7CgoJKysqcG9zOwoJKytpdGVyLT5pZDsKCXJldHVybiAodm9pZCAqKSBoYXNoYmluX2dldF9uZXh0KGlydHRwLT50c2Fwcyk7Cn0KCnN0YXRpYyB2b2lkIGlydHRwX3NlcV9zdG9wKHN0cnVjdCBzZXFfZmlsZSAqc2VxLCB2b2lkICp2KQp7CglzcGluX3VubG9ja19pcnEoJmlydHRwLT50c2Fwcy0+aGJfc3BpbmxvY2spOwp9CgpzdGF0aWMgaW50IGlydHRwX3NlcV9zaG93KHN0cnVjdCBzZXFfZmlsZSAqc2VxLCB2b2lkICp2KQp7Cgljb25zdCBzdHJ1Y3QgaXJ0dHBfaXRlcl9zdGF0ZSAqaXRlciA9IHNlcS0+cHJpdmF0ZTsKCWNvbnN0IHN0cnVjdCB0c2FwX2NiICpzZWxmID0gdjsKCglzZXFfcHJpbnRmKHNlcSwgIlRTQVAgJWQsICIsIGl0ZXItPmlkKTsKCXNlcV9wcmludGYoc2VxLCAic3RzYXBfc2VsOiAlMDJ4LCAiLAoJCSAgIHNlbGYtPnN0c2FwX3NlbCk7CglzZXFfcHJpbnRmKHNlcSwgImR0c2FwX3NlbDogJTAyeFxuIiwKCQkgICBzZWxmLT5kdHNhcF9zZWwpOwoJc2VxX3ByaW50ZihzZXEsICIgIGNvbm5lY3RlZDogJXMsICIsCgkJICAgc2VsZi0+Y29ubmVjdGVkPyAiVFJVRSI6IkZBTFNFIik7CglzZXFfcHJpbnRmKHNlcSwgImF2YWlsIGNyZWRpdDogJWQsICIsCgkJICAgc2VsZi0+YXZhaWxfY3JlZGl0KTsKCXNlcV9wcmludGYoc2VxLCAicmVtb3RlIGNyZWRpdDogJWQsICIsCgkJICAgc2VsZi0+cmVtb3RlX2NyZWRpdCk7CglzZXFfcHJpbnRmKHNlcSwgInNlbmQgY3JlZGl0OiAlZFxuIiwKCQkgICBzZWxmLT5zZW5kX2NyZWRpdCk7CglzZXFfcHJpbnRmKHNlcSwgIiAgdHggcGFja2V0czogJWxkLCAiLAoJCSAgIHNlbGYtPnN0YXRzLnR4X3BhY2tldHMpOwoJc2VxX3ByaW50ZihzZXEsICJyeCBwYWNrZXRzOiAlbGQsICIsCgkJICAgc2VsZi0+c3RhdHMucnhfcGFja2V0cyk7CglzZXFfcHJpbnRmKHNlcSwgInR4X3F1ZXVlIGxlbjogJWQgIiwKCQkgICBza2JfcXVldWVfbGVuKCZzZWxmLT50eF9xdWV1ZSkpOwoJc2VxX3ByaW50ZihzZXEsICJyeF9xdWV1ZSBsZW46ICVkXG4iLAoJCSAgIHNrYl9xdWV1ZV9sZW4oJnNlbGYtPnJ4X3F1ZXVlKSk7CglzZXFfcHJpbnRmKHNlcSwgIiAgdHhfc2R1X2J1c3k6ICVzLCAiLAoJCSAgIHNlbGYtPnR4X3NkdV9idXN5PyAiVFJVRSI6IkZBTFNFIik7CglzZXFfcHJpbnRmKHNlcSwgInJ4X3NkdV9idXN5OiAlc1xuIiwKCQkgICBzZWxmLT5yeF9zZHVfYnVzeT8gIlRSVUUiOiJGQUxTRSIpOwoJc2VxX3ByaW50ZihzZXEsICIgIG1heF9zZWdfc2l6ZTogJWQsICIsCgkJICAgc2VsZi0+bWF4X3NlZ19zaXplKTsKCXNlcV9wcmludGYoc2VxLCAidHhfbWF4X3NkdV9zaXplOiAlZCwgIiwKCQkgICBzZWxmLT50eF9tYXhfc2R1X3NpemUpOwoJc2VxX3ByaW50ZihzZXEsICJyeF9tYXhfc2R1X3NpemU6ICVkXG4iLAoJCSAgIHNlbGYtPnJ4X21heF9zZHVfc2l6ZSk7CgoJc2VxX3ByaW50ZihzZXEsICIgIFVzZWQgYnkgKCVzKVxuXG4iLAoJCSAgIHNlbGYtPm5vdGlmeS5uYW1lKTsKCXJldHVybiAwOwp9CgpzdGF0aWMgc3RydWN0IHNlcV9vcGVyYXRpb25zIGlydHRwX3NlcV9vcHMgPSB7Cgkuc3RhcnQgID0gaXJ0dHBfc2VxX3N0YXJ0LAoJLm5leHQgICA9IGlydHRwX3NlcV9uZXh0LAoJLnN0b3AgICA9IGlydHRwX3NlcV9zdG9wLAoJLnNob3cgICA9IGlydHRwX3NlcV9zaG93LAp9OwoKc3RhdGljIGludCBpcnR0cF9zZXFfb3BlbihzdHJ1Y3QgaW5vZGUgKmlub2RlLCBzdHJ1Y3QgZmlsZSAqZmlsZSkKewoJc3RydWN0IHNlcV9maWxlICpzZXE7CglpbnQgcmMgPSAtRU5PTUVNOwoJc3RydWN0IGlydHRwX2l0ZXJfc3RhdGUgKnM7CgoJcyA9IGt6YWxsb2Moc2l6ZW9mKCpzKSwgR0ZQX0tFUk5FTCk7CglpZiAoIXMpCgkJZ290byBvdXQ7CgoJcmMgPSBzZXFfb3BlbihmaWxlLCAmaXJ0dHBfc2VxX29wcyk7CglpZiAocmMpCgkJZ290byBvdXRfa2ZyZWU7CgoJc2VxCSAgICAgPSBmaWxlLT5wcml2YXRlX2RhdGE7CglzZXEtPnByaXZhdGUgPSBzOwpvdXQ6CglyZXR1cm4gcmM7Cm91dF9rZnJlZToKCWtmcmVlKHMpOwoJZ290byBvdXQ7Cn0KCnN0cnVjdCBmaWxlX29wZXJhdGlvbnMgaXJ0dHBfc2VxX2ZvcHMgPSB7Cgkub3duZXIJCT0gVEhJU19NT0RVTEUsCgkub3BlbiAgICAgICAgICAgPSBpcnR0cF9zZXFfb3BlbiwKCS5yZWFkICAgICAgICAgICA9IHNlcV9yZWFkLAoJLmxsc2VlayAgICAgICAgID0gc2VxX2xzZWVrLAoJLnJlbGVhc2UJPSBzZXFfcmVsZWFzZV9wcml2YXRlLAp9OwoKI2VuZGlmIC8qIFBST0NfRlMgKi8K