aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJan Kiszka <jan.kiszka@siemens.com>2017-02-08 11:09:09 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-02-10 09:13:26 -0500
commit172c33cb61da0df5ccbdf1a8e736c8837d165a00 (patch)
treec4970cf40db51135afffcdaf524477c0e85ef1b2
parent7e12357ed64afdc8e60d64b8f8f17d711acf950a (diff)
serial: exar: Enable MSI support
Use pci_alloc_irq_vectors to enable MSI when available. At least the XR17V352 supports this. Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/tty/serial/8250/8250_exar.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/drivers/tty/serial/8250/8250_exar.c b/drivers/tty/serial/8250/8250_exar.c
index f612da326e82..b89c4ffc0486 100644
--- a/drivers/tty/serial/8250/8250_exar.c
+++ b/drivers/tty/serial/8250/8250_exar.c
@@ -283,10 +283,16 @@ exar_pci_probe(struct pci_dev *pcidev, const struct pci_device_id *ent)
283 283
284 priv->board = board; 284 priv->board = board;
285 285
286 pci_set_master(pcidev);
287
288 rc = pci_alloc_irq_vectors(pcidev, 1, 1, PCI_IRQ_ALL_TYPES);
289 if (rc < 0)
290 return rc;
291
286 memset(&uart, 0, sizeof(uart)); 292 memset(&uart, 0, sizeof(uart));
287 uart.port.flags = UPF_SKIP_TEST | UPF_BOOT_AUTOCONF | UPF_SHARE_IRQ 293 uart.port.flags = UPF_SKIP_TEST | UPF_BOOT_AUTOCONF | UPF_SHARE_IRQ
288 | UPF_EXAR_EFR; 294 | UPF_EXAR_EFR;
289 uart.port.irq = pcidev->irq; 295 uart.port.irq = pci_irq_vector(pcidev, 0);
290 uart.port.dev = &pcidev->dev; 296 uart.port.dev = &pcidev->dev;
291 297
292 for (i = 0; i < nr_ports && i < maxnr; i++) { 298 for (i = 0; i < nr_ports && i < maxnr; i++) {