Commit 90b9aacf authored by Andy Shevchenko's avatar Andy Shevchenko Committed by Greg Kroah-Hartman

serial: 8250_pci: add Intel Tangier support

Intel Tangier contains 4 HSUART ports as found on Intel Edison board which are
8250 compatible. The patch adds necessary bits to the driver.

Note that the HSU port0 is currently unavailable and thus not supported.
Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 594eb4a4
...@@ -1540,6 +1540,14 @@ static void intel_mid_set_termios(struct uart_port *p, ...@@ -1540,6 +1540,14 @@ static void intel_mid_set_termios(struct uart_port *p,
serial8250_do_set_termios(p, termios, old); serial8250_do_set_termios(p, termios, old);
} }
static void intel_mid_set_termios_38_4M(struct uart_port *p,
struct ktermios *termios,
struct ktermios *old)
{
intel_mid_set_termios(p, termios, old, 38400000);
}
static void intel_mid_set_termios_50M(struct uart_port *p, static void intel_mid_set_termios_50M(struct uart_port *p,
struct ktermios *termios, struct ktermios *termios,
struct ktermios *old) struct ktermios *old)
...@@ -1636,6 +1644,27 @@ static int pnw_serial_setup(struct serial_private *priv, ...@@ -1636,6 +1644,27 @@ static int pnw_serial_setup(struct serial_private *priv,
return intel_mid_serial_setup(priv, board, port, idx, index, dma_dev); return intel_mid_serial_setup(priv, board, port, idx, index, dma_dev);
} }
#define PCI_DEVICE_ID_INTEL_TNG_UART 0x1191
static int tng_serial_setup(struct serial_private *priv,
const struct pciserial_board *board,
struct uart_8250_port *port, int idx)
{
struct pci_dev *pdev = priv->dev;
struct pci_dev *dma_dev;
int index = PCI_FUNC(pdev->devfn);
/* Currently no support for HSU port0 */
if (index-- == 0)
return -ENODEV;
dma_dev = pci_get_slot(pdev->bus, PCI_DEVFN(5, 0));
port->port.set_termios = intel_mid_set_termios_38_4M;
return intel_mid_serial_setup(priv, board, port, idx, index, dma_dev);
}
static int static int
pci_omegapci_setup(struct serial_private *priv, pci_omegapci_setup(struct serial_private *priv,
const struct pciserial_board *board, const struct pciserial_board *board,
...@@ -2112,6 +2141,13 @@ static struct pci_serial_quirk pci_serial_quirks[] __refdata = { ...@@ -2112,6 +2141,13 @@ static struct pci_serial_quirk pci_serial_quirks[] __refdata = {
.subdevice = PCI_ANY_ID, .subdevice = PCI_ANY_ID,
.setup = pnw_serial_setup, .setup = pnw_serial_setup,
}, },
{
.vendor = PCI_VENDOR_ID_INTEL,
.device = PCI_DEVICE_ID_INTEL_TNG_UART,
.subvendor = PCI_ANY_ID,
.subdevice = PCI_ANY_ID,
.setup = tng_serial_setup,
},
{ {
.vendor = PCI_VENDOR_ID_INTEL, .vendor = PCI_VENDOR_ID_INTEL,
.device = PCI_DEVICE_ID_INTEL_BSW_UART1, .device = PCI_DEVICE_ID_INTEL_BSW_UART1,
...@@ -2990,6 +3026,7 @@ enum pci_board_num_t { ...@@ -2990,6 +3026,7 @@ enum pci_board_num_t {
pbn_ce4100_1_115200, pbn_ce4100_1_115200,
pbn_byt, pbn_byt,
pbn_pnw, pbn_pnw,
pbn_tng,
pbn_qrk, pbn_qrk,
pbn_omegapci, pbn_omegapci,
pbn_NETMOS9900_2s_115200, pbn_NETMOS9900_2s_115200,
...@@ -3761,6 +3798,11 @@ static struct pciserial_board pci_boards[] = { ...@@ -3761,6 +3798,11 @@ static struct pciserial_board pci_boards[] = {
.num_ports = 1, .num_ports = 1,
.base_baud = 115200, .base_baud = 115200,
}, },
[pbn_tng] = {
.flags = FL_BASE0,
.num_ports = 1,
.base_baud = 1843200,
},
[pbn_qrk] = { [pbn_qrk] = {
.flags = FL_BASE0, .flags = FL_BASE0,
.num_ports = 1, .num_ports = 1,
...@@ -5506,6 +5548,13 @@ static struct pci_device_id serial_pci_tbl[] = { ...@@ -5506,6 +5548,13 @@ static struct pci_device_id serial_pci_tbl[] = {
PCI_ANY_ID, PCI_ANY_ID, 0, 0, PCI_ANY_ID, PCI_ANY_ID, 0, 0,
pbn_pnw}, pbn_pnw},
/*
* Intel Tangier
*/
{ PCI_VENDOR_ID_INTEL, PCI_DEVICE_ID_INTEL_TNG_UART,
PCI_ANY_ID, PCI_ANY_ID, 0, 0,
pbn_tng},
/* /*
* Intel Quark x1000 * Intel Quark x1000
*/ */
......
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