From patchwork Thu Jan 2 18:18:34 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Lad, Prabhakar" X-Patchwork-Id: 13924738 X-Patchwork-Delegate: geert@linux-m68k.org Received: from mail-wm1-f51.google.com (mail-wm1-f51.google.com [209.85.128.51]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 493D613AA5D; Thu, 2 Jan 2025 18:18:50 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.51 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841932; cv=none; b=F63OCBiLP8H4kg+S5gt89agJun6VC/UdnQ2sqrCv6YKzmtmEhNmGxs9BcXiEo4YPBEYUhby+yfEhpmMcvqSTfaT3ksjavNHAGXOyQxqoaoLpzU8PZbRkDJkrWKLpFEDrHxZARMkM07wPXMY4+As9ZP0AAWkyiPxStHN7pAEjP18= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841932; c=relaxed/simple; bh=JmLk4ljuZ7xiX8bADf4dNc7I5vAM/pMGBhfwySLwVe4=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=mODfTUOo1AATfkts+MffI6lR/gECl1Ov67RpYWCbdKuO4AAuuAHWxB9QVPqe9Qd/z3wf2PrPgSVXg2hKCJj24YLtMS2aV9CSw2KLC2sbsUMYdLSuXtqh+7IoM9i2R6ZD2qlXVl3OGRe8DI7wAXDqgosAI+GOOgoV8baDSIK1bmA= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=MZX8ZCzB; arc=none smtp.client-ip=209.85.128.51 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="MZX8ZCzB" Received: by mail-wm1-f51.google.com with SMTP id 5b1f17b1804b1-436a03197b2so31697795e9.2; Thu, 02 Jan 2025 10:18:49 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1735841928; x=1736446728; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=E8F8nI85CSoBO0AFHab1AQK0sPA9I8Q3LIq61hfLXVI=; b=MZX8ZCzBzvxBWq217A2ryjrebekNoy8hE4SiYUgTFca1oKuQBKvXXYdRy8Rk2jR30F oxGJ8P4LYU6guXOUD3uHtrYR/WKav6Py0aMb4yTvTRclWxyMrSQXJY+wW6k78fvBefDI JUWEy4x02jhMUzXJwTrrfbYRYmODCoIX0plurse3qvGbnYcjg4rSE1Nr7k9+wMvsgZbW 6oEhF0Ac9rsBwOw1xlD1S7rQHHPOxGGMIyUnpInIcvYvjAv1BOQOGK9pvNARByEjpF7/ opE2GWIAfBaBb/aOBx4qwBa0u8GzuyBxXzpXAL4JdUKyzb5q4Jm2Rgimj+3l745HJ6aE PV7A== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1735841928; x=1736446728; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=E8F8nI85CSoBO0AFHab1AQK0sPA9I8Q3LIq61hfLXVI=; b=MqVr1NG4B4auOGKYV/1NVwZllXLjrIyoxPzuO77JWay+DCx1YRplOzbE1M82M0r7Cq EP7P/u1GqFTBwirm+yiIViIrtDuPudvpCDDr+PYCq8aQq/J5dgIc1WiSbFdDWCQ2v60b 10UcXMOLgDGTMrgfdUxOFplwm7lcKjPNymwqx4sewp5VsI8i8P6M1TZbRMyGZv2UjOVZ zQOEOZVbUSrzOkFTL9gFR47dtyhiQiILFds8uIslNLRIgizMqgSGPhHEHpelANK5ux5j Okj1q1vq11/S80v82s1VIRPvVhKPfwhSEu5YhbhRd5h2Htl2cUcgtubi79j59n9a/QZ4 kqjA== X-Forwarded-Encrypted: i=1; AJvYcCUFmYpcZMb3SPSMyu0lZPXNyStTlBarvcvwjDnyveBkkELKx8vAphzgw3oqVJm6T0vzcbt9pAlcRSw=@vger.kernel.org, AJvYcCWrRvPeyRFEqJIXwcW/hYhcRaLjhYHNtI3KcP6Zg//CkZcgcWCgTj3X1ESakbf/pti/sgayXTzDZOL/dnqo@vger.kernel.org X-Gm-Message-State: AOJu0Yy+amZreZT/CTErI41G7ZuinmCjQr/kXKDAtpI8LNPARAa6HEI1 PXRUvZUttLGvB3Zvb3FyhYj01ZxxyBu/6Ja7PxgHoCZTtWvoPuAh X-Gm-Gg: ASbGncuopX63xIJYzVbA2x7pCslXynlM2hrmckRGhHoOPNtST/WrpGLoT9d2npoAZiA YZrSpuz2IgmtAkOhTeGNl+IMBQS8Osd2e53MMFhuI0XgUq8DgHg5Bj1zhJcoxzVoYqckGG+0xR3 /IYjT4Of4sdN28zPBB+CCyyonnlM+3/TbrgFD4A8Akq8+r3sFm/XSgbGAMko4qn6tynDGkOzh/I o7ZFGVTZDi4Oei4pas9oVuh9vq2mAPKESmpB81koEQ5zP6c6N/s6ekNtMNQhIYn/I1d8fo+J4LZ 6TlleI4f0g== X-Google-Smtp-Source: AGHT+IFPD1EWDqDdGpCCElpuTOvOSEJPb4ISn6eD8ISWuPe+ZEUB9gfQDHHQlAPbXHD1tjVDqjgQrg== X-Received: by 2002:a05:600c:68d7:b0:434:f270:a513 with SMTP id 5b1f17b1804b1-4366d357401mr372196745e9.29.1735841928270; Thu, 02 Jan 2025 10:18:48 -0800 (PST) Received: from prasmi.Home ([2a06:5906:61b:2d00:84e9:7adb:b646:c9c0]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-43656af6cbbsm493291925e9.3.2025.01.02.10.18.47 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Jan 2025 10:18:47 -0800 (PST) From: Prabhakar X-Google-Original-From: Prabhakar To: Geert Uytterhoeven , Michael Turquette , Stephen Boyd Cc: linux-renesas-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org, Prabhakar , Biju Das , Fabrizio Castro , Lad Prabhakar Subject: [PATCH v3 1/6] clk: renesas: rzv2h: Fix use-after-free in MSTOP refcount handling Date: Thu, 2 Jan 2025 18:18:34 +0000 Message-ID: <20250102181839.352599-2-prabhakar.mahadev-lad.rj@bp.renesas.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> References: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> Precedence: bulk X-Mailing-List: linux-renesas-soc@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 From: Lad Prabhakar Avoid triggering a `refcount_t: addition on 0; use-after-free.` warning when registering a module clock with the same MSTOP configuration. The issue arises when a module clock is registered but not enabled, resulting in a `ref_cnt` of 0. Subsequent calls to `refcount_inc()` on such clocks cause the kernel to warn about use-after-free. [ 0.113529] ------------[ cut here ]------------ [ 0.113537] refcount_t: addition on 0; use-after-free. [ 0.113576] WARNING: CPU: 2 PID: 1 at lib/refcount.c:25 refcount_warn_saturate+0x120/0x144 [ 0.113602] Modules linked in: [ 0.113616] CPU: 2 UID: 0 PID: 1 Comm: swapper/0 Not tainted 6.13.0-rc3+ #446 [ 0.113629] Hardware name: Renesas RZ/V2H EVK Board based on r9a09g057h44 (DT) [ 0.113641] pstate: 60400005 (nZCv daif +PAN -UAO -TCO -DIT -SSBS BTYPE=--) [ 0.113652] pc : refcount_warn_saturate+0x120/0x144 [ 0.113664] lr : refcount_warn_saturate+0x120/0x144 [ 0.113675] sp : ffff8000818aba90 [ 0.113682] x29: ffff8000818aba90 x28: ffff0000c0d96450 x27: ffff0000c0d96440 [ 0.113699] x26: 0000000000000014 x25: 0000000000051000 x24: ffff0000c0ad6480 [ 0.113714] x23: ffff0000c0d96200 x22: ffff800080fae558 x21: 00000000000001e0 [ 0.113730] x20: ffff0000c0b11c10 x19: ffff8000815ae6f0 x18: 0000000000000006 [ 0.113745] x17: ffff800081765368 x16: 0000000000000000 x15: 0765076507720766 [ 0.113760] x14: ffff8000816a3ea0 x13: 0765076507720766 x12: 072d077207650774 [ 0.113776] x11: ffff8000816a3ea0 x10: 00000000000000ce x9 : ffff8000816fbea0 [ 0.113791] x8 : 0000000000017fe8 x7 : 00000000fffff000 x6 : ffff8000816fbea0 [ 0.113806] x5 : 80000000fffff000 x4 : 0000000000000000 x3 : 0000000000000000 [ 0.113821] x2 : 0000000000000000 x1 : 0000000000000000 x0 : ffff0000c0158000 [ 0.113837] Call trace: [ 0.113845] refcount_warn_saturate+0x120/0x144 (P) [ 0.113859] rzv2h_cpg_probe+0x7f8/0xa38 [ 0.113874] platform_probe+0x68/0xdc [ 0.113890] really_probe+0xbc/0x2c0 [ 0.113901] __driver_probe_device+0x78/0x120 [ 0.113912] driver_probe_device+0x3c/0x154 [ 0.113923] __driver_attach+0x90/0x1a0 [ 0.113933] bus_for_each_dev+0x7c/0xe0 [ 0.113944] driver_attach+0x24/0x30 [ 0.113954] bus_add_driver+0xe4/0x208 [ 0.113965] driver_register+0x68/0x124 [ 0.113975] __platform_driver_probe+0x54/0xd4 [ 0.113987] rzv2h_cpg_init+0x24/0x30 [ 0.113998] do_one_initcall+0x60/0x1d4 [ 0.114013] kernel_init_freeable+0x214/0x278 [ 0.114028] kernel_init+0x20/0x140 [ 0.114041] ret_from_fork+0x10/0x20 [ 0.114052] ---[ end trace 0000000000000000 ]--- Resolve this by checking the `ref_cnt` value before calling `refcount_inc()`. If `ref_cnt` is 0, reset it to 1 using `refcount_set()`. Fixes: 7bd4cb3d6b7c ("clk: renesas: rzv2h: Add MSTOP support") Signed-off-by: Lad Prabhakar Reviewed-by: Geert Uytterhoeven --- v2->v3 - Included RB tag from Geert v1->v2 - Updated commit description - Updated fixes tag commit header --- drivers/clk/renesas/rzv2h-cpg.c | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/drivers/clk/renesas/rzv2h-cpg.c b/drivers/clk/renesas/rzv2h-cpg.c index 668a2880b2d3..23c89b0de38a 100644 --- a/drivers/clk/renesas/rzv2h-cpg.c +++ b/drivers/clk/renesas/rzv2h-cpg.c @@ -565,8 +565,12 @@ static struct rzv2h_mstop continue; if (BUS_MSTOP(clk->mstop->idx, clk->mstop->mask) == mstop_data) { - if (rzv2h_mod_clock_is_enabled(&clock->hw)) - refcount_inc(&clk->mstop->ref_cnt); + if (rzv2h_mod_clock_is_enabled(&clock->hw)) { + if (refcount_read(&clk->mstop->ref_cnt)) + refcount_inc(&clk->mstop->ref_cnt); + else + refcount_set(&clk->mstop->ref_cnt, 1); + } return clk->mstop; } } From patchwork Thu Jan 2 18:18:35 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Lad, Prabhakar" X-Patchwork-Id: 13924739 X-Patchwork-Delegate: geert@linux-m68k.org Received: from mail-wm1-f50.google.com (mail-wm1-f50.google.com [209.85.128.50]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 6EDC0188596; Thu, 2 Jan 2025 18:18:51 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.50 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841933; cv=none; b=QA2ZbcQjnL70wqp7VbdnjDe2LKl1zBcA9EbUx39znWi/VfkAOcvi/8S153Jvtai/+0P8wyF3JdbHsCU0rhPYyPe9mAxbGrHlr3PRAUSbC2X4YlCQyigb+d6WkVH7BYatFqqgDxOkT27AHeFifeLSontOzR/U0akh15IA51ngZ5g= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841933; c=relaxed/simple; bh=ZSo94qHiMehA9YL1TEdJYICeakm1X0RTS6YmBtreBjA=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=fC+AxtIweELBj/y8lp/02rNwNB9nDcy0YwatLOmuy5AKpSQpe19kcJ9JDHtdLIUMyL0HC2LBCVWKAObSOOCvARTaKJ3/6jWbWfUKg2qoQfv7EAtQS06uXKoNSckVBPs/TGu0H8xZLNeFwP/uUh+b7MJJv02h+/KlLW+r8m+ThLw= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=FtAwlAa+; arc=none smtp.client-ip=209.85.128.50 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="FtAwlAa+" Received: by mail-wm1-f50.google.com with SMTP id 5b1f17b1804b1-4361e89b6daso79234475e9.3; Thu, 02 Jan 2025 10:18:51 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1735841930; x=1736446730; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=q0+JLrW5DLnjAHxth74m+OnybyFYzKU3YKVZKXvyhr8=; b=FtAwlAa+KwMPM4ozkOJtGdYl+du5DNKlvIPzrVn0wc8nZQRa/jBzZdVbK5ElRz4aHP lKCr6NYN3VIore52/GL1Ay6vgRiTMFSJTAO4BODikNJT9Pe/JDRLiTRzcYCv3rFTIG9r CFIdsFQTIvZD/NEeub177ydVc2EZiRLOJY8EPyeExkcHbv7p/S+1GoMfrFIrY5yLNyuF Rh++v+DpKvwRhKYQdLBNCKtj+hM2vp9/En0g9Sxn/5Ftyx+GTn0+qSd4fLSCnseCj+6z nzksILvy9KmkjBf8X6YUT3KtaXhaizt7gGr/HwdTjmdC4DNFNiRrXT1LK4Dl5LxHCsFv 7SXQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1735841930; x=1736446730; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=q0+JLrW5DLnjAHxth74m+OnybyFYzKU3YKVZKXvyhr8=; b=mue4NhqEcXqSq5Yfq6oUiXrkBL/2CYs/cwvS9I5Cy5TddxtZbBnaeszrl5XRqzlKfN YswCOENN8b+OXvIKXmCCWDxupHDOgB48wIS7KTDsDt8Fp8loOEu7liJ88i+CN3aC/TGq LYkvVcFRTVewoIqBtz7Omfg17g4OmFhe5OKKCY544BdDKVfj8pZolkgBLmIJMI33Q2D+ EVy3Fb4cIECOz4VQ93gHJBeT+ObQAQT0VQZFYmld2FRqutBC7wwtrDD4WZrXDUpA3B5N veikTOL4uSA3M2HQhWQv8knDJy9KYLj8JHR/oob0ZnUhcOG6OOm/nGJorhvAE05BPmhy myGw== X-Forwarded-Encrypted: i=1; AJvYcCUSeBkeTcpFlwJN4qKFcMc83KepgGh4hlWtvyhz6Fwo/Q0r16s2Ky0BTgZMRtW8yDlY7ABZGKKUwPOPSDhU@vger.kernel.org, AJvYcCVxh5gsshDzZx6lh77yeA+deMRAVXpD4X+ml657x/PGaa/yka9jm0RL3GaYOq65ncWdhBEPBjdNTtA=@vger.kernel.org X-Gm-Message-State: AOJu0Yx/I8uKdsPLfJcrQezgoGH2QZZkfGQXzeJwM1dWHNVTFybMbWVl MPQjz4dnlTxGsjCnssjoIiIZOOuGnCA6tRZ5TN/B360x4n22U6NIi+GzPg== X-Gm-Gg: ASbGncvTW+Z6kZVb7T4X+XYsuTzA/dUaUASnauel7BojJ/znuyBXMQYB+dUGpkLZYdo YCJZ9d9qr0op/x0MnqAgAjdoyDMX8GyG1ETlh4Gmuuh4m4bJDrAa3Ds7c4EIqR1oXCx5kYMAZpI vaSKpQ01LDuSzTlCPKrUVjt/tGQ+RsEnYj4h1XRNpP9OIeEHyHVuUoj38OnsrtkRy5uqJcarZom 8AQe3Qxr+UbawUm5UgcrkKYQb4WI38IYovocHkYcqj0tOvRgwuioFlWTpfwcKeB1E5TDYlsJcS8 Xfh3LTM50w== X-Google-Smtp-Source: AGHT+IGZ/F/4VOijh17y1ntXU7fmXNTrz/uGpVCJ6UqXE+SrXZ5z+HxfJS3znSdnKNVvkY2ucRkr1A== X-Received: by 2002:a05:600c:5246:b0:42c:bb96:340e with SMTP id 5b1f17b1804b1-43668b7857amr428349845e9.31.1735841929730; Thu, 02 Jan 2025 10:18:49 -0800 (PST) Received: from prasmi.Home ([2a06:5906:61b:2d00:84e9:7adb:b646:c9c0]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-43656af6cbbsm493291925e9.3.2025.01.02.10.18.48 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Jan 2025 10:18:49 -0800 (PST) From: Prabhakar X-Google-Original-From: Prabhakar To: Geert Uytterhoeven , Michael Turquette , Stephen Boyd Cc: linux-renesas-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org, Prabhakar , Biju Das , Fabrizio Castro , Lad Prabhakar Subject: [PATCH v3 2/6] clk: renesas: rzv2h: Relocate MSTOP-related macros to the family driver Date: Thu, 2 Jan 2025 18:18:35 +0000 Message-ID: <20250102181839.352599-3-prabhakar.mahadev-lad.rj@bp.renesas.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> References: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> Precedence: bulk X-Mailing-List: linux-renesas-soc@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 From: Lad Prabhakar The `CPG_BUS_1_MSTOP` and `CPG_BUS_MSTOP` macros are exclusively used by the RZ/V2H(P) CPG family driver and are not required in the SoC-specific clock driver. Signed-off-by: Lad Prabhakar Reviewed-by: Geert Uytterhoeven --- v2->v3 - Included RB tag from Geert v1->v2 - None --- drivers/clk/renesas/rzv2h-cpg.c | 3 +++ drivers/clk/renesas/rzv2h-cpg.h | 3 --- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/drivers/clk/renesas/rzv2h-cpg.c b/drivers/clk/renesas/rzv2h-cpg.c index 23c89b0de38a..38edddfc42d9 100644 --- a/drivers/clk/renesas/rzv2h-cpg.c +++ b/drivers/clk/renesas/rzv2h-cpg.c @@ -41,6 +41,9 @@ #define GET_RST_OFFSET(x) (0x900 + ((x) * 4)) #define GET_RST_MON_OFFSET(x) (0xA00 + ((x) * 4)) +#define CPG_BUS_1_MSTOP (0xd00) +#define CPG_BUS_MSTOP(m) (CPG_BUS_1_MSTOP + ((m) - 1) * 4) + #define KDIV(val) ((s16)FIELD_GET(GENMASK(31, 16), (val))) #define MDIV(val) FIELD_GET(GENMASK(15, 6), (val)) #define PDIV(val) FIELD_GET(GENMASK(5, 0), (val)) diff --git a/drivers/clk/renesas/rzv2h-cpg.h b/drivers/clk/renesas/rzv2h-cpg.h index 9be5a312fa96..810275eba473 100644 --- a/drivers/clk/renesas/rzv2h-cpg.h +++ b/drivers/clk/renesas/rzv2h-cpg.h @@ -35,7 +35,6 @@ struct ddiv { #define CPG_CDDIV1 (0x404) #define CPG_CDDIV3 (0x40C) #define CPG_CDDIV4 (0x410) -#define CPG_BUS_1_MSTOP (0xd00) #define CDDIV0_DIVCTL2 DDIV_PACK(CPG_CDDIV0, 8, 3, 2) #define CDDIV1_DIVCTL0 DDIV_PACK(CPG_CDDIV1, 0, 2, 4) @@ -47,8 +46,6 @@ struct ddiv { #define CDDIV4_DIVCTL1 DDIV_PACK(CPG_CDDIV4, 4, 1, 17) #define CDDIV4_DIVCTL2 DDIV_PACK(CPG_CDDIV4, 8, 1, 18) -#define CPG_BUS_MSTOP(m) (CPG_BUS_1_MSTOP + ((m) - 1) * 4) - #define BUS_MSTOP(idx, mask) (((idx) & 0xffff) << 16 | (mask)) #define BUS_MSTOP_NONE GENMASK(31, 0) From patchwork Thu Jan 2 18:18:36 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Lad, Prabhakar" X-Patchwork-Id: 13924740 X-Patchwork-Delegate: geert@linux-m68k.org Received: from mail-wm1-f50.google.com (mail-wm1-f50.google.com [209.85.128.50]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 5394C1922DD; Thu, 2 Jan 2025 18:18:52 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.50 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841934; cv=none; b=C88dsX3NrzfdwEJu6209ILlhJDuEsZSErS05AcqIpSjHMD6kJtHHKdZTvfCcc3EaliEYPQB54CHoUtPmQJ3zqpABL569/i2Ke8qZCVQA2tpBwavjpCmQy7Vat7O7UwuByWoMR9rY3p8KXGvv8ALs/J3U5pxadQzatHQ3I/tZCI0= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841934; c=relaxed/simple; bh=NJrckm+X0jY7m27sv5LtekG5oeOI7Lx4lnBR9Gj0Z5I=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=F7xB3eNy6mQdOV/hWvTLeecc/GDt53HA/LzVoNMfFYqkj6M/LTKnbaPa7Bqaj5rGAvdidFsl809FFSiBquRUAx4qpJfaSwkuKe4dJJVY9Mi8uKSGJbYt/FSpe3kB4yHdzIr2Weg0VENS3iNpBRIybwNobOPmdm9FKydnuSQcKiI= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=UTXxq/pF; arc=none smtp.client-ip=209.85.128.50 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="UTXxq/pF" Received: by mail-wm1-f50.google.com with SMTP id 5b1f17b1804b1-43626213fffso73896035e9.1; Thu, 02 Jan 2025 10:18:51 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1735841930; x=1736446730; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=tVpezAOIY8u7O4nqWlwsaNhzAHGIf1UMTuZ4EeLwVkg=; b=UTXxq/pFGTNBAQgmvXR7ULGRVtcy+F+Lj4pRRmzrKdv950ScIgcRVhTd1AablyGYUU VsATu05asFo0DCh32K/fxpNz4cid0PE1FgggP0swqkTL5tsc99rkh93QvxjE64jDw+v+ ywkbVewKFDAJJx+6rSD+8gtjVcaMP+IM2BcNq5baeXaBmVmzA57pucHMdBxJMbrd8iHv 3TzWMfZf0+EkznT8Nvzj5sFjUNxjCyf4mpbSEyUi6rdmhZf2a+qrTp69P5MlJYDZXymo i78cAXD6H2DeyG1LNi2dX1PjKZXRJu/1CEUlO/OOWtkh2ijnhVLWEVyW4iko0cF8QdIE ldyg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1735841930; x=1736446730; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=tVpezAOIY8u7O4nqWlwsaNhzAHGIf1UMTuZ4EeLwVkg=; b=uTiQxyTS2NYJoJlXXBEv/4bGMx1g4gWk6poKzLd3ivOVoHte9da5Lj0XmdjR4Uja2B vJckRiKd6SuXpJN5ne/vVI3eotK4tlC86wNi+8ICKsCq0dWNk//Ws76z5O8xE+FqIP0O 0Vpp5fjCPSWEr7MIVIOGesbnjDQX55VkPuzYM2/3KNERiGY/fiVcxalPzxktDLVm/JK4 NRDytLd5DPgRcMolQ2Fw9CAxLozOzTiVurgMgqdEciH2TJW/v7qk/43jRRSc0MMXGBGu x5yAVJzICeav2GexAgn2g51LPtZAIvXYWA9vJXAlh+eo0MeSXKny9fiNZMMtRRH2ATrN uTcQ== X-Forwarded-Encrypted: i=1; AJvYcCWAdYPx2827az8FYVouxtxzL6S+jaGoW95gewouzl0R+85x3ajpGq0Nrkhnp9MBz35A9d0ornLhPKgN2aMq@vger.kernel.org, AJvYcCWLn3OwsFQ9Vhveke8L3gARNuMiu0F7vStmmAd2f2be97ZZ3HZ2F7sDkJk7Zdy0o8PE4kCVh0QXPUo=@vger.kernel.org X-Gm-Message-State: AOJu0Yyr6qeTUo1kout8oIPUpWQBu4jIM8ZCsM5Cus9efzsKFwEUWdys pWV6OlJdwtOZQXuVtDjbVgnIYe4K6pkzfsIZWXoDpm6voowUjIz4 X-Gm-Gg: ASbGncu0Bur6IHb1OUoXxPC7EgYFVE3XFcdUYLez1oy6KRjIPefau73VNXOR+sCrx69 OERR8Abmg2QqqY9/unYce5InFkmKkj6CF+uFMj90L8/TEXr2gIRAr9/v8aM+p9FTEeyHKf56Br+ SMtNJ/WrH0aRnyiP/n6OHISoKri3I7/4ODn8fyrqUyqGvyr7OaK+V0l3feKFbRA9yrYK9N0wAyn Qnxq6R34uZjPq31+nCGZ0iH5PKwLGSWHFQL9GQp+rgKE/Hyxl7jVhHfui0Cm6aswX27k8bmo/tb kpaKxNnDJw== X-Google-Smtp-Source: AGHT+IHy4mAkEjD3wCssYhb67xfcfDIZcOH5dDqmz0MfWDAzYkvyun9MvRmStc8mFIYES8k3qg2rdQ== X-Received: by 2002:a5d:6d03:0:b0:386:3213:5b80 with SMTP id ffacd0b85a97d-38a1a274920mr40851699f8f.24.1735841930544; Thu, 02 Jan 2025 10:18:50 -0800 (PST) Received: from prasmi.Home ([2a06:5906:61b:2d00:84e9:7adb:b646:c9c0]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-43656af6cbbsm493291925e9.3.2025.01.02.10.18.49 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Jan 2025 10:18:50 -0800 (PST) From: Prabhakar X-Google-Original-From: Prabhakar To: Geert Uytterhoeven , Michael Turquette , Stephen Boyd Cc: linux-renesas-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org, Prabhakar , Biju Das , Fabrizio Castro , Lad Prabhakar Subject: [PATCH v3 3/6] clk: renesas: rzv2h: Simplify BUS_MSTOP macros and field extraction Date: Thu, 2 Jan 2025 18:18:36 +0000 Message-ID: <20250102181839.352599-4-prabhakar.mahadev-lad.rj@bp.renesas.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> References: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> Precedence: bulk X-Mailing-List: linux-renesas-soc@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 From: Lad Prabhakar Replace manual bit manipulation in `BUS_MSTOP` with `FIELD_PREP_CONST` and `FIELD_GET` macros for better clarity and maintainability. Introduce explicit masks (`BUS_MSTOP_IDX_MASK`, `BUS_MSTOP_BITS_MASK`) to improve readability. Signed-off-by: Lad Prabhakar Reviewed-by: Geert Uytterhoeven --- v2->v3 - Dropped unnecessary parentheses - Included RB tag from Geert v1->v2 - None --- drivers/clk/renesas/rzv2h-cpg.c | 4 ++-- drivers/clk/renesas/rzv2h-cpg.h | 5 ++++- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/drivers/clk/renesas/rzv2h-cpg.c b/drivers/clk/renesas/rzv2h-cpg.c index 38edddfc42d9..23fb209d3232 100644 --- a/drivers/clk/renesas/rzv2h-cpg.c +++ b/drivers/clk/renesas/rzv2h-cpg.c @@ -582,8 +582,8 @@ static struct rzv2h_mstop if (!mstop) return NULL; - mstop->idx = (mstop_data >> 16) & 0xffff; - mstop->mask = mstop_data & 0xffff; + mstop->idx = FIELD_GET(BUS_MSTOP_IDX_MASK, mstop_data); + mstop->mask = FIELD_GET(BUS_MSTOP_BITS_MASK, mstop_data); if (rzv2h_mod_clock_is_enabled(&clock->hw)) refcount_set(&mstop->ref_cnt, 1); else diff --git a/drivers/clk/renesas/rzv2h-cpg.h b/drivers/clk/renesas/rzv2h-cpg.h index 810275eba473..f918620c4650 100644 --- a/drivers/clk/renesas/rzv2h-cpg.h +++ b/drivers/clk/renesas/rzv2h-cpg.h @@ -46,7 +46,10 @@ struct ddiv { #define CDDIV4_DIVCTL1 DDIV_PACK(CPG_CDDIV4, 4, 1, 17) #define CDDIV4_DIVCTL2 DDIV_PACK(CPG_CDDIV4, 8, 1, 18) -#define BUS_MSTOP(idx, mask) (((idx) & 0xffff) << 16 | (mask)) +#define BUS_MSTOP_IDX_MASK GENMASK(31, 16) +#define BUS_MSTOP_BITS_MASK GENMASK(15, 0) +#define BUS_MSTOP(idx, mask) (FIELD_PREP_CONST(BUS_MSTOP_IDX_MASK, (idx)) | \ + FIELD_PREP_CONST(BUS_MSTOP_BITS_MASK, (mask))) #define BUS_MSTOP_NONE GENMASK(31, 0) /** From patchwork Thu Jan 2 18:18:37 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Lad, Prabhakar" X-Patchwork-Id: 13924780 X-Patchwork-Delegate: geert@linux-m68k.org Received: from mail-wm1-f43.google.com (mail-wm1-f43.google.com [209.85.128.43]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 30CAB1B4128; Thu, 2 Jan 2025 18:18:53 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.43 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841936; cv=none; b=ZxlGehUomdBq5CHKPBBBNhJKZSXjnMjRpBJCe+aOy6arWjjLaJesIDUVXiXmSYvATr0Zu0E+IQ3ThqwZmGyJEsQHvkhhZ0Cue405aZspwmv3PtISCsSEEcLyN2B4QnZArF9xwOojKnYM8YzkTt9HmvqTLC5yqbVyRS0ZlmxQXyI= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841936; c=relaxed/simple; bh=D6NR7+lE0Olhkdz1KjttTYXISwJwgHV81pUVtekEvfM=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=t7oRNeuWYY29nugISChElMDLAij/M0OgSmzevVfJlYXXBcmYayzhLyWMXoN0uRZNsv0a1na6OmZat9WK7k3DCv5i21a+QdO4K6z9KvFBBDiJH8xteY11KHmVj1SghVsI6xLaXF6j9+yWgwmfn7wRpccyBEllST3YEFZfy+6jVzY= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=JTWCHQir; arc=none smtp.client-ip=209.85.128.43 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="JTWCHQir" Received: by mail-wm1-f43.google.com with SMTP id 5b1f17b1804b1-436a39e4891so28393605e9.1; Thu, 02 Jan 2025 10:18:53 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1735841932; x=1736446732; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=NFsyeZ2ZqXf9GNuav8SYMOiYdjreplqm9Nxe79T96Ig=; b=JTWCHQirLEKTj0R6cYqLuHZP3HEh8u4ayJ0G8Jib4fvGaTcMQXlqEDnfXmULzR4zde Raa/SYMm17F/gfU9PIv27/e+tLV4aQwvrZCC9CHRSzAnvgftIifZPMWa52pywMpfV8R/ +2eiv/eLPamAnZwXeXbpSffwBTznaeXRJBKUmPKVYY0MhFC/c4fxHUoQDC5koOIFcEWe +bke8EYHmqT3FbGGrFCbbvNcOj1k8hhrNpa5eOawcEvUI/OpgxlJcw7Qb1TbYF3sz22n wjcUXjeRUo6zgX/l4QT6yVhDuTovhO5ic6quIsD6ay30fkvswEF1AO/hgLU2ECyJZ8HF NnWw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1735841932; x=1736446732; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=NFsyeZ2ZqXf9GNuav8SYMOiYdjreplqm9Nxe79T96Ig=; b=Yb244H5FwLhPH2Tt8tGw0WoeaObHIdKa4oZAuaHEIVhhCB6qtqANwGsXP7g7Z7AjCp oWi4GEE8GCgGN+IWMIDLW4dYIFIOey5zvUeur0h/AX7ogdr+mdnqumgixTPV7W6e1/rS 1arAS/yqbHOVUGOAts8Cp0NVj/ymzO6nsxYLvBGwBxv9JubT4n9WG7F9+31fIcZtLhiZ ccbSFy+tFQkfaaHS9eM1DCfBMc4QbnzmqFKLmv/ZT8w07e+fomi0PAWgHQ/89I2Q5pSE BRHIG/rPZh1moRa4IJLUV+L3U2KbcinJvApGHhOFYWfGzA1wnmfsWsnSEe5FDRMKwlr6 xFoQ== X-Forwarded-Encrypted: i=1; AJvYcCW1kKf8npneQv860ExCJ//wxDt+/XDpRNmEAfKha4bdz9vwjKdYhcUOOBvfouyfnZeFZC9a76ZdKvA=@vger.kernel.org, AJvYcCXTIvQKS3glbbTeCPMeBtH+E7Xz/2QCJYfaf94GaP0TXfyhZNBoJsTx2ZJepP/lg4CJOuJl0YLhDS8McmMx@vger.kernel.org X-Gm-Message-State: AOJu0YwWaoaWSWUOihrRfrxG7jNfQ40wtVLd+DVCoZivQjeim43rBzUq qQgWB2z8K8cpszyfx6m91A301HtgtTZ8xzvHvSOU7HiVjc8lKWgs X-Gm-Gg: ASbGncs9y2YhUwF2KrMDZXbDPadbNVAdFxJz7Dmjf4Ux9dQ8+U3HFiDN5wlg/OICcEU QREyr65gBnyS/ZVygBQqApFpAx6HTeyu9h0ubXTIHBTRX+Uy9zAmDCvbvnTQoZGVLpkIe0v2rtN abxMvvMip8ELfT+3CmkU76bYcfvGFKw4QH/kKxSuUhzuCbZh8OZGl39Yfaruj8lqDSEUUQbxsCq TtRhKTw/ke1YZiE4jA3kEdoxxwH+pgiCJa/P9oiO8WBTsDycx9Ost0imsUPL8O2g4iFSMt9btXz UHRqEC3a/A== X-Google-Smtp-Source: AGHT+IFcgQaOcZ3bVZEsxgVHkZnb030SmH2AaWY0tmHI3uMUq4FY+Ie37rApGvTi2+tG+5SASHksJQ== X-Received: by 2002:a05:600c:1c91:b0:434:f219:6b28 with SMTP id 5b1f17b1804b1-43668b499f6mr353550635e9.24.1735841932053; Thu, 02 Jan 2025 10:18:52 -0800 (PST) Received: from prasmi.Home ([2a06:5906:61b:2d00:84e9:7adb:b646:c9c0]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-43656af6cbbsm493291925e9.3.2025.01.02.10.18.50 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Jan 2025 10:18:50 -0800 (PST) From: Prabhakar X-Google-Original-From: Prabhakar To: Geert Uytterhoeven , Michael Turquette , Stephen Boyd Cc: linux-renesas-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org, Prabhakar , Biju Das , Fabrizio Castro , Lad Prabhakar Subject: [PATCH v3 4/6] clk: renesas: rzv2h: Switch MSTOP configuration to per-bit basis Date: Thu, 2 Jan 2025 18:18:37 +0000 Message-ID: <20250102181839.352599-5-prabhakar.mahadev-lad.rj@bp.renesas.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> References: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> Precedence: bulk X-Mailing-List: linux-renesas-soc@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 From: Lad Prabhakar Switch MSTOP handling from group-based to per-bit configuration to address issues with shared dependencies between module clocks. In the current group-based configuration, multiple module clocks may rely on a single MSTOP bit. When both clocks are turned ON and one is subsequently turned OFF, the shared MSTOP bit will still be set, which is incorrect since the other dependent module clock remains ON. By switching to a per-bit configuration, we ensure precise control over individual MSTOP bits, preventing such conflicts. Replace the refcount API with atomic operations for managing MSTOP bit counters. The refcount API requires explicitly setting the counter to `1` before calling `refcount_inc()`, which introduces potential edge cases and unnecessary complexity. Using atomic operations simplifies the logic and avoids such issues, resulting in cleaner and more maintainable code. Signed-off-by: Lad Prabhakar Reviewed-by: Geert Uytterhoeven --- v2->v3 - Dropped unnecessary parentheses - Switched using to devm_kcalloc() instead of devm_kmalloc_array() - Optimized check in rzv2h_mod_clock_endisable() if the states are same - Dropped GET_MSTOP_IDX() macro and handled indexing in the code - Made mstop_mask to unsigned long to avoid casting v1->v2 - None --- drivers/clk/renesas/r9a09g047-cpg.c | 2 + drivers/clk/renesas/r9a09g057-cpg.c | 2 + drivers/clk/renesas/rzv2h-cpg.c | 186 ++++++++++++++-------------- drivers/clk/renesas/rzv2h-cpg.h | 5 + 4 files changed, 104 insertions(+), 91 deletions(-) diff --git a/drivers/clk/renesas/r9a09g047-cpg.c b/drivers/clk/renesas/r9a09g047-cpg.c index 7945b9f95b95..536d922bed70 100644 --- a/drivers/clk/renesas/r9a09g047-cpg.c +++ b/drivers/clk/renesas/r9a09g047-cpg.c @@ -145,4 +145,6 @@ const struct rzv2h_cpg_info r9a09g047_cpg_info __initconst = { /* Resets */ .resets = r9a09g047_resets, .num_resets = ARRAY_SIZE(r9a09g047_resets), + + .num_mstop_bits = 208, }; diff --git a/drivers/clk/renesas/r9a09g057-cpg.c b/drivers/clk/renesas/r9a09g057-cpg.c index 59dadedb2217..a45b4020996b 100644 --- a/drivers/clk/renesas/r9a09g057-cpg.c +++ b/drivers/clk/renesas/r9a09g057-cpg.c @@ -275,4 +275,6 @@ const struct rzv2h_cpg_info r9a09g057_cpg_info __initconst = { /* Resets */ .resets = r9a09g057_resets, .num_resets = ARRAY_SIZE(r9a09g057_resets), + + .num_mstop_bits = 192, }; diff --git a/drivers/clk/renesas/rzv2h-cpg.c b/drivers/clk/renesas/rzv2h-cpg.c index 23fb209d3232..a4c1e92e1fd7 100644 --- a/drivers/clk/renesas/rzv2h-cpg.c +++ b/drivers/clk/renesas/rzv2h-cpg.c @@ -68,6 +68,7 @@ * @resets: Array of resets * @num_resets: Number of Module Resets in info->resets[] * @last_dt_core_clk: ID of the last Core Clock exported to DT + * @mstop_count: Array of mstop values * @rcdev: Reset controller entity */ struct rzv2h_cpg_priv { @@ -82,17 +83,13 @@ struct rzv2h_cpg_priv { unsigned int num_resets; unsigned int last_dt_core_clk; + atomic_t *mstop_count; + struct reset_controller_dev rcdev; }; #define rcdev_to_priv(x) container_of(x, struct rzv2h_cpg_priv, rcdev) -struct rzv2h_mstop { - u16 idx; - u16 mask; - refcount_t ref_cnt; -}; - struct pll_clk { struct rzv2h_cpg_priv *priv; void __iomem *base; @@ -107,7 +104,7 @@ struct pll_clk { * struct mod_clock - Module clock * * @priv: CPG private data - * @mstop: handle to cpg bus mstop data + * @mstop_data: mstop data relating to module clock * @hw: handle between common and hardware-specific interfaces * @no_pm: flag to indicate PM is not supported * @on_index: register offset @@ -117,7 +114,7 @@ struct pll_clk { */ struct mod_clock { struct rzv2h_cpg_priv *priv; - struct rzv2h_mstop *mstop; + unsigned int mstop_data; struct clk_hw hw; bool no_pm; u8 on_index; @@ -446,38 +443,70 @@ rzv2h_cpg_register_core_clk(const struct cpg_core_clk *core, } static void rzv2h_mod_clock_mstop_enable(struct rzv2h_cpg_priv *priv, - struct mod_clock *clock) + u32 mstop_data) { + unsigned long mstop_mask = FIELD_GET(BUS_MSTOP_BITS_MASK, mstop_data); + u16 mstop_index = FIELD_GET(BUS_MSTOP_IDX_MASK, mstop_data); + unsigned int index = (mstop_index - 1) * 16; + atomic_t *mstop = &priv->mstop_count[index]; unsigned long flags; - u32 val; + unsigned int i; + u32 val = 0; spin_lock_irqsave(&priv->rmw_lock, flags); - if (!refcount_read(&clock->mstop->ref_cnt)) { - val = clock->mstop->mask << 16; - writel(val, priv->base + CPG_BUS_MSTOP(clock->mstop->idx)); - refcount_set(&clock->mstop->ref_cnt, 1); - } else { - refcount_inc(&clock->mstop->ref_cnt); + for_each_set_bit(i, &mstop_mask, 16) { + if (!atomic_read(&mstop[i])) + val |= BIT(i) << 16; + atomic_inc(&mstop[i]); } + if (val) + writel(val, priv->base + CPG_BUS_MSTOP(mstop_index)); spin_unlock_irqrestore(&priv->rmw_lock, flags); } static void rzv2h_mod_clock_mstop_disable(struct rzv2h_cpg_priv *priv, - struct mod_clock *clock) + u32 mstop_data) { + unsigned long mstop_mask = FIELD_GET(BUS_MSTOP_BITS_MASK, mstop_data); + u16 mstop_index = FIELD_GET(BUS_MSTOP_IDX_MASK, mstop_data); + unsigned int index = (mstop_index - 1) * 16; + atomic_t *mstop = &priv->mstop_count[index]; unsigned long flags; - u32 val; + unsigned int i; + u32 val = 0; spin_lock_irqsave(&priv->rmw_lock, flags); - if (refcount_dec_and_test(&clock->mstop->ref_cnt)) { - val = clock->mstop->mask << 16 | clock->mstop->mask; - writel(val, priv->base + CPG_BUS_MSTOP(clock->mstop->idx)); + for_each_set_bit(i, &mstop_mask, 16) { + if (!atomic_read(&mstop[i]) || + atomic_dec_and_test(&mstop[i])) + val |= BIT(i) << 16 | BIT(i); } + if (val) + writel(val, priv->base + CPG_BUS_MSTOP(mstop_index)); spin_unlock_irqrestore(&priv->rmw_lock, flags); } +static int rzv2h_mod_clock_is_enabled(struct clk_hw *hw) +{ + struct mod_clock *clock = to_mod_clock(hw); + struct rzv2h_cpg_priv *priv = clock->priv; + u32 bitmask; + u32 offset; + + if (clock->mon_index >= 0) { + offset = GET_CLK_MON_OFFSET(clock->mon_index); + bitmask = BIT(clock->mon_bit); + } else { + offset = GET_CLK_ON_OFFSET(clock->on_index); + bitmask = BIT(clock->on_bit); + } + + return readl(priv->base + offset) & bitmask; +} + static int rzv2h_mod_clock_endisable(struct clk_hw *hw, bool enable) { + bool enabled = rzv2h_mod_clock_is_enabled(hw); struct mod_clock *clock = to_mod_clock(hw); unsigned int reg = GET_CLK_ON_OFFSET(clock->on_index); struct rzv2h_cpg_priv *priv = clock->priv; @@ -489,15 +518,18 @@ static int rzv2h_mod_clock_endisable(struct clk_hw *hw, bool enable) dev_dbg(dev, "CLK_ON 0x%x/%pC %s\n", reg, hw->clk, enable ? "ON" : "OFF"); + if (enabled == enable) + return 0; + value = bitmask << 16; if (enable) { value |= bitmask; writel(value, priv->base + reg); - if (clock->mstop) - rzv2h_mod_clock_mstop_enable(priv, clock); + if (clock->mstop_data != BUS_MSTOP_NONE) + rzv2h_mod_clock_mstop_enable(priv, clock->mstop_data); } else { - if (clock->mstop) - rzv2h_mod_clock_mstop_disable(priv, clock); + if (clock->mstop_data != BUS_MSTOP_NONE) + rzv2h_mod_clock_mstop_disable(priv, clock->mstop_data); writel(value, priv->base + reg); } @@ -525,73 +557,12 @@ static void rzv2h_mod_clock_disable(struct clk_hw *hw) rzv2h_mod_clock_endisable(hw, false); } -static int rzv2h_mod_clock_is_enabled(struct clk_hw *hw) -{ - struct mod_clock *clock = to_mod_clock(hw); - struct rzv2h_cpg_priv *priv = clock->priv; - u32 bitmask; - u32 offset; - - if (clock->mon_index >= 0) { - offset = GET_CLK_MON_OFFSET(clock->mon_index); - bitmask = BIT(clock->mon_bit); - } else { - offset = GET_CLK_ON_OFFSET(clock->on_index); - bitmask = BIT(clock->on_bit); - } - - return readl(priv->base + offset) & bitmask; -} - static const struct clk_ops rzv2h_mod_clock_ops = { .enable = rzv2h_mod_clock_enable, .disable = rzv2h_mod_clock_disable, .is_enabled = rzv2h_mod_clock_is_enabled, }; -static struct rzv2h_mstop -*rzv2h_cpg_get_mstop(struct rzv2h_cpg_priv *priv, struct mod_clock *clock, u32 mstop_data) -{ - struct rzv2h_mstop *mstop; - unsigned int i; - - for (i = 0; i < priv->num_mod_clks; i++) { - struct mod_clock *clk; - struct clk_hw *hw; - - if (priv->clks[priv->num_core_clks + i] == ERR_PTR(-ENOENT)) - continue; - - hw = __clk_get_hw(priv->clks[priv->num_core_clks + i]); - clk = to_mod_clock(hw); - if (!clk->mstop) - continue; - - if (BUS_MSTOP(clk->mstop->idx, clk->mstop->mask) == mstop_data) { - if (rzv2h_mod_clock_is_enabled(&clock->hw)) { - if (refcount_read(&clk->mstop->ref_cnt)) - refcount_inc(&clk->mstop->ref_cnt); - else - refcount_set(&clk->mstop->ref_cnt, 1); - } - return clk->mstop; - } - } - - mstop = devm_kzalloc(priv->dev, sizeof(*mstop), GFP_KERNEL); - if (!mstop) - return NULL; - - mstop->idx = FIELD_GET(BUS_MSTOP_IDX_MASK, mstop_data); - mstop->mask = FIELD_GET(BUS_MSTOP_BITS_MASK, mstop_data); - if (rzv2h_mod_clock_is_enabled(&clock->hw)) - refcount_set(&mstop->ref_cnt, 1); - else - refcount_set(&mstop->ref_cnt, 0); - - return mstop; -} - static void __init rzv2h_cpg_register_mod_clk(const struct rzv2h_mod_clk *mod, struct rzv2h_cpg_priv *priv) @@ -638,6 +609,7 @@ rzv2h_cpg_register_mod_clk(const struct rzv2h_mod_clk *mod, clock->no_pm = mod->no_pm; clock->priv = priv; clock->hw.init = &init; + clock->mstop_data = mod->mstop_data; ret = devm_clk_hw_register(dev, &clock->hw); if (ret) { @@ -647,12 +619,39 @@ rzv2h_cpg_register_mod_clk(const struct rzv2h_mod_clk *mod, priv->clks[id] = clock->hw.clk; - if (mod->mstop_data != BUS_MSTOP_NONE) { - clock->mstop = rzv2h_cpg_get_mstop(priv, clock, mod->mstop_data); - if (!clock->mstop) { - clk = ERR_PTR(-ENOMEM); - goto fail; + /* + * Ensure the module clocks and MSTOP bits are synchronized when they are + * turned ON by the bootloader. Enable MSTOP bits for module clocks that were + * turned ON in an earlier boot stage. + */ + if (clock->mstop_data != BUS_MSTOP_NONE && + !mod->critical && rzv2h_mod_clock_is_enabled(&clock->hw)) { + rzv2h_mod_clock_mstop_enable(priv, clock->mstop_data); + } else if (clock->mstop_data != BUS_MSTOP_NONE && mod->critical) { + unsigned long mstop_mask = FIELD_GET(BUS_MSTOP_BITS_MASK, clock->mstop_data); + u16 mstop_index = FIELD_GET(BUS_MSTOP_IDX_MASK, clock->mstop_data); + unsigned int index = (mstop_index - 1) * 16; + atomic_t *mstop = &priv->mstop_count[index]; + unsigned long flags; + unsigned int i; + u32 val = 0; + + /* + * Critical clocks are turned ON immediately upon registration, and the + * MSTOP counter is updated through the rzv2h_mod_clock_enable() path. + * However, if the critical clocks were already turned ON by the initial + * bootloader, synchronize the atomic counter here and clear the MSTOP bit. + */ + spin_lock_irqsave(&priv->rmw_lock, flags); + for_each_set_bit(i, &mstop_mask, 16) { + if (atomic_read(&mstop[i])) + continue; + val |= BIT(i) << 16; + atomic_inc(&mstop[i]); } + if (val) + writel(val, priv->base + CPG_BUS_MSTOP(mstop_index)); + spin_unlock_irqrestore(&priv->rmw_lock, flags); } return; @@ -922,6 +921,11 @@ static int __init rzv2h_cpg_probe(struct platform_device *pdev) if (!clks) return -ENOMEM; + priv->mstop_count = devm_kcalloc(dev, info->num_mstop_bits, + sizeof(*priv->mstop_count), GFP_KERNEL); + if (!priv->mstop_count) + return -ENOMEM; + priv->resets = devm_kmemdup(dev, info->resets, sizeof(*info->resets) * info->num_resets, GFP_KERNEL); if (!priv->resets) diff --git a/drivers/clk/renesas/rzv2h-cpg.h b/drivers/clk/renesas/rzv2h-cpg.h index f918620c4650..a772304f9057 100644 --- a/drivers/clk/renesas/rzv2h-cpg.h +++ b/drivers/clk/renesas/rzv2h-cpg.h @@ -193,6 +193,9 @@ struct rzv2h_reset { * * @resets: Array of Module Reset definitions * @num_resets: Number of entries in resets[] + * + * @num_mstop_bits: Maximum number of MSTOP bits supported, equivalent to the + * number of CPG_BUS_m_MSTOP registers multiplied by 16. */ struct rzv2h_cpg_info { /* Core Clocks */ @@ -209,6 +212,8 @@ struct rzv2h_cpg_info { /* Resets */ const struct rzv2h_reset *resets; unsigned int num_resets; + + unsigned int num_mstop_bits; }; extern const struct rzv2h_cpg_info r9a09g047_cpg_info; From patchwork Thu Jan 2 18:18:38 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Lad, Prabhakar" X-Patchwork-Id: 13924781 X-Patchwork-Delegate: geert@linux-m68k.org Received: from mail-wm1-f44.google.com (mail-wm1-f44.google.com [209.85.128.44]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 3598C1B4242; Thu, 2 Jan 2025 18:18:55 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.44 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841937; cv=none; b=pvt03nYy/7YWBEc1XyqTHKgx/I9dIrCiFAskrCvNtYE5owls5huM6soZAoe+/ZgDfU7Tk3Fw/qvGdwBK0D/RvNxKAiZoU5O7K26vSsuNuWWPpCuRsYaICNUGHWzozDFKv0xDFrEojl8J+dTNbncWcTe9Ax868CY/iDPN0njtUwE= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841937; c=relaxed/simple; bh=YWBalBfbLw05CwNO1Yu3YVQXfFIypEpMG6x9yovyN9g=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=m+NfMbYDWgVH0VvtihzhZNSDO/cj3cm0JQi88k/ZWVEviy4ybuhiAF0wyCozaHUItQdzq4mRLF1qapTEzjGpo+r+0ET+wzvJXMntwjuzjh/lcNWmycGVXdzPUIcnED1B/mqdh7hdRFLpIoD5zRr5am9L0xCkCI4OmzLU8unsk80= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=d4Z0lrPe; arc=none smtp.client-ip=209.85.128.44 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="d4Z0lrPe" Received: by mail-wm1-f44.google.com with SMTP id 5b1f17b1804b1-4363ae65100so120662625e9.0; Thu, 02 Jan 2025 10:18:55 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1735841934; x=1736446734; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=TML8pafkEldphvG9BXvPyEHI6XceyFa9xZsDrKzfCdc=; b=d4Z0lrPeR/iaqfPRCn//qL3P30WAZFCrRHCI0Vj/hQBBN015W3EpSPFDF3MBlif7ss h8/kkAXq+vOpXM2SXbnpk9wMvWLXR2zRSeQ5JjrEalzlt30KvoVmnL82AdIoFNGH8THl vkTYea5uJ9twmz5M/6hwO+yaqDzAo+6iANYQ8QhWZz2RPcdk1FiC+vMLVzKr87nGiKWx 3Jhfge+wxD4RZCISbNYo1yWr+nJjcAZNZbBnKCRsmmtqUprmpDVUoimMumxlyAjvOe0/ 8eToAc+OdgJ4RIhz5VKXK6Nj1PfuzVLPxUi/kWFe83Xz6gZA+q+fVHeJGDkAPWsN9VOP zdLg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1735841934; x=1736446734; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=TML8pafkEldphvG9BXvPyEHI6XceyFa9xZsDrKzfCdc=; b=d63YL+loR74YYNDT2BS2xMEUA5Ntk/s7FQsCm/QAyGJwAxFn+g3bQDv1E73c2Zkw+v 59I07zX5W6lusunXsXWcuNqE1AtZSSTdxy8yDHrM2dxD51UZXI+7PQfIpjvZdLYJ7hoV YDfmLb1NRrEOON3ORQ2ys4oE97q0mwx60ja6RvZAhmx7ktGGVSkbGqITrVcOxjoKiKbB Rwyqr84wjNEvIMOmZVujniXdkobScEb7ECcUVBgowaFZYwkFHOcoC3F7TVaz3eMpkFH+ dzE4Wbz1bM03O2csUCUMmKPP+HW139FAI6odzZ56AmAy/BRKRgqTJPKvhsO4DPshQleL bepA== X-Forwarded-Encrypted: i=1; AJvYcCWc5XTIvQ34vnyafHk5nK+YkOtPBKTfhaKohD0TN8K3okkcY+qGq9+y/gxHnwg2w5XE37m4q/CVOOdoQSMy@vger.kernel.org, AJvYcCWoGsvByDd337ftNFMRNUA3c/Qm1esaJtG0Zvae+uY5wupSSUGeOVR9x/tkivHJQakGeQKnk8IT12U=@vger.kernel.org X-Gm-Message-State: AOJu0Yw2HBgcALgGFt+xJ2CEkGQZsS08GhmEdh8C4fq7nQW+PBrDnoR0 1AIbyyEM0aGYzp8y5v83O7mTgPwCX5l7PkllPDkVGoon18i+QoDn X-Gm-Gg: ASbGncta2+m+E0zzcHrQocQ9ulcHjumAcUIo3OwbUuhTNVQ/xNKTqRpfdQBd3u2HMth ymmtMmgXglybCbpo5f+78jPmjlVjCPXr+/JjuUoMuKhFNmR9FBPrsZX8aqZ1FigmxAzlSCTSCpm Px7A+wwfiAOSsIeKmBCHE9f2OR8RUt17xnz1EVrCY4GhQnn8MALLG1RiBMvr5jApNCGPCIsCmcL IQjcXfD9bFXJcqtWa93hZzjBUqddnj0F8j7eEZ9/Wr2AZOwiuXR1BEOAeqxx3WHxB1n+jYON953 bH7ueyyrig== X-Google-Smtp-Source: AGHT+IHYPHGwvX2Cyf3fV8kygAWfC0zV+G6bMCi/dII6Oj6ZIRRLxZzNO0VpytKFwEuYYYaFGlvJqg== X-Received: by 2002:a05:600c:198c:b0:431:542d:2599 with SMTP id 5b1f17b1804b1-43668a3a3cfmr385115105e9.22.1735841932906; Thu, 02 Jan 2025 10:18:52 -0800 (PST) Received: from prasmi.Home ([2a06:5906:61b:2d00:84e9:7adb:b646:c9c0]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-43656af6cbbsm493291925e9.3.2025.01.02.10.18.52 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Jan 2025 10:18:52 -0800 (PST) From: Prabhakar X-Google-Original-From: Prabhakar To: Geert Uytterhoeven , Michael Turquette , Stephen Boyd Cc: linux-renesas-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org, Prabhakar , Biju Das , Fabrizio Castro , Lad Prabhakar Subject: [PATCH v3 5/6] clk: renesas: r9a09g057: Add reset entry for SYS Date: Thu, 2 Jan 2025 18:18:38 +0000 Message-ID: <20250102181839.352599-6-prabhakar.mahadev-lad.rj@bp.renesas.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> References: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> Precedence: bulk X-Mailing-List: linux-renesas-soc@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 From: Lad Prabhakar Add the missing reset entry for the `SYS` module in the clock driver. The corresponding core clock entry for `SYS` is already present. Signed-off-by: Lad Prabhakar Reviewed-by: Geert Uytterhoeven --- v2->v3 - Included RB tag from Geert v1->v2 - None --- drivers/clk/renesas/r9a09g057-cpg.c | 1 + 1 file changed, 1 insertion(+) diff --git a/drivers/clk/renesas/r9a09g057-cpg.c b/drivers/clk/renesas/r9a09g057-cpg.c index a45b4020996b..7ef681dfcba5 100644 --- a/drivers/clk/renesas/r9a09g057-cpg.c +++ b/drivers/clk/renesas/r9a09g057-cpg.c @@ -220,6 +220,7 @@ static const struct rzv2h_mod_clk r9a09g057_mod_clks[] __initconst = { }; static const struct rzv2h_reset r9a09g057_resets[] __initconst = { + DEF_RST(3, 0, 1, 1), /* SYS_0_PRESETN */ DEF_RST(3, 6, 1, 7), /* ICU_0_PRESETN_I */ DEF_RST(6, 13, 2, 30), /* GTM_0_PRESETZ */ DEF_RST(6, 14, 2, 31), /* GTM_1_PRESETZ */ From patchwork Thu Jan 2 18:18:39 2025 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Lad, Prabhakar" X-Patchwork-Id: 13924782 X-Patchwork-Delegate: geert@linux-m68k.org Received: from mail-wm1-f51.google.com (mail-wm1-f51.google.com [209.85.128.51]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 708621B4245; Thu, 2 Jan 2025 18:18:56 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=none smtp.client-ip=209.85.128.51 ARC-Seal: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841938; cv=none; b=PE8XCIJHCwqz9sG/KE/kYv43vjy48VL8owZ0hVMo6BtKkP3LwOufSVjcSoZiPDPobV6saXz6dVl+Xp/gduVpXBXLQvVRbHe3fENLx9mIhBdCj97vRbt8PvhZ4XfaXhiNNXtj8DL0IA+xpNvFPFUj9XjNLaQ2D25Jz3vz9MLgsUc= ARC-Message-Signature: i=1; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735841938; c=relaxed/simple; bh=n+waWRDwlWy9TC6uXDWXKs5D4sPMvcPJkXcJ1csNOiI=; h=From:To:Cc:Subject:Date:Message-ID:In-Reply-To:References: MIME-Version; b=mHe9hf/BVS/FaNgo1/cXSfmTMWUkVjXZQVI1HF/vy426dS9knCy1yCSik9ljLzQEXidG29czXythouLAByPcDA51x+wzWC2eKURlHltxD25gbqrUqjS2gsdtrtQK6ESn08gxG+AHhmd+xGM5iH8x+Oiu2zZEQ14HazduPeoztwA= ARC-Authentication-Results: i=1; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com; spf=pass smtp.mailfrom=gmail.com; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b=LCRe+hBE; arc=none smtp.client-ip=209.85.128.51 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=gmail.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=gmail.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="LCRe+hBE" Received: by mail-wm1-f51.google.com with SMTP id 5b1f17b1804b1-43634b570c1so83495645e9.0; Thu, 02 Jan 2025 10:18:56 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20230601; t=1735841935; x=1736446735; darn=vger.kernel.org; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:from:to:cc:subject:date :message-id:reply-to; bh=A0Qe4ppfMb0zVlMFJxlO8X1Mm4KvjWS+KLYaYeS1TX8=; b=LCRe+hBEI2gvCTS/jss3ELht7m08bVU2yQgc6vE8vzI0wThGipCYPsRmCD0hXfes9M l7mYvFT9+Lpedd8mf7bJJaAxGyWs/qW9AE1EALSzdll0dhljaOYXMzqkdQF61P/XgWA3 U4LdVjCgBvKm3xxOV4o9DMl2ZRD1Equ826SQNAm9IsctYdkJP2JlzbD1SqR6nwVcEhdD CY+IKhIa2jb2OvexiTgMZPxUkHLwHpzaC7YpUNOK4dqdvgivVvIuK/wRpX+u2vzKThnT V00L/2xiwa0x9BPHNPtQ6XnqOCXt3MSLBngfvNhXtKJcUsPHUD41bioYAWii9Mn8Y93U V6rQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20230601; t=1735841935; x=1736446735; h=content-transfer-encoding:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:x-gm-message-state:from:to:cc :subject:date:message-id:reply-to; bh=A0Qe4ppfMb0zVlMFJxlO8X1Mm4KvjWS+KLYaYeS1TX8=; b=CsDJhgNcSe3EKW0uDk7jaMBR73zzCT8eD7+ZSxjC3GOXYVcvai/GnzwbexVyeGIEPE TRsXCGzjAxoNypbAlmgwLBKv6ir4qhyvIdpHx6GHEa5AEua2xP/IBHZNbhoaNAX/HOe3 RQOniB7fbGRkIVl3o0h1UdxSbLSHjMbv04SmiqaOxjOpTyGlnvlXGI/jMLn+i2wzhlsA LIWVghOrxWohrHPOgysJRUka6BKxDwTCOSAndmCkuX6rYX7Ua0xYMIus9spU+szw00Gj RGt+6KaMsNVn+251P1SBTmHoB5hLpll3/DRFAOFP9OE2z1FtX/YN9NCNfRvWikyr0W/z G4Tw== X-Forwarded-Encrypted: i=1; AJvYcCU/9Qzj7Vf5NqLhCgDQWn0LPFt7qYsFfMWIXlXnHsSeeU8l28vFIKiGp78cXqiDLvWpJjWw15ryKF7MysH4@vger.kernel.org, AJvYcCVNxqIdpfXyMB6KZwNbnpGZu63ECEeyVvx5no7WMdP+n+/livGiuz96qxAoM75pRB2x0bqCNZqeECc=@vger.kernel.org X-Gm-Message-State: AOJu0YwchzLBnDswOWiD38Ows6V0pRHMEUjm0wGe4T8YfbouaszUrdpp bFcieIcMf/qUBnsuYqbj83ehi9c8AO2h7aVVrKZNAiiSfzIxNedN X-Gm-Gg: ASbGnct+3T17ybAvewHGWo0yLn4ftgP9u1rb1r3nUUKe9GFVOB+NK/I2YY5FzhbPBoh oer+tURIx1UgWaZ68LDLiUWbalf/dSlLvPPOKtZjPZJ3nzl720G5aAY+AyvbyS3iN5wCSDb2Ypw Itq34pDyRMgjCrEtDxgR8lIR2lRhtAAbCjbtfIpAWjaBbUQ7XPQEScHzfU/oYtB+OeXYYnRz0SG KeA3JNrR97/H3chioTil6o05F0+XKLELPvnfjy5nP7PLFP2jQcHMSQQT9GBoDwx79WBab2fYxIy UmGjnkY8IA== X-Google-Smtp-Source: AGHT+IH5KR3E6Jz6QvSdqpU1+FfFO52Vb1APmL5SRnsUQRv82ukZRNLKODQzqhsk3l1Cb/VPdhJIiA== X-Received: by 2002:a05:600c:1396:b0:42f:7e87:3438 with SMTP id 5b1f17b1804b1-4366790cd9bmr439652885e9.0.1735841934379; Thu, 02 Jan 2025 10:18:54 -0800 (PST) Received: from prasmi.Home ([2a06:5906:61b:2d00:84e9:7adb:b646:c9c0]) by smtp.gmail.com with ESMTPSA id 5b1f17b1804b1-43656af6cbbsm493291925e9.3.2025.01.02.10.18.53 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 02 Jan 2025 10:18:53 -0800 (PST) From: Prabhakar X-Google-Original-From: Prabhakar To: Geert Uytterhoeven , Michael Turquette , Stephen Boyd Cc: linux-renesas-soc@vger.kernel.org, linux-clk@vger.kernel.org, linux-kernel@vger.kernel.org, Prabhakar , Biju Das , Fabrizio Castro , Lad Prabhakar Subject: [PATCH v3 6/6] clk: renesas: r9a09g057: Add clock and reset entries for GIC Date: Thu, 2 Jan 2025 18:18:39 +0000 Message-ID: <20250102181839.352599-7-prabhakar.mahadev-lad.rj@bp.renesas.com> X-Mailer: git-send-email 2.43.0 In-Reply-To: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> References: <20250102181839.352599-1-prabhakar.mahadev-lad.rj@bp.renesas.com> Precedence: bulk X-Mailing-List: linux-renesas-soc@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 From: Lad Prabhakar Add clock and reset entries for GIC. Signed-off-by: Lad Prabhakar Reviewed-by: Geert Uytterhoeven --- v2->v3 - Included RB tag from Geert v1->v2 - None --- drivers/clk/renesas/r9a09g057-cpg.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/drivers/clk/renesas/r9a09g057-cpg.c b/drivers/clk/renesas/r9a09g057-cpg.c index 7ef681dfcba5..3705e18f66ad 100644 --- a/drivers/clk/renesas/r9a09g057-cpg.c +++ b/drivers/clk/renesas/r9a09g057-cpg.c @@ -117,6 +117,8 @@ static const struct cpg_core_clk r9a09g057_core_clks[] __initconst = { static const struct rzv2h_mod_clk r9a09g057_mod_clks[] __initconst = { DEF_MOD_CRITICAL("icu_0_pclk_i", CLK_PLLCM33_DIV16, 0, 5, 0, 5, BUS_MSTOP_NONE), + DEF_MOD_CRITICAL("gic_0_gicclk", CLK_PLLDTY_ACPU_DIV4, 1, 3, 0, 19, + BUS_MSTOP(3, BIT(5))), DEF_MOD("gtm_0_pclk", CLK_PLLCM33_DIV16, 4, 3, 2, 3, BUS_MSTOP(5, BIT(10))), DEF_MOD("gtm_1_pclk", CLK_PLLCM33_DIV16, 4, 4, 2, 4, @@ -222,6 +224,8 @@ static const struct rzv2h_mod_clk r9a09g057_mod_clks[] __initconst = { static const struct rzv2h_reset r9a09g057_resets[] __initconst = { DEF_RST(3, 0, 1, 1), /* SYS_0_PRESETN */ DEF_RST(3, 6, 1, 7), /* ICU_0_PRESETN_I */ + DEF_RST(3, 8, 1, 9), /* GIC_0_GICRESET_N */ + DEF_RST(3, 9, 1, 10), /* GIC_0_DBG_GICRESET_N */ DEF_RST(6, 13, 2, 30), /* GTM_0_PRESETZ */ DEF_RST(6, 14, 2, 31), /* GTM_1_PRESETZ */ DEF_RST(6, 15, 3, 0), /* GTM_2_PRESETZ */