提交 c600040f 编写于 作者: A Axel Lin 提交者: Samuel Ortiz

mfd: Remove unneeded io_mutex from struct twl6040

Current code has been converted to use regmap APIs, the io_mutex is not needed.
Thus remove the io_mutex.
Signed-off-by: NAxel Lin <axel.lin@gmail.com>
Acked-by: NPeter Ujfalusi <peter.ujfalusi@ti.com>
Signed-off-by: NSamuel Ortiz <sameo@linux.intel.com>
上级 706c96b7
...@@ -64,19 +64,15 @@ int twl6040_reg_read(struct twl6040 *twl6040, unsigned int reg) ...@@ -64,19 +64,15 @@ int twl6040_reg_read(struct twl6040 *twl6040, unsigned int reg)
int ret; int ret;
unsigned int val; unsigned int val;
mutex_lock(&twl6040->io_mutex);
/* Vibra control registers from cache */ /* Vibra control registers from cache */
if (unlikely(reg == TWL6040_REG_VIBCTLL || if (unlikely(reg == TWL6040_REG_VIBCTLL ||
reg == TWL6040_REG_VIBCTLR)) { reg == TWL6040_REG_VIBCTLR)) {
val = twl6040->vibra_ctrl_cache[VIBRACTRL_MEMBER(reg)]; val = twl6040->vibra_ctrl_cache[VIBRACTRL_MEMBER(reg)];
} else { } else {
ret = regmap_read(twl6040->regmap, reg, &val); ret = regmap_read(twl6040->regmap, reg, &val);
if (ret < 0) { if (ret < 0)
mutex_unlock(&twl6040->io_mutex);
return ret; return ret;
}
} }
mutex_unlock(&twl6040->io_mutex);
return val; return val;
} }
...@@ -86,12 +82,10 @@ int twl6040_reg_write(struct twl6040 *twl6040, unsigned int reg, u8 val) ...@@ -86,12 +82,10 @@ int twl6040_reg_write(struct twl6040 *twl6040, unsigned int reg, u8 val)
{ {
int ret; int ret;
mutex_lock(&twl6040->io_mutex);
ret = regmap_write(twl6040->regmap, reg, val); ret = regmap_write(twl6040->regmap, reg, val);
/* Cache the vibra control registers */ /* Cache the vibra control registers */
if (reg == TWL6040_REG_VIBCTLL || reg == TWL6040_REG_VIBCTLR) if (reg == TWL6040_REG_VIBCTLL || reg == TWL6040_REG_VIBCTLR)
twl6040->vibra_ctrl_cache[VIBRACTRL_MEMBER(reg)] = val; twl6040->vibra_ctrl_cache[VIBRACTRL_MEMBER(reg)] = val;
mutex_unlock(&twl6040->io_mutex);
return ret; return ret;
} }
...@@ -99,23 +93,13 @@ EXPORT_SYMBOL(twl6040_reg_write); ...@@ -99,23 +93,13 @@ EXPORT_SYMBOL(twl6040_reg_write);
int twl6040_set_bits(struct twl6040 *twl6040, unsigned int reg, u8 mask) int twl6040_set_bits(struct twl6040 *twl6040, unsigned int reg, u8 mask)
{ {
int ret; return regmap_update_bits(twl6040->regmap, reg, mask, mask);
mutex_lock(&twl6040->io_mutex);
ret = regmap_update_bits(twl6040->regmap, reg, mask, mask);
mutex_unlock(&twl6040->io_mutex);
return ret;
} }
EXPORT_SYMBOL(twl6040_set_bits); EXPORT_SYMBOL(twl6040_set_bits);
int twl6040_clear_bits(struct twl6040 *twl6040, unsigned int reg, u8 mask) int twl6040_clear_bits(struct twl6040 *twl6040, unsigned int reg, u8 mask)
{ {
int ret; return regmap_update_bits(twl6040->regmap, reg, mask, 0);
mutex_lock(&twl6040->io_mutex);
ret = regmap_update_bits(twl6040->regmap, reg, mask, 0);
mutex_unlock(&twl6040->io_mutex);
return ret;
} }
EXPORT_SYMBOL(twl6040_clear_bits); EXPORT_SYMBOL(twl6040_clear_bits);
...@@ -573,7 +557,6 @@ static int __devinit twl6040_probe(struct i2c_client *client, ...@@ -573,7 +557,6 @@ static int __devinit twl6040_probe(struct i2c_client *client,
twl6040->irq = client->irq; twl6040->irq = client->irq;
mutex_init(&twl6040->mutex); mutex_init(&twl6040->mutex);
mutex_init(&twl6040->io_mutex);
init_completion(&twl6040->ready); init_completion(&twl6040->ready);
twl6040->rev = twl6040_reg_read(twl6040, TWL6040_REG_ASICREV); twl6040->rev = twl6040_reg_read(twl6040, TWL6040_REG_ASICREV);
......
...@@ -206,7 +206,6 @@ struct twl6040 { ...@@ -206,7 +206,6 @@ struct twl6040 {
struct regmap *regmap; struct regmap *regmap;
struct regulator_bulk_data supplies[2]; /* supplies for vio, v2v1 */ struct regulator_bulk_data supplies[2]; /* supplies for vio, v2v1 */
struct mutex mutex; struct mutex mutex;
struct mutex io_mutex;
struct mutex irq_mutex; struct mutex irq_mutex;
struct mfd_cell cells[TWL6040_CELLS]; struct mfd_cell cells[TWL6040_CELLS];
struct completion ready; struct completion ready;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册