diff options
author | Alan Cox <alan@lxorguk.ukuu.org.uk> | 2009-04-07 10:30:57 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-04-07 11:44:06 -0400 |
commit | 51dcdfec6a274afc1c6fce180d582add9ff512c0 (patch) | |
tree | 51442c7adc06f36977859e8133b645c6c42ea0c9 /drivers/parport/parport_serial.c | |
parent | 8e7d91c97570ba1a16c0b4f984c04f04f039a231 (diff) |
parport: Use the PCI IRQ if offered
PCI parallel port devices can IRQ share so we should stop them hogging
the line and making a mess on modern PC systems. We know the sharing
side works as the PCMCIA driver has shared the parallel port IRQ for
some time.
Signed-off-by: Alan Cox <alan@lxorguk.ukuu.org.uk>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers/parport/parport_serial.c')
-rw-r--r-- | drivers/parport/parport_serial.c | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/drivers/parport/parport_serial.c b/drivers/parport/parport_serial.c index f3492110b1ad..c3bb84ac931e 100644 --- a/drivers/parport/parport_serial.c +++ b/drivers/parport/parport_serial.c | |||
@@ -21,6 +21,7 @@ | |||
21 | #include <linux/module.h> | 21 | #include <linux/module.h> |
22 | #include <linux/init.h> | 22 | #include <linux/init.h> |
23 | #include <linux/pci.h> | 23 | #include <linux/pci.h> |
24 | #include <linux/interrupt.h> | ||
24 | #include <linux/parport.h> | 25 | #include <linux/parport.h> |
25 | #include <linux/parport_pc.h> | 26 | #include <linux/parport_pc.h> |
26 | #include <linux/8250_pci.h> | 27 | #include <linux/8250_pci.h> |
@@ -311,6 +312,7 @@ static int __devinit parport_register (struct pci_dev *dev, | |||
311 | int lo = card->addr[n].lo; | 312 | int lo = card->addr[n].lo; |
312 | int hi = card->addr[n].hi; | 313 | int hi = card->addr[n].hi; |
313 | unsigned long io_lo, io_hi; | 314 | unsigned long io_lo, io_hi; |
315 | int irq; | ||
314 | 316 | ||
315 | if (priv->num_par == ARRAY_SIZE (priv->port)) { | 317 | if (priv->num_par == ARRAY_SIZE (priv->port)) { |
316 | printk (KERN_WARNING | 318 | printk (KERN_WARNING |
@@ -329,10 +331,20 @@ static int __devinit parport_register (struct pci_dev *dev, | |||
329 | "hi" as an offset (see SYBA | 331 | "hi" as an offset (see SYBA |
330 | def.) */ | 332 | def.) */ |
331 | /* TODO: test if sharing interrupts works */ | 333 | /* TODO: test if sharing interrupts works */ |
332 | dev_dbg(&dev->dev, "PCI parallel port detected: I/O at " | 334 | irq = dev->irq; |
333 | "%#lx(%#lx)\n", io_lo, io_hi); | 335 | if (irq == IRQ_NONE) { |
334 | port = parport_pc_probe_port (io_lo, io_hi, PARPORT_IRQ_NONE, | 336 | dev_dbg(&dev->dev, |
335 | PARPORT_DMA_NONE, &dev->dev); | 337 | "PCI parallel port detected: I/O at %#lx(%#lx)\n", |
338 | io_lo, io_hi); | ||
339 | irq = PARPORT_IRQ_NONE; | ||
340 | } else { | ||
341 | dev_dbg(&dev->dev, | ||
342 | "PCI parallel port detected: I/O at %#lx(%#lx), IRQ %d\n", | ||
343 | io_lo, io_hi, irq); | ||
344 | irq = PARPORT_IRQ_NONE; | ||
345 | } | ||
346 | port = parport_pc_probe_port (io_lo, io_hi, irq, | ||
347 | PARPORT_DMA_NONE, &dev->dev, IRQF_SHARED); | ||
336 | if (port) { | 348 | if (port) { |
337 | priv->port[priv->num_par++] = port; | 349 | priv->port[priv->num_par++] = port; |
338 | success = 1; | 350 | success = 1; |