From nobody Fri Jun 12 12:43:13 2026 Received: from CHN02-BJS-obe.outbound.protection.partner.outlook.cn (mail-bjschn02on2125.outbound.protection.partner.outlook.cn [139.219.17.125]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id B30573DF015; Fri, 15 May 2026 07:19:29 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=139.219.17.125 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778829573; cv=fail; b=r8YvqrONVTzr4VabBeemjzEOjX1zfWyMrbNbURurKCGcYxhMT/EGJi3g+dlazw/xZFCNNWEYtbFTDppGbPY+u5xIGico1AFBlqZtUhqWyaDGoZMHpaG2LR+J8ae2OEdsQ3GLmde6cTB/bdQNXXGimYUREDerhyjWLh7MUaxEVNU= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778829573; c=relaxed/simple; bh=mB2qnBuk3VA7hkaylR5bZFVaCjNlkHgh4SOUYexsCIU=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=N5ItaVusFhOn9ZidoJExd8gsk/INcw1SlRfrqHBHQkm8ur+D6MzWKdI3t5qPuIg1zHMKnxVM+caO2A/7Anz+dyPe2RVQmJ+KGrX2ijqq/Z7xfZuMh3XGvFE0fhiD13DwjjIZPaRbLn/MYoPeIudK0mqNFqJCPdw0AtZHDmlGeRc= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=starfivetech.com; spf=pass smtp.mailfrom=starfivetech.com; arc=fail smtp.client-ip=139.219.17.125 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=starfivetech.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=starfivetech.com ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=mdjHJF553PcTy7kTKoIsHvUZiU/qDtMEBBsOBpTVUuqAPfShEQoTBxa5KyD3DE6W53Bz9X1FSDT5NJ9U3tUQvwTzi+hQTCK+BfNmvMTnxlZy7I3zikrSaWtbbR2N93jGIX96KfL5i2YNl7gidrmyeUCqi6XRc/GKRphKdlc2YlEhb4Q3L8R19BOuIxxoq5OKghXxapyHMWrL7zaqK+6LBXejGm+5tIS7Usw4ZXeds9gUlQQ7vGsYUSA6m9gQ7PTdp0bl3xugrNWP5LzREbeW3OmPY5Cu/npsaj1dv1Z1cFIEYbnZyPA5PayHLNhWu/LW0HUKcWJugBGx7rRmkmumpw== 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=xQsOsFCyy2ameyCBGoWUv1iv8VoGWNLHXYWUj5o+09w=; b=em53A5yV4rJjQWemH+On2KsUcMc+Me4xDf/LckSkNf3+fMh3cmPI1RFPX8rFyNf3sagPIDP0ZUEeERHFaTOGMWuSJipDps5s40JR31JL2nWmKZAfrEcEv6BK0RDL2EU0T8+7JIHNtDG6YroO05K6zNkQqJxVvcTjpDPPW5xi++J76ecsa5LTamccNZiNFKqKVryB1wd2eY4R0m9PEWAiTzUlWZMqzZuxNUKa3KaYxll3EMcqx6+sRPfm4vkkrB6/uqnU37pca4NxCG83tXsDX3T63Com7X1FxZQQbvnaurkYHueGYbQFvtuMiID8SPU0G7YsR3Eo5qXbyuuaowKV8w== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=starfivetech.com; dmarc=pass action=none header.from=starfivetech.com; dkim=pass header.d=starfivetech.com; arc=none Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=starfivetech.com; Received: from ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:7::14) by ZQ2PR01MB1276.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:10::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9913.12; Fri, 15 May 2026 05:47:32 +0000 Received: from ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn ([fe80::4386:5cc4:3bc4:4795]) by ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn ([fe80::4386:5cc4:3bc4:4795%4]) with mapi id 15.20.9913.009; Fri, 15 May 2026 05:47:32 +0000 From: Hal Feng To: =?UTF-8?q?Uwe=20Kleine-K=C3=B6nig?= , Philipp Zabel , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Emil Renner Berthing , Palmer Dabbelt , Paul Walmsley , Albert Ou Cc: Changhuang Liang , Hal Feng , linux-pwm@vger.kernel.org, devicetree@vger.kernel.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v18 1/3] dt-bindings: pwm: opencores: Drop starfive compatibles and update maintainers Date: Fri, 15 May 2026 13:47:20 +0800 Message-ID: <20260515054723.25024-2-hal.feng@starfivetech.com> X-Mailer: git-send-email 2.43.2 In-Reply-To: <20260515054723.25024-1-hal.feng@starfivetech.com> References: <20260515054723.25024-1-hal.feng@starfivetech.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: SHXPR01CA0013.CHNPR01.prod.partner.outlook.cn (2406:e500:c311:1b::22) To ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:7::14) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: ZQ2PR01MB1307:EE_|ZQ2PR01MB1276:EE_ X-MS-Office365-Filtering-Correlation-Id: a06aca4b-2e62-4d6a-f177-08deb2457519 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014|52116014|56012099003|18002099003|22082099003|38350700014|3023799003; X-Microsoft-Antispam-Message-Info: i72FRP+ko0OU0mWpM1kmjfcNPewgUUzAn77Wqf4eJz+LovjfvPEGTghsx3qwkAb32FFtGFGPvSHETtCxu0AH7a7sdcnnRqmNwZGuJpzcGckHxVci8D35YPnCnExK446/T182xymWJyxqo4OqOnOvzvSxzFtIjCcQB2HHyDB+H9OoYcVgGdsHiBsjZskkntQRECKfuWR+tBE2jqGtI71CeqHQqhxFEzTK/PxiVkkr7iTuWDEinUoX8RzPG4f+3Ik6m55TcunqU5srOttPqCQyqV6LSz2xN0YhwnEZ+9OUobYTKmwE/Jg/7ISX7YQK6GTHQJcVsqQEViHepcYORYxuF4Yj58koPXZBgNBF/jjbGrOMUA1TNAjUm0aRFheSky9oRQPWKUSWGyl5YEqtqybHFYbUQq1fUtR+9MDRRIbLZPBvR+eyHOCYPIyM2WOCck95f+vXZYe/hJ1D7ObNIHjEDUBk9LhspLi8Th+DwSnI5koQdOMPjYzT+HAnNsahE/FX2RkD3bP5kiic/tJgkEdEscnDqg9XaWYqSXo4b6NwKL6HnyVyjwV1lXOhqAaKPl7I X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn;PTR:;CAT:NONE;SFS:(13230040)(366016)(1800799024)(7416014)(376014)(52116014)(56012099003)(18002099003)(22082099003)(38350700014)(3023799003);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?n0cBSbonTq3EE5FyXpaUOAdDA5nmTPv11TtJRnXT6WR+EVyuHjWwgx7iM+Pb?= =?us-ascii?Q?iyRtiTfT70eYtAH26ASyywn75LXajPFYDRsrNRIdWgC3hNjOXqiDYDQkerfr?= =?us-ascii?Q?aLODkDYP6mZhserIpHxU1oQm7fOPnDVVmxbdoqanTtnUf8CXMwRy6UWipkoT?= =?us-ascii?Q?GnLO8CJDLDlu1JFMaNpfBckSOqVy2QIa2BBxOC3lnZYxkEQsExhmoR7OzWiT?= =?us-ascii?Q?zt1Z+FmV83dBRb+Wwma9M3hgJGLmHt3aSJ+mGM8dniMZApICMj3uW3uZ66Ok?= =?us-ascii?Q?vER+u+fFHwSbMQmZukYBc4X2jD+Uv8iIElDlO7Ht2ZHaGlvSrQ5v0mMoDnF9?= =?us-ascii?Q?BTLPvbYtNFjRR0b2LAiyXud5pNGa/RYrdA9KH2TzndW0ArpiS6kPmB4LE9o+?= =?us-ascii?Q?9b/nsDC7IPL/u8+HtThAztk6UebtHGw1KVEYDIvrv63n+3COHAmR8aE0qSdP?= =?us-ascii?Q?CIHWQDjlrTTp8IUGkPzLXirNaOsQjjnF2tHpsuQIJqMZKNlR2ZQByU6HgAji?= =?us-ascii?Q?dWyChPqnLxqGjT0s5wxre5zFksl2i3whwDZQUjCSqEc+ramGYFk1rmMjIs3a?= =?us-ascii?Q?5Bqoi0D62AaNDUlegZVuXXIX1HhBE64DLE0JVT+SzymKq7GiF6YxzI4LPjJf?= =?us-ascii?Q?MYuaC0CDexeU5/3tC5Dabr2lGjpbV9cXT1COmRb9ggWVuLGdpAzhFJN6qzOQ?= =?us-ascii?Q?Z6nT3rVbqQZN+eStylBA8gLbFopTZTEtOd8+IF0/rbscR8y10TIkfHgrihDd?= =?us-ascii?Q?PqBvy12PDA5BJpRXkXtRMhQV0P2oqzBuuHVPFpD7wbnuGCRYGZdLsY7ZsmgW?= =?us-ascii?Q?3o6ijistqbjAwf/U0Bg8NmiZS4hpht80AYZhz5TzWMHUvPJO7JMw+pD1pkNO?= =?us-ascii?Q?VUfE/5+rlpMjKJtIgab9H8oFzJPDe3kIJCywTLqOi+DNIUtmNwkoQxFXpYyh?= =?us-ascii?Q?FMkOlfVvuslRIUaEKbAE7jjveINBVQg8S0AOpC6PElKOs00Jfe3ni3SKycUH?= =?us-ascii?Q?hetD2T+S/jsba5n6nIxdxei/OVJo58ddGhgcTg5pxx8HOiVhd5iyzTfSZXsf?= =?us-ascii?Q?hKdV4SaR9OiCHFUnfINDI2xJMaGhOzkp0N3ae+TX0uLoaO1oFSQbwhORjReP?= =?us-ascii?Q?U/a8fduuq/AV87AazapzaVFKn3TBMXB6By+tOssUZKOteN0xMrfYqCXjH6cL?= =?us-ascii?Q?05cyMLNFfxxia+TuetgWpwCfFkcdEmb8yrQiwfzs4HpzJYNjOQZw/fC2JV9x?= =?us-ascii?Q?MctY8VqAlEZx69jjTAtOcuRXH3RcaISLC4kRp9b1/mc1+LnPax1id1E3EMe4?= =?us-ascii?Q?knVkupBmEb0OGxLL9Zq/tetwJ3MOcHJI4Vb7xHm4paSM1nfSbNghgonknjkM?= =?us-ascii?Q?6B4zrH/6jIi1u/C4yCPI4x8YFkHwLcEHPzmcBecGw3HjLkyhAoW1qCKg9iH3?= =?us-ascii?Q?726LJZkLvALsWW3hZ/ChawRJa1rWt7emDjC7V2qpO4a6fZYxhL3uvSx7WXuB?= =?us-ascii?Q?KIf1h2pYB2MeE+FnezI1SWbp5AU/ZZA3gQIQIGdAwXsr14iTkVCY5VSSF+Es?= =?us-ascii?Q?WhIW+cZhwPuTdvf7H89ewoRTB8JSfOXPUjlBp/MdpxDjLvZLul/Xw4ks792j?= =?us-ascii?Q?4kLYIWGec7IKnGAFFgSE0LhXP0n6JI+54+gVx/IK3HoBGytz4shkE7bQDFpS?= =?us-ascii?Q?nv8yhVF9dYlXtQp8Qa+LOosQQkRgE6hWlovfimcfHvqHg1LJjIKOeWUUoFvG?= =?us-ascii?Q?ee+atyaLwhA0+bO4AxwUlvJJpp32M3o=3D?= X-OriginatorOrg: starfivetech.com X-MS-Exchange-CrossTenant-Network-Message-Id: a06aca4b-2e62-4d6a-f177-08deb2457519 X-MS-Exchange-CrossTenant-AuthSource: ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 May 2026 05:47:32.1472 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 06fe3fa3-1221-43d3-861b-5a4ee687a85c X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 4PjZL1uUOLCV6BN+/WbCpKkSN+7EGRl6jie6fHP4HGTVuu85TjVtKY6JNr2vlkiwFBRjSkrUXIymp9/bYCYfy3ifpSIuXqRPPWmmR1oS9EU= X-MS-Exchange-Transport-CrossTenantHeadersStamped: ZQ2PR01MB1276 Content-Type: text/plain; charset="utf-8" Each of the StarFive JH7100/JH7110/JH8100 SoCs has 8 OpenCores PTC IP cores. One OpenCores PTC IP core can output one PWM channel. The only difference among them is the register base address. There is no need to add starfive compatibles to distinguish them. I will maintain the pwm module in place of William. Signed-off-by: Hal Feng --- .../devicetree/bindings/pwm/opencores,pwm.yaml | 10 +++------- 1 file changed, 3 insertions(+), 7 deletions(-) diff --git a/Documentation/devicetree/bindings/pwm/opencores,pwm.yaml b/Doc= umentation/devicetree/bindings/pwm/opencores,pwm.yaml index 52a59d245cdb..834fb17ec595 100644 --- a/Documentation/devicetree/bindings/pwm/opencores,pwm.yaml +++ b/Documentation/devicetree/bindings/pwm/opencores,pwm.yaml @@ -7,7 +7,7 @@ $schema: http://devicetree.org/meta-schemas/core.yaml# title: OpenCores PWM controller =20 maintainers: - - William Qiu + - Hal Feng =20 description: The OpenCores PTC ip core contains a PWM controller. When operating in P= WM @@ -20,10 +20,6 @@ allOf: properties: compatible: items: - - enum: - - starfive,jh7100-pwm - - starfive,jh7110-pwm - - starfive,jh8100-pwm - const: opencores,pwm-v1 =20 reg: @@ -48,8 +44,8 @@ additionalProperties: false examples: - | pwm@12490000 { - compatible =3D "starfive,jh7110-pwm", "opencores,pwm-v1"; - reg =3D <0x12490000 0x10000>; + compatible =3D "opencores,pwm-v1"; + reg =3D <0x12490000 0x10>; clocks =3D <&clkgen 181>; resets =3D <&rstgen 109>; #pwm-cells =3D <3>; --=20 2.43.2 From nobody Fri Jun 12 12:43:13 2026 Received: from CHN02-BJS-obe.outbound.protection.partner.outlook.cn (mail-bjschn02on2109.outbound.protection.partner.outlook.cn [139.219.17.109]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id AA31935CBC3; Fri, 15 May 2026 06:22:01 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=139.219.17.109 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778826126; cv=fail; b=B+TQwRtXHCTL0qseyNUaTjibnZ15Rj0hxTH+TnC3MJ+DfYclE/UFpaxASkuUyZAIFevaKc/C/jtP4ZXZtQbq0HUYFeaXat3tb4qqzgJJ2WsPQ81nLzR4oFDXGV74VSLmPgSG5Pf2YN7okUkmF7aBGKMt3CO+JWh4JAhJJHWgpOI= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778826126; c=relaxed/simple; bh=8Ovq9YxJAqBQs10MPKgl+MRFDNyQLnWR8e+CZKogHEM=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=rk83Cu+bvw9QdXY8Zdnm5z+HrKN8HeZT6iRw/Ef6XdUYfFrlRgngJqfjgwGFFay1D4PrLL6VvuelEBunatA5IAeuDSZU52JpavBxfTRNxR+EW6WEJWboN1nvsXql8K8fsfnFIM44RcBJ+GAPcsN9Xgwjn50CFanm4ELyrXxEdO0= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=starfivetech.com; spf=pass smtp.mailfrom=starfivetech.com; arc=fail smtp.client-ip=139.219.17.109 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=starfivetech.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=starfivetech.com ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=oTxNwFj+U5lDpbv16sEWHyFTb6wslbqgdJ9XoO8UuzByUExHfHTRAVEQfA4w4A2w1Ew43njI3Kz/G3nz9olZFKdaARbjhU5FjjwWziUrCdLrOmfJw7A9lED8kUer9AK2QzTxteKRkJj9r3Kxg7ExhIaXgt3EvnN7DDMfGxuhzkrtN8F6qrIrn3AUf7y5+1Mj68Yp95r8p3XoD+Jn3MiQSl8YKjeE4t24lwRS2boJ8Y1C6aUcphznYi5j2JjBnL0Q9O2FQlDmrDsIuCWucEgHCpMocO2PPZkpeYghVEK9lPm6IN2j9Vo3FGmQquW+9Q+OZDp/78mjqdgRYQAHBQnJ5g== 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=5ZYYZjaF5OePaKfu4ka3nc+Ja1B53Rjud8gvilZ5QUo=; b=UZHfHCDqyMX2FeZEs7rFqBAShpzvK2Ql7aL28Xfx7YwmbbckIBvAJ2Surj3g4OfdAEogvrJK+Gq4IOCOldmS38qqPzrvHdwTQK/+IoseMe+23eBiXyaZAMyRkw1GC4rN8CPUIcrjxBubPtehnqAYaawswiVqCMxAxmnOBeXwgz3bAN5E7TtgRl/dVY68Qwt2Xc8grzJiu4hR2qIzimvLo6NOFTdDKvhHyb4Bgv1TGdQZRx/qtLA8/3AmJ/0uZvMikJgtETCploR7QA9hBOfViPu3pVVNcWeT3owLW/iOKFARZwHdpFSqqz3STSDTW9oq0KGx6mvCAmi8PrA6K2QyqA== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=starfivetech.com; dmarc=pass action=none header.from=starfivetech.com; dkim=pass header.d=starfivetech.com; arc=none Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=starfivetech.com; Received: from ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:7::14) by ZQ2PR01MB1276.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:10::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9913.12; Fri, 15 May 2026 05:47:33 +0000 Received: from ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn ([fe80::4386:5cc4:3bc4:4795]) by ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn ([fe80::4386:5cc4:3bc4:4795%4]) with mapi id 15.20.9913.009; Fri, 15 May 2026 05:47:33 +0000 From: Hal Feng To: =?UTF-8?q?Uwe=20Kleine-K=C3=B6nig?= , Philipp Zabel , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Emil Renner Berthing , Palmer Dabbelt , Paul Walmsley , Albert Ou Cc: Changhuang Liang , Hal Feng , linux-pwm@vger.kernel.org, devicetree@vger.kernel.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v18 2/3] riscv: dts: starfive: Correct pwm nodes Date: Fri, 15 May 2026 13:47:21 +0800 Message-ID: <20260515054723.25024-3-hal.feng@starfivetech.com> X-Mailer: git-send-email 2.43.2 In-Reply-To: <20260515054723.25024-1-hal.feng@starfivetech.com> References: <20260515054723.25024-1-hal.feng@starfivetech.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: SHXPR01CA0013.CHNPR01.prod.partner.outlook.cn (2406:e500:c311:1b::22) To ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:7::14) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: ZQ2PR01MB1307:EE_|ZQ2PR01MB1276:EE_ X-MS-Office365-Filtering-Correlation-Id: 958f09c7-6672-4f82-79e2-08deb24575e2 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014|52116014|56012099003|18002099003|22082099003|38350700014|3023799003; X-Microsoft-Antispam-Message-Info: 26tbQgFqIcr5nYFgKrSgrTeDRv0iS46Y26iepQyxDiphl9NoEhbFC3qtWR0iTYuivmpwJSka8jp9oEJap2hiTq5Cdyqzmet8gt4qjxNht7BDY9OMpWibUPvR7ZrZNQjclHeXY8KDigmRY8K49QkSaAR9GHSA6a5gIiQr1uRRpvA1ul9X82j8Iomy1o63aNa6kBYqrwx9l0azE4PYTD/S25nTr4pJGC8QtakDdQJ8L4jSRG9pNish15fjlmVHySu6kVZ4BvYfBzL/agzgx0PV6Ao9ybIwduTkdV+w9D9o3v0So2v4zZfTj7RoNBhsLuX4OxJVZpUkbpFsb/7guOL3fNBJeD5soHx9F+mqBu8W4JwHDYTFe993jZ/BivG0R2QukHqjgjyZQEebEC5SYmaVHj+oThuQVvhrr6X9viABYqk9ERiSyH863fNvDHFeMg4z2Z4E84xGuzFD+sc3XzEWyf+FWlGUgxJDqRa5KMT/8N4zjnNi0hut9y6yDbMJO+KmUHWB9gTpTu1GtI3ED/JoxOyl6y0bylMykQQ0hxaHxKKA8WnZ+ZA+qlrc/zI6c3cy X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn;PTR:;CAT:NONE;SFS:(13230040)(366016)(1800799024)(7416014)(376014)(52116014)(56012099003)(18002099003)(22082099003)(38350700014)(3023799003);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?4jTn6owov5OBSnAV4W1K8OxA5DhdzLFgPRKVoKSSdsmO1PTEZnsJGLcxyY3f?= =?us-ascii?Q?hurov/ixnnMzKJSOb7e/6VdC9mjYiFt9ISa8fkVUrH6gHIhnn29tQJUtVovt?= =?us-ascii?Q?mBu+03SDhgXnOrmuOqph19W/vZPtInMgLrnuwdgp5qnubVYuxAttcEYjaYrF?= =?us-ascii?Q?WgCj8fKsPFFF4gilotknvFOFNycVaLxPXQD2h5qibI/nanrd52ZLZ2hv8c54?= =?us-ascii?Q?QHjK+uISXJXZ/yy5KT+1/Gsw6OW8eSbGrU4sRCYyj2atGEO4URGRQAL7Cw4y?= =?us-ascii?Q?rO8pUsH8HjZziLnpHXIuAa7nutcZAA80jvSDEwKyu+CKG1IZeg1+5CEbyop4?= =?us-ascii?Q?GAunH8Y89g0FxwXAPWH3dCr9MZ2zPsqyFjB7HXAl1LxX+JoxBTSVwQtMi4GM?= =?us-ascii?Q?Zyq0NlpbkmG0TQiWFZOhZd1SB8OEy9hIqiklFtHxIsf/hQ6K5hMqLElptv0r?= =?us-ascii?Q?W53mmBVWcM4iQ2Hz1LpUPQ9GX7arRiogqHGT8WfB943HaVN0XiosBcTygUWT?= =?us-ascii?Q?cMmIxfHXc6NGyuHyMHW1hwLXmrvKe/rLhkOkSTMk80Y4J8n9i0/Z0/cUDWgl?= =?us-ascii?Q?BKjh8AkV3FpIojkJs2DV4NSLvbtH+na9q+2X7MJle8HwnwrT7CjdP4cNr9NE?= =?us-ascii?Q?HuWtCEM846+qCCSqipgM2VCFQwypW6P+lGiMLMa8zcwvSySu5Oc25ramIco6?= =?us-ascii?Q?R2GydCv2edwbaVQXLYH/xU8KKlT4EGrgQpLv/hn4yQHNg+DGCPJl6XH/xBQx?= =?us-ascii?Q?B4WJswbtQRsri6utEWcLMfMn4Z6MdsN/noqiOoNv+NAGLUlnEVGub/8D58I4?= =?us-ascii?Q?RnPfuDWjP6s+fhgzpM4eqgMirSfeXd9JKo4RaOy6Uh5RFKvgblmL9br5E7Nu?= =?us-ascii?Q?946EH9u0EV4R8gA0DIEyjPCzEv7jospfS1wLH0s/qkVg2ZnHpw2L9k9hUfA5?= =?us-ascii?Q?Xes0FtTGkVuBRI1nluQVlkgxik3ScOn/irRhpOq441CsKm3X6PgmTMYsqLW8?= =?us-ascii?Q?XPVdkyTM3trJA/WhdjZ0A7dtGB1STxkhQBUgLBe2Rnqv5lXy/DEuD85k6Pk5?= =?us-ascii?Q?iQ+/xXVyPRLBiRJqBnTXuyGGnjVMLHRQWHczmRN6bDqW8Fd9UVnlJrP6dO65?= =?us-ascii?Q?Qd4jaKw1z93SncigZozmdPTIrDNQpqgOjxoPPxvdPouWo0Rwt6W2XUY7ov0g?= =?us-ascii?Q?z1Ky6DRsA/eknPK7kP1CUb9aeEGBBYZFvXJwEfPw2jO3Cqux1+sYJDTmeHTc?= =?us-ascii?Q?8FwL6DmSc+vb4VD6H2TZt1Z6jfuxqY61O2jTajzNMSE6NPcUwSTkHPuZ4xza?= =?us-ascii?Q?5QNY5HculYu76Fuctu+L/G+Xu3KKKJnFruqBkhRtxdjpbLVEKAhMVISYP8zL?= =?us-ascii?Q?wiS6/ELGVK+8PN4VSg4V7ay9AmVdTxWJVczNG1cg7OuJqpEvJF9xnWTMnFkW?= =?us-ascii?Q?enUZIUmKTzkyrEuSczwoEaN93dpOw0IQSD6nuyBnAegPeWN3vnHdiYUkaRIT?= =?us-ascii?Q?aS+AqD98rk0HPG50YTcHZRe1fZYGh4t32/KYYgxXIdZj19X8QxlrA4Bqk/Qh?= =?us-ascii?Q?QJvMYT5nkqc2MDOlPps3V1oU1KPdqDjnFNd6ESTGEWuu9RIfhnEloA7puo/6?= =?us-ascii?Q?jHUfXkFnfIC+cLkTwYbs1EBfC3s5I9IH99tql2E6xS3AZnmL4RU1pSXbsUAD?= =?us-ascii?Q?1ZMFCSGpkJez6cIKaFDYw8j1rjwiXXJGviX6GzQQQmaSUCLkgKMjDej5LNha?= =?us-ascii?Q?uUVEfd3w0hck4wwFHA3tOxPVAamWtS4=3D?= X-OriginatorOrg: starfivetech.com X-MS-Exchange-CrossTenant-Network-Message-Id: 958f09c7-6672-4f82-79e2-08deb24575e2 X-MS-Exchange-CrossTenant-AuthSource: ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 May 2026 05:47:33.5195 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 06fe3fa3-1221-43d3-861b-5a4ee687a85c X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: qDk/52otvWK5/9Nv0Lvp3Z/4ixqWUw9Qb8qvifCW0lf7wHmlIQ6GV09cONYePQ68eaViw7laXwzM0oTMEJN/WkbbpDnol50mPlTEXbM2cvM= X-MS-Exchange-Transport-CrossTenantHeadersStamped: ZQ2PR01MB1276 Content-Type: text/plain; charset="utf-8" Each of the StarFive JH7100/JH7110 SoCs has 8 OpenCores PTC IP cores. One OpenCores PTC IP core can output one PWM channel. Signed-off-by: Hal Feng --- .../boot/dts/starfive/jh7100-common.dtsi | 28 ++++++-- arch/riscv/boot/dts/starfive/jh7100.dtsi | 69 ++++++++++++++++++- .../boot/dts/starfive/jh7110-common.dtsi | 27 ++++++-- .../boot/dts/starfive/jh7110-milkv-mars.dts | 6 +- .../dts/starfive/jh7110-milkv-marscm.dtsi | 6 +- .../dts/starfive/jh7110-pine64-star64.dts | 6 +- .../jh7110-starfive-visionfive-2-lite.dtsi | 6 +- .../jh7110-starfive-visionfive-2.dtsi | 6 +- arch/riscv/boot/dts/starfive/jh7110.dtsi | 69 ++++++++++++++++++- 9 files changed, 200 insertions(+), 23 deletions(-) diff --git a/arch/riscv/boot/dts/starfive/jh7100-common.dtsi b/arch/riscv/b= oot/dts/starfive/jh7100-common.dtsi index ae1a6aeb0aea..85106545090e 100644 --- a/arch/riscv/boot/dts/starfive/jh7100-common.dtsi +++ b/arch/riscv/boot/dts/starfive/jh7100-common.dtsi @@ -199,13 +199,23 @@ GPO_I2C2_PAD_SDA_OEN, }; }; =20 - pwm_pins: pwm-0 { - pwm-pins { + pwm0_pins: pwm0-0 { + pwm0-pins { pinmux =3D , - ; + bias-disable; + drive-strength =3D <35>; + input-disable; + input-schmitt-disable; + slew-rate =3D <0>; + }; + }; + + pwm1_pins: pwm1-0 { + pwm1-pins { + pinmux =3D ; @@ -359,9 +369,15 @@ &osc_aud { clock-frequency =3D <27000000>; }; =20 -&pwm { +&pwm0 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pwm0_pins>; + status =3D "okay"; +}; + +&pwm1 { pinctrl-names =3D "default"; - pinctrl-0 =3D <&pwm_pins>; + pinctrl-0 =3D <&pwm1_pins>; status =3D "okay"; }; =20 diff --git a/arch/riscv/boot/dts/starfive/jh7100.dtsi b/arch/riscv/boot/dts= /starfive/jh7100.dtsi index 7de0732b8eab..4629e9747307 100644 --- a/arch/riscv/boot/dts/starfive/jh7100.dtsi +++ b/arch/riscv/boot/dts/starfive/jh7100.dtsi @@ -360,9 +360,72 @@ watchdog@12480000 { <&rstgen JH7100_RSTN_WDT>; }; =20 - pwm: pwm@12490000 { - compatible =3D "starfive,jh7100-pwm", "opencores,pwm-v1"; - reg =3D <0x0 0x12490000 0x0 0x10000>; + pwm0: pwm@12490000 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x12490000 0x0 0x10>; + clocks =3D <&clkgen JH7100_CLK_PWM_APB>; + resets =3D <&rstgen JH7100_RSTN_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm1: pwm@12490010 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x12490010 0x0 0x10>; + clocks =3D <&clkgen JH7100_CLK_PWM_APB>; + resets =3D <&rstgen JH7100_RSTN_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm2: pwm@12490020 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x12490020 0x0 0x10>; + clocks =3D <&clkgen JH7100_CLK_PWM_APB>; + resets =3D <&rstgen JH7100_RSTN_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm3: pwm@12490030 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x12490030 0x0 0x10>; + clocks =3D <&clkgen JH7100_CLK_PWM_APB>; + resets =3D <&rstgen JH7100_RSTN_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm4: pwm@12498000 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x12498000 0x0 0x10>; + clocks =3D <&clkgen JH7100_CLK_PWM_APB>; + resets =3D <&rstgen JH7100_RSTN_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm5: pwm@12498010 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x12498010 0x0 0x10>; + clocks =3D <&clkgen JH7100_CLK_PWM_APB>; + resets =3D <&rstgen JH7100_RSTN_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm6: pwm@12498020 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x12498020 0x0 0x10>; + clocks =3D <&clkgen JH7100_CLK_PWM_APB>; + resets =3D <&rstgen JH7100_RSTN_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm7: pwm@12498030 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x12498030 0x0 0x10>; clocks =3D <&clkgen JH7100_CLK_PWM_APB>; resets =3D <&rstgen JH7100_RSTN_PWM_APB>; #pwm-cells =3D <3>; diff --git a/arch/riscv/boot/dts/starfive/jh7110-common.dtsi b/arch/riscv/b= oot/dts/starfive/jh7110-common.dtsi index 8cfe8033305d..5aa225b8bca8 100644 --- a/arch/riscv/boot/dts/starfive/jh7110-common.dtsi +++ b/arch/riscv/boot/dts/starfive/jh7110-common.dtsi @@ -351,9 +351,14 @@ uboot@100000 { }; }; =20 -&pwm { +&pwm0 { pinctrl-names =3D "default"; - pinctrl-0 =3D <&pwm_pins>; + pinctrl-0 =3D <&pwm0_pins>; +}; + +&pwm1 { + pinctrl-names =3D "default"; + pinctrl-0 =3D <&pwm1_pins>; }; =20 &spi0 { @@ -553,12 +558,22 @@ GPOEN_ENABLE, }; }; =20 - pwm_pins: pwm-0 { - pwm-pins { + pwm0_pins: pwm0-0 { + pwm0-pins { pinmux =3D , - ; + bias-disable; + drive-strength =3D <12>; + input-disable; + input-schmitt-disable; + slew-rate =3D <0>; + }; + }; + + pwm1_pins: pwm1-0 { + pwm1-pins { + pinmux =3D ; bias-disable; diff --git a/arch/riscv/boot/dts/starfive/jh7110-milkv-mars.dts b/arch/risc= v/boot/dts/starfive/jh7110-milkv-mars.dts index 21873612d993..54013c70f4b4 100644 --- a/arch/riscv/boot/dts/starfive/jh7110-milkv-mars.dts +++ b/arch/riscv/boot/dts/starfive/jh7110-milkv-mars.dts @@ -68,7 +68,11 @@ &phy0 { motorcomm,tx-clk-adj-enabled; }; =20 -&pwm { +&pwm0 { + status =3D "okay"; +}; + +&pwm1 { status =3D "okay"; }; =20 diff --git a/arch/riscv/boot/dts/starfive/jh7110-milkv-marscm.dtsi b/arch/r= iscv/boot/dts/starfive/jh7110-milkv-marscm.dtsi index 025471061d43..31afac27b86d 100644 --- a/arch/riscv/boot/dts/starfive/jh7110-milkv-marscm.dtsi +++ b/arch/riscv/boot/dts/starfive/jh7110-milkv-marscm.dtsi @@ -87,7 +87,11 @@ &phy0 { motorcomm,tx-clk-adj-enabled; }; =20 -&pwm { +&pwm0 { + status =3D "okay"; +}; + +&pwm1 { status =3D "okay"; }; =20 diff --git a/arch/riscv/boot/dts/starfive/jh7110-pine64-star64.dts b/arch/r= iscv/boot/dts/starfive/jh7110-pine64-star64.dts index aec7ae3d1f5b..a9e82f25efde 100644 --- a/arch/riscv/boot/dts/starfive/jh7110-pine64-star64.dts +++ b/arch/riscv/boot/dts/starfive/jh7110-pine64-star64.dts @@ -95,7 +95,11 @@ &phy1 { motorcomm,tx-clk-100-inverted; }; =20 -&pwm { +&pwm0 { + status =3D "okay"; +}; + +&pwm1 { status =3D "okay"; }; =20 diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-lite= .dtsi b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-lite.dtsi index f8797a666dbf..85b56a72dff7 100644 --- a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-lite.dtsi +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2-lite.dtsi @@ -74,7 +74,11 @@ &phy0 { tx-internal-delay-ps =3D <1500>; }; =20 -&pwm { +&pwm0 { + status =3D "okay"; +}; + +&pwm1 { status =3D "okay"; }; =20 diff --git a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2.dtsi= b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2.dtsi index edc8f4588133..35208f95cd3d 100644 --- a/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2.dtsi +++ b/arch/riscv/boot/dts/starfive/jh7110-starfive-visionfive-2.dtsi @@ -73,7 +73,11 @@ &pcie1 { status =3D "okay"; }; =20 -&pwm { +&pwm0 { + status =3D "okay"; +}; + +&pwm1 { status =3D "okay"; }; =20 diff --git a/arch/riscv/boot/dts/starfive/jh7110.dtsi b/arch/riscv/boot/dts= /starfive/jh7110.dtsi index 6e56e9d20bb0..e6b9b02bf8b2 100644 --- a/arch/riscv/boot/dts/starfive/jh7110.dtsi +++ b/arch/riscv/boot/dts/starfive/jh7110.dtsi @@ -846,9 +846,72 @@ i2stx1: i2s@120c0000 { status =3D "disabled"; }; =20 - pwm: pwm@120d0000 { - compatible =3D "starfive,jh7110-pwm", "opencores,pwm-v1"; - reg =3D <0x0 0x120d0000 0x0 0x10000>; + pwm0: pwm@120d0000 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x120d0000 0x0 0x10>; + clocks =3D <&syscrg JH7110_SYSCLK_PWM_APB>; + resets =3D <&syscrg JH7110_SYSRST_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm1: pwm@120d0010 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x120d0010 0x0 0x10>; + clocks =3D <&syscrg JH7110_SYSCLK_PWM_APB>; + resets =3D <&syscrg JH7110_SYSRST_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm2: pwm@120d0020 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x120d0020 0x0 0x10>; + clocks =3D <&syscrg JH7110_SYSCLK_PWM_APB>; + resets =3D <&syscrg JH7110_SYSRST_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm3: pwm@120d0030 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x120d0030 0x0 0x10>; + clocks =3D <&syscrg JH7110_SYSCLK_PWM_APB>; + resets =3D <&syscrg JH7110_SYSRST_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm4: pwm@120d8000 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x120d8000 0x0 0x10>; + clocks =3D <&syscrg JH7110_SYSCLK_PWM_APB>; + resets =3D <&syscrg JH7110_SYSRST_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm5: pwm@120d8010 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x120d8010 0x0 0x10>; + clocks =3D <&syscrg JH7110_SYSCLK_PWM_APB>; + resets =3D <&syscrg JH7110_SYSRST_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm6: pwm@120d8020 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x120d8020 0x0 0x10>; + clocks =3D <&syscrg JH7110_SYSCLK_PWM_APB>; + resets =3D <&syscrg JH7110_SYSRST_PWM_APB>; + #pwm-cells =3D <3>; + status =3D "disabled"; + }; + + pwm7: pwm@120d8030 { + compatible =3D "opencores,pwm-v1"; + reg =3D <0x0 0x120d8030 0x0 0x10>; clocks =3D <&syscrg JH7110_SYSCLK_PWM_APB>; resets =3D <&syscrg JH7110_SYSRST_PWM_APB>; #pwm-cells =3D <3>; --=20 2.43.2 From nobody Fri Jun 12 12:43:13 2026 Received: from CHN02-BJS-obe.outbound.protection.partner.outlook.cn (mail-bjschn02on2093.outbound.protection.partner.outlook.cn [139.219.17.93]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id BB9ED357A40; Fri, 15 May 2026 05:48:50 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=139.219.17.93 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778824135; cv=fail; b=PMUGtlFOhOHQiHXOj+cAk9CJeZjn+ExuFqWYFepaYsd2zojil1zoP8ld82hByRR3c2tbMkyosaQQBvRDyAQHewOmaypBg5j+c23toEWFPTV07tj0ahXCCNNkYoomWx4KU/hBx56QiyBfbj9Vbrm5nZ4wh97gaGgp75VkT3CDt+w= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1778824135; c=relaxed/simple; bh=wzlg8jr9UzZybZmk3buMCxSpXkcMzEI4MhBbbvIpyBk=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: Content-Type:MIME-Version; b=DADlGXPeEclNaeMPNc4FCaMCM9Tm8b48d5tL4wNmKO4YPMd+n+gJ32chjwdn2kMIPt2DQKC4rWiFOifAols9N1cyAsOJNiXsh9D1Of1AIN3eZlYlnOWQELDgHQIUIiKPisXbkhxSGRdi7AOz3Ox0BaX25KVvizmAkzC1WE0pnNo= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=starfivetech.com; spf=pass smtp.mailfrom=starfivetech.com; arc=fail smtp.client-ip=139.219.17.93 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=quarantine dis=none) header.from=starfivetech.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=starfivetech.com ARC-Seal: i=1; a=rsa-sha256; s=arcselector9901; d=microsoft.com; cv=none; b=dZFpP/1vnaMawTshJkug2yHznX73WsQ2kWUU9mV+hx4ouB3oBCfTDftqG0xZ0uiQC6359kGxp0Ppq+lSfEqP3BVP/jC5zRBcEMOF63ZVGaPfk+99xouV+bgriayW0iTHVa8Biv+fUi4+NTRIv3vHwE2L0H+Qh8dH8CEcgYyyUw66r+FuL5vIDKyHg2U7/0a950v/P5q3LYpf9z9MvqsaPrubN5BkobzVtqLUbHHLSdeQ4oEWWCJ7RbP+PDwFlU6CfYRegCnkxCy6lefzzp7EWEhb7sgnO3X1qxXDiP+qtpx+z30WYquzDLlewjC51TLckI/DAf4r23rorRUCfxYTRg== 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=OivD3rqodpHTLCVPIlZiEbGvMcTPZG5rEDwZdFQa/DM=; b=Oc2yhB9a2ddLv9Du38yKltwEBsftLHDxcFSPTJZCXz6vgQSpLlwdbyTMcYKesnlX8XK3SrEJK8b1MiX1pKZzg4eUnBrYvBGphQ0oyQk6O+YEJUL8hQobld54J1Dpjamv15zU7wUYVTL63cuXAwMFs7bU/USwlSVtEZ1FJBLSUbp/lKx2elN5NpZj3KpK8RBSPDPwpJ8wBIz8jHpDqJfOdW4ucKjinLEXVVDIkOjYCWVU3wiMGYvW9IXkIfJwHpqZXVD+JTRWRN1Kfm7FZMhG32KuA+MhEEtFKK8rw0LRS3iUxuMz2FtqMVbi8iufINAnx9o+Oi3B7UMKPMV1v77hfQ== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=starfivetech.com; dmarc=pass action=none header.from=starfivetech.com; dkim=pass header.d=starfivetech.com; arc=none Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=starfivetech.com; Received: from ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:7::14) by ZQ2PR01MB1276.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:10::7) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.9913.12; Fri, 15 May 2026 05:47:34 +0000 Received: from ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn ([fe80::4386:5cc4:3bc4:4795]) by ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn ([fe80::4386:5cc4:3bc4:4795%4]) with mapi id 15.20.9913.009; Fri, 15 May 2026 05:47:34 +0000 From: Hal Feng To: =?UTF-8?q?Uwe=20Kleine-K=C3=B6nig?= , Philipp Zabel , Rob Herring , Krzysztof Kozlowski , Conor Dooley , Emil Renner Berthing , Palmer Dabbelt , Paul Walmsley , Albert Ou Cc: Changhuang Liang , Hal Feng , linux-pwm@vger.kernel.org, devicetree@vger.kernel.org, linux-riscv@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH v18 3/3] pwm: Add OpenCores PTC PWM driver Date: Fri, 15 May 2026 13:47:22 +0800 Message-ID: <20260515054723.25024-4-hal.feng@starfivetech.com> X-Mailer: git-send-email 2.43.2 In-Reply-To: <20260515054723.25024-1-hal.feng@starfivetech.com> References: <20260515054723.25024-1-hal.feng@starfivetech.com> Content-Transfer-Encoding: quoted-printable X-ClientProxiedBy: SHXPR01CA0013.CHNPR01.prod.partner.outlook.cn (2406:e500:c311:1b::22) To ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn (2406:e500:c550:7::14) Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: ZQ2PR01MB1307:EE_|ZQ2PR01MB1276:EE_ X-MS-Office365-Filtering-Correlation-Id: 2a1bb34a-4fd6-425b-5554-08deb24576a4 X-MS-Exchange-SenderADCheck: 1 X-Microsoft-Antispam: BCL:0;ARA:13230040|366016|1800799024|7416014|376014|52116014|56012099003|18002099003|22082099003|13003099007|38350700014|3023799003; X-Microsoft-Antispam-Message-Info: 5zLsvayno+h3nRiQ7BiMFjexR1Sxz4VjSjK8qGSjgsdQDyzS2aS1loinpBNeSI4A6gTAbGv1DfSORTsB8gI6ub823X/pY7nKUP15R+OeA2W3difDDePGExP6FzFSmxWNwWg1+wwdMYpVYbFq+liIsdptoHegktgqH1UbfNjpE0L8XwMufzfJs2Whu5oRkfu/PRkBebYAGY0aQZ+ytL+DCZgzqJlMgsa9rGJlzbA+BrCueDDQ7mok8pIGghqoCUglhOaBQX+QjBTb8iVVmIulrjyiFBUEKN/MmQZ9mcPX2c0iOjysH/lOKdU7BRhf4FOQ5L048uV+In3boQYIzWjj6EayPAapRQ7rZBHu50Kj9LdsLZCp9wE7CCmtlwpuVKMRfIqAKjOX8+OtDwQamrUEEQgBR+ndehEcU2kYZHuKRp6+2IPt+pimQKrMqokpp/nydUUVH4ehnqblWmkpaYf0FqKwCwjhQzb8ixHYEofsa+HjO8jl2oIFux+f5YQox82N33Me7PZcI2nQ0dRHgktgi7yVtThLiJyjonlYySeIx/QuAeTxKonIZgqTpdO9/0bP X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn;PTR:;CAT:NONE;SFS:(13230040)(366016)(1800799024)(7416014)(376014)(52116014)(56012099003)(18002099003)(22082099003)(13003099007)(38350700014)(3023799003);DIR:OUT;SFP:1102; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?us-ascii?Q?zQ8tPd76SvGIQooECcohFPeNWveL+Wr+1KhuWGwNDE1sU8kSfCEyEXlG6VDa?= =?us-ascii?Q?vG+OtqA/4ULI/nwC7LZnSFLOOYpwOpxbAQwg0Bhk5UvzNTct3Z3dKrmP1U4G?= =?us-ascii?Q?OikgOjNE71CBrZre8vGDYEKeWE0XFVt3xYrdCKms6csvcpUWGbz/LYn7Rt1l?= =?us-ascii?Q?MPlgHGNumfQ61bpIB2Z8oUs1pKQSBuQjJqHvgfJUs/avOaps17wuj8JDofwE?= =?us-ascii?Q?DBDWU3FZ0sdVx20lzXuTHI9M2jdzmRfD2aXPplNOkwHaDsaCX9inBK30TJXy?= =?us-ascii?Q?XWYwK7kzEHE+x2AXrWCz+JR4/cWqbbDndvBX1oM/31jwFAm9nnaVXPLH/rcu?= =?us-ascii?Q?DHGE77o+5ecJuqqqn372NwqzxQXkCx3vAmsTgVdEVNzDT0eQiLIdni0zLILA?= =?us-ascii?Q?y5sWI382fsoj7l8U4Te+xC5jhbmnfiWdngHiYGTYk0YeS4mnKrXHJv3vZ5J+?= =?us-ascii?Q?HnHrhCd1Viv53ribNvlS7gt0bQPgs1YdANIVjDzDCar/SxWpS51yVZozJ6Y5?= =?us-ascii?Q?NVQMdKCrUEQytx2QzqSsIyIjV96PteQVwQ6reg8bsBD8W5veggVeY1HY6HIP?= =?us-ascii?Q?6JATZ0ar7vC8RHqkL8Zr9bp6TUiNlRGMxyTkTvqww5A8GiP9K1AkJ+ZU8Dxe?= =?us-ascii?Q?SsKTS7PASDMFAxUCk69nkmiGqFjyYmXkx0nHiZfyG+e1rjSc2QskKRH56/Li?= =?us-ascii?Q?x0WLO2M0+/9n8WZ/q2YXvi6O57DSeJNxK5FmJT3vPx8q5EB3gmmOC1uqF+ic?= =?us-ascii?Q?uq6op+zZM55mdz7Kb6MXN5sEkoUfdsLoi8X1+AB5/6Eppw3mxmMyul4h0XGm?= =?us-ascii?Q?a1jhfto13LLrGIHHSHEK5ifpqzkXPGpX/jUmyLck0hthbEef1g9tb0HPJohH?= =?us-ascii?Q?1MIIfzZr97WFeJY7NY0UarrDvEJKKOyqdnL4egadW73Oi05IlWh4Vfr7F/X1?= =?us-ascii?Q?iAmn2DZ65PSX4A36kfkZxL2cQYJK8WauC9rm4V3YBJ7OmxRQkW4N5jsVr0Le?= =?us-ascii?Q?+slCG8k0UtJgKApikx3oPelLlIijORnVaO/je8GxgiMBx2kBUFGWjboYgVzC?= =?us-ascii?Q?WttNllKem2XIyGaMLqVUJxXqjzCuCsxYb41H3MXaUoozZRyWZSIcuIcIGC3c?= =?us-ascii?Q?4htz1K63/9KqMqPZG63zMagmHdFh18w7dDEvTQVJWJY5+2TnyqTBpgi5GF0T?= =?us-ascii?Q?6TNwMMLrS0s765k3coJLkBVYmqHhF1Tamo0c0OZrYKqLMyZ4kOps7ehGURhl?= =?us-ascii?Q?2I8/odwmoxFt4XQ45SDo+WWebJ1xQVgUtM99aJJJL1lkd4ibNoIugYBCiw2h?= =?us-ascii?Q?AnFkb5/2Wtgt7xXzd1O6nhBjhLZyY/WrDexw44Ee55ciBFNCgeyRin8ViVlG?= =?us-ascii?Q?RNBq2zhLkoHGTCGO/TecEBILriTxrCeUOszb0DpaC2IJ5/pTp2TpXMxHTLM2?= =?us-ascii?Q?PjzHiP/TVy+Rj+5Je3Tck8fb697GCHYfp4JtUJJqHqa0NikLWUnsfN7rpxzr?= =?us-ascii?Q?RPJOFf+SkEMFPS9OTD3rQN/M+kCTGjVwGpiOf6mctFfIrcWmhrQEn0y/Qqu2?= =?us-ascii?Q?aC6e7s3L98u/ExuJk04RjwRLVjR2Ll9OBYiT1Oz3GBFpFRTuek6kkW0agPdo?= =?us-ascii?Q?/PVLm1dCMijeh3aLy8N0wW6Iqq7kdpDcTPSrEQhKf1j8U5bxJZvZXX0eP1zj?= =?us-ascii?Q?K1RJmRwtkcf68CSvDX6RaGNB/JYkPC5WfcZdROvSoRkHqlZpWONHCW4Q1Ckr?= =?us-ascii?Q?7Gd11x6f2Y9q4Lx9HZ/ZLVvfmHSjy4I=3D?= X-OriginatorOrg: starfivetech.com X-MS-Exchange-CrossTenant-Network-Message-Id: 2a1bb34a-4fd6-425b-5554-08deb24576a4 X-MS-Exchange-CrossTenant-AuthSource: ZQ2PR01MB1307.CHNPR01.prod.partner.outlook.cn X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 15 May 2026 05:47:34.7720 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 06fe3fa3-1221-43d3-861b-5a4ee687a85c X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: 3jWDgQHqBVIDwipNeV/m/YPBQC9QiKOXbDOr9PdOrH6xTjLcPeF4Gyh5D5bn/941/fkokjMoBWKo8T1a3Xq8dJKVyoJqp26YTWLFmpe+M2E= X-MS-Exchange-Transport-CrossTenantHeadersStamped: ZQ2PR01MB1276 Content-Type: text/plain; charset="utf-8" Add PWM driver for OpenCores PTC IP core. Signed-off-by: Hal Feng --- MAINTAINERS | 6 + drivers/pwm/Kconfig | 12 ++ drivers/pwm/Makefile | 1 + drivers/pwm/pwm-ocores.c | 249 +++++++++++++++++++++++++++++++++++++++ 4 files changed, 268 insertions(+) create mode 100644 drivers/pwm/pwm-ocores.c diff --git a/MAINTAINERS b/MAINTAINERS index 6aa3fe2ee1bb..14af609f4ada 100644 --- a/MAINTAINERS +++ b/MAINTAINERS @@ -20027,6 +20027,12 @@ F: Documentation/i2c/busses/i2c-ocores.rst F: drivers/i2c/busses/i2c-ocores.c F: include/linux/platform_data/i2c-ocores.h =20 +OPENCORES PWM DRIVER +M: Hal Feng +S: Supported +F: Documentation/devicetree/bindings/pwm/opencores,pwm.yaml +F: drivers/pwm/pwm-ocores.c + OPENRISC ARCHITECTURE M: Jonas Bonn M: Stefan Kristiansson diff --git a/drivers/pwm/Kconfig b/drivers/pwm/Kconfig index 6f3147518376..dd7f3bf5c3eb 100644 --- a/drivers/pwm/Kconfig +++ b/drivers/pwm/Kconfig @@ -534,6 +534,18 @@ config PWM_NTXEC controller found in certain e-book readers designed by the original design manufacturer Netronix. =20 +config PWM_OCORES + tristate "OpenCores PTC PWM support" + depends on HAS_IOMEM && OF + depends on COMMON_CLK + depends on ARCH_STARFIVE || COMPILE_TEST + help + PWM driver for OpenCores PTC IP core. + For details see https://opencores.org/projects/ptc. + + To compile this driver as a module, choose M here: the module + will be called pwm-ocores. + config PWM_OMAP_DMTIMER tristate "OMAP Dual-Mode Timer PWM support" depends on OF diff --git a/drivers/pwm/Makefile b/drivers/pwm/Makefile index 0dc0d2b69025..2d47bad7bd74 100644 --- a/drivers/pwm/Makefile +++ b/drivers/pwm/Makefile @@ -47,6 +47,7 @@ obj-$(CONFIG_PWM_MICROCHIP_CORE) +=3D pwm-microchip-core.o obj-$(CONFIG_PWM_MTK_DISP) +=3D pwm-mtk-disp.o obj-$(CONFIG_PWM_MXS) +=3D pwm-mxs.o obj-$(CONFIG_PWM_NTXEC) +=3D pwm-ntxec.o +obj-$(CONFIG_PWM_OCORES) +=3D pwm-ocores.o obj-$(CONFIG_PWM_OMAP_DMTIMER) +=3D pwm-omap-dmtimer.o obj-$(CONFIG_PWM_PCA9685) +=3D pwm-pca9685.o obj-$(CONFIG_PWM_PXA) +=3D pwm-pxa.o diff --git a/drivers/pwm/pwm-ocores.c b/drivers/pwm/pwm-ocores.c new file mode 100644 index 000000000000..fa6a34117cde --- /dev/null +++ b/drivers/pwm/pwm-ocores.c @@ -0,0 +1,249 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * OpenCores PTC PWM Driver + * + * https://opencores.org/projects/ptc + * + * Copyright (C) 2018-2026 StarFive Technology Co., Ltd. + * + * Limitations: + * - The hardware only supports inverted polarity. + * - The hardware minimum period / duty_cycle of PWM is (1 / pwm_apb clock= frequency). + * - The hardware maximum period / duty_cycle of PWM is (U32_MAX / pwm_apb= clock frequency). + * - The output is immediately set to low when the module is disabled. + */ + +#include +#include +#include +#include +#include +#include +#include + +#define OCPWM_HRC 0x4 +#define OCPWM_LRC 0x8 +#define OCPWM_CTRL 0xC + +#define OCPWM_CTRL_EN BIT(0) +#define OCPWM_CTRL_OE BIT(3) +#define OCPWM_CTRL_RST BIT(7) + +struct ocores_pwm_device { + void __iomem *base; + struct clk *clk; + unsigned long clk_rate; + struct reset_control *rst; +}; + +static int ocores_pwm_get_state(struct pwm_chip *chip, + struct pwm_device *pwm, + struct pwm_state *state) +{ + struct ocores_pwm_device *ddata =3D pwmchip_get_drvdata(chip); + u32 period_data, duty_data, ctrl_data; + int ret; + + ret =3D pm_runtime_resume_and_get(pwmchip_parent(chip)); + if (ret < 0) + return ret; + + period_data =3D readl(ddata->base + OCPWM_LRC); + duty_data =3D readl(ddata->base + OCPWM_HRC); + ctrl_data =3D readl(ddata->base + OCPWM_CTRL); + + state->period =3D DIV_ROUND_UP_ULL((u64)period_data * NSEC_PER_SEC, ddata= ->clk_rate); + state->duty_cycle =3D DIV_ROUND_UP_ULL((u64)duty_data * NSEC_PER_SEC, dda= ta->clk_rate); + if (state->duty_cycle > state->period) + state->duty_cycle =3D state->period; + + state->polarity =3D PWM_POLARITY_INVERSED; + state->enabled =3D (ctrl_data & OCPWM_CTRL_EN) ? true : false; + + pm_runtime_put(pwmchip_parent(chip)); + + return 0; +} + +static int ocores_pwm_apply(struct pwm_chip *chip, + struct pwm_device *pwm, + const struct pwm_state *state) +{ + struct ocores_pwm_device *ddata =3D pwmchip_get_drvdata(chip); + u64 period_data, duty_data; + int ret; + + if (state->polarity !=3D PWM_POLARITY_INVERSED) + return -EINVAL; + + if (state->enabled) { + if (!pwm_is_enabled(pwm)) { + ret =3D pm_runtime_resume_and_get(pwmchip_parent(chip)); + if (ret < 0) + return ret; + } + } else { + if (pwm_is_enabled(pwm)) { + writel(0, ddata->base + OCPWM_CTRL); + pm_runtime_put(pwmchip_parent(chip)); + } + return 0; + } + + writel(0, ddata->base + OCPWM_CTRL); + writel(OCPWM_CTRL_RST, ddata->base + OCPWM_CTRL); + + period_data =3D mul_u64_u32_div(state->period, ddata->clk_rate, NSEC_PER_= SEC); + if (period_data > U32_MAX) + period_data =3D U32_MAX; + + duty_data =3D mul_u64_u32_div(state->duty_cycle, ddata->clk_rate, NSEC_PE= R_SEC); + if (duty_data > U32_MAX) + duty_data =3D U32_MAX; + + writel(period_data, ddata->base + OCPWM_LRC); + writel(duty_data, ddata->base + OCPWM_HRC); + writel(OCPWM_CTRL_OE | OCPWM_CTRL_EN, ddata->base + OCPWM_CTRL); + + return 0; +} + +static const struct pwm_ops ocores_pwm_ops =3D { + .get_state =3D ocores_pwm_get_state, + .apply =3D ocores_pwm_apply, +}; + +static int ocores_pwm_runtime_suspend(struct device *dev) +{ + struct ocores_pwm_device *ddata =3D dev_get_drvdata(dev); + + clk_disable_unprepare(ddata->clk); + + return 0; +} + +static int ocores_pwm_runtime_resume(struct device *dev) +{ + struct ocores_pwm_device *ddata =3D dev_get_drvdata(dev); + int ret; + + ret =3D clk_prepare_enable(ddata->clk); + if (ret) + return dev_err_probe(dev, ret, "Failed to enable clock\n"); + + return 0; +} + +static const struct dev_pm_ops ocores_pwm_pm_ops =3D { + RUNTIME_PM_OPS(ocores_pwm_runtime_suspend, + ocores_pwm_runtime_resume, NULL) + SYSTEM_SLEEP_PM_OPS(pm_runtime_force_suspend, + pm_runtime_force_resume) +}; + +static void ocores_pwm_pm_disable(void *data) +{ + struct device *dev =3D data; + struct ocores_pwm_device *ddata =3D dev_get_drvdata(dev); + + pm_runtime_disable(dev); + + if (!pm_runtime_status_suspended(dev)) + ocores_pwm_runtime_suspend(dev); + + reset_control_assert(ddata->rst); +} + +static int ocores_pwm_probe(struct platform_device *pdev) +{ + struct device *dev =3D &pdev->dev; + struct ocores_pwm_device *ddata; + struct pwm_chip *chip; + int ret; + + chip =3D devm_pwmchip_alloc(dev, 1, sizeof(*ddata)); + if (IS_ERR(chip)) + return -ENOMEM; + + chip->ops =3D &ocores_pwm_ops; + ddata =3D pwmchip_get_drvdata(chip); + + ddata->base =3D devm_platform_ioremap_resource(pdev, 0); + if (IS_ERR(ddata->base)) + return dev_err_probe(dev, PTR_ERR(ddata->base), + "Failed to map IO resources\n"); + + ddata->clk =3D devm_clk_get(dev, NULL); + if (IS_ERR(ddata->clk)) + return dev_err_probe(dev, PTR_ERR(ddata->clk), + "Failed to get clock\n"); + + ddata->clk_rate =3D clk_get_rate(ddata->clk); + if (!ddata->clk_rate || ddata->clk_rate > NSEC_PER_SEC) + return dev_err_probe(dev, -EINVAL, + "Invalid clock rate: %lu\n", ddata->clk_rate); + + ddata->rst =3D devm_reset_control_get_optional_shared(dev, NULL); + if (IS_ERR(ddata->rst)) + return dev_err_probe(dev, PTR_ERR(ddata->rst), + "Failed to get reset\n"); + + platform_set_drvdata(pdev, ddata); + + ret =3D ocores_pwm_runtime_resume(dev); + if (ret) + return ret; + + ret =3D reset_control_deassert(ddata->rst); + if (ret) + goto err_clk_disable; + + ret =3D pm_runtime_set_active(dev); + if (ret) + goto err_reset_assert; + + pm_runtime_enable(dev); + + ret =3D devm_add_action_or_reset(dev, ocores_pwm_pm_disable, dev); + if (ret) + return dev_err_probe(dev, ret, "Failed to add pm disable action\n"); + + pm_runtime_get_noresume(dev); + + writel(0, ddata->base + OCPWM_CTRL); + + pm_runtime_put(dev); + + ret =3D devm_pwmchip_add(dev, chip); + if (ret < 0) + return dev_err_probe(dev, ret, "Could not register PWM chip\n"); + + return 0; + +err_reset_assert: + reset_control_assert(ddata->rst); +err_clk_disable: + ocores_pwm_runtime_suspend(dev); + return dev_err_probe(dev, ret, "Failed to init pwm power\n"); +} + +static const struct of_device_id ocores_pwm_of_match[] =3D { + { .compatible =3D "opencores,pwm-v1" }, + { /* sentinel */ } +}; +MODULE_DEVICE_TABLE(of, ocores_pwm_of_match); + +static struct platform_driver ocores_pwm_driver =3D { + .probe =3D ocores_pwm_probe, + .driver =3D { + .name =3D "ocores-pwm", + .of_match_table =3D ocores_pwm_of_match, + .pm =3D pm_ptr(&ocores_pwm_pm_ops), + }, +}; +module_platform_driver(ocores_pwm_driver); + +MODULE_AUTHOR("Jieqin Chen"); +MODULE_AUTHOR("Hal Feng "); +MODULE_DESCRIPTION("OpenCores PTC PWM driver"); +MODULE_LICENSE("GPL"); --=20 2.43.2