Add new option to fdisk: -e

This wipes the MBR and creates slice 1 as a FreeBSD slice covering the
disk starting from the second track to the cylinder aligned end of the disk.

This is the most compatibly layout we have as far as I know.
This commit is contained in:
phk 1999-08-23 11:06:19 +00:00
parent 41ff5573af
commit 78878d252b
4 changed files with 80 additions and 26 deletions

View File

@ -1,4 +1,4 @@
.\" $Id: $
.\" $Id: fdisk.8,v 1.14 1999/06/27 19:29:14 rnordier Exp $
.\"
.Dd October 4, 1996
.Dt FDISK 8
@ -8,7 +8,7 @@
.Nd PC partition table maintenance program
.Sh SYNOPSIS
.Nm fdisk
.Op Fl Baitu
.Op Fl Baeitu
.Op Fl b Ar bootcode
.Op Fl 1234
.Op Ar disk
@ -50,11 +50,6 @@ table. The second is used to write a partition table using a
and is designed to be used by other scripts/programs.
.Pp
Options are:
.It Fl B
Reinitialize the boot code contained in sector 0 of the disk. Ignored
if
.Fl f
is given.
.It Fl a
Change the active partition only. Ignored if
.Fl f
@ -62,6 +57,13 @@ is given.
.It Fl b Ar bootcode
Get the boot code from the file
.Ar bootcode .
.It Fl B
Reinitialize the boot code contained in sector 0 of the disk. Ignored
if
.Fl f
is given.
.It Fl e
Initialize the contents of sector 0 with one FreeBSD slice covering the entire disk.
.It Fl f Ar configfile
Set partition values using the file
.Ar configfile .

View File

@ -26,7 +26,7 @@
#ifndef lint
static const char rcsid[] =
"$Id: fdisk.c,v 1.28 1999/01/22 11:54:17 rnordier Exp $";
"$Id: fdisk.c,v 1.29 1999/06/27 19:29:15 rnordier Exp $";
#endif /* not lint */
#include <sys/disklabel.h>
@ -120,6 +120,7 @@ typedef struct cmd {
static int B_flag = 0; /* replace boot code */
static int a_flag = 0; /* set active partition */
static char *b_flag = NULL; /* path to boot code */
static int e_flag = 0; /* use entire disk for FreeBSD */
static int i_flag = 0; /* replace partition data */
static int u_flag = 0; /* update partition data */
static int t_flag = 0; /* test only, if f_flag is given */
@ -215,7 +216,7 @@ main(int argc, char *argv[])
{
int c, i;
while ((c = getopt(argc, argv, "Bab:f:ituv1234")) != -1)
while ((c = getopt(argc, argv, "Bab:ef:ituv1234")) != -1)
switch (c) {
case 'B':
B_flag = 1;
@ -226,6 +227,9 @@ main(int argc, char *argv[])
case 'b':
b_flag = optarg;
break;
case 'e':
e_flag = 1;
break;
case 'f':
f_flag = optarg;
break;
@ -288,6 +292,27 @@ main(int argc, char *argv[])
printf("******* Working on device %s *******\n",disk);
if (e_flag)
{
struct dos_partition *partp;
read_s0();
reset_boot();
partp = (struct dos_partition *) (&mboot.parts[0]);
partp->dp_typ = DOSPTYP_386BSD;
partp->dp_flag = ACTIVE;
partp->dp_start = dos_sectors;
partp->dp_size = disksecs - dos_sectors;
dos(partp->dp_start, partp->dp_size,
&partp->dp_scyl, &partp->dp_ssect, &partp->dp_shd);
dos(partp->dp_start + partp->dp_size - 1, partp->dp_size,
&partp->dp_ecyl, &partp->dp_esect, &partp->dp_ehd);
if (v_flag)
print_s0(-1);
write_s0();
exit(0);
}
if (f_flag)
{
if (read_s0() || i_flag)
@ -623,7 +648,7 @@ struct stat st;
if ( !(st.st_mode & S_IFCHR) )
warnx("device %s is not character special", disk);
if ((fd = open(disk,
a_flag || B_flag || u_flag ? O_RDWR : O_RDONLY)) == -1) {
a_flag || e_flag || B_flag || u_flag ? O_RDWR : O_RDONLY)) == -1) {
if(errno == ENXIO)
return -2;
warnx("can't open device %s", disk);
@ -717,16 +742,16 @@ write_s0()
* needed if the disklabel protected area also protects
* sector 0. (e.g. empty disk)
*/
flag = 1;
#ifdef NOT_NOW
flag = 1;
if (ioctl(fd, DIOCWLABEL, &flag) < 0)
warn("ioctl DIOCWLABEL");
#endif
if (write_disk(0, (char *) mboot.bootinst) == -1) {
warnx("can't write fdisk partition table");
warn("can't write fdisk partition table");
return -1;
flag = 0;
#ifdef NOT_NOW
flag = 0;
(void) ioctl(fd, DIOCWLABEL, &flag);
#endif
}

View File

@ -1,4 +1,4 @@
.\" $Id: $
.\" $Id: fdisk.8,v 1.14 1999/06/27 19:29:14 rnordier Exp $
.\"
.Dd October 4, 1996
.Dt FDISK 8
@ -8,7 +8,7 @@
.Nd PC partition table maintenance program
.Sh SYNOPSIS
.Nm fdisk
.Op Fl Baitu
.Op Fl Baeitu
.Op Fl b Ar bootcode
.Op Fl 1234
.Op Ar disk
@ -50,11 +50,6 @@ table. The second is used to write a partition table using a
and is designed to be used by other scripts/programs.
.Pp
Options are:
.It Fl B
Reinitialize the boot code contained in sector 0 of the disk. Ignored
if
.Fl f
is given.
.It Fl a
Change the active partition only. Ignored if
.Fl f
@ -62,6 +57,13 @@ is given.
.It Fl b Ar bootcode
Get the boot code from the file
.Ar bootcode .
.It Fl B
Reinitialize the boot code contained in sector 0 of the disk. Ignored
if
.Fl f
is given.
.It Fl e
Initialize the contents of sector 0 with one FreeBSD slice covering the entire disk.
.It Fl f Ar configfile
Set partition values using the file
.Ar configfile .

View File

@ -26,7 +26,7 @@
#ifndef lint
static const char rcsid[] =
"$Id: fdisk.c,v 1.28 1999/01/22 11:54:17 rnordier Exp $";
"$Id: fdisk.c,v 1.29 1999/06/27 19:29:15 rnordier Exp $";
#endif /* not lint */
#include <sys/disklabel.h>
@ -120,6 +120,7 @@ typedef struct cmd {
static int B_flag = 0; /* replace boot code */
static int a_flag = 0; /* set active partition */
static char *b_flag = NULL; /* path to boot code */
static int e_flag = 0; /* use entire disk for FreeBSD */
static int i_flag = 0; /* replace partition data */
static int u_flag = 0; /* update partition data */
static int t_flag = 0; /* test only, if f_flag is given */
@ -215,7 +216,7 @@ main(int argc, char *argv[])
{
int c, i;
while ((c = getopt(argc, argv, "Bab:f:ituv1234")) != -1)
while ((c = getopt(argc, argv, "Bab:ef:ituv1234")) != -1)
switch (c) {
case 'B':
B_flag = 1;
@ -226,6 +227,9 @@ main(int argc, char *argv[])
case 'b':
b_flag = optarg;
break;
case 'e':
e_flag = 1;
break;
case 'f':
f_flag = optarg;
break;
@ -288,6 +292,27 @@ main(int argc, char *argv[])
printf("******* Working on device %s *******\n",disk);
if (e_flag)
{
struct dos_partition *partp;
read_s0();
reset_boot();
partp = (struct dos_partition *) (&mboot.parts[0]);
partp->dp_typ = DOSPTYP_386BSD;
partp->dp_flag = ACTIVE;
partp->dp_start = dos_sectors;
partp->dp_size = disksecs - dos_sectors;
dos(partp->dp_start, partp->dp_size,
&partp->dp_scyl, &partp->dp_ssect, &partp->dp_shd);
dos(partp->dp_start + partp->dp_size - 1, partp->dp_size,
&partp->dp_ecyl, &partp->dp_esect, &partp->dp_ehd);
if (v_flag)
print_s0(-1);
write_s0();
exit(0);
}
if (f_flag)
{
if (read_s0() || i_flag)
@ -623,7 +648,7 @@ struct stat st;
if ( !(st.st_mode & S_IFCHR) )
warnx("device %s is not character special", disk);
if ((fd = open(disk,
a_flag || B_flag || u_flag ? O_RDWR : O_RDONLY)) == -1) {
a_flag || e_flag || B_flag || u_flag ? O_RDWR : O_RDONLY)) == -1) {
if(errno == ENXIO)
return -2;
warnx("can't open device %s", disk);
@ -717,16 +742,16 @@ write_s0()
* needed if the disklabel protected area also protects
* sector 0. (e.g. empty disk)
*/
flag = 1;
#ifdef NOT_NOW
flag = 1;
if (ioctl(fd, DIOCWLABEL, &flag) < 0)
warn("ioctl DIOCWLABEL");
#endif
if (write_disk(0, (char *) mboot.bootinst) == -1) {
warnx("can't write fdisk partition table");
warn("can't write fdisk partition table");
return -1;
flag = 0;
#ifdef NOT_NOW
flag = 0;
(void) ioctl(fd, DIOCWLABEL, &flag);
#endif
}