public inbox for linux-sh@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] sh: add mode4 pin support to sh7785 clock code
@ 2009-05-07 10:50 Magnus Damm
  0 siblings, 0 replies; only message in thread
From: Magnus Damm @ 2009-05-07 10:50 UTC (permalink / raw)
  To: linux-sh

From: Magnus Damm <damm@igel.co.jp>

Use early_param() to select mode4 configuration
for the sh7785 clock code. Without this patch
there is no board configuration code that
selects PLL multiplier (36x/72x) for sh7785.

The board code must make sure that mode4 is
setup according to the hardware configuration.

Signed-off-by: Magnus Damm <damm@igel.co.jp>
---

 arch/sh/kernel/cpu/sh4a/clock-sh7785.c |   18 +++++++++++++++++-
 1 file changed, 17 insertions(+), 1 deletion(-)

--- 0001/arch/sh/kernel/cpu/sh4a/clock-sh7785.c
+++ work/arch/sh/kernel/cpu/sh4a/clock-sh7785.c	2009-05-07 16:28:24.000000000 +0900
@@ -15,6 +15,22 @@
 #include <asm/freq.h>
 #include <asm/io.h>
 
+static int mode4_pin;
+
+static int __init setup_mode4_pin(char *buf)
+{
+	if (buf) {
+		if (strstr(buf, "high"))
+			mode4_pin = 1;
+
+		if (strstr(buf, "low"))
+			mode4_pin = 0;
+	}
+
+	return 0;
+}
+early_param("mode4_pin", setup_mode4_pin);
+
 static int ifc_divisors[] = { 1, 2, 4, 6 };
 static int ufc_divisors[] = { 1, 1, 4, 6 };
 static int sfc_divisors[] = { 1, 1, 4, 6 };
@@ -26,7 +42,7 @@ static int pfc_divisors[] = { 1, 1, 1, 1
 
 static void master_clk_init(struct clk *clk)
 {
-	clk->rate *= pfc_divisors[ctrl_inl(FRQMR1) & 0x000f];
+	clk->rate *= mode4_pin ? 36 : 72;
 }
 
 static struct clk_ops sh7785_master_clk_ops = {

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2009-05-07 10:50 UTC | newest]

Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-05-07 10:50 [PATCH] sh: add mode4 pin support to sh7785 clock code Magnus Damm

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox