summaryrefslogtreecommitdiff
path: root/sys/arch/sparc64
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/sparc64')
-rw-r--r--sys/arch/sparc64/sparc64/disksubr.c46
1 files changed, 15 insertions, 31 deletions
diff --git a/sys/arch/sparc64/sparc64/disksubr.c b/sys/arch/sparc64/sparc64/disksubr.c
index 7addd06835e..99c28286c3c 100644
--- a/sys/arch/sparc64/sparc64/disksubr.c
+++ b/sys/arch/sparc64/sparc64/disksubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: disksubr.c,v 1.47 2007/09/19 23:47:50 tsi Exp $ */
+/* $OpenBSD: disksubr.c,v 1.48 2007/10/02 03:26:59 krw Exp $ */
/* $NetBSD: disksubr.c,v 1.13 2000/12/17 22:39:18 pk Exp $ */
/*
@@ -229,11 +229,12 @@ sun_extended_sum(struct sun_disklabel *sl, void *end)
static char *
disklabel_sun_to_bsd(struct sun_disklabel *sl, struct disklabel *lp)
{
- struct partition *npp;
- struct sun_dkpart *spp;
+ struct sun_preamble *preamble = (struct sun_preamble *)sl;
struct sun_partinfo *ppp;
- int i, secpercyl;
+ struct sun_dkpart *spp;
+ struct partition *npp;
u_short cksum = 0, *sp1, *sp2;
+ int i, secpercyl;
/* Verify the XOR check. */
sp1 = (u_short *)sl;
@@ -336,42 +337,24 @@ disklabel_sun_to_bsd(struct sun_disklabel *sl, struct disklabel *lp)
npp->p_cpg = sl->sl_cpg[i];
}
}
- } else if (sl->sl_nparts <= 8) {
+ } else if (preamble->sl_nparts <= 8) {
/*
* A more traditional Sun label. Recognise certain filesystem
* types from it, if they are available.
*/
- if ((i = sl->sl_nparts) == 0) {
- for (i = 8; i-- > 0; ) {
- npp = &lp->d_partitions[i];
- if (npp->p_size == 0)
- continue;
-
- ppp = &sl->sl_ipart[i];
- if ((ppp->spi_tag == 0) && (ppp->spi_flag == 0))
- continue;
+ i = preamble->sl_nparts;
+ if (i == 0)
+ i = 8;
- i = 8;
- break;
- }
- }
-
- while (i-- > 0) {
- npp = &lp->d_partitions[i];
+ npp = &lp->d_partitions[i-1];
+ ppp = &preamble->sl_part[i-1];
+ for (; i > 0; i--, npp--, ppp--) {
if (npp->p_size == 0)
continue;
+ if ((ppp->spi_tag == 0) && (ppp->spi_flag == 0))
+ continue;
- ppp = &sl->sl_ipart[i];
switch (ppp->spi_tag) {
- case SPTAG_EMPTY:
- case SPTAG_BOOT:
- case SPTAG_WHOLE_DISK:
- npp->p_fstype = FS_UNUSED;
- break;
- case SPTAG_SUNOS_SWAP:
- case SPTAG_LINUX_SWAP:
- npp->p_fstype = FS_UNUSED; /* FS_SWAP? */
- break;
case SPTAG_SUNOS_ROOT:
case SPTAG_SUNOS_USR:
case SPTAG_SUNOS_VAR:
@@ -385,6 +368,7 @@ disklabel_sun_to_bsd(struct sun_disklabel *sl, struct disklabel *lp)
npp->p_fstype = FS_EXT2FS;
break;
default:
+ /* FS_SWAP for _SUNOS_SWAP and _LINUX_SWAP? */
npp->p_fstype = FS_UNUSED;
break;
}