提交 9e08fa50 编写于 作者: H Heikki Krogerus 提交者: Greg Kroah-Hartman

serial: 8250_dw: add dw8250_quirks function

Merging the DT and ACPI specific probe functions into
dw8250_quirks. Those functions did not have that much code
any more and some of the quirks need to be shared. This
will also allow platforms without DT or ACPI to use the
driver.
Signed-off-by: NHeikki Krogerus <heikki.krogerus@linux.intel.com>
Reviewed-by: NAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 4f042054
...@@ -283,12 +283,26 @@ static void dw8250_setup_port(struct uart_8250_port *up) ...@@ -283,12 +283,26 @@ static void dw8250_setup_port(struct uart_8250_port *up)
up->capabilities |= UART_CAP_AFE; up->capabilities |= UART_CAP_AFE;
} }
static int dw8250_probe_of(struct uart_port *p, static bool dw8250_idma_filter(struct dma_chan *chan, void *param)
struct dw8250_data *data) {
struct device *dev = param;
if (dev != chan->device->dev->parent)
return false;
return true;
}
static void dw8250_quirks(struct uart_port *p, struct dw8250_data *data)
{ {
if (p->dev->of_node) {
struct device_node *np = p->dev->of_node; struct device_node *np = p->dev->of_node;
int id; int id;
/* get index of serial line, if found in DT aliases */
id = of_alias_get_id(np, "serial");
if (id >= 0)
p->line = id;
#ifdef CONFIG_64BIT #ifdef CONFIG_64BIT
if (of_device_is_compatible(np, "cavium,octeon-3860-uart")) { if (of_device_is_compatible(np, "cavium,octeon-3860-uart")) {
p->serial_in = dw8250_serial_inq; p->serial_in = dw8250_serial_inq;
...@@ -299,45 +313,22 @@ static int dw8250_probe_of(struct uart_port *p, ...@@ -299,45 +313,22 @@ static int dw8250_probe_of(struct uart_port *p,
data->skip_autocfg = true; data->skip_autocfg = true;
} }
#endif #endif
/* get index of serial line, if found in DT aliases */ } else if (has_acpi_companion(p->dev)) {
id = of_alias_get_id(np, "serial");
if (id >= 0)
p->line = id;
return 0;
}
static bool dw8250_idma_filter(struct dma_chan *chan, void *param)
{
struct device *dev = param;
if (dev != chan->device->dev->parent)
return false;
return true;
}
static int dw8250_probe_acpi(struct uart_8250_port *up,
struct dw8250_data *data)
{
struct uart_port *p = &up->port;
p->iotype = UPIO_MEM32; p->iotype = UPIO_MEM32;
p->regshift = 2;
p->serial_in = dw8250_serial_in32; p->serial_in = dw8250_serial_in32;
p->serial_out = dw8250_serial_out32; p->serial_out = dw8250_serial_out32;
p->regshift = 2; p->set_termios = dw8250_set_termios;
}
/* Platforms with iDMA */ /* Platforms with iDMA */
if (platform_get_resource_byname(to_platform_device(up->port.dev), if (platform_get_resource_byname(to_platform_device(p->dev),
IORESOURCE_MEM, "lpss_priv")) { IORESOURCE_MEM, "lpss_priv")) {
data->dma.rx_param = up->port.dev->parent; p->set_termios = dw8250_set_termios;
data->dma.tx_param = up->port.dev->parent; data->dma.rx_param = p->dev->parent;
data->dma.tx_param = p->dev->parent;
data->dma.fn = dw8250_idma_filter; data->dma.fn = dw8250_idma_filter;
} }
up->port.set_termios = dw8250_set_termios;
return 0;
} }
static int dw8250_probe(struct platform_device *pdev) static int dw8250_probe(struct platform_device *pdev)
...@@ -468,18 +459,7 @@ static int dw8250_probe(struct platform_device *pdev) ...@@ -468,18 +459,7 @@ static int dw8250_probe(struct platform_device *pdev)
data->dma.tx_param = data; data->dma.tx_param = data;
data->dma.fn = dw8250_dma_filter; data->dma.fn = dw8250_dma_filter;
if (pdev->dev.of_node) { dw8250_quirks(p, data);
err = dw8250_probe_of(p, data);
if (err)
goto err_reset;
} else if (ACPI_HANDLE(&pdev->dev)) {
err = dw8250_probe_acpi(&uart, data);
if (err)
goto err_reset;
} else {
err = -ENODEV;
goto err_reset;
}
if (!data->skip_autocfg) if (!data->skip_autocfg)
dw8250_setup_port(&uart); dw8250_setup_port(&uart);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册