diff options
author | Theo de Raadt <deraadt@cvs.openbsd.org> | 1995-12-15 13:51:46 +0000 |
---|---|---|
committer | Theo de Raadt <deraadt@cvs.openbsd.org> | 1995-12-15 13:51:46 +0000 |
commit | db5da40b69bcf3378394f04b9cb622c6e2992cbd (patch) | |
tree | cbb4da0fb92bec599d3be1816ee0ef62a524a567 | |
parent | f5e1bb00af2da73350a4a4d728921024c7f3437a (diff) |
from gwr, changes in sun3 port
-rw-r--r-- | sys/arch/sparc/sparc/disksubr.c | 35 |
1 files changed, 21 insertions, 14 deletions
diff --git a/sys/arch/sparc/sparc/disksubr.c b/sys/arch/sparc/sparc/disksubr.c index 70d30d142c6..71a746fd8c1 100644 --- a/sys/arch/sparc/sparc/disksubr.c +++ b/sys/arch/sparc/sparc/disksubr.c @@ -233,19 +233,8 @@ setdisklabel(olp, nlp, openmask, clp) npp = &nlp->d_partitions[i]; 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); + *olp = *nlp; return (0); } @@ -391,7 +380,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; @@ -418,10 +408,24 @@ 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 { npp->p_fstype = sun_fstypes[i]; + if (npp->p_fstype == FS_BSDFFS) { + /* + * The sun label does not store the FFS fields, + * so just set them with default values here. + */ + npp->p_fsize = 1024; + npp->p_frag = 8; + npp->p_cpg = 16; + } + } } + lp->d_checksum = 0; + lp->d_checksum = dkcksum(lp); return (NULL); } @@ -442,6 +446,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. */ |