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 6DDD4C47DB3 for ; Wed, 31 Jan 2024 14:40:58 +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-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:Cc:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=yx2LoIREiRXyrZxhDTvavrerYNRL97ZhBoNf0neVmcc=; b=1HemM1DD7DaOgz TFtfdNMCEQ/WIwNCzdm++qeP+lfJcj1nW00J0ecpzhx9zh7kYpXlKo19atN88csJ8jpoodqdXj+8M FjnZaSLS21XG0kOrebZLoYs+tSGiE9gts9Bj3vdft1S39jmfOUUiCE+UlsKmMNMFYzL8bQf9xwHPA A/H0yiesfaYffqJHy0zm9cC9CtHYWy6onIsI8L2G+xXd0MVyxGPwMCp0Dz5WKe0OJ7u3yjbc8jOkY 5/9ZbeCsulE4ohnbSyzuvg1ijGWJyFSv8fhE6Nus12JD9Qv1L6c16TrMS2V0yQNnQXdli4RAbIZDu gLZVVGtGmqcrRp2k8qnQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.97.1 #2 (Red Hat Linux)) id 1rVBld-00000003x1A-1F6K; Wed, 31 Jan 2024 14:40:45 +0000 Received: from mail-wm1-x32b.google.com ([2a00:1450:4864:20::32b]) by bombadil.infradead.org with esmtps (Exim 4.97.1 #2 (Red Hat Linux)) id 1rVBlP-00000003wqq-1DOS for linux-arm-kernel@lists.infradead.org; Wed, 31 Jan 2024 14:40:32 +0000 Received: by mail-wm1-x32b.google.com with SMTP id 5b1f17b1804b1-40f0218476aso41255e9.1 for ; Wed, 31 Jan 2024 06:40:29 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20230601; t=1706712028; x=1707316828; darn=lists.infradead.org; h=in-reply-to:content-transfer-encoding:content-disposition :mime-version:references:message-id:subject:cc:to:from:date:from:to :cc:subject:date:message-id:reply-to; bh=Atx/A/Kd3wBowOOB5SPB5s3413xE127qaDJyNH22uRE=; b=VqRc7InACwL2g27q6ExqL7dBInjTXyq0VP2SMZFaQhixfLRJqZxqn/9uVOMlnVB6oa 90cgUdpdJnHnRSov5GSsPQ00RR5tI1vDvTyL4yORKHRRKnr+RBXrCQZFgJrRzgLEfwN4 LvL+MUF3htANSgvMvNcauWbupaonNEvBiwXSnCFdb6M7jWqLds0306vcQdMfij6cmAYd 9LhCNIyVlz0cpFiAeWaOuIwnIq4/Jxzv6vK0eoXuRVjzQBq3OAdz1cQK3+RkU8fVSg3a dIwR84eYcaRIXKSDU/DSvZW/EXZrgbI80kglViZmh39NEXhfsmNUFvH5B8OPjch2pVtB n0Cg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1706712028; x=1707316828; h=in-reply-to:content-transfer-encoding:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :x-gm-message-state:from:to:cc:subject:date:message-id:reply-to; bh=Atx/A/Kd3wBowOOB5SPB5s3413xE127qaDJyNH22uRE=; b=R1TwtbP6y3qkFl9O5iOVX/f+HZQf0IN4r3SjN/Os7vJzFkG6k7RbiYSgjTRSq439xU A8IvYWrSzgXMERFC+NY3iYB6V8OB34Pp7KvHaRgNyCAGVR+9lpewbzdkfH1zXm7UkVTf jVgIyHxZj/2QAbdB+yVhmTfCY7ObDjHt5d8D/mkD5H3EgWJ/WCCHCCcJH1RJ9ppd0Fho UPCTFK+bPdRczfvkrkD7Xfi+r/zYWMBxXwmu54zQMJK7jTRX+Vkxl4lNgPRz5W7/MVQq 9TR9R63/JVEtKPBgkicVcgR8acUpEq0wN8dt6y8fe0TxX03bCryJquqyE7a1HlSD/vYi NXeQ== X-Gm-Message-State: AOJu0YydXzgGJFRhmHFHtZG9p8KDp51t8Oo7sojKJhci73+iomgTAi/N 1HhXDEtRXJ8R5b25b6MoyLbt23gvzAJShMtcxfxy7rE8XDBtfh5moY/v562jLg== X-Google-Smtp-Source: AGHT+IFGRt09c6PIlbuscZsW9acxH4MnSEQpbtHlnr1JNGy8lWeZDj43fMMk3YtpQqNOOURR2IHc5Q== X-Received: by 2002:a05:600c:1d87:b0:40f:b527:8bac with SMTP id p7-20020a05600c1d8700b0040fb5278bacmr89654wms.6.1706712028512; Wed, 31 Jan 2024 06:40:28 -0800 (PST) X-Forwarded-Encrypted: i=0; AJvYcCWQVE9hQOeqiOMK6vLLmfMU/tchY9ZDvRnuK3KoaYw9q1E6Ggp1DCZRXFnNf7ZrLg9HOjy7TYJhths1jd2JwKjdkxsiOHPzmNrQoJSpJx/u96KBSF+5ur9oMD9RG2M9nZlyPUcf3Px0pQQE5NIlB4NgafdhYD3xUn+d44xTncbMAMHgNj0bZMUu+zdy+ucy1DdzGFlmpiOEQx5CTH53RHFA1EhIJPhiRa3uI4e2Vr0drAYOenTjoeGzXrvGUBq9g85BL2wC5yei2mJRZ+/I8uHntm4+jqIoYERNjBUlienCAVUZfCa95u73N5/2iGQckyK4dvXSFLI648BVxzYQpqKNmcy8PbpMqHRXXhiomEmpLqLtJigtr02r Received: from google.com (185.83.140.34.bc.googleusercontent.com. [34.140.83.185]) by smtp.gmail.com with ESMTPSA id bq28-20020a5d5a1c000000b0033af3ef600asm6983955wrb.86.2024.01.31.06.40.28 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Wed, 31 Jan 2024 06:40:28 -0800 (PST) Date: Wed, 31 Jan 2024 14:40:24 +0000 From: Mostafa Saleh To: Jason Gunthorpe Cc: iommu@lists.linux.dev, Joerg Roedel , linux-arm-kernel@lists.infradead.org, Robin Murphy , Will Deacon , Moritz Fischer , Moritz Fischer , Michael Shavit , Nicolin Chen , patches@lists.linux.dev, Shameer Kolothum Subject: Re: [PATCH v4 02/16] iommu/arm-smmu-v3: Consolidate the STE generation for abort/bypass Message-ID: References: <0-v4-c93b774edcc4+42d2b-smmuv3_newapi_p1_jgg@nvidia.com> <2-v4-c93b774edcc4+42d2b-smmuv3_newapi_p1_jgg@nvidia.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <2-v4-c93b774edcc4+42d2b-smmuv3_newapi_p1_jgg@nvidia.com> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20240131_064031_404794_FE4D8C31 X-CRM114-Status: GOOD ( 29.16 ) 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-Type: text/plain; charset="utf-8" Content-Transfer-Encoding: base64 Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org SGkgSmFzb24sCgpPbiBUaHUsIEphbiAyNSwgMjAyNCBhdCAwNzo1NzoxMlBNIC0wNDAwLCBKYXNv biBHdW50aG9ycGUgd3JvdGU6Cj4gVGhpcyBhbGxvd3Mgd3JpdGluZyB0aGUgZmxvdyBvZiBhcm1f c21tdV93cml0ZV9zdHJ0YWJfZW50KCkgYXJvdW5kIGFib3J0Cj4gYW5kIGJ5cGFzcyBkb21haW5z IG1vcmUgbmF0dXJhbGx5Lgo+IAo+IE5vdGUgdGhhdCB0aGUgY29yZSBjb2RlIG5vIGxvbmdlciBz dXBwbGllcyBOVUxMIGRvbWFpbnMsIHRob3VnaCB0aGVyZSBpcwo+IHN0aWxsIGEgZmxvdyBpbiB0 aGUgZHJpdmVyIHRoYXQgZW5kIHVwIGluIGFybV9zbW11X3dyaXRlX3N0cnRhYl9lbnQoKSB3aXRo Cj4gTlVMTC4gQSBsYXRlciBwYXRjaCB3aWxsIHJlbW92ZSBpdC4KPiAKPiBSZW1vdmUgdGhlIGR1 cGxpY2F0ZSBjYWxjdWxhdGlvbiBvZiB0aGUgU1RFIGluIGFybV9zbW11X2luaXRfYnlwYXNzX3N0 ZXMoKQo+IGFuZCByZW1vdmUgdGhlIGZvcmNlIHBhcmFtZXRlci4gYXJtX3NtbXVfcm1yX2luc3Rh bGxfYnlwYXNzX3N0ZSgpIGNhbiBub3cKPiBzaW1wbHkgaW52b2tlIGFybV9zbW11X21ha2VfYnlw YXNzX3N0ZSgpIGRpcmVjdGx5Lgo+IAo+IFJldmlld2VkLWJ5OiBNaWNoYWVsIFNoYXZpdCA8bXNo YXZpdEBnb29nbGUuY29tPgo+IFJldmlld2VkLWJ5OiBOaWNvbGluIENoZW4gPG5pY29saW5jQG52 aWRpYS5jb20+Cj4gVGVzdGVkLWJ5OiBTaGFtZWVyIEtvbG90aHVtIDxzaGFtZWVyYWxpLmtvbG90 aHVtLnRob2RpQGh1YXdlaS5jb20+Cj4gVGVzdGVkLWJ5OiBOaWNvbGluIENoZW4gPG5pY29saW5j QG52aWRpYS5jb20+Cj4gVGVzdGVkLWJ5OiBNb3JpdHogRmlzY2hlciA8bW9yaXR6ZkBnb29nbGUu Y29tPgo+IFNpZ25lZC1vZmYtYnk6IEphc29uIEd1bnRob3JwZSA8amdnQG52aWRpYS5jb20+Cj4g LS0tCj4gIGRyaXZlcnMvaW9tbXUvYXJtL2FybS1zbW11LXYzL2FybS1zbW11LXYzLmMgfCA4OSAr KysrKysrKysrKy0tLS0tLS0tLS0KPiAgMSBmaWxlIGNoYW5nZWQsIDQ3IGluc2VydGlvbnMoKyks IDQyIGRlbGV0aW9ucygtKQo+IAo+IGRpZmYgLS1naXQgYS9kcml2ZXJzL2lvbW11L2FybS9hcm0t c21tdS12My9hcm0tc21tdS12My5jIGIvZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUtdjMvYXJt LXNtbXUtdjMuYwo+IGluZGV4IDY5MDc0MmU4ZjE3M2ViLi4zOGJjYjRlZDFmY2NjMSAxMDA2NDQK PiAtLS0gYS9kcml2ZXJzL2lvbW11L2FybS9hcm0tc21tdS12My9hcm0tc21tdS12My5jCj4gKysr IGIvZHJpdmVycy9pb21tdS9hcm0vYXJtLXNtbXUtdjMvYXJtLXNtbXUtdjMuYwo+IEBAIC0xNDk2 LDYgKzE0OTYsMjQgQEAgc3RhdGljIHZvaWQgYXJtX3NtbXVfd3JpdGVfc3RlKHN0cnVjdCBhcm1f c21tdV9tYXN0ZXIgKm1hc3RlciwgdTMyIHNpZCwKPiAgCX0KPiAgfQo+ICAKPiArc3RhdGljIHZv aWQgYXJtX3NtbXVfbWFrZV9hYm9ydF9zdGUoc3RydWN0IGFybV9zbW11X3N0ZSAqdGFyZ2V0KQo+ ICt7Cj4gKwltZW1zZXQodGFyZ2V0LCAwLCBzaXplb2YoKnRhcmdldCkpOwo+ICsJdGFyZ2V0LT5k YXRhWzBdID0gY3B1X3RvX2xlNjQoCj4gKwkJU1RSVEFCX1NURV8wX1YgfAo+ICsJCUZJRUxEX1BS RVAoU1RSVEFCX1NURV8wX0NGRywgU1RSVEFCX1NURV8wX0NGR19BQk9SVCkpOwo+ICt9Cj4gKwo+ ICtzdGF0aWMgdm9pZCBhcm1fc21tdV9tYWtlX2J5cGFzc19zdGUoc3RydWN0IGFybV9zbW11X3N0 ZSAqdGFyZ2V0KQo+ICt7Cj4gKwltZW1zZXQodGFyZ2V0LCAwLCBzaXplb2YoKnRhcmdldCkpOwoK SSBzZWUgdGhpcyBjYW4gYmUgdXNlZCB3aXRoIHRoZSBhY3R1YWwgU1RFLiBBbHRob3VnaCB0aGlz IGlzIGRvbmUgYXQgaW5pdCwgYnV0CmJyaWVmbHkgbWFraW5nIHRoZSBTVEUgYWJvcnQgZnJvbSDi gJxhcm1fc21tdV9tYWtlX2J5cGFzc19zdGXigJ0sIHNlZW1zIGEgYml0CmZyYWdpbGUgdG8gbWUs IGluIGNhc2Ugd2UgdXNlIHRoaXMgaW4gdGhlIGZ1dHVyZSBpbiBkaWZmZXJlbnQgc2NlbmFyaW9z LCBpdAptaWdodCBicmVhayB0aGUgaGl0bGVzcyBhc3N1bXB0aW9uLiBCdXQgbm8gc3Ryb25nIG9w aW5pb24gdGhvdWdoLgoKPiArCXRhcmdldC0+ZGF0YVswXSA9IGNwdV90b19sZTY0KAo+ICsJCVNU UlRBQl9TVEVfMF9WIHwKPiArCQlGSUVMRF9QUkVQKFNUUlRBQl9TVEVfMF9DRkcsIFNUUlRBQl9T VEVfMF9DRkdfQllQQVNTKSk7Cj4gKwl0YXJnZXQtPmRhdGFbMV0gPSBjcHVfdG9fbGU2NCgKPiAr CQlGSUVMRF9QUkVQKFNUUlRBQl9TVEVfMV9TSENGRywgU1RSVEFCX1NURV8xX1NIQ0ZHX0lOQ09N SU5HKSk7Cj4gK30KPiArCj4gIHN0YXRpYyB2b2lkIGFybV9zbW11X3dyaXRlX3N0cnRhYl9lbnQo c3RydWN0IGFybV9zbW11X21hc3RlciAqbWFzdGVyLCB1MzIgc2lkLAo+ICAJCQkJICAgICAgc3Ry dWN0IGFybV9zbW11X3N0ZSAqZHN0KQo+ICB7Cj4gQEAgLTE1MDYsMzcgKzE1MjQsMzEgQEAgc3Rh dGljIHZvaWQgYXJtX3NtbXVfd3JpdGVfc3RydGFiX2VudChzdHJ1Y3QgYXJtX3NtbXVfbWFzdGVy ICptYXN0ZXIsIHUzMiBzaWQsCj4gIAlzdHJ1Y3QgYXJtX3NtbXVfZG9tYWluICpzbW11X2RvbWFp biA9IG1hc3Rlci0+ZG9tYWluOwo+ICAJc3RydWN0IGFybV9zbW11X3N0ZSB0YXJnZXQgPSB7fTsK PiAgCj4gLQlpZiAoc21tdV9kb21haW4pIHsKPiAtCQlzd2l0Y2ggKHNtbXVfZG9tYWluLT5zdGFn ZSkgewo+IC0JCWNhc2UgQVJNX1NNTVVfRE9NQUlOX1MxOgo+IC0JCQljZF90YWJsZSA9ICZtYXN0 ZXItPmNkX3RhYmxlOwo+IC0JCQlicmVhazsKPiAtCQljYXNlIEFSTV9TTU1VX0RPTUFJTl9TMjoK PiAtCQkJczJfY2ZnID0gJnNtbXVfZG9tYWluLT5zMl9jZmc7Cj4gLQkJCWJyZWFrOwo+IC0JCWRl ZmF1bHQ6Cj4gLQkJCWJyZWFrOwo+IC0JCX0KPiArCWlmICghc21tdV9kb21haW4pIHsKPiArCQlp ZiAoZGlzYWJsZV9ieXBhc3MpCj4gKwkJCWFybV9zbW11X21ha2VfYWJvcnRfc3RlKCZ0YXJnZXQp Owo+ICsJCWVsc2UKPiArCQkJYXJtX3NtbXVfbWFrZV9ieXBhc3Nfc3RlKCZ0YXJnZXQpOwo+ICsJ CWFybV9zbW11X3dyaXRlX3N0ZShtYXN0ZXIsIHNpZCwgZHN0LCAmdGFyZ2V0KTsKPiArCQlyZXR1 cm47Cj4gKwl9Cj4gKwo+ICsJc3dpdGNoIChzbW11X2RvbWFpbi0+c3RhZ2UpIHsKPiArCWNhc2Ug QVJNX1NNTVVfRE9NQUlOX1MxOgo+ICsJCWNkX3RhYmxlID0gJm1hc3Rlci0+Y2RfdGFibGU7Cj4g KwkJYnJlYWs7Cj4gKwljYXNlIEFSTV9TTU1VX0RPTUFJTl9TMjoKPiArCQlzMl9jZmcgPSAmc21t dV9kb21haW4tPnMyX2NmZzsKPiArCQlicmVhazsKPiArCWNhc2UgQVJNX1NNTVVfRE9NQUlOX0JZ UEFTUzoKPiArCQlhcm1fc21tdV9tYWtlX2J5cGFzc19zdGUoJnRhcmdldCk7Cj4gKwkJYXJtX3Nt bXVfd3JpdGVfc3RlKG1hc3Rlciwgc2lkLCBkc3QsICZ0YXJnZXQpOwo+ICsJCXJldHVybjsKPiAg CX0KPiAgCj4gIAkvKiBOdWtlIHRoZSBleGlzdGluZyBTVEVfMCB2YWx1ZSwgYXMgd2UncmUgZ29p bmcgdG8gcmV3cml0ZSBpdCAqLwo+ICAJdmFsID0gU1RSVEFCX1NURV8wX1Y7Cj4gIAo+IC0JLyog QnlwYXNzL2ZhdWx0ICovCj4gLQlpZiAoIXNtbXVfZG9tYWluIHx8ICEoY2RfdGFibGUgfHwgczJf Y2ZnKSkgewo+IC0JCWlmICghc21tdV9kb21haW4gJiYgZGlzYWJsZV9ieXBhc3MpCj4gLQkJCXZh bCB8PSBGSUVMRF9QUkVQKFNUUlRBQl9TVEVfMF9DRkcsIFNUUlRBQl9TVEVfMF9DRkdfQUJPUlQp Owo+IC0JCWVsc2UKPiAtCQkJdmFsIHw9IEZJRUxEX1BSRVAoU1RSVEFCX1NURV8wX0NGRywgU1RS VEFCX1NURV8wX0NGR19CWVBBU1MpOwo+IC0KPiAtCQl0YXJnZXQuZGF0YVswXSA9IGNwdV90b19s ZTY0KHZhbCk7Cj4gLQkJdGFyZ2V0LmRhdGFbMV0gPSBjcHVfdG9fbGU2NChGSUVMRF9QUkVQKFNU UlRBQl9TVEVfMV9TSENGRywKPiAtCQkJCQkJU1RSVEFCX1NURV8xX1NIQ0ZHX0lOQ09NSU5HKSk7 Cj4gLQkJdGFyZ2V0LmRhdGFbMl0gPSAwOyAvKiBOdWtlIHRoZSBWTUlEICovCj4gLQkJYXJtX3Nt bXVfd3JpdGVfc3RlKG1hc3Rlciwgc2lkLCBkc3QsICZ0YXJnZXQpOwo+IC0JCXJldHVybjsKPiAt CX0KPiAtCj4gIAlpZiAoY2RfdGFibGUpIHsKPiAgCQl1NjQgc3RydyA9IHNtbXUtPmZlYXR1cmVz ICYgQVJNX1NNTVVfRkVBVF9FMkggPwo+ICAJCQlTVFJUQUJfU1RFXzFfU1RSV19FTDIgOiBTVFJU QUJfU1RFXzFfU1RSV19OU0VMMTsKPiBAQCAtMTU4MiwyMSArMTU5NCwxNSBAQCBzdGF0aWMgdm9p ZCBhcm1fc21tdV93cml0ZV9zdHJ0YWJfZW50KHN0cnVjdCBhcm1fc21tdV9tYXN0ZXIgKm1hc3Rl ciwgdTMyIHNpZCwKPiAgfQo+ICAKPiAgc3RhdGljIHZvaWQgYXJtX3NtbXVfaW5pdF9ieXBhc3Nf c3RlcyhzdHJ1Y3QgYXJtX3NtbXVfc3RlICpzdHJ0YWIsCj4gLQkJCQkgICAgICB1bnNpZ25lZCBp bnQgbmVudCwgYm9vbCBmb3JjZSkKPiArCQkJCSAgICAgIHVuc2lnbmVkIGludCBuZW50KQo+ICB7 Cj4gIAl1bnNpZ25lZCBpbnQgaTsKPiAtCXU2NCB2YWwgPSBTVFJUQUJfU1RFXzBfVjsKPiAtCj4g LQlpZiAoZGlzYWJsZV9ieXBhc3MgJiYgIWZvcmNlKQo+IC0JCXZhbCB8PSBGSUVMRF9QUkVQKFNU UlRBQl9TVEVfMF9DRkcsIFNUUlRBQl9TVEVfMF9DRkdfQUJPUlQpOwo+IC0JZWxzZQo+IC0JCXZh bCB8PSBGSUVMRF9QUkVQKFNUUlRBQl9TVEVfMF9DRkcsIFNUUlRBQl9TVEVfMF9DRkdfQllQQVNT KTsKPiAgCj4gIAlmb3IgKGkgPSAwOyBpIDwgbmVudDsgKytpKSB7Cj4gLQkJc3RydGFiLT5kYXRh WzBdID0gY3B1X3RvX2xlNjQodmFsKTsKPiAtCQlzdHJ0YWItPmRhdGFbMV0gPSBjcHVfdG9fbGU2 NChGSUVMRF9QUkVQKAo+IC0JCQlTVFJUQUJfU1RFXzFfU0hDRkcsIFNUUlRBQl9TVEVfMV9TSENG R19JTkNPTUlORykpOwo+IC0JCXN0cnRhYi0+ZGF0YVsyXSA9IDA7Cj4gKwkJaWYgKGRpc2FibGVf YnlwYXNzKQo+ICsJCQlhcm1fc21tdV9tYWtlX2Fib3J0X3N0ZShzdHJ0YWIpOwo+ICsJCWVsc2UK PiArCQkJYXJtX3NtbXVfbWFrZV9ieXBhc3Nfc3RlKHN0cnRhYik7Cj4gIAkJc3RydGFiKys7Cj4g IAl9Cj4gIH0KPiBAQCAtMTYyNCw3ICsxNjMwLDcgQEAgc3RhdGljIGludCBhcm1fc21tdV9pbml0 X2wyX3N0cnRhYihzdHJ1Y3QgYXJtX3NtbXVfZGV2aWNlICpzbW11LCB1MzIgc2lkKQo+ICAJCXJl dHVybiAtRU5PTUVNOwo+ICAJfQo+ICAKPiAtCWFybV9zbW11X2luaXRfYnlwYXNzX3N0ZXMoZGVz Yy0+bDJwdHIsIDEgPDwgU1RSVEFCX1NQTElULCBmYWxzZSk7Cj4gKwlhcm1fc21tdV9pbml0X2J5 cGFzc19zdGVzKGRlc2MtPmwycHRyLCAxIDw8IFNUUlRBQl9TUExJVCk7Cj4gIAlhcm1fc21tdV93 cml0ZV9zdHJ0YWJfbDFfZGVzYyhzdHJ0YWIsIGRlc2MpOwo+ICAJcmV0dXJuIDA7Cj4gIH0KPiBA QCAtMzI0Myw3ICszMjQ5LDcgQEAgc3RhdGljIGludCBhcm1fc21tdV9pbml0X3N0cnRhYl9saW5l YXIoc3RydWN0IGFybV9zbW11X2RldmljZSAqc21tdSkKPiAgCXJlZyB8PSBGSUVMRF9QUkVQKFNU UlRBQl9CQVNFX0NGR19MT0cyU0laRSwgc21tdS0+c2lkX2JpdHMpOwo+ICAJY2ZnLT5zdHJ0YWJf YmFzZV9jZmcgPSByZWc7Cj4gIAo+IC0JYXJtX3NtbXVfaW5pdF9ieXBhc3Nfc3RlcyhzdHJ0YWIs IGNmZy0+bnVtX2wxX2VudHMsIGZhbHNlKTsKPiArCWFybV9zbW11X2luaXRfYnlwYXNzX3N0ZXMo c3RydGFiLCBjZmctPm51bV9sMV9lbnRzKTsKPiAgCXJldHVybiAwOwo+ICB9Cj4gIAo+IEBAIC0z OTU0LDcgKzM5NjAsNiBAQCBzdGF0aWMgdm9pZCBhcm1fc21tdV9ybXJfaW5zdGFsbF9ieXBhc3Nf c3RlKHN0cnVjdCBhcm1fc21tdV9kZXZpY2UgKnNtbXUpCj4gIAlpb3J0X2dldF9ybXJfc2lkcyhk ZXZfZndub2RlKHNtbXUtPmRldiksICZybXJfbGlzdCk7Cj4gIAo+ICAJbGlzdF9mb3JfZWFjaF9l bnRyeShlLCAmcm1yX2xpc3QsIGxpc3QpIHsKPiAtCQlzdHJ1Y3QgYXJtX3NtbXVfc3RlICpzdGVw Owo+ICAJCXN0cnVjdCBpb21tdV9pb3J0X3Jtcl9kYXRhICpybXI7Cj4gIAkJaW50IHJldCwgaTsK PiAgCj4gQEAgLTM5NjcsOCArMzk3Miw4IEBAIHN0YXRpYyB2b2lkIGFybV9zbW11X3Jtcl9pbnN0 YWxsX2J5cGFzc19zdGUoc3RydWN0IGFybV9zbW11X2RldmljZSAqc21tdSkKPiAgCQkJCWNvbnRp bnVlOwo+ICAJCQl9Cj4gIAo+IC0JCQlzdGVwID0gYXJtX3NtbXVfZ2V0X3N0ZXBfZm9yX3NpZChz bW11LCBybXItPnNpZHNbaV0pOwo+IC0JCQlhcm1fc21tdV9pbml0X2J5cGFzc19zdGVzKHN0ZXAs IDEsIHRydWUpOwo+ICsJCQlhcm1fc21tdV9tYWtlX2J5cGFzc19zdGUoCj4gKwkJCQlhcm1fc21t dV9nZXRfc3RlcF9mb3Jfc2lkKHNtbXUsIHJtci0+c2lkc1tpXSkpOwo+ICAJCX0KPiAgCX0KPiAg Cj4gLS0gCj4gMi40My4wCj4KClJldmlld2VkLWJ5OiBNb3N0YWZhIFNhbGVoIDxzbW9zdGFmYUBn b29nbGUuY29tPgoKVGhhbmtzLApNb3N0YWZhCgpfX19fX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fXwpsaW51eC1hcm0ta2VybmVsIG1haWxpbmcgbGlzdApsaW51eC1h cm0ta2VybmVsQGxpc3RzLmluZnJhZGVhZC5vcmcKaHR0cDovL2xpc3RzLmluZnJhZGVhZC5vcmcv bWFpbG1hbi9saXN0aW5mby9saW51eC1hcm0ta2VybmVsCg==