linux-gpio.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Varshini Rajendran <varshini.rajendran@microchip.com>
To: <robh+dt@kernel.org>, <krzysztof.kozlowski+dt@linaro.org>,
	<conor+dt@kernel.org>, <nicolas.ferre@microchip.com>,
	<alexandre.belloni@bootlin.com>, <claudiu.beznea@microchip.com>,
	<mturquette@baylibre.com>, <sboyd@kernel.org>,
	<herbert@gondor.apana.org.au>, <davem@davemloft.net>,
	<vkoul@kernel.org>, <tglx@linutronix.de>, <maz@kernel.org>,
	<lee@kernel.org>, <ulf.hansson@linaro.org>,
	<tudor.ambarus@linaro.org>, <miquel.raynal@bootlin.com>,
	<richard@nod.at>, <vigneshr@ti.com>, <edumazet@google.com>,
	<kuba@kernel.org>, <pabeni@redhat.com>,
	<linus.walleij@linaro.org>, <p.zabel@pengutronix.de>,
	<olivia@selenic.com>, <a.zummo@towertech.it>,
	<radu_nicolae.pirea@upb.ro>, <richard.genoud@gmail.com>,
	<gregkh@linuxfoundation.org>, <lgirdwood@gmail.com>,
	<broonie@kernel.org>, <wim@linux-watchdog.org>,
	<linux@roeck-us.net>, <arnd@arndb.de>, <olof@lixom.net>,
	<soc@kernel.org>, <linux@armlinux.org.uk>, <sre@kernel.org>,
	<jerry.ray@microchip.com>, <horatiu.vultur@microchip.com>,
	<durai.manickamkr@microchip.com>,
	<varshini.rajendran@microchip.com>, <andrew@lunn.ch>,
	<alain.volmat@foss.st.com>, <neil.armstrong@linaro.org>,
	<mihai.sain@microchip.com>, <eugen.hristev@collabora.com>,
	<devicetree@vger.kernel.org>,
	<linux-arm-kernel@lists.infradead.org>,
	<linux-kernel@vger.kernel.org>, <linux-clk@vger.kernel.org>,
	<linux-crypto@vger.kernel.org>, <dmaengine@vger.kernel.org>,
	<linux-i2c@vger.kernel.org>, <linux-mmc@vger.kernel.org>,
	<linux-mtd@lists.infradead.org>, <netdev@vger.kernel.org>,
	<linux-gpio@vger.kernel.org>, <linux-rtc@vger.kernel.org>,
	<linux-spi@vger.kernel.org>, <linux-serial@vger.kernel.org>,
	<alsa-devel@alsa-project.org>, <linux-usb@vger.kernel.org>,
	<linux-watchdog@vger.kernel.org>, <linux-pm@vger.kernel.org>
Cc: <Hari.PrasathGE@microchip.com>, <cristian.birsan@microchip.com>,
	<balamanikandan.gunasundar@microchip.com>,
	<manikandan.m@microchip.com>, <dharma.b@microchip.com>,
	<nayabbasha.sayed@microchip.com>, <balakrishnan.s@microchip.com>
Subject: [PATCH v2 08/45] clk: at91: clk-sam9x60-pll: re-factor to support individual core freq outputs
Date: Sat, 24 Jun 2023 02:00:19 +0530	[thread overview]
Message-ID: <20230623203056.689705-9-varshini.rajendran@microchip.com> (raw)
In-Reply-To: <20230623203056.689705-1-varshini.rajendran@microchip.com>

SAM9X7 SoC family supports different core output frequencies for
different PLL IDs. To handle the same in the PLL driver, a separate
parameter core_output is added. The sam9x60 and sama7g5 SoC PMC drivers
are aligned to the PLL driver by adding the core output freq range in
the PLL characteristics configurations.

Signed-off-by: Varshini Rajendran <varshini.rajendran@microchip.com>
---
 drivers/clk/at91/clk-sam9x60-pll.c | 12 ++++++------
 drivers/clk/at91/pmc.h             |  1 +
 drivers/clk/at91/sam9x60.c         |  7 +++++++
 drivers/clk/at91/sama7g5.c         |  7 +++++++
 4 files changed, 21 insertions(+), 6 deletions(-)

diff --git a/drivers/clk/at91/clk-sam9x60-pll.c b/drivers/clk/at91/clk-sam9x60-pll.c
index 0882ed01d5c2..b3012641214c 100644
--- a/drivers/clk/at91/clk-sam9x60-pll.c
+++ b/drivers/clk/at91/clk-sam9x60-pll.c
@@ -23,9 +23,6 @@
 #define UPLL_DIV		2
 #define PLL_MUL_MAX		(FIELD_GET(PMC_PLL_CTRL1_MUL_MSK, UINT_MAX) + 1)
 
-#define FCORE_MIN		(600000000)
-#define FCORE_MAX		(1200000000)
-
 #define PLL_MAX_ID		7
 
 struct sam9x60_pll_core {
@@ -194,7 +191,8 @@ static long sam9x60_frac_pll_compute_mul_frac(struct sam9x60_pll_core *core,
 	unsigned long nmul = 0;
 	unsigned long nfrac = 0;
 
-	if (rate < FCORE_MIN || rate > FCORE_MAX)
+	if (rate < core->characteristics->core_output[0].min ||
+	    rate > core->characteristics->core_output[0].max)
 		return -ERANGE;
 
 	/*
@@ -214,7 +212,8 @@ static long sam9x60_frac_pll_compute_mul_frac(struct sam9x60_pll_core *core,
 	}
 
 	/* Check if resulted rate is a valid.  */
-	if (tmprate < FCORE_MIN || tmprate > FCORE_MAX)
+	if (tmprate < core->characteristics->core_output[0].min ||
+	    tmprate > core->characteristics->core_output[0].max)
 		return -ERANGE;
 
 	if (update) {
@@ -666,7 +665,8 @@ sam9x60_clk_register_frac_pll(struct regmap *regmap, spinlock_t *lock,
 			goto free;
 		}
 
-		ret = sam9x60_frac_pll_compute_mul_frac(&frac->core, FCORE_MIN,
+		ret = sam9x60_frac_pll_compute_mul_frac(&frac->core,
+							characteristics->core_output[0].min,
 							parent_rate, true);
 		if (ret < 0) {
 			hw = ERR_PTR(ret);
diff --git a/drivers/clk/at91/pmc.h b/drivers/clk/at91/pmc.h
index 1b3ca7dd9b57..3e36dcc464c1 100644
--- a/drivers/clk/at91/pmc.h
+++ b/drivers/clk/at91/pmc.h
@@ -75,6 +75,7 @@ struct clk_pll_characteristics {
 	struct clk_range input;
 	int num_output;
 	const struct clk_range *output;
+	const struct clk_range *core_output;
 	u16 *icpll;
 	u8 *out;
 	u8 upll : 1;
diff --git a/drivers/clk/at91/sam9x60.c b/drivers/clk/at91/sam9x60.c
index ac070db58195..452ad45cf251 100644
--- a/drivers/clk/at91/sam9x60.c
+++ b/drivers/clk/at91/sam9x60.c
@@ -26,10 +26,16 @@ static const struct clk_range plla_outputs[] = {
 	{ .min = 2343750, .max = 1200000000 },
 };
 
+/* Fractional PLL core output range. */
+static const struct clk_range core_outputs[] = {
+	{ .min = 600000000, .max = 1200000000 },
+};
+
 static const struct clk_pll_characteristics plla_characteristics = {
 	.input = { .min = 12000000, .max = 48000000 },
 	.num_output = ARRAY_SIZE(plla_outputs),
 	.output = plla_outputs,
+	.core_output = core_outputs,
 };
 
 static const struct clk_range upll_outputs[] = {
@@ -40,6 +46,7 @@ static const struct clk_pll_characteristics upll_characteristics = {
 	.input = { .min = 12000000, .max = 48000000 },
 	.num_output = ARRAY_SIZE(upll_outputs),
 	.output = upll_outputs,
+	.core_output = core_outputs,
 	.upll = true,
 };
 
diff --git a/drivers/clk/at91/sama7g5.c b/drivers/clk/at91/sama7g5.c
index f135b662f1ff..468a3c5449b5 100644
--- a/drivers/clk/at91/sama7g5.c
+++ b/drivers/clk/at91/sama7g5.c
@@ -104,11 +104,17 @@ static const struct clk_range pll_outputs[] = {
 	{ .min = 2343750, .max = 1200000000 },
 };
 
+/* Fractional PLL core output range. */
+static const struct clk_range core_outputs[] = {
+	{ .min = 600000000, .max = 1200000000 },
+};
+
 /* CPU PLL characteristics. */
 static const struct clk_pll_characteristics cpu_pll_characteristics = {
 	.input = { .min = 12000000, .max = 50000000 },
 	.num_output = ARRAY_SIZE(cpu_pll_outputs),
 	.output = cpu_pll_outputs,
+	.core_output = core_outputs,
 };
 
 /* PLL characteristics. */
@@ -116,6 +122,7 @@ static const struct clk_pll_characteristics pll_characteristics = {
 	.input = { .min = 12000000, .max = 50000000 },
 	.num_output = ARRAY_SIZE(pll_outputs),
 	.output = pll_outputs,
+	.core_output = core_outputs,
 };
 
 /*
-- 
2.25.1


  parent reply	other threads:[~2023-06-23 20:36 UTC|newest]

Thread overview: 82+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-06-23 20:30 [PATCH v2 00/45] Add support for sam9x7 SoC family Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 01/45] dt-bindings: microchip: atmel,at91rm9200-tcb: add sam9x60, sam9x7 compatible Varshini Rajendran
2023-06-24  7:53   ` Krzysztof Kozlowski
2023-06-24  9:19     ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 02/45] dt-bindings: usb: ehci: Add atmel at91sam9g45-ehci compatible Varshini Rajendran
2023-06-24  7:53   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 03/45] dt-bindings: usb: generic-ehci: Document clock-names property Varshini Rajendran
2023-06-24  7:54   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 04/45] dt-bindings: net: cdns,macb: add documentation for sam9x7 ethernet interface Varshini Rajendran
2023-06-24  7:54   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 05/45] ARM: at91: pm: add support for sam9x7 SoC family Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 06/45] ARM: at91: pm: add sam9x7 SoC init config Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 07/45] ARM: at91: add support in SoC driver for new sam9x7 Varshini Rajendran
2023-06-23 20:30 ` Varshini Rajendran [this message]
2023-06-23 20:30 ` [PATCH v2 09/45] clk: at91: sam9x7: add support for HW PLL freq dividers Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 10/45] clk: at91: sama7g5: move mux table macros to header file Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 11/45] dt-bindings: clk: at91: add bindings for SAM9X7's clock controller Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 12/45] dt-bindings: reset: atmel,at91sam9260-reset: add sam9x7 binding Varshini Rajendran
2023-06-24  7:57   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 13/45] dt-bindings: atmel-sysreg: add bindings for sam9x7 Varshini Rajendran
2023-06-24  8:00   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 14/45] dt-bindings: crypto: add bindings for sam9x7 in Atmel AES Varshini Rajendran
2023-06-24  7:58   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 15/45] dt-bindings: crypto: add bindings for sam9x7 in Atmel SHA Varshini Rajendran
2023-06-24  7:59   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 16/45] dt-bindings: crypto: add bindings for sam9x7 in Atmel TDES Varshini Rajendran
2023-06-24  7:59   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 17/45] dt-bindings: dmaengine: at_xdmac: add compatible with microchip,sam9x7 Varshini Rajendran
2023-06-24  8:27   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 18/45] dt-bindings: i2c: at91: Add SAM9X7 compatible string Varshini Rajendran
2023-06-24  8:00   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 19/45] dt-bindings: mfd: " Varshini Rajendran
2023-06-24  8:23   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 20/45] dt-bindings: atmel-gpbr: add microchip,sam9x7-gpbr Varshini Rajendran
2023-06-24  8:23   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 21/45] dt-bindings: atmel-matrix: add microchip,sam9x7-matrix Varshini Rajendran
2023-06-24  8:24   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 22/45] dt-bindings: atmel-smc: add microchip,sam9x7-smc Varshini Rajendran
2023-06-24  8:24   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 23/45] dt-bindings: atmel-ssc: add microchip,sam9x7-ssc Varshini Rajendran
2023-06-24  8:24   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 24/45] dt-bindings: sdhci-of-at91: add microchip,sam9x7-sdhci Varshini Rajendran
2023-06-24  8:24   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 25/45] dt-bindings: atmel-nand: add microchip,sam9x7-pmecc Varshini Rajendran
2023-06-24  8:24   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 26/45] dt-bindings: pinctrl: at91: add bindings for SAM9X7 Varshini Rajendran
2023-06-24  8:24   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 27/45] dt-bindings: rng: atmel,at91-trng: document sam9x7 TRNG Varshini Rajendran
2023-06-24  8:01   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 28/45] dt-bindings: rtc: at91rm9200: add sam9x7 compatible Varshini Rajendran
2023-06-24  8:01   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 29/45] dt-bindings: rtt: at91rm9260: " Varshini Rajendran
2023-06-24  8:02   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 30/45] dt-bindings: serial: atmel,at91-usart: add compatible for sam9x7 Varshini Rajendran
2023-06-24  8:02   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 31/45] dt-bindings: atmel-classd: add sam9x7 compatible Varshini Rajendran
2023-06-23 23:43   ` Rob Herring
2023-06-24  8:02   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 32/45] spi: dt-bindings: atmel,at91rm9200-spi: " Varshini Rajendran
2023-06-24  8:02   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 33/45] dt-bindings: usb: atmel: Update DT bindings documentation for sam9x7 Varshini Rajendran
2023-06-24  8:23   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 34/45] dt-bindings: watchdog: sama5d4-wdt: add compatible for sam9x7-wdt Varshini Rajendran
2023-06-24  8:03   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 35/45] dt-bindings: irqchip/atmel-aic5: Add support for sam9x7 aic Varshini Rajendran
2023-06-24  8:23   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 36/45] clk: at91: sam9x7: add sam9x7 pmc driver Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 37/45] irqchip/atmel-aic5: Add support for sam9x7 aic Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 38/45] power: reset: at91-poweroff: lookup for proper pmc dt node for sam9x7 Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 39/45] power: reset: at91-reset: add reset support for sam9x7 SoC Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 40/45] power: reset: at91-reset: add sdhwc " Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 41/45] ARM: at91: Kconfig: add config flag for SAM9X7 SoC Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 42/45] ARM: configs: at91: enable config flags for sam9x7 SoC family Varshini Rajendran
2023-06-23 20:30 ` [PATCH v2 43/45] ARM: dts: at91: sam9x7: add device tree for SoC Varshini Rajendran
2023-06-24  8:09   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 44/45] dt-bindings: arm: add sam9x75 curiosity board Varshini Rajendran
2023-06-24  8:03   ` Krzysztof Kozlowski
2023-06-23 20:30 ` [PATCH v2 45/45] ARM: dts: at91: sam9x75_curiosity: add device tree for " Varshini Rajendran
2023-06-24  8:12   ` Krzysztof Kozlowski
2023-06-24  7:56 ` [PATCH v2 00/45] Add support for sam9x7 SoC family Krzysztof Kozlowski
     [not found] ` <168756794811.1155588.11719780333735420720.b4-ty@kernel.org>
2023-06-24  8:13   ` (subset) " Krzysztof Kozlowski
2023-06-24  8:28 ` Krzysztof Kozlowski

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20230623203056.689705-9-varshini.rajendran@microchip.com \
    --to=varshini.rajendran@microchip.com \
    --cc=Hari.PrasathGE@microchip.com \
    --cc=a.zummo@towertech.it \
    --cc=alain.volmat@foss.st.com \
    --cc=alexandre.belloni@bootlin.com \
    --cc=alsa-devel@alsa-project.org \
    --cc=andrew@lunn.ch \
    --cc=arnd@arndb.de \
    --cc=balakrishnan.s@microchip.com \
    --cc=balamanikandan.gunasundar@microchip.com \
    --cc=broonie@kernel.org \
    --cc=claudiu.beznea@microchip.com \
    --cc=conor+dt@kernel.org \
    --cc=cristian.birsan@microchip.com \
    --cc=davem@davemloft.net \
    --cc=devicetree@vger.kernel.org \
    --cc=dharma.b@microchip.com \
    --cc=dmaengine@vger.kernel.org \
    --cc=durai.manickamkr@microchip.com \
    --cc=edumazet@google.com \
    --cc=eugen.hristev@collabora.com \
    --cc=gregkh@linuxfoundation.org \
    --cc=herbert@gondor.apana.org.au \
    --cc=horatiu.vultur@microchip.com \
    --cc=jerry.ray@microchip.com \
    --cc=krzysztof.kozlowski+dt@linaro.org \
    --cc=kuba@kernel.org \
    --cc=lee@kernel.org \
    --cc=lgirdwood@gmail.com \
    --cc=linus.walleij@linaro.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-clk@vger.kernel.org \
    --cc=linux-crypto@vger.kernel.org \
    --cc=linux-gpio@vger.kernel.org \
    --cc=linux-i2c@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-mmc@vger.kernel.org \
    --cc=linux-mtd@lists.infradead.org \
    --cc=linux-pm@vger.kernel.org \
    --cc=linux-rtc@vger.kernel.org \
    --cc=linux-serial@vger.kernel.org \
    --cc=linux-spi@vger.kernel.org \
    --cc=linux-usb@vger.kernel.org \
    --cc=linux-watchdog@vger.kernel.org \
    --cc=linux@armlinux.org.uk \
    --cc=linux@roeck-us.net \
    --cc=manikandan.m@microchip.com \
    --cc=maz@kernel.org \
    --cc=mihai.sain@microchip.com \
    --cc=miquel.raynal@bootlin.com \
    --cc=mturquette@baylibre.com \
    --cc=nayabbasha.sayed@microchip.com \
    --cc=neil.armstrong@linaro.org \
    --cc=netdev@vger.kernel.org \
    --cc=nicolas.ferre@microchip.com \
    --cc=olivia@selenic.com \
    --cc=olof@lixom.net \
    --cc=p.zabel@pengutronix.de \
    --cc=pabeni@redhat.com \
    --cc=radu_nicolae.pirea@upb.ro \
    --cc=richard.genoud@gmail.com \
    --cc=richard@nod.at \
    --cc=robh+dt@kernel.org \
    --cc=sboyd@kernel.org \
    --cc=soc@kernel.org \
    --cc=sre@kernel.org \
    --cc=tglx@linutronix.de \
    --cc=tudor.ambarus@linaro.org \
    --cc=ulf.hansson@linaro.org \
    --cc=vigneshr@ti.com \
    --cc=vkoul@kernel.org \
    --cc=wim@linux-watchdog.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).