From patchwork Fri Feb 25 01:42:30 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Peng Fan (OSS)" X-Patchwork-Id: 12759519 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 08445C433F5 for ; Fri, 25 Feb 2022 01:42:38 +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=k1GTfJMEd9P4TDxNT4ogqxyIVpRx/c0KXq1l0s73xx0=; b=F+5fv4wTpA8qpD fdNz7kZzgSwocUSmxwllpyxWTfQ/Ugi6GD5BqokIoQi63Tgw4k1Ux7GatUSUUcksCrSI9pW1nH293 vqFts+djgia6Y84LGaJrOxG5CgZfRc92po7wHxotBDgw0CiRTWL1xJZ2HhA5iZPQR3r95tSbsYA7n 28ulzeElVvDrYv9hYZWPewYbMQJc7TGQRVBJiJdFm2WPykHKFAUQi2W84ilxZ9ZgTnWKim+KaYmdR Zp8Qebdl92eo15d5iIuU3tLQd90iFSXFYfB7bBoNV2mbw5xLcfjrzYAE5WtIIhoYh8mxaz54mSegB GDbKvm2P+ku/BwjOXLxQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPbR-002sUg-LN; Fri, 25 Feb 2022 01:41:01 +0000 Received: from mail-vi1eur05on20628.outbound.protection.outlook.com ([2a01:111:f400:7d00::628] helo=EUR05-VI1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPbK-002sSw-9u for linux-arm-kernel@lists.infradead.org; Fri, 25 Feb 2022 01:40:57 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=gA8VM3ATkKdDGfRRHP/JrX7NcMThJGmyIC8XTOxSQXCm/erBfONTljVgfgKeQiNAoiwh7RGS6PCWw0gaZ87kb86KScM/stj62H93QSrSSW6df/TIs0x1/M1AH5S7uwjdkVg1bjkdOUvY3Bs9abhjXCivFvXjSbppP7WOytjk8Yr3IMDACHVQ28oY2imCNoBsSeBBggJOqxIOL4OJsxkkz96iPkdMuYYfVoVUyZ5jl+52v4u8k9/3EuarejLFyxFIAtBIPOWJJZeWcwdrhxGsgRomvZaCX2v7/+QzNPqISVXeaFC53XupQwjle44KdLR0AcRK6mC0RffbSm96IrxJzw== 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=MfF5Y7GmTNKJ45HdHi0W7Efe3Jzbng9SswwoEO+DmMY=; b=ljFjxK7L1HDN1gcH8nI3BehB8O7Yye36kejZKnbQ0n7gOWbepRMzEEpXsyzMeFNUBDOPK6IKLa7i3rVwzurnT+HxuvLrFZ1VI7XO4M8hyrfC31qpYSwRnBJtZ/TTID87Y6zEgRF0d9g/4HUpU9vYrmb42C+EZ+vmvtXpMQ7oEAke1CBU01nDkjmokEc3W6B9UjetlccuubCbOHYKIn593ep8F9M1nfor2zdcI0IiTWXqMxCJ+uWEx+CRw9cOmwCluznvHTuQ9vCeqOWkS7bPXo8VN5FuXun4Hs185lBozfXX3ApAbQI85eTVNvsGPSJib8MLeQQ3fzO0XnwVofvCdw== 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=selector2-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=MfF5Y7GmTNKJ45HdHi0W7Efe3Jzbng9SswwoEO+DmMY=; b=GanfsarwHEntysEKVjigAMCgOZrLNrK3smfFiPNu/2ylF1t15fPcremE5cayhkO0CmDeHskQL+zAHFyPW/AXNy+eDbNdin4uV4LU7zqjasNwG+60X8/TpKuh95iEMhGZvJUoF7YOQcbafZ5HAw4WEGE68gJTE/qjvEUa3kp9DqE= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) by AM0PR04MB5316.eurprd04.prod.outlook.com (2603:10a6:208:d0::25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5017.25; Fri, 25 Feb 2022 01:40:50 +0000 Received: from DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc]) by DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc%4]) with mapi id 15.20.4995.018; Fri, 25 Feb 2022 01:40:50 +0000 From: "Peng Fan (OSS)" To: sboyd@kernel.org, robh+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, abel.vesa@nxp.com Cc: kernel@pengutronix.de, festevam@gmail.com, linux-imx@nxp.com, linux-clk@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Peng Fan , Rob Herring Subject: [PATCH V5 1/5] dt-bindings: clock: Add imx93 clock support Date: Fri, 25 Feb 2022 09:42:30 +0800 Message-Id: <20220225014234.1766305-2-peng.fan@oss.nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220225014234.1766305-1-peng.fan@oss.nxp.com> References: <20220225014234.1766305-1-peng.fan@oss.nxp.com> X-ClientProxiedBy: SI2PR02CA0018.apcprd02.prod.outlook.com (2603:1096:4:194::18) To DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 700afbc4-e083-42f0-d5b7-08d9f7ffda27 X-MS-TrafficTypeDiagnostic: AM0PR04MB5316:EE_ X-MS-Exchange-SharedMailbox-RoutingAgent-Processed: True X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: oSS2x2MDbJIF0g3Ygc7B+ef06u7s11zxp3XFnbiMTgRaoG6WyGMXPHzyVS1HRxQPn9ZQRHuDBZESCOP0ohKL0WFZ2Ts1W3SqASw9yWVEWlXRO5HfOkCSyikI4FoASqU4Z++GKXEbW5GBB9qSdmNOPgRD9/C2byt9uXIfNzVL3es/bvr1nmGouAVZV55PbJMtAxnOFB5WldUlCaiSP9E6WojsWTCihNhdmUZS1FkLfe7MDq1SAntJA5ALUQCOuvutPHNyc4eVdUzkwjTMdtpKm1j63SRIrzccfyCqGhhJ4+zDMCc9k2PYS6IYmEmGbYw++e+h0bSshwKatkgnsg3KammhSjic53q2zabEo1HY8Tgpet1yyRLmGFDH+t+5YlXexRjGsh4AY5ebosddR79oJoxtBZtyJe3IvwmjES4uWHbfkcQ5njV3KgupMCWw9vifbXyKnh9N3sfP4nUm5q0RWE1Sm0Twvkts6MDZX/fasxFtY0RgER0ulcwpxdMys26R0vXle35NMn3i+betKr/pxe1ozAy5qtS8oM8dpraPI1b+ZGN86F7TrgNTnrW444OgDGV9IySF1G/kb7uIo9msyanu4kptVS2HKxXecAgC5xVORnNMuP+cVE/QRIHiAfx8aLLPEJYf/irxIjUznfFn+TtLxpovJtnmKZNUE53CmKjNLcjp62WuLhFFOu551yahnDMiDrlyZ9n4jLAf49Sg5ye/+bjpe2WivIo30KkBFr0FUjoLez6k/mUdtWKZJdcL9V2/SI6mP8HmIWpmKTWJ/EPyz/p0ENkFgUAGSnAMKmeD5WtweTUHe1bgzaEjL1OlxE0rDhDPJ9WrXbqpcn+VeQ== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DU0PR04MB9417.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230001)(4636009)(366004)(8936002)(508600001)(38100700002)(83380400001)(38350700002)(54906003)(966005)(6486002)(316002)(66946007)(5660300002)(7416002)(6512007)(6666004)(8676002)(86362001)(66476007)(66556008)(4326008)(52116002)(2906002)(2616005)(26005)(1076003)(186003)(6506007); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: KmDWWlKmsW80HWEiu9oeyFQM21qxb3HT/3V0r+KuJnWDT/A5EewrPZg7PlG5aum8tFeXiXP9vsUPCq7H/6+2udz3as5M70FkmBbOs/XDyOXrJw26Y6pLxteaIEztlj6dJ54PBPlHWoYKvND3BL8JvTW0sRlTyBNg5IPGOdjryeGtxj0OTZOEXl7gBZW+zvn674fBHYKQ9IaLxxwVZ+be95EVFZY10WKLaX1dRXfjJnb7fDnluHnmpBSyj5GxVUMcGR9ISaNVftxMggSkX4zawZe80m0xtRwTa5QkyYsqo7zeNP801DeF3PbglnFZZ0xTeOZsIZmb0nR1OZQRBq803gLiPd1Sc40ZOgLNxeNWfqneZFUe3oDJno4NNsGeZx7erhj5oURs3pDAQ1Rsj6CaNvkm1w4SaWBaf+nUy4H1+33bgr0gKonFVdvnOMYfA3jgasXQWPSvTQM0chMK1kinoW9pk0BX4c0LUFuuzPn/FjgGtOnXzseBBPZDceaDLFr6SUArwXf1f4hgDzUv3KsIu3BMErMJ1tuNxhiic4Rm7CdzieDfQ04G4YKW8DKDo9p0BCGQcOD+6yS6FNU5UXftRyA38nGXG/AG9o10BJIaL8sMyYEZymwvwD7aqGT+HlbR9gWjW86Lf0ysHzlP+MxAbPTeZ/F3PbhuJamX19HI/FSnYaVae3eFvGpCmSl25yqMz2Mz9ozSMm4Gl1cObGy+4EezVIARUh7A3CEsgXE378OBBfIhWgIIzDPn+imBzStG7os5zGKCVg8NBWFS7Dw5tnI9cH5h/zNtW1iMDksVkXkSqcm+oPVOmPLQvdeZRD2PSAwD6pW0zbsw/Ca//0STw5Uyl+LI+DkYoNIalMuZDnI/nC9VZt6PwGNm5hR5UH4nN5xdY1D6mYruRlBN/jzrlxbOpRyhu5JIIHyVKbclC1LrY1JdLF50Nzp9IjE/2C0+KfxWul/Awm2e2mFxyii2Hh/WmrDNQiVUSKzyon4OufXqQvP5Ffm1yz+qy15tZ4nTkcFfnTwipITqwYYL9BLojqUXpFgOWdhCUwFJccztvtxbnarYGTKWZRT0yzhyAPq5vwuFpIHdNderF7mSChTz90acTam96OKYzRXxu0QeuiVaoYQNNXkekNG+dw1AKkHG00EnTSEztozR1Yzjrq80QOBeox/BUGr+c2aif+tUphE/WCET4wdUW9cynlogDqCP1MHziFRPJQ76+NWdD/96UkuP5Mw5m9ZuZStEzo4irYcpsBwKd5bdIFum7H1mgkpBbhEY9vXj57Mhokdb+EDrEFZgGJI6ewlLKoLovytCu+YLl1aSGq0P4vO0MbXEVBJMugL4hvBS8Lt3/or+NAAsZx/d1Vrng8dTCHJb+xKOXmDDIQxOOL+7GtRxuQz8ROTgQgvqU0EuHqNKzZScJAb9xIn/GndzaYeR5lqYV9gMb4ZcG3JB2IFjYVLGYU2OSblKjWrXYe+kjsAjxwFNt+C+JO7V75QJvfZ0FgDSXnB85j2PXr7LpRlhino5wfHUUnXdd8X/+05ELU6OJGGCydFlZDPcuiX71Lh96GN4B44vEUIYR17GIc8e6Xz4D1gDMO4Cq0WDvtofZCh3V1sR3SXly30ySNC/X7+SPtGyRQSbLDk= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 700afbc4-e083-42f0-d5b7-08d9f7ffda27 X-MS-Exchange-CrossTenant-AuthSource: DU0PR04MB9417.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 Feb 2022 01:40:50.1056 (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: Zo6Qo+F8PBs8FQ7UMITK+kyYXV8xlgF5OwJ7vyGQS5L5dus9Ei3uUnyF3bmO6HpmnLAs68Gvfo3iePr5768nEA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM0PR04MB5316 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220224_174054_385627_F97B34D1 X-CRM114-Status: GOOD ( 11.92 ) 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 Add the clock dt-binding file for i.MX93. Reviewed-by: Abel Vesa Signed-off-by: Peng Fan Reviewed-by: Rob Herring Reviewed-by: Stephen Boyd --- .../bindings/clock/imx93-clock.yaml | 62 +++++++++++++++++++ 1 file changed, 62 insertions(+) create mode 100644 Documentation/devicetree/bindings/clock/imx93-clock.yaml diff --git a/Documentation/devicetree/bindings/clock/imx93-clock.yaml b/Documentation/devicetree/bindings/clock/imx93-clock.yaml new file mode 100644 index 000000000000..21a06194e4a3 --- /dev/null +++ b/Documentation/devicetree/bindings/clock/imx93-clock.yaml @@ -0,0 +1,62 @@ +# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) +%YAML 1.2 +--- +$id: http://devicetree.org/schemas/clock/imx93-clock.yaml# +$schema: http://devicetree.org/meta-schemas/core.yaml# + +title: NXP i.MX93 Clock Control Module Binding + +maintainers: + - Peng Fan + +description: | + i.MX93 clock control module is an integrated clock controller, which + includes clock generator, clock gate and supplies to all modules. + +properties: + compatible: + enum: + - fsl,imx93-ccm + + reg: + maxItems: 1 + + clocks: + description: + specify the external clocks used by the CCM module. + items: + - description: 32k osc + - description: 24m osc + - description: ext1 clock input + + clock-names: + description: + specify the external clocks names used by the CCM module. + items: + - const: osc_32k + - const: osc_24m + - const: clk_ext1 + + '#clock-cells': + const: 1 + description: + See include/dt-bindings/clock/imx93-clock.h for the full list of + i.MX93 clock IDs. + +required: + - compatible + - reg + - '#clock-cells' + +additionalProperties: false + +examples: + # Clock Control Module node: + - | + clock-controller@44450000 { + compatible = "fsl,imx93-ccm"; + reg = <0x44450000 0x10000>; + #clock-cells = <1>; + }; + +... From patchwork Fri Feb 25 01:42:31 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Peng Fan (OSS)" X-Patchwork-Id: 12759518 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 C80B4C433EF for ; Fri, 25 Feb 2022 01:42:36 +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=yhjxVGOoIueplsVVyxcrMcAQFnddprUfNh722yTqa2g=; b=X+pcgbUXUGHUI+ 7ZPG92fAwxsWzwyu+q93zqOoP8uNuqMm4sWtbyvPrcNEE1OJBwFe9lnWSUBL7d0BkUIbCOpn2mMNw pcn6dLXeZr6ODMAzQOD+ZYtg111gYLXnme6nG3Wv4Yor9FMs0RC/oxJT+NfagiDRdgjeEusFmOVCW O1WNtC9MpeCUglcI9UgGrc3ycjZuuR4JJvqeysRDUDQ4AHt8FwLnWR+Yl+Z56tpLKhucRGhPYEwn0 SXlx7dEx2tP5Aud+hLkMo53vUqyMdXO8CDvdSbqKMeAaPQYRY9E3IjxrS7eTbsa+0FbFUVTG6xxYP HWeK2K3hUMOwywHWUUgw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPbd-002sYq-Gg; Fri, 25 Feb 2022 01:41:13 +0000 Received: from mail-vi1eur05on20628.outbound.protection.outlook.com ([2a01:111:f400:7d00::628] helo=EUR05-VI1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPbN-002sSw-Th for linux-arm-kernel@lists.infradead.org; Fri, 25 Feb 2022 01:40:59 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=j2n3hVFHCp/7Plak/ErZ9eJJkc0shqtYMdlSn+vAtRLa8LlKI8pLPABb+tyEmg/t81Danx7jCiOZSt/31E3Gw7kLb5V+MwOs48fGqtYgYHmZWphnRS+Pw5XEtu6ARYEPtr2BRQ4WKrvcE2V3PeEWSxQ/0Ce+Rm7yQlMWcC+R18VwOxW0ReHHJYEWFf6+IcBe0t/8NJ1H3gu8CahV/1RaCtnIIQeUiOcft4si7zm7I8XXpLyA8v0bhkEtCSg42yt62toSQf9Xh2zPf23KV80UdQj2CwhR7bNvZ13z0iGK98x/HNdknOgo3bx4ilz/7o54G4q4c+PAA6otVxVGPeCq7w== 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=OoGw+pt5GV/yatYjec2iLBkRZMn7BMljR1MVO4EMpOY=; b=fK8j/LI0q1J9unu4uwamCE+Uhl+JqAaZJEmhAf2r713z9SgRL4pwuJBrYlp7ls1XaZM9m09BpGeXv/WcYqgLZVH1LxWGwWXZzDhIArcqijV5KOgaFdF8sy+oLtj4VHoOIEwYyR1Y5h1bPC7Lb26YpRfXftw28XYOo97BSCNjCS7t/plXgzLS9Ta6HlzrmShadOIvuzDejxaRnYtwXEh6qzrLhQVfWjhdm/Q/4j7np8OEGCusc8IvSssi3ke4FRh0yKL4VNU0WwRZWxCyyjddHJ+tSUaJ8TfSfTBtLtG+ATycEo3Fvaru45ksyGv5Dl/Vw5UXaAv3EG9pLWeItg5POQ== 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=selector2-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=OoGw+pt5GV/yatYjec2iLBkRZMn7BMljR1MVO4EMpOY=; b=inqxpbY/NI6l6u6wYfswQucIl4qhd9p2e6LWumce5uEjIiSirQKQOYW5r3lvfw6oEmAlvoPaj9s9EDesOtczHDBwhftbqd73wk0qU5GHv93nFcj0OnPEk3UcFYuga+tZon+kUu2CUpHEakv2k6+q1cK+3ddoW26t6C22bD1PZwM= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) by AM0PR04MB5316.eurprd04.prod.outlook.com (2603:10a6:208:d0::25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5017.25; Fri, 25 Feb 2022 01:40:54 +0000 Received: from DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc]) by DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc%4]) with mapi id 15.20.4995.018; Fri, 25 Feb 2022 01:40:54 +0000 From: "Peng Fan (OSS)" To: sboyd@kernel.org, robh+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, abel.vesa@nxp.com Cc: kernel@pengutronix.de, festevam@gmail.com, linux-imx@nxp.com, linux-clk@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Peng Fan , Krzysztof Kozlowski , Rob Herring Subject: [PATCH V5 2/5] dt-bindings: clock: add i.MX93 clock definition Date: Fri, 25 Feb 2022 09:42:31 +0800 Message-Id: <20220225014234.1766305-3-peng.fan@oss.nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220225014234.1766305-1-peng.fan@oss.nxp.com> References: <20220225014234.1766305-1-peng.fan@oss.nxp.com> X-ClientProxiedBy: SI2PR02CA0018.apcprd02.prod.outlook.com (2603:1096:4:194::18) To DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 3bc20c47-6db5-4fa5-bcc9-08d9f7ffdce2 X-MS-TrafficTypeDiagnostic: AM0PR04MB5316:EE_ X-MS-Exchange-SharedMailbox-RoutingAgent-Processed: True X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: SksYIFLHSDMYTqfrDjTw0p+7KvsHdT7aJH/CaT9VFoUjXTcfOk1mAGZYwQ9MK/yMhUvzllckXwCk509F3C4OgAa861+esFBd2Aixcg3616nzglj7XK9Ac3xQ+ZTVK0FfzWuVSwALYSIFTBm75UFkgS2Ij8RhVRm3vc99MNFuDL6rQbOW9bnsfTnAokp/P41NtkRAOx6SToCyKfoYU8G3GXEh16cNhzIA1XASywZtW68gwyBRt6u6vh5QG/xQvMydmMY5jFbycLTo5bt3B/xeEP2V9brmh/RjpbkdUVcIO/04DTrH6hD4BVp7zsGJkrYMt76tBJJ87dxJeH1WuzQgtA7Y4grzey0R7xW5yYRupglnev2zV6pNKM4zMdTzNOgxUqYjfPjaANmrrWNuB+dDJ3SHBPMletv5/oJLZ0Ly1ZtcNOdZTgbMYqXZmcU/z4VWqi0iGol5A1thSxCUfzB11qZNaXkXtcNLMcUPv+iyd/3hkjcwpKO3lDLKgewzn8aRu/ZTGGEKYhh2FocrGMhIVixD+H64utSpBeYV7nC18LL7zAXdOPwMKehFbfb1E7qWaxUsY+Mw7tlIK3/apSPlt2VhTxuHYCd749ghUUr3c9xQqZ6GGKEcO5p+9K2zXeuv1PO/PiAxVk26g//RriAsMbVdZsgpEXNAX/ISK3h3SE61bH2V5QyJm3tEZLn1+8e1o2Q4k1FJWtXFxEtP9V57hQ== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DU0PR04MB9417.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230001)(4636009)(366004)(8936002)(508600001)(38100700002)(83380400001)(38350700002)(54906003)(6486002)(316002)(66946007)(5660300002)(7416002)(6512007)(6666004)(8676002)(86362001)(66476007)(66556008)(4326008)(52116002)(2906002)(2616005)(26005)(1076003)(186003)(6506007); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: 2zfAe21PkkIhL/4KCEBC5DUKKj/pbb3cifGExhAHfk9nux2EVZxbHLSMFB8qWHto3bFDKqhKe89UpYj876plTM9y8Gy/BmAlmAjYDBfr1J+lnKPLXhsYQFtF1WgRN+EkSdUTnXiZqEb4LsBumj8phb2ZVmxr9HY96eTlwhDgkFJbE3aQpMfJMulSOojt8bfC1XMTLd9OkdZcaqzUQq8OQ8Z9tI0OrTjxMeQMz+E/++8ELoybPJucaWGI2ZM64z+6+A/Q58lx0d/ibwxS1h01NNP8BDraWLLZnE7mE1IRz46cMHchENanhGIiXYLCmzTVI5mI3+MLFov1rHZFnHHSAk8oMcwZLLPob4tqTdo2dtzHfiJrqDDR8jasf6ewW3GgBHaphTaXvsJpDDsn1RanagH08pau89YkIi1GIyQtJOKKHC/KEw9BmDvti38k4tLZNNLUIzt9oOgLVDriWpgiav26nOcrScQvUzV6RreDpFTfHpXZUlFUJ4Hr6IPunrkvgSwKs/N4Ma67mK3FvDPOD5Zv83YVXMrRqDyOVwlRcg2SaJuD9ZbPfBrQNFtfZO72h7RoT9c1XtnSqU4gdiRSXf7hDc24dxuMZLh7d3MvQp1wIDvZI0hCVSeM1NGn5OGiioyK6jwvL0djyIOph2fxy/VRdurTrK7vBDCEDLfpUoifg5/4fRpQcxOyqkjuwuL89+Qe0SJHTBH3RowBDxz4///Kwtgk+Ay7XjGx6oede2iDXyG6iv6RJNKSyxsWcU64am4ig4MAiyGgjFdL2b/Z5oNHQkcZ/vRohtpONn5eUWi2V4mrLBEawierXIPXWKua92HjGy/AZfykJ4bENJcjYB7GXkvoYRxBWUO6rgz7emYzAf9oCh8+7PK+iribbP90oN6j3LbKhJNnCdPyiuZnp5HxFB9SBHhHvTj9i2LZqDBK+Q+y7vOjfLynz+4wbIWky9OgtI0f8z18w9H3KNDLnoPDAbLNAeifQdsdPxPNiQv9KwYSmNVtLq6F9j4n8tlC78VFjfQ/JI6b98AD3a3Egrj+XWJ/gjPDG4nA0rb0dUHOa4y50WAYfDAOe0Ror688tsQp73yd6u1ctDPWnrjubU2I2/mlERy3yD9uDaoEJCsDsSNdrxSJALWOwRublU1Ikj8gxOcVj8ZFyFKSJvRljxmfHRFEDXKG4+/6L0ce6rJnsq85yx8DLYfKH9ljkIXkQNzkzQEWgNJihDyfXyMDqXEX67Y6vxUvCf+CbHS5HdupLULYM9jsurEiLcp5bUMKCwEq8E/PRYEXiyLMkK+mAxbUemLkjkigVhzDTKcXtmAckXip2h8wXJAaKRrZEzXEBQz9kttRktTFv9GwixCv7wNOFGDk3oShHGcNgUC/HGXPeP5MCSLMgXaXFPRXMk/MOWclDvVcqlQZSpxAp0gzsjNgIi2FbWhX9OUaRICLROH314TPNuQd4CwwVHIHdPv2w7Jq1Yz3fPfN3dkOmCI0cjbIwMePL7q1s5VVNHroq8OEYXSCd/4qmqIutB+I+SwHIoEpupw7mF7k1Qyx9f9wI1JFWeTF1mgaaFcBNX4njzVvzrvpoPb7Hz4mqsSP/kGtj2xZspqn1a5YB4+kojn2hbQRLFOS+xTBlC8RZtdKaSM= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 3bc20c47-6db5-4fa5-bcc9-08d9f7ffdce2 X-MS-Exchange-CrossTenant-AuthSource: DU0PR04MB9417.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 Feb 2022 01:40:54.6078 (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: i3F6vfuRS7mynTXCbWaOpAGq2jTVkG1jbaXR/DRsbyXfmeGgJZiih6sdtk55SRicxXNbCS8JVAqHFP7yq+rdUw== X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM0PR04MB5316 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220224_174057_993901_476F2BB9 X-CRM114-Status: UNSURE ( 9.50 ) X-CRM114-Notice: Please train this message. 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 Add i.MX93 clock definition Reviewed-by: Abel Vesa Acked-by: Krzysztof Kozlowski Signed-off-by: Peng Fan Acked-by: Rob Herring Reviewed-by: Stephen Boyd --- include/dt-bindings/clock/imx93-clock.h | 201 ++++++++++++++++++++++++ 1 file changed, 201 insertions(+) create mode 100644 include/dt-bindings/clock/imx93-clock.h diff --git a/include/dt-bindings/clock/imx93-clock.h b/include/dt-bindings/clock/imx93-clock.h new file mode 100644 index 000000000000..21fda9c5cb5e --- /dev/null +++ b/include/dt-bindings/clock/imx93-clock.h @@ -0,0 +1,201 @@ +/* SPDX-License-Identifier: GPL-2.0+ OR MIT */ +/* + * Copyright 2022 NXP + */ + +#ifndef __DT_BINDINGS_CLOCK_IMX93_CLK_H +#define __DT_BINDINGS_CLOCK_IMX93_CLK_H + +#define IMX93_CLK_DUMMY 0 +#define IMX93_CLK_24M 1 +#define IMX93_CLK_EXT1 2 +#define IMX93_CLK_SYS_PLL_PFD0 3 +#define IMX93_CLK_SYS_PLL_PFD0_DIV2 4 +#define IMX93_CLK_SYS_PLL_PFD1 5 +#define IMX93_CLK_SYS_PLL_PFD1_DIV2 6 +#define IMX93_CLK_SYS_PLL_PFD2 7 +#define IMX93_CLK_SYS_PLL_PFD2_DIV2 8 +#define IMX93_CLK_AUDIO_PLL 9 +#define IMX93_CLK_VIDEO_PLL 10 +#define IMX93_CLK_A55_PERIPH 11 +#define IMX93_CLK_A55_MTR_BUS 12 +#define IMX93_CLK_A55 13 +#define IMX93_CLK_M33 14 +#define IMX93_CLK_BUS_WAKEUP 15 +#define IMX93_CLK_BUS_AON 16 +#define IMX93_CLK_WAKEUP_AXI 17 +#define IMX93_CLK_SWO_TRACE 18 +#define IMX93_CLK_M33_SYSTICK 19 +#define IMX93_CLK_FLEXIO1 20 +#define IMX93_CLK_FLEXIO2 21 +#define IMX93_CLK_LPIT1 22 +#define IMX93_CLK_LPIT2 23 +#define IMX93_CLK_LPTMR1 24 +#define IMX93_CLK_LPTMR2 25 +#define IMX93_CLK_TPM1 26 +#define IMX93_CLK_TPM2 27 +#define IMX93_CLK_TPM3 28 +#define IMX93_CLK_TPM4 29 +#define IMX93_CLK_TPM5 30 +#define IMX93_CLK_TPM6 31 +#define IMX93_CLK_FLEXSPI1 32 +#define IMX93_CLK_CAN1 33 +#define IMX93_CLK_CAN2 34 +#define IMX93_CLK_LPUART1 35 +#define IMX93_CLK_LPUART2 36 +#define IMX93_CLK_LPUART3 37 +#define IMX93_CLK_LPUART4 38 +#define IMX93_CLK_LPUART5 39 +#define IMX93_CLK_LPUART6 40 +#define IMX93_CLK_LPUART7 41 +#define IMX93_CLK_LPUART8 42 +#define IMX93_CLK_LPI2C1 43 +#define IMX93_CLK_LPI2C2 44 +#define IMX93_CLK_LPI2C3 45 +#define IMX93_CLK_LPI2C4 46 +#define IMX93_CLK_LPI2C5 47 +#define IMX93_CLK_LPI2C6 48 +#define IMX93_CLK_LPI2C7 49 +#define IMX93_CLK_LPI2C8 50 +#define IMX93_CLK_LPSPI1 51 +#define IMX93_CLK_LPSPI2 52 +#define IMX93_CLK_LPSPI3 53 +#define IMX93_CLK_LPSPI4 54 +#define IMX93_CLK_LPSPI5 55 +#define IMX93_CLK_LPSPI6 56 +#define IMX93_CLK_LPSPI7 57 +#define IMX93_CLK_LPSPI8 58 +#define IMX93_CLK_I3C1 59 +#define IMX93_CLK_I3C2 60 +#define IMX93_CLK_USDHC1 61 +#define IMX93_CLK_USDHC2 62 +#define IMX93_CLK_USDHC3 63 +#define IMX93_CLK_SAI1 64 +#define IMX93_CLK_SAI2 65 +#define IMX93_CLK_SAI3 66 +#define IMX93_CLK_CCM_CKO1 67 +#define IMX93_CLK_CCM_CKO2 68 +#define IMX93_CLK_CCM_CKO3 69 +#define IMX93_CLK_CCM_CKO4 70 +#define IMX93_CLK_HSIO 71 +#define IMX93_CLK_HSIO_USB_TEST_60M 72 +#define IMX93_CLK_HSIO_ACSCAN_80M 73 +#define IMX93_CLK_HSIO_ACSCAN_480M 74 +#define IMX93_CLK_ML_APB 75 +#define IMX93_CLK_ML 76 +#define IMX93_CLK_MEDIA_AXI 77 +#define IMX93_CLK_MEDIA_APB 78 +#define IMX93_CLK_MEDIA_LDB 79 +#define IMX93_CLK_MEDIA_DISP_PIX 80 +#define IMX93_CLK_CAM_PIX 81 +#define IMX93_CLK_MIPI_TEST_BYTE 82 +#define IMX93_CLK_MIPI_PHY_CFG 83 +#define IMX93_CLK_ADC 84 +#define IMX93_CLK_PDM 85 +#define IMX93_CLK_TSTMR1 86 +#define IMX93_CLK_TSTMR2 87 +#define IMX93_CLK_MQS1 88 +#define IMX93_CLK_MQS2 89 +#define IMX93_CLK_AUDIO_XCVR 90 +#define IMX93_CLK_SPDIF 91 +#define IMX93_CLK_ENET 92 +#define IMX93_CLK_ENET_TIMER1 93 +#define IMX93_CLK_ENET_TIMER2 94 +#define IMX93_CLK_ENET_REF 95 +#define IMX93_CLK_ENET_REF_PHY 96 +#define IMX93_CLK_I3C1_SLOW 97 +#define IMX93_CLK_I3C2_SLOW 98 +#define IMX93_CLK_USB_PHY_BURUNIN 99 +#define IMX93_CLK_PAL_CAME_SCAN 100 +#define IMX93_CLK_A55_GATE 101 +#define IMX93_CLK_CM33_GATE 102 +#define IMX93_CLK_ADC1_GATE 103 +#define IMX93_CLK_WDOG1_GATE 104 +#define IMX93_CLK_WDOG2_GATE 105 +#define IMX93_CLK_WDOG3_GATE 106 +#define IMX93_CLK_WDOG4_GATE 107 +#define IMX93_CLK_WDOG5_GATE 108 +#define IMX93_CLK_SEMA1_GATE 109 +#define IMX93_CLK_SEMA2_GATE 110 +#define IMX93_CLK_MU_A_GATE 111 +#define IMX93_CLK_MU_B_GATE 112 +#define IMX93_CLK_EDMA1_GATE 113 +#define IMX93_CLK_EDMA2_GATE 114 +#define IMX93_CLK_FLEXSPI1_GATE 115 +#define IMX93_CLK_GPIO1_GATE 116 +#define IMX93_CLK_GPIO2_GATE 117 +#define IMX93_CLK_GPIO3_GATE 118 +#define IMX93_CLK_GPIO4_GATE 119 +#define IMX93_CLK_FLEXIO1_GATE 120 +#define IMX93_CLK_FLEXIO2_GATE 121 +#define IMX93_CLK_LPIT1_GATE 122 +#define IMX93_CLK_LPIT2_GATE 123 +#define IMX93_CLK_LPTMR1_GATE 124 +#define IMX93_CLK_LPTMR2_GATE 125 +#define IMX93_CLK_TPM1_GATE 126 +#define IMX93_CLK_TPM2_GATE 127 +#define IMX93_CLK_TPM3_GATE 128 +#define IMX93_CLK_TPM4_GATE 129 +#define IMX93_CLK_TPM5_GATE 130 +#define IMX93_CLK_TPM6_GATE 131 +#define IMX93_CLK_CAN1_GATE 132 +#define IMX93_CLK_CAN2_GATE 133 +#define IMX93_CLK_LPUART1_GATE 134 +#define IMX93_CLK_LPUART2_GATE 135 +#define IMX93_CLK_LPUART3_GATE 136 +#define IMX93_CLK_LPUART4_GATE 137 +#define IMX93_CLK_LPUART5_GATE 138 +#define IMX93_CLK_LPUART6_GATE 139 +#define IMX93_CLK_LPUART7_GATE 140 +#define IMX93_CLK_LPUART8_GATE 141 +#define IMX93_CLK_LPI2C1_GATE 142 +#define IMX93_CLK_LPI2C2_GATE 143 +#define IMX93_CLK_LPI2C3_GATE 144 +#define IMX93_CLK_LPI2C4_GATE 145 +#define IMX93_CLK_LPI2C5_GATE 146 +#define IMX93_CLK_LPI2C6_GATE 147 +#define IMX93_CLK_LPI2C7_GATE 148 +#define IMX93_CLK_LPI2C8_GATE 149 +#define IMX93_CLK_LPSPI1_GATE 150 +#define IMX93_CLK_LPSPI2_GATE 151 +#define IMX93_CLK_LPSPI3_GATE 152 +#define IMX93_CLK_LPSPI4_GATE 153 +#define IMX93_CLK_LPSPI5_GATE 154 +#define IMX93_CLK_LPSPI6_GATE 155 +#define IMX93_CLK_LPSPI7_GATE 156 +#define IMX93_CLK_LPSPI8_GATE 157 +#define IMX93_CLK_I3C1_GATE 158 +#define IMX93_CLK_I3C2_GATE 159 +#define IMX93_CLK_USDHC1_GATE 160 +#define IMX93_CLK_USDHC2_GATE 161 +#define IMX93_CLK_USDHC3_GATE 162 +#define IMX93_CLK_SAI1_GATE 163 +#define IMX93_CLK_SAI2_GATE 164 +#define IMX93_CLK_SAI3_GATE 165 +#define IMX93_CLK_MIPI_CSI_GATE 166 +#define IMX93_CLK_MIPI_DSI_GATE 167 +#define IMX93_CLK_LVDS_GATE 168 +#define IMX93_CLK_LCDIF_GATE 169 +#define IMX93_CLK_PXP_GATE 170 +#define IMX93_CLK_ISI_GATE 171 +#define IMX93_CLK_NIC_MEDIA_GATE 172 +#define IMX93_CLK_USB_CONTROLLER_GATE 173 +#define IMX93_CLK_USB_TEST_60M_GATE 174 +#define IMX93_CLK_HSIO_TROUT_24M_GATE 175 +#define IMX93_CLK_PDM_GATE 176 +#define IMX93_CLK_MQS1_GATE 177 +#define IMX93_CLK_MQS2_GATE 178 +#define IMX93_CLK_AUD_XCVR_GATE 179 +#define IMX93_CLK_SPDIF_GATE 180 +#define IMX93_CLK_HSIO_32K_GATE 181 +#define IMX93_CLK_ENET1_GATE 182 +#define IMX93_CLK_ENET_QOS_GATE 183 +#define IMX93_CLK_SYS_CNT_GATE 184 +#define IMX93_CLK_TSTMR1_GATE 185 +#define IMX93_CLK_TSTMR2_GATE 186 +#define IMX93_CLK_TMC_GATE 187 +#define IMX93_CLK_PMRO_GATE 188 +#define IMX93_CLK_32K 189 +#define IMX93_CLK_END 190 + +#endif From patchwork Fri Feb 25 01:42:32 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Peng Fan (OSS)" X-Patchwork-Id: 12759520 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 21073C433F5 for ; Fri, 25 Feb 2022 01:42:59 +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=BxXKjrpXYNBoh5GVfrlZJZUXxUzQ3HAzmojW0GnxJ9I=; b=AUlXYi42HgiMd9 fKJRwVjEj6ti2v07ANMREEquNhDg0a1e9zV4OwmEU9rn0C4VSVGoklDIgANRqhfDIJUBLMkpYc2pT /ocE9VOpbC+Kn//RYz3y5HDmnlQXe4pRhanHw3HxN/FEtjlaAydql7RFq+5m+rZ5Gu1Y1wgbjrA6a dUrB1eIVOMZDpwrrrseIM3w22xO7wMvAIfsqyyPyDQw1P0m+4OG1mzconLdJ2iZ/Zh2yNnb2fZW4Q sVcB57e8RG/SGojLvVpyx99KcBy+u7f3hq0Xo0/HiQyQmTcCaxIKe3f6ODdIeSdkxFyiJ3GaLm4Pj 7IYAX/bAbsjaIfgf08cw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPbq-002scB-49; Fri, 25 Feb 2022 01:41:26 +0000 Received: from mail-vi1eur05on20622.outbound.protection.outlook.com ([2a01:111:f400:7d00::622] helo=EUR05-VI1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPbR-002sUe-PT for linux-arm-kernel@lists.infradead.org; Fri, 25 Feb 2022 01:41:03 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=beDJz/82IkfSRBjLCHiFyyhkrJgfzeY5MKxBVeuwKGoQGbwT6LiAE9V7YrcoHdc4X0O/OhhuTlIgH9Ykm5QkBDB8ZqcD6VJHCf5hJKn4/VxbphwJJMeRBn2v30KauQZImiBGCwAc4VNj+PS3W/8027BTBDaHblOo6qnQf8GGR9yVwDYgqAlftae8kLcPpzzlZp3f4qxVt96N3djO8y24sdGZnrCYywmiCjnp7T9zJIpWvY6yNgyOjk1VQm3Rhyx1eH4Q/sVGhi26hIdcvVsuiJmsrtgTaKWUr2Z4ILScQQmbTe2AytUJ1LlIbAephmgz1roDUqJ6+cflyYfw9NtoEQ== 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=95IDiUFtvRZ0WigCxqiNnm/vDbrI1VwXxaIzhdy3oT0=; b=R1HHSgT2Wp7apZ8kvUr3hSOoCTOs/Eo8heQFRj69wkCRWWRIoJ5agExF5DoNabNADS1Jlq2breUSWCZYb66rGP9x3kH9c8gM14nUVsKjYo/jYO9/nL695BkoLGzPr5di3HfpnXTMzR8a2XU1lhF9uPBLf2Wutjzavh15PtJoAUhmiDCpwIAajgPWZSzs5g0iLazYoGq+0kQzw7UGJiifiwPapnLBbytaQVJ9L/yw+UdD1Eixos9QulHKK8Ook/e334LybSJOJJUTBafCoiFgkL2cra1U5Oum0rE7y7ND3hnZLsG1cB5pqZLhHPo00BPBqxuGGBN+qjgQFHdFNJhLzg== 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=selector2-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=95IDiUFtvRZ0WigCxqiNnm/vDbrI1VwXxaIzhdy3oT0=; b=HQc+a2tOuxtgkjiU4qZuK5c0XpZ+AVK9aBsqwRQfNtNwoDuY8+lS9RwpCpRpfm0pBhjGG2cyBGXAmnmYBSHYfJBcWK3bZuAEmtEK64L/AYCQ99fEWa5T7qxxfgkgBFRwC74RGrmQQQRiTGW/SgtsF9WzrSFgHKRbf4vJidQqoEI= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) by AM0PR04MB5316.eurprd04.prod.outlook.com (2603:10a6:208:d0::25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5017.25; Fri, 25 Feb 2022 01:40:58 +0000 Received: from DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc]) by DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc%4]) with mapi id 15.20.4995.018; Fri, 25 Feb 2022 01:40:58 +0000 From: "Peng Fan (OSS)" To: sboyd@kernel.org, robh+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, abel.vesa@nxp.com Cc: kernel@pengutronix.de, festevam@gmail.com, linux-imx@nxp.com, linux-clk@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Peng Fan Subject: [PATCH V5 3/5] clk: imx: add i.MX93 composite clk Date: Fri, 25 Feb 2022 09:42:32 +0800 Message-Id: <20220225014234.1766305-4-peng.fan@oss.nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220225014234.1766305-1-peng.fan@oss.nxp.com> References: <20220225014234.1766305-1-peng.fan@oss.nxp.com> X-ClientProxiedBy: SI2PR02CA0018.apcprd02.prod.outlook.com (2603:1096:4:194::18) To DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: dd1de25b-6fb1-427a-f4f5-08d9f7ffdf47 X-MS-TrafficTypeDiagnostic: AM0PR04MB5316:EE_ X-MS-Exchange-SharedMailbox-RoutingAgent-Processed: True X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: 6q9w3d21M5XUTVOdkUPmEIHYRro2IRgW4OEcAyX/spx4Wr9TCs8cvieB4qn+5Mv0ZZD9luUx0sxH8ObQeiA3UH3wOqH5h2vpAgBWaq+1HPJMyFS0oftzHRvkX8QHiOODJbglYW8IFGmocx2auQ/PZ2bUPQ6BzFY0/lvW4zJoSPUTVCPEK+4TOVejHU6XCDjNnussF1smRWzhoCSt1tptXN8krI4iKShA3Im9tj2bZxdsazEa7x5x+X5rY2k66TLuFCMkrkrLpAHb9ILyNn9PVjvmRzXjTdxYiGewQ8W+ryyElLn0DwJT13/os5uU2im/2qc09XzrzciVo4VrDoW3Vp+RcRh2qzHnWNLpkFOVF8ohmqFk/gypQHPmpze2vT2XRmkzGiGd2GFvPUEUWvbynQmIT7H6Wt9fzikhX4/ulk0qRsP3mFCQTKCuJaIwTihxMGZbF1xzAuODAkWoeB16anL6FcycNJ28i65g5R6lRPyn7/zMPBKqmv0lDOycn4l9WjKznTzDfN3TQsoa/pcuaw4hwcflzFD9hGp6u5AVK6AK7xftqZUQqhrACjnHA78KbSxzjOXhtCwUyYfF+oY87AU2ZcBqZSXiJdBD4G85xkAR4gxsjl22GcTyzWnvNyRbCB463z7CCdGeHyOIicEs0I0KpMpLyyQJPZQ+0NzvUMHQ0wHdiSyWDUEsJASORrBLlHcxgNyoMJUlOuMdCtQigQ== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DU0PR04MB9417.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230001)(4636009)(366004)(8936002)(508600001)(38100700002)(83380400001)(38350700002)(6486002)(316002)(66946007)(5660300002)(7416002)(6512007)(6666004)(8676002)(86362001)(66476007)(66556008)(4326008)(52116002)(2906002)(2616005)(26005)(1076003)(186003)(6506007); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: VPYIE5iWIYKz5+IgvmPh6JdVerwtW9JaLjxk/RHmeZgDA0S67hCc1/sPzLaoahmIPXVEZNjYimVCfEwiStbSQGf5uC3d3+0z8hqYiluHZ492p4iTAou4vurEMbE4P7a8K3wX+7lICBAqpIEZg3sVuYunJCuwgnZJtUpgYvYP6TcqoYoRp3SIVWoWn07HkhNwL4trEjmM8KSm3Za1yIiCRAm5AfB/hpfos9tv/Kpkxbagzz1ArURzSTHOk6LA4vrA/sxxcDhaXCvIrjJWvkxrm+h2YM+cDS7BjmsG9EXB+Z4mqFvJInLOKUDpAWAPyxRCguF86SulLDOIBhp41qHJpxIdr47afbDeT2iUd1fB1vhdAhg3XSggOKx5UXt78V3gJYJhfrOkVR1u8uq0mE2dX8av7MZzSyrxXehPzoizAei4XJeSMpIjH9xUuX+T7AdJZBzbx0oUFahjKqt+5UWBBJv8msx/LH3spR/0kv3gE9/GgekN89RODSnxb24dSs7fN4mCRSni9/YCN0b/MIB+t1VdZxY+YUPnjUl3TzEm0Y98whb+bsVPB2fU298mFtmfI/xsfIkzI4PqQ/j3kLR7AxeWnVhnfqukdPsQwXqfp7Dj7LyhIRdxN5ep/XIy+f+aYWxSUMKfvQzeN9+x9l+NznttHmlZ1uSLV3r9ALG3i2gQu/L5hLBl6ULy9NJGM2BV9fHqHZrHs6H0KmbIHnv4o5UetfT7AWZ4LN9ulbnV0Mok9uaQULVlEbaFoxtmI+MqbTQcswJxL27f7+GclSFwZE6KJaVpPhcvYQgR/kbhqR33mZQYM2B/hGEfXcAJ6H12uq+BUcq5or/+NfYp4dviERFFPfscPlThuYZaVoGY47aSfvrB58NaRU4Jc5R/+v3VP9UD3e2uUU9cgmFlgmJ7iljcJgDa14leF5NAOb2SprtGDkDsa0zWNVW8BCtBG2tPlYwTibXhEeor78WG0Zqhp65+eAI4F5g8BiYFAi6uhtW3XQy+P0C1KDPsgiND8o8+7e45xPUbIUvT+jSxhBuZPe7iowIESoaCcktvt/00o0bb69a1hexylIwXPYpwApvoaNJeDtbloYkk8g/LILLAAC3uBcfQN6E2DO/mUELDzokyZoIALcDJfOtAhrHIpjfu81GR027imVPYkP8zsAKjZpt4F0iUCPEXihmXUiaZwFaAFbImcacLaS+/zHNNR6omqH0V7FR+JB5JB9iZuqh4C2PNjULhBgvh5D6D4xxG9mMTGYRONXc4UmlRAInyTXEzv5PVl3ZovRn9Uyeh6m2e5DevhD5tjdS+eKDU23Xj4WH6qQwXPufTbZsry2jnDLKDa7T7N2b4LkiLS4VFJdhx2u8YGrz4+BXuKyu8ZNNMlO0SLk80z60LQHqzsvgz45z1p4XOLn8tK/QbXPdfvyuQLOXb0PY3QJFnZENt3CIsW9nqS5GuJ6Wh/RlIVzjeghv69tMl86PiUlILnSGnpaMMU4GkslQ++NsbBEe7bZBtXSRVZGTseHxU281pD2OylhW9ReJPDCkl87uI5TvMClhgKGzmnn4rgTP0iHmDDjhl46x+ZJhD6BWEV8zW3pyJ3iGK35JpLIPSWUqXydH1KJGG010hZRJDqo+KixPePGuH9Bo= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: dd1de25b-6fb1-427a-f4f5-08d9f7ffdf47 X-MS-Exchange-CrossTenant-AuthSource: DU0PR04MB9417.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 Feb 2022 01:40:58.5954 (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: WmnYrb9rjjEzQzHfOSgxZDC2dUDvb7je73JJrQzjwZCQLdRfWUGVVHpIXeBoixE6bxOBgcWZblMwro3+aVpaMA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM0PR04MB5316 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220224_174101_856608_64761BD0 X-CRM114-Status: GOOD ( 16.03 ) 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.MX93 CCM ROOT clock has a mux, gate and divider in one register, here is to combine all these into one composite clk and simplify clk tree. i.MX93 CCM is a new IP compared with i.MX8M, so introduce a new file. Reviewed-by: Abel Vesa Signed-off-by: Peng Fan Reviewed-by: Stephen Boyd --- drivers/clk/imx/Makefile | 1 + drivers/clk/imx/clk-composite-93.c | 93 ++++++++++++++++++++++++++++++ drivers/clk/imx/clk.h | 9 +++ 3 files changed, 103 insertions(+) create mode 100644 drivers/clk/imx/clk-composite-93.c diff --git a/drivers/clk/imx/Makefile b/drivers/clk/imx/Makefile index aa8f5204d7e1..36c04922d789 100644 --- a/drivers/clk/imx/Makefile +++ b/drivers/clk/imx/Makefile @@ -4,6 +4,7 @@ mxc-clk-objs += clk.o mxc-clk-objs += clk-busy.o mxc-clk-objs += clk-composite-7ulp.o mxc-clk-objs += clk-composite-8m.o +mxc-clk-objs += clk-composite-93.o mxc-clk-objs += clk-cpu.o mxc-clk-objs += clk-divider-gate.o mxc-clk-objs += clk-fixup-div.o diff --git a/drivers/clk/imx/clk-composite-93.c b/drivers/clk/imx/clk-composite-93.c new file mode 100644 index 000000000000..b44619aa5ca5 --- /dev/null +++ b/drivers/clk/imx/clk-composite-93.c @@ -0,0 +1,93 @@ +// SPDX-License-Identifier: GPL-2.0+ +/* + * Copyright 2021 NXP + * + * Peng Fan + */ + +#include +#include +#include +#include +#include + +#include "clk.h" + +#define CCM_DIV_SHIFT 0 +#define CCM_DIV_WIDTH 8 +#define CCM_MUX_SHIFT 8 +#define CCM_MUX_MASK 3 +#define CCM_OFF_SHIFT 24 + +#define AUTHEN_OFFSET 0x30 +#define TZ_NS_SHIFT 9 +#define TZ_NS_MASK BIT(9) + +struct clk_hw *imx93_clk_composite_flags(const char *name, const char * const *parent_names, + int num_parents, void __iomem *reg, + unsigned long flags) +{ + struct clk_hw *hw = ERR_PTR(-ENOMEM), *mux_hw; + struct clk_hw *div_hw, *gate_hw; + struct clk_divider *div = NULL; + struct clk_gate *gate = NULL; + struct clk_mux *mux = NULL; + bool clk_ro = false; + + mux = kzalloc(sizeof(*mux), GFP_KERNEL); + if (!mux) + goto fail; + + mux_hw = &mux->hw; + mux->reg = reg; + mux->shift = CCM_MUX_SHIFT; + mux->mask = CCM_MUX_MASK; + mux->lock = &imx_ccm_lock; + + div = kzalloc(sizeof(*div), GFP_KERNEL); + if (!div) + goto fail; + + div_hw = &div->hw; + div->reg = reg; + div->shift = CCM_DIV_SHIFT; + div->width = CCM_DIV_WIDTH; + div->lock = &imx_ccm_lock; + div->flags = CLK_DIVIDER_ROUND_CLOSEST; + + if (!(readl(reg + AUTHEN_OFFSET) & TZ_NS_MASK)) + clk_ro = true; + + if (clk_ro) { + hw = clk_hw_register_composite(NULL, name, parent_names, num_parents, + mux_hw, &clk_mux_ro_ops, div_hw, + &clk_divider_ro_ops, NULL, NULL, flags); + } else { + gate = kzalloc(sizeof(*gate), GFP_KERNEL); + if (!gate) + goto fail; + + gate_hw = &gate->hw; + gate->reg = reg; + gate->bit_idx = CCM_OFF_SHIFT; + gate->lock = &imx_ccm_lock; + gate->flags = CLK_GATE_SET_TO_DISABLE; + + hw = clk_hw_register_composite(NULL, name, parent_names, num_parents, + mux_hw, &clk_mux_ops, div_hw, + &clk_divider_ops, gate_hw, + &clk_gate_ops, flags | CLK_SET_RATE_NO_REPARENT); + } + + if (IS_ERR(hw)) + goto fail; + + return hw; + +fail: + kfree(gate); + kfree(div); + kfree(mux); + return ERR_CAST(hw); +} +EXPORT_SYMBOL_GPL(imx93_clk_composite_flags); diff --git a/drivers/clk/imx/clk.h b/drivers/clk/imx/clk.h index 7d220a01de1f..63eb7c53b123 100644 --- a/drivers/clk/imx/clk.h +++ b/drivers/clk/imx/clk.h @@ -419,6 +419,15 @@ struct clk_hw *__imx8m_clk_hw_composite(const char *name, IMX_COMPOSITE_FW_MANAGED, \ IMX_COMPOSITE_CLK_FLAGS_CRITICAL_GET_RATE_NO_CACHE) +struct clk_hw *imx93_clk_composite_flags(const char *name, + const char * const *parent_names, + int num_parents, + void __iomem *reg, + unsigned long flags); +#define imx93_clk_composite(name, parent_names, num_parents, reg) \ + imx93_clk_composite_flags(name, parent_names, num_parents, reg, \ + CLK_SET_RATE_NO_REPARENT | CLK_OPS_PARENT_ENABLE) + struct clk_hw *imx_clk_hw_divider_gate(const char *name, const char *parent_name, unsigned long flags, void __iomem *reg, u8 shift, u8 width, u8 clk_divider_flags, const struct clk_div_table *table, From patchwork Fri Feb 25 01:42:33 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Peng Fan (OSS)" X-Patchwork-Id: 12759521 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 6EA4FC433F5 for ; Fri, 25 Feb 2022 01:43:15 +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=shOuzNJ/0/neJAhjszlK+hLJN1T/4VpNdms3W6N2GYI=; b=YKvsOeOhtCXD8Z +iX1+8PVv0AdoTWGtc5ZEl9AR5eO9aSX/L0DspNOs7YxBiaLahvgdmoCwSEv7icBdC5tmjtDZka4N eIGY904o01CPv5fhTOt5+g8AXdkDdLfYwWKF2tcoRVhysgSSoWFmt06hlGCH4QQCazgVS8tOqIzbJ dy3rSC55vHpN37wOs4Ddtt57HDeZ8jLFmLpf8IB/aFRMluuF8F5XVXTDX/X6ISVij4zqPV7SsbKIR XgLH/+bcVYnYfn+8/UeulgAGEvytU4sWtKj6RK10W2xcU276dpc+d2ELJqTWt6WFyHanDxRBToRoB x5RpcB6lBpX2r5uiHgcQ==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPc5-002sgQ-2F; Fri, 25 Feb 2022 01:41:41 +0000 Received: from mail-vi1eur05on2060d.outbound.protection.outlook.com ([2a01:111:f400:7d00::60d] helo=EUR05-VI1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPbW-002sWF-Ll for linux-arm-kernel@lists.infradead.org; Fri, 25 Feb 2022 01:41:08 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=KJ/TFDuUeZ3goPxvWohIxUKYywtWbwNgYsPckJnYV4Eyh9x8mkfkJl1kw+fUtAxRIMlBHAvbIjKgtOsxE3MhlIafffrfh3/QYZQiBh7vwR5ebLZDf7qVdKH0cTs91bocVrUkVMQ0H0QzGkzTr/LQVxzB0JdMcCARUPACAVe5iqL3mGtgx17HfFoNrhGPaYlam67zQtKUPp6vRxQtXpRcRMOGryMf7S6IGpGaUT0KxI56wMxNAkl57q3vcDvzoEJkf7Y5iOpoxJp0qH211vEUjPGC3LnuzCq/IrdyUYHuTyBL8LmSjpZ8W6l2eIH0kvJEq1r8UxCPJHo9F+YTq9g8qw== 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=472JtMyjDKwlsbwQ+gio1oaDgOuinj7d63Xp5NSztZw=; b=MmSmHjB/F6erUPBjja872TdpoaDnVRnSe7wr4I5jQ6Jx+RyfMX+T9BrROoezFFLGrYDi0p2nBOVL1D/ML+cwcXBXP7IHH6h7p9YwsACLU2LpSPNWUu+zBND2seU8IYnC0dy7U+QAv8QZS+WM3X37CSDP77PGhVMK9L+n0AU/So2p80cz0JZIEvS+5/jrML8K37hYTrkdYzWN3p0K7v+ci1FvK4rW/Jw6mVPzOneLoXNbcZ6hBZa7ycqnsRLzQwQcPrkOu0K4gG5e6i4r5/Z2kuM6cHacaShQC6/EGlvuAskVnn2f25XDm6i/BnVp63wgAjt3UfQ7JeSmVpTIlmkBjw== 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=selector2-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=472JtMyjDKwlsbwQ+gio1oaDgOuinj7d63Xp5NSztZw=; b=giZrCpgE0sCjJw9tLDA0y9GWcV1H4IAMoYg0Dyj181+AK4YTBOXrGLh+Q7CkqTlLPNs82n7Yez5ZirUUoZhqwDK8aDBBA+9XjqfxY06CLDqfpkEupV/erhu0RmyauFnrOkZ32fuOi5Hj8V7sTYf77QeiY4hKmX2X+4M6NWRSQ70= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) by AM0PR04MB5316.eurprd04.prod.outlook.com (2603:10a6:208:d0::25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5017.25; Fri, 25 Feb 2022 01:41:02 +0000 Received: from DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc]) by DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc%4]) with mapi id 15.20.4995.018; Fri, 25 Feb 2022 01:41:02 +0000 From: "Peng Fan (OSS)" To: sboyd@kernel.org, robh+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, abel.vesa@nxp.com Cc: kernel@pengutronix.de, festevam@gmail.com, linux-imx@nxp.com, linux-clk@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Peng Fan Subject: [PATCH V5 4/5] clk: imx: support fracn gppll Date: Fri, 25 Feb 2022 09:42:33 +0800 Message-Id: <20220225014234.1766305-5-peng.fan@oss.nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220225014234.1766305-1-peng.fan@oss.nxp.com> References: <20220225014234.1766305-1-peng.fan@oss.nxp.com> X-ClientProxiedBy: SI2PR02CA0018.apcprd02.prod.outlook.com (2603:1096:4:194::18) To DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: c8e80b7e-8d86-410e-04a0-08d9f7ffe1a8 X-MS-TrafficTypeDiagnostic: AM0PR04MB5316:EE_ X-MS-Exchange-SharedMailbox-RoutingAgent-Processed: True X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: NdmHRA7lC5vHROEzwY3+7hpvrp+U5OrZ7jkDPCEyJnI17JAFRPQMeR05Bo3qQFIqhskYbzpxm3Mz+kRLII8f4r++5f23/+xtQ4O3kjYHlBOqKo9QmKUdSgPZy0Vtp1OONFQ5DGdLQCVMUnaSjbdE1bcKVBcberBKamGNkDK7WbG4WyZz2VkxXSoNsuRzBEK3HrgP4sVno8iEwJRj4QHX/inwngDnF9IP81HzKC6IrMxe5Il8iRwgilFLov8s5jArYpbGxUmEiL5HmxVZyVTCkYchLc8v65SGgoWKqHrl/Fh0BYQeRNh/LWHsIxUfX7Pp0w+Ql9tQhWSossqOALuSirDEjqbK4QKBbOKIX4zbQn62ZOMA0YARm5VgDbyDLltYMPN0RdJl7Soiby+7oaQwPOzghi/BQnaHPxVHRN6sewSNe9svl5u0rmTbibq72eIOZs/nLaASXopfSVxB4Fvmv0uScuDE+Sm8N6TajCQja+pHL6L48gZKZoGuWL0CVfdKAH0RS4BZFN3VjyoVk7KIrtOhQ84i6+tmO2y80Pu+RiCJD0J+2Fm232hIa0WJbcOjjzPFQV+C9cQrojqIp8uK6s/JF3PLkACcL4mQwdT9UqsAgyREUwmYUqeuWt/OexsrWnskEXRZCDwsLCehpOLboGc4duNjNgKaxRYmqluBeDGKpEQy8sWYh4YGdFy55AHI7ds9EHxztvszFasfGO/YUA== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DU0PR04MB9417.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230001)(4636009)(366004)(8936002)(508600001)(38100700002)(83380400001)(38350700002)(6486002)(316002)(66946007)(5660300002)(7416002)(6512007)(6666004)(8676002)(86362001)(66476007)(66556008)(4326008)(52116002)(2906002)(2616005)(30864003)(26005)(1076003)(186003)(6506007); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: Qx+LykGTbYyZ5ZS8oLO3dszaPZkZIWMqruBr77E2f90gzrowtDONeCRte/5oPF/yGoJZ1zhW1II1xBzzvwgQidaO/Ow+VT/A2YVHbYTgssGjn+t5WDebwRTKgvpXlC5Ji+gC4hiSeeD2VfqDg4+INCpdHE24lgZfQhsw1jhSzktADaVrHeVaKkAXgeBIKAmCcd+TIicitSaCd2qD9XyrpkBdI/2eXmO3EAOMx7Or+P0YjriI3JxcwLR1/cukRKAhzpZ8V4awdgDRNHAsOtzlWTCblXunsIdF6axpBqzlPH/xYUcGl2TQEErCZj5YYN+UK6Xa9X0ftV7NgQPRRYCoOZ6UBuQGl+d0SfxIZ+9NoN2A7pBMNuQ6ynTstLF/luDWvtuL16aBL9WUf/tyOEmaL5WVG71BVRIaQ1B8QicmL7+2irU4m/lyEA1tUwiSOImNdWSxzSDQwSTJ4392S80r5g0tJfLm2xsFlA52whV+WwRadTNv9Vbvd0eq9sZBx3Ve+QIDF57LB2GhFO0xoSCV2o84G1u9tenkNRlkH7n7b8u/rF0MmgN8FjWE3SF2Isp4jEX8RNy3a+bryUup2y2R6bx+3/8khzfE0ATRxRYWhT1z+MQ2s70DshFT28a6KGk89zzm7SHALPXmR8TcsHnBHGb7SOwGCcslE2fzuBvo60rcakkW35XjvPUb8Sx06LojcXPoroG5oxwyHyIAzBx2NvksbBS9HHZinP/AWcrtzGP6aQb9goWQYdE/s5ApJQy4mGpTu12ZcrOI98OGrnL8hoI6OrzosyfLZoiTn3U792ZNLj/RK0YtGxS4l95x3M8EWHTyUX277FqXSa+1smoZdCvoCy4k0thmUcgYViCmXG8PWMcHDy+aWu7jCC0QzuJ26OuDm9/V4+sQKFHgI4zgRt40/m2DuaZgrqbt5QNNY5MapXx1ea00VhVConsAiVGQlhlA7q4QbCOhS97Lvbei+4BLNEnj+9CFA35dKlcj5gDlopzwODFcqei7L7bUq2D9usHih6Xocak9zWVwqCv5kPs+HdCzm/VL+TxN7AVqUYX4Y95tPoIyqIVKPzybHXW84NqmuhAwV1ifFsPSwxEWVOkXQPmA9PUbkJPtoj3MYqbnK+lJvVE7ZqEIdvyRHoOHuKVkxfJyWY+pMz9a2egsL0gnQt4zm0TdP9f2Zm/N/LxemiHYS86/9v3YoXEm59AGiyemMI/G9QpiSNKOs0UsO8e84gwERf3LPZ5riN1+bgMPx810drpBZUoNrcyeTld++NQA82lApfzwskUGfckaWak2Qk107gzIuzF3SGitQs5MtRzFAF9bYTQYqFUI+CuuzVOxibB1Cn+OvMovxiVrkaaOgBpQQZEI5emMD3uuqbKRkiHHY7YK4HBV/7iZ/jrPx/sJyHuESSXHS0SL7gtgknJudtcIube24PTICRvDd3EZHpfAvH5llwvW1v40iuurNY9MQLvkKzpLHqLDODwjq07P7hiEVXY6dx6KYKLuspf7hTuS8qnSp1sPYzyOmYh+qmNKfZ5FkcziE2H0XjI6DxgNgLwvFkN2BilTM6CWksA7Ht++SHgpQO8c5ubgNrOj+ljKQtnbFJzSjzQm+1eKWpdOnlUPVvZJz1WkQppKWys= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: c8e80b7e-8d86-410e-04a0-08d9f7ffe1a8 X-MS-Exchange-CrossTenant-AuthSource: DU0PR04MB9417.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 Feb 2022 01:41:02.7522 (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: mIj0XqAP5LoC0IBLzwSHeHTqbYYgCdpxB3/fCL2Vmz5mbzWX05mk8oGKstLfO912tYD54ueHnhn3T9x/Od2Q2g== X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM0PR04MB5316 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220224_174106_909602_AFCCE34D X-CRM114-Status: GOOD ( 20.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: , Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org From: Peng Fan This PLL module is a Fractional-N synthesizer, supporting 30-bit numerator and denominator. Numerator is a signed number. It has feature to adjust fractional portion of feedback divider dynamically. This fracn gppll is used in i.MX93. Reviewed-by: Abel Vesa Signed-off-by: Peng Fan Reviewed-by: Sascha Hauer --- drivers/clk/imx/Makefile | 1 + drivers/clk/imx/clk-fracn-gppll.c | 324 ++++++++++++++++++++++++++++++ drivers/clk/imx/clk.h | 21 ++ 3 files changed, 346 insertions(+) create mode 100644 drivers/clk/imx/clk-fracn-gppll.c diff --git a/drivers/clk/imx/Makefile b/drivers/clk/imx/Makefile index 36c04922d789..60c8a4bb7574 100644 --- a/drivers/clk/imx/Makefile +++ b/drivers/clk/imx/Makefile @@ -5,6 +5,7 @@ mxc-clk-objs += clk-busy.o mxc-clk-objs += clk-composite-7ulp.o mxc-clk-objs += clk-composite-8m.o mxc-clk-objs += clk-composite-93.o +mxc-clk-objs += clk-fracn-gppll.o mxc-clk-objs += clk-cpu.o mxc-clk-objs += clk-divider-gate.o mxc-clk-objs += clk-fixup-div.o diff --git a/drivers/clk/imx/clk-fracn-gppll.c b/drivers/clk/imx/clk-fracn-gppll.c new file mode 100644 index 000000000000..57b38147f05a --- /dev/null +++ b/drivers/clk/imx/clk-fracn-gppll.c @@ -0,0 +1,324 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright 2021 NXP + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "clk.h" + +#define PLL_CTRL 0x0 +#define CLKMUX_BYPASS BIT(2) +#define CLKMUX_EN BIT(1) +#define POWERUP_MASK BIT(0) + +#define PLL_ANA_PRG 0x10 +#define PLL_SPREAD_SPECTRUM 0x30 + +#define PLL_NUMERATOR 0x40 +#define PLL_MFN_MASK GENMASK(31, 2) + +#define PLL_DENOMINATOR 0x50 +#define PLL_MFD_MASK GENMASK(29, 0) + +#define PLL_DIV 0x60 +#define PLL_MFI_MASK GENMASK(24, 16) +#define PLL_RDIV_MASK GENMASK(15, 13) +#define PLL_ODIV_MASK GENMASK(7, 0) + +#define PLL_DFS_CTRL(x) (0x70 + (x) * 0x10) + +#define PLL_STATUS 0xF0 +#define LOCK_STATUS BIT(0) + +#define DFS_STATUS 0xF4 + +#define LOCK_TIMEOUT_US 200 + +#define PLL_FRACN_GP(_rate, _mfi, _mfn, _mfd, _rdiv, _odiv) \ + { \ + .rate = (_rate), \ + .mfi = (_mfi), \ + .mfn = (_mfn), \ + .mfd = (_mfd), \ + .rdiv = (_rdiv), \ + .odiv = (_odiv), \ + } + +struct clk_fracn_gppll { + struct clk_hw hw; + void __iomem *base; + const struct imx_fracn_gppll_rate_table *rate_table; + int rate_count; +}; + +/* + * Fvco = Fref * (MFI + MFN / MFD) + * Fout = Fvco / (rdiv * odiv) + */ +static const struct imx_fracn_gppll_rate_table fracn_tbl[] = { + PLL_FRACN_GP(650000000U, 81, 0, 0, 0, 3), + PLL_FRACN_GP(594000000U, 198, 0, 0, 0, 8), + PLL_FRACN_GP(560000000U, 70, 0, 0, 0, 3), + PLL_FRACN_GP(400000000U, 50, 0, 0, 0, 3), + PLL_FRACN_GP(393216000U, 81, 92, 100, 0, 5) +}; + +struct imx_fracn_gppll_clk imx_fracn_gppll = { + .rate_table = fracn_tbl, + .rate_count = ARRAY_SIZE(fracn_tbl), +}; +EXPORT_SYMBOL_GPL(imx_fracn_gppll); + +static inline struct clk_fracn_gppll *to_clk_fracn_gppll(struct clk_hw *hw) +{ + return container_of(hw, struct clk_fracn_gppll, hw); +} + +static const struct imx_fracn_gppll_rate_table * +imx_get_pll_settings(struct clk_fracn_gppll *pll, unsigned long rate) +{ + const struct imx_fracn_gppll_rate_table *rate_table = pll->rate_table; + int i; + + for (i = 0; i < pll->rate_count; i++) + if (rate == rate_table[i].rate) + return &rate_table[i]; + + return NULL; +} + +static long clk_fracn_gppll_round_rate(struct clk_hw *hw, unsigned long rate, + unsigned long *prate) +{ + struct clk_fracn_gppll *pll = to_clk_fracn_gppll(hw); + const struct imx_fracn_gppll_rate_table *rate_table = pll->rate_table; + int i; + + /* Assuming rate_table is in descending order */ + for (i = 0; i < pll->rate_count; i++) + if (rate >= rate_table[i].rate) + return rate_table[i].rate; + + /* return minimum supported value */ + return rate_table[pll->rate_count - 1].rate; +} + +static unsigned long clk_fracn_gppll_recalc_rate(struct clk_hw *hw, unsigned long parent_rate) +{ + struct clk_fracn_gppll *pll = to_clk_fracn_gppll(hw); + const struct imx_fracn_gppll_rate_table *rate_table = pll->rate_table; + u32 pll_numerator, pll_denominator, pll_div; + u32 mfi, mfn, mfd, rdiv, odiv; + u64 fvco = parent_rate; + long rate = 0; + int i; + + pll_numerator = readl_relaxed(pll->base + PLL_NUMERATOR); + mfn = FIELD_GET(PLL_MFN_MASK, pll_numerator); + + pll_denominator = readl_relaxed(pll->base + PLL_DENOMINATOR); + mfd = FIELD_GET(PLL_MFD_MASK, pll_denominator); + + pll_div = readl_relaxed(pll->base + PLL_DIV); + mfi = FIELD_GET(PLL_MFI_MASK, pll_div); + + rdiv = FIELD_GET(PLL_RDIV_MASK, pll_div); + rdiv = rdiv + 1; + odiv = FIELD_GET(PLL_ODIV_MASK, pll_div); + switch (odiv) { + case 0: + odiv = 2; + break; + case 1: + odiv = 3; + break; + default: + break; + } + + /* + * Sometimes, the recalculated rate has deviation due to + * the frac part. So find the accurate pll rate from the table + * first, if no match rate in the table, use the rate calculated + * from the equation below. + */ + for (i = 0; i < pll->rate_count; i++) { + if (rate_table[i].mfn == mfn && rate_table[i].mfi == mfi && + rate_table[i].mfd == mfd && rate_table[i].rdiv == rdiv && + rate_table[i].odiv == odiv) + rate = rate_table[i].rate; + } + + if (rate) + return (unsigned long)rate; + + /* Fvco = Fref * (MFI + MFN / MFD) */ + fvco = fvco * mfi * mfd + fvco * mfn; + do_div(fvco, mfd * rdiv * odiv); + + return (unsigned long)fvco; +} + +static int clk_fracn_gppll_wait_lock(struct clk_fracn_gppll *pll) +{ + u32 val; + + return readl_poll_timeout(pll->base + PLL_STATUS, val, + val & LOCK_STATUS, 0, LOCK_TIMEOUT_US); +} + +static int clk_fracn_gppll_set_rate(struct clk_hw *hw, unsigned long drate, + unsigned long prate) +{ + struct clk_fracn_gppll *pll = to_clk_fracn_gppll(hw); + const struct imx_fracn_gppll_rate_table *rate; + u32 tmp, pll_div, ana_mfn; + int ret; + + rate = imx_get_pll_settings(pll, drate); + + /* Disable output */ + tmp = readl_relaxed(pll->base + PLL_CTRL); + tmp &= ~CLKMUX_EN; + writel_relaxed(tmp, pll->base + PLL_CTRL); + + /* Power Down */ + tmp &= ~POWERUP_MASK; + writel_relaxed(tmp, pll->base + PLL_CTRL); + + /* Disable BYPASS */ + tmp &= ~CLKMUX_BYPASS; + writel_relaxed(tmp, pll->base + PLL_CTRL); + + pll_div = FIELD_PREP(PLL_RDIV_MASK, rate->rdiv) | rate->odiv | + FIELD_PREP(PLL_MFI_MASK, rate->mfi); + writel_relaxed(pll_div, pll->base + PLL_DIV); + writel_relaxed(rate->mfd, pll->base + PLL_DENOMINATOR); + writel_relaxed(FIELD_PREP(PLL_MFN_MASK, rate->mfn), pll->base + PLL_NUMERATOR); + + /* Wait for 5us according to fracn mode pll doc */ + udelay(5); + + /* Enable Powerup */ + tmp |= POWERUP_MASK; + writel_relaxed(tmp, pll->base + PLL_CTRL); + + /* Wait Lock */ + ret = clk_fracn_gppll_wait_lock(pll); + if (ret) + return ret; + + /* Enable output */ + tmp |= CLKMUX_EN; + writel_relaxed(tmp, pll->base + PLL_CTRL); + + ana_mfn = readl_relaxed(pll->base + PLL_STATUS); + ana_mfn = FIELD_GET(PLL_MFN_MASK, ana_mfn); + + WARN(ana_mfn != rate->mfn, "ana_mfn != rate->mfn\n"); + + return 0; +} + +static int clk_fracn_gppll_prepare(struct clk_hw *hw) +{ + struct clk_fracn_gppll *pll = to_clk_fracn_gppll(hw); + u32 val; + int ret; + + val = readl_relaxed(pll->base + PLL_CTRL); + if (val & POWERUP_MASK) + return 0; + + val |= CLKMUX_BYPASS; + writel_relaxed(val, pll->base + PLL_CTRL); + + val |= POWERUP_MASK; + writel_relaxed(val, pll->base + PLL_CTRL); + + val |= CLKMUX_EN; + writel_relaxed(val, pll->base + PLL_CTRL); + + ret = clk_fracn_gppll_wait_lock(pll); + if (ret) + return ret; + + val &= ~CLKMUX_BYPASS; + writel_relaxed(val, pll->base + PLL_CTRL); + + return 0; +} + +static int clk_fracn_gppll_is_prepared(struct clk_hw *hw) +{ + struct clk_fracn_gppll *pll = to_clk_fracn_gppll(hw); + u32 val; + + val = readl_relaxed(pll->base + PLL_CTRL); + + return (val & POWERUP_MASK) ? 1 : 0; +} + +static void clk_fracn_gppll_unprepare(struct clk_hw *hw) +{ + struct clk_fracn_gppll *pll = to_clk_fracn_gppll(hw); + u32 val; + + val = readl_relaxed(pll->base + PLL_CTRL); + val &= ~POWERUP_MASK; + writel_relaxed(val, pll->base + PLL_CTRL); +} + +static const struct clk_ops clk_fracn_gppll_ops = { + .prepare = clk_fracn_gppll_prepare, + .unprepare = clk_fracn_gppll_unprepare, + .is_prepared = clk_fracn_gppll_is_prepared, + .recalc_rate = clk_fracn_gppll_recalc_rate, + .round_rate = clk_fracn_gppll_round_rate, + .set_rate = clk_fracn_gppll_set_rate, +}; + +struct clk_hw *imx_clk_fracn_gppll(const char *name, const char *parent_name, void __iomem *base, + const struct imx_fracn_gppll_clk *pll_clk) +{ + struct clk_fracn_gppll *pll; + struct clk_hw *hw; + struct clk_init_data init; + int ret; + + pll = kzalloc(sizeof(*pll), GFP_KERNEL); + if (!pll) + return ERR_PTR(-ENOMEM); + + init.name = name; + init.flags = pll_clk->flags; + init.parent_names = &parent_name; + init.num_parents = 1; + init.ops = &clk_fracn_gppll_ops; + + pll->base = base; + pll->hw.init = &init; + pll->rate_table = pll_clk->rate_table; + pll->rate_count = pll_clk->rate_count; + + hw = &pll->hw; + + ret = clk_hw_register(NULL, hw); + if (ret) { + pr_err("%s: failed to register pll %s %d\n", __func__, name, ret); + kfree(pll); + return ERR_PTR(ret); + } + + return hw; +} +EXPORT_SYMBOL_GPL(imx_clk_fracn_gppll); diff --git a/drivers/clk/imx/clk.h b/drivers/clk/imx/clk.h index 63eb7c53b123..a7cbbcd1a3f4 100644 --- a/drivers/clk/imx/clk.h +++ b/drivers/clk/imx/clk.h @@ -72,6 +72,27 @@ extern struct imx_pll14xx_clk imx_1416x_pll; extern struct imx_pll14xx_clk imx_1443x_pll; extern struct imx_pll14xx_clk imx_1443x_dram_pll; +/* NOTE: Rate table should be kept sorted in descending order. */ +struct imx_fracn_gppll_rate_table { + unsigned int rate; + unsigned int mfi; + unsigned int mfn; + unsigned int mfd; + unsigned int rdiv; + unsigned int odiv; +}; + +struct imx_fracn_gppll_clk { + const struct imx_fracn_gppll_rate_table *rate_table; + int rate_count; + int flags; +}; + +struct clk_hw *imx_clk_fracn_gppll(const char *name, const char *parent_name, void __iomem *base, + const struct imx_fracn_gppll_clk *pll_clk); + +extern struct imx_fracn_gppll_clk imx_fracn_gppll; + #define imx_clk_cpu(name, parent_name, div, mux, pll, step) \ to_clk(imx_clk_hw_cpu(name, parent_name, div, mux, pll, step)) From patchwork Fri Feb 25 01:42:34 2022 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Peng Fan (OSS)" X-Patchwork-Id: 12759522 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 E96CEC433F5 for ; Fri, 25 Feb 2022 01:43:40 +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=fUzyeKWS79S14CdEyFuwXC1Ja7CF6dlM4bJembZ0ekE=; b=c7iGCV+wRtRM/j ZbZA05aJTfUzVf2Bwcnht/QgTV5BptdxVNklCDdJ+FsGZ24WQlGWo3AioDokxV2IGSHyWGoQJ6pzi JDSNE/hYvWfeNM627x02fopp62lc487/6s7yR5TKd1HTxNW2x1ifn4BZKQr70AeVuuXBuAbvTI1lp jCN1DCTZmTEMC80cUhQKYhACu2dvqqgBz/ldUX8oWtW8Zq8+GXb+PD0izCCqRTu2AVllhrBNC6BbW l9syP55NL6SKemOtJ8rA5j+9SBh4wdFOvX+e8zyHAhbQB/pp5NPejNIjWX5HUERdnzWJcJUNtrLSY t1AJmPkMcGRwXEsvhT1w==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPcX-002srS-Q7; Fri, 25 Feb 2022 01:42:10 +0000 Received: from mail-vi1eur05on20625.outbound.protection.outlook.com ([2a01:111:f400:7d00::625] helo=EUR05-VI1-obe.outbound.protection.outlook.com) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nNPbb-002sXq-Sk for linux-arm-kernel@lists.infradead.org; Fri, 25 Feb 2022 01:41:15 +0000 ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=kfswS2MJaEkkxq1bHMQglr9v8Uvpgg66BrHTaTtlQBR2qjtjRe1O7wEO1lQOgbhwDHQbLvf/StvPc0NDlPJ+rKK74IrWIECsEUGk7Kh/uDhv2S6iwThncz+cBGI3ji/USr00oAwZOtuyH/o+kLGKr6lCueNkBs/SMoNCtTMgq5vxyJnu26gP7ogkm9RrkP8LPk4ZqW3hMGHzefkuTAdqFM+sro4EvLm9iM3SdA1wG8LV1mP0tAYmLmphY7oQZEQZ4c1g00B8X06n0Ql4NbWf85cWOyXVujXdLU5eaVdBdQOj2aeFb+S2oh5q9H9loMVmbcreqiLq2/NduIZTBsXUww== 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=pWsqDCPjul/3v+fpSij+Ne9ILFushZ47W7wBext0djc=; b=ax94qN97L+tFXllWCrMQOf2J7hG41/TrAN4czTC3jxjS4NRuz6u9sQ1kxPZ1fiRsEVDcdDP6ZHxMgUeeIz+/Ns5/APvObFu4GTAnK0udA0Y8DvP6A9faIf6R2zGp0nfrVQtf1/IPK9nEG+hYx5zwpeDOiDFA9BXz7YOhV/n6UBpC3wZwyILZypKMqSfWKvIsHdOkaiaadxc4zCUsYGDdDfz9jdDx9dtDJbQj37pFoznKLhWm8aKNb6qBW33qMaAMjjJdqmU4PsPlBuM4Ti9fVwRyTZfMihjHLlc0Jb1xwSoIfdyM4V66lkZcEMzEuTx2pA9S5l/nYj+YIxa8MYQ76w== 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=selector2-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=pWsqDCPjul/3v+fpSij+Ne9ILFushZ47W7wBext0djc=; b=cZ+TwFIuG55rF9sGN2FrEQy8xBGYg4nij7JX9VL+RxevbIrcwUJfSu1NtCUKX6nK6KHaWw5UNI3lIL+gkRxwokhNjFKvUc7kq+5r9sKPhNbPXWlm0VbI+EsxAfnkrEaBawgneHFPHkmnRC5TLUglQNQUB8r6bAD2XYuh83yo0eE= Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) by AM0PR04MB5316.eurprd04.prod.outlook.com (2603:10a6:208:d0::25) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.5017.25; Fri, 25 Feb 2022 01:41:07 +0000 Received: from DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc]) by DU0PR04MB9417.eurprd04.prod.outlook.com ([fe80::552c:ed46:26dc:77cc%4]) with mapi id 15.20.4995.018; Fri, 25 Feb 2022 01:41:07 +0000 From: "Peng Fan (OSS)" To: sboyd@kernel.org, robh+dt@kernel.org, shawnguo@kernel.org, s.hauer@pengutronix.de, abel.vesa@nxp.com Cc: kernel@pengutronix.de, festevam@gmail.com, linux-imx@nxp.com, linux-clk@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Peng Fan Subject: [PATCH V5 5/5] clk: imx: add i.MX93 clk Date: Fri, 25 Feb 2022 09:42:34 +0800 Message-Id: <20220225014234.1766305-6-peng.fan@oss.nxp.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220225014234.1766305-1-peng.fan@oss.nxp.com> References: <20220225014234.1766305-1-peng.fan@oss.nxp.com> X-ClientProxiedBy: SI2PR02CA0018.apcprd02.prod.outlook.com (2603:1096:4:194::18) To DU0PR04MB9417.eurprd04.prod.outlook.com (2603:10a6:10:358::11) MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-Office365-Filtering-Correlation-Id: 23e0773d-2f3e-4dc5-0648-08d9f7ffe452 X-MS-TrafficTypeDiagnostic: AM0PR04MB5316:EE_ X-MS-Exchange-SharedMailbox-RoutingAgent-Processed: True X-Microsoft-Antispam-PRVS: X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0; X-Microsoft-Antispam-Message-Info: S4DwISU6KGoFMvAQt0UzISq5jCuGeFcw+6/9uw1ixdW+9XX2Df+q3cLsRWcd221AJ9Gmjb1hiLCbx/IiJqhD/BOwZsMbcA4LIO5BTZZUzPq8GIZuSDrQrKd5tYNtKDko458q3QLWBmtgJs7USrl3YWHl8pwlXDgNm38LS4ri8Ap3NecXK7/CdNP3gu0jtxmEH5Dg4MO1sNhbZGRyA7Cu7ejkEFsVzhLl7uI7LWdBLoi9bvcwGJPlf+jfVKDemt0lXTFhJTxMDsMTLueOJSfoQEqiRZ4ngLb0RRSjnLnIkdZoKOrBVzLNcSSUns6vG01fl05udBWHtk8I5930gL8VgO6twihZ6OrfkWFz85XhuhO1M29Rpp4EJ7bmcIJl1YcLadIK1hSj1fJD56jf6uCykQfWzfTx58YibGqhulFivqEAy6j3rEMH5VjAiy3K8YiTm7gnJXSdoT9OAJqXPJUL/30z2A2hfr2FB4pRWpNAG87kR4sq/nnD/0ytyMnQdk4Bu6YlH8YxkSFajt5O8huuaUDTik8aNMTexZKu/a8tBHIBbproeiGb4LJ0YvwuVO3Yf0zM6GM2+8k7e/IxMLTOVmlgPuk1n5TciE/LLIS2HaDsfm8fkJxERjtKNSoVJzJFuySgWklLusSc5n1di7ETIJ+wXExHuIqj8Yak3HcRPXySJx6GR1w1v+3oP89MkL70z8KEGYPx/grvfiIEY7lPYw== X-Forefront-Antispam-Report: CIP:255.255.255.255; CTRY:; LANG:en; SCL:1; SRV:; IPV:NLI; SFV:NSPM; H:DU0PR04MB9417.eurprd04.prod.outlook.com; PTR:; CAT:NONE; SFS:(13230001)(4636009)(366004)(8936002)(508600001)(38100700002)(83380400001)(38350700002)(6486002)(316002)(66946007)(5660300002)(7416002)(6512007)(6666004)(8676002)(86362001)(66476007)(66556008)(4326008)(52116002)(2906002)(2616005)(30864003)(26005)(1076003)(186003)(6506007); DIR:OUT; SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: nBHwTT1H09ilNpvm0zeiVds2eOKDC0f975yIIdtZ/00CTPJHJNqqwfF6jm0fLrVQSEX9y6zSeGspry/T7ye1T54BPbD54Qr/fplMog1T0GfiWvK15pEu5rvrjfSYTxvqAIoEi7IM9vXIKzkuZVC/KTYfJIu8dA7mn890XpjepiwapOp4dT5F5nzOEI/5ER/r1hPTPdvWU3+Dl5rITLbdnKjus+Rf1+ZMPQNQ8wyPkLoIskg0/4t7F6KeptZlfMu15m8H3bWV/Db/Q3gP0Vw3PMZPSP6DplxDqO9qS6Fy5eGOUVPuRuF7rDZnYieCJ/ZGts2YKMDeWrHY6gVhceFuIZKImqPQkXIpi5nLPi/MhpUTDovPj/mUHaBQnIb2lIhEkb/3BvZALe9TSfKtEkIXEr8LSmlHkwFo17etVAa5388ki+qKKHaHMY9gZf/26lP1E61DjTFpseHEQ68Uas0B/7LQSsqSMJ/kWmXm5EGkWk41MBsonUmZRysHVs3wuMohM5bf6nSxYXnod0MbblIcFRZHmDW6iCwrPdrw/KXPv+Sfabv3X9GAV5/GmvnF+HChXH2rFwy7F9RIHk0QtCXNxh/tbTsgUB5S8zUv4QUOtyXeurblkNamDafR+l73QlZNJfWhh4WuONGI0IUSUw9M3qKGOSZsaIAtwvLPlEzH8K0ADTRP6/iQSCttiInUylyKoyz2L++3gD17GEyh9W7XfKAKnb4XlUZeE5OC2Q6VSn2uuW2NGChcY/4/U/dgob20vM2CLu+fKtQf23ilqeA21/0n6fgwFqvdibIKsYOliJuCbAL6vZKAtDqQO6fnMcTqGuBpg22o3NTtHZmZdY32wK+RoVFTYH7b9tfFW0/drdBYH5IEAl2FW/VlpIS1uI5CVxhd51sdJvhh9S2udJCU2Sw8t8c9W/QBJu9WzrKRGbKlXfetY6wuDzy8cazsQ+DCTOnI0hfKJexx3TvYnWdEVudQnS6S374ORmFVyK7cFKP9nWTDoQnAyj+2jKCH40/K845qGFUlIqv1qLnefCe+XzlrBOvy2DH/4FGaqyhD4+OVk2nXDFKIY7iJ5PdWMFJWXNH8jzA9b9ZTx0KzBBPGElToZ2e1ni7b5dW3p+H31O8D0Y5K1uj6HjUODUHO+AOJXbovzn6i8V4004IXzT/GCOgzeUdb6AW9BIMnRD2BXyzFgJ5XqDeA+xSRfgN/k43Lducu/9oAeYTUdRkU00ess7hyOUdIDlhhFGPbKZ+Dw858+E2t8oVG7AmkMxTDQq/OjniVk9IBESUvmMAzOlkxFSVsWvQ+DNe00ovhTGbi4M/3Fme2U0vb3awPclVb+ebYdex5tZ/gyoEHiU5QhKp2CryAPVWbPNVOg1aKFZJBfAlqrNUFg8Fq1cYvP8o8GPQtwAN9jX39peSod/yxJleJNH6PUGtKu/CMcIgl4t9uW4D+kI4lhlJF77H4Y0ZCh0SJh2CpueGxHlzWF9A6kMM11h/5+1nj4idzb8EWP39b7kwGBpfsA/OGl0PEFXXXL7KUtDmNydDkOT3+Tdy2DqhrpuF928nPPAHP/+pgydiY64G0bpyE3v1RfT1LXTTCyIXOA3WrdpBWxwUoI+uhbHewCyPjXXNfv0ccxDQ2l1jJ4Ok= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 23e0773d-2f3e-4dc5-0648-08d9f7ffe452 X-MS-Exchange-CrossTenant-AuthSource: DU0PR04MB9417.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 25 Feb 2022 01:41:07.1749 (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: RN/8SKBizw21O9p/0ynQn4DT4N59g8cBjzuJnoMIwYn5ns3yYOuvtm2hAc6srjzCuGQCTjpa1jn2w0M16/Lpew== X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM0PR04MB5316 X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220224_174112_160417_13C7A7FB X-CRM114-Status: GOOD ( 12.63 ) 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 Add i.MX93 clk driver. i.MX93 clk hardware design is different compared with i.MX8M. It supports 4 sources for each clk root and the sources are separated into a few groups, low speed/fast io/audio and etc. Reviewed-by: Abel Vesa Signed-off-by: Peng Fan --- drivers/clk/imx/Kconfig | 6 + drivers/clk/imx/Makefile | 2 + drivers/clk/imx/clk-imx93.c | 338 ++++++++++++++++++++++++++++++++++++ 3 files changed, 346 insertions(+) create mode 100644 drivers/clk/imx/clk-imx93.c diff --git a/drivers/clk/imx/Kconfig b/drivers/clk/imx/Kconfig index 45641b8bdc50..cc464a42d646 100644 --- a/drivers/clk/imx/Kconfig +++ b/drivers/clk/imx/Kconfig @@ -106,6 +106,12 @@ config CLK_IMX8ULP help Build the driver for i.MX8ULP CCM Clock Driver +config CLK_IMX93 + tristate "IMX93 CCM Clock Driver" + depends on ARCH_MXC || COMPILE_TEST + help + Build the driver for i.MX93 CCM Clock Driver + config CLK_IMXRT1050 tristate "IMXRT1050 CCM Clock Driver" depends on SOC_IMXRT diff --git a/drivers/clk/imx/Makefile b/drivers/clk/imx/Makefile index 60c8a4bb7574..88b9b9285d22 100644 --- a/drivers/clk/imx/Makefile +++ b/drivers/clk/imx/Makefile @@ -28,6 +28,8 @@ obj-$(CONFIG_CLK_IMX8MN) += clk-imx8mn.o obj-$(CONFIG_CLK_IMX8MP) += clk-imx8mp.o obj-$(CONFIG_CLK_IMX8MQ) += clk-imx8mq.o +obj-$(CONFIG_CLK_IMX93) += clk-imx93.o + obj-$(CONFIG_MXC_CLK_SCU) += clk-imx-scu.o clk-imx-lpcg-scu.o clk-imx-scu-$(CONFIG_CLK_IMX8QXP) += clk-scu.o clk-imx8qxp.o \ clk-imx8qxp-rsrc.o clk-imx8qm-rsrc.o \ diff --git a/drivers/clk/imx/clk-imx93.c b/drivers/clk/imx/clk-imx93.c new file mode 100644 index 000000000000..7cd5e7fb0c8b --- /dev/null +++ b/drivers/clk/imx/clk-imx93.c @@ -0,0 +1,338 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Copyright 2021 NXP. + */ + +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +#include "clk.h" + +enum clk_sel { + LOW_SPEED_IO_SEL, + NON_IO_SEL, + FAST_SEL, + AUDIO_SEL, + VIDEO_SEL, + TPM_SEL, + CKO1_SEL, + CKO2_SEL, + MISC_SEL, + MAX_SEL +}; + +static const char *parent_names[MAX_SEL][4] = { + {"osc_24m", "sys_pll_pfd0_div2", "sys_pll_pfd1_div2", "video_pll"}, + {"osc_24m", "sys_pll_pfd0_div2", "sys_pll_pfd1_div2", "sys_pll_pfd2_div2"}, + {"osc_24m", "sys_pll_pfd0", "sys_pll_pfd1", "sys_pll_pfd2"}, + {"osc_24m", "audio_pll", "video_pll", "clk_ext1"}, + {"osc_24m", "audio_pll", "video_pll", "sys_pll_pfd0"}, + {"osc_24m", "sys_pll_pfd0", "audio_pll", "clk_ext1"}, + {"osc_24m", "sys_pll_pfd0", "sys_pll_pfd1", "audio_pll"}, + {"osc_24m", "sys_pll_pfd0", "sys_pll_pfd1", "video_pll"}, + {"osc_24m", "audio_pll", "video_pll", "sys_pll_pfd2"}, +}; + +struct imx93_clk_root { + u32 clk; + char *name; + u32 off; + enum clk_sel sel; + unsigned long flags; +} root_array[] = { + { IMX93_CLK_A55_PERIPH, "a55_periph_root", 0x0000, FAST_SEL, CLK_IS_CRITICAL }, + { IMX93_CLK_A55_MTR_BUS, "a55_mtr_bus_root", 0x0080, LOW_SPEED_IO_SEL, CLK_IS_CRITICAL }, + { IMX93_CLK_A55, "a55_root", 0x0100, FAST_SEL, CLK_IS_CRITICAL }, + { IMX93_CLK_M33, "m33_root", 0x0180, LOW_SPEED_IO_SEL, CLK_IS_CRITICAL }, + { IMX93_CLK_BUS_WAKEUP, "bus_wakeup_root", 0x0280, LOW_SPEED_IO_SEL, CLK_IS_CRITICAL }, + { IMX93_CLK_BUS_AON, "bus_aon_root", 0x0300, LOW_SPEED_IO_SEL, CLK_IS_CRITICAL }, + { IMX93_CLK_WAKEUP_AXI, "wakeup_axi_root", 0x0380, FAST_SEL, CLK_IS_CRITICAL }, + { IMX93_CLK_SWO_TRACE, "swo_trace_root", 0x0400, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_M33_SYSTICK, "m33_systick_root", 0x0480, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_FLEXIO1, "flexio1_root", 0x0500, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_FLEXIO2, "flexio2_root", 0x0580, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPIT1, "lpit1_root", 0x0600, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPIT2, "lpit2_root", 0x0680, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPTMR1, "lptmr1_root", 0x0700, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPTMR2, "lptmr2_root", 0x0780, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_TPM1, "tpm1_root", 0x0800, TPM_SEL, }, + { IMX93_CLK_TPM2, "tpm2_root", 0x0880, TPM_SEL, }, + { IMX93_CLK_TPM3, "tpm3_root", 0x0900, TPM_SEL, }, + { IMX93_CLK_TPM4, "tpm4_root", 0x0980, TPM_SEL, }, + { IMX93_CLK_TPM5, "tpm5_root", 0x0a00, TPM_SEL, }, + { IMX93_CLK_TPM6, "tpm6_root", 0x0a80, TPM_SEL, }, + { IMX93_CLK_FLEXSPI1, "flexspi1_root", 0x0b00, FAST_SEL, }, + { IMX93_CLK_CAN1, "can1_root", 0x0b80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_CAN2, "can2_root", 0x0c00, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPUART1, "lpuart1_root", 0x0c80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPUART2, "lpuart2_root", 0x0d00, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPUART3, "lpuart3_root", 0x0d80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPUART4, "lpuart4_root", 0x0e00, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPUART5, "lpuart5_root", 0x0e80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPUART6, "lpuart6_root", 0x0f00, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPUART7, "lpuart7_root", 0x0f80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPUART8, "lpuart8_root", 0x1000, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPI2C1, "lpi2c1_root", 0x1080, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPI2C2, "lpi2c2_root", 0x1100, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPI2C3, "lpi2c3_root", 0x1180, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPI2C4, "lpi2c4_root", 0x1200, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPI2C5, "lpi2c5_root", 0x1280, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPI2C6, "lpi2c6_root", 0x1300, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPI2C7, "lpi2c7_root", 0x1380, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPI2C8, "lpi2c8_root", 0x1400, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPSPI1, "lpspi1_root", 0x1480, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPSPI2, "lpspi2_root", 0x1500, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPSPI3, "lpspi3_root", 0x1580, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPSPI4, "lpspi4_root", 0x1600, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPSPI5, "lpspi5_root", 0x1680, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPSPI6, "lpspi6_root", 0x1700, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPSPI7, "lpspi7_root", 0x1780, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_LPSPI8, "lpspi8_root", 0x1800, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_I3C1, "i3c1_root", 0x1880, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_I3C2, "i3c2_root", 0x1900, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_USDHC1, "usdhc1_root", 0x1980, FAST_SEL, }, + { IMX93_CLK_USDHC2, "usdhc2_root", 0x1a00, FAST_SEL, }, + { IMX93_CLK_USDHC3, "usdhc3_root", 0x1a80, FAST_SEL, }, + { IMX93_CLK_SAI1, "sai1_root", 0x1b00, AUDIO_SEL, }, + { IMX93_CLK_SAI2, "sai2_root", 0x1b80, AUDIO_SEL, }, + { IMX93_CLK_SAI3, "sai3_root", 0x1c00, AUDIO_SEL, }, + { IMX93_CLK_CCM_CKO1, "ccm_cko1_root", 0x1c80, CKO1_SEL, }, + { IMX93_CLK_CCM_CKO2, "ccm_cko2_root", 0x1d00, CKO2_SEL, }, + { IMX93_CLK_CCM_CKO3, "ccm_cko3_root", 0x1d80, CKO1_SEL, }, + { IMX93_CLK_CCM_CKO4, "ccm_cko4_root", 0x1e00, CKO2_SEL, }, + { IMX93_CLK_HSIO, "hsio_root", 0x1e80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_HSIO_USB_TEST_60M, "hsio_usb_test_60m_root", 0x1f00, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_HSIO_ACSCAN_80M, "hsio_acscan_80m_root", 0x1f80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_HSIO_ACSCAN_480M, "hsio_acscan_480m_root", 0x2000, MISC_SEL, }, + { IMX93_CLK_ML_APB, "ml_apb_root", 0x2180, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_ML, "ml_root", 0x2200, FAST_SEL, }, + { IMX93_CLK_MEDIA_AXI, "media_axi_root", 0x2280, FAST_SEL, }, + { IMX93_CLK_MEDIA_APB, "media_apb_root", 0x2300, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_MEDIA_LDB, "media_ldb_root", 0x2380, VIDEO_SEL, }, + { IMX93_CLK_MEDIA_DISP_PIX, "media_disp_pix_root", 0x2400, VIDEO_SEL, }, + { IMX93_CLK_CAM_PIX, "cam_pix_root", 0x2480, VIDEO_SEL, }, + { IMX93_CLK_MIPI_TEST_BYTE, "mipi_test_byte_root", 0x2500, VIDEO_SEL, }, + { IMX93_CLK_MIPI_PHY_CFG, "mipi_phy_cfg_root", 0x2580, VIDEO_SEL, }, + { IMX93_CLK_ADC, "adc_root", 0x2700, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_PDM, "pdm_root", 0x2780, AUDIO_SEL, }, + { IMX93_CLK_TSTMR1, "tstmr1_root", 0x2800, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_TSTMR2, "tstmr2_root", 0x2880, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_MQS1, "mqs1_root", 0x2900, AUDIO_SEL, }, + { IMX93_CLK_MQS2, "mqs2_root", 0x2980, AUDIO_SEL, }, + { IMX93_CLK_AUDIO_XCVR, "audio_xcvr_root", 0x2a00, NON_IO_SEL, }, + { IMX93_CLK_SPDIF, "spdif_root", 0x2a80, AUDIO_SEL, }, + { IMX93_CLK_ENET, "enet_root", 0x2b00, NON_IO_SEL, }, + { IMX93_CLK_ENET_TIMER1, "enet_timer1_root", 0x2b80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_ENET_TIMER2, "enet_timer2_root", 0x2c00, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_ENET_REF, "enet_ref_root", 0x2c80, NON_IO_SEL, }, + { IMX93_CLK_ENET_REF_PHY, "enet_ref_phy_root", 0x2d00, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_I3C1_SLOW, "i3c1_slow_root", 0x2d80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_I3C2_SLOW, "i3c2_slow_root", 0x2e00, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_USB_PHY_BURUNIN, "usb_phy_root", 0x2e80, LOW_SPEED_IO_SEL, }, + { IMX93_CLK_PAL_CAME_SCAN, "pal_came_scan_root", 0x2f00, MISC_SEL, } +}; + +struct imx93_clk_ccgr { + u32 clk; + char *name; + char *parent_name; + u32 off; + unsigned long flags; +} ccgr_array[] = { + { IMX93_CLK_A55_GATE, "a55", "a55_root", 0x8000, CLK_IS_CRITICAL }, + { IMX93_CLK_CM33_GATE, "cm33", "m33_root", 0x8040, CLK_IS_CRITICAL }, + { IMX93_CLK_ADC1_GATE, "adc1", "osc_24m", 0x82c0, }, + { IMX93_CLK_WDOG1_GATE, "wdog1", "osc_24m", 0x8300, }, + { IMX93_CLK_WDOG2_GATE, "wdog2", "osc_24m", 0x8340, }, + { IMX93_CLK_WDOG3_GATE, "wdog3", "osc_24m", 0x8380, }, + { IMX93_CLK_WDOG4_GATE, "wdog4", "osc_24m", 0x83c0, }, + { IMX93_CLK_WDOG5_GATE, "wdog5", "osc_24m", 0x8400, }, + { IMX93_CLK_SEMA1_GATE, "sema1", "bus_aon_root", 0x8440, }, + { IMX93_CLK_SEMA2_GATE, "sema2", "bus_wakeup_root", 0x8480, }, + { IMX93_CLK_MU_A_GATE, "mu_a", "bus_aon_root", 0x84c0, }, + { IMX93_CLK_MU_B_GATE, "mu_b", "bus_aon_root", 0x8500, }, + { IMX93_CLK_EDMA1_GATE, "edma1", "wakeup_axi_root", 0x8540, }, + { IMX93_CLK_EDMA2_GATE, "edma2", "wakeup_axi_root", 0x8580, }, + { IMX93_CLK_FLEXSPI1_GATE, "flexspi", "flexspi_root", 0x8640, }, + { IMX93_CLK_GPIO1_GATE, "gpio1", "m33_root", 0x8880, }, + { IMX93_CLK_GPIO2_GATE, "gpio2", "bus_wakeup_root", 0x88c0, }, + { IMX93_CLK_GPIO3_GATE, "gpio3", "bus_wakeup_root", 0x8900, }, + { IMX93_CLK_GPIO4_GATE, "gpio4", "bus_wakeup_root", 0x8940, }, + { IMX93_CLK_FLEXIO1_GATE, "flexio1", "flexio1_root", 0x8980, }, + { IMX93_CLK_FLEXIO2_GATE, "flexio2", "flexio2_root", 0x89c0, }, + { IMX93_CLK_LPIT1_GATE, "lpit1", "lpit1_root", 0x8a00, }, + { IMX93_CLK_LPIT2_GATE, "lpit2", "lpit2_root", 0x8a40, }, + { IMX93_CLK_LPTMR1_GATE, "lptmr1", "lptmr1_root", 0x8a80, }, + { IMX93_CLK_LPTMR2_GATE, "lptmr2", "lptmr2_root", 0x8ac0, }, + { IMX93_CLK_TPM1_GATE, "tpm1", "tpm1_root", 0x8b00, }, + { IMX93_CLK_TPM2_GATE, "tpm2", "tpm2_root", 0x8b40, }, + { IMX93_CLK_TPM3_GATE, "tpm3", "tpm3_root", 0x8b80, }, + { IMX93_CLK_TPM4_GATE, "tpm4", "tpm4_root", 0x8bc0, }, + { IMX93_CLK_TPM5_GATE, "tpm5", "tpm5_root", 0x8c00, }, + { IMX93_CLK_TPM6_GATE, "tpm6", "tpm6_root", 0x8c40, }, + { IMX93_CLK_CAN1_GATE, "can1", "can1_root", 0x8c80, }, + { IMX93_CLK_CAN2_GATE, "can2", "can2_root", 0x8cc0, }, + { IMX93_CLK_LPUART1_GATE, "lpuart1", "lpuart1_root", 0x8d00, }, + { IMX93_CLK_LPUART2_GATE, "lpuart2", "lpuart2_root", 0x8d40, }, + { IMX93_CLK_LPUART3_GATE, "lpuart3", "lpuart3_root", 0x8d80, }, + { IMX93_CLK_LPUART4_GATE, "lpuart4", "lpuart4_root", 0x8dc0, }, + { IMX93_CLK_LPUART5_GATE, "lpuart5", "lpuart5_root", 0x8e00, }, + { IMX93_CLK_LPUART6_GATE, "lpuart6", "lpuart6_root", 0x8e40, }, + { IMX93_CLK_LPUART7_GATE, "lpuart7", "lpuart7_root", 0x8e80, }, + { IMX93_CLK_LPUART8_GATE, "lpuart8", "lpuart8_root", 0x8ec0, }, + { IMX93_CLK_LPI2C1_GATE, "lpi2c1", "lpi2c1_root", 0x8f00, }, + { IMX93_CLK_LPI2C2_GATE, "lpi2c2", "lpi2c2_root", 0x8f40, }, + { IMX93_CLK_LPI2C3_GATE, "lpi2c3", "lpi2c3_root", 0x8f80, }, + { IMX93_CLK_LPI2C4_GATE, "lpi2c4", "lpi2c4_root", 0x8fc0, }, + { IMX93_CLK_LPI2C5_GATE, "lpi2c5", "lpi2c5_root", 0x9000, }, + { IMX93_CLK_LPI2C6_GATE, "lpi2c6", "lpi2c6_root", 0x9040, }, + { IMX93_CLK_LPI2C7_GATE, "lpi2c7", "lpi2c7_root", 0x9080, }, + { IMX93_CLK_LPI2C8_GATE, "lpi2c8", "lpi2c8_root", 0x90c0, }, + { IMX93_CLK_LPSPI1_GATE, "lpspi1", "lpspi1_root", 0x9100, }, + { IMX93_CLK_LPSPI2_GATE, "lpspi2", "lpspi2_root", 0x9140, }, + { IMX93_CLK_LPSPI3_GATE, "lpspi3", "lpspi3_root", 0x9180, }, + { IMX93_CLK_LPSPI4_GATE, "lpspi4", "lpspi4_root", 0x91c0, }, + { IMX93_CLK_LPSPI5_GATE, "lpspi5", "lpspi5_root", 0x9200, }, + { IMX93_CLK_LPSPI6_GATE, "lpspi6", "lpspi6_root", 0x9240, }, + { IMX93_CLK_LPSPI7_GATE, "lpspi7", "lpspi7_root", 0x9280, }, + { IMX93_CLK_LPSPI8_GATE, "lpspi8", "lpspi8_root", 0x92c0, }, + { IMX93_CLK_I3C1_GATE, "i3c1", "i3c1_root", 0x9300, }, + { IMX93_CLK_I3C2_GATE, "i3c2", "i3c2_root", 0x9340, }, + { IMX93_CLK_USDHC1_GATE, "usdhc1", "usdhc1_root", 0x9380, }, + { IMX93_CLK_USDHC2_GATE, "usdhc2", "usdhc2_root", 0x93c0, }, + { IMX93_CLK_USDHC3_GATE, "usdhc3", "usdhc3_root", 0x9400, }, + { IMX93_CLK_SAI1_GATE, "sai1", "sai1_root", 0x9440, }, + { IMX93_CLK_SAI2_GATE, "sai2", "sai2_root", 0x9480, }, + { IMX93_CLK_SAI3_GATE, "sai3", "sai3_root", 0x94c0, }, + { IMX93_CLK_MIPI_CSI_GATE, "mipi_csi", "media_apb_root", 0x9580, }, + { IMX93_CLK_MIPI_DSI_GATE, "mipi_dsi", "media_apb_root", 0x95c0, }, + { IMX93_CLK_LVDS_GATE, "lvds", "media_ldb_root", 0x9600, }, + { IMX93_CLK_LCDIF_GATE, "lcdif", "media_apb_root", 0x9640, }, + { IMX93_CLK_PXP_GATE, "pxp", "media_apb_root", 0x9680, }, + { IMX93_CLK_ISI_GATE, "isi", "media_apb_root", 0x96c0, }, + { IMX93_CLK_NIC_MEDIA_GATE, "nic_media", "media_apb_root", 0x9700, }, + { IMX93_CLK_USB_CONTROLLER_GATE, "usb_controller", "hsio_root", 0x9a00, }, + { IMX93_CLK_USB_TEST_60M_GATE, "usb_test_60m", "hsio_usb_test_60m_root", 0x9a40, }, + { IMX93_CLK_HSIO_TROUT_24M_GATE, "hsio_trout_24m", "osc_24m", 0x9a80, }, + { IMX93_CLK_PDM_GATE, "pdm", "pdm_root", 0x9ac0, }, + { IMX93_CLK_MQS1_GATE, "mqs1", "sai1_root", 0x9b00, }, + { IMX93_CLK_MQS2_GATE, "mqs2", "sai3_root", 0x9b40, }, + { IMX93_CLK_AUD_XCVR_GATE, "aud_xcvr", "audio_xcvr_root", 0x9b80, }, + { IMX93_CLK_SPDIF_GATE, "spdif", "spdif_root", 0x9c00, }, + { IMX93_CLK_HSIO_32K_GATE, "hsio_32k", "osc_32k", 0x9dc0, }, + { IMX93_CLK_ENET1_GATE, "enet1", "enet_root", 0x9e00, }, + { IMX93_CLK_ENET_QOS_GATE, "enet_qos", "wakeup_axi_root", 0x9e40, }, + { IMX93_CLK_SYS_CNT_GATE, "sys_cnt", "osc_24m", 0x9e80, }, + { IMX93_CLK_TSTMR1_GATE, "tstmr1", "bus_aon_root", 0x9ec0, }, + { IMX93_CLK_TSTMR2_GATE, "tstmr2", "bus_wakeup_root", 0x9f00, }, + { IMX93_CLK_TMC_GATE, "tmc", "osc_24m", 0x9f40, }, + { IMX93_CLK_PMRO_GATE, "pmro", "osc_24m", 0x9f80, } +}; + +static struct clk_hw_onecell_data *clk_hw_data; +static struct clk_hw **clks; + +static int imx93_clocks_probe(struct platform_device *pdev) +{ + struct device *dev = &pdev->dev; + struct device_node *np = dev->of_node; + struct imx93_clk_root *root; + struct imx93_clk_ccgr *ccgr; + void __iomem *base = NULL; + int i, ret; + + clk_hw_data = kzalloc(struct_size(clk_hw_data, hws, + IMX93_CLK_END), GFP_KERNEL); + if (WARN_ON(!clk_hw_data)) + return -ENOMEM; + + clk_hw_data->num = IMX93_CLK_END; + clks = clk_hw_data->hws; + + clks[IMX93_CLK_DUMMY] = imx_clk_hw_fixed("dummy", 0); + clks[IMX93_CLK_24M] = imx_obtain_fixed_clk_hw(np, "osc_24m"); + clks[IMX93_CLK_32K] = imx_obtain_fixed_clk_hw(np, "osc_32k"); + clks[IMX93_CLK_EXT1] = imx_obtain_fixed_clk_hw(np, "clk_ext1"); + + clks[IMX93_CLK_SYS_PLL_PFD0] = imx_clk_hw_fixed("sys_pll_pfd0", 1000000000); + clks[IMX93_CLK_SYS_PLL_PFD0_DIV2] = imx_clk_hw_fixed_factor("sys_pll_pfd0_div2", + "sys_pll_pfd0", 1, 2); + clks[IMX93_CLK_SYS_PLL_PFD1] = imx_clk_hw_fixed("sys_pll_pfd1", 800000000); + clks[IMX93_CLK_SYS_PLL_PFD1_DIV2] = imx_clk_hw_fixed_factor("sys_pll_pfd1_div2", + "sys_pll_pfd1", 1, 2); + clks[IMX93_CLK_SYS_PLL_PFD2] = imx_clk_hw_fixed("sys_pll_pfd2", 625000000); + clks[IMX93_CLK_SYS_PLL_PFD2_DIV2] = imx_clk_hw_fixed_factor("sys_pll_pfd2_div2", + "sys_pll_pfd2", 1, 2); + + np = of_find_compatible_node(NULL, NULL, "fsl,imx93-anatop"); + base = of_iomap(np, 0); + of_node_put(np); + if (WARN_ON(!base)) + return -ENOMEM; + + clks[IMX93_CLK_AUDIO_PLL] = imx_clk_fracn_gppll("audio_pll", "osc_24m", base + 0x1200, + &imx_fracn_gppll); + clks[IMX93_CLK_VIDEO_PLL] = imx_clk_fracn_gppll("video_pll", "osc_24m", base + 0x1400, + &imx_fracn_gppll); + + np = dev->of_node; + base = devm_platform_ioremap_resource(pdev, 0); + if (WARN_ON(IS_ERR(base))) + return PTR_ERR(base); + + for (i = 0; i < ARRAY_SIZE(root_array); i++) { + root = &root_array[i]; + clks[root->clk] = imx93_clk_composite_flags(root->name, + parent_names[root->sel], + 4, base + root->off, + root->flags); + } + + for (i = 0; i < ARRAY_SIZE(ccgr_array); i++) { + ccgr = &ccgr_array[i]; + clks[ccgr->clk] = imx_clk_hw_gate4_flags(ccgr->name, + ccgr->parent_name, + base + ccgr->off, 0, + ccgr->flags); + } + + imx_check_clk_hws(clks, IMX93_CLK_END); + + ret = of_clk_add_hw_provider(np, of_clk_hw_onecell_get, clk_hw_data); + if (ret < 0) { + dev_err(dev, "failed to register clks for i.MX93\n"); + goto unregister_hws; + } + + return 0; + +unregister_hws: + imx_unregister_hw_clocks(clks, IMX93_CLK_END); + + return ret; +} + +static const struct of_device_id imx93_clk_of_match[] = { + { .compatible = "fsl,imx93-ccm" }, + { /* Sentinel */ }, +}; +MODULE_DEVICE_TABLE(of, imx93_clk_of_match); + +static struct platform_driver imx93_clk_driver = { + .probe = imx93_clocks_probe, + .driver = { + .name = "imx93-ccm", + .suppress_bind_attrs = true, + .of_match_table = of_match_ptr(imx93_clk_of_match), + }, +}; +module_platform_driver(imx93_clk_driver);