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

serial: 8250_dw: don't limit DMA support to ACPI

It should be available for DT users as well. This does not
enable DMA by default except with ACPI. DT users can enable
DMA based on a property.
Signed-off-by: NHeikki Krogerus <heikki.krogerus@linux.intel.com>
Signed-off-by: NGreg Kroah-Hartman <gregkh@linuxfoundation.org>
上级 2797f6fb
...@@ -56,11 +56,12 @@ ...@@ -56,11 +56,12 @@
struct dw8250_data { struct dw8250_data {
u8 usr_reg;
int last_lcr; int last_lcr;
int last_mcr; int last_mcr;
int line; int line;
struct clk *clk; struct clk *clk;
u8 usr_reg; struct uart_8250_dma dma;
}; };
static inline int dw8250_modify_msr(struct uart_port *p, int offset, int value) static inline int dw8250_modify_msr(struct uart_port *p, int offset, int value)
...@@ -241,7 +242,8 @@ static int dw8250_probe_of(struct uart_port *p, ...@@ -241,7 +242,8 @@ static int dw8250_probe_of(struct uart_port *p,
} }
#ifdef CONFIG_ACPI #ifdef CONFIG_ACPI
static int dw8250_probe_acpi(struct uart_8250_port *up) static int dw8250_probe_acpi(struct uart_8250_port *up,
struct dw8250_data *data)
{ {
const struct acpi_device_id *id; const struct acpi_device_id *id;
struct uart_port *p = &up->port; struct uart_port *p = &up->port;
...@@ -260,9 +262,7 @@ static int dw8250_probe_acpi(struct uart_8250_port *up) ...@@ -260,9 +262,7 @@ static int dw8250_probe_acpi(struct uart_8250_port *up)
if (!p->uartclk) if (!p->uartclk)
p->uartclk = (unsigned int)id->driver_data; p->uartclk = (unsigned int)id->driver_data;
up->dma = devm_kzalloc(p->dev, sizeof(*up->dma), GFP_KERNEL); up->dma = &data->dma;
if (!up->dma)
return -ENOMEM;
up->dma->rxconf.src_maxburst = p->fifosize / 4; up->dma->rxconf.src_maxburst = p->fifosize / 4;
up->dma->txconf.dst_maxburst = p->fifosize / 4; up->dma->txconf.dst_maxburst = p->fifosize / 4;
...@@ -324,7 +324,7 @@ static int dw8250_probe(struct platform_device *pdev) ...@@ -324,7 +324,7 @@ static int dw8250_probe(struct platform_device *pdev)
if (err) if (err)
return err; return err;
} else if (ACPI_HANDLE(&pdev->dev)) { } else if (ACPI_HANDLE(&pdev->dev)) {
err = dw8250_probe_acpi(&uart); err = dw8250_probe_acpi(&uart, data);
if (err) if (err)
return err; return err;
} else { } else {
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册