Provide a mutex to protect against format changes on the pads. The mutex can also be used to protect against control changes, or other userspace facing interactions as necessary Signed-off-by: Kieran Bingham <kieran.bingham+renesas@xxxxxxxxxxxxxxxx> --- drivers/media/i2c/max9286.c | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/drivers/media/i2c/max9286.c b/drivers/media/i2c/max9286.c index 911323d6d3c4..17830c362a50 100644 --- a/drivers/media/i2c/max9286.c +++ b/drivers/media/i2c/max9286.c @@ -18,6 +18,7 @@ #include <linux/i2c.h> #include <linux/i2c-mux.h> #include <linux/module.h> +#include <linux/mutex.h> #include <linux/of_graph.h> #include <linux/regulator/consumer.h> #include <linux/slab.h> @@ -157,6 +158,9 @@ struct max9286_priv { struct v4l2_mbus_framefmt fmt[MAX9286_N_SINKS]; + /* Protects controls and fmt structures */ + struct mutex mutex; + unsigned int nsources; unsigned int source_mask; unsigned int route_mask; @@ -680,7 +684,9 @@ static int max9286_set_fmt(struct v4l2_subdev *sd, if (!cfg_fmt) return -EINVAL; + mutex_lock(&priv->mutex); *cfg_fmt = format->format; + mutex_unlock(&priv->mutex); return 0; } @@ -699,7 +705,9 @@ static int max9286_get_fmt(struct v4l2_subdev *sd, if (!cfg_fmt) return -EINVAL; + mutex_lock(&priv->mutex); format->format = *cfg_fmt; + mutex_unlock(&priv->mutex); return 0; } @@ -1148,6 +1156,8 @@ static int max9286_probe(struct i2c_client *client) if (!priv) return -ENOMEM; + mutex_init(&priv->mutex); + priv->client = client; i2c_set_clientdata(client, priv); -- 2.20.1