mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-12 00:38:55 +00:00
m68knommu: fix fec driver interrupt races
The FEC driver has a common interrupt handler for all interrupt event types. It is raised on a number of distinct interrupt vectors. This handler can't be re-entered while processing an interrupt, so make sure all requested vectors are flagged as IRQF_DISABLED. Signed-off-by: Greg Ungerer <gerg@uclinux.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
e311f68a4e
commit
0a504779d3
@ -1253,7 +1253,7 @@ static void __inline__ fec_request_intrs(struct net_device *dev)
|
|||||||
|
|
||||||
/* Setup interrupt handlers. */
|
/* Setup interrupt handlers. */
|
||||||
for (idp = id; idp->name; idp++) {
|
for (idp = id; idp->name; idp++) {
|
||||||
if (request_irq(idp->irq, idp->handler, 0, idp->name, dev) != 0)
|
if (request_irq(idp->irq, idp->handler, IRQF_DISABLED, idp->name, dev) != 0)
|
||||||
printk("FEC: Could not allocate %s IRQ(%d)!\n", idp->name, idp->irq);
|
printk("FEC: Could not allocate %s IRQ(%d)!\n", idp->name, idp->irq);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1382,7 +1382,7 @@ static void __inline__ fec_request_intrs(struct net_device *dev)
|
|||||||
|
|
||||||
/* Setup interrupt handlers. */
|
/* Setup interrupt handlers. */
|
||||||
for (idp = id; idp->name; idp++) {
|
for (idp = id; idp->name; idp++) {
|
||||||
if (request_irq(b+idp->irq, fec_enet_interrupt, 0, idp->name, dev) != 0)
|
if (request_irq(b+idp->irq, fec_enet_interrupt, IRQF_DISABLED, idp->name, dev) != 0)
|
||||||
printk("FEC: Could not allocate %s IRQ(%d)!\n", idp->name, b+idp->irq);
|
printk("FEC: Could not allocate %s IRQ(%d)!\n", idp->name, b+idp->irq);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1553,7 +1553,7 @@ static void __inline__ fec_request_intrs(struct net_device *dev)
|
|||||||
|
|
||||||
/* Setup interrupt handlers. */
|
/* Setup interrupt handlers. */
|
||||||
for (idp = id; idp->name; idp++) {
|
for (idp = id; idp->name; idp++) {
|
||||||
if (request_irq(b+idp->irq,fec_enet_interrupt,0,idp->name,dev)!=0)
|
if (request_irq(b+idp->irq, fec_enet_interrupt, IRQF_DISABLED, idp->name,dev) != 0)
|
||||||
printk("FEC: Could not allocate %s IRQ(%d)!\n", idp->name, b+idp->irq);
|
printk("FEC: Could not allocate %s IRQ(%d)!\n", idp->name, b+idp->irq);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1680,7 +1680,7 @@ static void __inline__ fec_request_intrs(struct net_device *dev)
|
|||||||
|
|
||||||
/* Setup interrupt handlers. */
|
/* Setup interrupt handlers. */
|
||||||
for (idp = id; idp->name; idp++) {
|
for (idp = id; idp->name; idp++) {
|
||||||
if (request_irq(b+idp->irq,fec_enet_interrupt,0,idp->name,dev)!=0)
|
if (request_irq(b+idp->irq, fec_enet_interrupt, IRQF_DISABLED, idp->name,dev) != 0)
|
||||||
printk("FEC: Could not allocate %s IRQ(%d)!\n",
|
printk("FEC: Could not allocate %s IRQ(%d)!\n",
|
||||||
idp->name, b+idp->irq);
|
idp->name, b+idp->irq);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user