/* $NetBSD: autoconf.c,v 1.9 2005/06/03 23:42:50 chris 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.9 2005/06/03 23:42:50 chris Exp $"); #include "opt_md.h" #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], buf[32]; const char *cp; struct device *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; sprintf(buf, "%s%d", devname, unit); TAILQ_FOREACH(dv, &alldevs, dv_list) { if (strcmp(buf, dv->dv_xname) == 0) { booted_device = dv; booted_partition = part; return; } } } static void set_root_device() { 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 ? booted_device->dv_xname : ""); setroot(booted_device, booted_partition); } /* * 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) { softintr_init(); /* * 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); /* Debugging information */ #ifndef TERSE 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 /* Time to start taking interrupts so lets open the flood gates .... */ (void)spl0(); } void device_register(struct device *dev, void *aux) { } /* End of autoconf.c */