diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 1998-05-07 19:03:48 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 1998-05-07 19:03:48 +0000 |
commit | ff633278b017921bc019f19a8262d60d9147a522 (patch) | |
tree | 380decf67c35bc4445a0923af1f560abe6f9b8d3 /sys | |
parent | c16d381f9fa78f4c3fd43daa8a33cddf6e422fed (diff) |
Write disk label in canonical location, do not scan. With this change
you can now fix a label that is in the wrong place via:
disklabel rz0 >! foo ; disklabel -R rz0 foo
like disklabel says you can.
Diffstat (limited to 'sys')
-rw-r--r-- | sys/arch/pmax/pmax/disksubr.c | 25 |
1 files changed, 1 insertions, 24 deletions
diff --git a/sys/arch/pmax/pmax/disksubr.c b/sys/arch/pmax/pmax/disksubr.c index afbeac9c5be..6a0c538d5d5 100644 --- a/sys/arch/pmax/pmax/disksubr.c +++ b/sys/arch/pmax/pmax/disksubr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: disksubr.c,v 1.11 1998/05/07 16:03:21 millert Exp $ */ +/* $OpenBSD: disksubr.c,v 1.12 1998/05/07 19:03:47 millert Exp $ */ /* $NetBSD: disksubr.c,v 1.14 1997/01/15 00:55:43 jonathan Exp $ */ /* @@ -269,7 +269,6 @@ writedisklabel(dev, strat, lp, osdep) struct cpu_disklabel *osdep; { struct buf *bp; - struct disklabel *dlp; int labelpart; int error = 0; @@ -287,28 +286,6 @@ writedisklabel(dev, strat, lp, osdep) (*strat)(bp); if ((error = biowait(bp)) != 0) goto done; - 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))) { - 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; - } - } - /* Write it in the regular place. */ *(struct disklabel *)(bp->b_data + LABELOFFSET) = *lp; bp->b_flags = B_BUSY | B_WRITE; (*strat)(bp); |