diff options
author | Robin Gong <b38343@freescale.com> | 2012-08-11 16:36:35 +0800 |
---|---|---|
committer | Xinyu Chen <xinyu.chen@freescale.com> | 2012-08-22 10:26:33 +0800 |
commit | 5ac3521539aa8775b9131699510e5bb55a8a4a86 (patch) | |
tree | 67a929688e9d5bec8a754992d295fa13e2375ff9 /arch/arm/plat-mxc | |
parent | 67c2bd5edef363412a074e9b4130b5207dac8a7f (diff) |
ENGR00220153 cpufreq mx6: new cpu set point and add VDDSOC/PU adjust
1.add new cpu setpoint: replace 498Mhz with 672Mhz,and remove 198Mhz.
but now 498Mhz seems not stable enough, comment now, test enough to
add it. Rigel kept unchange now.
2.support adjusting VDDSOC/VDDPU when cpu frequency change.
Signed-off-by: Robin Gong <b38343@freescale.com>
Diffstat (limited to 'arch/arm/plat-mxc')
-rwxr-xr-x | arch/arm/plat-mxc/cpufreq.c | 40 | ||||
-rwxr-xr-x | arch/arm/plat-mxc/include/mach/mxc.h | 2 | ||||
-rwxr-xr-x | arch/arm/plat-mxc/include/mach/mxc_dvfs.h | 6 |
3 files changed, 46 insertions, 2 deletions
diff --git a/arch/arm/plat-mxc/cpufreq.c b/arch/arm/plat-mxc/cpufreq.c index 935570707e6b..fd285cfce0bc 100755 --- a/arch/arm/plat-mxc/cpufreq.c +++ b/arch/arm/plat-mxc/cpufreq.c @@ -42,6 +42,7 @@ static int cpu_freq_suspend_in; static struct mutex set_cpufreq_lock; #endif +static int soc_regulator_set; static int cpu_freq_khz_min; static int cpu_freq_khz_max; @@ -53,6 +54,8 @@ static struct cpu_op *cpu_op_tbl; static u32 pre_suspend_rate; extern struct regulator *cpu_regulator; +extern struct regulator *soc_regulator; +extern struct regulator *pu_regulator; extern int dvfs_core_is_active; extern struct cpu_op *(*get_cpu_op)(int *op); extern int low_bus_freq_mode; @@ -68,14 +71,19 @@ int set_cpu_freq(int freq) int i, ret = 0; int org_cpu_rate; int gp_volt = 0; + int soc_volt = 0; + int pu_volt = 0; org_cpu_rate = clk_get_rate(cpu_clk); if (org_cpu_rate == freq) return ret; for (i = 0; i < cpu_op_nr; i++) { - if (freq == cpu_op_tbl[i].cpu_rate) + if (freq == cpu_op_tbl[i].cpu_rate) { gp_volt = cpu_op_tbl[i].cpu_voltage; + soc_volt = cpu_op_tbl[i].soc_voltage; + pu_volt = cpu_op_tbl[i].pu_voltage; + } } if (gp_volt == 0) @@ -91,6 +99,21 @@ int set_cpu_freq(int freq) if (low_bus_freq_mode || audio_bus_freq_mode) set_high_bus_freq(0); mutex_unlock(&bus_freq_mutex); + if (freq == cpu_op_tbl[0].cpu_rate && soc_regulator && pu_regulator) { + ret = regulator_set_voltage(soc_regulator, soc_volt, + soc_volt); + if (ret < 0) { + printk(KERN_DEBUG "COULD NOT SET SOC VOLTAGE!!!!\n"); + return ret; + } + ret = regulator_set_voltage(pu_regulator, pu_volt, + pu_volt); + if (ret < 0) { + printk(KERN_DEBUG "COULD NOT SET PU VOLTAGE!!!!\n"); + return ret; + } + soc_regulator_set = 1; + } ret = regulator_set_voltage(cpu_regulator, gp_volt, gp_volt); if (ret < 0) { @@ -112,6 +135,21 @@ int set_cpu_freq(int freq) printk(KERN_DEBUG "COULD NOT SET GP VOLTAGE!!!!\n"); return ret; } + if (soc_regulator_set && soc_regulator && pu_regulator) { + ret = regulator_set_voltage(soc_regulator, soc_volt, + soc_volt); + if (ret < 0) { + printk(KERN_DEBUG "COULD NOT SET SOC VOLTAGE BACK!!!!\n"); + return ret; + } + ret = regulator_set_voltage(pu_regulator, pu_volt, + pu_volt); + if (ret < 0) { + printk(KERN_DEBUG "COULD NOT SET PU VOLTAGE!!!!\n"); + return ret; + } + soc_regulator_set = 0; + } mutex_lock(&bus_freq_mutex); if (low_freq_bus_used() && !(low_bus_freq_mode || audio_bus_freq_mode)) diff --git a/arch/arm/plat-mxc/include/mach/mxc.h b/arch/arm/plat-mxc/include/mach/mxc.h index 2f23c725a971..82457673c5ad 100755 --- a/arch/arm/plat-mxc/include/mach/mxc.h +++ b/arch/arm/plat-mxc/include/mach/mxc.h @@ -253,6 +253,8 @@ struct cpu_op { u32 mfi; u32 mfd; u32 mfn; + u32 pu_voltage; + u32 soc_voltage; u32 cpu_voltage; u32 cpu_podf; }; diff --git a/arch/arm/plat-mxc/include/mach/mxc_dvfs.h b/arch/arm/plat-mxc/include/mach/mxc_dvfs.h index fd0039597dbb..64639ae86aa6 100755 --- a/arch/arm/plat-mxc/include/mach/mxc_dvfs.h +++ b/arch/arm/plat-mxc/include/mach/mxc_dvfs.h @@ -1,5 +1,5 @@ /* - * Copyright (C) 2009-2011 Freescale Semiconductor, Inc. All Rights Reserved. + * Copyright (C) 2009-2012 Freescale Semiconductor, Inc. All Rights Reserved. */ /* @@ -136,6 +136,10 @@ struct dvfs_op { struct mxc_dvfs_platform_data { /** Supply voltage regulator name string */ char *reg_id; + /*vdd_soc regulator name string*/ + char *soc_id; + /*vdd_pu regulator name string*/ + char *pu_id; /* CPU clock name string */ char *clk1_id; /* DVFS clock name string */ |