Commit dcdc7e09 authored by Andy Shevchenko's avatar Andy Shevchenko Committed by Greg Kroah-Hartman

serial: 8250_aspeed_vuart: Switch to use uart_read_port_properties()

Since we have now a common helper to read port properties
use it instead of sparse home grown solution.
Reviewed-by: default avatarAndi Shyti <andi.shyti@linux.intel.com>
Signed-off-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
Reviewed-by: default avatarAndrew Jeffery <andrew@codeconstruct.com.au>
Link: https://lore.kernel.org/r/20240304123035.758700-5-andriy.shevchenko@linux.intel.comSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent e894b600
...@@ -419,8 +419,8 @@ static int aspeed_vuart_probe(struct platform_device *pdev) ...@@ -419,8 +419,8 @@ static int aspeed_vuart_probe(struct platform_device *pdev)
struct aspeed_vuart *vuart; struct aspeed_vuart *vuart;
struct device_node *np; struct device_node *np;
struct resource *res; struct resource *res;
u32 clk, prop, sirq[2];
int rc, sirq_polarity; int rc, sirq_polarity;
u32 prop, sirq[2];
struct clk *vclk; struct clk *vclk;
np = pdev->dev.of_node; np = pdev->dev.of_node;
...@@ -447,53 +447,35 @@ static int aspeed_vuart_probe(struct platform_device *pdev) ...@@ -447,53 +447,35 @@ static int aspeed_vuart_probe(struct platform_device *pdev)
port.port.status = UPSTAT_SYNC_FIFO; port.port.status = UPSTAT_SYNC_FIFO;
port.port.dev = &pdev->dev; port.port.dev = &pdev->dev;
port.port.has_sysrq = IS_ENABLED(CONFIG_SERIAL_8250_CONSOLE); port.port.has_sysrq = IS_ENABLED(CONFIG_SERIAL_8250_CONSOLE);
port.port.flags = UPF_BOOT_AUTOCONF | UPF_IOREMAP | UPF_FIXED_PORT | UPF_FIXED_TYPE |
UPF_NO_THRE_TEST;
port.bugs |= UART_BUG_TXRACE; port.bugs |= UART_BUG_TXRACE;
rc = sysfs_create_group(&vuart->dev->kobj, &aspeed_vuart_attr_group); rc = sysfs_create_group(&vuart->dev->kobj, &aspeed_vuart_attr_group);
if (rc < 0) if (rc < 0)
return rc; return rc;
if (of_property_read_u32(np, "clock-frequency", &clk)) { rc = uart_read_port_properties(&port.port);
if (rc)
goto err_sysfs_remove;
/* Get clk rate through clk driver if present */
if (!port.port.uartclk) {
vclk = devm_clk_get_enabled(dev, NULL); vclk = devm_clk_get_enabled(dev, NULL);
if (IS_ERR(vclk)) { if (IS_ERR(vclk)) {
rc = dev_err_probe(dev, PTR_ERR(vclk), "clk or clock-frequency not defined\n"); rc = dev_err_probe(dev, PTR_ERR(vclk), "clk or clock-frequency not defined\n");
goto err_sysfs_remove; goto err_sysfs_remove;
} }
clk = clk_get_rate(vclk); port.port.uartclk = clk_get_rate(vclk);
} }
/* If current-speed was set, then try not to change it. */ /* If current-speed was set, then try not to change it. */
if (of_property_read_u32(np, "current-speed", &prop) == 0) if (of_property_read_u32(np, "current-speed", &prop) == 0)
port.port.custom_divisor = clk / (16 * prop); port.port.custom_divisor = port.port.uartclk / (16 * prop);
/* Check for shifted address mapping */
if (of_property_read_u32(np, "reg-offset", &prop) == 0)
port.port.mapbase += prop;
/* Check for registers offset within the devices address range */
if (of_property_read_u32(np, "reg-shift", &prop) == 0)
port.port.regshift = prop;
/* Check for fifo size */
if (of_property_read_u32(np, "fifo-size", &prop) == 0)
port.port.fifosize = prop;
/* Check for a fixed line number */
rc = of_alias_get_id(np, "serial");
if (rc >= 0)
port.port.line = rc;
port.port.irq = irq_of_parse_and_map(np, 0);
port.port.handle_irq = aspeed_vuart_handle_irq; port.port.handle_irq = aspeed_vuart_handle_irq;
port.port.iotype = UPIO_MEM;
port.port.type = PORT_ASPEED_VUART; port.port.type = PORT_ASPEED_VUART;
port.port.uartclk = clk;
port.port.flags = UPF_SHARE_IRQ | UPF_BOOT_AUTOCONF | UPF_IOREMAP
| UPF_FIXED_PORT | UPF_FIXED_TYPE | UPF_NO_THRE_TEST;
if (of_property_read_bool(np, "no-loopback-test"))
port.port.flags |= UPF_SKIP_TEST;
if (port.port.fifosize) if (port.port.fifosize)
port.capabilities = UART_CAP_FIFO; port.capabilities = UART_CAP_FIFO;
...@@ -503,7 +485,7 @@ static int aspeed_vuart_probe(struct platform_device *pdev) ...@@ -503,7 +485,7 @@ static int aspeed_vuart_probe(struct platform_device *pdev)
rc = serial8250_register_8250_port(&port); rc = serial8250_register_8250_port(&port);
if (rc < 0) if (rc < 0)
goto err_clk_disable; goto err_sysfs_remove;
vuart->line = rc; vuart->line = rc;
vuart->port = serial8250_get_port(vuart->line); vuart->port = serial8250_get_port(vuart->line);
...@@ -529,7 +511,7 @@ static int aspeed_vuart_probe(struct platform_device *pdev) ...@@ -529,7 +511,7 @@ static int aspeed_vuart_probe(struct platform_device *pdev)
rc = aspeed_vuart_set_lpc_address(vuart, prop); rc = aspeed_vuart_set_lpc_address(vuart, prop);
if (rc < 0) { if (rc < 0) {
dev_err_probe(dev, rc, "invalid value in aspeed,lpc-io-reg property\n"); dev_err_probe(dev, rc, "invalid value in aspeed,lpc-io-reg property\n");
goto err_clk_disable; goto err_sysfs_remove;
} }
rc = of_property_read_u32_array(np, "aspeed,lpc-interrupts", sirq, 2); rc = of_property_read_u32_array(np, "aspeed,lpc-interrupts", sirq, 2);
...@@ -541,14 +523,14 @@ static int aspeed_vuart_probe(struct platform_device *pdev) ...@@ -541,14 +523,14 @@ static int aspeed_vuart_probe(struct platform_device *pdev)
rc = aspeed_vuart_set_sirq(vuart, sirq[0]); rc = aspeed_vuart_set_sirq(vuart, sirq[0]);
if (rc < 0) { if (rc < 0) {
dev_err_probe(dev, rc, "invalid sirq number in aspeed,lpc-interrupts property\n"); dev_err_probe(dev, rc, "invalid sirq number in aspeed,lpc-interrupts property\n");
goto err_clk_disable; goto err_sysfs_remove;
} }
sirq_polarity = aspeed_vuart_map_irq_polarity(sirq[1]); sirq_polarity = aspeed_vuart_map_irq_polarity(sirq[1]);
if (sirq_polarity < 0) { if (sirq_polarity < 0) {
rc = dev_err_probe(dev, sirq_polarity, rc = dev_err_probe(dev, sirq_polarity,
"invalid sirq polarity in aspeed,lpc-interrupts property\n"); "invalid sirq polarity in aspeed,lpc-interrupts property\n");
goto err_clk_disable; goto err_sysfs_remove;
} }
aspeed_vuart_set_sirq_polarity(vuart, sirq_polarity); aspeed_vuart_set_sirq_polarity(vuart, sirq_polarity);
...@@ -559,8 +541,6 @@ static int aspeed_vuart_probe(struct platform_device *pdev) ...@@ -559,8 +541,6 @@ static int aspeed_vuart_probe(struct platform_device *pdev)
return 0; return 0;
err_clk_disable:
irq_dispose_mapping(port.port.irq);
err_sysfs_remove: err_sysfs_remove:
sysfs_remove_group(&vuart->dev->kobj, &aspeed_vuart_attr_group); sysfs_remove_group(&vuart->dev->kobj, &aspeed_vuart_attr_group);
return rc; return rc;
......
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