[PATCH 2.6 IrDA] smsc-ircc2 irq retval

From: Jean Tourrilhes
Date: Mon Feb 09 2004 - 20:20:09 EST


ir262_irq_retval_smsc2.diff :
~~~~~~~~~~~~~~~~~~~~~~~~~~~
<Patch from Stephen Hemminger>
o [CORRECT] Better handling of shared IRQs in smsc-ircc2 driver.


diff -u -p linux/drivers/net/irda.d7/smsc-ircc2.c linux/drivers/net/irda/smsc-ircc2.c
--- linux/drivers/net/irda.d7/smsc-ircc2.c Wed Feb 4 11:55:57 2004
+++ linux/drivers/net/irda/smsc-ircc2.c Mon Feb 9 16:12:38 2004
@@ -154,7 +154,7 @@ static void smsc_ircc_dma_xmit_complete(
static void smsc_ircc_change_speed(void *priv, u32 speed);
static void smsc_ircc_set_sir_speed(void *priv, u32 speed);
static irqreturn_t smsc_ircc_interrupt(int irq, void *dev_id, struct pt_regs *regs);
-static void smsc_ircc_interrupt_sir(int irq, void *dev_id, struct pt_regs *regs);
+static irqreturn_t smsc_ircc_interrupt_sir(struct net_device *dev);
static void smsc_ircc_sir_start(struct smsc_ircc_cb *self);
#if SMSC_IRCC2_C_SIR_STOP
static void smsc_ircc_sir_stop(struct smsc_ircc_cb *self);
@@ -1401,9 +1401,9 @@ static irqreturn_t smsc_ircc_interrupt(i

/* Check if we should use the SIR interrupt handler */
if (self->io.speed <= SMSC_IRCC2_MAX_SIR_SPEED) {
- smsc_ircc_interrupt_sir(irq, dev_id, regs);
+ irqreturn_t ret = smsc_ircc_interrupt_sir(dev);
spin_unlock(&self->lock);
- return IRQ_HANDLED;
+ return ret;
}
iobase = self->io.fir_base;

@@ -1435,7 +1435,7 @@ static irqreturn_t smsc_ircc_interrupt(i
outb(IRCC_IER_ACTIVE_FRAME|IRCC_IER_EOM, iobase+IRCC_IER);

spin_unlock(&self->lock);
- return IRQ_HANDLED;
+ return IRQ_RETVAL(iir);
}

/*
@@ -1443,21 +1443,13 @@ static irqreturn_t smsc_ircc_interrupt(i
*
* Interrupt handler for SIR modes
*/
-void smsc_ircc_interrupt_sir(int irq, void *dev_id, struct pt_regs *regs)
+static irqreturn_t smsc_ircc_interrupt_sir(struct net_device *dev)
{
- struct net_device *dev = (struct net_device *) dev_id;
- struct smsc_ircc_cb *self;
+ struct smsc_ircc_cb *self = dev->priv;
int boguscount = 0;
int iobase;
int iir, lsr;

- if (!dev) {
- WARNING("%s() irq %d for unknown device.\n",
- __FUNCTION__, irq);
- return;
- }
- self = (struct smsc_ircc_cb *) dev->priv;
-
/* Already locked comming here in smsc_ircc_interrupt() */
/*spin_lock(&self->lock);*/

@@ -1497,6 +1489,7 @@ void smsc_ircc_interrupt_sir(int irq, vo
iir = inb(iobase + UART_IIR) & UART_IIR_ID;
}
/*spin_unlock(&self->lock);*/
+ return IRQ_RETVAL(iir);
}


-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/