aboutsummaryrefslogtreecommitdiff
path: root/sbin/disklabel/disklabel.c
diff options
context:
space:
mode:
authorJoerg Wunsch <joerg@FreeBSD.org>1996-01-22 01:01:15 +0000
committerJoerg Wunsch <joerg@FreeBSD.org>1996-01-22 01:01:15 +0000
commit425bed3abfd52960840d5124f7d7db7a93f47cd3 (patch)
tree5576c9391cf0e505da676bd2b14affcd1ecc20c4 /sbin/disklabel/disklabel.c
parentaaf0927a09615af89a260c3577bc45c0ad84bba8 (diff)
downloadsrc-425bed3abfd52960840d5124f7d7db7a93f47cd3.tar.gz
src-425bed3abfd52960840d5124f7d7db7a93f47cd3.zip
Finally implement the "auto" disktype. It attempts to get all the
required information from the driver, and produce a virgin disklabel for it. The latter might be further edited with `disklabel -e' to satisfy the user's need. The magic sequence is: disklabel -r -w sdX auto disklabel -e sdX
Notes
Notes: svn path=/head/; revision=13550
Diffstat (limited to 'sbin/disklabel/disklabel.c')
-rw-r--r--sbin/disklabel/disklabel.c48
1 files changed, 47 insertions, 1 deletions
diff --git a/sbin/disklabel/disklabel.c b/sbin/disklabel/disklabel.c
index d3337c1941a5..cf93fc4373ff 100644
--- a/sbin/disklabel/disklabel.c
+++ b/sbin/disklabel/disklabel.c
@@ -110,6 +110,7 @@ void Warning (char *, ...);
void Perror __P((char *));
void usage __P((void));
extern u_short dkcksum __P((struct disklabel *));
+struct disklabel * getvirginlabel __P((void));
#define DEFEDITOR _PATH_VI
#define streq(a,b) (strcmp(a,b) == 0)
@@ -336,7 +337,10 @@ makelabel(type, name, lp)
register struct disklabel *lp;
{
register struct disklabel *dp;
- char *strcpy();
+
+ if (strcmp(type, "auto") == 0)
+ dp = getvirginlabel();
+ else
dp = getdiskbyname(type);
if (dp == NULL) {
fprintf(stderr, "%s: unknown disk type\n", type);
@@ -1280,6 +1284,48 @@ checklabel(lp)
}
/*
+ * When operating on a "virgin" disk, try getting an initial label
+ * from the associated device driver. This might work for all device
+ * drivers that are able to fetch some initial device parameters
+ * without even having access to a (BSD) disklabel, like SCSI disks,
+ * most IDE drives, or vn devices.
+ *
+ * The device name must be given in its "canonical" form.
+ */
+struct disklabel *
+getvirginlabel(void)
+{
+ static struct disklabel lab;
+ char namebuf[BBSIZE];
+ int f;
+
+ if (dkname[0] == '/') {
+ fprintf(stderr,
+ "\"auto\" requires the usage of a canonical disk name.\n");
+ return 0;
+ }
+ (void)snprintf(namebuf, BBSIZE, "%sr%s", _PATH_DEV, dkname);
+ if ((f = open(namebuf, O_RDONLY, 0)) == -1) {
+ Perror("open()");
+ return 0;
+ }
+ if (ioctl(f, DIOCGDINFO, &lab) < 0) {
+ Perror("ioctl DIOCGDINFO");
+ close(f);
+ return 0;
+ }
+ close(f);
+ /* insert reasonable defaults where necessary */
+ if (lab.d_npartitions < 8) lab.d_npartitions = 8;
+ if (lab.d_bbsize == 0) lab.d_bbsize = BBSIZE;
+ if (lab.d_sbsize == 0) lab.d_sbsize = SBSIZE;
+ if (lab.d_rpm == 0) lab.d_rpm = 3600;
+ if (lab.d_interleave == 0) lab.d_interleave = 1;
+ return &lab;
+}
+
+
+/*
* If we are installing a boot program that doesn't fit in d_bbsize
* we need to mark those partitions that the boot overflows into.
* This allows newfs to prevent creation of a filesystem where it might