serial: 8250_fintek: Add F81216 Support

Fintek F81216 is a LPC to 4 UARTs device. It's the F81216 series but
support less functional than F81216AD/F81216H

The following list is brief descriptions of F81216 series:

F81216H (0105)
	9Bit/High baud rate(not implements with mainline)
	RS485, 128Bytes FIFO (implemented)

F81216AD (0216)
	9Bit(not implements with mainline)
	RS485(implemented)

F81216 (0208)
	basically 16550A

Suggested-by: Ricardo Ribalda Delgado <ricardo.ribalda@gmail.com>
Signed-off-by: Ji-Ze Hong (Peter Hong) <hpeter+linux_kernel@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
Ji-Ze Hong (Peter Hong) 2016-10-04 16:28:02 +08:00 коммит произвёл Greg Kroah-Hartman
Родитель c2236facae
Коммит 1e26c472c1
1 изменённых файлов: 24 добавлений и 2 удалений

Просмотреть файл

@ -23,6 +23,7 @@
#define CHIP_ID2 0x21 #define CHIP_ID2 0x21
#define CHIP_ID_F81216AD 0x1602 #define CHIP_ID_F81216AD 0x1602
#define CHIP_ID_F81216H 0x0501 #define CHIP_ID_F81216H 0x0501
#define CHIP_ID_F81216 0x0802
#define VENDOR_ID1 0x23 #define VENDOR_ID1 0x23
#define VENDOR_ID1_VAL 0x19 #define VENDOR_ID1_VAL 0x19
#define VENDOR_ID2 0x24 #define VENDOR_ID2 0x24
@ -107,8 +108,14 @@ static int fintek_8250_check_id(struct fintek_8250 *pdata)
chip = sio_read_reg(pdata, CHIP_ID1); chip = sio_read_reg(pdata, CHIP_ID1);
chip |= sio_read_reg(pdata, CHIP_ID2) << 8; chip |= sio_read_reg(pdata, CHIP_ID2) << 8;
if (chip != CHIP_ID_F81216AD && chip != CHIP_ID_F81216H) switch (chip) {
case CHIP_ID_F81216AD:
case CHIP_ID_F81216H:
case CHIP_ID_F81216:
break;
default:
return -ENODEV; return -ENODEV;
}
pdata->pid = chip; pdata->pid = chip;
return 0; return 0;
@ -235,6 +242,21 @@ static int probe_setup_port(struct fintek_8250 *pdata, u16 io_address,
return -ENODEV; return -ENODEV;
} }
static void fintek_8250_set_rs485_handler(struct uart_8250_port *uart)
{
struct fintek_8250 *pdata = uart->port.private_data;
switch (pdata->pid) {
case CHIP_ID_F81216AD:
case CHIP_ID_F81216H:
uart->port.rs485_config = fintek_8250_rs485_config;
break;
default: /* No RS485 Auto direction functional */
break;
}
}
int fintek_8250_probe(struct uart_8250_port *uart) int fintek_8250_probe(struct uart_8250_port *uart)
{ {
struct fintek_8250 *pdata; struct fintek_8250 *pdata;
@ -248,8 +270,8 @@ int fintek_8250_probe(struct uart_8250_port *uart)
return -ENOMEM; return -ENOMEM;
memcpy(pdata, &probe_data, sizeof(probe_data)); memcpy(pdata, &probe_data, sizeof(probe_data));
uart->port.rs485_config = fintek_8250_rs485_config;
uart->port.private_data = pdata; uart->port.private_data = pdata;
fintek_8250_set_rs485_handler(uart);
return 0; return 0;
} }