gpu: ipu-v3: ipu-dmfc: Protect function ipu_dmfc_init_channel() with mutex
authorLiu Ying <gnuiyl@gmail.com>
Mon, 14 Mar 2016 08:10:08 +0000 (16:10 +0800)
committerPhilipp Zabel <p.zabel@pengutronix.de>
Thu, 31 Mar 2016 09:24:30 +0000 (11:24 +0200)
To avoid race condition issue, we should protect the function
ipu_dmfc_init_channel() with the mutex dmfc->priv->mutex, since it
configures the register DMFC_GENERAL1 at runtime which contains
several control bits for various display channels.  This matches
better with fine grained locking logic in upper layer.

Signed-off-by: Liu Ying <gnuiyl@gmail.com>
Signed-off-by: Philipp Zabel <p.zabel@pengutronix.de>
drivers/gpu/ipu-v3/ipu-dmfc.c

index 042c3958e2a099224b25cafd194e076b7150f67c..129ccfa9d1d604bfcdc7056d810534521fc304ce 100644 (file)
@@ -355,6 +355,8 @@ int ipu_dmfc_init_channel(struct dmfc_channel *dmfc, int width)
        struct ipu_dmfc_priv *priv = dmfc->priv;
        u32 dmfc_gen1;
 
+       mutex_lock(&priv->mutex);
+
        dmfc_gen1 = readl(priv->base + DMFC_GENERAL1);
 
        if ((dmfc->slots * 64 * 4) / width > dmfc->data->max_fifo_lines)
@@ -364,6 +366,8 @@ int ipu_dmfc_init_channel(struct dmfc_channel *dmfc, int width)
 
        writel(dmfc_gen1, priv->base + DMFC_GENERAL1);
 
+       mutex_unlock(&priv->mutex);
+
        return 0;
 }
 EXPORT_SYMBOL_GPL(ipu_dmfc_init_channel);