summaryrefslogtreecommitdiff
path: root/sys/arch
diff options
context:
space:
mode:
authorTodd C. Miller <millert@cvs.openbsd.org>1998-05-07 16:03:22 +0000
committerTodd C. Miller <millert@cvs.openbsd.org>1998-05-07 16:03:22 +0000
commite223554c2914e7fdebab8dcb99925a312e23cd93 (patch)
treec046546174037c76e9098d317900389d90dd6a5c /sys/arch
parent7c19756e9b74ab416a5f3fdb79d92d0ea72f6094 (diff)
readdisklabel: Look for label in the correct place (LABELSECTOR + LABELOFFSET)
first and then fall back to scanning starting at LABELSECTOR. Previously it just did the scan. writedisklabel: Write label to the correct place (LABELSECTOR + LABELOFFSET) if disk is unlabelled. Previously it was written at LABELSECTOR which hosed bootblock writing (as the boot blocks would overwrite the label).
Diffstat (limited to 'sys/arch')
-rw-r--r--sys/arch/pmax/pmax/disksubr.c50
1 files changed, 34 insertions, 16 deletions
diff --git a/sys/arch/pmax/pmax/disksubr.c b/sys/arch/pmax/pmax/disksubr.c
index d0e43b779aa..afbeac9c5be 100644
--- a/sys/arch/pmax/pmax/disksubr.c
+++ b/sys/arch/pmax/pmax/disksubr.c
@@ -1,3 +1,4 @@
+/* $OpenBSD: disksubr.c,v 1.11 1998/05/07 16:03:21 millert Exp $ */
/* $NetBSD: disksubr.c,v 1.14 1997/01/15 00:55:43 jonathan Exp $ */
/*
@@ -93,21 +94,30 @@ readdisklabel(dev, strat, lp, osdep)
(*strat)(bp);
if (biowait(bp)) {
msg = "I/O error";
- } else for (dlp = (struct disklabel *)bp->b_un.b_addr;
- dlp <= (struct disklabel *)(bp->b_un.b_addr+DEV_BSIZE-sizeof(*dlp));
- dlp = (struct disklabel *)((char *)dlp + sizeof(long))) {
- if (dlp->d_magic != DISKMAGIC || dlp->d_magic2 != DISKMAGIC) {
- if (msg == NULL)
- msg = "no disk label";
- } else if (dlp->d_npartitions > MAXPARTITIONS ||
- dkcksum(dlp) != 0)
- msg = "disk label corrupted";
- else {
- *lp = *dlp;
- msg = NULL;
- break;
+ } else {
+ dlp = (struct disklabel *)bp->b_un.b_addr + LABELOFFSET;
+ if (dlp->d_magic == DISKMAGIC && dlp->d_magic2 == DISKMAGIC) {
+ if (dlp->d_npartitions > MAXPARTITIONS || dkcksum(dlp))
+ msg = "disk label corrupted";
+ else
+ *lp = *dlp;
+ } else for (dlp = (struct disklabel *)bp->b_un.b_addr;
+ dlp <= (struct disklabel *)(bp->b_un.b_addr+DEV_BSIZE-sizeof(*dlp));
+ dlp = (struct disklabel *)((char *)dlp + sizeof(long))) {
+ if (dlp->d_magic != DISKMAGIC || dlp->d_magic2 != DISKMAGIC) {
+ if (msg == NULL)
+ msg = "no disk label";
+ } else if (dlp->d_npartitions > MAXPARTITIONS ||
+ dkcksum(dlp) != 0)
+ msg = "disk label corrupted";
+ else {
+ *lp = *dlp;
+ msg = NULL;
+ break;
+ }
}
}
+
bp->b_flags = B_INVAL | B_AGE;
brelse(bp);
return (msg);
@@ -116,7 +126,7 @@ readdisklabel(dev, strat, lp, osdep)
#ifdef COMPAT_ULTRIX
/*
* Given a buffer bp, try and interpret it as an Ultrix disk label,
- * putting the partition info into a native NetBSD label
+ * putting the partition info into a native OpenBSD label
*/
char *
compat_label(dev, strat, lp, osdep)
@@ -277,7 +287,15 @@ writedisklabel(dev, strat, lp, osdep)
(*strat)(bp);
if ((error = biowait(bp)) != 0)
goto done;
- for (dlp = (struct disklabel *)bp->b_un.b_addr;
+ dlp = (struct disklabel *)bp->b_un.b_addr + LABELOFFSET;
+ if (dlp->d_magic == DISKMAGIC && dlp->d_magic2 == DISKMAGIC &&
+ dkcksum(dlp) == 0) {
+ *dlp = *lp;
+ bp->b_flags = B_WRITE;
+ (*strat)(bp);
+ error = biowait(bp);
+ goto done;
+ } else for (dlp = (struct disklabel *)bp->b_un.b_addr;
dlp <= (struct disklabel *)
(bp->b_un.b_addr + lp->d_secsize - sizeof(*dlp));
dlp = (struct disklabel *)((char *)dlp + sizeof(long))) {
@@ -291,7 +309,7 @@ writedisklabel(dev, strat, lp, osdep)
}
}
/* Write it in the regular place. */
- *(struct disklabel *)bp->b_data = *lp;
+ *(struct disklabel *)(bp->b_data + LABELOFFSET) = *lp;
bp->b_flags = B_BUSY | B_WRITE;
(*strat)(bp);
error = biowait(bp);