From: Rajendra Nayak <rna...@ti.com>

This patch resets the voltage level for each OPP on SR disable.

Signed-off-by: Rajendra Nayak <rna...@ti.com>
Signed-off-by: Jouni Hogander <jouni.hogan...@nokia.com>
---
 arch/arm/mach-omap2/smartreflex.c |   49 ++++++++++++++++++++++++++++++++++++++
 1 files changed, 49 insertions(+)

Index: linux-omap-pm/arch/arm/mach-omap2/smartreflex.c
===================================================================
--- linux-omap-pm.orig/arch/arm/mach-omap2/smartreflex.c        2009-03-24 
14:41:00.471057326 +0530
+++ linux-omap-pm/arch/arm/mach-omap2/smartreflex.c     2009-03-24 
14:41:06.054889481 +0530
@@ -379,6 +379,51 @@
        sr->is_sr_reset = 0;
 }
 
+static int sr_reset_voltage(int srid)
+{
+       u32 target_opp_no, vsel = 0;
+       u32 reg_addr = 0;
+       u32 loop_cnt = 0, retries_cnt = 0;
+       u32 vc_bypass_value;
+
+       if (srid == SR1) {
+               target_opp_no = resource_get_level("vdd1_opp");
+               vsel = mpu_opps[target_opp_no].vsel;
+               reg_addr = R_VDD1_SR_CONTROL;
+       } else if (srid == SR2) {
+               target_opp_no = resource_get_level("vdd2_opp");
+               vsel = l3_opps[target_opp_no].vsel;
+               reg_addr = R_VDD2_SR_CONTROL;
+       }
+
+       vc_bypass_value = (vsel << OMAP3430_DATA_SHIFT) |
+                       (reg_addr << OMAP3430_REGADDR_SHIFT) |
+                       (R_SRI2C_SLAVE_ADDR << OMAP3430_SLAVEADDR_SHIFT);
+
+       prm_write_mod_reg(vc_bypass_value, OMAP3430_GR_MOD,
+                       OMAP3_PRM_VC_BYPASS_VAL_OFFSET);
+
+       vc_bypass_value = prm_set_mod_reg_bits(OMAP3430_VALID, OMAP3430_GR_MOD,
+                                       OMAP3_PRM_VC_BYPASS_VAL_OFFSET);
+
+       while ((vc_bypass_value & OMAP3430_VALID) != 0x0) {
+               loop_cnt++;
+               if (retries_cnt > 10) {
+                       printk(KERN_INFO "Loop count exceeded in check SR I2C"
+                                                               "write\n");
+                       return SR_FAIL;
+               }
+               if (loop_cnt > 50) {
+                       retries_cnt++;
+                       loop_cnt = 0;
+                       udelay(10);
+               }
+               vc_bypass_value = prm_read_mod_reg(OMAP3430_GR_MOD,
+                                       OMAP3_PRM_VC_BYPASS_VAL_OFFSET);
+       }
+       return SR_PASS;
+}
+
 static int sr_enable(struct omap_sr *sr, u32 target_opp_no)
 {
        u32 nvalue_reciprocal, v;
@@ -544,6 +589,8 @@
                sr_disable(sr);
                sr_clk_disable(sr);
                sr->is_autocomp_active = 0;
+               /* Reset the volatage for current OPP */
+               sr_reset_voltage(srid);
                return SR_TRUE;
        } else {
                printk(KERN_WARNING "SR%d: VDD autocomp is not active\n",
@@ -612,6 +659,8 @@
                                                OMAP3430_GR_MOD,
                                                OMAP3_PRM_VP2_CONFIG_OFFSET);
                        }
+                       /* Reset the volatage for current OPP */
+                       sr_reset_voltage(srid);
                }
        }
 }
--
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

Reply via email to