diff options
Diffstat (limited to 'arch/arm/mach-tegra/tegra3_speedo.c')
-rw-r--r-- | arch/arm/mach-tegra/tegra3_speedo.c | 39 |
1 files changed, 35 insertions, 4 deletions
diff --git a/arch/arm/mach-tegra/tegra3_speedo.c b/arch/arm/mach-tegra/tegra3_speedo.c index a0307ba33682..5c37fd3f3a84 100644 --- a/arch/arm/mach-tegra/tegra3_speedo.c +++ b/arch/arm/mach-tegra/tegra3_speedo.c @@ -52,8 +52,8 @@ static const u32 core_process_speedos[][CORE_PROCESS_CORNERS_NUM] = { {192}, /* [9]: soc_speedo_id = 2 - T33S */ /* T30 'L' family */ - {192}, /* [10]: soc_speedo_id 2: T30L */ - {192}, /* [11]: soc_speedo_id 2: T30SL */ + {192}, /* [10]: soc_speedo_id 1: T30L */ + {192}, /* [11]: soc_speedo_id 1: T30SL */ }; /* Maximum speedo levels for each CPU process corner */ @@ -170,7 +170,7 @@ static void rev_sku_to_speedo_ids(int rev, int sku) switch (package_id) { case 1: /* MID => T30L */ cpu_speedo_id = 7; - soc_speedo_id = 2; + soc_speedo_id = 1; threshold_index = 10; break; case 2: /* DSC => T30S */ @@ -188,7 +188,7 @@ static void rev_sku_to_speedo_ids(int rev, int sku) case 0x8F: /* T30SL */ cpu_speedo_id = 8; - soc_speedo_id = 2; + soc_speedo_id = 1; threshold_index = 11; break; @@ -340,3 +340,34 @@ int tegra_package_id(void) { return package_id; } + +/* + * CPU and core nominal voltage levels as determined by chip SKU and speedo + * (not final - can be lowered by dvfs tables and rail dependencies; the + * latter is resolved by the dvfs code) + */ +static const int cpu_speedo_nominal_millivolts[] = +/* speedo_id 0, 1, 2, 3, 4, 5, 6, 7, 8 */ + { 1125, 1150, 1150, 1150, 1237, 1237, 1237, 1150, 1150 }; + +int tegra_cpu_speedo_mv(void) +{ + BUG_ON(cpu_speedo_id >= ARRAY_SIZE(cpu_speedo_nominal_millivolts)); + return cpu_speedo_nominal_millivolts[cpu_speedo_id]; +} + +int tegra_core_speedo_mv(void) +{ + switch (soc_speedo_id) { + case 0: + return 1200; + case 1: + if ((cpu_speedo_id != 7) && (cpu_speedo_id != 8)) + return 1200; + /* fall thru for T30L or T30SL */ + case 2: + return 1300; + default: + BUG(); + } +} |