mirror of https://gitee.com/openkylin/linux.git
serial: 8250_exar: No need to autoconfigure Exar ports
Since we have a separate driver there is no need to autoconfigure ports, we already know what they are. Drop autoconfiguration in 8250_port and move type detection to 8250_exar. Cc: Aaron Sierra <asierra@xes-inc.com> Cc: Jan Kiszka <jan.kiszka@siemens.com> Cc: Sudip Mukherjee <sudip.mukherjee@codethink.co.uk> Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Link: https://lore.kernel.org/r/20190731170558.52897-1-andriy.shevchenko@linux.intel.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
6aa57f1618
commit
6be254c211
|
@ -36,6 +36,7 @@
|
||||||
|
|
||||||
#define UART_EXAR_INT0 0x80
|
#define UART_EXAR_INT0 0x80
|
||||||
#define UART_EXAR_8XMODE 0x88 /* 8X sampling rate select */
|
#define UART_EXAR_8XMODE 0x88 /* 8X sampling rate select */
|
||||||
|
#define UART_EXAR_DVID 0x8d /* Device identification */
|
||||||
|
|
||||||
#define UART_EXAR_FCTR 0x08 /* Feature Control Register */
|
#define UART_EXAR_FCTR 0x08 /* Feature Control Register */
|
||||||
#define UART_FCTR_EXAR_IRDA 0x10 /* IrDa data encode select */
|
#define UART_FCTR_EXAR_IRDA 0x10 /* IrDa data encode select */
|
||||||
|
@ -133,12 +134,27 @@ static int default_setup(struct exar8250 *priv, struct pci_dev *pcidev,
|
||||||
{
|
{
|
||||||
const struct exar8250_board *board = priv->board;
|
const struct exar8250_board *board = priv->board;
|
||||||
unsigned int bar = 0;
|
unsigned int bar = 0;
|
||||||
|
unsigned char status;
|
||||||
|
|
||||||
port->port.iotype = UPIO_MEM;
|
port->port.iotype = UPIO_MEM;
|
||||||
port->port.mapbase = pci_resource_start(pcidev, bar) + offset;
|
port->port.mapbase = pci_resource_start(pcidev, bar) + offset;
|
||||||
port->port.membase = priv->virt + offset;
|
port->port.membase = priv->virt + offset;
|
||||||
port->port.regshift = board->reg_shift;
|
port->port.regshift = board->reg_shift;
|
||||||
|
|
||||||
|
/*
|
||||||
|
* XR17V35x UARTs have an extra divisor register, DLD that gets enabled
|
||||||
|
* with when DLAB is set which will cause the device to incorrectly match
|
||||||
|
* and assign port type to PORT_16650. The EFR for this UART is found
|
||||||
|
* at offset 0x09. Instead check the Deice ID (DVID) register
|
||||||
|
* for a 2, 4 or 8 port UART.
|
||||||
|
*/
|
||||||
|
status = readb(port->port.membase + UART_EXAR_DVID);
|
||||||
|
if (status == 0x82 || status == 0x84 || status == 0x88) {
|
||||||
|
port->port.type = PORT_XR17V35X;
|
||||||
|
} else {
|
||||||
|
port->port.type = PORT_XR17D15X;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -494,8 +510,7 @@ exar_pci_probe(struct pci_dev *pcidev, const struct pci_device_id *ent)
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
memset(&uart, 0, sizeof(uart));
|
memset(&uart, 0, sizeof(uart));
|
||||||
uart.port.flags = UPF_SKIP_TEST | UPF_BOOT_AUTOCONF | UPF_SHARE_IRQ
|
uart.port.flags = UPF_SHARE_IRQ | UPF_EXAR_EFR | UPF_FIXED_TYPE | UPF_FIXED_PORT;
|
||||||
| UPF_EXAR_EFR;
|
|
||||||
uart.port.irq = pci_irq_vector(pcidev, 0);
|
uart.port.irq = pci_irq_vector(pcidev, 0);
|
||||||
uart.port.dev = &pcidev->dev;
|
uart.port.dev = &pcidev->dev;
|
||||||
|
|
||||||
|
|
|
@ -45,7 +45,6 @@
|
||||||
*/
|
*/
|
||||||
#define UART_EXAR_INT0 0x80
|
#define UART_EXAR_INT0 0x80
|
||||||
#define UART_EXAR_SLEEP 0x8b /* Sleep mode */
|
#define UART_EXAR_SLEEP 0x8b /* Sleep mode */
|
||||||
#define UART_EXAR_DVID 0x8d /* Device identification */
|
|
||||||
|
|
||||||
/* Nuvoton NPCM timeout register */
|
/* Nuvoton NPCM timeout register */
|
||||||
#define UART_NPCM_TOR 7
|
#define UART_NPCM_TOR 7
|
||||||
|
@ -1011,27 +1010,6 @@ static void autoconfig_16550a(struct uart_8250_port *up)
|
||||||
up->port.type = PORT_16550A;
|
up->port.type = PORT_16550A;
|
||||||
up->capabilities |= UART_CAP_FIFO;
|
up->capabilities |= UART_CAP_FIFO;
|
||||||
|
|
||||||
/*
|
|
||||||
* XR17V35x UARTs have an extra divisor register, DLD
|
|
||||||
* that gets enabled with when DLAB is set which will
|
|
||||||
* cause the device to incorrectly match and assign
|
|
||||||
* port type to PORT_16650. The EFR for this UART is
|
|
||||||
* found at offset 0x09. Instead check the Deice ID (DVID)
|
|
||||||
* register for a 2, 4 or 8 port UART.
|
|
||||||
*/
|
|
||||||
if (up->port.flags & UPF_EXAR_EFR) {
|
|
||||||
status1 = serial_in(up, UART_EXAR_DVID);
|
|
||||||
if (status1 == 0x82 || status1 == 0x84 || status1 == 0x88) {
|
|
||||||
DEBUG_AUTOCONF("Exar XR17V35x ");
|
|
||||||
up->port.type = PORT_XR17V35X;
|
|
||||||
up->capabilities |= UART_CAP_AFE | UART_CAP_EFR |
|
|
||||||
UART_CAP_SLEEP;
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Check for presence of the EFR when DLAB is set.
|
* Check for presence of the EFR when DLAB is set.
|
||||||
* Only ST16C650V1 UARTs pass this test.
|
* Only ST16C650V1 UARTs pass this test.
|
||||||
|
@ -1170,18 +1148,6 @@ static void autoconfig_16550a(struct uart_8250_port *up)
|
||||||
}
|
}
|
||||||
serial_out(up, UART_IER, iersave);
|
serial_out(up, UART_IER, iersave);
|
||||||
|
|
||||||
/*
|
|
||||||
* Exar uarts have EFR in a weird location
|
|
||||||
*/
|
|
||||||
if (up->port.flags & UPF_EXAR_EFR) {
|
|
||||||
DEBUG_AUTOCONF("Exar XR17D15x ");
|
|
||||||
up->port.type = PORT_XR17D15X;
|
|
||||||
up->capabilities |= UART_CAP_AFE | UART_CAP_EFR |
|
|
||||||
UART_CAP_SLEEP;
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We distinguish between 16550A and U6 16550A by counting
|
* We distinguish between 16550A and U6 16550A by counting
|
||||||
* how many bytes are in the FIFO.
|
* how many bytes are in the FIFO.
|
||||||
|
|
Loading…
Reference in New Issue