diff options
author | Nathan Whitehorn <nwhitehorn@FreeBSD.org> | 2014-02-05 14:44:22 +0000 |
---|---|---|
committer | Nathan Whitehorn <nwhitehorn@FreeBSD.org> | 2014-02-05 14:44:22 +0000 |
commit | 65d08437ef519124f39f113262a3cc71dadb8569 (patch) | |
tree | a1c26991ebc26c8653ff139a31f4170c40ded476 /sys/dev/fdt | |
parent | 2fdfccfd7ccce8bb79cd88b8956aa88b39b702e5 (diff) | |
download | src-65d08437ef519124f39f113262a3cc71dadb8569.tar.gz src-65d08437ef519124f39f113262a3cc71dadb8569.zip |
Move Open Firmware device root on PowerPC, ARM, and MIPS systems to
a sub-node of nexus (ofwbus) rather than direct attach under nexus. This
fixes FDT on x86 and will make coexistence with ACPI on ARM systems easier.
SPARC is unchanged.
Reviewed by: imp, ian
Notes
Notes:
svn path=/head/; revision=261513
Diffstat (limited to 'sys/dev/fdt')
-rw-r--r-- | sys/dev/fdt/fdtbus.c | 91 | ||||
-rw-r--r-- | sys/dev/fdt/simplebus.c | 2 |
2 files changed, 1 insertions, 92 deletions
diff --git a/sys/dev/fdt/fdtbus.c b/sys/dev/fdt/fdtbus.c deleted file mode 100644 index a0ebec8e0c85..000000000000 --- a/sys/dev/fdt/fdtbus.c +++ /dev/null @@ -1,91 +0,0 @@ -/*- - * Copyright (c) 2009-2010 The FreeBSD Foundation - * All rights reserved. - * - * This software was developed by Semihalf under sponsorship from - * the FreeBSD Foundation. - * - * Redistribution and use in source and binary forms, with or without - * modification, are permitted provided that the following conditions - * are met: - * 1. Redistributions of source code must retain the above copyright - * notice, this list of conditions and the following disclaimer. - * 2. Redistributions in binary form must reproduce the above copyright - * notice, this list of conditions and the following disclaimer in the - * documentation and/or other materials provided with the distribution. - * - * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND - * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE - * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE - * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE - * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL - * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS - * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) - * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT - * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY - * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF - * SUCH DAMAGE. - */ - -#include <sys/cdefs.h> -__FBSDID("$FreeBSD$"); - -#include <sys/param.h> -#include <sys/systm.h> -#include <sys/ktr.h> -#include <sys/kernel.h> -#include <sys/module.h> -#include <sys/bus.h> -#include <sys/rman.h> -#include <sys/malloc.h> - -#include <dev/ofw/openfirm.h> -#include <dev/ofw/ofw_nexus.h> - -#include "ofw_bus_if.h" - -/* - * Prototypes. - */ -static void fdtbus_identify(driver_t *, device_t); -static int fdtbus_probe(device_t); - -/* - * Bus interface definition. - */ -static device_method_t fdtbus_methods[] = { - /* Device interface */ - DEVMETHOD(device_identify, fdtbus_identify), - DEVMETHOD(device_probe, fdtbus_probe), - - /* Bus interface */ - DEVMETHOD(bus_activate_resource, bus_generic_activate_resource), - DEVMETHOD(bus_deactivate_resource, bus_generic_deactivate_resource), - DEVMETHOD(bus_config_intr, bus_generic_config_intr), - DEVMETHOD(bus_setup_intr, bus_generic_setup_intr), - DEVMETHOD(bus_teardown_intr, bus_generic_teardown_intr), - - DEVMETHOD_END -}; - -devclass_t fdtbus_devclass; -DEFINE_CLASS_1(fdtbus, fdtbus_driver, fdtbus_methods, - sizeof(struct ofw_nexus_softc), ofw_nexus_driver); -DRIVER_MODULE(fdtbus, nexus, fdtbus_driver, fdtbus_devclass, 0, 0); - -static void -fdtbus_identify(driver_t *driver, device_t parent) -{ - - if (device_find_child(parent, "fdtbus", -1) == NULL) - BUS_ADD_CHILD(parent, 0, "fdtbus", -1); -} - -static int -fdtbus_probe(device_t dev) -{ - - device_set_desc(dev, "Flattened Device Tree"); - return (BUS_PROBE_NOWILDCARD); -} - diff --git a/sys/dev/fdt/simplebus.c b/sys/dev/fdt/simplebus.c index ee968aecbbe9..d36cba4917bd 100644 --- a/sys/dev/fdt/simplebus.c +++ b/sys/dev/fdt/simplebus.c @@ -121,7 +121,7 @@ static driver_t simplebus_driver = { sizeof(struct simplebus_softc) }; static devclass_t simplebus_devclass; -DRIVER_MODULE(simplebus, nexus, simplebus_driver, simplebus_devclass, 0, 0); +DRIVER_MODULE(simplebus, ofwbus, simplebus_driver, simplebus_devclass, 0, 0); DRIVER_MODULE(simplebus, simplebus, simplebus_driver, simplebus_devclass, 0, 0); static int |