summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/arch/powerpc/powerpc/autoconf.c87
-rw-r--r--sys/arch/powerpc/powerpc/machdep.c6
2 files changed, 56 insertions, 37 deletions
diff --git a/sys/arch/powerpc/powerpc/autoconf.c b/sys/arch/powerpc/powerpc/autoconf.c
index b53460fa60a..412a4da2a54 100644
--- a/sys/arch/powerpc/powerpc/autoconf.c
+++ b/sys/arch/powerpc/powerpc/autoconf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: autoconf.c,v 1.3 1997/10/13 13:42:53 pefo Exp $ */
+/* $OpenBSD: autoconf.c,v 1.4 1997/10/21 11:00:09 pefo Exp $ */
/*
* Copyright (c) 1996, 1997 Per Fogelstrom
* Copyright (c) 1995 Theo de Raadt
@@ -41,7 +41,7 @@
* from: Utah Hdr: autoconf.c 1.31 91/01/21
*
* from: @(#)autoconf.c 8.1 (Berkeley) 6/10/93
- * $Id: autoconf.c,v 1.3 1997/10/13 13:42:53 pefo Exp $
+ * $Id: autoconf.c,v 1.4 1997/10/21 11:00:09 pefo Exp $
*/
/*
@@ -70,6 +70,7 @@ extern void dumpconf __P((void));
static int findblkmajor __P((struct device *));
static struct device * getdisk __P((char *, int, int, dev_t *));
struct device * getdevunit __P((char *, int));
+static struct devmap * findtype __P((char **));
void makebootdev __P((char *cp));
int getpno __P((char **));
@@ -229,6 +230,7 @@ setroot()
#endif
printf("bootpath: '%s'\n", bootpath);
+ makebootdev(bootpath);
if(boothowto & RB_DFLTROOT)
return; /* Boot compiled in */
@@ -429,45 +431,67 @@ getdevunit(name, unit)
}
struct devmap {
- char *attachment;
+ char *att;
char *dev;
+ int type;
};
+#define T_BUS 0
+#define T_SCSI 1
+#define T_DISK 2
-/*
- * Look at the string 'cp' and decode the boot device.
- * Boot names look like: '/pci/scsi@c/disk@0,0/bsd'
- * (beware for empty scsi id's...)
- */
-void
-makebootdev(cp)
- char *cp;
+static struct devmap *
+findtype(s)
+ char **s;
{
- int unit, part, ctrl;
static struct devmap devmap[] = {
- { "multi", "fd" },
- { "eisa", "wd" },
- { "scsi", "sd" },
+ { "/pci", NULL, T_BUS },
+ { "/scsi@", "sd", T_SCSI },
+ { "/disk@", "sd", T_DISK },
{ NULL, NULL }
};
struct devmap *dp = &devmap[0];
- while (dp->attachment) {
- if (strncmp (cp, dp->attachment, strlen(dp->attachment)) == 0)
+ while (dp->att) {
+ if (strncmp (*s, dp->att, strlen(dp->att)) == 0) {
+ *s += strlen(dp->att);
break;
+ }
dp++;
}
- if (!dp->attachment) {
- printf("Warning: boot device unrecognized: %s\n", cp);
+ return(dp);
+}
+
+/*
+ * Look at the string 'cp' and decode the boot device.
+ * Boot names look like: '/pci/scsi@c/disk@0,0/bsd'
+ */
+void
+makebootdev(bp)
+ char *bp;
+{
+ int unit;
+ char *dev, *cp;
+ struct devmap *dp;
+
+ cp = bp;
+ do {
+ dp = findtype(&cp);
+ if (!dp->att) {
+ printf("Warning: boot device unrecognized: %s\n", bp);
+ return;
+ }
+ } while(dp->type != T_SCSI);
+
+ dev = dp->dev;
+ while(*cp && *cp != '/')
+ cp++;
+ dp = findtype(&cp);
+ if (!dp->att || dp->type != T_DISK) {
+ printf("Warning: boot device unrecognized: %s\n", bp);
return;
}
- ctrl = getpno(&cp);
- if(*cp++ == ')')
- unit = getpno(&cp);
- if(*cp++ == ')')
- getpno(&cp);
- if(*cp++ == ')')
- part = getpno(&cp) - 1;
- sprintf(bootdev, "%s%d%c", dp->dev, ctrl*16 + unit, 'a' + part);
+ unit = getpno(&cp);
+ sprintf(bootdev, "%s%d%c", dev, unit, 'a');
}
int
@@ -477,14 +501,9 @@ getpno(cp)
int val = 0;
char *cx = *cp;
- while(*cx && *cx != '(')
+ while(*cx && *cx >= '0' && *cx <= '9') {
+ val = val * 10 + *cx - '0';
cx++;
- if(*cx == '(') {
- cx++;
- while(*cx && *cx != ')') {
- val = val * 10 + *cx - '0';
- cx++;
- }
}
*cp = cx;
return val;
diff --git a/sys/arch/powerpc/powerpc/machdep.c b/sys/arch/powerpc/powerpc/machdep.c
index 2ccc1968b39..351225153fe 100644
--- a/sys/arch/powerpc/powerpc/machdep.c
+++ b/sys/arch/powerpc/powerpc/machdep.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: machdep.c,v 1.10 1997/10/15 14:07:52 pefo Exp $ */
+/* $OpenBSD: machdep.c,v 1.11 1997/10/21 11:00:10 pefo Exp $ */
/* $NetBSD: machdep.c,v 1.4 1996/10/16 19:33:11 ws Exp $ */
/*
@@ -239,8 +239,8 @@ initppc(startkernel, endkernel, args)
*/
#ifdef RAMDISK_HOOKS
boothowto = RB_SINGLE | RB_DFLTROOT;
-#else
- boothowto = RB_SINGLE | RB_ASKNAME;
+#else
+ boothowto = RB_AUTOBOOT;
#endif /* RAMDISK_HOOKS */
/*