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 vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 0C309C25B06 for ; Sun, 14 Aug 2022 15:27:51 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239843AbiHNP1t (ORCPT ); Sun, 14 Aug 2022 11:27:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37058 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239624AbiHNP1h (ORCPT ); Sun, 14 Aug 2022 11:27:37 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 95EF0AE62; Sun, 14 Aug 2022 08:27:35 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by ams.source.kernel.org (Postfix) with ESMTPS id 1A1E6B80B27; Sun, 14 Aug 2022 15:27:34 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id C4449C433C1; Sun, 14 Aug 2022 15:27:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1660490852; bh=5GyLM1CyVv10Ove+YIIf3oMlmnKfA55OKySxx0jDfxA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=A67viJI2thCRSB5Fr624goC6G8U1y/41RffDWMv3el7/1F5562HU7+47a5YiiP9Ot TysGLZucmttPDDe19UCllhJRbGjjdO+lTNKqdr/axnMHyP1s9OpcWvPpF3u0iriyrQ uiLjl49XE4bTjfYG1at4sIHhvbZuB4+4B9QcN53jzRhvZGyuywshhbVWGoOSR3oiMy zlrcu5+0RPdHL5glYp30e1m95EwxtmV+Vfc2BvC0W2q9kqaGyTV7Fy0mGwObry0X1v cNMHHoajVxJQOIbWVerTbdoquP7uleM1qwZEF+VVtbbB5ia36TLPHB85Toy00u2UOp xZ436PF4wxogA== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: =?UTF-8?q?Pali=20Roh=C3=A1r?= , =?UTF-8?q?Marek=20Beh=C3=BAn?= , Bjorn Helgaas , Sasha Levin , thomas.petazzoni@bootlin.com, lpieralisi@kernel.org, linux-pci@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: [PATCH AUTOSEL 5.19 12/64] PCI: aardvark: Fix reporting Slot capabilities on emulated bridge Date: Sun, 14 Aug 2022 11:23:45 -0400 Message-Id: <20220814152437.2374207-12-sashal@kernel.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220814152437.2374207-1-sashal@kernel.org> References: <20220814152437.2374207-1-sashal@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Pali Rohár [ Upstream commit bcdb6fd4f3e9ac1097698c8d8f56b70853b49873 ] Slot capabilities are currently not reported because emulated bridge does not report the PCI_EXP_FLAGS_SLOT flag. Set PCI_EXP_FLAGS_SLOT to let the kernel know that PCI_EXP_SLT* registers are supported. Move setting of PCI_EXP_SLTCTL register from "dynamic" pcie_conf_read function to static buffer as it is only statically filled the PCI_EXP_SLTSTA_PDS flag and dynamic read callback is not needed for this register. Set Presence State Bit to 1 since there is no support for unplugging the card and there is currently no platform able to detect presence of a card - in such a case the bit needs to be set to 1. Finally correctly set Physical Slot Number to 1 since there is only one port and zero value is reserved for ports within the same silicon as Root Port which is not our case for Aardvark HW. Link: https://lore.kernel.org/r/20220524132827.8837-3-kabel@kernel.org Signed-off-by: Pali Rohár Signed-off-by: Marek Behún Signed-off-by: Bjorn Helgaas Signed-off-by: Sasha Levin --- drivers/pci/controller/pci-aardvark.c | 33 +++++++++++++++++++-------- 1 file changed, 24 insertions(+), 9 deletions(-) diff --git a/drivers/pci/controller/pci-aardvark.c b/drivers/pci/controller/pci-aardvark.c index ffec82c8a523..62db476a8651 100644 --- a/drivers/pci/controller/pci-aardvark.c +++ b/drivers/pci/controller/pci-aardvark.c @@ -8,6 +8,7 @@ * Author: Hezi Shahmoon */ +#include #include #include #include @@ -857,14 +858,11 @@ advk_pci_bridge_emul_pcie_conf_read(struct pci_bridge_emul *bridge, switch (reg) { - case PCI_EXP_SLTCTL: - *value = PCI_EXP_SLTSTA_PDS << 16; - return PCI_BRIDGE_EMUL_HANDLED; - /* - * PCI_EXP_RTCTL and PCI_EXP_RTSTA are also supported, but do not need - * to be handled here, because their values are stored in emulated - * config space buffer, and we read them from there when needed. + * PCI_EXP_SLTCAP, PCI_EXP_SLTCTL, PCI_EXP_RTCTL and PCI_EXP_RTSTA are + * also supported, but do not need to be handled here, because their + * values are stored in emulated config space buffer, and we read them + * from there when needed. */ case PCI_EXP_LNKCAP: { @@ -977,8 +975,25 @@ static int advk_sw_pci_bridge_init(struct advk_pcie *pcie) /* Support interrupt A for MSI feature */ bridge->conf.intpin = PCI_INTERRUPT_INTA; - /* Aardvark HW provides PCIe Capability structure in version 2 */ - bridge->pcie_conf.cap = cpu_to_le16(2); + /* + * Aardvark HW provides PCIe Capability structure in version 2 and + * indicate slot support, which is emulated. + */ + bridge->pcie_conf.cap = cpu_to_le16(2 | PCI_EXP_FLAGS_SLOT); + + /* + * Set Presence Detect State bit permanently since there is no support + * for unplugging the card nor detecting whether it is plugged. (If a + * platform exists in the future that supports it, via a GPIO for + * example, it should be implemented via this bit.) + * + * Set physical slot number to 1 since there is only one port and zero + * value is reserved for ports within the same silicon as Root Port + * which is not our case. + */ + bridge->pcie_conf.slotcap = cpu_to_le32(FIELD_PREP(PCI_EXP_SLTCAP_PSN, + 1)); + bridge->pcie_conf.slotsta = cpu_to_le16(PCI_EXP_SLTSTA_PDS); /* Indicates supports for Completion Retry Status */ bridge->pcie_conf.rootcap = cpu_to_le16(PCI_EXP_RTCAP_CRSVIS); -- 2.35.1 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 73CF2C25B08 for ; Sun, 14 Aug 2022 15:29:16 +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=X8Cov217U45wqFRvNnScw+5QGdVrvrvcxAVrl4csNPQ=; b=26hpdBwVDCRpJh P2gvFeEsznaMUChNz0uPEX9ruPwvK32cPu+B9iGzFul7wbuoxvZ9osbkgSw75tFrZlY2wOQelRsUR s4BHlUU4lzN3Ivk2cee+U6PZX4DjV+Mf86Jwx47VMN7B7kO1nf1ML4xSMmTbwcNCbFVnXYtRegDps JW9tvaRgcLyHMexYijI+PfAAWNthoFCcQ7Fvs3y8G5boivjPlNBdimOsi0AXvIcKPNhFshcpT0Gft /Skcqj02E06IPjG81F3O8y2ck9h+sjRzopS45J6t0W22b5Wd5qvIh84FXm1h+7IAtZe/1jSNs31L3 qzJGw7DOxkLz/FnCVlPQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1oNFWe-007NDx-0m; Sun, 14 Aug 2022 15:27:40 +0000 Received: from dfw.source.kernel.org ([2604:1380:4641:c500::1]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1oNFWY-007NAw-2D for linux-arm-kernel@lists.infradead.org; Sun, 14 Aug 2022 15:27:35 +0000 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 70B4460C0B; Sun, 14 Aug 2022 15:27:33 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id C4449C433C1; Sun, 14 Aug 2022 15:27:31 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1660490852; bh=5GyLM1CyVv10Ove+YIIf3oMlmnKfA55OKySxx0jDfxA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=A67viJI2thCRSB5Fr624goC6G8U1y/41RffDWMv3el7/1F5562HU7+47a5YiiP9Ot TysGLZucmttPDDe19UCllhJRbGjjdO+lTNKqdr/axnMHyP1s9OpcWvPpF3u0iriyrQ uiLjl49XE4bTjfYG1at4sIHhvbZuB4+4B9QcN53jzRhvZGyuywshhbVWGoOSR3oiMy zlrcu5+0RPdHL5glYp30e1m95EwxtmV+Vfc2BvC0W2q9kqaGyTV7Fy0mGwObry0X1v cNMHHoajVxJQOIbWVerTbdoquP7uleM1qwZEF+VVtbbB5ia36TLPHB85Toy00u2UOp xZ436PF4wxogA== From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: =?UTF-8?q?Pali=20Roh=C3=A1r?= , =?UTF-8?q?Marek=20Beh=C3=BAn?= , Bjorn Helgaas , Sasha Levin , thomas.petazzoni@bootlin.com, lpieralisi@kernel.org, linux-pci@vger.kernel.org, linux-arm-kernel@lists.infradead.org Subject: [PATCH AUTOSEL 5.19 12/64] PCI: aardvark: Fix reporting Slot capabilities on emulated bridge Date: Sun, 14 Aug 2022 11:23:45 -0400 Message-Id: <20220814152437.2374207-12-sashal@kernel.org> X-Mailer: git-send-email 2.35.1 In-Reply-To: <20220814152437.2374207-1-sashal@kernel.org> References: <20220814152437.2374207-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220814_082734_211095_815BC2CE X-CRM114-Status: GOOD ( 18.90 ) 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 RnJvbTogUGFsaSBSb2jDoXIgPHBhbGlAa2VybmVsLm9yZz4KClsgVXBzdHJlYW0gY29tbWl0IGJj ZGI2ZmQ0ZjNlOWFjMTA5NzY5OGM4ZDhmNTZiNzA4NTNiNDk4NzMgXQoKU2xvdCBjYXBhYmlsaXRp ZXMgYXJlIGN1cnJlbnRseSBub3QgcmVwb3J0ZWQgYmVjYXVzZSBlbXVsYXRlZCBicmlkZ2UgZG9l cwpub3QgcmVwb3J0IHRoZSBQQ0lfRVhQX0ZMQUdTX1NMT1QgZmxhZy4KClNldCBQQ0lfRVhQX0ZM QUdTX1NMT1QgdG8gbGV0IHRoZSBrZXJuZWwga25vdyB0aGF0IFBDSV9FWFBfU0xUKiByZWdpc3Rl cnMKYXJlIHN1cHBvcnRlZC4KCk1vdmUgc2V0dGluZyBvZiBQQ0lfRVhQX1NMVENUTCByZWdpc3Rl ciBmcm9tICJkeW5hbWljIiBwY2llX2NvbmZfcmVhZApmdW5jdGlvbiB0byBzdGF0aWMgYnVmZmVy IGFzIGl0IGlzIG9ubHkgc3RhdGljYWxseSBmaWxsZWQgdGhlClBDSV9FWFBfU0xUU1RBX1BEUyBm bGFnIGFuZCBkeW5hbWljIHJlYWQgY2FsbGJhY2sgaXMgbm90IG5lZWRlZCBmb3IgdGhpcwpyZWdp c3Rlci4KClNldCBQcmVzZW5jZSBTdGF0ZSBCaXQgdG8gMSBzaW5jZSB0aGVyZSBpcyBubyBzdXBw b3J0IGZvciB1bnBsdWdnaW5nIHRoZQpjYXJkIGFuZCB0aGVyZSBpcyBjdXJyZW50bHkgbm8gcGxh dGZvcm0gYWJsZSB0byBkZXRlY3QgcHJlc2VuY2Ugb2YgYSBjYXJkIC0KaW4gc3VjaCBhIGNhc2Ug dGhlIGJpdCBuZWVkcyB0byBiZSBzZXQgdG8gMS4KCkZpbmFsbHkgY29ycmVjdGx5IHNldCBQaHlz aWNhbCBTbG90IE51bWJlciB0byAxIHNpbmNlIHRoZXJlIGlzIG9ubHkgb25lCnBvcnQgYW5kIHpl cm8gdmFsdWUgaXMgcmVzZXJ2ZWQgZm9yIHBvcnRzIHdpdGhpbiB0aGUgc2FtZSBzaWxpY29uIGFz IFJvb3QKUG9ydCB3aGljaCBpcyBub3Qgb3VyIGNhc2UgZm9yIEFhcmR2YXJrIEhXLgoKTGluazog aHR0cHM6Ly9sb3JlLmtlcm5lbC5vcmcvci8yMDIyMDUyNDEzMjgyNy44ODM3LTMta2FiZWxAa2Vy bmVsLm9yZwpTaWduZWQtb2ZmLWJ5OiBQYWxpIFJvaMOhciA8cGFsaUBrZXJuZWwub3JnPgpTaWdu ZWQtb2ZmLWJ5OiBNYXJlayBCZWjDum4gPGthYmVsQGtlcm5lbC5vcmc+ClNpZ25lZC1vZmYtYnk6 IEJqb3JuIEhlbGdhYXMgPGJoZWxnYWFzQGdvb2dsZS5jb20+ClNpZ25lZC1vZmYtYnk6IFNhc2hh IExldmluIDxzYXNoYWxAa2VybmVsLm9yZz4KLS0tCiBkcml2ZXJzL3BjaS9jb250cm9sbGVyL3Bj aS1hYXJkdmFyay5jIHwgMzMgKysrKysrKysrKysrKysrKysrKy0tLS0tLS0tCiAxIGZpbGUgY2hh bmdlZCwgMjQgaW5zZXJ0aW9ucygrKSwgOSBkZWxldGlvbnMoLSkKCmRpZmYgLS1naXQgYS9kcml2 ZXJzL3BjaS9jb250cm9sbGVyL3BjaS1hYXJkdmFyay5jIGIvZHJpdmVycy9wY2kvY29udHJvbGxl ci9wY2ktYWFyZHZhcmsuYwppbmRleCBmZmVjODJjOGE1MjMuLjYyZGI0NzZhODY1MSAxMDA2NDQK LS0tIGEvZHJpdmVycy9wY2kvY29udHJvbGxlci9wY2ktYWFyZHZhcmsuYworKysgYi9kcml2ZXJz L3BjaS9jb250cm9sbGVyL3BjaS1hYXJkdmFyay5jCkBAIC04LDYgKzgsNyBAQAogICogQXV0aG9y OiBIZXppIFNoYWhtb29uIDxoZXppLnNoYWhtb29uQG1hcnZlbGwuY29tPgogICovCiAKKyNpbmNs dWRlIDxsaW51eC9iaXRmaWVsZC5oPgogI2luY2x1ZGUgPGxpbnV4L2RlbGF5Lmg+CiAjaW5jbHVk ZSA8bGludXgvZ3Bpby9jb25zdW1lci5oPgogI2luY2x1ZGUgPGxpbnV4L2ludGVycnVwdC5oPgpA QCAtODU3LDE0ICs4NTgsMTEgQEAgYWR2a19wY2lfYnJpZGdlX2VtdWxfcGNpZV9jb25mX3JlYWQo c3RydWN0IHBjaV9icmlkZ2VfZW11bCAqYnJpZGdlLAogCiAKIAlzd2l0Y2ggKHJlZykgewotCWNh c2UgUENJX0VYUF9TTFRDVEw6Ci0JCSp2YWx1ZSA9IFBDSV9FWFBfU0xUU1RBX1BEUyA8PCAxNjsK LQkJcmV0dXJuIFBDSV9CUklER0VfRU1VTF9IQU5ETEVEOwotCiAJLyoKLQkgKiBQQ0lfRVhQX1JU Q1RMIGFuZCBQQ0lfRVhQX1JUU1RBIGFyZSBhbHNvIHN1cHBvcnRlZCwgYnV0IGRvIG5vdCBuZWVk Ci0JICogdG8gYmUgaGFuZGxlZCBoZXJlLCBiZWNhdXNlIHRoZWlyIHZhbHVlcyBhcmUgc3RvcmVk IGluIGVtdWxhdGVkCi0JICogY29uZmlnIHNwYWNlIGJ1ZmZlciwgYW5kIHdlIHJlYWQgdGhlbSBm cm9tIHRoZXJlIHdoZW4gbmVlZGVkLgorCSAqIFBDSV9FWFBfU0xUQ0FQLCBQQ0lfRVhQX1NMVENU TCwgUENJX0VYUF9SVENUTCBhbmQgUENJX0VYUF9SVFNUQSBhcmUKKwkgKiBhbHNvIHN1cHBvcnRl ZCwgYnV0IGRvIG5vdCBuZWVkIHRvIGJlIGhhbmRsZWQgaGVyZSwgYmVjYXVzZSB0aGVpcgorCSAq IHZhbHVlcyBhcmUgc3RvcmVkIGluIGVtdWxhdGVkIGNvbmZpZyBzcGFjZSBidWZmZXIsIGFuZCB3 ZSByZWFkIHRoZW0KKwkgKiBmcm9tIHRoZXJlIHdoZW4gbmVlZGVkLgogCSAqLwogCiAJY2FzZSBQ Q0lfRVhQX0xOS0NBUDogewpAQCAtOTc3LDggKzk3NSwyNSBAQCBzdGF0aWMgaW50IGFkdmtfc3df cGNpX2JyaWRnZV9pbml0KHN0cnVjdCBhZHZrX3BjaWUgKnBjaWUpCiAJLyogU3VwcG9ydCBpbnRl cnJ1cHQgQSBmb3IgTVNJIGZlYXR1cmUgKi8KIAlicmlkZ2UtPmNvbmYuaW50cGluID0gUENJX0lO VEVSUlVQVF9JTlRBOwogCi0JLyogQWFyZHZhcmsgSFcgcHJvdmlkZXMgUENJZSBDYXBhYmlsaXR5 IHN0cnVjdHVyZSBpbiB2ZXJzaW9uIDIgKi8KLQlicmlkZ2UtPnBjaWVfY29uZi5jYXAgPSBjcHVf dG9fbGUxNigyKTsKKwkvKgorCSAqIEFhcmR2YXJrIEhXIHByb3ZpZGVzIFBDSWUgQ2FwYWJpbGl0 eSBzdHJ1Y3R1cmUgaW4gdmVyc2lvbiAyIGFuZAorCSAqIGluZGljYXRlIHNsb3Qgc3VwcG9ydCwg d2hpY2ggaXMgZW11bGF0ZWQuCisJICovCisJYnJpZGdlLT5wY2llX2NvbmYuY2FwID0gY3B1X3Rv X2xlMTYoMiB8IFBDSV9FWFBfRkxBR1NfU0xPVCk7CisKKwkvKgorCSAqIFNldCBQcmVzZW5jZSBE ZXRlY3QgU3RhdGUgYml0IHBlcm1hbmVudGx5IHNpbmNlIHRoZXJlIGlzIG5vIHN1cHBvcnQKKwkg KiBmb3IgdW5wbHVnZ2luZyB0aGUgY2FyZCBub3IgZGV0ZWN0aW5nIHdoZXRoZXIgaXQgaXMgcGx1 Z2dlZC4gKElmIGEKKwkgKiBwbGF0Zm9ybSBleGlzdHMgaW4gdGhlIGZ1dHVyZSB0aGF0IHN1cHBv cnRzIGl0LCB2aWEgYSBHUElPIGZvcgorCSAqIGV4YW1wbGUsIGl0IHNob3VsZCBiZSBpbXBsZW1l bnRlZCB2aWEgdGhpcyBiaXQuKQorCSAqCisJICogU2V0IHBoeXNpY2FsIHNsb3QgbnVtYmVyIHRv IDEgc2luY2UgdGhlcmUgaXMgb25seSBvbmUgcG9ydCBhbmQgemVybworCSAqIHZhbHVlIGlzIHJl c2VydmVkIGZvciBwb3J0cyB3aXRoaW4gdGhlIHNhbWUgc2lsaWNvbiBhcyBSb290IFBvcnQKKwkg KiB3aGljaCBpcyBub3Qgb3VyIGNhc2UuCisJICovCisJYnJpZGdlLT5wY2llX2NvbmYuc2xvdGNh cCA9IGNwdV90b19sZTMyKEZJRUxEX1BSRVAoUENJX0VYUF9TTFRDQVBfUFNOLAorCQkJCQkJCSAg IDEpKTsKKwlicmlkZ2UtPnBjaWVfY29uZi5zbG90c3RhID0gY3B1X3RvX2xlMTYoUENJX0VYUF9T TFRTVEFfUERTKTsKIAogCS8qIEluZGljYXRlcyBzdXBwb3J0cyBmb3IgQ29tcGxldGlvbiBSZXRy eSBTdGF0dXMgKi8KIAlicmlkZ2UtPnBjaWVfY29uZi5yb290Y2FwID0gY3B1X3RvX2xlMTYoUENJ X0VYUF9SVENBUF9DUlNWSVMpOwotLSAKMi4zNS4xCgoKX19fX19fX19fX19fX19fX19fX19fX19f X19fX19fX19fX19fX19fX19fX19fX18KbGludXgtYXJtLWtlcm5lbCBtYWlsaW5nIGxpc3QKbGlu dXgtYXJtLWtlcm5lbEBsaXN0cy5pbmZyYWRlYWQub3JnCmh0dHA6Ly9saXN0cy5pbmZyYWRlYWQu b3JnL21haWxtYW4vbGlzdGluZm8vbGludXgtYXJtLWtlcm5lbAo=