diff options
-rw-r--r-- | sys/arch/sun3/sun3/disksubr.c | 55 |
1 files changed, 35 insertions, 20 deletions
diff --git a/sys/arch/sun3/sun3/disksubr.c b/sys/arch/sun3/sun3/disksubr.c index 779d1569831..f16a50520ca 100644 --- a/sys/arch/sun3/sun3/disksubr.c +++ b/sys/arch/sun3/sun3/disksubr.c @@ -1,4 +1,4 @@ -/* $NetBSD: disksubr.c,v 1.9.2.1 1995/10/30 23:36:34 gwr Exp $ */ +/* $NetBSD: disksubr.c,v 1.9.2.2 1995/11/18 06:58:03 gwr Exp $ */ /* * Copyright (c) 1994, 1995 Gordon W. Ross @@ -151,9 +151,9 @@ setdisklabel(olp, nlp, openmask, clp) int i; /* sanity clause */ - if (nlp->d_secpercyl == 0 || nlp->d_secsize == 0 - || (nlp->d_secsize % DEV_BSIZE) != 0) - return(EINVAL); + if ((nlp->d_secpercyl == 0) || (nlp->d_secsize == 0) || + (nlp->d_secsize % DEV_BSIZE) != 0) + return(EINVAL); /* special case to allow disklabel to be invalidated */ if (nlp->d_magic == 0xffffffff) { @@ -161,7 +161,8 @@ setdisklabel(olp, nlp, openmask, clp) return (0); } - if (nlp->d_magic != DISKMAGIC || nlp->d_magic2 != DISKMAGIC || + if (nlp->d_magic != DISKMAGIC || + nlp->d_magic2 != DISKMAGIC || dkcksum(nlp) != 0) return (EINVAL); @@ -172,21 +173,12 @@ setdisklabel(olp, nlp, openmask, clp) return (EBUSY); opp = &olp->d_partitions[i]; npp = &nlp->d_partitions[i]; - if (npp->p_offset != opp->p_offset || npp->p_size < opp->p_size) + if (npp->p_offset != opp->p_offset || + npp->p_size < opp->p_size) return (EBUSY); - /* - * Copy internally-set partition information - * if new label doesn't include it. XXX - */ - if (npp->p_fstype == FS_UNUSED && opp->p_fstype != FS_UNUSED) { - npp->p_fstype = opp->p_fstype; - npp->p_fsize = opp->p_fsize; - npp->p_frag = opp->p_frag; - npp->p_cpg = opp->p_cpg; - } } - nlp->d_checksum = 0; - nlp->d_checksum = dkcksum(nlp); + + /* We did not modify the new label, so the checksum is OK. */ *olp = *nlp; return (0); } @@ -338,7 +330,8 @@ disklabel_sun_to_bsd(cp, lp) return("SunOS disk label, bad checksum"); /* Format conversion. */ - lp->d_magic = 0; /* denote as pseudo */ + lp->d_magic = DISKMAGIC; + lp->d_magic2 = DISKMAGIC; memcpy(lp->d_packname, sl->sl_text, sizeof(lp->d_packname)); lp->d_secsize = 512; @@ -365,10 +358,29 @@ disklabel_sun_to_bsd(cp, lp) npp = &lp->d_partitions[i]; npp->p_offset = spp->sdkp_cyloffset * secpercyl; npp->p_size = spp->sdkp_nsectors; - if (npp->p_size) + if (npp->p_size == 0) + npp->p_fstype = FS_UNUSED; + else { + /* Partition has non-zero size. Set type, etc. */ npp->p_fstype = sun_fstypes[i]; + /* + * The sun label does not store the FFS fields, + * so just set them with default values here. + * XXX: This keeps newfs from trying to rewrite + * XXX: the disk label in the most common case. + * XXX: (Should remove that code from newfs...) + */ + if (npp->p_fstype == FS_BSDFFS) { + npp->p_fsize = 1024; + npp->p_frag = 8; + npp->p_cpg = 16; + } + } } + lp->d_checksum = 0; + lp->d_checksum = dkcksum(lp); + return(NULL); } @@ -389,6 +401,9 @@ disklabel_bsd_to_sun(lp, cp) int i, secpercyl; u_short cksum, *sp1, *sp2; + if (lp->d_secsize != 512) + return (EINVAL); + sl = (struct sun_disklabel *)cp; /* Format conversion. */ |