aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/misc
diff options
context:
space:
mode:
authorIra Snyder <iws@ovro.caltech.edu>2012-01-26 05:59:54 -0500
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2012-02-26 19:33:59 -0500
commit75ff85a81680e5779383aa6210a4f89ed76e40ec (patch)
treec327f25f2a51fc32382f0fcff4fee7c0532b6f15 /drivers/misc
parent6d45584fdc202fd30da655120412210153429104 (diff)
carma-fpga: fix lockdep warning
Lockdep occasionally complains with the message: INFO: HARDIRQ-safe -> HARDIRQ-unsafe lock order detected This is caused by calling videobuf_dma_unmap() under spin_lock_irq(). To fix the warning, we drop the lock before unmapping and freeing the buffer. Signed-off-by: Ira W. Snyder <iws@ovro.caltech.edu> Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'drivers/misc')
-rw-r--r--drivers/misc/carma/carma-fpga.c13
1 files changed, 11 insertions, 2 deletions
diff --git a/drivers/misc/carma/carma-fpga.c b/drivers/misc/carma/carma-fpga.c
index 14e974b2a781..4fd896deda0d 100644
--- a/drivers/misc/carma/carma-fpga.c
+++ b/drivers/misc/carma/carma-fpga.c
@@ -1079,6 +1079,7 @@ static ssize_t data_read(struct file *filp, char __user *ubuf, size_t count,
1079 struct fpga_reader *reader = filp->private_data; 1079 struct fpga_reader *reader = filp->private_data;
1080 struct fpga_device *priv = reader->priv; 1080 struct fpga_device *priv = reader->priv;
1081 struct list_head *used = &priv->used; 1081 struct list_head *used = &priv->used;
1082 bool drop_buffer = false;
1082 struct data_buf *dbuf; 1083 struct data_buf *dbuf;
1083 size_t avail; 1084 size_t avail;
1084 void *data; 1085 void *data;
@@ -1166,10 +1167,12 @@ have_buffer:
1166 * One of two things has happened, the device is disabled, or the 1167 * One of two things has happened, the device is disabled, or the
1167 * device has been reconfigured underneath us. In either case, we 1168 * device has been reconfigured underneath us. In either case, we
1168 * should just throw away the buffer. 1169 * should just throw away the buffer.
1170 *
1171 * Lockdep complains if this is done under the spinlock, so we
1172 * handle it during the unlock path.
1169 */ 1173 */
1170 if (!priv->enabled || dbuf->size != priv->bufsize) { 1174 if (!priv->enabled || dbuf->size != priv->bufsize) {
1171 videobuf_dma_unmap(priv->dev, &dbuf->vb); 1175 drop_buffer = true;
1172 data_free_buffer(dbuf);
1173 goto out_unlock; 1176 goto out_unlock;
1174 } 1177 }
1175 1178
@@ -1178,6 +1181,12 @@ have_buffer:
1178 1181
1179out_unlock: 1182out_unlock:
1180 spin_unlock_irq(&priv->lock); 1183 spin_unlock_irq(&priv->lock);
1184
1185 if (drop_buffer) {
1186 videobuf_dma_unmap(priv->dev, &dbuf->vb);
1187 data_free_buffer(dbuf);
1188 }
1189
1181 return count; 1190 return count;
1182} 1191}
1183 1192