From mboxrd@z Thu Jan 1 00:00:00 1970 From: YT Shen Subject: Re: [RFC v3 4/5] drm/mediatek: add support for Mediatek SoC MT2701 Date: Mon, 20 Jun 2016 16:53:48 +0800 Message-ID: <1466412828.14292.6.camel@mtksdaap41> References: <1465401825-43642-1-git-send-email-yt.shen@mediatek.com> <1465401825-43642-5-git-send-email-yt.shen@mediatek.com> <1465797366.27253.2.camel@mtksdaap41> Mime-Version: 1.0 Content-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Return-path: In-Reply-To: <1465797366.27253.2.camel@mtksdaap41> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: dri-devel-bounces@lists.freedesktop.org Sender: "dri-devel" To: CK Hu Cc: Mark Rutland , devicetree@vger.kernel.org, Russell King , Pawel Moll , Ian Campbell , emil.l.velikov@gmail.com, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Mao Huang , srv_heupstream@mediatek.com, Rob Herring , linux-mediatek@lists.infradead.org, Kumar Gala , Matthias Brugger , yingjoe.chen@mediatek.com, Sascha Hauer , linux-arm-kernel@lists.infradead.org List-Id: devicetree@vger.kernel.org SGkgQ0ssCgpUaGFua3MgZm9yIHlvdXIgY29tbWVudHMuCgpPbiBNb24sIDIwMTYtMDYtMTMgYXQg MTM6NTYgKzA4MDAsIENLIEh1IHdyb3RlOgo+IEhpLCBZVDoKPiAKPiBTb21lIGNvbW1lbnRzIGlu bGluZS4KPiAKPiBPbiBUaHUsIDIwMTYtMDYtMDkgYXQgMDA6MDMgKzA4MDAsIFlUIFNoZW4gd3Jv dGU6Cj4gPiBUaGlzIHBhdGNoIGFkZCBzdXBwb3J0IGZvciB0aGUgTWVkaWF0ZWsgTVQyNzAxIERJ U1Agc3Vic3lzdGVtLgo+ID4gVGhlcmUgaXMgb25seSBvbmUgT1ZMIGVuZ2luZSBpbiBNVDI3MDEu Cj4gPiAKPiA+IFNpZ25lZC1vZmYtYnk6IFlUIFNoZW4gPHl0LnNoZW5AbWVkaWF0ZWsuY29tPgo+ ID4gLS0tCj4gPiAgZHJpdmVycy9ncHUvZHJtL21lZGlhdGVrL210a19kaXNwX292bC5jICAgICB8 ICAgIDYgKysrKwo+ID4gIGRyaXZlcnMvZ3B1L2RybS9tZWRpYXRlay9tdGtfZGlzcF9yZG1hLmMg ICAgfCAgICA2ICsrKysKPiA+ICBkcml2ZXJzL2dwdS9kcm0vbWVkaWF0ZWsvbXRrX2RybV9kZHAu YyAgICAgIHwgICA0MiArKysrKysrKysrKysrKysrKysrKysrKysrKysKPiA+ICBkcml2ZXJzL2dw dS9kcm0vbWVkaWF0ZWsvbXRrX2RybV9kZHBfY29tcC5jIHwgICAgOCArKysrKwo+ID4gIGRyaXZl cnMvZ3B1L2RybS9tZWRpYXRlay9tdGtfZHJtX2RkcF9jb21wLmggfCAgICAyICsrCj4gPiAgZHJp dmVycy9ncHUvZHJtL21lZGlhdGVrL210a19kcm1fZHJ2LmMgICAgICB8ICAgMzEgKysrKysrKysr KysrKysrKysrKysKPiA+ICA2IGZpbGVzIGNoYW5nZWQsIDk1IGluc2VydGlvbnMoKykKPiA+IAo+ ID4gZGlmZiAtLWdpdCBhL2RyaXZlcnMvZ3B1L2RybS9tZWRpYXRlay9tdGtfZGlzcF9vdmwuYyBi L2RyaXZlcnMvZ3B1L2RybS9tZWRpYXRlay9tdGtfZGlzcF9vdmwuYwo+ID4gaW5kZXggZWI1YzA1 ZS4uMWRhMGE3MSAxMDA2NDQKPiA+IC0tLSBhL2RyaXZlcnMvZ3B1L2RybS9tZWRpYXRlay9tdGtf ZGlzcF9vdmwuYwo+ID4gKysrIGIvZHJpdmVycy9ncHUvZHJtL21lZGlhdGVrL210a19kaXNwX292 bC5jCj4gPiBAQCAtMjg2LDExICsyODYsMTcgQEAgc3RhdGljIGludCBtdGtfZGlzcF9vdmxfcmVt b3ZlKHN0cnVjdCBwbGF0Zm9ybV9kZXZpY2UgKnBkZXYpCj4gPiAgCXJldHVybiAwOwo+ID4gIH0K PiA+ICAKPiA+ICtzdGF0aWMgY29uc3Qgc3RydWN0IG10a19kZHBfY29tcF9kcml2ZXJfZGF0YSBt dDI3MDFfb3ZsX2RyaXZlcl9kYXRhID0gewo+ID4gKwkub3ZsID0gezB4MDA0MCwgMSA8PCAxMiwg MH0KPiA+ICt9Owo+ID4gKwo+ID4gIHN0YXRpYyBjb25zdCBzdHJ1Y3QgbXRrX2RkcF9jb21wX2Ry aXZlcl9kYXRhIG10ODE3M19vdmxfZHJpdmVyX2RhdGEgPSB7Cj4gPiAgCS5vdmwgPSB7MHgwZjQw LCAwLCAxIDw8IDEyfQo+ID4gIH07Cj4gPiAgCj4gPiAgc3RhdGljIGNvbnN0IHN0cnVjdCBvZl9k ZXZpY2VfaWQgbXRrX2Rpc3Bfb3ZsX2RyaXZlcl9kdF9tYXRjaFtdID0gewo+ID4gKwl7IC5jb21w YXRpYmxlID0gIm1lZGlhdGVrLG10MjcwMS1kaXNwLW92bCIsCj4gPiArCSAgLmRhdGEgPSAmbXQy NzAxX292bF9kcml2ZXJfZGF0YX0sCj4gPiAgCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQ4 MTczLWRpc3Atb3ZsIiwKPiA+ICAJICAuZGF0YSA9ICZtdDgxNzNfb3ZsX2RyaXZlcl9kYXRhfSwK PiA+ICAJe30sCj4gPiBkaWZmIC0tZ2l0IGEvZHJpdmVycy9ncHUvZHJtL21lZGlhdGVrL210a19k aXNwX3JkbWEuYyBiL2RyaXZlcnMvZ3B1L2RybS9tZWRpYXRlay9tdGtfZGlzcF9yZG1hLmMKPiA+ IGluZGV4IGZiMGRiNTAuLjUwNmEzNTMgMTAwNjQ0Cj4gPiAtLS0gYS9kcml2ZXJzL2dwdS9kcm0v bWVkaWF0ZWsvbXRrX2Rpc3BfcmRtYS5jCj4gPiArKysgYi9kcml2ZXJzL2dwdS9kcm0vbWVkaWF0 ZWsvbXRrX2Rpc3BfcmRtYS5jCj4gPiBAQCAtMjI1LDExICsyMjUsMTcgQEAgc3RhdGljIGludCBt dGtfZGlzcF9yZG1hX3JlbW92ZShzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2KQo+ID4gIAly ZXR1cm4gMDsKPiA+ICB9Cj4gPiAgCj4gPiArc3RhdGljIGNvbnN0IHN0cnVjdCBtdGtfZGRwX2Nv bXBfZHJpdmVyX2RhdGEgbXQyNzAxX3JkbWFfZHJpdmVyX2RhdGEgPSB7Cj4gPiArCS5yZG1hX2Zp Zm9fcHNldWRvX3NpemUgPSBTWl80SywKPiA+ICt9Owo+ID4gKwo+ID4gIHN0YXRpYyBjb25zdCBz dHJ1Y3QgbXRrX2RkcF9jb21wX2RyaXZlcl9kYXRhIG10ODE3M19yZG1hX2RyaXZlcl9kYXRhID0g ewo+ID4gIAkucmRtYV9maWZvX3BzZXVkb19zaXplID0gU1pfOEssCj4gPiAgfTsKPiA+ICAKPiA+ ICBzdGF0aWMgY29uc3Qgc3RydWN0IG9mX2RldmljZV9pZCBtdGtfZGlzcF9yZG1hX2RyaXZlcl9k dF9tYXRjaFtdID0gewo+ID4gKwl7IC5jb21wYXRpYmxlID0gIm1lZGlhdGVrLG10MjcwMS1kaXNw LXJkbWEiLAo+ID4gKwkgIC5kYXRhID0gJm10MjcwMV9yZG1hX2RyaXZlcl9kYXRhfSwKPiA+ICAJ eyAuY29tcGF0aWJsZSA9ICJtZWRpYXRlayxtdDgxNzMtZGlzcC1yZG1hIiwKPiA+ICAJICAuZGF0 YSA9ICZtdDgxNzNfcmRtYV9kcml2ZXJfZGF0YX0sCj4gPiAgCXt9LAo+ID4gZGlmZiAtLWdpdCBh L2RyaXZlcnMvZ3B1L2RybS9tZWRpYXRlay9tdGtfZHJtX2RkcC5jIGIvZHJpdmVycy9ncHUvZHJt L21lZGlhdGVrL210a19kcm1fZGRwLmMKPiA+IGluZGV4IGZhNTM4MDYuLjdhYjY5ODYgMTAwNjQ0 Cj4gPiAtLS0gYS9kcml2ZXJzL2dwdS9kcm0vbWVkaWF0ZWsvbXRrX2RybV9kZHAuYwo+ID4gKysr IGIvZHJpdmVycy9ncHUvZHJtL21lZGlhdGVrL210a19kcm1fZGRwLmMKPiA+IEBAIC0zMiw2ICsz MiwxMCBAQAo+ID4gICNkZWZpbmUgRElTUF9SRUdfQ09ORklHX0RJU1BfUkRNQTFfTU9VVF9FTgkw eDBjOAo+ID4gICNkZWZpbmUgRElTUF9SRUdfQ09ORklHX01NU1lTX0NHX0NPTjAJCTB4MTAwCj4g PiAgCj4gPiArI2RlZmluZSBESVNQX1JFR19DT05GSUdfRElTUF9PVkxfTU9VVF9FTgkweDAzMAo+ ID4gKyNkZWZpbmUgRElTUF9SRUdfQ09ORklHX09VVF9TRUwJCQkweDA0Ywo+ID4gKyNkZWZpbmUg RElTUF9SRUdfQ09ORklHX0RTSV9TRUwJCQkweDA1MAo+IAo+IEFsaWduIHRoZSBkaWdpdGFsIHZh bHVlLgpPSy4KPiAKPiA+ICsKPiA+ICAjZGVmaW5lIERJU1BfUkVHX01VVEVYX0VOKG4pCSgweDIw ICsgMHgyMCAqIChuKSkKPiA+ICAjZGVmaW5lIERJU1BfUkVHX01VVEVYKG4pCSgweDI0ICsgMHgy MCAqIChuKSkKPiA+ICAjZGVmaW5lIERJU1BfUkVHX01VVEVYX1JTVChuKQkoMHgyOCArIDB4MjAg KiAobikpCj4gPiBAQCAtNTQsNiArNTgsMTMgQEAKPiA+ICAjZGVmaW5lIE1UODE3M19NVVRFWF9N T0RfRElTUF9QV00xCQlCSVQoMjQpCj4gPiAgI2RlZmluZSBNVDgxNzNfTVVURVhfTU9EX0RJU1Bf T0QJCUJJVCgyNSkKPiA+ICAKPiA+ICsjZGVmaW5lIE1UMjcwMV9NVVRFWF9NT0RfRElTUF9PVkwJ CUJJVCgzKQo+ID4gKyNkZWZpbmUgTVQyNzAxX01VVEVYX01PRF9ESVNQX1dETUEJCUJJVCg2KQo+ ID4gKyNkZWZpbmUgTVQyNzAxX01VVEVYX01PRF9ESVNQX0NPTE9SCQlCSVQoNykKPiA+ICsjZGVm aW5lIE1UMjcwMV9NVVRFWF9NT0RfRElTUF9CTFMJCUJJVCg5KQo+ID4gKyNkZWZpbmUgTVQyNzAx X01VVEVYX01PRF9ESVNQX1JETUEwCQlCSVQoMTApCj4gPiArI2RlZmluZSBNVDI3MDFfTVVURVhf TU9EX0RJU1BfUkRNQTEJCUJJVCgxMikKPiA+ICsKPiA+ICAjZGVmaW5lIE1VVEVYX1NPRl9TSU5H TEVfTU9ERQkJMAo+ID4gICNkZWZpbmUgTVVURVhfU09GX0RTSTAJCQkxCj4gPiAgI2RlZmluZSBN VVRFWF9TT0ZfRFNJMQkJCTIKPiA+IEBAIC02OSw2ICs4MCwxMCBAQAo+ID4gICNkZWZpbmUgRFBJ MF9TRUxfSU5fUkRNQTEJCTB4MQo+ID4gICNkZWZpbmUgQ09MT1IxX1NFTF9JTl9PVkwxCQkweDEK PiA+ICAKPiA+ICsjZGVmaW5lIE9WTF9NT1VUX0VOX1JETUEJCTB4MQo+ID4gKyNkZWZpbmUgQkxT X1RPX0RTSV9SRE1BMV9UT19EUEkxCTB4OAo+ID4gKyNkZWZpbmUgRFNJX1NFTF9JTl9CTFMJCQkw eDAKPiA+ICsKPiA+ICBzdHJ1Y3QgbXRrX2Rpc3BfbXV0ZXggewo+ID4gIAlpbnQgaWQ7Cj4gPiAg CWJvb2wgY2xhaW1lZDsKPiA+IEBAIC04Miw2ICs5NywxNSBAQCBzdHJ1Y3QgbXRrX2RkcCB7Cj4g PiAgCWNvbnN0IHVuc2lnbmVkIGludAkJKm11dGV4X21vZDsKPiA+ICB9Owo+ID4gIAo+ID4gK3N0 YXRpYyBjb25zdCB1bnNpZ25lZCBpbnQgbXQyNzAxX211dGV4X21vZFtERFBfQ09NUE9ORU5UX0lE X01BWF0gPSB7Cj4gPiArCVtERFBfQ09NUE9ORU5UX0JMU10gPSBNVDI3MDFfTVVURVhfTU9EX0RJ U1BfQkxTLAo+ID4gKwlbRERQX0NPTVBPTkVOVF9DT0xPUjBdID0gTVQyNzAxX01VVEVYX01PRF9E SVNQX0NPTE9SLAo+ID4gKwlbRERQX0NPTVBPTkVOVF9PVkwwXSA9IE1UMjcwMV9NVVRFWF9NT0Rf RElTUF9PVkwsCj4gPiArCVtERFBfQ09NUE9ORU5UX1JETUEwXSA9IE1UMjcwMV9NVVRFWF9NT0Rf RElTUF9SRE1BMCwKPiA+ICsJW0REUF9DT01QT05FTlRfUkRNQTFdID0gTVQyNzAxX01VVEVYX01P RF9ESVNQX1JETUExLAo+ID4gKwlbRERQX0NPTVBPTkVOVF9XRE1BMF0gPSBNVDI3MDFfTVVURVhf TU9EX0RJU1BfV0RNQSwKPiA+ICt9Owo+ID4gKwo+ID4gIHN0YXRpYyBjb25zdCB1bnNpZ25lZCBp bnQgbXQ4MTczX211dGV4X21vZFtERFBfQ09NUE9ORU5UX0lEX01BWF0gPSB7Cj4gPiAgCVtERFBf Q09NUE9ORU5UX0FBTF0gPSBNVDgxNzNfTVVURVhfTU9EX0RJU1BfQUFMLAo+ID4gIAlbRERQX0NP TVBPTkVOVF9DT0xPUjBdID0gTVQ4MTczX01VVEVYX01PRF9ESVNQX0NPTE9SMCwKPiA+IEBAIC0x MDksNiArMTMzLDkgQEAgc3RhdGljIHVuc2lnbmVkIGludCBtdGtfZGRwX21vdXRfZW4oZW51bSBt dGtfZGRwX2NvbXBfaWQgY3VyLAo+ID4gIAlpZiAoY3VyID09IEREUF9DT01QT05FTlRfT1ZMMCAm JiBuZXh0ID09IEREUF9DT01QT05FTlRfQ09MT1IwKSB7Cj4gPiAgCQkqYWRkciA9IERJU1BfUkVH X0NPTkZJR19ESVNQX09WTDBfTU9VVF9FTjsKPiA+ICAJCXZhbHVlID0gT1ZMMF9NT1VUX0VOX0NP TE9SMDsKPiA+ICsJfSBlbHNlIGlmIChjdXIgPT0gRERQX0NPTVBPTkVOVF9PVkwwICYmIG5leHQg PT0gRERQX0NPTVBPTkVOVF9SRE1BMCkgewo+ID4gKwkJKmFkZHIgPSBESVNQX1JFR19DT05GSUdf RElTUF9PVkxfTU9VVF9FTjsKPiA+ICsJCXZhbHVlID0gT1ZMX01PVVRfRU5fUkRNQTsKPiA+ICAJ fSBlbHNlIGlmIChjdXIgPT0gRERQX0NPTVBPTkVOVF9PRCAmJiBuZXh0ID09IEREUF9DT01QT05F TlRfUkRNQTApIHsKPiA+ICAJCSphZGRyID0gRElTUF9SRUdfQ09ORklHX0RJU1BfT0RfTU9VVF9F TjsKPiA+ICAJCXZhbHVlID0gT0RfTU9VVF9FTl9SRE1BMDsKPiA+IEBAIC0xNDYsNiArMTczLDkg QEAgc3RhdGljIHVuc2lnbmVkIGludCBtdGtfZGRwX3NlbF9pbihlbnVtIG10a19kZHBfY29tcF9p ZCBjdXIsCj4gPiAgCX0gZWxzZSBpZiAoY3VyID09IEREUF9DT01QT05FTlRfT1ZMMSAmJiBuZXh0 ID09IEREUF9DT01QT05FTlRfQ09MT1IxKSB7Cj4gPiAgCQkqYWRkciA9IERJU1BfUkVHX0NPTkZJ R19ESVNQX0NPTE9SMV9TRUxfSU47Cj4gPiAgCQl2YWx1ZSA9IENPTE9SMV9TRUxfSU5fT1ZMMTsK PiA+ICsJfSBlbHNlIGlmIChjdXIgPT0gRERQX0NPTVBPTkVOVF9CTFMgJiYgbmV4dCA9PSBERFBf Q09NUE9ORU5UX0RTSTApIHsKPiA+ICsJCSphZGRyID0gRElTUF9SRUdfQ09ORklHX0RTSV9TRUw7 Cj4gPiArCQl2YWx1ZSA9IERTSV9TRUxfSU5fQkxTOwo+ID4gIAl9IGVsc2Ugewo+ID4gIAkJdmFs dWUgPSAwOwo+ID4gIAl9Cj4gPiBAQCAtMTUzLDYgKzE4MywxNSBAQCBzdGF0aWMgdW5zaWduZWQg aW50IG10a19kZHBfc2VsX2luKGVudW0gbXRrX2RkcF9jb21wX2lkIGN1ciwKPiA+ICAJcmV0dXJu IHZhbHVlOwo+ID4gIH0KPiA+ICAKPiA+ICtzdGF0aWMgdm9pZCBtdGtfZGRwX3NvdXRfc2VsKHZv aWQgX19pb21lbSAqY29uZmlnX3JlZ3MsCj4gPiArCQkJICAgIGVudW0gbXRrX2RkcF9jb21wX2lk IGN1ciwgZW51bSBtdGtfZGRwX2NvbXBfaWQgbmV4dCkKPiA+ICt7Cj4gPiArCWlmIChjdXIgPT0g RERQX0NPTVBPTkVOVF9CTFMgJiYgbmV4dCA9PSBERFBfQ09NUE9ORU5UX0RTSTApIHsKPiA+ICsJ CXdyaXRlbF9yZWxheGVkKEJMU19UT19EU0lfUkRNQTFfVE9fRFBJMSwKPiA+ICsJCQkgICAgICAg Y29uZmlnX3JlZ3MgKyBESVNQX1JFR19DT05GSUdfT1VUX1NFTCk7Cj4gPiArCX0KPiAKPiBSZWR1 bmRhbnQgcGFyZW50aGVzZXMuCk9LLCBJIHdpbGwgcmVtb3ZlIHRoZSByZWR1bmRhbnQuCj4gCj4g PiArfQo+ID4gKwo+ID4gIHZvaWQgbXRrX2RkcF9hZGRfY29tcF90b19wYXRoKHZvaWQgX19pb21l bSAqY29uZmlnX3JlZ3MsCj4gPiAgCQkJICAgICAgZW51bSBtdGtfZGRwX2NvbXBfaWQgY3VyLAo+ ID4gIAkJCSAgICAgIGVudW0gbXRrX2RkcF9jb21wX2lkIG5leHQpCj4gPiBAQCAtMTY1LDYgKzIw NCw4IEBAIHZvaWQgbXRrX2RkcF9hZGRfY29tcF90b19wYXRoKHZvaWQgX19pb21lbSAqY29uZmln X3JlZ3MsCj4gPiAgCQl3cml0ZWxfcmVsYXhlZChyZWcsIGNvbmZpZ19yZWdzICsgYWRkcik7Cj4g PiAgCX0KPiA+ICAKPiA+ICsJbXRrX2RkcF9zb3V0X3NlbChjb25maWdfcmVncywgY3VyLCBuZXh0 KTsKPiA+ICsKPiA+ICAJdmFsdWUgPSBtdGtfZGRwX3NlbF9pbihjdXIsIG5leHQsICZhZGRyKTsK PiA+ICAJaWYgKHZhbHVlKSB7Cj4gPiAgCQlyZWcgPSByZWFkbF9yZWxheGVkKGNvbmZpZ19yZWdz ICsgYWRkcikgfCB2YWx1ZTsKPiA+IEBAIC0zNjIsNiArNDAzLDcgQEAgc3RhdGljIGludCBtdGtf ZGRwX3JlbW92ZShzdHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2KQo+ID4gIH0KPiA+ICAKPiA+ ICBzdGF0aWMgY29uc3Qgc3RydWN0IG9mX2RldmljZV9pZCBkZHBfZHJpdmVyX2R0X21hdGNoW10g PSB7Cj4gPiArCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQyNzAxLWRpc3AtbXV0ZXgiLCAu ZGF0YSA9IG10MjcwMV9tdXRleF9tb2R9LAo+ID4gIAl7IC5jb21wYXRpYmxlID0gIm1lZGlhdGVr LG10ODE3My1kaXNwLW11dGV4IiwgLmRhdGEgPSBtdDgxNzNfbXV0ZXhfbW9kfSwKPiA+ICAJe30s Cj4gPiAgfTsKPiA+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vbWVkaWF0ZWsvbXRrX2Ry bV9kZHBfY29tcC5jIGIvZHJpdmVycy9ncHUvZHJtL21lZGlhdGVrL210a19kcm1fZGRwX2NvbXAu Ywo+ID4gaW5kZXggNGI0ZTQ0OS4uODdlMDQzNiAxMDA2NDQKPiA+IC0tLSBhL2RyaXZlcnMvZ3B1 L2RybS9tZWRpYXRlay9tdGtfZHJtX2RkcF9jb21wLmMKPiA+ICsrKyBiL2RyaXZlcnMvZ3B1L2Ry bS9tZWRpYXRlay9tdGtfZHJtX2RkcF9jb21wLmMKPiA+IEBAIC0xMDIsNiArMTAyLDcgQEAgc3Rh dGljIGNvbnN0IGNoYXIgKiBjb25zdCBtdGtfZGRwX2NvbXBfc3RlbVtNVEtfRERQX0NPTVBfVFlQ RV9NQVhdID0gewo+ID4gIAlbTVRLX0RJU1BfUFdNXSA9ICJwd20iLAo+ID4gIAlbTVRLX0RJU1Bf TVVURVhdID0gIm11dGV4IiwKPiA+ICAJW01US19ESVNQX09EXSA9ICJvZCIsCj4gPiArCVtNVEtf RElTUF9CTFNdID0gImJscyIsCj4gPiAgfTsKPiA+ICAKPiA+ICBzdHJ1Y3QgbXRrX2RkcF9jb21w X21hdGNoIHsKPiA+IEBAIC0xMTIsNiArMTEzLDcgQEAgc3RydWN0IG10a19kZHBfY29tcF9tYXRj aCB7Cj4gPiAgCj4gPiAgc3RhdGljIGNvbnN0IHN0cnVjdCBtdGtfZGRwX2NvbXBfbWF0Y2ggbXRr X2RkcF9tYXRjaGVzW0REUF9DT01QT05FTlRfSURfTUFYXSA9IHsKPiA+ICAJW0REUF9DT01QT05F TlRfQUFMXQk9IHsgTVRLX0RJU1BfQUFMLAkwLCBOVUxMIH0sCj4gPiArCVtERFBfQ09NUE9ORU5U X0JMU10JPSB7IE1US19ESVNQX0JMUywJMCwgTlVMTCB9LAo+ID4gIAlbRERQX0NPTVBPTkVOVF9D T0xPUjBdCT0geyBNVEtfRElTUF9DT0xPUiwJMCwgJmRkcF9jb2xvciB9LAo+ID4gIAlbRERQX0NP TVBPTkVOVF9DT0xPUjFdCT0geyBNVEtfRElTUF9DT0xPUiwJMSwgJmRkcF9jb2xvciB9LAo+ID4g IAlbRERQX0NPTVBPTkVOVF9EUEkwXQk9IHsgTVRLX0RQSSwJCTAsIE5VTEwgfSwKPiA+IEBAIC0x MzAsMTEgKzEzMiwxNyBAQCBzdGF0aWMgY29uc3Qgc3RydWN0IG10a19kZHBfY29tcF9tYXRjaCBt dGtfZGRwX21hdGNoZXNbRERQX0NPTVBPTkVOVF9JRF9NQVhdID0gewo+ID4gIAlbRERQX0NPTVBP TkVOVF9XRE1BMV0JPSB7IE1US19ESVNQX1dETUEsCTEsIE5VTEwgfSwKPiA+ICB9Owo+ID4gIAo+ ID4gK3N0YXRpYyBjb25zdCBzdHJ1Y3QgbXRrX2RkcF9jb21wX2RyaXZlcl9kYXRhIG10MjcwMV9j b2xvcl9kcml2ZXJfZGF0YSA9IHsKPiA+ICsJLmNvbG9yX29mZnNldCA9IDB4MGYwMCwKPiA+ICt9 Owo+ID4gKwo+ID4gIHN0YXRpYyBjb25zdCBzdHJ1Y3QgbXRrX2RkcF9jb21wX2RyaXZlcl9kYXRh IG10ODE3M19jb2xvcl9kcml2ZXJfZGF0YSA9IHsKPiA+ICAJLmNvbG9yX29mZnNldCA9IDB4MGMw MCwKPiA+ICB9Owo+ID4gIAo+ID4gIHN0YXRpYyBjb25zdCBzdHJ1Y3Qgb2ZfZGV2aWNlX2lkIG10 a19kaXNwX2NvbG9yX2RyaXZlcl9kdF9tYXRjaFtdID0gewo+ID4gKwl7IC5jb21wYXRpYmxlID0g Im1lZGlhdGVrLG10MjcwMS1kaXNwLWNvbG9yIiwKPiA+ICsJICAuZGF0YSA9ICZtdDI3MDFfY29s b3JfZHJpdmVyX2RhdGF9LAo+ID4gIAl7IC5jb21wYXRpYmxlID0gIm1lZGlhdGVrLG10ODE3My1k aXNwLWNvbG9yIiwKPiA+ICAJICAuZGF0YSA9ICZtdDgxNzNfY29sb3JfZHJpdmVyX2RhdGF9LAo+ ID4gIAl7fSwKPiA+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vbWVkaWF0ZWsvbXRrX2Ry bV9kZHBfY29tcC5oIGIvZHJpdmVycy9ncHUvZHJtL21lZGlhdGVrL210a19kcm1fZGRwX2NvbXAu aAo+ID4gaW5kZXggNTMwNjVjNy4uNmUyZDkxOCAxMDA2NDQKPiA+IC0tLSBhL2RyaXZlcnMvZ3B1 L2RybS9tZWRpYXRlay9tdGtfZHJtX2RkcF9jb21wLmgKPiA+ICsrKyBiL2RyaXZlcnMvZ3B1L2Ry bS9tZWRpYXRlay9tdGtfZHJtX2RkcF9jb21wLmgKPiA+IEBAIC0zNSw2ICszNSw3IEBAIGVudW0g bXRrX2RkcF9jb21wX3R5cGUgewo+ID4gIAlNVEtfRElTUF9QV00sCj4gPiAgCU1US19ESVNQX01V VEVYLAo+ID4gIAlNVEtfRElTUF9PRCwKPiA+ICsJTVRLX0RJU1BfQkxTLAo+ID4gIAlNVEtfRERQ X0NPTVBfVFlQRV9NQVgsCj4gPiAgfTsKPiA+ICAKPiA+IEBAIC01Nyw2ICs1OCw3IEBAIGVudW0g bXRrX2RkcF9jb21wX2lkIHsKPiA+ICAJRERQX0NPTVBPTkVOVF9VRk9FLAo+ID4gIAlERFBfQ09N UE9ORU5UX1dETUEwLAo+ID4gIAlERFBfQ09NUE9ORU5UX1dETUExLAo+ID4gKwlERFBfQ09NUE9O RU5UX0JMUywKPiA+ICAJRERQX0NPTVBPTkVOVF9JRF9NQVgsCj4gPiAgfTsKPiA+ICAKPiA+IGRp ZmYgLS1naXQgYS9kcml2ZXJzL2dwdS9kcm0vbWVkaWF0ZWsvbXRrX2RybV9kcnYuYyBiL2RyaXZl cnMvZ3B1L2RybS9tZWRpYXRlay9tdGtfZHJtX2Rydi5jCj4gPiBpbmRleCBlOWViNTM1Li5iNGI2 NmE3IDEwMDY0NAo+ID4gLS0tIGEvZHJpdmVycy9ncHUvZHJtL21lZGlhdGVrL210a19kcm1fZHJ2 LmMKPiA+ICsrKyBiL2RyaXZlcnMvZ3B1L2RybS9tZWRpYXRlay9tdGtfZHJtX2Rydi5jCj4gPiBA QCAtMTA5LDYgKzEwOSwxOSBAQCBzdGF0aWMgY29uc3Qgc3RydWN0IGRybV9tb2RlX2NvbmZpZ19m dW5jcyBtdGtfZHJtX21vZGVfY29uZmlnX2Z1bmNzID0gewo+ID4gIAkuYXRvbWljX2NvbW1pdCA9 IG10a19hdG9taWNfY29tbWl0LAo+ID4gIH07Cj4gPiAgCj4gPiArc3RhdGljIGNvbnN0IGVudW0g bXRrX2RkcF9jb21wX2lkIG10MjcwMV9tdGtfZGRwX21haW5bXSA9IHsKPiA+ICsJRERQX0NPTVBP TkVOVF9PVkwwLAo+ID4gKwlERFBfQ09NUE9ORU5UX1JETUEwLAo+ID4gKwlERFBfQ09NUE9ORU5U X0NPTE9SMCwKPiA+ICsJRERQX0NPTVBPTkVOVF9CTFMsCj4gPiArCUREUF9DT01QT05FTlRfRFNJ MCwKPiA+ICt9Owo+ID4gKwo+ID4gK3N0YXRpYyBjb25zdCBlbnVtIG10a19kZHBfY29tcF9pZCBt dDI3MDFfbXRrX2RkcF9leHRbXSA9IHsKPiA+ICsJRERQX0NPTVBPTkVOVF9SRE1BMSwKPiA+ICsJ RERQX0NPTVBPTkVOVF9EUEkwLAo+ID4gK307Cj4gPiArCj4gPiAgc3RhdGljIGNvbnN0IGVudW0g bXRrX2RkcF9jb21wX2lkIG10ODE3M19tdGtfZGRwX21haW5bXSA9IHsKPiA+ICAJRERQX0NPTVBP TkVOVF9PVkwwLAo+ID4gIAlERFBfQ09NUE9ORU5UX0NPTE9SMCwKPiA+IEBAIC0xMjgsNiArMTQx LDE0IEBAIHN0YXRpYyBjb25zdCBlbnVtIG10a19kZHBfY29tcF9pZCBtdDgxNzNfbXRrX2RkcF9l eHRbXSA9IHsKPiA+ICAJRERQX0NPTVBPTkVOVF9EUEkwLAo+ID4gIH07Cj4gPiAgCj4gPiArc3Rh dGljIGNvbnN0IHN0cnVjdCBtdGtfbW1zeXNfZHJpdmVyX2RhdGEgbXQyNzAxX21tc3lzX2RyaXZl cl9kYXRhID0gewo+ID4gKwkubWFpbl9wYXRoID0gbXQyNzAxX210a19kZHBfbWFpbiwKPiA+ICsJ Lm1haW5fbGVuID0gQVJSQVlfU0laRShtdDI3MDFfbXRrX2RkcF9tYWluKSwKPiA+ICsJLmV4dF9w YXRoID0gbXQyNzAxX210a19kZHBfZXh0LAo+ID4gKwkuZXh0X2xlbiA9IEFSUkFZX1NJWkUobXQy NzAxX210a19kZHBfZXh0KSwKPiA+ICsJLnNoYWRvd19yZWdpc3RlciA9IHRydWUsCj4gPiArfTsK PiA+ICsKPiA+ICBzdGF0aWMgY29uc3Qgc3RydWN0IG10a19tbXN5c19kcml2ZXJfZGF0YSBtdDgx NzNfbW1zeXNfZHJpdmVyX2RhdGEgPSB7Cj4gPiAgCS5tYWluX3BhdGggPSBtdDgxNzNfbXRrX2Rk cF9tYWluLAo+ID4gIAkubWFpbl9sZW4gPSBBUlJBWV9TSVpFKG10ODE3M19tdGtfZGRwX21haW4p LAo+ID4gQEAgLTMzMiwxOCArMzUzLDI2IEBAIHN0YXRpYyBjb25zdCBzdHJ1Y3QgY29tcG9uZW50 X21hc3Rlcl9vcHMgbXRrX2RybV9vcHMgPSB7Cj4gPiAgfTsKPiA+ICAKPiA+ICBzdGF0aWMgY29u c3Qgc3RydWN0IG9mX2RldmljZV9pZCBtdGtfZGRwX2NvbXBfZHRfaWRzW10gPSB7Cj4gPiArCXsg LmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQyNzAxLWRpc3Atb3ZsIiwgICAuZGF0YSA9ICh2b2lk ICopTVRLX0RJU1BfT1ZMIH0sCj4gPiAgCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQ4MTcz LWRpc3Atb3ZsIiwgICAuZGF0YSA9ICh2b2lkICopTVRLX0RJU1BfT1ZMIH0sCj4gPiArCXsgLmNv bXBhdGlibGUgPSAibWVkaWF0ZWssbXQyNzAxLWRpc3AtcmRtYSIsICAuZGF0YSA9ICh2b2lkICop TVRLX0RJU1BfUkRNQSB9LAo+ID4gIAl7IC5jb21wYXRpYmxlID0gIm1lZGlhdGVrLG10ODE3My1k aXNwLXJkbWEiLCAgLmRhdGEgPSAodm9pZCAqKU1US19ESVNQX1JETUEgfSwKPiA+ICsJeyAuY29t cGF0aWJsZSA9ICJtZWRpYXRlayxtdDI3MDEtZGlzcC13ZG1hIiwgIC5kYXRhID0gKHZvaWQgKilN VEtfRElTUF9XRE1BIH0sCj4gPiAgCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQ4MTczLWRp c3Atd2RtYSIsICAuZGF0YSA9ICh2b2lkICopTVRLX0RJU1BfV0RNQSB9LAo+ID4gKwl7IC5jb21w YXRpYmxlID0gIm1lZGlhdGVrLG10MjcwMS1kaXNwLWNvbG9yIiwgLmRhdGEgPSAodm9pZCAqKU1U S19ESVNQX0NPTE9SIH0sCj4gPiAgCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQ4MTczLWRp c3AtY29sb3IiLCAuZGF0YSA9ICh2b2lkICopTVRLX0RJU1BfQ09MT1IgfSwKPiA+ICAJeyAuY29t cGF0aWJsZSA9ICJtZWRpYXRlayxtdDgxNzMtZGlzcC1hYWwiLCAgIC5kYXRhID0gKHZvaWQgKilN VEtfRElTUF9BQUx9LAo+ID4gIAl7IC5jb21wYXRpYmxlID0gIm1lZGlhdGVrLG10ODE3My1kaXNw LWdhbW1hIiwgLmRhdGEgPSAodm9pZCAqKU1US19ESVNQX0dBTU1BLCB9LAo+ID4gIAl7IC5jb21w YXRpYmxlID0gIm1lZGlhdGVrLG10ODE3My1kaXNwLXVmb2UiLCAgLmRhdGEgPSAodm9pZCAqKU1U S19ESVNQX1VGT0UgfSwKPiA+ICsJeyAuY29tcGF0aWJsZSA9ICJtZWRpYXRlayxtdDI3MDEtZHNp IiwJICAgICAgLmRhdGEgPSAodm9pZCAqKU1US19EU0kgfSwKPiA+ICAJeyAuY29tcGF0aWJsZSA9 ICJtZWRpYXRlayxtdDgxNzMtZHNpIiwgICAgICAgIC5kYXRhID0gKHZvaWQgKilNVEtfRFNJIH0s Cj4gPiArCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQyNzAxLWRwaSIsCSAgICAgIC5kYXRh ID0gKHZvaWQgKilNVEtfRFBJIH0sCj4gPiAgCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQ4 MTczLWRwaSIsICAgICAgICAuZGF0YSA9ICh2b2lkICopTVRLX0RQSSB9LAo+ID4gKwl7IC5jb21w YXRpYmxlID0gIm1lZGlhdGVrLG10MjcwMS1kaXNwLW11dGV4IiwgLmRhdGEgPSAodm9pZCAqKU1U S19ESVNQX01VVEVYIH0sCj4gPiAgCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQ4MTczLWRp c3AtbXV0ZXgiLCAuZGF0YSA9ICh2b2lkICopTVRLX0RJU1BfTVVURVggfSwKPiA+ICAJeyAuY29t cGF0aWJsZSA9ICJtZWRpYXRlayxtdDgxNzMtZGlzcC1wd20iLCAgIC5kYXRhID0gKHZvaWQgKilN VEtfRElTUF9QV00gfSwKPiA+ICAJeyAuY29tcGF0aWJsZSA9ICJtZWRpYXRlayxtdDgxNzMtZGlz cC1vZCIsICAgIC5kYXRhID0gKHZvaWQgKilNVEtfRElTUF9PRCB9LAo+ID4gKwl7IC5jb21wYXRp YmxlID0gIm1lZGlhdGVrLG10MjcwMS1kaXNwLWJscyIsICAgLmRhdGEgPSAodm9pZCAqKU1US19E SVNQX0JMUyB9LAo+ID4gIAl7IH0KPiA+ICB9Owo+ID4gIAo+ID4gQEAgLTUxNSw2ICs1NDQsOCBA QCBzdGF0aWMgU0lNUExFX0RFVl9QTV9PUFMobXRrX2RybV9wbV9vcHMsIG10a19kcm1fc3lzX3N1 c3BlbmQsCj4gPiAgCQkJIG10a19kcm1fc3lzX3Jlc3VtZSk7Cj4gPiAgCj4gPiAgc3RhdGljIGNv bnN0IHN0cnVjdCBvZl9kZXZpY2VfaWQgbXRrX2RybV9vZl9pZHNbXSA9IHsKPiA+ICsJeyAuY29t cGF0aWJsZSA9ICJtZWRpYXRlayxtdDI3MDEtbW1zeXMiLAo+ID4gKwkgIC5kYXRhID0gJm10Mjcw MV9tbXN5c19kcml2ZXJfZGF0YX0sCj4gPiAgCXsgLmNvbXBhdGlibGUgPSAibWVkaWF0ZWssbXQ4 MTczLW1tc3lzIiwKPiA+ICAJICAuZGF0YSA9ICZtdDgxNzNfbW1zeXNfZHJpdmVyX2RhdGF9LAo+ ID4gIAl7IH0KPiAKPiBSZWdhcmRzLAo+IENLCj4gCgoKX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX18KZHJpLWRldmVsIG1haWxpbmcgbGlzdApkcmktZGV2ZWxA bGlzdHMuZnJlZWRlc2t0b3Aub3JnCmh0dHBzOi8vbGlzdHMuZnJlZWRlc2t0b3Aub3JnL21haWxt YW4vbGlzdGluZm8vZHJpLWRldmVsCg==