/*- * Copyright (c) 2001 Benno Rice * All rights reserved. * Copyright (c) 1998 Doug Rabson * 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. * * 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. * * $FreeBSD: src/sys/alpha/alpha/autoconf.c,v 1.39 2000/10/20 07:57:54 jhb Exp $ */ #include "opt_bootp.h" #include "opt_nfs.h" #include "opt_nfsroot.h" #include #include #include #include #include /* for BASE_SLICE, MAX_SLICES */ #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include static void configure __P((void *)); SYSINIT(configure, SI_SUB_CONFIGURE, SI_ORDER_THIRD, configure, NULL) static void configure_finish __P((void)); static void configure_start __P((void)); extern int nfs_diskless_valid; dev_t rootdev = NODEV; dev_t dumpdev = NODEV; static void configure_start() { } static void configure_finish() { } #if 0 static int atoi(const char *s) { int n = 0; while (*s >= '0' && *s <= '9') n = n * 10 + (*s++ - '0'); return n; } static const char * bootdev_field(int which) { char *p = bootinfo.booted_dev; char *q; static char field[128]; /* Skip characters to find the right field */ for (; which; which--) { while (*p != ' ' && *p != '\0') p++; if (*p) p++; } /* Copy out the field and return it */ q = field; while (*p != ' ' && *p != '\0') *q++ = *p++; *q = '\0'; return field; } static const char * bootdev_protocol(void) { return bootdev_field(0); } static int bootdev_slot(void) { return atoi(bootdev_field(2)); } static int bootdev_unit(void) { return atoi(bootdev_field(5)); } static int bootdev_bus(void) { return atoi(bootdev_field(1)); } static int bootdev_channel(void) { return atoi(bootdev_field(3)); } static const char * bootdev_remote_address(void) { return bootdev_field(4); } static int bootdev_boot_dev_type(void) { return atoi(bootdev_field(6)); } static const char * bootdev_ctrl_dev_type(void) { return bootdev_field(7); } #endif /* * Determine i/o configuration for a machine. */ static void configure(void *dummy) { configure_start(); #if 0 device_add_child(root_bus, platform.iobus, 0); root_bus_configure(); if((hwrpb->rpb_type != ST_DEC_3000_300) && (hwrpb->rpb_type != ST_DEC_3000_500)){ /* * Probe ISA devices after everything. */ #if NISA > 0 if (isa_bus_device) isa_probe_children(isa_bus_device); #endif } #endif configure_finish(); #if 0 cninit_finish(); /* * Now we're ready to handle (pending) interrupts. * XXX this is slightly misplaced. */ alpha_pal_swpipl(ALPHA_PSL_IPL_0); #endif cold = 0; } /* * Do legacy root filesystem discovery. This isn't really * needed on the Alpha, which has always used the loader. */ void cpu_rootconf() { int order = 0; #if defined(NFS) && defined(NFS_ROOT) #if !defined(BOOTP_NFSROOT) if (nfs_diskless_valid) #endif rootdevnames[order++] = "nfs:"; #endif #if defined(FFS) && defined(FFS_ROOT) rootdevnames[order++] = "ufs:da0a"; #endif } SYSINIT(cpu_rootconf, SI_SUB_ROOT_CONF, SI_ORDER_FIRST, cpu_rootconf, NULL)