diff options
author | Jens Künzer <Jens.Kuenzer@fpga.homeip.net> | 2010-03-06 02:02:24 -0500 |
---|---|---|
committer | Dominik Brodowski <linux@dominikbrodowski.net> | 2010-03-15 09:50:16 -0400 |
commit | ba8819e991ac507fcbfa080eacdff3e7eea4dc03 (patch) | |
tree | 5818320dffb0b3a2dd7751557bb790606fe714be /drivers/pcmcia | |
parent | 28ca8dd71fc170090edca62cb8129625d01b7760 (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.c | 6 |
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 | } |