diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 1998-04-20 07:25:16 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 1998-04-20 07:25:16 +0000 |
commit | 2d25bb8cedd87a935fbf797d94187fb35cd2b941 (patch) | |
tree | a662908bfaa14d7708f9879a37f02e29a7b175f2 /sys/arch | |
parent | 7cb300911a389d3e6e1eab3b4ea952c0c440dcac (diff) |
fix the problem w/ /boot being fragmented in a non-contig
blocks. fixed by flushing the previous blocks completely
before starting new record for a new block(s) location.
Diffstat (limited to 'sys/arch')
-rw-r--r-- | sys/arch/i386/stand/installboot/installboot.c | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/sys/arch/i386/stand/installboot/installboot.c b/sys/arch/i386/stand/installboot/installboot.c index c1a6aca4c0f..c938c51f005 100644 --- a/sys/arch/i386/stand/installboot/installboot.c +++ b/sys/arch/i386/stand/installboot/installboot.c @@ -1,4 +1,4 @@ -/* $OpenBSD: installboot.c,v 1.30 1998/04/18 07:39:38 deraadt Exp $ */ +/* $OpenBSD: installboot.c,v 1.31 1998/04/20 07:25:15 mickey Exp $ */ /* $NetBSD: installboot.c,v 1.5 1995/11/17 23:23:50 gwr Exp $ */ /* @@ -458,6 +458,7 @@ loadblocknums(boot, devfd, dl) if (verbose) fprintf(stderr, "Using disk geometry of %u sectors and %u heads.\n", dl->d_nsectors, dl->d_secpercyl/dl->d_nsectors); + /* * Get the block numbers; we don't handle fragments */ @@ -512,6 +513,7 @@ record_block(bt, blk, bs, dl) static u_int ss = 0, l = 0, i = 0; /* start and len of group */ int ret = 0; + /* printf("%u, %u\n", blk, bs); */ if (ss == 0) { /* very beginning */ ss = blk; l = bs; @@ -538,18 +540,20 @@ record_block(bt, blk, bs, dl) if (verbose) fprintf(stderr, "%2d: %2d @(%d %d %d) (%d-%d)\n", i, bt[3], c, bt[2], s, ss, ss + bt[3] - 1); + i++; - if ((ss % dl->d_nsectors + l) >= dl->d_nsectors) { - ss += bt[3]; - l -= bt[3]; - l += bs; - } else { + ss += bt[3]; + l -= bt[3]; + if ((ss + l) != blk) { + /* printf ("l=%u\n", l); */ + if (l) + ret += record_block(bt + 4, 0, 0, dl); ss = blk; l = bs; - } + } else + l += bs; - i++; - ret = 4; + ret += 4; } else { l += bs; } |