Commit 254cc774 authored by Felipe Balbi's avatar Felipe Balbi Committed by Greg Kroah-Hartman

serial: 8250_lpss: Switch over to MSI interrupts

Some devices support MSI interrupts. Let's at least try to use them in
platforms that provide MSI capability.

While at that, remove the now duplicated code from qrp_serial_setup().
Signed-off-by: default avatarFelipe Balbi <felipe.balbi@linux.intel.com>
Link: https://lore.kernel.org/r/20191001115825.795700-1-felipe.balbi@linux.intel.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 38b101c6
...@@ -221,17 +221,6 @@ static void qrk_serial_exit_dma(struct lpss8250 *lpss) {} ...@@ -221,17 +221,6 @@ static void qrk_serial_exit_dma(struct lpss8250 *lpss) {}
static int qrk_serial_setup(struct lpss8250 *lpss, struct uart_port *port) static int qrk_serial_setup(struct lpss8250 *lpss, struct uart_port *port)
{ {
struct pci_dev *pdev = to_pci_dev(port->dev);
int ret;
pci_set_master(pdev);
ret = pci_alloc_irq_vectors(pdev, 1, 1, PCI_IRQ_ALL_TYPES);
if (ret < 0)
return ret;
port->irq = pci_irq_vector(pdev, 0);
qrk_serial_setup_dma(lpss, port); qrk_serial_setup_dma(lpss, port);
return 0; return 0;
} }
...@@ -293,16 +282,22 @@ static int lpss8250_probe(struct pci_dev *pdev, const struct pci_device_id *id) ...@@ -293,16 +282,22 @@ static int lpss8250_probe(struct pci_dev *pdev, const struct pci_device_id *id)
if (ret) if (ret)
return ret; return ret;
pci_set_master(pdev);
lpss = devm_kzalloc(&pdev->dev, sizeof(*lpss), GFP_KERNEL); lpss = devm_kzalloc(&pdev->dev, sizeof(*lpss), GFP_KERNEL);
if (!lpss) if (!lpss)
return -ENOMEM; return -ENOMEM;
ret = pci_alloc_irq_vectors(pdev, 1, 1, PCI_IRQ_ALL_TYPES);
if (ret < 0)
return ret;
lpss->board = (struct lpss8250_board *)id->driver_data; lpss->board = (struct lpss8250_board *)id->driver_data;
memset(&uart, 0, sizeof(struct uart_8250_port)); memset(&uart, 0, sizeof(struct uart_8250_port));
uart.port.dev = &pdev->dev; uart.port.dev = &pdev->dev;
uart.port.irq = pdev->irq; uart.port.irq = pci_irq_vector(pdev, 0);
uart.port.private_data = &lpss->data; uart.port.private_data = &lpss->data;
uart.port.type = PORT_16550A; uart.port.type = PORT_16550A;
uart.port.iotype = UPIO_MEM; uart.port.iotype = UPIO_MEM;
...@@ -337,6 +332,7 @@ static int lpss8250_probe(struct pci_dev *pdev, const struct pci_device_id *id) ...@@ -337,6 +332,7 @@ static int lpss8250_probe(struct pci_dev *pdev, const struct pci_device_id *id)
err_exit: err_exit:
if (lpss->board->exit) if (lpss->board->exit)
lpss->board->exit(lpss); lpss->board->exit(lpss);
pci_free_irq_vectors(pdev);
return ret; return ret;
} }
...@@ -348,6 +344,7 @@ static void lpss8250_remove(struct pci_dev *pdev) ...@@ -348,6 +344,7 @@ static void lpss8250_remove(struct pci_dev *pdev)
if (lpss->board->exit) if (lpss->board->exit)
lpss->board->exit(lpss); lpss->board->exit(lpss);
pci_free_irq_vectors(pdev);
} }
static const struct lpss8250_board byt_board = { static const struct lpss8250_board byt_board = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment