Browse Source

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: David Brownell <dbrownell@users.sourceforge.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
David Brownell 17 years ago
parent
commit
d52df2e2ea
1 changed files with 3 additions and 2 deletions
  1. 3 2
      drivers/spi/spi_bitbang.c

+ 3 - 2
drivers/spi/spi_bitbang.c

@@ -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)
 	 */
 	 */
 
 
 	/* 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;
 }
 }