summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>2007-06-08 22:17:11 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>2007-06-08 22:17:11 +0000
commite1769cf649989a39a8dc0a31695bd2d9f0e2696a (patch)
tree745ef152f9f6991c539bf3c541e5d0ff3c463472
parent2fe0fa70ea5d2b75bedbe1aab017c30f164ab998 (diff)
we need a new sub-code in the VID driver to indicate new "struct partition"
fields which contain p_sizeh and such fields. handle both kinds correctly, we hope. tested on mvme68k
-rw-r--r--sys/arch/mvme68k/mvme68k/disksubr.c14
-rw-r--r--sys/arch/mvme88k/mvme88k/disksubr.c14
2 files changed, 16 insertions, 12 deletions
diff --git a/sys/arch/mvme68k/mvme68k/disksubr.c b/sys/arch/mvme68k/mvme68k/disksubr.c
index 278bb282843..41988697b2c 100644
--- a/sys/arch/mvme68k/mvme68k/disksubr.c
+++ b/sys/arch/mvme68k/mvme68k/disksubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: disksubr.c,v 1.48 2007/06/08 05:34:28 deraadt Exp $ */
+/* $OpenBSD: disksubr.c,v 1.49 2007/06/08 22:17:06 deraadt Exp $ */
/*
* Copyright (c) 1998 Steve Murphree, Jr.
* Copyright (c) 1995 Dale Rahn.
@@ -351,7 +351,7 @@ bsdtocpulabel(struct disklabel *lp, struct cpu_disklabel *clp)
clp->checksum = lp->d_checksum;
bcopy(&lp->d_partitions[0], clp->vid_4, sizeof(struct partition) * 4);
bcopy(&lp->d_partitions[4], clp->cfg_4, sizeof(struct partition) * 12);
- clp->version = 1;
+ clp->version = 2;
/* Put "MOTOROLA" in the VID. This makes it a valid boot disk. */
mot = clp->vid_mot;
@@ -370,6 +370,7 @@ cputobsdlabel(struct disklabel *lp, struct cpu_disklabel *clp)
{
int i;
+ lp->d_version = 0;
if (clp->version == 0) {
lp->d_magic = clp->magic1;
lp->d_type = clp->type;
@@ -426,8 +427,6 @@ cputobsdlabel(struct disklabel *lp, struct cpu_disklabel *clp)
lp->d_sbsize = clp->sbsize;
bcopy(clp->vid_4, &lp->d_partitions[0], sizeof(struct partition) * 4);
bcopy(clp->cfg_4, &lp->d_partitions[4], sizeof(struct partition) * 12);
- lp->d_checksum = 0;
- lp->d_checksum = dkcksum(lp);
} else {
lp->d_magic = clp->magic1;
lp->d_type = clp->type;
@@ -484,7 +483,10 @@ cputobsdlabel(struct disklabel *lp, struct cpu_disklabel *clp)
lp->d_sbsize = clp->sbsize;
bcopy(clp->vid_4, &lp->d_partitions[0], sizeof(struct partition) * 4);
bcopy(clp->cfg_4, &lp->d_partitions[4], sizeof(struct partition) * 12);
- lp->d_checksum = 0;
- lp->d_checksum = dkcksum(lp);
}
+
+ if (clp->version == 2)
+ lp->d_version = 1;
+ lp->d_checksum = 0;
+ lp->d_checksum = dkcksum(lp);
}
diff --git a/sys/arch/mvme88k/mvme88k/disksubr.c b/sys/arch/mvme88k/mvme88k/disksubr.c
index 37e746f253b..01b194c612b 100644
--- a/sys/arch/mvme88k/mvme88k/disksubr.c
+++ b/sys/arch/mvme88k/mvme88k/disksubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: disksubr.c,v 1.44 2007/06/08 05:34:28 deraadt Exp $ */
+/* $OpenBSD: disksubr.c,v 1.45 2007/06/08 22:17:10 deraadt Exp $ */
/*
* Copyright (c) 1998 Steve Murphree, Jr.
* Copyright (c) 1995 Dale Rahn.
@@ -351,7 +351,7 @@ bsdtocpulabel(struct disklabel *lp, struct cpu_disklabel *clp)
clp->checksum = lp->d_checksum;
bcopy(&lp->d_partitions[0], clp->vid_4, sizeof(struct partition) * 4);
bcopy(&lp->d_partitions[4], clp->cfg_4, sizeof(struct partition) * 12);
- clp->version = 1;
+ clp->version = 2;
/* Put "MOTOROLA" in the VID. This makes it a valid boot disk. */
mot = clp->vid_mot;
@@ -370,6 +370,7 @@ cputobsdlabel(struct disklabel *lp, struct cpu_disklabel *clp)
{
int i;
+ lp->d_version = 0;
if (clp->version == 0) {
lp->d_magic = clp->magic1;
lp->d_type = clp->type;
@@ -426,8 +427,6 @@ cputobsdlabel(struct disklabel *lp, struct cpu_disklabel *clp)
lp->d_sbsize = clp->sbsize;
bcopy(clp->vid_4, &lp->d_partitions[0], sizeof(struct partition) * 4);
bcopy(clp->cfg_4, &lp->d_partitions[4], sizeof(struct partition) * 12);
- lp->d_checksum = 0;
- lp->d_checksum = dkcksum(lp);
} else {
lp->d_magic = clp->magic1;
lp->d_type = clp->type;
@@ -484,7 +483,10 @@ cputobsdlabel(struct disklabel *lp, struct cpu_disklabel *clp)
lp->d_sbsize = clp->sbsize;
bcopy(clp->vid_4, &lp->d_partitions[0], sizeof(struct partition) * 4);
bcopy(clp->cfg_4, &lp->d_partitions[4], sizeof(struct partition) * 12);
- lp->d_checksum = 0;
- lp->d_checksum = dkcksum(lp);
}
+
+ if (clp->version == 2)
+ lp->d_version = 1;
+ lp->d_checksum = 0;
+ lp->d_checksum = dkcksum(lp);
}