Commit f5836a55 authored by Heikki Krogerus's avatar Heikki Krogerus Committed by Greg Kroah-Hartman

serial: 8250_dw: Set maxburst size

The default burst is often 1 byte which is not very optimal.
The ideal burst size when using 16550A type port would be
1/2 of fifosize, but this does not work with all Designware
implementations. Setting it to 1/4 fifosize.
Signed-off-by: default avatarHeikki Krogerus <heikki.krogerus@linux.intel.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 053fac36
...@@ -178,6 +178,7 @@ dw8250_acpi_walk_resource(struct acpi_resource *res, void *data) ...@@ -178,6 +178,7 @@ dw8250_acpi_walk_resource(struct acpi_resource *res, void *data)
slave->direction = DMA_MEM_TO_DEV; slave->direction = DMA_MEM_TO_DEV;
slave->dst_addr_width = DMA_SLAVE_BUSWIDTH_1_BYTE; slave->dst_addr_width = DMA_SLAVE_BUSWIDTH_1_BYTE;
slave->slave_id = fixed_dma->request_lines; slave->slave_id = fixed_dma->request_lines;
slave->dst_maxburst = port->tx_loadsz / 4;
dma->tx_chan_id = fixed_dma->channels; dma->tx_chan_id = fixed_dma->channels;
dma->tx_param = &dma->tx_chan_id; dma->tx_param = &dma->tx_chan_id;
...@@ -189,6 +190,7 @@ dw8250_acpi_walk_resource(struct acpi_resource *res, void *data) ...@@ -189,6 +190,7 @@ dw8250_acpi_walk_resource(struct acpi_resource *res, void *data)
slave->direction = DMA_DEV_TO_MEM; slave->direction = DMA_DEV_TO_MEM;
slave->src_addr_width = DMA_SLAVE_BUSWIDTH_1_BYTE; slave->src_addr_width = DMA_SLAVE_BUSWIDTH_1_BYTE;
slave->slave_id = fixed_dma->request_lines; slave->slave_id = fixed_dma->request_lines;
slave->src_maxburst = p->fifosize / 4;
dma->rx_chan_id = fixed_dma->channels; dma->rx_chan_id = fixed_dma->channels;
dma->rx_param = &dma->rx_chan_id; dma->rx_param = &dma->rx_chan_id;
...@@ -296,6 +298,8 @@ static int dw8250_probe(struct platform_device *pdev) ...@@ -296,6 +298,8 @@ static int dw8250_probe(struct platform_device *pdev)
uart.port.serial_in = dw8250_serial_in; uart.port.serial_in = dw8250_serial_in;
uart.port.serial_out = dw8250_serial_out; uart.port.serial_out = dw8250_serial_out;
dw8250_setup_port(&uart);
if (pdev->dev.of_node) { if (pdev->dev.of_node) {
err = dw8250_probe_of(&uart.port); err = dw8250_probe_of(&uart.port);
if (err) if (err)
...@@ -308,8 +312,6 @@ static int dw8250_probe(struct platform_device *pdev) ...@@ -308,8 +312,6 @@ static int dw8250_probe(struct platform_device *pdev)
return -ENODEV; return -ENODEV;
} }
dw8250_setup_port(&uart);
data = devm_kzalloc(&pdev->dev, sizeof(*data), GFP_KERNEL); data = devm_kzalloc(&pdev->dev, sizeof(*data), GFP_KERNEL);
if (!data) if (!data)
return -ENOMEM; return -ENOMEM;
......
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