Commit d52df2e2 authored by David Brownell's avatar David Brownell Committed by Linus Torvalds

spi_bitbang: always grab lock with irqs blocked

Fix a glitch reported by lockdep in the spi_bitbang code: it needs to
consistently block IRQs when holding that spinlock.
Signed-off-by: default avatarDavid Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent a2b484a2
...@@ -184,6 +184,7 @@ int spi_bitbang_setup(struct spi_device *spi) ...@@ -184,6 +184,7 @@ int spi_bitbang_setup(struct spi_device *spi)
struct spi_bitbang_cs *cs = spi->controller_state; struct spi_bitbang_cs *cs = spi->controller_state;
struct spi_bitbang *bitbang; struct spi_bitbang *bitbang;
int retval; int retval;
unsigned long flags;
bitbang = spi_master_get_devdata(spi->master); bitbang = spi_master_get_devdata(spi->master);
...@@ -222,12 +223,12 @@ int spi_bitbang_setup(struct spi_device *spi) ...@@ -222,12 +223,12 @@ int spi_bitbang_setup(struct spi_device *spi)
*/ */
/* deselect chip (low or high) */ /* deselect chip (low or high) */
spin_lock(&bitbang->lock); spin_lock_irqsave(&bitbang->lock, flags);
if (!bitbang->busy) { if (!bitbang->busy) {
bitbang->chipselect(spi, BITBANG_CS_INACTIVE); bitbang->chipselect(spi, BITBANG_CS_INACTIVE);
ndelay(cs->nsecs); ndelay(cs->nsecs);
} }
spin_unlock(&bitbang->lock); spin_unlock_irqrestore(&bitbang->lock, flags);
return 0; return 0;
} }
......
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