diff options
| author | Arnd Bergmann <arnd@arndb.de> | 2013-05-06 23:38:00 +0200 | 
|---|---|---|
| committer | Arnd Bergmann <arnd@arndb.de> | 2013-05-06 23:38:00 +0200 | 
| commit | 4183bef2e093a2f0aab45f2d5fed82b0e02aeacf (patch) | |
| tree | e84c484db3746a0f3ead0fb7a2bb9e5a42b89e85 /drivers/spi/spi-s3c64xx.c | |
| parent | 662478d060a39b8faf2b1fe2fbbb212556c2e052 (diff) | |
| parent | 775c4f66fd855e68a98fc5049003810fe98e2e20 (diff) | |
| download | olio-linux-3.10-4183bef2e093a2f0aab45f2d5fed82b0e02aeacf.tar.xz olio-linux-3.10-4183bef2e093a2f0aab45f2d5fed82b0e02aeacf.zip  | |
Merge branch 'late/dt' into next/dt2
This is support for the ARM Chromebook, originally scheduled
as a "late" pull request. Since it's already late now, we
can combine this into the existing next/dt2 branch.
* late/dt:
  ARM: exynos: dts: cros5250: add EC device
  ARM: dts: Add sbs-battery for exynos5250-snow
  ARM: dts: Add i2c-arbitrator bus for exynos5250-snow
  ARM: dts: Add chip-id controller node on Exynos4/5 SoC
  ARM: EXYNOS: Create virtual I/O mapping for Chip-ID controller using device tree
Diffstat (limited to 'drivers/spi/spi-s3c64xx.c')
| -rw-r--r-- | drivers/spi/spi-s3c64xx.c | 41 | 
1 files changed, 25 insertions, 16 deletions
diff --git a/drivers/spi/spi-s3c64xx.c b/drivers/spi/spi-s3c64xx.c index e862ab8853a..4188b2faac5 100644 --- a/drivers/spi/spi-s3c64xx.c +++ b/drivers/spi/spi-s3c64xx.c @@ -994,25 +994,30 @@ static irqreturn_t s3c64xx_spi_irq(int irq, void *data)  {  	struct s3c64xx_spi_driver_data *sdd = data;  	struct spi_master *spi = sdd->master; -	unsigned int val; +	unsigned int val, clr = 0; -	val = readl(sdd->regs + S3C64XX_SPI_PENDING_CLR); +	val = readl(sdd->regs + S3C64XX_SPI_STATUS); -	val &= S3C64XX_SPI_PND_RX_OVERRUN_CLR | -		S3C64XX_SPI_PND_RX_UNDERRUN_CLR | -		S3C64XX_SPI_PND_TX_OVERRUN_CLR | -		S3C64XX_SPI_PND_TX_UNDERRUN_CLR; - -	writel(val, sdd->regs + S3C64XX_SPI_PENDING_CLR); - -	if (val & S3C64XX_SPI_PND_RX_OVERRUN_CLR) +	if (val & S3C64XX_SPI_ST_RX_OVERRUN_ERR) { +		clr = S3C64XX_SPI_PND_RX_OVERRUN_CLR;  		dev_err(&spi->dev, "RX overrun\n"); -	if (val & S3C64XX_SPI_PND_RX_UNDERRUN_CLR) +	} +	if (val & S3C64XX_SPI_ST_RX_UNDERRUN_ERR) { +		clr |= S3C64XX_SPI_PND_RX_UNDERRUN_CLR;  		dev_err(&spi->dev, "RX underrun\n"); -	if (val & S3C64XX_SPI_PND_TX_OVERRUN_CLR) +	} +	if (val & S3C64XX_SPI_ST_TX_OVERRUN_ERR) { +		clr |= S3C64XX_SPI_PND_TX_OVERRUN_CLR;  		dev_err(&spi->dev, "TX overrun\n"); -	if (val & S3C64XX_SPI_PND_TX_UNDERRUN_CLR) +	} +	if (val & S3C64XX_SPI_ST_TX_UNDERRUN_ERR) { +		clr |= S3C64XX_SPI_PND_TX_UNDERRUN_CLR;  		dev_err(&spi->dev, "TX underrun\n"); +	} + +	/* Clear the pending irq by setting and then clearing it */ +	writel(clr, sdd->regs + S3C64XX_SPI_PENDING_CLR); +	writel(0, sdd->regs + S3C64XX_SPI_PENDING_CLR);  	return IRQ_HANDLED;  } @@ -1036,9 +1041,13 @@ static void s3c64xx_spi_hwinit(struct s3c64xx_spi_driver_data *sdd, int channel)  	writel(0, regs + S3C64XX_SPI_MODE_CFG);  	writel(0, regs + S3C64XX_SPI_PACKET_CNT); -	/* Clear any irq pending bits */ -	writel(readl(regs + S3C64XX_SPI_PENDING_CLR), -				regs + S3C64XX_SPI_PENDING_CLR); +	/* Clear any irq pending bits, should set and clear the bits */ +	val = S3C64XX_SPI_PND_RX_OVERRUN_CLR | +		S3C64XX_SPI_PND_RX_UNDERRUN_CLR | +		S3C64XX_SPI_PND_TX_OVERRUN_CLR | +		S3C64XX_SPI_PND_TX_UNDERRUN_CLR; +	writel(val, regs + S3C64XX_SPI_PENDING_CLR); +	writel(0, regs + S3C64XX_SPI_PENDING_CLR);  	writel(0, regs + S3C64XX_SPI_SWAP_CFG);  |