/* $NetBSD: autoconf.c,v 1.19 2014/04/02 11:35:36 matt Exp $ */ /* * Copyright (c) 1994-1998 Mark Brinicombe. * Copyright (c) 1994 Brini. * All rights reserved. * * 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. * 3. All advertising materials mentioning features or use of this software * must display the following acknowledgement: * This product includes software developed by Mark Brinicombe for * the NetBSD project. * 4. The name of the company nor the name of the author may be used to * endorse or promote products derived from this software without specific * prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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. * * RiscBSD kernel project * * autoconf.c * * Autoconfiguration functions */ #include __KERNEL_RCSID(0, "$NetBSD: autoconf.c,v 1.19 2014/04/02 11:35:36 matt Exp $"); #include "opt_md.h" #include #include #include #include #include #include #include #include #include #include #include #include "isa.h" void isa_intr_init(void); static void get_device(const char *name); static void set_root_device(void); /* Decode a device name to a major and minor number */ static void get_device(const char *name) { int unit, part; char devname[16]; const char *cp; device_t dv; if (strncmp(name, "/dev/", 5) == 0) name += 5; if (devsw_name2blk(name, devname, sizeof(devname)) == -1) return; name += strlen(devname); unit = part = 0; cp = name; while (*cp >= '0' && *cp <= '9') unit = (unit * 10) + (*cp++ - '0'); if (cp == name) return; if (*cp >= 'a' && *cp <= ('a' + MAXPARTITIONS)) part = *cp - 'a'; else if (*cp != '\0' && *cp != ' ') return; if ((dv = device_find_by_driver_unit(devname, unit)) != NULL) { booted_device = dv; booted_partition = part; } } static void set_root_device(void) { char *ptr; if (boot_file) get_device(boot_file); if (boot_args && get_bootconf_option(boot_args, "root", BOOTOPT_TYPE_STRING, &ptr)) get_device(ptr); } /* * Set up the root device from the boot args */ void cpu_rootconf(void) { set_root_device(); printf("boot device: %s\n", booted_device != NULL ? device_xname(booted_device) : ""); rootconf(); } /* * void cpu_configure() * * Configure all the root devices * The root devices are expected to configure their own children */ extern int footbridge_imask[NIPL]; void cpu_configure(void) { footbridge_intr_evcnt_attach(); /* * Since various PCI interrupts could be routed via the ICU * (for PCI devices in the bridge) we need to set up the ICU * now so that these interrupts can be established correctly * i.e. This is a hack. */ isa_intr_init(); config_rootfound("mainbus", NULL); #if defined(DEBUG) /* Debugging information */ printf("ipl_bio=%08x ipl_net=%08x ipl_tty=%08x ipl_vm=%08x\n", footbridge_imask[IPL_BIO], footbridge_imask[IPL_NET], footbridge_imask[IPL_TTY], footbridge_imask[IPL_VM]); printf("ipl_audio=%08x ipl_imp=%08x ipl_high=%08x ipl_serial=%08x\n", footbridge_imask[IPL_AUDIO], footbridge_imask[IPL_CLOCK], footbridge_imask[IPL_HIGH], footbridge_imask[IPL_SERIAL]); #endif /* defined(DEBUG) */ /* Time to start taking interrupts so lets open the flood gates .... */ (void)spl0(); } void device_register(device_t dev, void *aux) { device_t pdev; if ((pdev = device_parent(dev)) != NULL && device_is_a(pdev, "pci")) { /* * cats builtin aceride is on 0:16:0 */ struct pci_attach_args *pa = aux; if (((pa)->pa_bus == 0 && (pa)->pa_device == 16 && (pa)->pa_function == 0)) { if (prop_dictionary_set_bool(device_properties(dev), "ali1543-ide-force-compat-mode", true) == false) { printf("WARNING: unable to set " "ali1543-ide-force-compat-mode " "property for %s\n", device_xname(dev)); } } } } /* End of autoconf.c */