From 7c24c568652099d54183ff75ebb1a488fdffa324 Mon Sep 17 00:00:00 2001 From: Miod Vallat Date: Sat, 14 Apr 2001 00:11:46 +0000 Subject: Correctly initialize disklabel structure in readdisklabel(). Prevents kernel from panic'ing or disklabel(1) from faulting with an empty (never labaled) disk. Also, use LABELSECTOR instead of hardwired constant. Tested by deraadt@ on mvme68k and myself on mvme88k, deraadt@ ok --- sys/arch/mvme68k/mvme68k/disksubr.c | 54 ++++++++++++++++--------------------- sys/arch/mvme88k/mvme88k/disksubr.c | 45 ++++++++++++++++++------------- 2 files changed, 49 insertions(+), 50 deletions(-) (limited to 'sys/arch') diff --git a/sys/arch/mvme68k/mvme68k/disksubr.c b/sys/arch/mvme68k/mvme68k/disksubr.c index 1592d54b2ee..251502dcdf4 100644 --- a/sys/arch/mvme68k/mvme68k/disksubr.c +++ b/sys/arch/mvme68k/mvme68k/disksubr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: disksubr.c,v 1.21 2000/10/18 21:00:37 mickey Exp $ */ +/* $OpenBSD: disksubr.c,v 1.22 2001/04/14 00:11:40 miod Exp $ */ /* * Copyright (c) 1998 Steve Murphree, Jr. * Copyright (c) 1995 Dale Rahn. @@ -101,16 +101,13 @@ dk_establish(dk, dev) char * readdisklabel(dev, strat, lp, clp, spoofonly) dev_t dev; - void (*strat)(); + void (*strat) __P((struct buf *)); struct disklabel *lp; struct cpu_disklabel *clp; int spoofonly; { struct buf *bp; - char *msg = NULL; - char *tmot = "MOTOROLA"; - char *mot; - int t; + int error, i; /* minimal requirements for archetypal disk label */ if (lp->d_secsize == 0) @@ -118,9 +115,12 @@ readdisklabel(dev, strat, lp, clp, spoofonly) if (lp->d_secperunit == 0) lp->d_secperunit = 0x1fffffff; lp->d_npartitions = RAW_PART + 1; - if (lp->d_partitions[RAW_PART].p_size == 0) - lp->d_partitions[RAW_PART].p_size = lp->d_secperunit; - lp->d_partitions[RAW_PART].p_offset = 0; + for (i = 0; i < RAW_PART; i++) { + lp->d_partitions[i].p_size = 0; + lp->d_partitions[i].p_offset = 0; + } + if (lp->d_partitions[i].p_size == 0) + lp->d_partitions[i].p_size = lp->d_secperunit; /* don't read the on-disk label if we are in spoofed-only mode */ if (spoofonly) @@ -131,40 +131,32 @@ readdisklabel(dev, strat, lp, clp, spoofonly) /* request no partition relocation by driver on I/O operations */ bp->b_dev = dev; - bp->b_blkno = 0; /* contained in block 0 */ + bp->b_blkno = LABELSECTOR; bp->b_bcount = lp->d_secsize; bp->b_flags = B_BUSY | B_READ; bp->b_cylin = 0; /* contained in block 0 */ (*strat)(bp); - if (biowait(bp)) { - msg = "cpu_disklabel read error\n"; - } else { + error = biowait(bp); + if (error == 0) bcopy(bp->b_data, clp, sizeof (struct cpu_disklabel)); - } - bp->b_flags = B_INVAL | B_AGE | B_READ; brelse(bp); - if (msg) { + if (error) + return ("disk label read error"); + #if defined(CD9660) - if (iso_disklabelspoof(dev, strat, lp) == 0) - msg = NULL; + if (iso_disklabelspoof(dev, strat, lp) == 0) + return (NULL); #endif - return (msg); - } - - if (clp->magic1 != DISKMAGIC || clp->magic2 != DISKMAGIC) { - msg = "no disk label"; - return (msg); - } + if (clp->magic1 != DISKMAGIC || clp->magic2 != DISKMAGIC) + return ("no disk label"); cputobsdlabel(lp, clp); - if (dkcksum(lp) != 0){ - msg = "disk label corrupted"; - return (msg); - } + if (dkcksum(lp) != 0) + return ("disk label corrupted"); #ifdef DEBUG if (disksubr_debug > 0) { @@ -172,7 +164,7 @@ readdisklabel(dev, strat, lp, clp, spoofonly) printclp(clp, "readdisklabel:cpu label"); } #endif - return (msg); + return (NULL); } /* @@ -267,7 +259,7 @@ writedisklabel(dev, strat, lp, clp) /* request no partition relocation by driver on I/O operations */ bp->b_dev = dev; - bp->b_blkno = 0; /* contained in block 0 */ + bp->b_blkno = LABELSECTOR; bp->b_bcount = lp->d_secsize; bp->b_flags = B_BUSY | B_READ; bp->b_cylin = 0; /* contained in block 0 */ diff --git a/sys/arch/mvme88k/mvme88k/disksubr.c b/sys/arch/mvme88k/mvme88k/disksubr.c index ec38c018a4a..06f356ff519 100644 --- a/sys/arch/mvme88k/mvme88k/disksubr.c +++ b/sys/arch/mvme88k/mvme88k/disksubr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: disksubr.c,v 1.14 2001/03/16 00:09:08 miod Exp $ */ +/* $OpenBSD: disksubr.c,v 1.15 2001/04/14 00:11:45 miod Exp $ */ /* * Copyright (c) 1998 Steve Murphree, Jr. * Copyright (c) 1995 Dale Rahn. @@ -134,13 +134,13 @@ dk_establish(dk, dev) char * readdisklabel(dev, strat, lp, clp, spoofonly) dev_t dev; - void (*strat)(); + void (*strat) __P((struct buf *)); struct disklabel *lp; struct cpu_disklabel *clp; int spoofonly; { struct buf *bp; - char *msg = NULL; + int error, i; /* minimal requirements for archetypal disk label */ if (lp->d_secsize == 0) @@ -148,9 +148,12 @@ readdisklabel(dev, strat, lp, clp, spoofonly) if (lp->d_secperunit == 0) lp->d_secperunit = 0x1fffffff; lp->d_npartitions = RAW_PART + 1; - if (lp->d_partitions[RAW_PART].p_size == 0) - lp->d_partitions[RAW_PART].p_size = lp->d_secperunit; - lp->d_partitions[RAW_PART].p_offset = 0; + for (i = 0; i < RAW_PART ; i++) { + lp->d_partitions[i].p_size = 0; + lp->d_partitions[i].p_offset = 0; + } + if (lp->d_partitions[i].p_size == 0) + lp->d_partitions[i].p_size = lp->d_secperunit; /* don't read the on-disk label if we are in spoofed-only mode */ if (spoofonly) @@ -161,36 +164,40 @@ readdisklabel(dev, strat, lp, clp, spoofonly) /* request no partition relocation by driver on I/O operations */ bp->b_dev = dev; - bp->b_blkno = 0; /* contained in block 0 */ + bp->b_blkno = LABELSECTOR; bp->b_bcount = lp->d_secsize; bp->b_flags = B_BUSY | B_READ; bp->b_cylin = 0; /* contained in block 0 */ (*strat)(bp); - if (biowait(bp)) { - msg = "cpu_disklabel read error\n"; - } else { + error = biowait(bp); + if (error == 0) bcopy(bp->b_data, clp, sizeof (struct cpu_disklabel)); - } - bp->b_flags = B_INVAL | B_AGE | B_READ; brelse(bp); - if (msg) { + if (error) + return ("disk label read error"); + #if defined(CD9660) - if (iso_disklabelspoof(dev, strat, lp) == 0) - msg = NULL; + if (iso_disklabelspoof(dev, strat, lp) == 0) + return (NULL); #endif - return (msg); - } + if (clp->magic1 != DISKMAGIC || clp->magic2 != DISKMAGIC) + return ("no disk label"); + cputobsdlabel(lp, clp); + + if (dkcksum(lp) != 0) + return ("disk label corrupted"); + #ifdef DEBUG if (disksubr_debug > 0) { printlp(lp, "readdisklabel:bsd label"); printclp(clp, "readdisklabel:cpu label"); } #endif - return (msg); + return (NULL); } #if 0 @@ -336,7 +343,7 @@ writedisklabel(dev, strat, lp, clp) /* request no partition relocation by driver on I/O operations */ bp->b_dev = dev; - bp->b_blkno = 0; /* contained in block 0 */ + bp->b_blkno = LABELSECTOR; bp->b_bcount = lp->d_secsize; bp->b_flags = B_BUSY | B_READ; bp->b_cylin = 0; /* contained in block 0 */ -- cgit v1.2.3