aboutsummaryrefslogtreecommitdiff
path: root/sys/dev/uart/uart_bus_fdt.c
diff options
context:
space:
mode:
authorMarcel Moolenaar <marcel@FreeBSD.org>2011-01-17 23:34:36 +0000
committerMarcel Moolenaar <marcel@FreeBSD.org>2011-01-17 23:34:36 +0000
commit3470949a74c925657875ef3fe9e584b461e6116e (patch)
tree6d6f7cfc79eec8bd71f807d87c6459650b07e71d /sys/dev/uart/uart_bus_fdt.c
parentbc35e60ec0c680cf82aaef1b5a853eaee5a24ee3 (diff)
Notes
Diffstat (limited to 'sys/dev/uart/uart_bus_fdt.c')
-rw-r--r--sys/dev/uart/uart_bus_fdt.c19
1 files changed, 11 insertions, 8 deletions
diff --git a/sys/dev/uart/uart_bus_fdt.c b/sys/dev/uart/uart_bus_fdt.c
index 27809cedcaa09..f8204b1801cb0 100644
--- a/sys/dev/uart/uart_bus_fdt.c
+++ b/sys/dev/uart/uart_bus_fdt.c
@@ -140,6 +140,15 @@ uart_cpu_getdev(int devtype, struct uart_devinfo *di)
u_long start, size;
int err;
+ uart_bus_space_mem = fdtbus_bs_tag;
+ uart_bus_space_io = NULL;
+
+ /* Allow overriding the FDT uning the environment. */
+ class = &uart_ns8250_class;
+ err = uart_getenv(devtype, di, class);
+ if (!err)
+ return (0);
+
if (devtype != UART_DEV_CONSOLE)
return (ENXIO);
@@ -183,18 +192,12 @@ uart_cpu_getdev(int devtype, struct uart_devinfo *di)
di->databits = 8;
di->stopbits = 1;
di->parity = UART_PARITY_NONE;
- di->bas.bst = fdtbus_bs_tag;
+ di->bas.bst = uart_bus_space_mem;
err = fdt_regsize(node, &start, &size);
if (err)
return (ENXIO);
start += fdt_immr_va;
- uart_bus_space_mem = fdtbus_bs_tag;
- uart_bus_space_io = NULL;
-
- if (bus_space_map(di->bas.bst, start, size, 0, &di->bas.bsh) != 0)
- return (ENXIO);
-
- return (0);
+ return (bus_space_map(di->bas.bst, start, size, 0, &di->bas.bsh));
}