summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKenneth R Westerback <krw@cvs.openbsd.org>2011-07-19 01:08:36 +0000
committerKenneth R Westerback <krw@cvs.openbsd.org>2011-07-19 01:08:36 +0000
commit35079cc1e8f038dc53a700df6b690ac8b2552f03 (patch)
treecfffbec194717d7262a27b85274016e283aec58e
parent880744d74684f8d48bb797c25dc53a6157a83643 (diff)
Warn about but don't prevent installboot from installing /boot when
the OpenBSD partition starts at >128G. This restores previous behaviour but adds the warning. ok deraadt@ guenther@
-rw-r--r--sys/arch/amd64/stand/installboot/installboot.c10
-rw-r--r--sys/arch/amd64/stand/libsa/biosdev.c6
-rw-r--r--sys/arch/i386/stand/installboot/installboot.c10
-rw-r--r--sys/arch/i386/stand/libsa/biosdev.c6
4 files changed, 12 insertions, 20 deletions
diff --git a/sys/arch/amd64/stand/installboot/installboot.c b/sys/arch/amd64/stand/installboot/installboot.c
index 0434eeed25a..9f38b5386e2 100644
--- a/sys/arch/amd64/stand/installboot/installboot.c
+++ b/sys/arch/amd64/stand/installboot/installboot.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: installboot.c,v 1.22 2011/07/05 18:34:10 krw Exp $ */
+/* $OpenBSD: installboot.c,v 1.23 2011/07/19 01:08:34 krw Exp $ */
/* $NetBSD: installboot.c,v 1.5 1995/11/17 23:23:50 gwr Exp $ */
/*
@@ -243,13 +243,13 @@ write_bootblocks(int devfd, struct disklabel *dl)
errx(1, "no OpenBSD partition");
}
- if (start + (protosize / dl->d_secsize) > BOOTBIOS_MAXSEC)
- errx(1, "invalid location: all of /boot must be < sector %u.",
- BOOTBIOS_MAXSEC);
-
if (verbose)
fprintf(stderr, "/boot will be written at sector %u\n", start);
+ if (start + (protosize / dl->d_secsize) > BOOTBIOS_MAXSEC)
+ warnx("/boot extends beyond sector %u. OpenBSD might not boot.",
+ BOOTBIOS_MAXSEC);
+
if (!nowrite) {
if (lseek(devfd, (off_t)start * dl->d_secsize, SEEK_SET) < 0)
err(1, "seek bootstrap");
diff --git a/sys/arch/amd64/stand/libsa/biosdev.c b/sys/arch/amd64/stand/libsa/biosdev.c
index d4bdfe2c5c4..a8950c2375e 100644
--- a/sys/arch/amd64/stand/libsa/biosdev.c
+++ b/sys/arch/amd64/stand/libsa/biosdev.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: biosdev.c,v 1.15 2011/03/17 12:53:44 krw Exp $ */
+/* $OpenBSD: biosdev.c,v 1.16 2011/07/19 01:08:35 krw Exp $ */
/*
* Copyright (c) 1996 Michael Shalayeff
@@ -216,10 +216,6 @@ EDD_rw(int rw, int dev, u_int32_t daddr, u_int32_t nblk, void *buf)
int rv;
volatile static struct EDD_CB cb;
- /* Some (most?) BIOSen get confused by i/o above 2 ^ 28 - 1 sector. */
- if ((daddr + nblk) > BOOTBIOS_MAXSEC)
- return (1); /* Invalid function/parameter. */
-
/* Zero out reserved stuff */
cb.edd_res1 = 0;
cb.edd_res2 = 0;
diff --git a/sys/arch/i386/stand/installboot/installboot.c b/sys/arch/i386/stand/installboot/installboot.c
index 5beecb783f3..781da08251a 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.65 2011/07/05 18:34:10 krw Exp $ */
+/* $OpenBSD: installboot.c,v 1.66 2011/07/19 01:08:35 krw Exp $ */
/* $NetBSD: installboot.c,v 1.5 1995/11/17 23:23:50 gwr Exp $ */
/*
@@ -239,13 +239,13 @@ write_bootblocks(int devfd, struct disklabel *dl)
errx(1, "no OpenBSD partition");
}
- if (start + (protosize / dl->d_secsize) > BOOTBIOS_MAXSEC)
- errx(1, "invalid location: all of /boot must be < sector %u.",
- BOOTBIOS_MAXSEC);
-
if (verbose)
fprintf(stderr, "/boot will be written at sector %u\n", start);
+ if (start + (protosize / dl->d_secsize) > BOOTBIOS_MAXSEC)
+ warnx("/boot extends beyond sector %u. OpenBSD might not boot.",
+ BOOTBIOS_MAXSEC);
+
if (!nowrite) {
if (lseek(devfd, (off_t)start * dl->d_secsize, SEEK_SET) < 0)
err(1, "seek bootstrap");
diff --git a/sys/arch/i386/stand/libsa/biosdev.c b/sys/arch/i386/stand/libsa/biosdev.c
index de6efca14e5..6a61ea47d78 100644
--- a/sys/arch/i386/stand/libsa/biosdev.c
+++ b/sys/arch/i386/stand/libsa/biosdev.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: biosdev.c,v 1.83 2011/03/17 12:53:44 krw Exp $ */
+/* $OpenBSD: biosdev.c,v 1.84 2011/07/19 01:08:35 krw Exp $ */
/*
* Copyright (c) 1996 Michael Shalayeff
@@ -217,10 +217,6 @@ EDD_rw(int rw, int dev, u_int32_t daddr, u_int32_t nblk, void *buf)
int rv;
volatile static struct EDD_CB cb;
- /* Some (most?) BIOSen get confused by i/o above 2 ^ 28 - 1 sector. */
- if ((daddr + nblk) > BOOTBIOS_MAXSEC)
- return (1); /* Invalid function/parameter. */
-
/* Zero out reserved stuff */
cb.edd_res1 = 0;
cb.edd_res2 = 0;