Commit e14432a5 authored by Antti Palosaari's avatar Antti Palosaari Committed by Mauro Carvalho Chehab

[media] tda10071: protect firmware command exec with mutex

There should be clearly some lock in order to make sure firmware
command in execution is not disturbed by another command. It has
worked as callbacks are serialized somehow pretty well and command
execution happens usually without any delays.
Signed-off-by: default avatarAntti Palosaari <crope@iki.fi>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@osg.samsung.com>
parent 54ab48ed
...@@ -61,25 +61,28 @@ static int tda10071_cmd_execute(struct tda10071_dev *dev, ...@@ -61,25 +61,28 @@ static int tda10071_cmd_execute(struct tda10071_dev *dev,
goto error; goto error;
} }
mutex_lock(&dev->cmd_execute_mutex);
/* write cmd and args for firmware */ /* write cmd and args for firmware */
ret = regmap_bulk_write(dev->regmap, 0x00, cmd->args, cmd->len); ret = regmap_bulk_write(dev->regmap, 0x00, cmd->args, cmd->len);
if (ret) if (ret)
goto error; goto error_mutex_unlock;
/* start cmd execution */ /* start cmd execution */
ret = regmap_write(dev->regmap, 0x1f, 1); ret = regmap_write(dev->regmap, 0x1f, 1);
if (ret) if (ret)
goto error; goto error_mutex_unlock;
/* wait cmd execution terminate */ /* wait cmd execution terminate */
for (i = 1000, uitmp = 1; i && uitmp; i--) { for (i = 1000, uitmp = 1; i && uitmp; i--) {
ret = regmap_read(dev->regmap, 0x1f, &uitmp); ret = regmap_read(dev->regmap, 0x1f, &uitmp);
if (ret) if (ret)
goto error; goto error_mutex_unlock;
usleep_range(200, 5000); usleep_range(200, 5000);
} }
mutex_unlock(&dev->cmd_execute_mutex);
dev_dbg(&client->dev, "loop=%d\n", i); dev_dbg(&client->dev, "loop=%d\n", i);
if (i == 0) { if (i == 0) {
...@@ -88,6 +91,8 @@ static int tda10071_cmd_execute(struct tda10071_dev *dev, ...@@ -88,6 +91,8 @@ static int tda10071_cmd_execute(struct tda10071_dev *dev,
} }
return ret; return ret;
error_mutex_unlock:
mutex_unlock(&dev->cmd_execute_mutex);
error: error:
dev_dbg(&client->dev, "failed=%d\n", ret); dev_dbg(&client->dev, "failed=%d\n", ret);
return ret; return ret;
...@@ -1167,6 +1172,7 @@ static int tda10071_probe(struct i2c_client *client, ...@@ -1167,6 +1172,7 @@ static int tda10071_probe(struct i2c_client *client,
} }
dev->client = client; dev->client = client;
mutex_init(&dev->cmd_execute_mutex);
dev->clk = pdata->clk; dev->clk = pdata->clk;
dev->i2c_wr_max = pdata->i2c_wr_max; dev->i2c_wr_max = pdata->i2c_wr_max;
dev->ts_mode = pdata->ts_mode; dev->ts_mode = pdata->ts_mode;
......
...@@ -30,6 +30,7 @@ struct tda10071_dev { ...@@ -30,6 +30,7 @@ struct tda10071_dev {
struct dvb_frontend fe; struct dvb_frontend fe;
struct i2c_client *client; struct i2c_client *client;
struct regmap *regmap; struct regmap *regmap;
struct mutex cmd_execute_mutex;
u32 clk; u32 clk;
u16 i2c_wr_max; u16 i2c_wr_max;
u8 ts_mode; u8 ts_mode;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment