/*- * 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. * * $Id: autoconf.c,v 1.11 1998/10/06 08:38:04 dfr Exp $ */ #include "opt_bootp.h" #include "opt_ffs.h" #include "opt_cd9660.h" #include "opt_mfs.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 #include #include #include "scbus.h" static void configure __P((void *)); SYSINIT(configure, SI_SUB_CONFIGURE, SI_ORDER_FIRST, configure, NULL) static void configure_finish __P((void)); static void configure_start __P((void)); device_t isa_bus_device = 0; struct cam_sim *boot_sim = 0; extern void xpt_init __P((void)); static void configure_start() { #if NSCBUS > 0 xpt_init(); #endif } static void configure_finish() { } extern void pci_configure(void); 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_bus(void) { return atoi(bootdev_field(1)); } static int bootdev_slot(void) { return atoi(bootdev_field(2)); } static int bootdev_channel(void) { return atoi(bootdev_field(3)); } static const char * bootdev_remote_address(void) { return bootdev_field(4); } static int bootdev_unit(void) { return atoi(bootdev_field(5)); } static int bootdev_boot_dev_type(void) { return atoi(bootdev_field(6)); } static const char * bootdev_ctrl_dev_type(void) { return bootdev_field(7); } void alpha_register_pci_scsi(int bus, int slot, struct cam_sim *sim) { if (!strcmp(bootdev_protocol(), "SCSI")) { int boot_slot = bootdev_slot(); if (bus == boot_slot / 1000 && slot == boot_slot % 1000) boot_sim = sim; } } /* * Determine i/o configuration for a machine. */ static void configure(void *dummy) { configure_start(); device_add_child(root_bus, platform.iobus, 0, 0); root_bus_configure(); if((hwrpb->rpb_type != ST_DEC_3000_300) && (hwrpb->rpb_type != ST_DEC_3000_500)){ pci_configure(); /* * Probe ISA devices after everything. */ if (isa_bus_device) bus_generic_attach(isa_bus_device); } configure_finish(); cninit_finish(); /* * Now we're ready to handle (pending) interrupts. * XXX this is slightly misplaced. */ spl0(); cold = 0; } void cpu_rootconf() { #ifdef MFS_ROOT if (!mountrootfsname) { extern u_char *mfs_getimage __P((void)); if (bootverbose) printf("Considering MFS root f/s.\n"); if (mfs_getimage()) mountrootfsname = "mfs"; else if (bootverbose) printf("No MFS image available as root f/s.\n"); } #endif #if defined(FFS) || defined(FFS_ROOT) if (!mountrootfsname) { static char rootname[] = "da0a"; if (bootverbose) printf("Considering UFS root f/s.\n"); mountrootfsname = "ufs"; if (boot_sim) { struct cam_path *path; struct cam_periph *periph; xpt_create_path(&path, NULL, cam_sim_path(boot_sim), bootdev_unit() / 100, 0); periph = cam_periph_find(path, "da"); if (periph) rootdev = makedev(4, dkmakeminor(periph->unit_number, COMPATIBILITY_SLICE, 0)); xpt_free_path(path); } rootdevs[0] = rootdev; rootname[2] += dkunit(minor(rootdev)); rootdevnames[0] = rootname; } #endif } void cpu_dumpconf() { }