Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sbin/disklabel Add options to define labelsector and -offset...
details: https://anonhg.NetBSD.org/src/rev/a54171f63e0a
branches: trunk
changeset: 1000049:a54171f63e0a
user: mlelstv <mlelstv%NetBSD.org@localhost>
date: Tue Jul 02 16:23:47 2019 +0000
description:
Add options to define labelsector and -offset and number of slices.
Make options to chose alternate label position for systems using MBR
more intuitive. -m now selects mode with MBR, -n selects mode without,
independent of the machine defaults.
diffstat:
sbin/disklabel/disklabel.8 | 51 ++++++++++++++++++++++++++++++++++++++++-----
sbin/disklabel/main.c | 50 +++++++++++++++++++++++++++++---------------
2 files changed, 78 insertions(+), 23 deletions(-)
diffs (237 lines):
diff -r a9784f3b710f -r a54171f63e0a sbin/disklabel/disklabel.8
--- a/sbin/disklabel/disklabel.8 Tue Jul 02 16:10:15 2019 +0000
+++ b/sbin/disklabel/disklabel.8 Tue Jul 02 16:23:47 2019 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: disklabel.8,v 1.68 2017/07/03 21:33:41 wiz Exp $
+.\" $NetBSD: disklabel.8,v 1.69 2019/07/02 16:23:47 mlelstv Exp $
.\"
.\" Copyright (c) 1987, 1988, 1991, 1993
.\" The Regents of the University of California. All rights reserved.
@@ -41,37 +41,52 @@
.Sh SYNOPSIS
.\" disklabel: read label
.Nm
-.Op Fl ACDFmrtv
+.Op Fl ACDFmnrtv
.Op Fl B Ar endian
+.Op Fl L Ar sector
.Op Fl M Ar machine
+.Op Fl O Ar offset
+.Op Fl P Ar size
.Ar disk
.\" disklabel -e: read/modify/write using $EDITOR
.Nm
.Fl e
-.Op Fl CDFImrv
+.Op Fl CDFImnrv
.Op Fl B Ar endian
+.Op Fl L Ar sector
.Op Fl M Ar machine
+.Op Fl O Ar offset
+.Op Fl P Ar size
.Ar disk
.\" disklabel -i: read/modify/write using builtin commands
.Nm
.Fl i
-.Op Fl DFImrv
+.Op Fl DFImnrv
.Op Fl B Ar endian
+.Op Fl L Ar sector
.Op Fl M Ar machine
+.Op Fl O Ar offset
+.Op Fl P Ar size
.Ar disk
.\" disklabel -R: write from edited output
.Nm
.Fl R
-.Op Fl DFmrv
+.Op Fl DFmnrv
.Op Fl B Ar endian
+.Op Fl L Ar sector
.Op Fl M Ar machine
+.Op Fl O Ar offset
+.Op Fl P Ar size
.Ar disk Ar protofile
.\" disklabel -w: write from disctab entry
.Nm
.Fl w
-.Op Fl DFmrv
+.Op Fl DFmnrv
.Op Fl B Ar endian
+.Op Fl L Ar sector
.Op Fl M Ar machine
+.Op Fl O Ar offset
+.Op Fl P Ar size
.Op Fl f Ar disktab
.Ar disk Ar disktype
.Oo Ar packid Oc
@@ -189,8 +204,23 @@
.It Fl M Ar machine
Specify the machine to generate a label for.
Defaults to the current machine it is compiled for.
+Specific details can be overridden via environment
+and with the options
+.Fl B, L, O, p, m
+and
+.Fl n.
+.It Fl L
+num specify the relative sector number of the disklabel
+similar to the environment variable DISKLABELSECTOR.
+.It Fl O
+num specify the relative byte offset of the disklabel.
+similar to the environment variable DISKLABELOFFSET.
+.It Fl P
+num specify the size of the partition table.
.It Fl m
expect the label to have an MBR.
+.It Fl n
+expect the label not to have an MBR.
.It Fl r
Read/write the disk directly rather than using
.Xr ioctl 2
@@ -368,3 +398,12 @@
to write directly to disk, and bypass the format translation.
This will result in a disk label that the PROMs will not recognize,
and that therefore cannot be booted from.
+.Pp
+The
+.Fl m
+flag previously toggled between using an MBR and not using an MBR,
+with the default being implied by the machine type.
+It now always enables MBR mode, independent of the machine default.
+Use the
+.Fl n
+flag to disable MBR mode.
diff -r a9784f3b710f -r a54171f63e0a sbin/disklabel/main.c
--- a/sbin/disklabel/main.c Tue Jul 02 16:10:15 2019 +0000
+++ b/sbin/disklabel/main.c Tue Jul 02 16:23:47 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: main.c,v 1.50 2018/06/27 01:14:48 kamil Exp $ */
+/* $NetBSD: main.c,v 1.51 2019/07/02 16:23:47 mlelstv Exp $ */
/*
* Copyright (c) 2006 The NetBSD Foundation, Inc.
@@ -76,7 +76,7 @@
static char sccsid[] = "@(#)disklabel.c 8.4 (Berkeley) 5/4/95";
/* from static char sccsid[] = "@(#)disklabel.c 1.2 (Symmetric) 11/28/85"; */
#else
-__RCSID("$NetBSD: main.c,v 1.50 2018/06/27 01:14:48 kamil Exp $");
+__RCSID("$NetBSD: main.c,v 1.51 2019/07/02 16:23:47 mlelstv Exp $");
#endif
#endif /* not lint */
@@ -154,7 +154,6 @@
static int Dflag; /* Delete old labels (use with write) */
static int Iflag; /* Read/write direct, but default if absent */
static int lflag; /* List all known file system types and exit */
-static int mflag; /* Expect disk to contain an MBR */
static int verbose;
static int read_all; /* set if op = READ && Aflag */
@@ -481,6 +480,7 @@
#endif
DELETE
} op = UNSPEC, old_op;
+ unsigned long val;
#ifndef HAVE_NBTOOL_CONFIG_H
#if !defined(NATIVELABEL_ONLY)
@@ -502,22 +502,13 @@
}
#endif
- mflag = labelusesmbr;
- if (mflag < 0) {
-#if HAVE_NBTOOL_CONFIG_H
- warn("getlabelusesmbr() failed");
-#else
- warn("getlabelusesmbr() failed");
- mflag = LABELUSESMBR;
-#endif
- }
#if HAVE_NBTOOL_CONFIG_H
/* We must avoid doing any ioctl requests */
Fflag = rflag = 1;
#endif
error = 0;
- while ((ch = getopt(argc, argv, "AB:CDFIM:NRWef:ilmrtvw")) != -1) {
+ while ((ch = getopt(argc, argv, "AB:CDFIL:M:NO:P:RWef:ilmnrtvw")) != -1) {
old_op = op;
switch (ch) {
case 'A': /* Action all labels */
@@ -559,6 +550,24 @@
case 'N': /* Disallow writes to label sector */
op = SETREADONLY;
break;
+ case 'L': /* Label sector */
+ val = strtoul(optarg, NULL, 10);
+ if ((val == ULONG_MAX && errno == ERANGE) || val > UINT_MAX)
+ err(EXIT_FAILURE, "invalid label sector: %s", optarg);
+ labelsector = val;
+ break;
+ case 'O': /* Label offset */
+ val = strtoul(optarg, NULL, 10);
+ if ((val == ULONG_MAX && errno == ERANGE) || val > UINT_MAX)
+ err(EXIT_FAILURE, "invalid label offset: %s", optarg);
+ labeloffset = val;
+ break;
+ case 'P': /* Max partitions */
+ val = strtoul(optarg, NULL, 10);
+ if ((val == ULONG_MAX && errno == ERANGE) || val < 1 || val > UINT_MAX)
+ err(EXIT_FAILURE, "invalid max partitions: %s", optarg);
+ maxpartitions = val;
+ break;
case 'W': /* Allow writes to label sector */
op = SETWRITABLE;
break;
@@ -578,7 +587,10 @@
lflag = 1;
break;
case 'm': /* Expect disk to have an MBR */
- mflag ^= 1;
+ labelusesmbr = 1;
+ break;
+ case 'n': /* Expect disk to not have an MBR */
+ labelusesmbr = 0;
break;
case 'r': /* Read/write label directly from disk */
rflag = 1;
@@ -600,6 +612,10 @@
usage();
}
+ if (maxpartitions > MAXPARTITIONS) {
+ errx(1, "too large maxpartitions > %u\n", MAXPARTITIONS);
+ }
+
#if !defined(NATIVELABEL_ONLY)
if (maxpartitions == 0) {
errx(1, "unknown label: use -M/-B and $MACHINE/$MACHINE_ARCH");
@@ -989,7 +1005,7 @@
static int
writelabel_mbr(int f, u_int sector)
{
- return update_label(f, sector, mflag ? LABELOFFSET_MBR : ~0U) ? 2 : 0;
+ return update_label(f, sector, labelusesmbr ? LABELOFFSET_MBR : ~0U) ? 2 : 0;
}
#endif /* !NO_MBR_SUPPORT */
@@ -1369,7 +1385,7 @@
}
}
- if (mflag && process_mbr(f, readlabel_mbr) == 0)
+ if (labelusesmbr && process_mbr(f, readlabel_mbr) == 0)
return 0;
disk_lp = find_label(f, 0);
@@ -1378,7 +1394,7 @@
return 0;
}
- if (!mflag && process_mbr(f, readlabel_mbr) == 0)
+ if (!labelusesmbr && process_mbr(f, readlabel_mbr) == 0)
return 0;
return 1;
Home |
Main Index |
Thread Index |
Old Index