From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id C908CC197A0 for ; Mon, 20 Nov 2023 10:26:09 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:Content-Type: Content-Transfer-Encoding:List-Subscribe:List-Help:List-Post:List-Archive: List-Unsubscribe:List-Id:In-Reply-To:From:References:CC:To:Subject: MIME-Version:Date:Message-ID:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=jThXFcyPpAJOVl4fhA0JJqU97P+Bkl9N3plVXJyr2FE=; b=ssVV4gTENllLK1 ttUFMKoDT4thy9wkBSvYI6e+/msHthZAHauy6hAe5peI52zmUAaEudd/3fdoYNcSA3HiA4OMA9lG0 LdbiDg5uNijd9Pjyrq7BLPelqjHyu1A8w10rjMWxYUCV7Vo0yD5qptK6ftnW7OjLxTc9+aIg9SmIc qdAi/texzr6sVKEF5qiqzxLYaWRpIuMC6xNywot7ckLJex1qhjPCFy6OqeoXXg89nnfJzXS9ualgZ s6SdCB0vZHEwLPjZ2ZC7iafmljJgv9cbEeCdBkJF+Hm8bLD3Hnb761qFW20TUIUu767KxjqG9hRhU 8C3/IPTy+Azj5sVGZxQg==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.96 #2 (Red Hat Linux)) id 1r51TG-00Blkc-28; Mon, 20 Nov 2023 10:25:38 +0000 Received: from mx0a-0031df01.pphosted.com ([205.220.168.131]) by bombadil.infradead.org with esmtps (Exim 4.96 #2 (Red Hat Linux)) id 1r51T9-00BliH-0V for linux-arm-kernel@lists.infradead.org; Mon, 20 Nov 2023 10:25:36 +0000 Received: from pps.filterd (m0279866.ppops.net [127.0.0.1]) by mx0a-0031df01.pphosted.com (8.17.1.19/8.17.1.19) with ESMTP id 3AK55xPM024798; Mon, 20 Nov 2023 10:25:13 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=quicinc.com; h=message-id : date : mime-version : subject : to : cc : references : from : in-reply-to : content-type : content-transfer-encoding; s=qcppdkim1; bh=HARuH2/uywFft0s3b5vZDnvbX98avvpKAPa/J9pF1To=; b=aiHhMCy+MP/oLPFNtu9+mmoVBTo6YCXXwiQ41DhpeKLjvDSuvjJEiu1alWARN6yc2fnU cDY/HazMUcuzMMNZw+9D75AOSx0r/78ZRDS2pdf+OantOSL0KcDviTCWuLzOTe5c1JQs jyO8mxqT3jkWoVabitgxxbznCRu2FOOxoQY0vFrzS71wJIBwx+IED12CheEMbvEJvsKe v7PyaV26ZSW7Hqo7ooq57GOJrwTr1xtzGDs9W7BscQLFIgdcasOHlQFQ0zqFluBXoNrk bKiaVaNuMRgRh6nc8SFKzIlrW2WL46Twm2Ua1XQ0IaB7mKL+o3uDLrb2EQ4hDhUQRCl+ Kg== Received: from nalasppmta02.qualcomm.com (Global_NAT1.qualcomm.com [129.46.96.20]) by mx0a-0031df01.pphosted.com (PPS) with ESMTPS id 3uepjhkjvx-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 20 Nov 2023 10:25:13 +0000 Received: from nalasex01c.na.qualcomm.com (nalasex01c.na.qualcomm.com [10.47.97.35]) by NALASPPMTA02.qualcomm.com (8.17.1.5/8.17.1.5) with ESMTPS id 3AKAPCrO030524 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Mon, 20 Nov 2023 10:25:12 GMT Received: from [10.214.66.253] (10.80.80.8) by nalasex01c.na.qualcomm.com (10.47.97.35) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.2.1118.40; Mon, 20 Nov 2023 02:25:07 -0800 Message-ID: <350c2fbe-a04d-4bcb-a7a9-cf9ca34ba10b@quicinc.com> Date: Mon, 20 Nov 2023 15:54:59 +0530 MIME-Version: 1.0 User-Agent: Mozilla Thunderbird Subject: Re: [PATCH v2 1/3] iommu/arm-smmu: introduction of ACTLR for custom prefetcher settings Content-Language: en-US To: Robin Murphy , , , , , , , CC: , , , , References: <20231114135654.30475-1-quic_bibekkum@quicinc.com> <20231114135654.30475-2-quic_bibekkum@quicinc.com> <372885ab-b24d-44ae-afb8-76755bcd6e21@arm.com> <2a65a498-6a0f-445c-9c00-9e9e4fbc3a98@quicinc.com> <23944508-1054-4a31-b119-66f006cf10de@arm.com> From: Bibek Kumar Patro In-Reply-To: <23944508-1054-4a31-b119-66f006cf10de@arm.com> X-Originating-IP: [10.80.80.8] X-ClientProxiedBy: nasanex01b.na.qualcomm.com (10.46.141.250) To nalasex01c.na.qualcomm.com (10.47.97.35) X-QCInternal: smtphost X-Proofpoint-Virus-Version: vendor=nai engine=6200 definitions=5800 signatures=585085 X-Proofpoint-ORIG-GUID: DiKnjHq3dS0rSM4JfvEThUf_sXV90UNx X-Proofpoint-GUID: DiKnjHq3dS0rSM4JfvEThUf_sXV90UNx X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.272,Aquarius:18.0.987,Hydra:6.0.619,FMLib:17.11.176.26 definitions=2023-11-20_08,2023-11-20_01,2023-05-22_02 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 priorityscore=1501 bulkscore=0 mlxlogscore=999 clxscore=1015 suspectscore=0 impostorscore=0 adultscore=0 lowpriorityscore=0 spamscore=0 malwarescore=0 mlxscore=0 phishscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2311060000 definitions=main-2311200070 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20231120_022531_223122_43CC057F X-CRM114-Status: GOOD ( 38.57 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Transfer-Encoding: base64 Content-Type: text/plain; charset="utf-8"; Format="flowed" Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org CgpPbiAxMS8xNS8yMDIzIDg6MzQgUE0sIFJvYmluIE11cnBoeSB3cm90ZToKPiBPbiAyMDIzLTEx LTE1IDEyOjMyIHBtLCBCaWJlayBLdW1hciBQYXRybyB3cm90ZToKPj4KPj4KPj4gT24gMTEvMTQv MjAyMyAxMDoyNSBQTSwgUm9iaW4gTXVycGh5IHdyb3RlOgo+Pj4gT24gMTQvMTEvMjAyMyAxOjU2 IHBtLCBCaWJlayBLdW1hciBQYXRybyB3cm90ZToKPj4+PiBDdXJyZW50bHkgaW4gUXVhbGNvbW3C oCBTb0NzIHRoZSBkZWZhdWx0IHByZWZldGNoIGlzIHNldCB0byAxIHdoaWNoIAo+Pj4+IGFsbG93 cwo+Pj4+IHRoZSBUTEIgdG8gZmV0Y2gganVzdCB0aGUgbmV4dCBwYWdlIHRhYmxlLiBNTVUtNTAw IGZlYXR1cmVzIEFDVExSCj4+Pj4gcmVnaXN0ZXIgd2hpY2ggaXMgaW1wbGVtZW50YXRpb24gZGVm aW5lZCBhbmQgaXMgdXNlZCBmb3IgUXVhbGNvbW0gU29Dcwo+Pj4+IHRvIGhhdmUgYSBwcmVmZXRj aCBzZXR0aW5nIG9mIDEvMy83LzE1IGVuYWJsaW5nIFRMQiB0byBwcmVmZXRjaAo+Pj4+IHRoZSBu ZXh0IHNldCBvZiBwYWdlIHRhYmxlcyBhY2NvcmRpbmdseSBhbGxvd2luZyBmb3IgZmFzdGVyIAo+ Pj4+IHRyYW5zbGF0aW9ucy4KPj4+Pgo+Pj4+IEFDVExSIHZhbHVlIGlzIHVuaXF1ZSBmb3IgZWFj aCBTTVIgKFN0cmVhbSBtYXRjaGluZyByZWdpc3RlcikgYW5kIAo+Pj4+IHN0b3JlZAo+Pj4+IGlu IGEgcHJlLXBvcHVsYXRlZCB0YWJsZS4gVGhpcyB2YWx1ZSBpcyBzZXQgdG8gdGhlIHJlZ2lzdGVy IGR1cmluZwo+Pj4+IGNvbnRleHQgYmFuayBpbml0aWFsaXNhdGlvbi4KPj4+Pgo+Pj4+IFNpZ25l ZC1vZmYtYnk6IEJpYmVrIEt1bWFyIFBhdHJvIDxxdWljX2JpYmVra3VtQHF1aWNpbmMuY29tPgo+ Pj4+IC0tLQo+Pj4+IMKgIGRyaXZlcnMvaW9tbXUvYXJtL2FybS1zbW11L2FybS1zbW11LXFjb20u YyB8IDQxIAo+Pj4+ICsrKysrKysrKysrKysrKysrKysrKysKPj4+PiDCoCBkcml2ZXJzL2lvbW11 L2FybS9hcm0tc21tdS9hcm0tc21tdS1xY29tLmggfMKgIDIgKysKPj4+PiDCoCBkcml2ZXJzL2lv bW11L2FybS9hcm0tc21tdS9hcm0tc21tdS5jwqDCoMKgwqDCoCB8wqAgNSArLS0KPj4+PiDCoCBk cml2ZXJzL2lvbW11L2FybS9hcm0tc21tdS9hcm0tc21tdS5owqDCoMKgwqDCoCB8wqAgNSArKysK Pj4+PiDCoCA0IGZpbGVzIGNoYW5nZWQsIDUxIGluc2VydGlvbnMoKyksIDIgZGVsZXRpb25zKC0p Cj4+Pj4KPj4+PiBkaWZmIC0tZ2l0IGEvZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUvYXJtLXNt bXUtcWNvbS5jIAo+Pj4+IGIvZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUvYXJtLXNtbXUtcWNv bS5jCj4+Pj4gaW5kZXggNTQ5YWU0ZGJhM2E2Li41NzhjNjYyYzdjMzAgMTAwNjQ0Cj4+Pj4gLS0t IGEvZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUvYXJtLXNtbXUtcWNvbS5jCj4+Pj4gKysrIGIv ZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUvYXJtLXNtbXUtcWNvbS5jCj4+Pj4gQEAgLTE0LDYg KzE0LDE3IEBACj4+Pj4KPj4+PiDCoCAjZGVmaW5lIFFDT01fRFVNTVlfVkFMwqDCoMKgIC0xCj4+ Pj4KPj4+PiArc3RydWN0IGFjdGxyX2NvbmZpZyB7Cj4+Pj4gK8KgwqDCoCBjb25zdCBzdHJ1Y3Qg YWN0bHJfZGF0YSAqYWRhdGE7Cj4+Pj4gK8KgwqDCoCBzaXplX3Qgc2l6ZTsKPj4+PiArfTsKPj4+ PiArCj4+Pj4gK3N0cnVjdCBhY3Rscl9kYXRhIHsKPj4+PiArwqDCoMKgIHUxNiBzaWQ7Cj4+Pj4g K8KgwqDCoCB1MTYgbWFzazsKPj4+Cj4+PiBEbyB3ZSBuZWVkIHRvIHdvcnJ5IGFib3V0IG1hc2tz PyBJZiB5b3UncmUgYWxyZWFkeSBhc3N1bWluZyB0aGF0IGFueSAKPj4+IFNNUiB3aWxsIGJlIHBy b2dyYW1tZWQgdG8gbWF0Y2ggYSBzdXBlcnNldCBvZiB0aGUgZGF0YSBoZXJlLCBzdXJlbHkgYSAK Pj4+IHNpbmdsZSB1bmlxdWUgSUQgcGVyIGRldmljZSB3b3VsZCBzdWZmaWNlPwo+Pj4KClRoYW5r cyBmb3IgdGhpcyBjb21tZW50LiBJIHNlZSBub3csIG9ubHkgYXNzdW1pbmcgc21ycyBtaWdodCBu b3QgYmUgYWJsZQp0byBjb3JyZWN0bHkgc2V0IHRoZSBBQ1RMUiB2YWx1ZXMgZm9yIGFsbCB0aGUg Y29udGV4dCBiYW5rcyB3aXRob3V0IHRoZQppbmRleC4gaXQgc2hvdWxkIGJlIHNtciA9IHNtbXUt PnNtcnNbaWR4XSBpbnN0ZWFkIG9mIHNtciA9IHNtbXUtPnNtcnMKb3IgaXQgd2lsbCBiZSBjb25z aWRlcmluZyB0aGUgc2luZ2xlIFNNUiBmb3IgYWxsIHRoZSBhc3NvY2lhdGVkIGRldmljZXMuCgo+ Pgo+PiBJZiB5b3UgcmVmZXIgdG8gdGhlIGFybV9zbW11X3NldF9hY3RsciBiZWxvdywgbWFzayB3 b3VsZCBiZSBuZWVkZWQgYXMgCj4+IHdlIHdvdWxkIGNoZWNrIGZvciBtYXNrIGFsb25nIHdpdGgg c2lkIGFzIHdlbGwgd2hpbGUgYXNzaWduaW5nIGFjdGxyIAo+PiBjb25maWd1cmF0aW9uLiBBbHNv IHdpdGggbWFzayBubyBvZiBhY3RsciBlbnRyaWVzIGNhbiBiZSByZWR1Y2VzIGFzCj4+IHdpdGgg b3V0IG1hc2sgd2UgaGF2ZSB0byBoYXZlIGVudHJ5IGZvciBlYWNoIHNpZC4KPiAKPiBCdXQgd2h5 PyBBcyBmYXIgYXMgSSBjYW4gdGVsbCwgdGhlIGRlc2lnbiBpbiBwYXRjaCAjMiBpcyB0byBoYXZl IGEgCj4gc2luZ2xlIGRhdGEgZW50cnkgZm9yIGVhY2ggZGlzdGluY3QgZGV2aWNlLCBzaW5jZSB5 b3UncmUgZXhwZWN0aW5nIHRvIAo+IHNlZSBhIHNpbmdsZSBTTVIgcHJvZ3JhbW1lZCB0byBtYXRj aCBhdCBsZWFzdCB0aGUgZnVsbCBpZC9tYXNrIHJhbmdlIG9mIAo+IHRoZSBlbnRyeS4gSG93ZXZl ciBhbnkgU01SIHdoaWNoIG1hdGNoZXMgdGhhdCBmdWxsIHJhbmdlIHdpbGwgYnkgCj4gZGVmaW5p dGlvbiBhbHNvIG1hdGNoIGFueSBzbWFsbGVyIHN1YnNldCBvZiB0aGF0IHJhbmdlIGFzIHdlbGws IHNvIHdlIAo+IGNhbiB1bmlxdWVseSBpZGVudGlmeSBhbnkgZGV2aWNlIGluIHRoaXMgY29udGV4 dCBmcm9tIGp1c3QgYW55ICpvbmUqIG9mIAo+IGl0cyBJRHMsIHRodXMgd2UgY291bGQgc3RvcmUg bGVzcyBkYXRhIGFuZCBoYXZlIHNpbXBsZXIgbWF0Y2hpbmcgbG9naWMuCj4gCgpJIHdhcyBnb2lu ZyB0aG91Z2ggeW91ciBlYXJsaWVyIHJlcGx5IG9uY2UgYWdhaW4gYW5kIG5vdGljZWQgd2Ugd291 bGQKbmVlZCB0byBtZW50aW9uIHRoZSBjb250ZXh0IGJhbmsgaW5kZXggYWdhaW5zdCB0aGUgc21y IGFzIHdlbGwgdG8gdGFrZQp0aGUgcmlnaHQgQUNUTFIgdmFsdWUsIGFzIEkgcmVwbGllZCB0byB5 b3VyIGVhcmxpZXIgcmVzcG9uc2UgYWJvdmUuCgo+Pj4+ICvCoMKgwqAgdTMyIGFjdGxyOwo+Pj4+ ICt9Owo+Pj4+ICsKPj4+PiDCoCBzdGF0aWMgc3RydWN0IHFjb21fc21tdSAqdG9fcWNvbV9zbW11 KHN0cnVjdCBhcm1fc21tdV9kZXZpY2UgKnNtbXUpCj4+Pj4gwqAgewo+Pj4+IMKgwqDCoMKgwqAg cmV0dXJuIGNvbnRhaW5lcl9vZihzbW11LCBzdHJ1Y3QgcWNvbV9zbW11LCBzbW11KTsKPj4+PiBA QCAtMjYxLDkgKzI3MiwzNiBAQCBzdGF0aWMgY29uc3Qgc3RydWN0IG9mX2RldmljZV9pZCAKPj4+ PiBxY29tX3NtbXVfY2xpZW50X29mX21hdGNoW10gX19tYXliZV91bnVzZWQgPSB7Cj4+Pj4gwqDC oMKgwqDCoCB7IH0KPj4+PiDCoCB9Owo+Pj4+Cj4+Pj4gK3N0YXRpYyB2b2lkIGFybV9zbW11X3Nl dF9hY3RscihzdHJ1Y3QgYXJtX3NtbXVfZGV2aWNlICpzbW11LCBpbnQgaWR4LAo+Pj4+ICvCoMKg wqDCoMKgwqDCoCBjb25zdCBzdHJ1Y3QgYWN0bHJfY29uZmlnICphY3RscmNmZykKPj4+PiArewo+ Pj4+ICvCoMKgwqAgc3RydWN0IGFybV9zbW11X3NtciAqc21yID0gc21tdS0+c21yczsKCkl0IHdv dWxkIGJlIHNtciA9IHNtbXUtPnNtcnNbaWR4XSBpbnN0ZWFkIG9mIHNtciA9IHNtbXUtPnNtcnMg dG8gZ2V0CnNpZCBvZiBpbmRpdmlkdWFsIGRldmljZSBhdHRhY2hlZCB0byBjb3JyZXNwb25kaW5n IGNvbnRleHQgYmFuay4KCj4+Pj4gK8KgwqDCoCBpbnQgaTsKPj4+PiArwqDCoMKgIHUxNiBpZDsK Pj4+PiArwqDCoMKgIHUxNiBtYXNrOwo+Pj4+ICsKPj4+PiArwqDCoMKgIGZvciAoaSA9IDA7IGkg PCBhY3RscmNmZy0+c2l6ZTsgKytpKSB7Cj4+Pj4gK8KgwqDCoMKgwqDCoMKgIGlkID0gYWN0bHJj ZmctPmFkYXRhW2ldLnNpZDsKPj4+PiArwqDCoMKgwqDCoMKgwqAgbWFzayA9IGFjdGxyY2ZnLT5h ZGF0YVtpXS5tYXNrOwo+Pj4+ICvCoMKgwqDCoMKgwqDCoCBpZiAoIXNtcl9pc19zdWJzZXQoKnNt ciwgaWQsIG1hc2spKQo+Pj4KPj4+IEhvdyB3ZWxsIGhhdmUgeW91IHRlc3RlZCB0aGlzPyA7KQo+ Pj4KPj4KPj4gV2VsbCwgdGhpcyBsb2dpYyBoYXMgd29ya2VkIHByZXR0eSBnb29kIGZvciB1cyB0 aWxsIG5vdyBpbiBvdXIKPj4gZG93bnN0cmVhbSBpbXBsZW1lbnRhdGlvbi4gOikgKER1cmluZyB0 ZXN0aW5nIGFzIHdlbGwgdGhpcyBsb2dpYyAKPj4gaGVscGVkIHRvIGJldHRlciBtYXRjaCB0aGUg U01ScyBpbnN0ZWFkIG9mIG1hbnVhbGx5IG1hdGhjaW5nIHRoZSBtYXNrIAo+PiBhbmQgU0lEIHdo aWNoIG1pc3NlZCBzb21lIFNJRHMpCj4+IEFsc28gdGhpcyBpcyBhbHJlYWR5IGJlaW5nIHVzZWQg dG8gYXJtX3NtbXVfZmluZF9zbWUgaGVuY2UgcGFja2FnZWQgdGhpcwo+PiBsb2dpYyBpbiBhIHdy YXBwZXIgdG8gYmUgdXNlZCBpbiBvdGhlciBwbGFjZXMgYXMgd2VsbChpbmNsdWRpbmcgQUNUTFIK Pj4gcmVnaXN0ZXIgc2V0dGluZyBjYXNlIGhlcmUuKQo+IAo+IDEpIExvb2sgYXQgd2hhdCB5b3Un cmUgbWF0Y2hpbmcgdGhlIGlkIGFuZCBtYXNrIHZhbHVlcyAqYWdhaW5zdCoKPiAKCkdvdCB0aGlz IG5vdy4gV2lsbCB0YWtlIGNhcmUgb2YgdGhpcyBpbiBuZXh0IHZlcnNpb24uCgo+IDIpIExvb2sg YXQgdGhlIHBvbGFyaXR5IG9mIHRoZSBjb25kaXRpb24KPiAKPiAzKSBDb25zaWRlciB0aGUgb2xk IHNheWluZyAidHdvIHdyb25ncyBkb24ndCBtYWtlIGEgcmlnaHQiCj4gCgpOb3RlZC4KCj4+Pj4g K8KgwqDCoMKgwqDCoMKgwqDCoMKgwqAgYXJtX3NtbXVfY2Jfd3JpdGUoc21tdSwgaWR4LCBBUk1f U01NVV9DQl9BQ1RMUiwKPj4+PiArwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoMKg wqAgYWN0bHJjZmctPmFkYXRhW2ldLmFjdGxyKTsKPj4+PiArwqDCoMKgIH0KPj4+PiArfQo+Pj4+ ICsKPj4+PiDCoCBzdGF0aWMgaW50IHFjb21fc21tdV9pbml0X2NvbnRleHQoc3RydWN0IGFybV9z bW11X2RvbWFpbiAKPj4+PiAqc21tdV9kb21haW4sCj4+Pj4gwqDCoMKgwqDCoMKgwqDCoMKgIHN0 cnVjdCBpb19wZ3RhYmxlX2NmZyAqcGd0YmxfY2ZnLCBzdHJ1Y3QgZGV2aWNlICpkZXYpCj4+Pj4g wqAgewo+Pj4+ICvCoMKgwqAgc3RydWN0IGFybV9zbW11X2RldmljZSAqc21tdSA9IHNtbXVfZG9t YWluLT5zbW11Owo+Pj4+ICvCoMKgwqAgc3RydWN0IHFjb21fc21tdSAqcXNtbXUgPSB0b19xY29t X3NtbXUoc21tdSk7Cj4+Pj4gK8KgwqDCoCBjb25zdCBzdHJ1Y3QgYWN0bHJfY29uZmlnICphY3Rs cmNmZzsKPj4+PiArwqDCoMKgIGludCBpZHggPSBzbW11X2RvbWFpbi0+Y2ZnLmNibmR4Owo+Pj4+ ICsKPj4+PiArwqDCoMKgIGlmIChxc21tdS0+YWN0bHJjZmcpIHsKPj4+PiArwqDCoMKgwqDCoMKg wqAgYWN0bHJjZmcgPSBxc21tdS0+YWN0bHJjZmc7Cj4+Pj4gK8KgwqDCoMKgwqDCoMKgIGFybV9z bW11X3NldF9hY3RscihzbW11LCBpZHgsIGFjdGxyY2ZnKTsKPj4+PiArwqDCoMKgIH0KPj4+PiAr Cj4+Pj4gwqDCoMKgwqDCoCBzbW11X2RvbWFpbi0+Y2ZnLmZsdXNoX3dhbGtfcHJlZmVyX3RsYmlh c2lkID0gdHJ1ZTsKPj4+Pgo+Pj4+IMKgwqDCoMKgwqAgcmV0dXJuIDA7Cj4+Pj4gQEAgLTQ2Nyw2 ICs1MDUsOSBAQCBzdGF0aWMgc3RydWN0IGFybV9zbW11X2RldmljZSAKPj4+PiAqcWNvbV9zbW11 X2NyZWF0ZShzdHJ1Y3QgYXJtX3NtbXVfZGV2aWNlICpzbW11LAo+Pj4+IMKgwqDCoMKgwqAgcXNt bXUtPnNtbXUuaW1wbCA9IGltcGw7Cj4+Pj4gwqDCoMKgwqDCoCBxc21tdS0+Y2ZnID0gZGF0YS0+ Y2ZnOwo+Pj4+Cj4+Pj4gK8KgwqDCoCBpZiAoZGF0YS0+YWN0bHJjZmcgJiYgKGRhdGEtPmFjdGxy Y2ZnLT5zaXplKSkKPj4+PiArwqDCoMKgwqDCoMKgwqAgcXNtbXUtPmFjdGxyY2ZnID0gZGF0YS0+ YWN0bHJjZmc7Cj4+Pgo+Pj4gRG8gd2UgcmVhbGx5IG5lZWQgdG8gcmVwbGljYXRlIG11bHRpcGxl IHBhcnRzIG9mIHRoZSBkYXRhLCBvciB3b3VsZCAKPj4+IGl0IGJlIHNlbnNpYmxlIHRvIGp1c3Qg cmVwbGFjZSBxc21tdS0+Y2ZnIHdpdGggcXNtbXUtPmRhdGEgYW5kIGhhbmRsZSAKPj4+IHRoZSBm dXJ0aGVyIGRlcmVmZXJlbmNlcyBpbiB0aGUgcGxhY2VzIHRoYXQgd2FudCB0aGVtPwo+Pj4KPj4+ PiArCj4+Pj4gwqDCoMKgwqDCoCByZXR1cm4gJnFzbW11LT5zbW11Owo+Pj4+IMKgIH0KPj4+Pgo+ Pj4+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2lvbW11L2FybS9hcm0tc21tdS9hcm0tc21tdS1xY29t LmggCj4+Pj4gYi9kcml2ZXJzL2lvbW11L2FybS9hcm0tc21tdS9hcm0tc21tdS1xY29tLmgKPj4+ PiBpbmRleCA1OTM5MTA1NjdiODguLjRiNjg2MjcxNTA3MCAxMDA2NDQKPj4+PiAtLS0gYS9kcml2 ZXJzL2lvbW11L2FybS9hcm0tc21tdS9hcm0tc21tdS1xY29tLmgKPj4+PiArKysgYi9kcml2ZXJz L2lvbW11L2FybS9hcm0tc21tdS9hcm0tc21tdS1xY29tLmgKPj4+PiBAQCAtOSw2ICs5LDcgQEAK Pj4+PiDCoCBzdHJ1Y3QgcWNvbV9zbW11IHsKPj4+PiDCoMKgwqDCoMKgIHN0cnVjdCBhcm1fc21t dV9kZXZpY2Ugc21tdTsKPj4+PiDCoMKgwqDCoMKgIGNvbnN0IHN0cnVjdCBxY29tX3NtbXVfY29u ZmlnICpjZmc7Cj4+Pj4gK8KgwqDCoCBjb25zdCBzdHJ1Y3QgYWN0bHJfY29uZmlnICphY3RscmNm ZzsKPj4+PiDCoMKgwqDCoMKgIGJvb2wgYnlwYXNzX3F1aXJrOwo+Pj4+IMKgwqDCoMKgwqAgdTgg YnlwYXNzX2NibmR4Owo+Pj4+IMKgwqDCoMKgwqAgdTMyIHN0YWxsX2VuYWJsZWQ7Cj4+Pj4gQEAg LTI1LDYgKzI2LDcgQEAgc3RydWN0IHFjb21fc21tdV9jb25maWcgewo+Pj4+IMKgIH07Cj4+Pj4K Pj4+PiDCoCBzdHJ1Y3QgcWNvbV9zbW11X21hdGNoX2RhdGEgewo+Pj4+ICvCoMKgwqAgY29uc3Qg c3RydWN0IGFjdGxyX2NvbmZpZyAqYWN0bHJjZmc7Cj4+Pj4gwqDCoMKgwqDCoCBjb25zdCBzdHJ1 Y3QgcWNvbV9zbW11X2NvbmZpZyAqY2ZnOwo+Pj4+IMKgwqDCoMKgwqAgY29uc3Qgc3RydWN0IGFy bV9zbW11X2ltcGwgKmltcGw7Cj4+Pj4gwqDCoMKgwqDCoCBjb25zdCBzdHJ1Y3QgYXJtX3NtbXVf aW1wbCAqYWRyZW5vX2ltcGw7Cj4+Pj4gZGlmZiAtLWdpdCBhL2RyaXZlcnMvaW9tbXUvYXJtL2Fy bS1zbW11L2FybS1zbW11LmMgCj4+Pj4gYi9kcml2ZXJzL2lvbW11L2FybS9hcm0tc21tdS9hcm0t c21tdS5jCj4+Pj4gaW5kZXggZDZkMWEyYTU1Y2MwLi44ZTRmYWYwMTUyODYgMTAwNjQ0Cj4+Pj4g LS0tIGEvZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUvYXJtLXNtbXUuYwo+Pj4+ICsrKyBiL2Ry aXZlcnMvaW9tbXUvYXJtL2FybS1zbW11L2FybS1zbW11LmMKPj4+PiBAQCAtOTkwLDkgKzk5MCwx MCBAQCBzdGF0aWMgaW50IGFybV9zbW11X2ZpbmRfc21lKHN0cnVjdCAKPj4+PiBhcm1fc21tdV9k ZXZpY2UgKnNtbXUsIHUxNiBpZCwgdTE2IG1hc2spCj4+Pj4gwqDCoMKgwqDCoMKgwqDCoMKgwqAg KiBleHBlY3Qgc2ltcGx5IGlkZW50aWNhbCBlbnRyaWVzIGZvciB0aGlzIGNhc2UsIGJ1dCB0aGVy ZSdzCj4+Pj4gwqDCoMKgwqDCoMKgwqDCoMKgwqAgKiBubyBoYXJtIGluIGFjY29tbW9kYXRpbmcg dGhlIGdlbmVyYWxpc2F0aW9uLgo+Pj4+IMKgwqDCoMKgwqDCoMKgwqDCoMKgICovCj4+Pj4gLcKg wqDCoMKgwqDCoMKgIGlmICgobWFzayAmIHNtcnNbaV0ubWFzaykgPT0gbWFzayAmJgo+Pj4+IC3C oMKgwqDCoMKgwqDCoMKgwqDCoMKgICEoKGlkIF4gc21yc1tpXS5pZCkgJiB+c21yc1tpXS5tYXNr KSkKPj4+PiArCj4+Pj4gK8KgwqDCoMKgwqDCoMKgIGlmIChzbXJfaXNfc3Vic2V0KHNtcnNbaV0s IGlkLCBtYXNrKSkKPj4+PiDCoMKgwqDCoMKgwqDCoMKgwqDCoMKgwqDCoCByZXR1cm4gaTsKPj4+ PiArCj4+Pj4gwqDCoMKgwqDCoMKgwqDCoMKgIC8qCj4+Pj4gwqDCoMKgwqDCoMKgwqDCoMKgwqAg KiBJZiB0aGUgbmV3IGVudHJ5IGhhcyBhbnkgb3RoZXIgb3ZlcmxhcCB3aXRoIGFuIGV4aXN0aW5n IAo+Pj4+IG9uZSwKPj4+PiDCoMKgwqDCoMKgwqDCoMKgwqDCoCAqIHRob3VnaCwgdGhlbiB0aGVy ZSBhbHdheXMgZXhpc3RzIGF0IGxlYXN0IG9uZSBzdHJlYW0gSUQKPj4+PiBkaWZmIC0tZ2l0IGEv ZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUvYXJtLXNtbXUuaCAKPj4+PiBiL2RyaXZlcnMvaW9t bXUvYXJtL2FybS1zbW11L2FybS1zbW11LmgKPj4+PiBpbmRleCA3MDNmZDU4MTdlYzEuLmIxNjM4 YmJjNDFkNCAxMDA2NDQKPj4+PiAtLS0gYS9kcml2ZXJzL2lvbW11L2FybS9hcm0tc21tdS9hcm0t c21tdS5oCj4+Pj4gKysrIGIvZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUvYXJtLXNtbXUuaAo+ Pj4+IEBAIC01MDEsNiArNTAxLDExIEBAIHN0YXRpYyBpbmxpbmUgdm9pZCBhcm1fc21tdV93cml0 ZXEoc3RydWN0IAo+Pj4+IGFybV9zbW11X2RldmljZSAqc21tdSwgaW50IHBhZ2UsCj4+Pj4gwqDC oMKgwqDCoMKgwqDCoMKgIHdyaXRlcV9yZWxheGVkKHZhbCwgYXJtX3NtbXVfcGFnZShzbW11LCBw YWdlKSArIG9mZnNldCk7Cj4+Pj4gwqAgfQo+Pj4+Cj4+Pj4gK3N0YXRpYyBpbmxpbmUgYm9vbCBz bXJfaXNfc3Vic2V0KHN0cnVjdCBhcm1fc21tdV9zbXIgc21ycywgdTE2IGlkLCAKPj4+PiB1MTYg bWFzaykKPj4+Cj4+PiBIbW0sIHRoYXQgbmFtZSByZWFkcyBhcyBpbXBseWluZyB0aGUgb3Bwb3Np dGUgb2Ygd2hhdCBpdCBhY3R1YWxseSAKPj4+IHRlc3RzLCBub3QgdG8gbWVudGlvbiB0aGF0IHBh c3Npbmcgc3RydWN0cyBieSB2YWx1ZSBpcyBhIGJpdCBob3JyaWQgCj4+PiBhcyB3ZWxsIDooCj4+ Pgo+Pgo+PiBJdCBtaWdodCBiZSBva2F5IHRvIG5hbWUgaXQgYXMgc3Vic2V0X29mX3NtcigpIHRo b3VnaC4gWW91IGhhdmUgYW55IAo+PiBvdGhlciBuYW1pbmcgc3VnZ2VzdGlvbiBpbiBtaW5kIHdo aWNoIGNvdWxkIGNvcnJlY3RseSBkZXNjcmliZSB0aGUKPj4gbG9naWM/Cj4gCj4gQXMgYWJvdmUg SSB0aGluayB0aGUgaWRlYWwgYW5zd2VyIGlzIHRvIGF2b2lkIHRoZSByZWFzb24gZm9yIGZhY3Rv cmluZyAKPiBpdCBvdXQgYXQgYWxsLCBieSB1c2luZyBhIHNpbXBsZXIgbWF0Y2hpbmcgcHJvY2Vz cyB0byBiZWdpbiB3aXRoLgo+CgpBcyBwZXIgdGhlIGFwcHJvYWNoIG1lbnRpb25lZCBhYm92ZSB0 byB1c2UgdGhlIGNvbnRleHQgYmFuayBpbmRleCwKdGhpcyBzYW1lIGFwcHJvYWNoIHNob3VsZCBi ZSBva2F5IHRvIGdvIGZvcndhcmQgd2l0aC4KClRoYW5rcyBSb2JpbiBmb3IgeW91IGFib3ZlIGNv bW1lbnRzLCBJIGhhdmUgbm90ZWQgdGhlIGlucHV0cyBhbmQgd2lsbAp0YWtlIGNhcmUgb2YgdGhp cyBpbiBuZXh0IHZlcnNpb24uCgpUaGFua3MgJiByZWdhcmRzLApCaWJlawoKPiBUaGFua3MsCj4g Um9iaW4uCgpfX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fXwps aW51eC1hcm0ta2VybmVsIG1haWxpbmcgbGlzdApsaW51eC1hcm0ta2VybmVsQGxpc3RzLmluZnJh ZGVhZC5vcmcKaHR0cDovL2xpc3RzLmluZnJhZGVhZC5vcmcvbWFpbG1hbi9saXN0aW5mby9saW51 eC1hcm0ta2VybmVsCg==