summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTheo de Raadt <deraadt@cvs.openbsd.org>2007-06-17 00:32:22 +0000
committerTheo de Raadt <deraadt@cvs.openbsd.org>2007-06-17 00:32:22 +0000
commitad5e118396fcd2a9b7b0e050d2afe54576f65cba (patch)
tree99adb4a0ec68c89788a0b5d911d2e6cc6cc58d9b
parentea009c71d607b258f0ac14f65c465aed5c53f364 (diff)
On Sun machines, disklabels coming from the kernel will now have a d_flags
bit D_VENDOR if they face the Sun cylinder / start-at-zero semantics. Other disklabels found on these architectures do not have these issues, and do not need to be constrained. checked by otto
-rw-r--r--sbin/disklabel/Makefile4
-rw-r--r--sbin/disklabel/disklabel.c27
-rw-r--r--sbin/disklabel/editor.c32
3 files changed, 39 insertions, 24 deletions
diff --git a/sbin/disklabel/Makefile b/sbin/disklabel/Makefile
index 2171bc7f567..0c71f15a09e 100644
--- a/sbin/disklabel/Makefile
+++ b/sbin/disklabel/Makefile
@@ -1,4 +1,4 @@
-# $OpenBSD: Makefile,v 1.44 2007/06/16 17:32:13 deraadt Exp $
+# $OpenBSD: Makefile,v 1.45 2007/06/17 00:32:21 deraadt Exp $
PROG= disklabel
SRCS= disklabel.c dkcksum.c editor.c manual.c
@@ -58,7 +58,7 @@ CFLAGS+= -DSEEALSO="\"installboot(8)\""
.if (${MACHINE} == "solbourne") || (${MACHINE} == "sparc") || \
(${MACHINE} == "sparc64")
-CFLAGS+= -DSEEALSO="\"installboot(8)\"" -DCYLCHECK -DAAT0
+CFLAGS+= -DSEEALSO="\"installboot(8)\"" -DSUN_CYLCHECK -DSUN_AAT0
.endif
.if (${MACHINE} == "zaurus")
diff --git a/sbin/disklabel/disklabel.c b/sbin/disklabel/disklabel.c
index 6c3bdd49bf9..b64099e807f 100644
--- a/sbin/disklabel/disklabel.c
+++ b/sbin/disklabel/disklabel.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: disklabel.c,v 1.113 2007/06/08 19:08:35 otto Exp $ */
+/* $OpenBSD: disklabel.c,v 1.114 2007/06/17 00:32:21 deraadt Exp $ */
/*
* Copyright (c) 1987, 1993
@@ -39,7 +39,7 @@ static const char copyright[] =
#endif /* not lint */
#ifndef lint
-static const char rcsid[] = "$OpenBSD: disklabel.c,v 1.113 2007/06/08 19:08:35 otto Exp $";
+static const char rcsid[] = "$OpenBSD: disklabel.c,v 1.114 2007/06/17 00:32:21 deraadt Exp $";
#endif /* not lint */
#include <sys/param.h>
@@ -1083,6 +1083,8 @@ display(FILE *f, struct disklabel *lp, char **mp, char unit, int edit,
fprintf(f, "flags:");
if (lp->d_flags & D_BADSECT)
fprintf(f, " badsect");
+ if (lp->d_flags & D_VENDOR)
+ fprintf(f, " vendor");
putc('\n', f);
}
fprintf(f, "bytes/sector: %u\n", lp->d_secsize);
@@ -1656,16 +1658,19 @@ checklabel(struct disklabel *lp)
if (DL_GETPSIZE(pp) == 0 && DL_GETPOFFSET(pp) != 0)
warnx("warning, partition %c: size 0, but offset %lld",
part, DL_GETPSIZE(pp));
-#ifdef CYLCHECK
- if (i != RAW_PART && DL_GETPSIZE(pp) % lp->d_secpercyl)
- warnx("warning, partition %c: size %% cylinder-size != 0",
- part);
- if (i != RAW_PART && DL_GETPOFFSET(pp) % lp->d_secpercyl)
- warnx("warning, partition %c: offset %% cylinder-size != 0",
- part);
+#ifdef SUN_CYLCHECK
+ if (lp->d_flags & D_VENDOR) {
+ if (i != RAW_PART && DL_GETPSIZE(pp) % lp->d_secpercyl)
+ warnx("warning, partition %c: size %% "
+ "cylinder-size != 0", part);
+ if (i != RAW_PART && DL_GETPOFFSET(pp) % lp->d_secpercyl)
+ warnx("warning, partition %c: offset %% "
+ "cylinder-size != 0", part);
+ }
#endif
-#ifdef AAT0
- if (i == 0 && DL_GETPSIZE(pp) != 0 && DL_GETPOFFSET(pp) != 0) {
+#ifdef SUN_AAT0
+ if ((lp->d_flags & D_VENDOR) &&
+ i == 0 && DL_GETPSIZE(pp) != 0 && DL_GETPOFFSET(pp) != 0) {
warnx("this architecture requires partition 'a' to "
"start at sector 0");
errors++;
diff --git a/sbin/disklabel/editor.c b/sbin/disklabel/editor.c
index df0196dd9a6..a4087326a45 100644
--- a/sbin/disklabel/editor.c
+++ b/sbin/disklabel/editor.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: editor.c,v 1.121 2007/06/08 20:21:13 millert Exp $ */
+/* $OpenBSD: editor.c,v 1.122 2007/06/17 00:32:21 deraadt Exp $ */
/*
* Copyright (c) 1997-2000 Todd C. Miller <Todd.Miller@courtesan.com>
@@ -17,7 +17,7 @@
*/
#ifndef lint
-static char rcsid[] = "$OpenBSD: editor.c,v 1.121 2007/06/08 20:21:13 millert Exp $";
+static char rcsid[] = "$OpenBSD: editor.c,v 1.122 2007/06/17 00:32:21 deraadt Exp $";
#endif /* not lint */
#include <sys/types.h>
@@ -150,8 +150,13 @@ editor(struct disklabel *lp, int f, char *dev, char *fstabfile)
pp->p_fragblock = pp->p_cpg = 0;
}
-#ifdef CYLCHECK
- puts("This platform requires that partition offsets/sizes be on cylinder boundaries.\nPartition offsets/sizes will be rounded to the nearest cylinder automatically.");
+#ifdef SUN_CYLCHECK
+ if (label.d_flags & D_VENDOR) {
+ puts("This platform requires that partition offsets/sizes "
+ "be on cylinder boundaries.\n"
+ "Partition offsets/sizes will be rounded to the "
+ "nearest cylinder automatically.");
+ }
#endif
/* Set d_bbsize and d_sbsize as necessary */
@@ -438,12 +443,15 @@ editor_add(struct disklabel *lp, char **mp, u_int64_t *freep, char *p)
u_int64_t ui, old_offset, old_size, new_offset, new_size;
/* XXX - prompt user to steal space from another partition instead */
-#ifdef CYLCHECK
- if (*freep < lp->d_secpercyl)
-#else
- if (*freep == 0)
+#ifdef SUN_CYLCHECK
+ if ((lp->d_flags & D_VENDOR) && *freep < lp->d_secpercyl) {
+ fputs("No space left, you need to shrink a partition "
+ "(need at least one full cylinder)\n",
+ stderr);
+ return;
+ }
#endif
- {
+ if (*freep == 0) {
fputs("No space left, you need to shrink a partition\n",
stderr);
return;
@@ -1116,7 +1124,9 @@ getuint(struct disklabel *lp, int partno, char *prompt, char *helpstring,
if ((flags & DO_ROUNDING) && rval != ULLONG_MAX) {
/* Round to nearest cylinder unless given in sectors */
if (
-#ifndef CYLCHECK
+#ifdef SUN_CYLCHECK
+ ((lp->d_flags & D_VENDOR) || mult != 1) &&
+#else
mult != 1 &&
#endif
(rval + offset) % lp->d_secpercyl != 0) {
@@ -1984,7 +1994,7 @@ get_offset(struct disklabel *lp, int partno)
"at sector %llu, you tried to add a partition at %llu."
" You can use the 'b' command to change the size "
"of the OpenBSD portion.\n", ending_sector, ui);
-#ifdef AAT0
+#ifdef SUN_AAT0
else if (partno == 0 && ui != 0)
fprintf(stderr, "This architecture requires that "
"partition 'a' start at sector 0.\n");