aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pcmcia
diff options
context:
space:
mode:
authorJens Künzer <Jens.Kuenzer@fpga.homeip.net>2010-03-06 02:02:24 -0500
committerDominik Brodowski <linux@dominikbrodowski.net>2010-03-15 09:50:16 -0400
commitba8819e991ac507fcbfa080eacdff3e7eea4dc03 (patch)
tree5818320dffb0b3a2dd7751557bb790606fe714be /drivers/pcmcia
parent28ca8dd71fc170090edca62cb8129625d01b7760 (diff)
pcmcia: allow for cb_irq to differ from pci_dev's irq in yenta_socket
cb_irq is presumed to be the same as the pci_dev's irq. This won't be true any more as soon as we allow the ISA irq to be used for Cardbus devices. Therefore, use the pci_dev's irq explicitely whenever we care about it. Part 2 of a series to allow the ISA irq to be used for Cardbus devices if the socket's PCI irq is unusable. [linux@dominikbrodowski.net: split up the original patch, commit message] Signed-off-by: Jens Kuenzer <Jens.Kuenzer@fpga.homeip.net> Signed-off-by: Dominik Brodowski <linux@dominikbrodowski.net>
Diffstat (limited to 'drivers/pcmcia')
-rw-r--r--drivers/pcmcia/yenta_socket.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/pcmcia/yenta_socket.c b/drivers/pcmcia/yenta_socket.c
index 42f6763db400..51ee68dbc613 100644
--- a/drivers/pcmcia/yenta_socket.c
+++ b/drivers/pcmcia/yenta_socket.c
@@ -329,8 +329,8 @@ static int yenta_set_socket(struct pcmcia_socket *sock, socket_state_t *state)
329 /* ISA interrupt control? */ 329 /* ISA interrupt control? */
330 intr = exca_readb(socket, I365_INTCTL); 330 intr = exca_readb(socket, I365_INTCTL);
331 intr = (intr & ~0xf); 331 intr = (intr & ~0xf);
332 if (!socket->cb_irq) { 332 if (!socket->dev->irq) {
333 intr |= state->io_irq; 333 intr |= socket->cb_irq ? socket->cb_irq : state->io_irq;
334 bridge |= CB_BRIDGE_INTR; 334 bridge |= CB_BRIDGE_INTR;
335 } 335 }
336 exca_writeb(socket, I365_INTCTL, intr); 336 exca_writeb(socket, I365_INTCTL, intr);
@@ -340,7 +340,7 @@ static int yenta_set_socket(struct pcmcia_socket *sock, socket_state_t *state)
340 reg = exca_readb(socket, I365_INTCTL) & (I365_RING_ENA | I365_INTR_ENA); 340 reg = exca_readb(socket, I365_INTCTL) & (I365_RING_ENA | I365_INTR_ENA);
341 reg |= (state->flags & SS_RESET) ? 0 : I365_PC_RESET; 341 reg |= (state->flags & SS_RESET) ? 0 : I365_PC_RESET;
342 reg |= (state->flags & SS_IOCARD) ? I365_PC_IOCARD : 0; 342 reg |= (state->flags & SS_IOCARD) ? I365_PC_IOCARD : 0;
343 if (state->io_irq != socket->cb_irq) { 343 if (state->io_irq != socket->dev->irq) {
344 reg |= state->io_irq; 344 reg |= state->io_irq;
345 bridge |= CB_BRIDGE_INTR; 345 bridge |= CB_BRIDGE_INTR;
346 } 346 }