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 74730C10F16 for ; Tue, 30 Apr 2024 09:45:53 +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:MIME-Version:References:In-Reply-To: Message-ID:Date:Subject:Cc:To:From:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=+4M5Q+A6+Hef4cDN4OAUfMYrB1HeukhjcoUwE3ljCd4=; b=Bsc2pYbfIt6DHB /AcZCFs5rxQ70EIVcgoXYvZHKPcFWKzE6w/ZKXbYEelyPF3NFh0Yh9NynCoZDk5zLxyKU/OzfoYK5 cpMe4eIeUhbwlboUUYewj1ePS3zqk0vOcftkdN3idY8vrDkL6jkmvnQmfETs0w1tTM2AyUnkJe85b yaebq10d9uMP0xvTHIzamBuME4mhsCK7Wsu1idKxFi0wymVoHXhBZ8dejIdpLAbA/1De7xR2UkJLI NGkKuiRMO7iJm4ZYMD4rBkQO2nlPeSoNxv3UUrmda5K4XHnvQRXSW9sce551CDdypSH8Zltgmz+HQ EwsXjQ+EHZCXvoOAnP8g==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.97.1 #2 (Red Hat Linux)) id 1s1k3R-00000005tM7-0j3L; Tue, 30 Apr 2024 09:45:41 +0000 Received: from relay7-d.mail.gandi.net ([217.70.183.200]) by bombadil.infradead.org with esmtps (Exim 4.97.1 #2 (Red Hat Linux)) id 1s1j1O-00000005dTA-2Dvh for linux-arm-kernel@lists.infradead.org; Tue, 30 Apr 2024 08:39:34 +0000 Received: by mail.gandi.net (Postfix) with ESMTPA id 5B7842000E; Tue, 30 Apr 2024 08:39:27 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=bootlin.com; s=gm1; t=1714466368; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=8HrxA/+8yLc71qfYdn9ZorS/cSEEyapLB+JeDi6Qlp8=; b=pHhh9Abxqvq2jTen/UgLW19vrJ4MHKM8pxomrQSjpHAxCqoD26axtEdoe3T2Kl9NACch7W s83NOYVZDAQuKLlrIFFdFp4W90n4ScUytC/iKZAcovL9p30B1olFpf2a3bP5NLQb9Lt5ln lMShcJiuTAPFsQfIovkudTpn06uwmMfTbaftdVzqqu75mWVnSsO3J/HcYvGdc9wCVgFtR4 AyRnkFcHDt8MY7KH6uVmsvwvzFn6UnHaII4hCDUBka8EGTa6LZJuS+ZuIy/IBX/jXfIiFL h+Bb7HWOXvlCrP1i4tHSa2/AaVXtUf0KlUpa9ATB9RVD7LJ41TTF/yUada7amA== From: Herve Codina To: Herve Codina , Thomas Gleixner , Rob Herring , Krzysztof Kozlowski , Conor Dooley , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Lee Jones , Arnd Bergmann , Horatiu Vultur , UNGLinuxDriver@microchip.com, Andrew Lunn , Heiner Kallweit , Russell King , Saravana Kannan , Bjorn Helgaas , Philipp Zabel , Lars Povlsen , Steen Hegelund , Daniel Machon , Alexandre Belloni Cc: linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, netdev@vger.kernel.org, linux-pci@vger.kernel.org, linux-arm-kernel@lists.infradead.org, Allan Nielsen , Steen Hegelund , Luca Ceresoli , Thomas Petazzoni Subject: [PATCH 12/17] irqchip: Add support for LAN966x OIC Date: Tue, 30 Apr 2024 10:37:21 +0200 Message-ID: <20240430083730.134918-13-herve.codina@bootlin.com> X-Mailer: git-send-email 2.44.0 In-Reply-To: <20240430083730.134918-1-herve.codina@bootlin.com> References: <20240430083730.134918-1-herve.codina@bootlin.com> MIME-Version: 1.0 X-GND-Sasl: herve.codina@bootlin.com X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20240430_013931_403377_148272DC X-CRM114-Status: GOOD ( 29.10 ) 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 VGhlIE1pY3JvY2hpcCBMQU45NjZ4IG91dGJhbmQgaW50ZXJydXB0IGNvbnRyb2xsZXIgKE9JQykg bWFwcyB0aGUKaW50ZXJuYWwgaW50ZXJydXB0IHNvdXJjZXMgb2YgdGhlIExBTjk2NnggZGV2aWNl IHRvIGFuIGV4dGVybmFsCmludGVycnVwdC4KV2hlbiB0aGUgTEFOOTY2eCBkZXZpY2UgaXMgdXNl ZCBhcyBhIFBDSSBkZXZpY2UsIHRoZSBleHRlcm5hbCBpbnRlcnJ1cHQKaXMgcm91dGVkIHRvIHRo ZSBQQ0kgaW50ZXJydXB0LgoKU2lnbmVkLW9mZi1ieTogSGVydmUgQ29kaW5hIDxoZXJ2ZS5jb2Rp bmFAYm9vdGxpbi5jb20+Ci0tLQogZHJpdmVycy9pcnFjaGlwL0tjb25maWcgICAgICAgICAgIHwg IDEyICsrCiBkcml2ZXJzL2lycWNoaXAvTWFrZWZpbGUgICAgICAgICAgfCAgIDEgKwogZHJpdmVy cy9pcnFjaGlwL2lycS1sYW45NjZ4LW9pYy5jIHwgMzAxICsrKysrKysrKysrKysrKysrKysrKysr KysrKysrKwogMyBmaWxlcyBjaGFuZ2VkLCAzMTQgaW5zZXJ0aW9ucygrKQogY3JlYXRlIG1vZGUg MTAwNjQ0IGRyaXZlcnMvaXJxY2hpcC9pcnEtbGFuOTY2eC1vaWMuYwoKZGlmZiAtLWdpdCBhL2Ry aXZlcnMvaXJxY2hpcC9LY29uZmlnIGIvZHJpdmVycy9pcnFjaGlwL0tjb25maWcKaW5kZXggNzJj MDdhMTJmNWUxLi45NzNlZWJjOGQxZDEgMTAwNjQ0Ci0tLSBhL2RyaXZlcnMvaXJxY2hpcC9LY29u ZmlnCisrKyBiL2RyaXZlcnMvaXJxY2hpcC9LY29uZmlnCkBAIC0xNjksNiArMTY5LDE4IEBAIGNv bmZpZyBJWFA0WFhfSVJRCiAJc2VsZWN0IElSUV9ET01BSU4KIAlzZWxlY3QgU1BBUlNFX0lSUQog Citjb25maWcgTEFOOTY2WF9PSUMKKwl0cmlzdGF0ZSAiTWljcm9jaGlwIExBTjk2NnggT0lDIFN1 cHBvcnQiCisJc2VsZWN0IEdFTkVSSUNfSVJRX0NISVAKKwlzZWxlY3QgSVJRX0RPTUFJTgorCWhl bHAKKwkgIEVuYWJsZSBzdXBwb3J0IGZvciB0aGUgTEFOOTY2eCBPdXRib3VuZCBJbnRlcnJ1cHQg Q29udHJvbGxlci4KKwkgIFRoaXMgY29udHJvbGxlciBpcyBwcmVzZW50IG9uIHRoZSBNaWNyb2No aXAgTEFOOTY2eCBQQ0kgZGV2aWNlIGFuZAorCSAgbWFwcyB0aGUgaW50ZXJuYWwgaW50ZXJydXB0 cyBzb3VyY2VzIHRvIFBDSWUgaW50ZXJydXB0LgorCisJICBUbyBjb21waWxlIHRoaXMgZHJpdmVy IGFzIGEgbW9kdWxlLCBjaG9vc2UgTSBoZXJlOiB0aGUgbW9kdWxlCisJICB3aWxsIGJlIGNhbGxl ZCBpcnEtbGFuOTY2eC1vaWMuCisKIGNvbmZpZyBNQURFUkFfSVJRCiAJdHJpc3RhdGUKIApkaWZm IC0tZ2l0IGEvZHJpdmVycy9pcnFjaGlwL01ha2VmaWxlIGIvZHJpdmVycy9pcnFjaGlwL01ha2Vm aWxlCmluZGV4IGVjNGExODM4MDk5OC4uNzYyZDMwNzhhYTNiIDEwMDY0NAotLS0gYS9kcml2ZXJz L2lycWNoaXAvTWFrZWZpbGUKKysrIGIvZHJpdmVycy9pcnFjaGlwL01ha2VmaWxlCkBAIC0xMDEs NiArMTAxLDcgQEAgb2JqLSQoQ09ORklHX0lNWF9JUlFTVEVFUikJCSs9IGlycS1pbXgtaXJxc3Rl ZXIubwogb2JqLSQoQ09ORklHX0lNWF9JTlRNVVgpCQkrPSBpcnEtaW14LWludG11eC5vCiBvYmot JChDT05GSUdfSU1YX01VX01TSSkJCSs9IGlycS1pbXgtbXUtbXNpLm8KIG9iai0kKENPTkZJR19N QURFUkFfSVJRKQkJKz0gaXJxLW1hZGVyYS5vCitvYmotJChDT05GSUdfTEFOOTY2WF9PSUMpCQkr PSBpcnEtbGFuOTY2eC1vaWMubwogb2JqLSQoQ09ORklHX0xTMVhfSVJRKQkJCSs9IGlycS1sczF4 Lm8KIG9iai0kKENPTkZJR19USV9TQ0lfSU5UUl9JUlFDSElQKQkrPSBpcnEtdGktc2NpLWludHIu bwogb2JqLSQoQ09ORklHX1RJX1NDSV9JTlRBX0lSUUNISVApCSs9IGlycS10aS1zY2ktaW50YS5v CmRpZmYgLS1naXQgYS9kcml2ZXJzL2lycWNoaXAvaXJxLWxhbjk2Nngtb2ljLmMgYi9kcml2ZXJz L2lycWNoaXAvaXJxLWxhbjk2Nngtb2ljLmMKbmV3IGZpbGUgbW9kZSAxMDA2NDQKaW5kZXggMDAw MDAwMDAwMDAwLi4zNDJmMGRiZjE2ZTMKLS0tIC9kZXYvbnVsbAorKysgYi9kcml2ZXJzL2lycWNo aXAvaXJxLWxhbjk2Nngtb2ljLmMKQEAgLTAsMCArMSwzMDEgQEAKKy8vIFNQRFgtTGljZW5zZS1J ZGVudGlmaWVyOiBHUEwtMi4wCisvKgorICogRHJpdmVyIGZvciB0aGUgTWljcm9jaGlwIExBTjk2 Nnggb3V0Ym91bmQgaW50ZXJydXB0IGNvbnRyb2xsZXIKKyAqCisgKiBDb3B5cmlnaHQgKGMpIDIw MjQgVGVjaG5vbG9neSBJbmMuIGFuZCBpdHMgc3Vic2lkaWFyaWVzLgorICoKKyAqIEF1dGhvcnM6 CisgKglIb3JhdGl1IFZ1bHR1ciA8aG9yYXRpdS52dWx0dXJAbWljcm9jaGlwLmNvbT4KKyAqCUNs w6ltZW50IEzDqWdlciA8Y2xlbWVudC5sZWdlckBib290bGluLmNvbT4KKyAqCUhlcnZlIENvZGlu YSA8aGVydmUuY29kaW5hQGJvb3RsaW4uY29tPgorICovCisKKyNpbmNsdWRlIDxsaW51eC9iaXRv cHMuaD4KKyNpbmNsdWRlIDxsaW51eC9idWlsZF9idWcuaD4KKyNpbmNsdWRlIDxsaW51eC9pbnRl cnJ1cHQuaD4KKyNpbmNsdWRlIDxsaW51eC9pcnFjaGlwL2NoYWluZWRfaXJxLmg+CisjaW5jbHVk ZSA8bGludXgvaXJxY2hpcC5oPgorI2luY2x1ZGUgPGxpbnV4L2lycS5oPgorI2luY2x1ZGUgPGxp bnV4L2lvcG9sbC5oPgorI2luY2x1ZGUgPGxpbnV4L21mZC9jb3JlLmg+CisjaW5jbHVkZSA8bGlu dXgvbW9kdWxlLmg+CisjaW5jbHVkZSA8bGludXgvcGNpLmg+CisjaW5jbHVkZSA8bGludXgvZGVs YXkuaD4KKworc3RydWN0IGxhbjk2Nnhfb2ljX2NoaXBfcmVncyB7CisJaW50IHJlZ19vZmZfZW5h X3NldDsKKwlpbnQgcmVnX29mZl9lbmFfY2xyOworCWludCByZWdfb2ZmX3N0aWNreTsKKwlpbnQg cmVnX29mZl9pZGVudDsKKwlpbnQgcmVnX29mZl9tYXA7Cit9OworCitzdHJ1Y3QgbGFuOTY2eF9v aWNfZGF0YSB7CisJc3RydWN0IGlycV9kb21haW4gKmRvbWFpbjsKKwl2b2lkIF9faW9tZW0gKnJl Z3M7CisJaW50IGlycTsKK307CisKKyNkZWZpbmUgTEFOOTY2WF9PSUNfTlJfSVJRIDg2CisKKy8q IEludGVycnVwdCBzdGlja3kgc3RhdHVzICovCisjZGVmaW5lIExBTjk2NlhfT0lDX0lOVFJfU1RJ Q0tZCQkweDMwCisjZGVmaW5lIExBTjk2NlhfT0lDX0lOVFJfU1RJQ0tZMQkweDM0CisjZGVmaW5l IExBTjk2NlhfT0lDX0lOVFJfU1RJQ0tZMgkweDM4CisKKy8qIEludGVycnVwdCBlbmFibGUgKi8K KyNkZWZpbmUgTEFOOTY2WF9PSUNfSU5UUl9FTkEJCTB4NDgKKyNkZWZpbmUgTEFOOTY2WF9PSUNf SU5UUl9FTkExCQkweDRjCisjZGVmaW5lIExBTjk2NlhfT0lDX0lOVFJfRU5BMgkJMHg1MAorCisv KiBBdG9taWMgY2xlYXIgb2YgaW50ZXJydXB0IGVuYWJsZSAqLworI2RlZmluZSBMQU45NjZYX09J Q19JTlRSX0VOQV9DTFIJMHg1NAorI2RlZmluZSBMQU45NjZYX09JQ19JTlRSX0VOQV9DTFIxCTB4 NTgKKyNkZWZpbmUgTEFOOTY2WF9PSUNfSU5UUl9FTkFfQ0xSMgkweDVjCisKKy8qIEF0b21pYyBz ZXQgb2YgaW50ZXJydXB0ICovCisjZGVmaW5lIExBTjk2NlhfT0lDX0lOVFJfRU5BX1NFVAkweDYw CisjZGVmaW5lIExBTjk2NlhfT0lDX0lOVFJfRU5BX1NFVDEJMHg2NAorI2RlZmluZSBMQU45NjZY X09JQ19JTlRSX0VOQV9TRVQyCTB4NjgKKworLyogTWFwcGluZyBvZiBzb3VyY2UgdG8gZGVzdGlu YXRpb24gaW50ZXJydXB0cyAoX24gPSAwLi44KSAqLworI2RlZmluZSBMQU45NjZYX09JQ19EU1Rf SU5UUl9NQVAoX24pCTB4NzgKKyNkZWZpbmUgTEFOOTY2WF9PSUNfRFNUX0lOVFJfTUFQMShfbikJ MHg5YworI2RlZmluZSBMQU45NjZYX09JQ19EU1RfSU5UUl9NQVAyKF9uKQkweGMwCisKKy8qIEN1 cnJlbnRseSBhY3RpdmUgaW50ZXJydXB0IHNvdXJjZXMgcGVyIGRlc3RpbmF0aW9uIChfbiA9IDAu LjgpICovCisjZGVmaW5lIExBTjk2NlhfT0lDX0RTVF9JTlRSX0lERU5UKF9uKQkweGU0CisjZGVm aW5lIExBTjk2NlhfT0lDX0RTVF9JTlRSX0lERU5UMShfbikJMHgxMDgKKyNkZWZpbmUgTEFOOTY2 WF9PSUNfRFNUX0lOVFJfSURFTlQyKF9uKQkweDEyYworCitzdGF0aWMgdW5zaWduZWQgaW50IGxh bjk2Nnhfb2ljX2lycV9zdGFydHVwKHN0cnVjdCBpcnFfZGF0YSAqZGF0YSkKK3sKKwlzdHJ1Y3Qg aXJxX2NoaXBfZ2VuZXJpYyAqZ2MgPSBpcnFfZGF0YV9nZXRfaXJxX2NoaXBfZGF0YShkYXRhKTsK KwlzdHJ1Y3QgaXJxX2NoaXBfdHlwZSAqY3QgPSBpcnFfZGF0YV9nZXRfY2hpcF90eXBlKGRhdGEp OworCXN0cnVjdCBsYW45NjZ4X29pY19jaGlwX3JlZ3MgKmNoaXBfcmVncyA9IGdjLT5wcml2YXRl OworCXUzMiBtYXA7CisKKwlpcnFfZ2NfbG9jayhnYyk7CisKKwkvKiBNYXAgdGhlIHNvdXJjZSBp bnRlcnJ1cHQgdG8gdGhlIGRlc3RpbmF0aW9uICovCisJbWFwID0gaXJxX3JlZ19yZWFkbChnYywg Y2hpcF9yZWdzLT5yZWdfb2ZmX21hcCk7CisJbWFwIHw9IGRhdGEtPm1hc2s7CisJaXJxX3JlZ193 cml0ZWwoZ2MsIG1hcCwgY2hpcF9yZWdzLT5yZWdfb2ZmX21hcCk7CisKKwlpcnFfZ2NfdW5sb2Nr KGdjKTsKKworCWN0LT5jaGlwLmlycV9hY2soZGF0YSk7CisJY3QtPmNoaXAuaXJxX3VubWFzayhk YXRhKTsKKworCXJldHVybiAwOworfQorCitzdGF0aWMgdm9pZCBsYW45NjZ4X29pY19pcnFfc2h1 dGRvd24oc3RydWN0IGlycV9kYXRhICpkYXRhKQoreworCXN0cnVjdCBpcnFfY2hpcF9nZW5lcmlj ICpnYyA9IGlycV9kYXRhX2dldF9pcnFfY2hpcF9kYXRhKGRhdGEpOworCXN0cnVjdCBpcnFfY2hp cF90eXBlICpjdCA9IGlycV9kYXRhX2dldF9jaGlwX3R5cGUoZGF0YSk7CisJc3RydWN0IGxhbjk2 Nnhfb2ljX2NoaXBfcmVncyAqY2hpcF9yZWdzID0gZ2MtPnByaXZhdGU7CisJdTMyIG1hcDsKKwor CWN0LT5jaGlwLmlycV9tYXNrKGRhdGEpOworCisJaXJxX2djX2xvY2soZ2MpOworCisJLyogVW5t YXAgdGhlIGludGVycnVwdCAqLworCW1hcCA9IGlycV9yZWdfcmVhZGwoZ2MsIGNoaXBfcmVncy0+ cmVnX29mZl9tYXApOworCW1hcCAmPSB+ZGF0YS0+bWFzazsKKwlpcnFfcmVnX3dyaXRlbChnYywg bWFwLCBjaGlwX3JlZ3MtPnJlZ19vZmZfbWFwKTsKKworCWlycV9nY191bmxvY2soZ2MpOworfQor CitzdGF0aWMgaW50IGxhbjk2Nnhfb2ljX2lycV9zZXRfdHlwZShzdHJ1Y3QgaXJxX2RhdGEgKmRh dGEsIHVuc2lnbmVkIGludCBmbG93X3R5cGUpCit7CisJaWYgKGZsb3dfdHlwZSAhPSBJUlFfVFlQ RV9MRVZFTF9ISUdIKSB7CisJCXByX2VycigibGFuOTY2eCBvaWMgZG9lc24ndCBzdXBwb3J0IGZs b3cgdHlwZSAlZFxuIiwgZmxvd190eXBlKTsKKwkJcmV0dXJuIC1FSU5WQUw7CisJfQorCisJcmV0 dXJuIDA7Cit9CisKK3N0YXRpYyB2b2lkIGxhbjk2Nnhfb2ljX2lycV9oYW5kbGVyX2RvbWFpbihz dHJ1Y3QgaXJxX2RvbWFpbiAqZCwgdTMyIGZpcnN0X2lycSkKK3sKKwlzdHJ1Y3QgaXJxX2NoaXBf Z2VuZXJpYyAqZ2MgPSBpcnFfZ2V0X2RvbWFpbl9nZW5lcmljX2NoaXAoZCwgZmlyc3RfaXJxKTsK KwlzdHJ1Y3QgbGFuOTY2eF9vaWNfY2hpcF9yZWdzICpjaGlwX3JlZ3MgPSBnYy0+cHJpdmF0ZTsK Kwl1bnNpZ25lZCBsb25nIGlkZW50OworCXVuc2lnbmVkIGludCBod2lycTsKKworCWlkZW50ID0g aXJxX3JlZ19yZWFkbChnYywgY2hpcF9yZWdzLT5yZWdfb2ZmX2lkZW50KTsKKwlpZiAoIWlkZW50 KQorCQlyZXR1cm47CisKKwlmb3JfZWFjaF9zZXRfYml0KGh3aXJxLCAmaWRlbnQsIDMyKQorCQln ZW5lcmljX2hhbmRsZV9kb21haW5faXJxKGQsIGh3aXJxICsgZmlyc3RfaXJxKTsKK30KKworc3Rh dGljIHZvaWQgbGFuOTY2eF9vaWNfaXJxX2hhbmRsZXIoc3RydWN0IGlycV9kZXNjICpkZXNjKQor eworCXN0cnVjdCBpcnFfZG9tYWluICpkID0gaXJxX2Rlc2NfZ2V0X2hhbmRsZXJfZGF0YShkZXNj KTsKKwlzdHJ1Y3QgaXJxX2NoaXAgKmNoaXAgPSBpcnFfZGVzY19nZXRfY2hpcChkZXNjKTsKKwor CWNoYWluZWRfaXJxX2VudGVyKGNoaXAsIGRlc2MpOworCWxhbjk2Nnhfb2ljX2lycV9oYW5kbGVy X2RvbWFpbihkLCAwKTsKKwlsYW45NjZ4X29pY19pcnFfaGFuZGxlcl9kb21haW4oZCwgMzIpOwor CWxhbjk2Nnhfb2ljX2lycV9oYW5kbGVyX2RvbWFpbihkLCA2NCk7CisJY2hhaW5lZF9pcnFfZXhp dChjaGlwLCBkZXNjKTsKK30KKworc3RhdGljIHN0cnVjdCBsYW45NjZ4X29pY19jaGlwX3JlZ3Mg bGFuOTY2eF9vaWNfY2hpcF9yZWdzWzNdID0geworCXsKKwkJLnJlZ19vZmZfZW5hX3NldCA9IExB Tjk2NlhfT0lDX0lOVFJfRU5BX1NFVCwKKwkJLnJlZ19vZmZfZW5hX2NsciA9IExBTjk2NlhfT0lD X0lOVFJfRU5BX0NMUiwKKwkJLnJlZ19vZmZfc3RpY2t5ID0gTEFOOTY2WF9PSUNfSU5UUl9TVElD S1ksCisJCS5yZWdfb2ZmX2lkZW50ID0gTEFOOTY2WF9PSUNfRFNUX0lOVFJfSURFTlQoMCksCisJ CS5yZWdfb2ZmX21hcCA9IExBTjk2NlhfT0lDX0RTVF9JTlRSX01BUCgwKSwKKwl9LCB7CisJCS5y ZWdfb2ZmX2VuYV9zZXQgPSBMQU45NjZYX09JQ19JTlRSX0VOQV9TRVQxLAorCQkucmVnX29mZl9l bmFfY2xyID0gTEFOOTY2WF9PSUNfSU5UUl9FTkFfQ0xSMSwKKwkJLnJlZ19vZmZfc3RpY2t5ID0g TEFOOTY2WF9PSUNfSU5UUl9TVElDS1kxLAorCQkucmVnX29mZl9pZGVudCA9IExBTjk2NlhfT0lD X0RTVF9JTlRSX0lERU5UMSgwKSwKKwkJLnJlZ19vZmZfbWFwID0gTEFOOTY2WF9PSUNfRFNUX0lO VFJfTUFQMSgwKSwKKwl9LCB7CisJCS5yZWdfb2ZmX2VuYV9zZXQgPSBMQU45NjZYX09JQ19JTlRS X0VOQV9TRVQyLAorCQkucmVnX29mZl9lbmFfY2xyID0gTEFOOTY2WF9PSUNfSU5UUl9FTkFfQ0xS MiwKKwkJLnJlZ19vZmZfc3RpY2t5ID0gTEFOOTY2WF9PSUNfSU5UUl9TVElDS1kyLAorCQkucmVn X29mZl9pZGVudCA9IExBTjk2NlhfT0lDX0RTVF9JTlRSX0lERU5UMigwKSwKKwkJLnJlZ19vZmZf bWFwID0gTEFOOTY2WF9PSUNfRFNUX0lOVFJfTUFQMigwKSwKKwl9Cit9OworCitzdGF0aWMgdm9p ZCBsYW45NjZ4X29pY19jaGlwX2luaXQoc3RydWN0IGxhbjk2Nnhfb2ljX2RhdGEgKmxhbjk2Nnhf b2ljLAorCQkJCSAgc3RydWN0IGlycV9jaGlwX2dlbmVyaWMgKmdjLAorCQkJCSAgc3RydWN0IGxh bjk2Nnhfb2ljX2NoaXBfcmVncyAqY2hpcF9yZWdzKQoreworCWdjLT5yZWdfYmFzZSA9IGxhbjk2 Nnhfb2ljLT5yZWdzOworCWdjLT5jaGlwX3R5cGVzWzBdLnJlZ3MuZW5hYmxlID0gY2hpcF9yZWdz LT5yZWdfb2ZmX2VuYV9zZXQ7CisJZ2MtPmNoaXBfdHlwZXNbMF0ucmVncy5kaXNhYmxlID0gY2hp cF9yZWdzLT5yZWdfb2ZmX2VuYV9jbHI7CisJZ2MtPmNoaXBfdHlwZXNbMF0ucmVncy5hY2sgPSBj aGlwX3JlZ3MtPnJlZ19vZmZfc3RpY2t5OworCWdjLT5jaGlwX3R5cGVzWzBdLmNoaXAuaXJxX3N0 YXJ0dXAgPSBsYW45NjZ4X29pY19pcnFfc3RhcnR1cDsKKwlnYy0+Y2hpcF90eXBlc1swXS5jaGlw LmlycV9zaHV0ZG93biA9IGxhbjk2Nnhfb2ljX2lycV9zaHV0ZG93bjsKKwlnYy0+Y2hpcF90eXBl c1swXS5jaGlwLmlycV9zZXRfdHlwZSA9IGxhbjk2Nnhfb2ljX2lycV9zZXRfdHlwZTsKKwlnYy0+ Y2hpcF90eXBlc1swXS5jaGlwLmlycV9tYXNrID0gaXJxX2djX21hc2tfZGlzYWJsZV9yZWc7CisJ Z2MtPmNoaXBfdHlwZXNbMF0uY2hpcC5pcnFfdW5tYXNrID0gaXJxX2djX3VubWFza19lbmFibGVf cmVnOworCWdjLT5jaGlwX3R5cGVzWzBdLmNoaXAuaXJxX2FjayA9IGlycV9nY19hY2tfc2V0X2Jp dDsKKwlnYy0+cHJpdmF0ZSA9IGNoaXBfcmVnczsKKworCS8qIERpc2FibGUgYWxsIGludGVycnVw dHMgaGFuZGxlZCBieSB0aGlzIGNoaXAgKi8KKwlpcnFfcmVnX3dyaXRlbChnYywgfjAsIGNoaXBf cmVncy0+cmVnX29mZl9lbmFfY2xyKTsKK30KKworc3RhdGljIHZvaWQgbGFuOTY2eF9vaWNfY2hp cF9leGl0KHN0cnVjdCBpcnFfY2hpcF9nZW5lcmljICpnYykKK3sKKwkvKiBEaXNhYmxlIGFuZCBh Y2sgYWxsIGludGVycnVwdHMgaGFuZGxlZCBieSB0aGlzIGNoaXAgKi8KKwlpcnFfcmVnX3dyaXRl bChnYywgfjAsIGdjLT5jaGlwX3R5cGVzWzBdLnJlZ3MuZGlzYWJsZSk7CisJaXJxX3JlZ193cml0 ZWwoZ2MsIH4wLCBnYy0+Y2hpcF90eXBlc1swXS5yZWdzLmFjayk7Cit9CisKK3N0YXRpYyBpbnQg bGFuOTY2eF9vaWNfcHJvYmUoc3RydWN0IHBsYXRmb3JtX2RldmljZSAqcGRldikKK3sKKwlzdHJ1 Y3QgZGV2aWNlX25vZGUgKm5vZGUgPSBwZGV2LT5kZXYub2Zfbm9kZTsKKwlzdHJ1Y3QgbGFuOTY2 eF9vaWNfZGF0YSAqbGFuOTY2eF9vaWM7CisJc3RydWN0IGRldmljZSAqZGV2ID0gJnBkZXYtPmRl djsKKwlzdHJ1Y3QgaXJxX2NoaXBfZ2VuZXJpYyAqZ2M7CisJaW50IHJldDsKKwlpbnQgaTsKKwor CWxhbjk2Nnhfb2ljID0gZGV2bV9rbWFsbG9jKGRldiwgc2l6ZW9mKCpsYW45NjZ4X29pYyksIEdG UF9LRVJORUwpOworCWlmICghbGFuOTY2eF9vaWMpCisJCXJldHVybiAtRU5PTUVNOworCisJbGFu OTY2eF9vaWMtPnJlZ3MgPSBkZXZtX3BsYXRmb3JtX2lvcmVtYXBfcmVzb3VyY2UocGRldiwgMCk7 CisJaWYgKElTX0VSUihsYW45NjZ4X29pYy0+cmVncykpCisJCXJldHVybiBkZXZfZXJyX3Byb2Jl KGRldiwgUFRSX0VSUihsYW45NjZ4X29pYy0+cmVncyksCisJCQkJICAgICAiZmFpbGVkIHRvIG1h cCByZXNvdXJjZVxuIik7CisKKwlsYW45NjZ4X29pYy0+ZG9tYWluID0gaXJxX2RvbWFpbl9hbGxv Y19saW5lYXIob2Zfbm9kZV90b19md25vZGUobm9kZSksCisJCQkJCQkgICAgICBMQU45NjZYX09J Q19OUl9JUlEsCisJCQkJCQkgICAgICAmaXJxX2dlbmVyaWNfY2hpcF9vcHMsIE5VTEwpOworCWlm ICghbGFuOTY2eF9vaWMtPmRvbWFpbikgeworCQlkZXZfZXJyKGRldiwgImZhaWxlZCB0byBjcmVh dGUgYW4gSVJRIGRvbWFpblxuIik7CisJCXJldHVybiAtRUlOVkFMOworCX0KKworCWxhbjk2Nnhf b2ljLT5pcnEgPSBwbGF0Zm9ybV9nZXRfaXJxKHBkZXYsIDApOworCWlmIChsYW45NjZ4X29pYy0+ aXJxIDwgMCkgeworCQlkZXZfZXJyX3Byb2JlKGRldiwgbGFuOTY2eF9vaWMtPmlycSwgImZhaWxl ZCB0byBnZXQgdGhlIElSUVxuIik7CisJCWdvdG8gZXJyX2RvbWFpbl9mcmVlOworCX0KKworCXJl dCA9IGlycV9hbGxvY19kb21haW5fZ2VuZXJpY19jaGlwcyhsYW45NjZ4X29pYy0+ZG9tYWluLCAz MiwgMSwgImxhbjk2Nngtb2ljIiwKKwkJCQkJICAgICBoYW5kbGVfbGV2ZWxfaXJxLCAwLCAwLCAw KTsKKwlpZiAocmV0KSB7CisJCWRldl9lcnJfcHJvYmUoZGV2LCByZXQsICJmYWlsZWQgdG8gYWxs b2MgaXJxIGRvbWFpbiBnY1xuIik7CisJCWdvdG8gZXJyX2RvbWFpbl9mcmVlOworCX0KKworCS8q IEluaXQgY2hpcHMgKi8KKwlCVUlMRF9CVUdfT04oRElWX1JPVU5EX1VQKExBTjk2NlhfT0lDX05S X0lSUSwgMzIpICE9IEFSUkFZX1NJWkUobGFuOTY2eF9vaWNfY2hpcF9yZWdzKSk7CisJZm9yIChp ID0gMDsgaSA8IEFSUkFZX1NJWkUobGFuOTY2eF9vaWNfY2hpcF9yZWdzKTsgaSsrKSB7CisJCWdj ID0gaXJxX2dldF9kb21haW5fZ2VuZXJpY19jaGlwKGxhbjk2Nnhfb2ljLT5kb21haW4sIGkgKiAz Mik7CisJCWxhbjk2Nnhfb2ljX2NoaXBfaW5pdChsYW45NjZ4X29pYywgZ2MsICZsYW45NjZ4X29p Y19jaGlwX3JlZ3NbaV0pOworCX0KKworCWlycV9zZXRfY2hhaW5lZF9oYW5kbGVyX2FuZF9kYXRh KGxhbjk2Nnhfb2ljLT5pcnEsIGxhbjk2Nnhfb2ljX2lycV9oYW5kbGVyLAorCQkJCQkgbGFuOTY2 eF9vaWMtPmRvbWFpbik7CisKKwlpcnFfZG9tYWluX3B1Ymxpc2gobGFuOTY2eF9vaWMtPmRvbWFp bik7CisJcGxhdGZvcm1fc2V0X2RydmRhdGEocGRldiwgbGFuOTY2eF9vaWMpOworCXJldHVybiAw OworCitlcnJfZG9tYWluX2ZyZWU6CisJaXJxX2RvbWFpbl9mcmVlKGxhbjk2Nnhfb2ljLT5kb21h aW4pOworCXJldHVybiByZXQ7Cit9CisKK3N0YXRpYyB2b2lkIGxhbjk2Nnhfb2ljX3JlbW92ZShz dHJ1Y3QgcGxhdGZvcm1fZGV2aWNlICpwZGV2KQoreworCXN0cnVjdCBsYW45NjZ4X29pY19kYXRh ICpsYW45NjZ4X29pYyA9IHBsYXRmb3JtX2dldF9kcnZkYXRhKHBkZXYpOworCXN0cnVjdCBpcnFf Y2hpcF9nZW5lcmljICpnYzsKKwlpbnQgaTsKKworCWZvciAoaSA9IDA7IGkgPCBBUlJBWV9TSVpF KGxhbjk2Nnhfb2ljX2NoaXBfcmVncyk7IGkrKykgeworCQlnYyA9IGlycV9nZXRfZG9tYWluX2dl bmVyaWNfY2hpcChsYW45NjZ4X29pYy0+ZG9tYWluLCBpICogMzIpOworCQlsYW45NjZ4X29pY19j aGlwX2V4aXQoZ2MpOworCX0KKworCWlycV9zZXRfY2hhaW5lZF9oYW5kbGVyX2FuZF9kYXRhKGxh bjk2Nnhfb2ljLT5pcnEsIE5VTEwsIE5VTEwpOworCisJZm9yIChpID0gMDsgaSA8IExBTjk2Nlhf T0lDX05SX0lSUTsgaSsrKQorCQlpcnFfZGlzcG9zZV9tYXBwaW5nKGlycV9maW5kX21hcHBpbmco bGFuOTY2eF9vaWMtPmRvbWFpbiwgaSkpOworCisJaXJxX2RvbWFpbl91bnB1Ymxpc2gobGFuOTY2 eF9vaWMtPmRvbWFpbik7CisKKwlmb3IgKGkgPSAwOyBpIDwgQVJSQVlfU0laRShsYW45NjZ4X29p Y19jaGlwX3JlZ3MpOyBpKyspIHsKKwkJZ2MgPSBpcnFfZ2V0X2RvbWFpbl9nZW5lcmljX2NoaXAo bGFuOTY2eF9vaWMtPmRvbWFpbiwgaSAqIDMyKTsKKwkJaXJxX3JlbW92ZV9nZW5lcmljX2NoaXAo Z2MsIH4wLCAwLCAwKTsKKwl9CisKKwlrZnJlZShsYW45NjZ4X29pYy0+ZG9tYWluLT5nYyk7CisJ aXJxX2RvbWFpbl9mcmVlKGxhbjk2Nnhfb2ljLT5kb21haW4pOworfQorCitzdGF0aWMgY29uc3Qg c3RydWN0IG9mX2RldmljZV9pZCBsYW45NjZ4X29pY19vZl9tYXRjaFtdID0geworCXsgLmNvbXBh dGlibGUgPSAibWljcm9jaGlwLGxhbjk2Nngtb2ljIiB9LAorCXt9IC8qIHNlbnRpbmVsICovCit9 OworTU9EVUxFX0RFVklDRV9UQUJMRShvZiwgbGFuOTY2eF9vaWNfb2ZfbWF0Y2gpOworCitzdGF0 aWMgc3RydWN0IHBsYXRmb3JtX2RyaXZlciBsYW45NjZ4X29pY19kcml2ZXIgPSB7CisJLnByb2Jl ID0gbGFuOTY2eF9vaWNfcHJvYmUsCisJLnJlbW92ZV9uZXcgPSBsYW45NjZ4X29pY19yZW1vdmUs CisJLmRyaXZlciA9IHsKKwkJLm5hbWUgPSAibGFuOTY2eC1vaWMiLAorCQkub2ZfbWF0Y2hfdGFi bGUgPSBsYW45NjZ4X29pY19vZl9tYXRjaCwKKwl9LAorfTsKK21vZHVsZV9wbGF0Zm9ybV9kcml2 ZXIobGFuOTY2eF9vaWNfZHJpdmVyKTsKKworTU9EVUxFX0FVVEhPUigiSGVydmUgQ29kaW5hIDxo ZXJ2ZS5jb2RpbmFAYm9vdGxpbi5jb20+Iik7CitNT0RVTEVfREVTQ1JJUFRJT04oIk1pY3JvY2hp cCBMQU45NjZ4IE9JQyBkcml2ZXIiKTsKK01PRFVMRV9MSUNFTlNFKCJHUEwiKTsKLS0gCjIuNDQu MAoKCl9fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fX19fCmxpbnV4 LWFybS1rZXJuZWwgbWFpbGluZyBsaXN0CmxpbnV4LWFybS1rZXJuZWxAbGlzdHMuaW5mcmFkZWFk Lm9yZwpodHRwOi8vbGlzdHMuaW5mcmFkZWFkLm9yZy9tYWlsbWFuL2xpc3RpbmZvL2xpbnV4LWFy bS1rZXJuZWwK