From nobody Sun Apr 12 00:53:09 2026 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 04C64C19F28 for ; Wed, 3 Aug 2022 12:27:38 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237967AbiHCM1g (ORCPT ); Wed, 3 Aug 2022 08:27:36 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:32908 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238070AbiHCM1N (ORCPT ); Wed, 3 Aug 2022 08:27:13 -0400 Received: from NAM12-DM6-obe.outbound.protection.outlook.com (mail-dm6nam12on2081.outbound.protection.outlook.com [40.107.243.81]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A9DA71A83B for ; Wed, 3 Aug 2022 05:27:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=Hk1zkJzDtlQm1gjsHXlCwHesnf6bbbZhziysphIWkiDqsU3zlqZZlYVv/tJAD1IokqCybzAHNoZvFKT3OQA/jaY0XrZISxN25uAtGxMWAWiix3mbqnfYvj2N2weLMJmLh5zysXX+tFNLKM1q9SktxFp9AfQ8oXCaOuNBgvYm25y1nYTZtPDYkYIne+tp3BA9ObQG/14xJ5Qpz9IQ7JvzYkIZFpgEV7wZKvcmUYR/MtlB4qJm2eEKgstia+kDX+r463d6otpDuLRM65vNm9evaZ3F2ov13ROGVjPJ50uE4V2k3gv4NUo/AgMrTT/FsM+BshSgdvagYWZUMDyrPvJa6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=XfIVfuOCDXtVtXB6ZrZ4HmxHRTWObBWCu3jDeTkx16k=; b=kRhMsyuZl5D5eyY2rSjoqo6MNMzDUvAJxw/AcCueC9640TMCUuyXkuDZEz5SFOpUCvBR5yK7fJl9fj/BPaf2h55cJj2B/ZqGKdlCqTYbcBPI15bhjb16EjVdFJTGg2a+2L0Q7emgcJTg9U3DiZLZ1xA3d8J12r3Rndf2c1XaKoLekLMdql5zigWujhlImxA+WUvaGVeRuXX8rLrZwRCP3ecUZLKaIS7kwpXXCSJWdYukCWxzqKw+/8qKof+8IcNtPOUaUIKKzgfpVmSIkGnqyN0gDUmi93b3mJK+4Zo9/izwG5DQa4QZKAfjLykeQedWDJne7mneHgwwzA6mrLN9GQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=vger.kernel.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=XfIVfuOCDXtVtXB6ZrZ4HmxHRTWObBWCu3jDeTkx16k=; b=UHkyQKd+eBuqpWviDHQyNSY+1f1+ZAOUvPV91JgHn1y+OT68gcQktvi3wWVfFcAfXTxm2u+SvamXoUxCBQwY6CLVk510RERXYyAU9bW0C0cvX2QPWI2Y5bvceG7Wn6LQtKJpq3/GfNXuQhJjVBN5jndWk8RNUFnBQVGK+37pNPM= Received: from BN9PR03CA0101.namprd03.prod.outlook.com (2603:10b6:408:fd::16) by PH7PR12MB5656.namprd12.prod.outlook.com (2603:10b6:510:13b::10) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5482.16; Wed, 3 Aug 2022 12:27:08 +0000 Received: from BN8NAM11FT060.eop-nam11.prod.protection.outlook.com (2603:10b6:408:fd:cafe::fc) by BN9PR03CA0101.outlook.office365.com (2603:10b6:408:fd::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5482.14 via Frontend Transport; Wed, 3 Aug 2022 12:27:08 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by BN8NAM11FT060.mail.protection.outlook.com (10.13.177.211) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5504.14 via Frontend Transport; Wed, 3 Aug 2022 12:27:08 +0000 Received: from SATLEXMB05.amd.com (10.181.40.146) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Wed, 3 Aug 2022 07:27:08 -0500 Received: from SATLEXMB04.amd.com (10.181.40.145) by SATLEXMB05.amd.com (10.181.40.146) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Wed, 3 Aug 2022 07:27:07 -0500 Received: from xhdipdslab49.xilinx.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server id 15.1.2375.28 via Frontend Transport; Wed, 3 Aug 2022 07:27:04 -0500 From: Nipun Gupta To: , , , , , CC: , , , , Nipun Gupta Subject: [RFC PATCH 1/2] irqchip: cdx-bus: add cdx-MSI domain with gic-its domain as parent Date: Wed, 3 Aug 2022 17:56:54 +0530 Message-ID: <20220803122655.100254-2-nipun.gupta@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220803122655.100254-1-nipun.gupta@amd.com> References: <20220803122655.100254-1-nipun.gupta@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 7938ca3e-e5cd-4511-56dd-08da754b7bcd X-MS-TrafficTypeDiagnostic: PH7PR12MB5656:EE_ X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: q7id9rWlHwUH7Gqz81V/8UhYUz5dEFOT+g5WTH9hrBIop89dUWXvTidWVMGiDZEIrlhVN4mH14GtYYdtFcNubhtAtKp7sBSX3ubNq7q06+qiVVmNi6KUMUCrm7REvnGkNMaBpBMfb3QDkGeW3H2825Z3RpTr7DUDGszge4GGBm/9bGp/HyMAuduJH2cP9nc5yqU2uPpwyhWjmYsXeZuZigwmIIDjHzlxOp6qs/dlBrqmTnIGhmaE4/mZIN16+vNAp2FlDDxyQtnGwE72wkMMXaBW0RzvDjfTQRd/ZqkSKZtA+5CEFMM6miwiD1SUStShC9eOMmJ7WhW1CL7AnKKLivacNe7CUlZ6HrXwlCcVZRy3lkCZcxsuEsZK6XKWQdVVt5hTVIrk6t/aKDLEphW/8iydNbslfpGgi2yHAhi7bbFPRH7RdLHIWmhnxqkZvRdVUfIM8ML7WZ9DMlVyzZLmnyS/YHSHyCqNbVmnJtDTkK1FXj/No5Sce4vW7EZaZeanT185wh/ejDHwFqpwVlBrlC+vZ2EIXvWx+21PEGWisAP0kS/eVm0dPClV+277RjIcomyDIeai2t6ln3VUxJge+5DnOhcaLnFbgEbrPyhJpxk7K4zAR3nJs4CiZdX5wUCUEcfw+7CyDY4DQxlj8kbdOw7PMQrJnnsI6xxPwYVOoVTEbVeyPNEjlumTZ/wwe7Ml9cY1Uy4AMTD49sHfEpD76GZt3raiBcALDXUhrde49x1p8QH2nDJ7ueTM8zsVS7yC5SYgg0+/W1XQEDvB4KJA8CsAQhEvQE195MFmXa9WjqIVCF87Tcu8yq1oJJMmtBZavSjGpzPmXr4SzNn04AVgF8OgDm84u8CZNWqN42nlIv0= X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230016)(4636009)(396003)(39860400002)(136003)(376002)(346002)(36840700001)(46966006)(40470700004)(70206006)(70586007)(8676002)(4326008)(82740400003)(40460700003)(356005)(44832011)(81166007)(86362001)(41300700001)(8936002)(40480700001)(2906002)(5660300002)(478600001)(26005)(6666004)(54906003)(83380400001)(110136005)(36860700001)(2616005)(47076005)(426003)(1076003)(82310400005)(316002)(186003)(336012)(36756003)(2101003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Aug 2022 12:27:08.5773 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 7938ca3e-e5cd-4511-56dd-08da754b7bcd X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: BN8NAM11FT060.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: PH7PR12MB5656 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" Devices on cdx bus are dynamically detected and registered using platform_device_register API. As these devices are not linked to of node they need a separate MSI domain for handling device ID to be provided to the GIC ITS domain. Signed-off-by: Nipun Gupta Signed-off-by: Nikhil Agarwal --- CONFIG_CDX_BUS and device tree bindings for xlnx,cdx-controller-1.0 would be added as part of CDX bus patches drivers/irqchip/Makefile | 1 + drivers/irqchip/irq-gic-v3-its-cdx-msi.c | 113 +++++++++++++++++++++++ include/linux/cdx/cdx.h | 15 +++ 3 files changed, 129 insertions(+) create mode 100644 drivers/irqchip/irq-gic-v3-its-cdx-msi.c create mode 100644 include/linux/cdx/cdx.h diff --git a/drivers/irqchip/Makefile b/drivers/irqchip/Makefile index 5b67450a9538..623adb8a1f20 100644 --- a/drivers/irqchip/Makefile +++ b/drivers/irqchip/Makefile @@ -115,3 +115,4 @@ obj-$(CONFIG_WPCM450_AIC) +=3D irq-wpcm450-aic.o obj-$(CONFIG_IRQ_IDT3243X) +=3D irq-idt3243x.o obj-$(CONFIG_APPLE_AIC) +=3D irq-apple-aic.o obj-$(CONFIG_MCHP_EIC) +=3D irq-mchp-eic.o +obj-$(CONFIG_CDX_BUS) +=3D irq-gic-v3-its-cdx-msi.o diff --git a/drivers/irqchip/irq-gic-v3-its-cdx-msi.c b/drivers/irqchip/irq= -gic-v3-its-cdx-msi.c new file mode 100644 index 000000000000..eb17b74efdc5 --- /dev/null +++ b/drivers/irqchip/irq-gic-v3-its-cdx-msi.c @@ -0,0 +1,113 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * AMD CDX bus driver MSI support + * + * Copyright(C) 2022 Xilinx Inc. + */ + +#include +#include +#include +#include +#include +#include +#include + +static struct irq_chip its_msi_irq_chip =3D { + .name =3D "ITS-fMSI", + .irq_mask =3D irq_chip_mask_parent, + .irq_unmask =3D irq_chip_unmask_parent, + .irq_eoi =3D irq_chip_eoi_parent, + .irq_set_affinity =3D msi_domain_set_affinity +}; + +static int its_cdx_msi_prepare(struct irq_domain *msi_domain, + struct device *dev, + int nvec, msi_alloc_info_t *info) +{ + struct msi_domain_info *msi_info; + struct cdx_device_data *dev_data; + u32 dev_id; + + dev_data =3D dev->platform_data; + dev_id =3D dev_data->dev_id; + + /* Set the device Id to be passed to the GIC-ITS */ + info->scratchpad[0].ul =3D dev_id; + + msi_info =3D msi_get_domain_info(msi_domain->parent); + + /* Allocate at least 32 MSIs, and always as a power of 2 */ + nvec =3D max_t(int, 32, roundup_pow_of_two(nvec)); + return msi_info->ops->msi_prepare(msi_domain->parent, dev, nvec, info); +} + +static struct msi_domain_ops its_cdx_msi_ops __ro_after_init =3D { + .msi_prepare =3D its_cdx_msi_prepare, +}; + +static struct msi_domain_info its_cdx_msi_domain_info =3D { + .flags =3D (MSI_FLAG_USE_DEF_DOM_OPS | MSI_FLAG_USE_DEF_CHIP_OPS), + .ops =3D &its_cdx_msi_ops, + .chip =3D &its_msi_irq_chip, +}; + +static const struct of_device_id cdx_device_id[] =3D { + {.compatible =3D "xlnx,cdx-controller-1.0", }, + {}, +}; + +struct irq_domain *get_parent(struct fwnode_handle *handle) +{ + return irq_find_matching_fwnode(handle, DOMAIN_BUS_NEXUS); +} + +static void __init its_cdx_msi_init_one(struct device_node *np, + const char *name) +{ + struct irq_domain *parent; + struct irq_domain *cdx_msi_domain; + struct fwnode_handle *fwnode_handle; + struct device_node *parent_node; + + parent_node =3D of_parse_phandle(np, "msi-parent", 0); + + parent =3D get_parent(of_node_to_fwnode(parent_node)); + if (!parent || !msi_get_domain_info(parent)) { + pr_err("%s: unable to locate ITS domain\n", name); + return; + } + + fwnode_handle =3D of_node_to_fwnode(np); + cdx_msi_domain =3D platform_msi_create_irq_domain(fwnode_handle, + &its_cdx_msi_domain_info, + parent); + if (!cdx_msi_domain) { + pr_err("%s: unable to create cdx bus domain\n", name); + return; + } + + pr_info("cdx bus MSI: %s domain created\n", name); +} + +static void __init its_cdx_of_msi_init(void) +{ + struct device_node *np; + + for (np =3D of_find_matching_node(NULL, cdx_device_id); np; + np =3D of_find_matching_node(np, cdx_device_id)) { + if (!of_device_is_available(np)) + continue; + + its_cdx_msi_init_one(np, np->full_name); + } +} + +static int __init its_cdx_msi_init(void) +{ + its_cdx_of_msi_init(); + + return 0; +} + +early_initcall(its_cdx_msi_init); diff --git a/include/linux/cdx/cdx.h b/include/linux/cdx/cdx.h new file mode 100644 index 000000000000..244ad721771d --- /dev/null +++ b/include/linux/cdx/cdx.h @@ -0,0 +1,15 @@ +/* SPDX-License-Identifier: GPL-2.0 */ +/* + * AMD CDX bus public interface + * + * Copyright(C) 2022 Xilinx Inc. + */ + +#ifndef _CDX_H_ +#define _CDX_H_ + +struct cdx_device_data { + int dev_id; +}; + +#endif /* _CDX_H_ */ --=20 2.25.1 From nobody Sun Apr 12 00:53:09 2026 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 D1957C19F28 for ; Wed, 3 Aug 2022 12:27:41 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S237971AbiHCM1j (ORCPT ); Wed, 3 Aug 2022 08:27:39 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:34720 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237945AbiHCM1V (ORCPT ); Wed, 3 Aug 2022 08:27:21 -0400 Received: from NAM10-BN7-obe.outbound.protection.outlook.com (mail-bn7nam10on2069.outbound.protection.outlook.com [40.107.92.69]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4E26653D00 for ; Wed, 3 Aug 2022 05:27:15 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=oYCar9gc/Hn2ktVOU3JF3e0gEcL0STnuJiDIVdtieBTsG+Jl/O+2O0cOL20VkFoVMVwzFjChNOMCColnWHeh7lqM1MPojWAaJD49Kgh+XH7YaOaUXwdLaby1bq7CeaYrPO+yD7dlEzgaHvFgikdBO9I3LeWuO37J4aGB40+Fsx0UkzuouOIcUWOB4BJH3L+Nb1Vqwbuwax0cENqN8Xn8cFEtYKiON2IUodrkZvJQrJ58JL8cFoMdjnjffI4y1NEbBJl3MwDMoff1i5ECF3Ugds8CPv/V4DTY/uVX2k/axbO4vWIEWowq+5SJ99nEYhTGlugMg5ZFJS462IBlXSaSew== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector9901; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=6Q7MHKEDtcRPDgbi9IX5EtqQnXbIhQbT/SKcHxC8gro=; b=h3EA9OsFnCvuKW5DdacHKvMdYt9Isj6f2oSHIAz8Pfl60UETAG8vUDN1GtDIfNczHbsajqg7W6ciyDO+QwNIV2n129VUCfDc1+rq5FGDLmdlvgOzxMJGkKkoPNFervGCpOt7vEx5WQLF2JfIMVtTVtRJkZ9ps08Js6Xdy1qJhL5PotW5VhUH5ecnsi3VWUdo94iCyoZ+JDYefGGGt4EbIXPRJiM4hrvBAc38KlzPUBaPeg64r5D+6s597SJYlJ1RKq8M595zTvJ/40medWJ4evFWt304NnRdCwppHOkh+wKrdNlKmKBCx5ZmbC8jEWdYjUBRs1Tb4UtwrLxnCKPIDw== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass (sender ip is 165.204.84.17) smtp.rcpttodomain=vger.kernel.org smtp.mailfrom=amd.com; dmarc=pass (p=quarantine sp=quarantine pct=100) action=none header.from=amd.com; dkim=none (message not signed); arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=amd.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=6Q7MHKEDtcRPDgbi9IX5EtqQnXbIhQbT/SKcHxC8gro=; b=hiU4LUwLRHMgzo1B83w3ZtHaUzF12kMqzllN3xvWqNEfm/JRzS2tkDWtHSlFjSCG35zzjplBrYDgKf+XumgT8IRjMilYBggFO/tD1LPOWlIj004G060nb3IoXVRjQRSdr90/K0d8gWktcR7qN5WiqUCpG609AMvnpgkTHHUq52Y= Received: from BN0PR04CA0187.namprd04.prod.outlook.com (2603:10b6:408:e9::12) by CY8PR12MB7340.namprd12.prod.outlook.com (2603:10b6:930:50::16) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5504.14; Wed, 3 Aug 2022 12:27:13 +0000 Received: from BN8NAM11FT040.eop-nam11.prod.protection.outlook.com (2603:10b6:408:e9:cafe::c6) by BN0PR04CA0187.outlook.office365.com (2603:10b6:408:e9::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5482.10 via Frontend Transport; Wed, 3 Aug 2022 12:27:13 +0000 X-MS-Exchange-Authentication-Results: spf=pass (sender IP is 165.204.84.17) smtp.mailfrom=amd.com; dkim=none (message not signed) header.d=none;dmarc=pass action=none header.from=amd.com; Received-SPF: Pass (protection.outlook.com: domain of amd.com designates 165.204.84.17 as permitted sender) receiver=protection.outlook.com; client-ip=165.204.84.17; helo=SATLEXMB04.amd.com; pr=C Received: from SATLEXMB04.amd.com (165.204.84.17) by BN8NAM11FT040.mail.protection.outlook.com (10.13.177.166) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.20.5504.14 via Frontend Transport; Wed, 3 Aug 2022 12:27:12 +0000 Received: from SATLEXMB05.amd.com (10.181.40.146) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Wed, 3 Aug 2022 07:27:11 -0500 Received: from SATLEXMB04.amd.com (10.181.40.145) by SATLEXMB05.amd.com (10.181.40.146) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.28; Wed, 3 Aug 2022 07:27:11 -0500 Received: from xhdipdslab49.xilinx.com (10.180.168.240) by SATLEXMB04.amd.com (10.181.40.145) with Microsoft SMTP Server id 15.1.2375.28 via Frontend Transport; Wed, 3 Aug 2022 07:27:08 -0500 From: Nipun Gupta To: , , , , , CC: , , , , Nipun Gupta Subject: [RFC PATCH 2/2] driver core: add compatible string in sysfs for platform devices Date: Wed, 3 Aug 2022 17:56:55 +0530 Message-ID: <20220803122655.100254-3-nipun.gupta@amd.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220803122655.100254-1-nipun.gupta@amd.com> References: <20220803122655.100254-1-nipun.gupta@amd.com> MIME-Version: 1.0 Content-Transfer-Encoding: quoted-printable X-EOPAttributedMessage: 0 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 0d0df5ff-af4e-424c-d4bd-08da754b7e6e X-MS-TrafficTypeDiagnostic: CY8PR12MB7340:EE_ X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 9co+kn22O1OAtYuvSjwhMEYAznwRzF+yrr8k1mMdie6d40wGzRya35ixyb6EDyxdLhYDURSA4ucsYAa+tW4SjOL+fbmXmqyrytANpqY/F0pl0rbvRnrhpzZQEfW0itnKsmMhiCwZNYVAPvppL5hpDno/TaoMPUz6wrzjSljSGhJdKzB9nS6pTsuGXjGLFX0b3BxLIyiabaBBzsE2aUs6lXq3AWqoFfjy35BARdnvIzMbA6yz8f0F4324EBs/dhzm7CRUrMLo8bFj6NxS4eZ8wc5xu9eBRB9kNuBBe/eHetzycBOeqTBpSHOaSgKK3zmtfEQobt74daDF2VMrMyGH6JH8CBaJzAisAiFAlqi5NheUVJvJdBk2QKQ/ikU9nHtooN9bwNwFa0dn/ldXcyykSW/2/hF4D/FDLA8+EPdDc5IfeBtSzU6QkZKgUl8sEbFcqn+qOr9YQm9h91cJAq1FrJmAsCbOq5R39nGz2WNdIG/PYalTRolmG6vNBhj8fpWJs5iukIIRmiqNIiYU2Gk4AqbC8KrosBC6+xUF2NV7nCBrMbsmZbxi76HDIpWN9Lyb8rPZLb3HuahA+qDIpnLiOSRrIHeMLu4L9MSXy6vlbd9r6pgY9FE4S3oiASsGjmFpWCIzS9PFCQ+eJHq2v/KcToINu3LwwkIFHzH9ApWkJoq6vTD1rRWnMD1gzkJnMSss3ksG8zShwAZMtrE1F+aVy+JCUVFOXAh4tFjpVN5HSWrQYaQzPwxAedVPZJuRkEWc7e/VKBfFVANpq0fH626FOhLJ0yAy+O97lLywf1iy3zU7bjrg0OZmgXE7pBePkm2o03oZGjN2QKzWp7/9fuH/lwLfaAbaX4SyT8GLNdV4RfA= X-Forefront-Antispam-Report: CIP:165.204.84.17;CTRY:US;LANG:en;SCL:1;SRV:;IPV:CAL;SFV:NSPM;H:SATLEXMB04.amd.com;PTR:InfoDomainNonexistent;CAT:NONE;SFS:(13230016)(4636009)(346002)(39860400002)(376002)(396003)(136003)(36840700001)(46966006)(40470700004)(44832011)(82310400005)(356005)(316002)(2906002)(86362001)(4326008)(8936002)(82740400003)(5660300002)(70206006)(70586007)(8676002)(81166007)(478600001)(2616005)(1076003)(40460700003)(426003)(36860700001)(6666004)(336012)(47076005)(26005)(41300700001)(186003)(40480700001)(36756003)(54906003)(110136005)(2101003)(36900700001);DIR:OUT;SFP:1101; X-OriginatorOrg: amd.com X-MS-Exchange-CrossTenant-OriginalArrivalTime: 03 Aug 2022 12:27:12.9911 (UTC) X-MS-Exchange-CrossTenant-Network-Message-Id: 0d0df5ff-af4e-424c-d4bd-08da754b7e6e X-MS-Exchange-CrossTenant-Id: 3dd8961f-e488-4e60-8e11-a82d994e183d X-MS-Exchange-CrossTenant-OriginalAttributedTenantConnectingIp: TenantId=3dd8961f-e488-4e60-8e11-a82d994e183d;Ip=[165.204.84.17];Helo=[SATLEXMB04.amd.com] X-MS-Exchange-CrossTenant-AuthSource: BN8NAM11FT040.eop-nam11.prod.protection.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Anonymous X-MS-Exchange-CrossTenant-FromEntityHeader: HybridOnPrem X-MS-Exchange-Transport-CrossTenantHeadersStamped: CY8PR12MB7340 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Type: text/plain; charset="utf-8" For devices registered dynamically using platform_device_register API, this patch exposes the sysfs entry for the compatible string. Signed-off-by: Nipun Gupta --- drivers/base/platform.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/drivers/base/platform.c b/drivers/base/platform.c index 51bb2289865c..89949f88a0a1 100644 --- a/drivers/base/platform.c +++ b/drivers/base/platform.c @@ -1289,10 +1289,25 @@ static ssize_t driver_override_store(struct device = *dev, } static DEVICE_ATTR_RW(driver_override); =20 +static ssize_t compatible_show(struct device *dev, struct device_attribute= *attr, + char *buf) +{ + const char *compat; + int ret; + + ret =3D device_property_read_string(dev, "compatible", &compat); + if (ret !=3D 0) + return 0; + + return sysfs_emit(buf, "%s", compat); +} +static DEVICE_ATTR_RO(compatible); + static struct attribute *platform_dev_attrs[] =3D { &dev_attr_modalias.attr, &dev_attr_numa_node.attr, &dev_attr_driver_override.attr, + &dev_attr_compatible.attr, NULL, }; =20 --=20 2.25.1