Browse Source

spi/pl022: Explicitly truncate large bitmask

When building on 64 bit architectures the use of bitwise negation generates
constants larger than 32 bits which won't fit in u32s used to represent
32 bit register values on the device. Explicitly cast to let the compiler
know that the higher bits are not significant and can be discarded.

Signed-off-by: Mark Brown <broonie@linaro.org>
Mark Brown 11 years ago
parent
commit
d555ea05f9
1 changed files with 1 additions and 1 deletions
  1. 1 1
      drivers/spi/spi-pl022.c

+ 1 - 1
drivers/spi/spi-pl022.c

@@ -1417,7 +1417,7 @@ static void do_interrupt_dma_transfer(struct pl022 *pl022)
 	 * Default is to enable all interrupts except RX -
 	 * Default is to enable all interrupts except RX -
 	 * this will be enabled once TX is complete
 	 * this will be enabled once TX is complete
 	 */
 	 */
-	u32 irqflags = ENABLE_ALL_INTERRUPTS & ~SSP_IMSC_MASK_RXIM;
+	u32 irqflags = (u32)(ENABLE_ALL_INTERRUPTS & ~SSP_IMSC_MASK_RXIM);
 
 
 	/* Enable target chip, if not already active */
 	/* Enable target chip, if not already active */
 	if (!pl022->next_msg_cs_active)
 	if (!pl022->next_msg_cs_active)