summaryrefslogtreecommitdiff
path: root/arch/arm/mach-tegra/tegra3_dvfs.c
diff options
context:
space:
mode:
authorAlex Frid <afrid@nvidia.com>2011-04-27 23:54:41 -0700
committerVarun Colbert <vcolbert@nvidia.com>2011-05-05 14:20:01 -0700
commit9625bac21ebe5b7a40792515653548788ed2a8ae (patch)
treef1dafb0b49a7c3970564301a73f07c7d70a65d7a /arch/arm/mach-tegra/tegra3_dvfs.c
parent9d27386f23e941060f83f4c567a57e1c9a148473 (diff)
ARM: tegra: power: Add Tegra3 core DVFS sysfs control
Change-Id: I085d8cff2b5fea60f5245c36eefe849aa17a58f5 Reviewed-on: http://git-master/r/29764 Reviewed-by: Aleksandr Frid <afrid@nvidia.com> Tested-by: Aleksandr Frid <afrid@nvidia.com> Reviewed-by: Scott Williams <scwilliams@nvidia.com>
Diffstat (limited to 'arch/arm/mach-tegra/tegra3_dvfs.c')
-rw-r--r--arch/arm/mach-tegra/tegra3_dvfs.c33
1 files changed, 32 insertions, 1 deletions
diff --git a/arch/arm/mach-tegra/tegra3_dvfs.c b/arch/arm/mach-tegra/tegra3_dvfs.c
index e685871e15c1..24685fa271c8 100644
--- a/arch/arm/mach-tegra/tegra3_dvfs.c
+++ b/arch/arm/mach-tegra/tegra3_dvfs.c
@@ -24,6 +24,7 @@
#include "fuse.h"
static bool tegra_dvfs_cpu_disabled = false;
+static bool tegra_dvfs_core_disabled = true;
static const int cpu_millivolts[MAX_DVFS_FREQS] =
{750, 775, 800, 825, 850, 875, 900, 925, 950, 975, 1000, 1025, 1050, 1075, 1100, 1125};
@@ -119,6 +120,23 @@ static struct dvfs core_dvfs_table[] = {
CORE_DVFS("disp2", -1, 0, KHZ, 158000, 158000, 190000, 190000, 190000, 190000, 190000),
};
+
+int tegra_dvfs_disable_core_set(const char *arg, const struct kernel_param *kp)
+{
+ int ret;
+
+ ret = param_set_bool(arg, kp);
+ if (ret)
+ return ret;
+
+ if (tegra_dvfs_core_disabled)
+ tegra_dvfs_rail_disable(&tegra3_dvfs_rail_vdd_core);
+ else
+ tegra_dvfs_rail_enable(&tegra3_dvfs_rail_vdd_core);
+
+ return 0;
+}
+
int tegra_dvfs_disable_cpu_set(const char *arg, const struct kernel_param *kp)
{
int ret;
@@ -140,12 +158,20 @@ int tegra_dvfs_disable_get(char *buffer, const struct kernel_param *kp)
return param_get_bool(buffer, kp);
}
+static struct kernel_param_ops tegra_dvfs_disable_core_ops = {
+ .set = tegra_dvfs_disable_core_set,
+ .get = tegra_dvfs_disable_get,
+};
+
static struct kernel_param_ops tegra_dvfs_disable_cpu_ops = {
.set = tegra_dvfs_disable_cpu_set,
.get = tegra_dvfs_disable_get,
};
-module_param_cb(disable_cpu, &tegra_dvfs_disable_cpu_ops, &tegra_dvfs_cpu_disabled, 0644);
+module_param_cb(disable_core, &tegra_dvfs_disable_core_ops,
+ &tegra_dvfs_core_disabled, 0644);
+module_param_cb(disable_cpu, &tegra_dvfs_disable_cpu_ops,
+ &tegra_dvfs_cpu_disabled, 0644);
static void init_dvfs_from_table(struct dvfs *dvfs_table, int table_size,
int speedo_id, int process_id)
@@ -186,6 +212,9 @@ void __init tegra_soc_init_dvfs(void)
int cpu_process_id = 0; /* FIXME: get real CPU process ID */
int core_process_id = 0; /* FIXME: get real core process ID */
+#ifndef CONFIG_TEGRA_CORE_DVFS
+ tegra_dvfs_cpu_disabled = true;
+#endif
#ifndef CONFIG_TEGRA_CPU_DVFS
tegra_dvfs_cpu_disabled = true;
#endif
@@ -199,6 +228,8 @@ void __init tegra_soc_init_dvfs(void)
init_dvfs_from_table(core_dvfs_table, ARRAY_SIZE(core_dvfs_table),
speedo_id, core_process_id);
+ if (tegra_dvfs_core_disabled)
+ tegra_dvfs_rail_disable(&tegra3_dvfs_rail_vdd_core);
if (tegra_dvfs_cpu_disabled)
tegra_dvfs_rail_disable(&tegra3_dvfs_rail_vdd_cpu);
}