|
Kyle McMartin |
4bd3ae5 |
From 1b3df4f489345b0fd6e83645ad5d464aee55f7de Mon Sep 17 00:00:00 2001
|
|
Kyle McMartin |
4bd3ae5 |
From: David Kilroy <kilroyd@googlemail.com>
|
|
Kyle McMartin |
4bd3ae5 |
Date: Sat, 4 Dec 2010 18:36:30 +0000
|
|
Kyle McMartin |
4bd3ae5 |
Subject: [PATCH] orinoco: initialise priv->hw before assigning the interrupt
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
The interrupt handler takes a lock - but since commit bcad6e80f3f this
|
|
Kyle McMartin |
4bd3ae5 |
lock goes through an indirection specified in the hermes_t structure.
|
|
Kyle McMartin |
4bd3ae5 |
We must therefore initialise the structure before setting up the
|
|
Kyle McMartin |
4bd3ae5 |
interrupt handler.
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
<https://bugzilla.kernel.org/show_bug.cgi?id=23932>
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
Fix both orinoco_cs and spectrum_cs
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
Bisected by: Matt Domsch <Matt_Domsch@dell.com>
|
|
Kyle McMartin |
4bd3ae5 |
Tested by: Matt Domsch <Matt_Domsch@dell.com>
|
|
Kyle McMartin |
4bd3ae5 |
Signed-off by: David Kilroy <kilroyd@googlemail.com>
|
|
Kyle McMartin |
4bd3ae5 |
---
|
|
Kyle McMartin |
4bd3ae5 |
drivers/net/wireless/orinoco/orinoco_cs.c | 12 ++++++------
|
|
Kyle McMartin |
4bd3ae5 |
drivers/net/wireless/orinoco/spectrum_cs.c | 12 ++++++------
|
|
Kyle McMartin |
4bd3ae5 |
2 files changed, 12 insertions(+), 12 deletions(-)
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
diff --git a/drivers/net/wireless/orinoco/orinoco_cs.c b/drivers/net/wireless/orinoco/orinoco_cs.c
|
|
Kyle McMartin |
4bd3ae5 |
index b16d5db..66c7bcc 100644
|
|
Kyle McMartin |
4bd3ae5 |
--- a/drivers/net/wireless/orinoco/orinoco_cs.c
|
|
Kyle McMartin |
4bd3ae5 |
+++ b/drivers/net/wireless/orinoco/orinoco_cs.c
|
|
Kyle McMartin |
4bd3ae5 |
@@ -251,19 +251,19 @@ orinoco_cs_config(struct pcmcia_device *link)
|
|
Kyle McMartin |
4bd3ae5 |
goto failed;
|
|
Kyle McMartin |
4bd3ae5 |
}
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
- ret = pcmcia_request_irq(link, orinoco_interrupt);
|
|
Kyle McMartin |
4bd3ae5 |
- if (ret)
|
|
Kyle McMartin |
4bd3ae5 |
+ mem = ioport_map(link->io.BasePort1, link->io.NumPorts1);
|
|
Kyle McMartin |
4bd3ae5 |
+ if (!mem)
|
|
Kyle McMartin |
4bd3ae5 |
goto failed;
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
/* We initialize the hermes structure before completing PCMCIA
|
|
Kyle McMartin |
4bd3ae5 |
* configuration just in case the interrupt handler gets
|
|
Kyle McMartin |
4bd3ae5 |
* called. */
|
|
Kyle McMartin |
4bd3ae5 |
- mem = ioport_map(link->io.BasePort1, link->io.NumPorts1);
|
|
Kyle McMartin |
4bd3ae5 |
- if (!mem)
|
|
Kyle McMartin |
4bd3ae5 |
- goto failed;
|
|
Kyle McMartin |
4bd3ae5 |
-
|
|
Kyle McMartin |
4bd3ae5 |
hermes_struct_init(hw, mem, HERMES_16BIT_REGSPACING);
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
+ ret = pcmcia_request_irq(link, orinoco_interrupt);
|
|
Kyle McMartin |
4bd3ae5 |
+ if (ret)
|
|
Kyle McMartin |
4bd3ae5 |
+ goto failed;
|
|
Kyle McMartin |
4bd3ae5 |
+
|
|
Kyle McMartin |
4bd3ae5 |
/*
|
|
Kyle McMartin |
4bd3ae5 |
* This actually configures the PCMCIA socket -- setting up
|
|
Kyle McMartin |
4bd3ae5 |
* the I/O windows and the interrupt mapping, and putting the
|
|
Kyle McMartin |
4bd3ae5 |
diff --git a/drivers/net/wireless/orinoco/spectrum_cs.c b/drivers/net/wireless/orinoco/spectrum_cs.c
|
|
Kyle McMartin |
4bd3ae5 |
index b51a9ad..0148763 100644
|
|
Kyle McMartin |
4bd3ae5 |
--- a/drivers/net/wireless/orinoco/spectrum_cs.c
|
|
Kyle McMartin |
4bd3ae5 |
+++ b/drivers/net/wireless/orinoco/spectrum_cs.c
|
|
Kyle McMartin |
4bd3ae5 |
@@ -325,20 +325,20 @@ spectrum_cs_config(struct pcmcia_device *link)
|
|
Kyle McMartin |
4bd3ae5 |
goto failed;
|
|
Kyle McMartin |
4bd3ae5 |
}
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
- ret = pcmcia_request_irq(link, orinoco_interrupt);
|
|
Kyle McMartin |
4bd3ae5 |
- if (ret)
|
|
Kyle McMartin |
4bd3ae5 |
+ mem = ioport_map(link->io.BasePort1, link->io.NumPorts1);
|
|
Kyle McMartin |
4bd3ae5 |
+ if (!mem)
|
|
Kyle McMartin |
4bd3ae5 |
goto failed;
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
/* We initialize the hermes structure before completing PCMCIA
|
|
Kyle McMartin |
4bd3ae5 |
* configuration just in case the interrupt handler gets
|
|
Kyle McMartin |
4bd3ae5 |
* called. */
|
|
Kyle McMartin |
4bd3ae5 |
- mem = ioport_map(link->io.BasePort1, link->io.NumPorts1);
|
|
Kyle McMartin |
4bd3ae5 |
- if (!mem)
|
|
Kyle McMartin |
4bd3ae5 |
- goto failed;
|
|
Kyle McMartin |
4bd3ae5 |
-
|
|
Kyle McMartin |
4bd3ae5 |
hermes_struct_init(hw, mem, HERMES_16BIT_REGSPACING);
|
|
Kyle McMartin |
4bd3ae5 |
hw->eeprom_pda = true;
|
|
Kyle McMartin |
4bd3ae5 |
|
|
Kyle McMartin |
4bd3ae5 |
+ ret = pcmcia_request_irq(link, orinoco_interrupt);
|
|
Kyle McMartin |
4bd3ae5 |
+ if (ret)
|
|
Kyle McMartin |
4bd3ae5 |
+ goto failed;
|
|
Kyle McMartin |
4bd3ae5 |
+
|
|
Kyle McMartin |
4bd3ae5 |
/*
|
|
Kyle McMartin |
4bd3ae5 |
* This actually configures the PCMCIA socket -- setting up
|
|
Kyle McMartin |
4bd3ae5 |
* the I/O windows and the interrupt mapping, and putting the
|
|
Kyle McMartin |
4bd3ae5 |
--
|
|
Kyle McMartin |
4bd3ae5 |
1.7.2.2
|
|
Kyle McMartin |
4bd3ae5 |
|