summaryrefslogtreecommitdiff
path: root/arch
diff options
context:
space:
mode:
authorColin Cross <ccross@android.com>2010-11-08 16:30:48 -0800
committerColin Cross <ccross@android.com>2010-11-09 15:03:27 -0800
commitd50e3188778dbd1e4159ee4d4925b2ecb970876c (patch)
tree3a528ad43b12c9f3a75df7044e1876fbbe6e2fc9 /arch
parentf58886c359db3c5056fea2d1a41d297f19e9f585 (diff)
ARM: tegra: dvfs: Add lock to dvfs_reg
Change-Id: I0496cf37da3a20d697eb4f372c32d01d49352f98 Signed-off-by: Colin Cross <ccross@android.com>
Diffstat (limited to 'arch')
-rw-r--r--arch/arm/mach-tegra/dvfs.c18
1 files changed, 15 insertions, 3 deletions
diff --git a/arch/arm/mach-tegra/dvfs.c b/arch/arm/mach-tegra/dvfs.c
index 82a10f80696f..ef58fae8afbd 100644
--- a/arch/arm/mach-tegra/dvfs.c
+++ b/arch/arm/mach-tegra/dvfs.c
@@ -40,6 +40,7 @@ struct dvfs_reg {
struct regulator *reg;
int max_millivolts;
int millivolts;
+ struct mutex lock;
};
static LIST_HEAD(dvfs_debug_list);
@@ -52,22 +53,29 @@ static int dvfs_reg_set_voltage(struct dvfs_reg *dvfs_reg)
{
int millivolts = 0;
struct dvfs *d;
+ int ret = 0;
+
+ mutex_lock(&dvfs_reg->lock);
list_for_each_entry(d, &dvfs_reg->dvfs, reg_node)
millivolts = max(d->cur_millivolts, millivolts);
if (millivolts == dvfs_reg->millivolts)
- return 0;
+ goto out;
dvfs_reg->millivolts = millivolts;
if (!dvfs_reg->reg) {
pr_warn("dvfs set voltage on %s ignored\n", dvfs_reg->reg_id);
- return 0;
+ goto out;
}
- return regulator_set_voltage(dvfs_reg->reg,
+ ret = regulator_set_voltage(dvfs_reg->reg,
millivolts * 1000, dvfs_reg->max_millivolts * 1000);
+
+out:
+ mutex_unlock(&dvfs_reg->lock);
+ return ret;
}
static int dvfs_reg_connect_to_regulator(struct dvfs_reg *dvfs_reg)
@@ -101,6 +109,7 @@ static struct dvfs_reg *get_dvfs_reg(struct dvfs *d)
goto out;
}
+ mutex_init(&dvfs_reg->lock);
INIT_LIST_HEAD(&dvfs_reg->dvfs);
dvfs_reg->reg_id = kstrdup(d->reg_id, GFP_KERNEL);
@@ -119,12 +128,15 @@ static struct dvfs_reg *attach_dvfs_reg(struct dvfs *d)
if (!dvfs_reg)
return NULL;
+ mutex_lock(&dvfs_reg->lock);
list_add_tail(&d->reg_node, &dvfs_reg->dvfs);
+
d->dvfs_reg = dvfs_reg;
if (d->max_millivolts > d->dvfs_reg->max_millivolts)
d->dvfs_reg->max_millivolts = d->max_millivolts;
d->cur_millivolts = d->max_millivolts;
+ mutex_unlock(&dvfs_reg->lock);
return dvfs_reg;
}