LyoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgogKiBGaWxlbmFtZTogICAgICBpcmlhcF9ldmVudC5jCiAqIFZlcnNpb246ICAgICAgIDAuMQogKiBEZXNjcmlwdGlvbjogICBJQVAgRmluaXRlIFN0YXRlIE1hY2hpbmUKICogU3RhdHVzOiAgICAgICAgRXhwZXJpbWVudGFsLgogKiBBdXRob3I6ICAgICAgICBEYWcgQnJhdHRsaSA8ZGFnYkBjcy51aXQubm8+CiAqIENyZWF0ZWQgYXQ6ICAgIFRodSBBdWcgMjEgMDA6MDI6MDcgMTk5NwogKiBNb2RpZmllZCBhdDogICBXZWQgTWFyICAxIDExOjI4OjM0IDIwMDAKICogTW9kaWZpZWQgYnk6ICAgRGFnIEJyYXR0bGkgPGRhZ2JAY3MudWl0Lm5vPgogKgogKiAgICAgQ29weXJpZ2h0IChjKSAxOTk3LCAxOTk5LTIwMDAgRGFnIEJyYXR0bGkgPGRhZ2JAY3MudWl0Lm5vPiwKICogICAgIEFsbCBSaWdodHMgUmVzZXJ2ZWQuCiAqICAgICBDb3B5cmlnaHQgKGMpIDIwMDAtMjAwMyBKZWFuIFRvdXJyaWxoZXMgPGp0QGhwbC5ocC5jb20+CiAqCiAqICAgICBUaGlzIHByb2dyYW0gaXMgZnJlZSBzb2Z0d2FyZTsgeW91IGNhbiByZWRpc3RyaWJ1dGUgaXQgYW5kL29yCiAqICAgICBtb2RpZnkgaXQgdW5kZXIgdGhlIHRlcm1zIG9mIHRoZSBHTlUgR2VuZXJhbCBQdWJsaWMgTGljZW5zZSBhcwogKiAgICAgcHVibGlzaGVkIGJ5IHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb247IGVpdGhlciB2ZXJzaW9uIDIgb2YKICogICAgIHRoZSBMaWNlbnNlLCBvciAoYXQgeW91ciBvcHRpb24pIGFueSBsYXRlciB2ZXJzaW9uLgogKgogKiAgICAgTmVpdGhlciBEYWcgQnJhdHRsaSBub3IgVW5pdmVyc2l0eSBvZiBUcm9tc/ggYWRtaXQgbGlhYmlsaXR5IG5vcgogKiAgICAgcHJvdmlkZSB3YXJyYW50eSBmb3IgYW55IG9mIHRoaXMgc29mdHdhcmUuIFRoaXMgbWF0ZXJpYWwgaXMKICogICAgIHByb3ZpZGVkICJBUy1JUyIgYW5kIGF0IG5vIGNoYXJnZS4KICoKICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqLwoKI2luY2x1ZGUgPG5ldC9pcmRhL2lyZGEuaD4KI2luY2x1ZGUgPG5ldC9pcmRhL2lybG1wLmg+CiNpbmNsdWRlIDxuZXQvaXJkYS9pcmlhcC5oPgojaW5jbHVkZSA8bmV0L2lyZGEvaXJpYXBfZXZlbnQuaD4KCnN0YXRpYyB2b2lkIHN0YXRlX3NfZGlzY29ubmVjdCAgIChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkJICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKTsKc3RhdGljIHZvaWQgc3RhdGVfc19jb25uZWN0aW5nICAgKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCQkgIHN0cnVjdCBza19idWZmICpza2IpOwpzdGF0aWMgdm9pZCBzdGF0ZV9zX2NhbGwgICAgICAgICAoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJCSAgc3RydWN0IHNrX2J1ZmYgKnNrYik7CgpzdGF0aWMgdm9pZCBzdGF0ZV9zX21ha2VfY2FsbCAgICAoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJCSAgc3RydWN0IHNrX2J1ZmYgKnNrYik7CnN0YXRpYyB2b2lkIHN0YXRlX3NfY2FsbGluZyAgICAgIChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkJICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKTsKc3RhdGljIHZvaWQgc3RhdGVfc19vdXRzdGFuZGluZyAgKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCQkgIHN0cnVjdCBza19idWZmICpza2IpOwpzdGF0aWMgdm9pZCBzdGF0ZV9zX3JlcGx5aW5nICAgICAoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJCSAgc3RydWN0IHNrX2J1ZmYgKnNrYik7CnN0YXRpYyB2b2lkIHN0YXRlX3Nfd2FpdF9mb3JfY2FsbChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkJICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKTsKc3RhdGljIHZvaWQgc3RhdGVfc193YWl0X2FjdGl2ZSAgKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCQkgIHN0cnVjdCBza19idWZmICpza2IpOwoKc3RhdGljIHZvaWQgc3RhdGVfcl9kaXNjb25uZWN0ICAgKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCQkgIHN0cnVjdCBza19idWZmICpza2IpOwpzdGF0aWMgdm9pZCBzdGF0ZV9yX2NhbGwgICAgICAgICAoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJCSAgc3RydWN0IHNrX2J1ZmYgKnNrYik7CnN0YXRpYyB2b2lkIHN0YXRlX3Jfd2FpdGluZyAgICAgIChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkJICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKTsKc3RhdGljIHZvaWQgc3RhdGVfcl93YWl0X2FjdGl2ZSAgKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCQkgIHN0cnVjdCBza19idWZmICpza2IpOwpzdGF0aWMgdm9pZCBzdGF0ZV9yX3JlY2VpdmluZyAgICAoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJCSAgc3RydWN0IHNrX2J1ZmYgKnNrYik7CnN0YXRpYyB2b2lkIHN0YXRlX3JfZXhlY3V0ZSAgICAgIChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkJICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKTsKc3RhdGljIHZvaWQgc3RhdGVfcl9yZXR1cm5pbmcgICAgKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCQkgIHN0cnVjdCBza19idWZmICpza2IpOwoKc3RhdGljIHZvaWQgKCppcmlhcF9zdGF0ZVtdKShzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkgICAgIHN0cnVjdCBza19idWZmICpza2IpID0gewoJLyogQ2xpZW50IEZTTSAqLwoJc3RhdGVfc19kaXNjb25uZWN0LAoJc3RhdGVfc19jb25uZWN0aW5nLAoJc3RhdGVfc19jYWxsLAoKCS8qIFMtQ2FsbCBGU00gKi8KCXN0YXRlX3NfbWFrZV9jYWxsLAoJc3RhdGVfc19jYWxsaW5nLAoJc3RhdGVfc19vdXRzdGFuZGluZywKCXN0YXRlX3NfcmVwbHlpbmcsCglzdGF0ZV9zX3dhaXRfZm9yX2NhbGwsCglzdGF0ZV9zX3dhaXRfYWN0aXZlLAoKCS8qIFNlcnZlciBGU00gKi8KCXN0YXRlX3JfZGlzY29ubmVjdCwKCXN0YXRlX3JfY2FsbCwKCgkvKiBSLUNvbm5lY3QgRlNNICovCglzdGF0ZV9yX3dhaXRpbmcsCglzdGF0ZV9yX3dhaXRfYWN0aXZlLAoJc3RhdGVfcl9yZWNlaXZpbmcsCglzdGF0ZV9yX2V4ZWN1dGUsCglzdGF0ZV9yX3JldHVybmluZywKfTsKCnZvaWQgaXJpYXBfbmV4dF9jbGllbnRfc3RhdGUoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9TVEFURSBzdGF0ZSkKewoJQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglBU1NFUlQoc2VsZi0+bWFnaWMgPT0gSUFTX01BR0lDLCByZXR1cm47KTsKCglzZWxmLT5jbGllbnRfc3RhdGUgPSBzdGF0ZTsKfQoKdm9pZCBpcmlhcF9uZXh0X2NhbGxfc3RhdGUoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9TVEFURSBzdGF0ZSkKewoJQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglBU1NFUlQoc2VsZi0+bWFnaWMgPT0gSUFTX01BR0lDLCByZXR1cm47KTsKCglzZWxmLT5jYWxsX3N0YXRlID0gc3RhdGU7Cn0KCnZvaWQgaXJpYXBfbmV4dF9zZXJ2ZXJfc3RhdGUoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9TVEFURSBzdGF0ZSkKewoJQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglBU1NFUlQoc2VsZi0+bWFnaWMgPT0gSUFTX01BR0lDLCByZXR1cm47KTsKCglzZWxmLT5zZXJ2ZXJfc3RhdGUgPSBzdGF0ZTsKfQoKdm9pZCBpcmlhcF9uZXh0X3JfY29ubmVjdF9zdGF0ZShzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX1NUQVRFIHN0YXRlKQp7CglBU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm47KTsKCUFTU0VSVChzZWxmLT5tYWdpYyA9PSBJQVNfTUFHSUMsIHJldHVybjspOwoKCXNlbGYtPnJfY29ubmVjdF9zdGF0ZSA9IHN0YXRlOwp9Cgp2b2lkIGlyaWFwX2RvX2NsaWVudF9ldmVudChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkgICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglBU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm47KTsKCUFTU0VSVChzZWxmLT5tYWdpYyA9PSBJQVNfTUFHSUMsIHJldHVybjspOwoKCSgqaXJpYXBfc3RhdGVbIHNlbGYtPmNsaWVudF9zdGF0ZV0pIChzZWxmLCBldmVudCwgc2tiKTsKfQoKdm9pZCBpcmlhcF9kb19jYWxsX2V2ZW50KHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCSBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglBU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm47KTsKCUFTU0VSVChzZWxmLT5tYWdpYyA9PSBJQVNfTUFHSUMsIHJldHVybjspOwoKCSgqaXJpYXBfc3RhdGVbIHNlbGYtPmNhbGxfc3RhdGVdKSAoc2VsZiwgZXZlbnQsIHNrYik7Cn0KCnZvaWQgaXJpYXBfZG9fc2VydmVyX2V2ZW50KHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCSAgIHN0cnVjdCBza19idWZmICpza2IpCnsKCUFTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybjspOwoJQVNTRVJUKHNlbGYtPm1hZ2ljID09IElBU19NQUdJQywgcmV0dXJuOyk7CgoJKCppcmlhcF9zdGF0ZVsgc2VsZi0+c2VydmVyX3N0YXRlXSkgKHNlbGYsIGV2ZW50LCBza2IpOwp9Cgp2b2lkIGlyaWFwX2RvX3JfY29ubmVjdF9ldmVudChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkgICAgICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglBU1NFUlQoc2VsZiAhPSBOVUxMLCByZXR1cm47KTsKCUFTU0VSVChzZWxmLT5tYWdpYyA9PSBJQVNfTUFHSUMsIHJldHVybjspOwoKCSgqaXJpYXBfc3RhdGVbIHNlbGYtPnJfY29ubmVjdF9zdGF0ZV0pIChzZWxmLCBldmVudCwgc2tiKTsKfQoKCi8qCiAqIEZ1bmN0aW9uIHN0YXRlX3NfZGlzY29ubmVjdCAoZXZlbnQsIHNrYikKICoKICogICAgUy1EaXNjb25uZWN0LCBUaGUgZGV2aWNlIGhhcyBubyBMU0FQIGNvbm5lY3Rpb24gdG8gYSBwYXJ0aWN1bGFyCiAqICAgIHJlbW90ZSBkZXZpY2UuCiAqLwpzdGF0aWMgdm9pZCBzdGF0ZV9zX2Rpc2Nvbm5lY3Qoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJICAgICAgIHN0cnVjdCBza19idWZmICpza2IpCnsKCUFTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybjspOwoJQVNTRVJUKHNlbGYtPm1hZ2ljID09IElBU19NQUdJQywgcmV0dXJuOyk7CgoJc3dpdGNoIChldmVudCkgewoJY2FzZSBJQVBfQ0FMTF9SRVFVRVNUX0dWQkM6CgkJaXJpYXBfbmV4dF9jbGllbnRfc3RhdGUoc2VsZiwgU19DT05ORUNUSU5HKTsKCQlBU1NFUlQoc2VsZi0+cmVxdWVzdF9za2IgPT0gTlVMTCwgcmV0dXJuOyk7CgkJLyogRG9uJ3QgZm9yZ2V0IHRvIHJlZmNvdW50IGl0IC0KCQkgKiBzZWUgaXJpYXBfZ2V0dmFsdWVieWNsYXNzX3JlcXVlc3QoKS4gKi8KCQlza2JfZ2V0KHNrYik7CgkJc2VsZi0+cmVxdWVzdF9za2IgPSBza2I7CgkJaXJpYXBfY29ubmVjdF9yZXF1ZXN0KHNlbGYpOwoJCWJyZWFrOwoJY2FzZSBJQVBfTE1fRElTQ09OTkVDVF9JTkRJQ0FUSU9OOgoJCWJyZWFrOwoJZGVmYXVsdDoKCQlJUkRBX0RFQlVHKDAsICIlcygpLCBVbmtub3duIGV2ZW50ICVkXG4iLCBfX0ZVTkNUSU9OX18sIGV2ZW50KTsKCQlicmVhazsKCX0KfQoKLyoKICogRnVuY3Rpb24gc3RhdGVfc19jb25uZWN0aW5nIChzZWxmLCBldmVudCwgc2tiKQogKgogKiAgICBTLUNvbm5lY3RpbmcKICoKICovCnN0YXRpYyB2b2lkIHN0YXRlX3NfY29ubmVjdGluZyhzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkgICAgICAgc3RydWN0IHNrX2J1ZmYgKnNrYikKewoJQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CglBU1NFUlQoc2VsZi0+bWFnaWMgPT0gSUFTX01BR0lDLCByZXR1cm47KTsKCglzd2l0Y2ggKGV2ZW50KSB7CgljYXNlIElBUF9MTV9DT05ORUNUX0NPTkZJUk06CgkJLyoKCQkgKiAgSnVtcCB0byBTLUNhbGwgRlNNCgkJICovCgkJaXJpYXBfZG9fY2FsbF9ldmVudChzZWxmLCBJQVBfQ0FMTF9SRVFVRVNULCBza2IpOwoJCS8qIGlyaWFwX2NhbGxfcmVxdWVzdChzZWxmLCAwLDAsMCk7ICovCgkJaXJpYXBfbmV4dF9jbGllbnRfc3RhdGUoc2VsZiwgU19DQUxMKTsKCQlicmVhazsKCWNhc2UgSUFQX0xNX0RJU0NPTk5FQ1RfSU5ESUNBVElPTjoKCQkvKiBBYm9ydCBjYWxscyAqLwoJCWlyaWFwX25leHRfY2FsbF9zdGF0ZShzZWxmLCBTX01BS0VfQ0FMTCk7CgkJaXJpYXBfbmV4dF9jbGllbnRfc3RhdGUoc2VsZiwgU19ESVNDT05ORUNUKTsKCQlicmVhazsKCWRlZmF1bHQ6CgkJSVJEQV9ERUJVRygwLCAiJXMoKSwgVW5rbm93biBldmVudCAlZFxuIiwgX19GVU5DVElPTl9fLCBldmVudCk7CgkJYnJlYWs7Cgl9Cn0KCi8qCiAqIEZ1bmN0aW9uIHN0YXRlX3NfY2FsbCAoc2VsZiwgZXZlbnQsIHNrYikKICoKICogICAgUy1DYWxsLCBUaGUgZGV2aWNlIGNhbiBwcm9jZXNzIGNhbGxzIHRvIGEgc3BlY2lmaWMgcmVtb3RlCiAqICAgIGRldmljZS4gV2hlbmV2ZXIgdGhlIExTQVAgY29ubmVjdGlvbiBpcyBkaXNjb25uZWN0ZWQsIHRoaXMgc3RhdGUKICogICAgY2F0Y2hlcyB0aGF0IGV2ZW50IGFuZCBjbGVhcnMgdXAKICovCnN0YXRpYyB2b2lkIHN0YXRlX3NfY2FsbChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkgc3RydWN0IHNrX2J1ZmYgKnNrYikKewoJQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CgoJc3dpdGNoIChldmVudCkgewoJY2FzZSBJQVBfTE1fRElTQ09OTkVDVF9JTkRJQ0FUSU9OOgoJCS8qIEFib3J0IGNhbGxzICovCgkJaXJpYXBfbmV4dF9jYWxsX3N0YXRlKHNlbGYsIFNfTUFLRV9DQUxMKTsKCQlpcmlhcF9uZXh0X2NsaWVudF9zdGF0ZShzZWxmLCBTX0RJU0NPTk5FQ1QpOwoJCWJyZWFrOwoJZGVmYXVsdDoKCQlJUkRBX0RFQlVHKDAsICJzdGF0ZV9zX2NhbGw6IFVua25vd24gZXZlbnQgJWRcbiIsIGV2ZW50KTsKCQlicmVhazsKCX0KfQoKLyoKICogRnVuY3Rpb24gc3RhdGVfc19tYWtlX2NhbGwgKGV2ZW50LCBza2IpCiAqCiAqICAgIFMtTWFrZS1DYWxsCiAqCiAqLwpzdGF0aWMgdm9pZCBzdGF0ZV9zX21ha2VfY2FsbChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkgICAgICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglzdHJ1Y3Qgc2tfYnVmZiAqdHhfc2tiOwoKCUFTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybjspOwoKCXN3aXRjaCAoZXZlbnQpIHsKCWNhc2UgSUFQX0NBTExfUkVRVUVTVDoKCQkvKiBBbHJlYWR5IHJlZmNvdW50ZWQgLSBzZWUgc3RhdGVfc19kaXNjb25uZWN0KCkgKi8KCQl0eF9za2IgPSBzZWxmLT5yZXF1ZXN0X3NrYjsKCQlzZWxmLT5yZXF1ZXN0X3NrYiA9IE5VTEw7CgoJCWlybG1wX2RhdGFfcmVxdWVzdChzZWxmLT5sc2FwLCB0eF9za2IpOwoJCWlyaWFwX25leHRfY2FsbF9zdGF0ZShzZWxmLCBTX09VVFNUQU5ESU5HKTsKCQlicmVhazsKCWRlZmF1bHQ6CgkJSVJEQV9ERUJVRygwLCAiJXMoKSwgVW5rbm93biBldmVudCAlZFxuIiwgX19GVU5DVElPTl9fLCBldmVudCk7CgkJYnJlYWs7Cgl9Cn0KCi8qCiAqIEZ1bmN0aW9uIHN0YXRlX3NfY2FsbGluZyAoZXZlbnQsIHNrYikKICoKICogICAgUy1DYWxsaW5nCiAqCiAqLwpzdGF0aWMgdm9pZCBzdGF0ZV9zX2NhbGxpbmcoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJICAgIHN0cnVjdCBza19idWZmICpza2IpCnsKCUlSREFfREVCVUcoMCwgIiVzKCksIE5vdCBpbXBsZW1lbnRlZFxuIiwgX19GVU5DVElPTl9fKTsKfQoKLyoKICogRnVuY3Rpb24gc3RhdGVfc19vdXRzdGFuZGluZyAoZXZlbnQsIHNrYikKICoKICogICAgUy1PdXRzdGFuZGluZywgVGhlIGRldmljZSBpcyB3YWl0aW5nIGZvciBhIHJlc3BvbnNlIHRvIGEgY29tbWFuZAogKgogKi8Kc3RhdGljIHZvaWQgc3RhdGVfc19vdXRzdGFuZGluZyhzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkJc3RydWN0IHNrX2J1ZmYgKnNrYikKewoJQVNTRVJUKHNlbGYgIT0gTlVMTCwgcmV0dXJuOyk7CgoJc3dpdGNoIChldmVudCkgewoJY2FzZSBJQVBfUkVDVl9GX0xTVDoKCQkvKmlyaWFwX3NlbmRfYWNrKHNlbGYpOyovCgkJLypMTV9JZGxlX3JlcXVlc3QoaWRsZSk7ICovCgoJCWlyaWFwX25leHRfY2FsbF9zdGF0ZShzZWxmLCBTX1dBSVRfRk9SX0NBTEwpOwoJCWJyZWFrOwoJZGVmYXVsdDoKCQlJUkRBX0RFQlVHKDAsICIlcygpLCBVbmtub3duIGV2ZW50ICVkXG4iLCBfX0ZVTkNUSU9OX18sIGV2ZW50KTsKCQlicmVhazsKCX0KfQoKLyoKICogRnVuY3Rpb24gc3RhdGVfc19yZXBseWluZyAoZXZlbnQsIHNrYikKICoKICogICAgUy1SZXBseWluZywgVGhlIGRldmljZSBpcyBjb2xsZWN0aW5nIGEgbXVsdGlwbGUgcGFydCByZXNwb25zZQogKi8Kc3RhdGljIHZvaWQgc3RhdGVfc19yZXBseWluZyhzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkgICAgIHN0cnVjdCBza19idWZmICpza2IpCnsKCUlSREFfREVCVUcoMCwgIiVzKCksIE5vdCBpbXBsZW1lbnRlZFxuIiwgX19GVU5DVElPTl9fKTsKfQoKLyoKICogRnVuY3Rpb24gc3RhdGVfc193YWl0X2Zvcl9jYWxsIChldmVudCwgc2tiKQogKgogKiAgICBTLVdhaXQtZm9yLUNhbGwKICoKICovCnN0YXRpYyB2b2lkIHN0YXRlX3Nfd2FpdF9mb3JfY2FsbChzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkJICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglJUkRBX0RFQlVHKDAsICIlcygpLCBOb3QgaW1wbGVtZW50ZWRcbiIsIF9fRlVOQ1RJT05fXyk7Cn0KCgovKgogKiBGdW5jdGlvbiBzdGF0ZV9zX3dhaXRfYWN0aXZlIChldmVudCwgc2tiKQogKgogKiAgICBTLVdhaXQtQWN0aXZlCiAqCiAqLwpzdGF0aWMgdm9pZCBzdGF0ZV9zX3dhaXRfYWN0aXZlKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCQlzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglJUkRBX0RFQlVHKDAsICIlcygpLCBOb3QgaW1wbGVtZW50ZWRcbiIsIF9fRlVOQ1RJT05fXyk7Cn0KCi8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKgogKgogKiAgU2VydmVyIEZTTQogKgogKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKiovCgovKgogKiBGdW5jdGlvbiBzdGF0ZV9yX2Rpc2Nvbm5lY3QgKHNlbGYsIGV2ZW50LCBza2IpCiAqCiAqICAgIExNLUlBUyBzZXJ2ZXIgaXMgZGlzY29ubmVjdGVkIChub3QgcHJvY2Vzc2luZyBhbnkgcmVxdWVzdHMhKQogKgogKi8Kc3RhdGljIHZvaWQgc3RhdGVfcl9kaXNjb25uZWN0KHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCSAgICAgICBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglzdHJ1Y3Qgc2tfYnVmZiAqdHhfc2tiOwoKCXN3aXRjaCAoZXZlbnQpIHsKCWNhc2UgSUFQX0xNX0NPTk5FQ1RfSU5ESUNBVElPTjoKCQl0eF9za2IgPSBkZXZfYWxsb2Nfc2tiKDY0KTsKCQlpZiAodHhfc2tiID09IE5VTEwpIHsKCQkJV0FSTklORygiJXM6IHVuYWJsZSB0byBtYWxsb2MhXG4iLCBfX0ZVTkNUSU9OX18pOwoJCQlyZXR1cm47CgkJfQoKCQkvKiBSZXNlcnZlIHNwYWNlIGZvciBNVVhfQ09OVFJPTCBhbmQgTEFQIGhlYWRlciAqLwoJCXNrYl9yZXNlcnZlKHR4X3NrYiwgTE1QX01BWF9IRUFERVIpOwoKCQlpcmxtcF9jb25uZWN0X3Jlc3BvbnNlKHNlbGYtPmxzYXAsIHR4X3NrYik7CgkJLypMTV9JZGxlX3JlcXVlc3QoaWRsZSk7ICovCgoJCWlyaWFwX25leHRfc2VydmVyX3N0YXRlKHNlbGYsIFJfQ0FMTCk7CgoJCS8qCgkJICogIEp1bXAgdG8gUi1Db25uZWN0IEZTTSwgd2Ugc2tpcCBSLVdhaXRpbmcgc2luY2Ugd2UgZG8gbm90CgkJICogIGNhcmUgYWJvdXQgTE1fSWRsZV9yZXF1ZXN0KCkhCgkJICovCgkJaXJpYXBfbmV4dF9yX2Nvbm5lY3Rfc3RhdGUoc2VsZiwgUl9SRUNFSVZJTkcpOwoJCWJyZWFrOwoJZGVmYXVsdDoKCQlJUkRBX0RFQlVHKDAsICIlcygpLCB1bmtub3duIGV2ZW50ICVkXG4iLCBfX0ZVTkNUSU9OX18sIGV2ZW50KTsKCQlicmVhazsKCX0KfQoKLyoKICogRnVuY3Rpb24gc3RhdGVfcl9jYWxsIChzZWxmLCBldmVudCwgc2tiKQogKi8Kc3RhdGljIHZvaWQgc3RhdGVfcl9jYWxsKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCSBzdHJ1Y3Qgc2tfYnVmZiAqc2tiKQp7CglJUkRBX0RFQlVHKDQsICIlcygpXG4iLCBfX0ZVTkNUSU9OX18pOwoKCXN3aXRjaCAoZXZlbnQpIHsKCWNhc2UgSUFQX0xNX0RJU0NPTk5FQ1RfSU5ESUNBVElPTjoKCQkvKiBBYm9ydCBjYWxsICovCgkJaXJpYXBfbmV4dF9zZXJ2ZXJfc3RhdGUoc2VsZiwgUl9ESVNDT05ORUNUKTsKCQlpcmlhcF9uZXh0X3JfY29ubmVjdF9zdGF0ZShzZWxmLCBSX1dBSVRJTkcpOwoJCWJyZWFrOwoJZGVmYXVsdDoKCQlJUkRBX0RFQlVHKDAsICIlcygpLCB1bmtub3duIGV2ZW50IVxuIiwgX19GVU5DVElPTl9fKTsKCQlicmVhazsKCX0KfQoKLyoKICogIFItQ29ubmVjdCBGU00KICovCgovKgogKiBGdW5jdGlvbiBzdGF0ZV9yX3dhaXRpbmcgKHNlbGYsIGV2ZW50LCBza2IpCiAqLwpzdGF0aWMgdm9pZCBzdGF0ZV9yX3dhaXRpbmcoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJICAgIHN0cnVjdCBza19idWZmICpza2IpCnsKCUlSREFfREVCVUcoMCwgIiVzKCksIE5vdCBpbXBsZW1lbnRlZFxuIiwgX19GVU5DVElPTl9fKTsKfQoKc3RhdGljIHZvaWQgc3RhdGVfcl93YWl0X2FjdGl2ZShzdHJ1Y3QgaXJpYXBfY2IgKnNlbGYsIElSSUFQX0VWRU5UIGV2ZW50LAoJCQkJc3RydWN0IHNrX2J1ZmYgKnNrYikKewoJSVJEQV9ERUJVRygwLCAiJXMoKSwgTm90IGltcGxlbWVudGVkXG4iLCBfX0ZVTkNUSU9OX18pOwp9CgovKgogKiBGdW5jdGlvbiBzdGF0ZV9yX3JlY2VpdmluZyAoc2VsZiwgZXZlbnQsIHNrYikKICoKICogICAgV2UgYXJlIHJlY2VpdmluZyBhIGNvbW1hbmQKICoKICovCnN0YXRpYyB2b2lkIHN0YXRlX3JfcmVjZWl2aW5nKHN0cnVjdCBpcmlhcF9jYiAqc2VsZiwgSVJJQVBfRVZFTlQgZXZlbnQsCgkJCSAgICAgIHN0cnVjdCBza19idWZmICpza2IpCnsKCUlSREFfREVCVUcoNCwgIiVzKClcbiIsIF9fRlVOQ1RJT05fXyk7CgoJc3dpdGNoIChldmVudCkgewoJY2FzZSBJQVBfUkVDVl9GX0xTVDoKCQlpcmlhcF9uZXh0X3JfY29ubmVjdF9zdGF0ZShzZWxmLCBSX0VYRUNVVEUpOwoKCQlpcmlhcF9jYWxsX2luZGljYXRpb24oc2VsZiwgc2tiKTsKCQlicmVhazsKCWRlZmF1bHQ6CgkJSVJEQV9ERUJVRygwLCAiJXMoKSwgdW5rbm93biBldmVudCFcbiIsIF9fRlVOQ1RJT05fXyk7CgkJYnJlYWs7Cgl9Cn0KCi8qCiAqIEZ1bmN0aW9uIHN0YXRlX3JfZXhlY3V0ZSAoc2VsZiwgZXZlbnQsIHNrYikKICoKICogICAgVGhlIHNlcnZlciBpcyBwcm9jZXNzaW5nIHRoZSByZXF1ZXN0CiAqCiAqLwpzdGF0aWMgdm9pZCBzdGF0ZV9yX2V4ZWN1dGUoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJICAgIHN0cnVjdCBza19idWZmICpza2IpCnsKCUlSREFfREVCVUcoNCwgIiVzKClcbiIsIF9fRlVOQ1RJT05fXyk7CgoJQVNTRVJUKHNrYiAhPSBOVUxMLCByZXR1cm47KTsKCUFTU0VSVChzZWxmICE9IE5VTEwsIHJldHVybjspOwoJQVNTRVJUKHNlbGYtPm1hZ2ljID09IElBU19NQUdJQywgcmV0dXJuOyk7CgoJc3dpdGNoIChldmVudCkgewoJY2FzZSBJQVBfQ0FMTF9SRVNQT05TRToKCQkvKgoJCSAqICBTaW5jZSB3ZSBkb24ndCBpbXBsZW1lbnQgdGhlIFdhaXRpbmcgc3RhdGUsIHdlIHJldHVybgoJCSAqICB0byBzdGF0ZSBSZWNlaXZpbmcgaW5zdGVhZCwgREIuCgkJICovCgkJaXJpYXBfbmV4dF9yX2Nvbm5lY3Rfc3RhdGUoc2VsZiwgUl9SRUNFSVZJTkcpOwoKCQkvKiBEb24ndCBmb3JnZXQgdG8gcmVmY291bnQgaXQgLSBzZWUKCQkgKiBpcmlhcF9nZXR2YWx1ZWJ5Y2xhc3NfcmVzcG9uc2UoKS4gKi8KCQlza2JfZ2V0KHNrYik7CgoJCWlybG1wX2RhdGFfcmVxdWVzdChzZWxmLT5sc2FwLCBza2IpOwoJCWJyZWFrOwoJZGVmYXVsdDoKCQlJUkRBX0RFQlVHKDAsICIlcygpLCB1bmtub3duIGV2ZW50IVxuIiwgX19GVU5DVElPTl9fKTsKCQlicmVhazsKCX0KfQoKc3RhdGljIHZvaWQgc3RhdGVfcl9yZXR1cm5pbmcoc3RydWN0IGlyaWFwX2NiICpzZWxmLCBJUklBUF9FVkVOVCBldmVudCwKCQkJICAgICAgc3RydWN0IHNrX2J1ZmYgKnNrYikKewoJSVJEQV9ERUJVRygwLCAiJXMoKSwgZXZlbnQ9JWRcbiIsIF9fRlVOQ1RJT05fXywgZXZlbnQpOwoKCXN3aXRjaCAoZXZlbnQpIHsKCWNhc2UgSUFQX1JFQ1ZfRl9MU1Q6CgkJYnJlYWs7CglkZWZhdWx0OgoJCWJyZWFrOwoJfQp9Cg==