aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/spi
diff options
context:
space:
mode:
authorYong Wang <yong.y.wang@linux.intel.com>2010-09-07 03:27:27 -0400
committerGrant Likely <grant.likely@secretlab.ca>2010-09-08 12:49:50 -0400
commitcbcc062abb16d39839b3d8d4e3d20360fc21eb58 (patch)
tree8ce802ede9dd14760e9426a75c2c95c4ce2b9474 /drivers/spi
parent9d8f86b56093d7b06d81d4063d5b9a4cbf887e75 (diff)
spi/dw_spi: Allow interrupt sharing
Allow interrupt sharing since exclusive interrupt line for DW SPI controller is not provided on every platform. Signed-off-by: Yong Wang <yong.y.wang@intel.com> Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
Diffstat (limited to 'drivers/spi')
-rw-r--r--drivers/spi/dw_spi.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/drivers/spi/dw_spi.c b/drivers/spi/dw_spi.c
index d256cb00604c..11fbbf6fb07b 100644
--- a/drivers/spi/dw_spi.c
+++ b/drivers/spi/dw_spi.c
@@ -396,6 +396,11 @@ static irqreturn_t interrupt_transfer(struct dw_spi *dws)
396static irqreturn_t dw_spi_irq(int irq, void *dev_id) 396static irqreturn_t dw_spi_irq(int irq, void *dev_id)
397{ 397{
398 struct dw_spi *dws = dev_id; 398 struct dw_spi *dws = dev_id;
399 u16 irq_status, irq_mask = 0x3f;
400
401 irq_status = dw_readw(dws, isr) & irq_mask;
402 if (!irq_status)
403 return IRQ_NONE;
399 404
400 if (!dws->cur_msg) { 405 if (!dws->cur_msg) {
401 spi_mask_intr(dws, SPI_INT_TXEI); 406 spi_mask_intr(dws, SPI_INT_TXEI);
@@ -883,7 +888,7 @@ int __devinit dw_spi_add_host(struct dw_spi *dws)
883 dws->dma_inited = 0; 888 dws->dma_inited = 0;
884 dws->dma_addr = (dma_addr_t)(dws->paddr + 0x60); 889 dws->dma_addr = (dma_addr_t)(dws->paddr + 0x60);
885 890
886 ret = request_irq(dws->irq, dw_spi_irq, 0, 891 ret = request_irq(dws->irq, dw_spi_irq, IRQF_SHARED,
887 "dw_spi", dws); 892 "dw_spi", dws);
888 if (ret < 0) { 893 if (ret < 0) {
889 dev_err(&master->dev, "can not get IRQ\n"); 894 dev_err(&master->dev, "can not get IRQ\n");