Commit 89ad26f5 authored by Rasmus Villemoes's avatar Rasmus Villemoes Committed by Li Yang

serial: ucc_uart: use of_property_read_u32() in ucc_uart_probe()

For this to work correctly on little-endian hosts, don't access the
device-tree properties directly in native endianness, but use the
of_property_read_u32() helper.
Reviewed-by: default avatarTimur Tabi <timur@kernel.org>
Acked-by: default avatarTimur Tabi <timur@kernel.org>
Signed-off-by: default avatarRasmus Villemoes <linux@rasmusvillemoes.dk>
Signed-off-by: default avatarLi Yang <leoyang.li@nxp.com>
parent 002dedc5
...@@ -1256,10 +1256,10 @@ static int soft_uart_init(struct platform_device *ofdev) ...@@ -1256,10 +1256,10 @@ static int soft_uart_init(struct platform_device *ofdev)
static int ucc_uart_probe(struct platform_device *ofdev) static int ucc_uart_probe(struct platform_device *ofdev)
{ {
struct device_node *np = ofdev->dev.of_node; struct device_node *np = ofdev->dev.of_node;
const unsigned int *iprop; /* Integer OF properties */
const char *sprop; /* String OF properties */ const char *sprop; /* String OF properties */
struct uart_qe_port *qe_port = NULL; struct uart_qe_port *qe_port = NULL;
struct resource res; struct resource res;
u32 val;
int ret; int ret;
/* /*
...@@ -1290,23 +1290,20 @@ static int ucc_uart_probe(struct platform_device *ofdev) ...@@ -1290,23 +1290,20 @@ static int ucc_uart_probe(struct platform_device *ofdev)
/* Get the UCC number (device ID) */ /* Get the UCC number (device ID) */
/* UCCs are numbered 1-7 */ /* UCCs are numbered 1-7 */
iprop = of_get_property(np, "cell-index", NULL); if (of_property_read_u32(np, "cell-index", &val)) {
if (!iprop) { if (of_property_read_u32(np, "device-id", &val)) {
iprop = of_get_property(np, "device-id", NULL); dev_err(&ofdev->dev, "UCC is unspecified in device tree\n");
if (!iprop) {
dev_err(&ofdev->dev, "UCC is unspecified in "
"device tree\n");
ret = -EINVAL; ret = -EINVAL;
goto out_free; goto out_free;
} }
} }
if ((*iprop < 1) || (*iprop > UCC_MAX_NUM)) { if (val < 1 || val > UCC_MAX_NUM) {
dev_err(&ofdev->dev, "no support for UCC%u\n", *iprop); dev_err(&ofdev->dev, "no support for UCC%u\n", val);
ret = -ENODEV; ret = -ENODEV;
goto out_free; goto out_free;
} }
qe_port->ucc_num = *iprop - 1; qe_port->ucc_num = val - 1;
/* /*
* In the future, we should not require the BRG to be specified in the * In the future, we should not require the BRG to be specified in the
...@@ -1350,13 +1347,12 @@ static int ucc_uart_probe(struct platform_device *ofdev) ...@@ -1350,13 +1347,12 @@ static int ucc_uart_probe(struct platform_device *ofdev)
} }
/* Get the port number, numbered 0-3 */ /* Get the port number, numbered 0-3 */
iprop = of_get_property(np, "port-number", NULL); if (of_property_read_u32(np, "port-number", &val)) {
if (!iprop) {
dev_err(&ofdev->dev, "missing port-number in device tree\n"); dev_err(&ofdev->dev, "missing port-number in device tree\n");
ret = -EINVAL; ret = -EINVAL;
goto out_free; goto out_free;
} }
qe_port->port.line = *iprop; qe_port->port.line = val;
if (qe_port->port.line >= UCC_MAX_UART) { if (qe_port->port.line >= UCC_MAX_UART) {
dev_err(&ofdev->dev, "port-number must be 0-%u\n", dev_err(&ofdev->dev, "port-number must be 0-%u\n",
UCC_MAX_UART - 1); UCC_MAX_UART - 1);
...@@ -1386,31 +1382,29 @@ static int ucc_uart_probe(struct platform_device *ofdev) ...@@ -1386,31 +1382,29 @@ static int ucc_uart_probe(struct platform_device *ofdev)
} }
} }
iprop = of_get_property(np, "brg-frequency", NULL); if (of_property_read_u32(np, "brg-frequency", &val)) {
if (!iprop) {
dev_err(&ofdev->dev, dev_err(&ofdev->dev,
"missing brg-frequency in device tree\n"); "missing brg-frequency in device tree\n");
ret = -EINVAL; ret = -EINVAL;
goto out_np; goto out_np;
} }
if (*iprop) if (val)
qe_port->port.uartclk = *iprop; qe_port->port.uartclk = val;
else { else {
/* /*
* Older versions of U-Boot do not initialize the brg-frequency * Older versions of U-Boot do not initialize the brg-frequency
* property, so in this case we assume the BRG frequency is * property, so in this case we assume the BRG frequency is
* half the QE bus frequency. * half the QE bus frequency.
*/ */
iprop = of_get_property(np, "bus-frequency", NULL); if (of_property_read_u32(np, "bus-frequency", &val)) {
if (!iprop) {
dev_err(&ofdev->dev, dev_err(&ofdev->dev,
"missing QE bus-frequency in device tree\n"); "missing QE bus-frequency in device tree\n");
ret = -EINVAL; ret = -EINVAL;
goto out_np; goto out_np;
} }
if (*iprop) if (val)
qe_port->port.uartclk = *iprop / 2; qe_port->port.uartclk = val / 2;
else { else {
dev_err(&ofdev->dev, dev_err(&ofdev->dev,
"invalid QE bus-frequency in device tree\n"); "invalid QE bus-frequency in device tree\n");
......
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