summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKenneth R Westerback <krw@cvs.openbsd.org>2006-07-07 23:47:38 +0000
committerKenneth R Westerback <krw@cvs.openbsd.org>2006-07-07 23:47:38 +0000
commit10157221a2659d2c272524b419801c7f9718ef12 (patch)
treee41780893a681e8d7edd098722398f743353136a
parent82591ef1eb156d609b57ff16c71feb7d88b92aa1 (diff)
Unroll DLT_* logic into simple 'look for native disklabel, then try
DOS MBR' logic. Leave DOS MBR logic inside #if defined(DISKLABEL_I386) blocks until impact on install media can be evaluated. Eliminates most remnants of cross-endian, cross-architecture disklabel processing attempts. Fix some mips64 issues with last commit, found by kettenis@. No functional change.
-rw-r--r--sys/arch/hppa/hppa/disksubr.c68
-rw-r--r--sys/arch/hppa/include/disklabel.h16
-rw-r--r--sys/arch/hppa64/hppa64/disksubr.c68
-rw-r--r--sys/arch/hppa64/include/disklabel.h16
-rw-r--r--sys/arch/mips64/include/disklabel.h16
-rw-r--r--sys/arch/mips64/mips64/disksubr.c76
6 files changed, 76 insertions, 184 deletions
diff --git a/sys/arch/hppa/hppa/disksubr.c b/sys/arch/hppa/hppa/disksubr.c
index d835103c18e..3c3c4597bb1 100644
--- a/sys/arch/hppa/hppa/disksubr.c
+++ b/sys/arch/hppa/hppa/disksubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: disksubr.c,v 1.26 2006/07/03 20:00:22 krw Exp $ */
+/* $OpenBSD: disksubr.c,v 1.27 2006/07/07 23:47:37 krw Exp $ */
/*
* Copyright (c) 1999 Michael Shalayeff
@@ -35,7 +35,7 @@
*/
/*
- * This disksubr.c module started to take it's present form on OpenBSD/alpha
+ * This disksubr.c module started to take its present form on OpenBSD/alpha
* but it was always thought it should be made completely MI and not need to
* be in that alpha-specific tree at all.
*
@@ -64,8 +64,6 @@ char *readdoslabel(struct buf *, void (*)(struct buf *),
char *readliflabel(struct buf *, void (*)(struct buf *),
struct disklabel *, struct cpu_disklabel *, int *, int *, int);
-static enum disklabel_tag probe_order[] = { LABELPROBES, -1 };
-
/*
* Try to read a standard BSD disklabel at a certain sector.
*/
@@ -146,7 +144,6 @@ readdisklabel(dev, strat, lp, osdep, spoofonly)
{
struct buf *bp = NULL;
char *msg = "no disk label";
- enum disklabel_tag *tp;
int i;
struct disklabel minilabel, fallbacklabel;
@@ -173,32 +170,22 @@ readdisklabel(dev, strat, lp, osdep, spoofonly)
bp = geteblk((int)lp->d_secsize);
bp->b_dev = dev;
- for (tp = probe_order; msg && *tp != -1; tp++) {
- switch (*tp) {
- case DLT_I386:
+ msg = readliflabel(bp, strat, lp, osdep, 0, 0, spoofonly);
+ if (msg)
+ *lp = minilabel;
#if defined(DISKLABEL_I386)
- msg = readdoslabel(bp, strat, lp, osdep, 0, 0, spoofonly);
- if (msg)
- /* Fallback alternative */
- fallbacklabel = *lp;
-#endif
- break;
-
- case DLT_HPPA:
- msg = readliflabel(bp, strat, lp, osdep, 0, 0, spoofonly);
- break;
-
- default:
- panic("unrecognized disklabel tag %d", *tp);
- }
- if (msg)
+ if (msg) {
+ msg = readdoslabel(bp, strat, lp, osdep, 0, 0, spoofonly);
+ if (msg) {
+ /* Fallback alternative XXX always valid? */
+ fallbacklabel = *lp;
*lp = minilabel;
+ }
}
-
+#endif
/* Record metainformation about the disklabel. */
if (msg == NULL) {
osdep->labelsector = bp->b_blkno;
- osdep->labeltag = *tp;
}
#if defined(CD9660)
@@ -648,7 +635,7 @@ setdisklabel(olp, nlp, openmask, osdep)
* XXX Nice thought, but it doesn't work, if the intention was to
* force a reread at the next *readdisklabel call. That does not
* happen. There's still some use for it though as you can pseudo-
- * partitition the disk.
+ * partition the disk.
*
* Special case to allow disklabel to be invalidated.
*/
@@ -701,7 +688,6 @@ writedisklabel(dev, strat, lp, osdep)
struct disklabel *lp;
struct cpu_disklabel *osdep;
{
- enum disklabel_tag *tp;
char *msg = "no disk label";
struct buf *bp;
struct disklabel dl;
@@ -718,28 +704,16 @@ writedisklabel(dev, strat, lp, osdep)
* think it might be useful to reprobe if someone has written
* a newer disklabel of another type with disklabel(8) and -r.
*/
- for (tp = probe_order; msg && *tp != -1; tp++) {
- dl = *lp;
- switch (*tp) {
- case DLT_I386:
+ dl = *lp;
+ msg = readliflabel(bp, strat, &dl, &cdl, &partoff, &cyl, 0);
+ labeloffset = HPPA_LABELOFFSET;
#if defined(DISKLABEL_I386)
- msg = readdoslabel(bp, strat, &dl, &cdl, &partoff,
- &cyl, 0);
- labeloffset = I386_LABELOFFSET;
-#endif
- break;
-
- case DLT_HPPA:
- msg = readliflabel(bp, strat, &dl, &cdl, &partoff,
- &cyl, 0);
- labeloffset = HPPA_LABELOFFSET;
- break;
-
- default:
- panic("unrecognized disklabel tag %d", *tp);
- }
+ if (msg) {
+ dl = *lp;
+ msg = readdoslabel(bp, strat, &dl, &cdl, &partoff, &cyl, 0);
+ labeloffset = I386_LABELOFFSET;
}
-
+#endif
if (msg) {
if (partoff == -1)
return EIO;
diff --git a/sys/arch/hppa/include/disklabel.h b/sys/arch/hppa/include/disklabel.h
index a3e5b90e628..8f9f32a2c68 100644
--- a/sys/arch/hppa/include/disklabel.h
+++ b/sys/arch/hppa/include/disklabel.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: disklabel.h,v 1.11 2006/07/03 20:00:22 krw Exp $ */
+/* $OpenBSD: disklabel.h,v 1.12 2006/07/07 23:47:37 krw Exp $ */
/* $NetBSD: disklabel.h,v 1.1 1995/02/13 23:07:34 cgd Exp $ */
/*
@@ -34,19 +34,10 @@
#ifndef _MACHINE_DISKLABEL_H_
#define _MACHINE_DISKLABEL_H_
-enum disklabel_tag { DLT_I386, DLT_HPPA };
-
-/*
- * What disklabels are we probing for, and in which order?
- */
-#ifndef LABELPROBES
-#define LABELPROBES DLT_I386, DLT_HPPA
-#endif
-
-#define I386_LABELSECTOR 1 /* sector containing label */
-#define I386_LABELOFFSET 0 /* offset of label in sector */
#define HPPA_LABELSECTOR 1 /* sector containing label */
#define HPPA_LABELOFFSET 0 /* offset of label in sector */
+#define I386_LABELSECTOR 1 /* sector containing label */
+#define I386_LABELOFFSET 0 /* offset of label in sector */
#define LABELSECTOR HPPA_LABELSECTOR
#define LABELOFFSET HPPA_LABELOFFSET
@@ -186,7 +177,6 @@ struct hpux_label {
#include <sys/dkbad.h>
struct cpu_disklabel {
- enum disklabel_tag labeltag;
int labelsector;
union {
struct {
diff --git a/sys/arch/hppa64/hppa64/disksubr.c b/sys/arch/hppa64/hppa64/disksubr.c
index e5ae72737c9..d6dfe643b3a 100644
--- a/sys/arch/hppa64/hppa64/disksubr.c
+++ b/sys/arch/hppa64/hppa64/disksubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: disksubr.c,v 1.9 2006/07/03 20:00:22 krw Exp $ */
+/* $OpenBSD: disksubr.c,v 1.10 2006/07/07 23:47:37 krw Exp $ */
/*
* Copyright (c) 1999 Michael Shalayeff
@@ -35,7 +35,7 @@
*/
/*
- * This disksubr.c module started to take it's present form on OpenBSD/alpha
+ * This disksubr.c module started to take its present form on OpenBSD/alpha
* but it was always thought it should be made completely MI and not need to
* be in that alpha-specific tree at all.
*
@@ -64,8 +64,6 @@ char *readdoslabel(struct buf *, void (*)(struct buf *),
char *readliflabel(struct buf *, void (*)(struct buf *),
struct disklabel *, struct cpu_disklabel *, int *, int *, int);
-static enum disklabel_tag probe_order[] = { LABELPROBES, -1 };
-
/*
* Try to read a standard BSD disklabel at a certain sector.
*/
@@ -146,7 +144,6 @@ readdisklabel(dev, strat, lp, osdep, spoofonly)
{
struct buf *bp = NULL;
char *msg = "no disk label";
- enum disklabel_tag *tp;
int i;
struct disklabel minilabel, fallbacklabel;
@@ -173,32 +170,22 @@ readdisklabel(dev, strat, lp, osdep, spoofonly)
bp = geteblk((int)lp->d_secsize);
bp->b_dev = dev;
- for (tp = probe_order; msg && *tp != -1; tp++) {
- switch (*tp) {
- case DLT_I386:
+ msg = readliflabel(bp, strat, lp, osdep, 0, 0, spoofonly);
+ if (msg)
+ *lp = minilabel;
#if defined(DISKLABEL_I386)
- msg = readdoslabel(bp, strat, lp, osdep, 0, 0, spoofonly);
- if (msg)
- /* Fallback alternative */
- fallbacklabel = *lp;
-#endif
- break;
-
- case DLT_HPPA:
- msg = readliflabel(bp, strat, lp, osdep, 0, 0, spoofonly);
- break;
-
- default:
- panic("unrecognized disklabel tag %d", *tp);
- }
- if (msg)
+ if (msg) {
+ msg = readdoslabel(bp, strat, lp, osdep, 0, 0, spoofonly);
+ if (msg) {
+ /* Fallback alternative XXX always valid? */
+ fallbacklabel = *lp;
*lp = minilabel;
+ }
}
-
+#endif
/* Record metainformation about the disklabel. */
if (msg == NULL) {
osdep->labelsector = bp->b_blkno;
- osdep->labeltag = *tp;
}
#if defined(CD9660)
@@ -644,7 +631,7 @@ setdisklabel(olp, nlp, openmask, osdep)
* XXX Nice thought, but it doesn't work, if the intention was to
* force a reread at the next *readdisklabel call. That does not
* happen. There's still some use for it though as you can pseudo-
- * partitition the disk.
+ * partition the disk.
*
* Special case to allow disklabel to be invalidated.
*/
@@ -697,7 +684,6 @@ writedisklabel(dev, strat, lp, osdep)
struct disklabel *lp;
struct cpu_disklabel *osdep;
{
- enum disklabel_tag *tp;
char *msg = "no disk label";
struct buf *bp;
struct disklabel dl;
@@ -714,28 +700,16 @@ writedisklabel(dev, strat, lp, osdep)
* think it might be useful to reprobe if someone has written
* a newer disklabel of another type with disklabel(8) and -r.
*/
- for (tp = probe_order; msg && *tp != -1; tp++) {
- dl = *lp;
- switch (*tp) {
- case DLT_I386:
+ dl = *lp;
+ msg = readliflabel(bp, strat, &dl, &cdl, &partoff, &cyl, 0);
+ labeloffset = HPPA_LABELOFFSET;
#if defined(DISKLABEL_I386)
- msg = readdoslabel(bp, strat, &dl, &cdl, &partoff,
- &cyl, 0);
- labeloffset = I386_LABELOFFSET;
-#endif
- break;
-
- case DLT_HPPA:
- msg = readliflabel(bp, strat, &dl, &cdl, &partoff,
- &cyl, 0);
- labeloffset = HPPA_LABELOFFSET;
- break;
-
- default:
- panic("unrecognized disklabel tag %d", *tp);
- }
+ if (msg) {
+ dl = *lp;
+ msg = readdoslabel(bp, strat, &dl, &cdl, &partoff, &cyl, 0);
+ labeloffset = I386_LABELOFFSET;
}
-
+#endif
if (msg) {
if (partoff == -1)
return EIO;
diff --git a/sys/arch/hppa64/include/disklabel.h b/sys/arch/hppa64/include/disklabel.h
index 08bd639495c..051dbe2865b 100644
--- a/sys/arch/hppa64/include/disklabel.h
+++ b/sys/arch/hppa64/include/disklabel.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: disklabel.h,v 1.5 2006/07/03 20:00:22 krw Exp $ */
+/* $OpenBSD: disklabel.h,v 1.6 2006/07/07 23:47:37 krw Exp $ */
/* $NetBSD: disklabel.h,v 1.1 1995/02/13 23:07:34 cgd Exp $ */
/*
@@ -34,19 +34,10 @@
#ifndef _MACHINE_DISKLABEL_H_
#define _MACHINE_DISKLABEL_H_
-enum disklabel_tag { DLT_I386, DLT_HPPA };
-
-/*
- * What disklabels are we probing for, and in which order?
- */
-#ifndef LABELPROBES
-#define LABELPROBES DLT_I386, DLT_HPPA
-#endif
-
-#define I386_LABELSECTOR 1 /* sector containing label */
-#define I386_LABELOFFSET 0 /* offset of label in sector */
#define HPPA_LABELSECTOR 1 /* sector containing label */
#define HPPA_LABELOFFSET 0 /* offset of label in sector */
+#define I386_LABELSECTOR 1 /* sector containing label */
+#define I386_LABELOFFSET 0 /* offset of label in sector */
#define LABELSECTOR HPPA_LABELSECTOR
#define LABELOFFSET HPPA_LABELOFFSET
@@ -186,7 +177,6 @@ struct hpux_label {
#include <sys/dkbad.h>
struct cpu_disklabel {
- enum disklabel_tag labeltag;
int labelsector;
union {
struct {
diff --git a/sys/arch/mips64/include/disklabel.h b/sys/arch/mips64/include/disklabel.h
index bf205a370e3..5eb868d0e2f 100644
--- a/sys/arch/mips64/include/disklabel.h
+++ b/sys/arch/mips64/include/disklabel.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: disklabel.h,v 1.7 2006/07/03 20:00:22 krw Exp $ */
+/* $OpenBSD: disklabel.h,v 1.8 2006/07/07 23:47:37 krw Exp $ */
/* $NetBSD: disklabel.h,v 1.1 1995/02/13 23:07:34 cgd Exp $ */
/*
@@ -34,19 +34,10 @@
#ifndef _MACHINE_DISKLABEL_H_
#define _MACHINE_DISKLABEL_H_
-enum disklabel_tag { DLT_I386, DLT_SGI };
-
-/*
- * What disklabels are we probing for, and in which order?
- */
-#ifndef LABELPROBES
-#define LABELPROBES DLT_I386, DLT_SGI
-#endif
-
-#define I386_LABELSECTOR 1 /* sector containing label */
-#define I386_LABELOFFSET 0 /* offset of label in sector */
#define SGI_LABELSECTOR 1 /* sector containing label */
#define SGI_LABELOFFSET 0 /* offset of label in sector */
+#define I386_LABELSECTOR 1 /* sector containing label */
+#define I386_LABELOFFSET 0 /* offset of label in sector */
#define LABELSECTOR SGI_LABELSECTOR
#define LABELOFFSET SGI_LABELOFFSET
@@ -158,7 +149,6 @@ struct sgilabel {
#include <sys/dkbad.h>
struct cpu_disklabel {
- enum disklabel_tag labeltag;
int labelsector;
union {
struct {
diff --git a/sys/arch/mips64/mips64/disksubr.c b/sys/arch/mips64/mips64/disksubr.c
index 95ab2485988..00b869f19a7 100644
--- a/sys/arch/mips64/mips64/disksubr.c
+++ b/sys/arch/mips64/mips64/disksubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: disksubr.c,v 1.15 2006/07/03 20:00:22 krw Exp $ */
+/* $OpenBSD: disksubr.c,v 1.16 2006/07/07 23:47:37 krw Exp $ */
/*
* Copyright (c) 1999 Michael Shalayeff
@@ -35,7 +35,7 @@
*/
/*
- * This disksubr.c module started to take it's present form on OpenBSD/alpha
+ * This disksubr.c module started to take its present form on OpenBSD/alpha
* but it was always thought it should be made completely MI and not need to
* be in that alpha-specific tree at all.
*
@@ -65,8 +65,6 @@ char *readsgilabel(struct buf *, void (*)(struct buf *),
struct disklabel *, struct cpu_disklabel *, int *, int *, int);
void map_sgi_label(struct disklabel *, struct sgilabel *);
-static enum disklabel_tag probe_order[] = { LABELPROBES, -1 };
-
/*
* Try to read a standard BSD disklabel at a certain sector.
*/
@@ -147,7 +145,6 @@ readdisklabel(dev, strat, lp, osdep, spoofonly)
{
struct buf *bp = NULL;
char *msg = "no disk label";
- enum disklabel_tag *tp;
int i;
struct disklabel minilabel, fallbacklabel;
@@ -174,35 +171,25 @@ readdisklabel(dev, strat, lp, osdep, spoofonly)
bp = geteblk((int)lp->d_secsize);
bp->b_dev = dev;
- for (tp = probe_order; msg && *tp != -1; tp++) {
- switch (*tp) {
- case DLT_I386:
+ msg = readsgilabel(bp, strat, lp, osdep, 0, 0, spoofonly);
+ if (msg) {
+ /* Fallback alternative XXX valid lp returned? */
+ fallbacklabel = *lp;
+ *lp = minilabel;
+ }
#if defined(DISKLABEL_I386)
- msg = readdoslabel(bp, strat, lp, osdep, 0, 0, spoofonly);
- if (msg)
- /* Fallback alternative */
- fallbacklabel = *lp;
-#endif
- break;
-
- case DLT_SGI:
- msg = readsgilabel(bp, strat, lp, osdep, 0, 0, spoofonly);
- if (msg)
- /* Fallback alternative */
- fallbacklabel = *lp;
- break;
-
- default:
- panic("unrecognized disklabel tag %d", *tp);
- }
- if (msg)
+ if (msg) {
+ msg = readdoslabel(bp, strat, lp, osdep, 0, 0, spoofonly);
+ if (msg) {
+ /* Fallback alternative XXX always valid? */
+ fallbacklabel = *lp;
*lp = minilabel;
+ }
}
-
+#endif
/* Record metainformation about the disklabel. */
if (msg == NULL) {
osdep->labelsector = bp->b_blkno;
- osdep->labeltag = *tp;
}
#if defined(CD9660)
@@ -541,7 +528,7 @@ readsgilabel(bp, strat, lp, osdep, partoffp, cylp, spoofonly)
*partoffp = fsoffs;
msg = readbsdlabel(bp, strat, 0, fsoffs + SGI_LABELSECTOR,
- SGI_LABELOFFSET, BIG_ENDIAN, lp, spoofonly);
+ SGI_LABELOFFSET, lp, spoofonly);
return msg;
}
@@ -594,7 +581,7 @@ setdisklabel(olp, nlp, openmask, osdep)
* XXX Nice thought, but it doesn't work, if the intention was to
* force a reread at the next *readdisklabel call. That does not
* happen. There's still some use for it though as you can pseudo-
- * partitition the disk.
+ * partition the disk.
*
* Special case to allow disklabel to be invalidated.
*/
@@ -647,7 +634,6 @@ writedisklabel(dev, strat, lp, osdep)
struct disklabel *lp;
struct cpu_disklabel *osdep;
{
- enum disklabel_tag *tp;
char *msg = "no disk label";
struct buf *bp;
struct disklabel dl;
@@ -664,28 +650,16 @@ writedisklabel(dev, strat, lp, osdep)
* think it might be useful to reprobe if someone has written
* a newer disklabel of another type with disklabel(8) and -r.
*/
- for (tp = probe_order; msg && *tp != -1; tp++) {
- dl = *lp;
- switch (*tp) {
- case DLT_I386:
+ dl = *lp;
+ msg = readsgilabel(bp, strat, &dl, &cdl, &partoff, &cyl, 0);
+ labeloffset = SGI_LABELOFFSET;
#if defined(DISKLABEL_I386)
- msg = readdoslabel(bp, strat, &dl, &cdl, &partoff,
- &cyl, 0);
- labeloffset = I386_LABELOFFSET;
-#endif
- break;
-
- case DLT_SGI:
- msg = readsgilabel(bp, strat, &dl, &cdl, &partoff,
- &cyl, 0);
- labeloffset = SGI_LABELOFFSET;
- break;
-
- default:
- panic("unrecognized disklabel tag %d", *tp);
- }
+ if (msg) {
+ dl = *lp;
+ msg = readdoslabel(bp, strat, &dl, &cdl, &partoff, &cyl, 0);
+ labeloffset = I386_LABELOFFSET;
}
-
+#endif
if (msg) {
if (partoff == -1)
return EIO;