|
@@ -45,11 +45,10 @@ ergo_interrupt(int intno, void *dev_id)
|
|
if (!card->irq_enabled)
|
|
if (!card->irq_enabled)
|
|
return IRQ_NONE; /* other device interrupting or irq switched off */
|
|
return IRQ_NONE; /* other device interrupting or irq switched off */
|
|
|
|
|
|
- save_flags(flags);
|
|
|
|
- cli(); /* no further irqs allowed */
|
|
|
|
|
|
+ spin_lock_irqsave(&card->hysdn_lock, flags); /* no further irqs allowed */
|
|
|
|
|
|
if (!(bytein(card->iobase + PCI9050_INTR_REG) & PCI9050_INTR_REG_STAT1)) {
|
|
if (!(bytein(card->iobase + PCI9050_INTR_REG) & PCI9050_INTR_REG_STAT1)) {
|
|
- restore_flags(flags); /* restore old state */
|
|
|
|
|
|
+ spin_unlock_irqrestore(&card->hysdn_lock, flags); /* restore old state */
|
|
return IRQ_NONE; /* no interrupt requested by E1 */
|
|
return IRQ_NONE; /* no interrupt requested by E1 */
|
|
}
|
|
}
|
|
/* clear any pending ints on the board */
|
|
/* clear any pending ints on the board */
|
|
@@ -61,7 +60,7 @@ ergo_interrupt(int intno, void *dev_id)
|
|
/* start kernel task immediately after leaving all interrupts */
|
|
/* start kernel task immediately after leaving all interrupts */
|
|
if (!card->hw_lock)
|
|
if (!card->hw_lock)
|
|
schedule_work(&card->irq_queue);
|
|
schedule_work(&card->irq_queue);
|
|
- restore_flags(flags);
|
|
|
|
|
|
+ spin_unlock_irqrestore(&card->hysdn_lock, flags);
|
|
return IRQ_HANDLED;
|
|
return IRQ_HANDLED;
|
|
} /* ergo_interrupt */
|
|
} /* ergo_interrupt */
|
|
|
|
|
|
@@ -83,10 +82,9 @@ ergo_irq_bh(hysdn_card * card)
|
|
|
|
|
|
dpr = card->dpram; /* point to DPRAM */
|
|
dpr = card->dpram; /* point to DPRAM */
|
|
|
|
|
|
- save_flags(flags);
|
|
|
|
- cli();
|
|
|
|
|
|
+ spin_lock_irqsave(&card->hysdn_lock, flags);
|
|
if (card->hw_lock) {
|
|
if (card->hw_lock) {
|
|
- restore_flags(flags); /* hardware currently unavailable */
|
|
|
|
|
|
+ spin_unlock_irqrestore(&card->hysdn_lock, flags); /* hardware currently unavailable */
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
card->hw_lock = 1; /* we now lock the hardware */
|
|
card->hw_lock = 1; /* we now lock the hardware */
|
|
@@ -120,7 +118,7 @@ ergo_irq_bh(hysdn_card * card)
|
|
card->hw_lock = 0; /* free hardware again */
|
|
card->hw_lock = 0; /* free hardware again */
|
|
} while (again); /* until nothing more to do */
|
|
} while (again); /* until nothing more to do */
|
|
|
|
|
|
- restore_flags(flags);
|
|
|
|
|
|
+ spin_unlock_irqrestore(&card->hysdn_lock, flags);
|
|
} /* ergo_irq_bh */
|
|
} /* ergo_irq_bh */
|
|
|
|
|
|
|
|
|
|
@@ -137,8 +135,7 @@ ergo_stopcard(hysdn_card * card)
|
|
#ifdef CONFIG_HYSDN_CAPI
|
|
#ifdef CONFIG_HYSDN_CAPI
|
|
hycapi_capi_stop(card);
|
|
hycapi_capi_stop(card);
|
|
#endif /* CONFIG_HYSDN_CAPI */
|
|
#endif /* CONFIG_HYSDN_CAPI */
|
|
- save_flags(flags);
|
|
|
|
- cli();
|
|
|
|
|
|
+ spin_lock_irqsave(&card->hysdn_lock, flags);
|
|
val = bytein(card->iobase + PCI9050_INTR_REG); /* get actual value */
|
|
val = bytein(card->iobase + PCI9050_INTR_REG); /* get actual value */
|
|
val &= ~(PCI9050_INTR_REG_ENPCI | PCI9050_INTR_REG_EN1); /* mask irq */
|
|
val &= ~(PCI9050_INTR_REG_ENPCI | PCI9050_INTR_REG_EN1); /* mask irq */
|
|
byteout(card->iobase + PCI9050_INTR_REG, val);
|
|
byteout(card->iobase + PCI9050_INTR_REG, val);
|
|
@@ -147,7 +144,7 @@ ergo_stopcard(hysdn_card * card)
|
|
card->state = CARD_STATE_UNUSED;
|
|
card->state = CARD_STATE_UNUSED;
|
|
card->err_log_state = ERRLOG_STATE_OFF; /* currently no log active */
|
|
card->err_log_state = ERRLOG_STATE_OFF; /* currently no log active */
|
|
|
|
|
|
- restore_flags(flags);
|
|
|
|
|
|
+ spin_unlock_irqrestore(&card->hysdn_lock, flags);
|
|
} /* ergo_stopcard */
|
|
} /* ergo_stopcard */
|
|
|
|
|
|
/**************************************************************************/
|
|
/**************************************************************************/
|
|
@@ -162,12 +159,11 @@ ergo_set_errlog_state(hysdn_card * card, int on)
|
|
card->err_log_state = ERRLOG_STATE_OFF; /* must be off */
|
|
card->err_log_state = ERRLOG_STATE_OFF; /* must be off */
|
|
return;
|
|
return;
|
|
}
|
|
}
|
|
- save_flags(flags);
|
|
|
|
- cli();
|
|
|
|
|
|
+ spin_lock_irqsave(&card->hysdn_lock, flags);
|
|
|
|
|
|
if (((card->err_log_state == ERRLOG_STATE_OFF) && !on) ||
|
|
if (((card->err_log_state == ERRLOG_STATE_OFF) && !on) ||
|
|
((card->err_log_state == ERRLOG_STATE_ON) && on)) {
|
|
((card->err_log_state == ERRLOG_STATE_ON) && on)) {
|
|
- restore_flags(flags);
|
|
|
|
|
|
+ spin_unlock_irqrestore(&card->hysdn_lock, flags);
|
|
return; /* nothing to do */
|
|
return; /* nothing to do */
|
|
}
|
|
}
|
|
if (on)
|
|
if (on)
|
|
@@ -175,7 +171,7 @@ ergo_set_errlog_state(hysdn_card * card, int on)
|
|
else
|
|
else
|
|
card->err_log_state = ERRLOG_STATE_STOP; /* request stop */
|
|
card->err_log_state = ERRLOG_STATE_STOP; /* request stop */
|
|
|
|
|
|
- restore_flags(flags);
|
|
|
|
|
|
+ spin_unlock_irqrestore(&card->hysdn_lock, flags);
|
|
schedule_work(&card->irq_queue);
|
|
schedule_work(&card->irq_queue);
|
|
} /* ergo_set_errlog_state */
|
|
} /* ergo_set_errlog_state */
|
|
|
|
|
|
@@ -356,8 +352,7 @@ ergo_waitpofready(struct HYSDN_CARD *card)
|
|
|
|
|
|
if (card->debug_flags & LOG_POF_RECORD)
|
|
if (card->debug_flags & LOG_POF_RECORD)
|
|
hysdn_addlog(card, "ERGO: pof boot success");
|
|
hysdn_addlog(card, "ERGO: pof boot success");
|
|
- save_flags(flags);
|
|
|
|
- cli();
|
|
|
|
|
|
+ spin_lock_irqsave(&card->hysdn_lock, flags);
|
|
|
|
|
|
card->state = CARD_STATE_RUN; /* now card is running */
|
|
card->state = CARD_STATE_RUN; /* now card is running */
|
|
/* enable the cards interrupt */
|
|
/* enable the cards interrupt */
|
|
@@ -370,7 +365,7 @@ ergo_waitpofready(struct HYSDN_CARD *card)
|
|
dpr->ToHyInt = 1;
|
|
dpr->ToHyInt = 1;
|
|
dpr->ToPcInt = 1; /* interrupt to E1 for all cards */
|
|
dpr->ToPcInt = 1; /* interrupt to E1 for all cards */
|
|
|
|
|
|
- restore_flags(flags);
|
|
|
|
|
|
+ spin_unlock_irqrestore(&card->hysdn_lock, flags);
|
|
if ((hynet_enable & (1 << card->myid))
|
|
if ((hynet_enable & (1 << card->myid))
|
|
&& (i = hysdn_net_create(card)))
|
|
&& (i = hysdn_net_create(card)))
|
|
{
|
|
{
|
|
@@ -448,6 +443,7 @@ ergo_inithardware(hysdn_card * card)
|
|
card->waitpofready = ergo_waitpofready;
|
|
card->waitpofready = ergo_waitpofready;
|
|
card->set_errlog_state = ergo_set_errlog_state;
|
|
card->set_errlog_state = ergo_set_errlog_state;
|
|
INIT_WORK(&card->irq_queue, (void *) (void *) ergo_irq_bh, card);
|
|
INIT_WORK(&card->irq_queue, (void *) (void *) ergo_irq_bh, card);
|
|
|
|
+ card->hysdn_lock = SPIN_LOCK_UNLOCKED;
|
|
|
|
|
|
return (0);
|
|
return (0);
|
|
} /* ergo_inithardware */
|
|
} /* ergo_inithardware */
|