summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPer Fogelstrom <pefo@cvs.openbsd.org>1996-09-27 19:14:09 +0000
committerPer Fogelstrom <pefo@cvs.openbsd.org>1996-09-27 19:14:09 +0000
commitfa6a09b54e98c39000009800f494eba1b766707d (patch)
tree5f01538487c35a0488f7e73caa9f0a235e7aa83b
parentb44a616ea5c66f88ef4bccbb7583afc03acb4c33 (diff)
OpenBSD changes
-rw-r--r--sys/arch/arc/arc/disksubr.c69
1 files changed, 46 insertions, 23 deletions
diff --git a/sys/arch/arc/arc/disksubr.c b/sys/arch/arc/arc/disksubr.c
index 6665f0e2d62..88cd87466bd 100644
--- a/sys/arch/arc/arc/disksubr.c
+++ b/sys/arch/arc/arc/disksubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: disksubr.c,v 1.4 1996/09/22 11:26:09 pefo Exp $ */
+/* $OpenBSD: disksubr.c,v 1.5 1996/09/27 19:14:08 pefo Exp $ */
/*
* Copyright (c) 1994, 1995 Carnegie-Mellon University.
@@ -51,11 +51,10 @@ dk_establish(dk, dev)
}
/*
- * Attempt to read a disk label from a device
- * using the indicated stategy routine.
+ * Attempt to read a disk label from a device * using the indicated stategy routine.
* The label must be partly set up before this:
- * secpercyl and anything required in the strategy routine
- * (e.g., sector size) must be filled in before calling us.
+ * secpercyl and anything required in the strategy routine
+ * (e.g., sector size) must be filled in before calling us.
* Returns null on success and an error string on failure.
*/
char *
@@ -69,8 +68,7 @@ readdisklabel(dev, strat, lp, clp)
struct disklabel *dlp;
struct dos_partition *dp = clp->dosparts;
char *msg = NULL;
- int dospartoff = 0;
- int i;
+ int dospart, dospartoff, i;
/* minimal requirements for archtypal disk label */
if (lp->d_secperunit == 0)
@@ -87,6 +85,8 @@ readdisklabel(dev, strat, lp, clp)
/* obtain buffer to probe drive with */
bp = geteblk((int)lp->d_secsize);
bp->b_dev = dev;
+ dospartoff = 0;
+ dospart = -1;
/* do dos partitions in the process of getting disklabel? */
if (dp) {
@@ -101,22 +101,35 @@ readdisklabel(dev, strat, lp, clp)
if (biowait(bp)) {
msg = "dos partition I/O error";
goto done;
- } else if (*(unsigned int *)(bp->b_data) == 0x8efac033) {
+ }
+ if (*(unsigned int *)(bp->b_data) == 0x8efac033) {
/* XXX how do we check veracity/bounds of this? */
bcopy(bp->b_data + DOSPARTOFF, dp, NDOSPART * sizeof(*dp));
- for (i = 0; i < NDOSPART; i++, dp++) {
- /* is this ours? */
+
+ for (i = 0, dp = clp->dosparts; i < NDOSPART; i++, dp++) {
+ if (dp->dp_size && dp->dp_typ == DOSPTYP_OPENBSD
+ && dospart < 0)
+ dospart = i;
+ }
+ for (i = 0, dp = clp->dosparts; i < NDOSPART; i++, dp++) {
if (dp->dp_size && dp->dp_typ == DOSPTYP_386BSD
- && dospartoff == 0) {
- dospartoff = dp->dp_start;
+ && dospart < 0)
+ dospart = i;
+ }
+ if(dospart >= 0) {
+ /*
+ * set part a to show OpenBSD part
+ */
+ dp = clp->dosparts+dospart;
+ dospartoff = dp->dp_start;
- /* set part a to show OpenBSD part */
- lp->d_partitions[0].p_size = dp->dp_size;
- lp->d_partitions[0].p_offset = dp->dp_start;
- lp->d_ntracks = dp->dp_ehd + 1;
- lp->d_nsectors = DPSECT(dp->dp_esect);
- lp->d_secpercyl = lp->d_ntracks * lp->d_nsectors;
- }
+ lp->d_partitions[0].p_size = dp->dp_size;
+ lp->d_partitions[0].p_offset = dp->dp_start;
+ lp->d_partitions[RAW_PART].p_size = dp->dp_size;
+ lp->d_partitions[RAW_PART].p_offset = dp->dp_start;
+ lp->d_ntracks = dp->dp_ehd + 1;
+ lp->d_nsectors = DPSECT(dp->dp_esect);
+ lp->d_secpercyl = lp->d_ntracks * lp->d_nsectors;
}
}
@@ -213,10 +226,12 @@ writedisklabel(dev, strat, lp, clp)
struct disklabel *dlp;
struct dos_partition *dp = clp->dosparts;
int error = 0, i;
- int dospartoff = 0;
+ int dospart, dospartoff;
bp = geteblk((int)lp->d_secsize);
bp->b_dev = dev;
+ dospart = -1;
+ dospartoff = 0;
/* do dos partitions in the process of getting disklabel? */
if (dp) {
@@ -231,10 +246,18 @@ writedisklabel(dev, strat, lp, clp)
&& *(unsigned int *)(bp->b_data) == 0x8efac033) {
/* XXX how do we check veracity/bounds of this? */
bcopy(bp->b_data + DOSPARTOFF, dp, NDOSPART * sizeof(*dp));
- for (i = 0; i < NDOSPART; i++, dp++) {
- /* is this ours? */
+
+ for (i = 0, dp = clp->dosparts; i < NDOSPART; i++, dp++) {
+ if (dp->dp_size && dp->dp_typ == DOSPTYP_OPENBSD
+ && dospart < 0) {
+ dospart = i;
+ dospartoff = dp->dp_start;
+ }
+ }
+ for (i = 0, dp = clp->dosparts; i < NDOSPART; i++, dp++) {
if (dp->dp_size && dp->dp_typ == DOSPTYP_386BSD
- && dospartoff == 0) {
+ && dospart < 0) {
+ dospart = i;
dospartoff = dp->dp_start;
}
}