Re: [PATCHv4 16/33] CLK: OMAP: DPLL: do not of_iomap NULL autoidle register

2013-07-31 Thread Tero Kristo

On 07/30/2013 10:49 PM, Nishanth Menon wrote:

On 07/23/2013 02:20 AM, Tero Kristo wrote:

AM33xx series SoCs do not have autoidle support, and for these the
autoidle register is marked as NULL. Check against a NULL pointer and
do not attempt to of_iomap in this case, as this just creates a bogus
pointer and causes a kernel crash during boot.

Signed-off-by: Tero Kristo t-kri...@ti.com
---
  drivers/clk/omap/dpll.c |   10 +-
  1 file changed, 9 insertions(+), 1 deletion(-)

diff --git a/drivers/clk/omap/dpll.c b/drivers/clk/omap/dpll.c
index 1d24feada..d8a958a 100644
--- a/drivers/clk/omap/dpll.c
+++ b/drivers/clk/omap/dpll.c
@@ -162,6 +162,7 @@ static void __init of_omap_dpll_setup(struct
device_node *node,
  u32 max_multiplier = 2047;
  u32 max_divider = 128;
  u32 min_divider = 1;
+u32 val;
  int i;

  dd = kzalloc(sizeof(struct dpll_data), GFP_KERNEL);
@@ -210,7 +211,14 @@ static void __init of_omap_dpll_setup(struct
device_node *node,

  dd-control_reg = of_iomap(node, 0);
  dd-idlest_reg = of_iomap(node, 1);
-dd-autoidle_reg = of_iomap(node, 2);
+/*
+ * AM33xx DPLLs have no autoidle support, and the autoidle reg
+ * for these is NULL. Do not attempt to of_iomap in this case,
+ * as this just creates a bogus pointer and crashes the kernel.
+ */
+of_property_read_u32_index(node, reg, 2 * 2, val);
+if (val)
+dd-autoidle_reg = of_iomap(node, 2);

should we not do that for all the parameters?


Maybe do the check for all.


OR:
move this as index 3 which is optional and is not defined for am33xx?


  dd-mult_div1_reg = of_iomap(node, 3);




  dd-idlest_mask = idlest_mask;


we could probably squash this in original dpll.c as a result?



Yea, can do that also.

--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


Re: [PATCHv4 16/33] CLK: OMAP: DPLL: do not of_iomap NULL autoidle register

2013-07-30 Thread Nishanth Menon

On 07/23/2013 02:20 AM, Tero Kristo wrote:

AM33xx series SoCs do not have autoidle support, and for these the
autoidle register is marked as NULL. Check against a NULL pointer and
do not attempt to of_iomap in this case, as this just creates a bogus
pointer and causes a kernel crash during boot.

Signed-off-by: Tero Kristo t-kri...@ti.com
---
  drivers/clk/omap/dpll.c |   10 +-
  1 file changed, 9 insertions(+), 1 deletion(-)

diff --git a/drivers/clk/omap/dpll.c b/drivers/clk/omap/dpll.c
index 1d24feada..d8a958a 100644
--- a/drivers/clk/omap/dpll.c
+++ b/drivers/clk/omap/dpll.c
@@ -162,6 +162,7 @@ static void __init of_omap_dpll_setup(struct device_node 
*node,
u32 max_multiplier = 2047;
u32 max_divider = 128;
u32 min_divider = 1;
+   u32 val;
int i;

dd = kzalloc(sizeof(struct dpll_data), GFP_KERNEL);
@@ -210,7 +211,14 @@ static void __init of_omap_dpll_setup(struct device_node 
*node,

dd-control_reg = of_iomap(node, 0);
dd-idlest_reg = of_iomap(node, 1);
-   dd-autoidle_reg = of_iomap(node, 2);
+   /*
+* AM33xx DPLLs have no autoidle support, and the autoidle reg
+* for these is NULL. Do not attempt to of_iomap in this case,
+* as this just creates a bogus pointer and crashes the kernel.
+*/
+   of_property_read_u32_index(node, reg, 2 * 2, val);
+   if (val)
+   dd-autoidle_reg = of_iomap(node, 2);

should we not do that for all the parameters?
OR:
move this as index 3 which is optional and is not defined for am33xx?


dd-mult_div1_reg = of_iomap(node, 3);




dd-idlest_mask = idlest_mask;


we could probably squash this in original dpll.c as a result?

--
Regards,
Nishanth Menon
--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[PATCHv4 16/33] CLK: OMAP: DPLL: do not of_iomap NULL autoidle register

2013-07-23 Thread Tero Kristo
AM33xx series SoCs do not have autoidle support, and for these the
autoidle register is marked as NULL. Check against a NULL pointer and
do not attempt to of_iomap in this case, as this just creates a bogus
pointer and causes a kernel crash during boot.

Signed-off-by: Tero Kristo t-kri...@ti.com
---
 drivers/clk/omap/dpll.c |   10 +-
 1 file changed, 9 insertions(+), 1 deletion(-)

diff --git a/drivers/clk/omap/dpll.c b/drivers/clk/omap/dpll.c
index 1d24feada..d8a958a 100644
--- a/drivers/clk/omap/dpll.c
+++ b/drivers/clk/omap/dpll.c
@@ -162,6 +162,7 @@ static void __init of_omap_dpll_setup(struct device_node 
*node,
u32 max_multiplier = 2047;
u32 max_divider = 128;
u32 min_divider = 1;
+   u32 val;
int i;
 
dd = kzalloc(sizeof(struct dpll_data), GFP_KERNEL);
@@ -210,7 +211,14 @@ static void __init of_omap_dpll_setup(struct device_node 
*node,
 
dd-control_reg = of_iomap(node, 0);
dd-idlest_reg = of_iomap(node, 1);
-   dd-autoidle_reg = of_iomap(node, 2);
+   /*
+* AM33xx DPLLs have no autoidle support, and the autoidle reg
+* for these is NULL. Do not attempt to of_iomap in this case,
+* as this just creates a bogus pointer and crashes the kernel.
+*/
+   of_property_read_u32_index(node, reg, 2 * 2, val);
+   if (val)
+   dd-autoidle_reg = of_iomap(node, 2);
dd-mult_div1_reg = of_iomap(node, 3);
 
dd-idlest_mask = idlest_mask;
-- 
1.7.9.5

--
To unsubscribe from this list: send the line unsubscribe linux-omap in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html