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