From patchwork Wed Jan 8 07:00:18 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Peng Fan X-Patchwork-Id: 13930248 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 D264DE77188 for ; Wed, 8 Jan 2025 07:13:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender:List-Subscribe:List-Help :List-Post:List-Archive:List-Unsubscribe:List-Id:MIME-Version:Cc:To: In-Reply-To:References:Message-Id:Content-Transfer-Encoding:Content-Type: Subject:Date:From:Reply-To:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Owner; bh=ficKDMJHutpnR9+e5tqPHRKXCOVxSEuXA7mZvXVxOjY=; b=jNfMZ1t2o7WUxUC5//Srm35IA+ 33bWuB55crfiKCCqL6eS9aMhgeTkFrD9+K9eHFrYfVH+80LMlLjfRHGcFR7vF+4W8meJH6oKsiMD/ e90R2+MdIB38nunB4D0wNIygdvcBOhBQtTIE2SSDi41fwePY++VrJf11p5hNU9ao0iLKs8KXEb94P EFSLjx+hUzOczoX6U55ZnVINp0HUW3vuPY0PhKDE+iRG8/iOuXTCpIkhP9Z9acvUl66QEND9BQtTf 0GizVmVbq6IhIOEpKY7KL6ugNZrp+sg58HIm/HnxDH6PeIDNeoa3GO+nOayh/tcT18yeM/E0fYbyA TfKJ5CWQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.98 #2 (Red Hat Linux)) id 1tVQFK-00000007OBN-2MCA; Wed, 08 Jan 2025 07:12:54 +0000 Received: from mail-vi1eur03on2062f.outbound.protection.outlook.com ([2a01:111:f403:260c::62f] helo=EUR03-VI1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.98 #2 (Red Hat Linux)) id 1tVQ44-00000007Kuj-2ZWj for linux-arm-kernel@lists.infradead.org; Wed, 08 Jan 2025 07:01:17 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=TxCJeKvUazaE8s3JEQBogrU6WFzBjR6J3iNVbNCg3QMetBRWH8Rzyc6yZNHcROswrMF7mGR3+0Z4ZdQQZZsDWSPuuNBXTJBfkhbPi2K9mO4whZBZxD42KN5PA2aEYfkA3lfU9nUG2ek5Fltcn49+NQ2aPjj8sT4D8Pqdjm/cKJOAsarOLJ68W2AnFugcts5VQ1/K1La9Ei3FmP1alpVLGyiREkJJG7wmx//Y3UOV0ANtoLLoxLcHCW5xKDhkyhimb08DLuKLyc3W8BhC7BpUpmJM5tW1NikHGfXgzoWKJnG88LSaRSkTV2SnU5ffHovTtoP3e2tlr+t30osHo9bOog== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; 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=ficKDMJHutpnR9+e5tqPHRKXCOVxSEuXA7mZvXVxOjY=; b=vpEWaDmx/Qh4hujduGHLXBIOZp4Ay+Hm8+ZVpoNrDUv0IgkX0ttlsEmQNKHnFofdypduE7Unbp/YBskPaFRoi7YieEIcvz2JTwkEURAppvOj7c8XRru5QrEMq7ofopetssLnfrYW1tD+penNFmIX+wXguQ+16hm/34FAGbCrdV74jhnYDZB41jPaO5asYA3CpX37fq6SW4kIoSi1Ooqoq2UB6HIT3U08PQceBT1zynJ0dyuVw8F9JKEA4Jc77f003fPyVdU0y8O2CLdHqirKeBNs5kqMUuxNNww9CerSmwkGI0lxCxMKaYcavX+Sq2Qgr9KFv3s+t79uyufo+REz+Q== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector1-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=ficKDMJHutpnR9+e5tqPHRKXCOVxSEuXA7mZvXVxOjY=; b=PqtaU6jN7CalDjBxvYv2xxHKYsV3WL8JeC1odvBAflNDhL+MRnLPbW9iuV4GqlTMFR0DZCSePVls7GaU6OQwVg3op7cKbi3HUr6nFrENY3yvDxMxkgaMO+ADByvyK9bF0Ccb7+Z1yxJqNyOMdqfoVtKB3xnQeMjnqBaews7IpxnM/IJ7aDxkHmevE4P2Dyct6PaaBS/4fEs9ngSFjPtl3ZYUD/icT4m9uQ6QO7Wb0VIVPStSHj5hs/h1ISDqVirKNN7vJ025t8ERLOw3LLOLBECk/7yxfs7BjpMCcxNnfTGxm9RzhwlIDwUUA0OLOL2HHYWKa1xgB3dHKz5I15dexA== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from PAXPR04MB8459.eurprd04.prod.outlook.com (2603:10a6:102:1da::15) by DB9PR04MB8299.eurprd04.prod.outlook.com (2603:10a6:10:241::8) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8335.11; Wed, 8 Jan 2025 07:01:13 +0000 Received: from PAXPR04MB8459.eurprd04.prod.outlook.com ([fe80::165a:30a2:5835:9630]) by PAXPR04MB8459.eurprd04.prod.outlook.com ([fe80::165a:30a2:5835:9630%5]) with mapi id 15.20.8335.011; Wed, 8 Jan 2025 07:01:12 +0000 From: "Peng Fan (OSS)" Date: Wed, 08 Jan 2025 15:00:18 +0800 Subject: [PATCH v5 2/2] nvmem: imx-ocotp-ele: Support accessing controller for i.MX9 Message-Id: <20250108-imx-ocotp-v5-2-a6d90e18ebe9@nxp.com> References: <20250108-imx-ocotp-v5-0-a6d90e18ebe9@nxp.com> In-Reply-To: <20250108-imx-ocotp-v5-0-a6d90e18ebe9@nxp.com> To: Srinivas Kandagatla , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Shawn Guo , Sascha Hauer , Pengutronix Kernel Team , Fabio Estevam Cc: devicetree@vger.kernel.org, imx@lists.linux.dev, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Peng Fan X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1736319636; l=8461; i=peng.fan@nxp.com; s=20230812; h=from:subject:message-id; bh=ygBXTu6sPO5G9v1oUfsK+vaVlx3iR8OEqYpTZT/i8Yw=; b=0P6tedobxHgxPhCRN34vbmBija8euo5KL5Lrv+tcVXecTC5b0a3qWri3bbcXT/3qzcxE/PraM I8ggoEqmHeOC7SnPdloNHZYjaQJ/nA3ibLwofRDRa2v7KUAKpKBF6QW X-Developer-Key: i=peng.fan@nxp.com; a=ed25519; pk=I4sJg7atIT1g63H7bb5lDRGR2gJW14RKDD0wFL8TT1g= X-ClientProxiedBy: SG2PR02CA0053.apcprd02.prod.outlook.com (2603:1096:4:54::17) To PAXPR04MB8459.eurprd04.prod.outlook.com (2603:10a6:102:1da::15) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAXPR04MB8459:EE_|DB9PR04MB8299:EE_ X-MS-Office365-Filtering-Correlation-Id: 2c462ade-f0e5-4062-ba3a-08dd2fb23cd3 X-MS-Exchange-SharedMailbox-RoutingAgent-Processed: True X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|376014|7416014|52116014|366016|38350700014; X-Microsoft-Antispam-Message-Info: =?utf-8?q?2sXl5OH8xv10eBSl4z3wLQqp49rtNCA?= =?utf-8?q?fTYlotB6uHwFVQsPLcJK82paIvnwffa6hm/8SQYuzItlpNSowt/P72RxtnEp2/SnI?= =?utf-8?q?YcreinmWusFeGut1gzenxL/HEYr6jP/pkBDJzmyxL8xaf2NMIj+RFUapkMDHkMU4J?= =?utf-8?q?BFwMCftfCikb7n6Vk+qfCD5xo0SSsNzQLb3xFMXHUcggIPc2WqCf5iTcQlEe0JhcC?= =?utf-8?q?EHCaH+MfuIryrSMGg6pcrNVJFL9ZTPJQrCATvhwDYUBm/Oq7Lx5SSD2Uey9qFdu/c?= =?utf-8?q?L4xiYUE+8XBXAJLaI+/mRs3j0Fv0GcDgOJUCnxTvkFW1y8UlbU9jDXAiOZC23t9UL?= =?utf-8?q?f9jo9KZN7uSqAOLmTu02runL8WYL71CeCrnVieM78DJwJfgFLL751n0NP7ATsiH8x?= =?utf-8?q?SLvZU6LWdpUYsvbplW7RrqT4XohiX65xC5NEO7RdiaSqf6JsXuW0LtHKoMdDGoLqI?= =?utf-8?q?V2vdW4M9Tp8wYNoQYc67bOh5sR7Miuuehol6JXjPekGa4lrY+atyGhBpX/4ZvHPw8?= =?utf-8?q?yb5vuVJYIJGklJQJurQwWSZgrU9seiylpvlkOUKZ64a43PpKl1PoTg7ol8yGbH+KK?= =?utf-8?q?ZSGPE+wqe+/sMWt8qmaPGkGDdHyY77MaeIsfq/+sK/77Wn+qGePf/S9iGj8vSI4RR?= =?utf-8?q?QKsEBq6K/zv5WF7bO88ghL7gXFUd2EoFX+KjrJYyvX8szMpM3FkE/pogyzBeW1mXf?= =?utf-8?q?QOD+fg/5ALkRnUEKdSLoqNG7GdRIK15M2FM3Qo3NSHWXKMkFSeNTPouMrqNid8gAU?= =?utf-8?q?h+nP1s/LchDY5Sv2JDeMQG1I7kyJC9M4dNPgmsl7+C2k83RgNHRmRhdU/cQq65sDm?= =?utf-8?q?uzBA0JuOfPjFvPueJ8dnDfvlVOZOT7JdAOU3WSMWBqLjJkhgLVaXbQAEGlPZEX4Fv?= =?utf-8?q?ufcf52TVw6Rtnve9x1GLDXMmHsOQ+urOLYg8UquXH0tnZ02/hypcvnFGBKbothJJe?= =?utf-8?q?WMdTfThZcqC5e/E0mHDSCEa3JBDP4/uT8YdhEUQQG41dlWkOVnrwyIbbLU1V6PWsW?= =?utf-8?q?P6H4DiTmQP6PMdpyHfdeThc4PqzoxeYRJEmvlueOljnAC8+s3Kwc/bliKjf5PR9Mf?= =?utf-8?q?areOcrYdqiEWGwXsFoR6Dtz8aEayyUV9rEH3qplqwxNhYqnqF6qCSLbCcQGKt6hr6?= =?utf-8?q?w5cH8uNqVdDQA4pxYkB3fcTRTI+Sv7Ymbs63ddqoqjSiN13fOuuRd4jduitWAxG9l?= =?utf-8?q?pp0PpvWJ53nUZixCl1WsPC2DyzZviBZ9EbMDh2F4YltW1xBaFWZdQUnAZ58JptqTO?= =?utf-8?q?pxBJCYo5SXv4nj65cYEN1JKVPoq5E9uSfXzAafbWBgOdNeRrQIdFR7KE1wI94CnpZ?= =?utf-8?q?VY1j/LxPGwhkmcsE7PtTdUm6M2Y1jT9RGmlq8BGl1BrVlNyQ/daKjvbVPwLphD0mJ?= =?utf-8?q?LG6pptdnRhU?= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAXPR04MB8459.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(376014)(7416014)(52116014)(366016)(38350700014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?q?ZkX2+Ss2AO1VHx1A+eh9+23aq1qg?= =?utf-8?q?C9WsHsKheGPcEP9Kn/IsgCPJR5EsFPFZ0EAm7qWmpjpjwuS8lP3sRXGxAfNSrDXeb?= =?utf-8?q?eLwmomp+/WLurDQXQ9CQo77Z5da4LpN1fas+NH0aBUFvSs9YzMEVHJxaaUXoZGH6B?= =?utf-8?q?fg8agMd0SWPSpyWGHHz15VrGuqMR+KAdQLk4viGa6bWivbWe4xmx32yHNHt9r9Vou?= =?utf-8?q?MDjT1Y0p65kxMZ2NDHkm5SvVshFSP/N48fP9lnxwkfsUFliomKb2f68nFR8cBT6Mb?= =?utf-8?q?laXpjC5ay6blN++Wt9ygQQet70zS6Sy9wI8VdiO6toc6rY2VLthJ+BRpsHhEMOs93?= =?utf-8?q?XN2aLhpSxs2xS+A+TNzIRqMbByTp/7cQf4y6JJ5Cbw07MSxQlYO1vScPh9XOYqPrs?= =?utf-8?q?KkCXr3aHsHf1aziVaUg/CmXA/3hebRQAi81gZC7+s/0bxwSN9y1kIT+ZPn/R/C16v?= =?utf-8?q?VRSMOO6FnWklyDdtgiJCtg1P1ztBIR4WAm5IvO1/X+CbESkAYAeJXy3Fg319Wqjug?= =?utf-8?q?91jQMwMj0CexyU7FV0PTCKLuzh/AAsikGqQvkJDCVXxH+9F4aVektYNU4W9D4phmc?= =?utf-8?q?9UF/9g4INTfVG8ZylbkjqJI6UsRLaRRoOyijcPWv1DF/B64VYHyoIEm2PXoDeQUOC?= =?utf-8?q?ze/YG29iRtH3jaGW/Edr+GunXvRUY/Sjcu6M7LM6SoavimWpiXU6nZgh8wix+qH9X?= =?utf-8?q?z1TOZOd9zbt5XkSGQr+GqftmuRpQ2i0jpnOgF9lsns3/ir9McB/KxvkihLH76EE9Q?= =?utf-8?q?FI8oGayZ18YfJfUHvtdSvILvQJ8zXee+C9VwFqo1FoP7Ura6HglT/kIjxRyb8Yy3Q?= =?utf-8?q?7ljiesnGqsY9AoAS4JICejMIx1PYMSg2lkXGL21w+3Fkee9CNxg7fZ9e0t1o9sJ60?= =?utf-8?q?4n6B+vdLhv0p1U2MhdFI+KNcLI8MX/SbOBoNT/VsiRp91MURtyB77tf2aDKvR42c5?= =?utf-8?q?5+K3PjQ1G9gHUlP80ap4jcmEe0btb+DvfsZxrtCR4obVpEvpbup10rUaOtaIBW7iD?= =?utf-8?q?Y6lgbmMkttatcjDhB/jPPXC0NXG4XYWbMake5O1MylCg7GHEZXpTma+lBuvcIwVBZ?= =?utf-8?q?oIg6Getsvk+4XXW8M5ijGIpLUY2rqMhgc07OpDDzbc6QzrjcUxRbdmSVJZ2bfXMlB?= =?utf-8?q?CCbhdhrBCXia+hj/6nZrBrVH3J57jstFz0O0WKx5YUoM2/BHoTE2f9tf5rn3c6/m8?= =?utf-8?q?emQ7b3GFYoOrG7qHGw7+XK3/xvsTG8xq2sryQJ9t39fqQUb2JZpBA5oaBpG/Q2AEK?= =?utf-8?q?jE3JOyPbFtr7c96M614rHRM010xGpGnLI8K0AoDQsG+Rn/A+P2v3k1V3j6k/rQMtn?= =?utf-8?q?W2YpcRIrlxpawHbAOcjejK+5KLU3rraevk6CpTfzmrz0fdsB2GFzBv4vFrniDdXBL?= =?utf-8?q?CWI0oXloScRAdzcqdlvrd6+UZoBr4r8CVD94jumwzvKEEz/9B6MpaMAMeaxGQ1kek?= =?utf-8?q?USEmU1sHvlgGGTXCvfpQoVg72bGB48phbWrfZdU3bzu4sXIo/+vkMSloAFEglZIt3?= =?utf-8?q?QI6d0aByCsAi?= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 2c462ade-f0e5-4062-ba3a-08dd2fb23cd3 X-MS-Exchange-CrossTenant-AuthSource: PAXPR04MB8459.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 08 Jan 2025 07:01:12.8644 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 3FIYwDIuuivr7n7bgkfVIFtP+N7RNJ698c2+7KFw6knkkGTdjPxvYglpfl57bBY/i7NYwk0bxHI/onh2bd2IBA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: DB9PR04MB8299 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20250107_230116_675456_AE36CCFC X-CRM114-Status: GOOD ( 17.89 ) 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: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org From: Peng Fan i.MX9 OCOTP supports a specific peripheral or function being fused which means disabled, so - Introduce ocotp_access_gates to be container of efuse gate info - Iterate all nodes to check accessing permission. If not allowed to be accessed, detach the node Signed-off-by: Peng Fan --- drivers/nvmem/imx-ocotp-ele.c | 172 +++++++++++++++++++++++++++++++++++++++++- 1 file changed, 171 insertions(+), 1 deletion(-) diff --git a/drivers/nvmem/imx-ocotp-ele.c b/drivers/nvmem/imx-ocotp-ele.c index ca6dd71d8a2e29888c6e556aaea116c1a967cb5f..5ea6d959ce38760eeed44a989992fb35c462c0b4 100644 --- a/drivers/nvmem/imx-ocotp-ele.c +++ b/drivers/nvmem/imx-ocotp-ele.c @@ -5,6 +5,8 @@ * Copyright 2023 NXP */ +#include +#include #include #include #include @@ -27,6 +29,7 @@ struct ocotp_map_entry { }; struct ocotp_devtype_data { + const struct ocotp_access_gates *access_gates; u32 reg_off; char *name; u32 size; @@ -36,6 +39,20 @@ struct ocotp_devtype_data { struct ocotp_map_entry entry[]; }; +#define OCOTP_MAX_NUM_GATE_WORDS 4 + +struct access_gate { + u32 word; + u32 mask; +}; + +struct ocotp_access_gates { + u32 num_words; + u32 words[OCOTP_MAX_NUM_GATE_WORDS]; + u32 num_gates; + struct access_gate *gates; +}; + struct imx_ocotp_priv { struct device *dev; void __iomem *base; @@ -131,6 +148,82 @@ static void imx_ocotp_fixup_dt_cell_info(struct nvmem_device *nvmem, cell->read_post_process = imx_ocotp_cell_pp; } +static int imx_ele_ocotp_check_access(struct imx_ocotp_priv *priv, u32 id) +{ + const struct ocotp_access_gates *access_gates = priv->data->access_gates; + void __iomem *reg = priv->base + priv->data->reg_off; + u32 word, mask, val; + + if (id >= access_gates->num_gates) { + dev_err(priv->config.dev, "Index %d too large\n", id); + return -EACCES; + } + + word = access_gates->gates[id].word; + mask = access_gates->gates[id].mask; + + reg = priv->base + priv->data->reg_off + (word << 2); + val = readl(reg); + + dev_dbg(priv->config.dev, "id:%d word:%d mask:0x%08x\n", id, word, mask); + /* true means not allow access */ + if (val & mask) + return -EACCES; + + return 0; +} + +static int imx_ele_ocotp_grant_access(struct imx_ocotp_priv *priv, struct device_node *parent) +{ + struct device *dev = priv->config.dev; + + for_each_available_child_of_node_scoped(parent, child) { + struct of_phandle_args args; + u32 id, idx = 0; + + while (!of_parse_phandle_with_args(child, "access-controllers", + "#access-controller-cells", + idx++, &args)) { + of_node_put(args.np); + if (args.np != dev->of_node) + continue; + + /* Only support one cell */ + if (args.args_count != 1) { + dev_err(dev, "wrong args count\n"); + continue; + } + + id = args.args[0]; + + dev_dbg(dev, "Checking node: %pOF gate: %d\n", child, id); + + if (imx_ele_ocotp_check_access(priv, id)) { + of_detach_node(child); + dev_info(dev, "%pOF: Not granted, device driver will not be probed\n", + child); + } + } + + imx_ele_ocotp_grant_access(priv, child); + } + + return 0; +} + +static int imx_ele_ocotp_access_control(struct imx_ocotp_priv *priv) +{ + struct device_node *root __free(device_node) = of_find_node_by_path("/"); + + if (!priv->data->access_gates) + return 0; + + /* This should never happen */ + WARN_ON(!root); + + return imx_ele_ocotp_grant_access(priv, root); +} + static int imx_ele_ocotp_probe(struct platform_device *pdev) { struct device *dev = &pdev->dev; @@ -161,14 +254,45 @@ static int imx_ele_ocotp_probe(struct platform_device *pdev) priv->config.fixup_dt_cell_info = imx_ocotp_fixup_dt_cell_info; mutex_init(&priv->lock); + platform_set_drvdata(pdev, priv); + nvmem = devm_nvmem_register(dev, &priv->config); if (IS_ERR(nvmem)) return PTR_ERR(nvmem); - return 0; + + return imx_ele_ocotp_access_control(priv); } +struct access_gate imx93_access_gate[] = { + [IMX93_OCOTP_NPU_GATE] = { .word = 19, .mask = BIT(13) }, + [IMX93_OCOTP_A550_GATE] = { .word = 19, .mask = BIT(14) }, + [IMX93_OCOTP_A551_GATE] = { .word = 19, .mask = BIT(15) }, + [IMX93_OCOTP_M33_GATE] = { .word = 19, .mask = BIT(24) }, + [IMX93_OCOTP_CAN1_FD_GATE] = { .word = 19, .mask = BIT(28) }, + [IMX93_OCOTP_CAN2_FD_GATE] = { .word = 19, .mask = BIT(29) }, + [IMX93_OCOTP_CAN1_GATE] = { .word = 19, .mask = BIT(30) }, + [IMX93_OCOTP_CAN2_GATE] = { .word = 19, .mask = BIT(31) }, + [IMX93_OCOTP_USB1_GATE] = { .word = 20, .mask = BIT(3) }, + [IMX93_OCOTP_USB2_GATE] = { .word = 20, .mask = BIT(4) }, + [IMX93_OCOTP_ENET1_GATE] = { .word = 20, .mask = BIT(5) }, + [IMX93_OCOTP_ENET2_GATE] = { .word = 20, .mask = BIT(6) }, + [IMX93_OCOTP_PXP_GATE] = { .word = 20, .mask = BIT(10) }, + [IMX93_OCOTP_MIPI_CSI1_GATE] = { .word = 20, .mask = BIT(17) }, + [IMX93_OCOTP_MIPI_DSI1_GATE] = { .word = 20, .mask = BIT(19) }, + [IMX93_OCOTP_LVDS1_GATE] = { .word = 20, .mask = BIT(24) }, + [IMX93_OCOTP_ADC1_GATE] = { .word = 21, .mask = BIT(7) }, +}; + +static const struct ocotp_access_gates imx93_access_gates_info = { + .num_words = 3, + .words = {19, 20, 21}, + .num_gates = ARRAY_SIZE(imx93_access_gate), + .gates = imx93_access_gate, +}; + static const struct ocotp_devtype_data imx93_ocotp_data = { + .access_gates = &imx93_access_gates_info, .reg_off = 0x8000, .reg_read = imx_ocotp_reg_read, .size = 2048, @@ -183,7 +307,53 @@ static const struct ocotp_devtype_data imx93_ocotp_data = { }, }; +struct access_gate imx95_access_gate[] = { + [IMX95_OCOTP_CANFD1_GATE] = { .word = 17, .mask = BIT(20) }, + [IMX95_OCOTP_CANFD2_GATE] = { .word = 17, .mask = BIT(21) }, + [IMX95_OCOTP_CANFD3_GATE] = { .word = 17, .mask = BIT(22) }, + [IMX95_OCOTP_CANFD4_GATE] = { .word = 17, .mask = BIT(23) }, + [IMX95_OCOTP_CANFD5_GATE] = { .word = 17, .mask = BIT(24) }, + [IMX95_OCOTP_CAN1_GATE] = { .word = 17, .mask = BIT(25) }, + [IMX95_OCOTP_CAN2_GATE] = { .word = 17, .mask = BIT(26) }, + [IMX95_OCOTP_CAN3_GATE] = { .word = 17, .mask = BIT(27) }, + [IMX95_OCOTP_CAN4_GATE] = { .word = 17, .mask = BIT(28) }, + [IMX95_OCOTP_CAN5_GATE] = { .word = 17, .mask = BIT(29) }, + [IMX95_OCOTP_NPU_GATE] = { .word = 18, .mask = BIT(0) }, + [IMX95_OCOTP_A550_GATE] = { .word = 18, .mask = BIT(1) }, + [IMX95_OCOTP_A551_GATE] = { .word = 18, .mask = BIT(2) }, + [IMX95_OCOTP_A552_GATE] = { .word = 18, .mask = BIT(3) }, + [IMX95_OCOTP_A553_GATE] = { .word = 18, .mask = BIT(4) }, + [IMX95_OCOTP_A554_GATE] = { .word = 18, .mask = BIT(5) }, + [IMX95_OCOTP_A555_GATE] = { .word = 18, .mask = BIT(6) }, + [IMX95_OCOTP_M7_GATE] = { .word = 18, .mask = BIT(9) }, + [IMX95_OCOTP_DCSS_GATE] = { .word = 18, .mask = BIT(22) }, + [IMX95_OCOTP_LVDS1_GATE] = { .word = 18, .mask = BIT(27) }, + [IMX95_OCOTP_ISP_GATE] = { .word = 18, .mask = BIT(29) }, + [IMX95_OCOTP_USB1_GATE] = { .word = 19, .mask = BIT(2) }, + [IMX95_OCOTP_USB2_GATE] = { .word = 19, .mask = BIT(3) }, + [IMX95_OCOTP_NETC_GATE] = { .word = 19, .mask = BIT(4) }, + [IMX95_OCOTP_PCIE1_GATE] = { .word = 19, .mask = BIT(6) }, + [IMX95_OCOTP_PCIE2_GATE] = { .word = 19, .mask = BIT(7) }, + [IMX95_OCOTP_ADC1_GATE] = { .word = 19, .mask = BIT(8) }, + [IMX95_OCOTP_EARC_RX_GATE] = { .word = 19, .mask = BIT(11) }, + [IMX95_OCOTP_GPU3D_GATE] = { .word = 19, .mask = BIT(16) }, + [IMX95_OCOTP_VPU_GATE] = { .word = 19, .mask = BIT(17) }, + [IMX95_OCOTP_JPEG_ENC_GATE] = { .word = 19, .mask = BIT(18) }, + [IMX95_OCOTP_JPEG_DEC_GATE] = { .word = 19, .mask = BIT(19) }, + [IMX95_OCOTP_MIPI_CSI1_GATE] = { .word = 19, .mask = BIT(21) }, + [IMX95_OCOTP_MIPI_CSI2_GATE] = { .word = 19, .mask = BIT(22) }, + [IMX95_OCOTP_MIPI_DSI1_GATE] = { .word = 19, .mask = BIT(23) }, +}; + +static const struct ocotp_access_gates imx95_access_gates_info = { + .num_words = 3, + .words = {17, 18, 19}, + .num_gates = ARRAY_SIZE(imx95_access_gate), + .gates = imx95_access_gate, +}; + static const struct ocotp_devtype_data imx95_ocotp_data = { + .access_gates = &imx95_access_gates_info, .reg_off = 0x8000, .reg_read = imx_ocotp_reg_read, .size = 2048,