summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ufs-utils/mkfs.c139
1 files changed, 132 insertions, 7 deletions
diff --git a/ufs-utils/mkfs.c b/ufs-utils/mkfs.c
index 821d67ae..f069e600 100644
--- a/ufs-utils/mkfs.c
+++ b/ufs-utils/mkfs.c
@@ -33,7 +33,7 @@
#ifndef lint
/*static char sccsid[] = "from: @(#)mkfs.c 8.3 (Berkeley) 2/3/94";*/
-static char *rcsid = "$Id: mkfs.c,v 1.3 1994/09/08 20:03:28 mib Exp $";
+static char *rcsid = "$Id: mkfs.c,v 1.4 1994/09/09 16:48:27 mib Exp $";
#endif /* not lint */
#include <unistd.h>
@@ -45,8 +45,10 @@ static char *rcsid = "$Id: mkfs.c,v 1.3 1994/09/08 20:03:28 mib Exp $";
#include "../ufs/dir.h"
#include "../ufs/fs.h"
/* #include <sys/disklabel.h> */
+#include <sys/stat.h>
+#include <fcntl.h>
-/* Begin additions for GNU Hurd */
+/* Begin misc additions for GNU Hurd */
/* For GNU Hurd: the ufs DIRSIZ macro is different than the BSD
4.4 version that mkfs expects. So we provide here the BSD version. */
@@ -68,6 +70,10 @@ static char *rcsid = "$Id: mkfs.c,v 1.3 1994/09/08 20:03:28 mib Exp $";
/* Provide mode from struct dinode * */
#define DI_MODE(dp) (((dp)->di_modeh << 16) | (dp)->di_model)
+#define DEV_BSIZE 512
+
+#define btodb(bytes) ((bytes) / DEV_BSIZE)
+
/* End additions for GNU Hurd */
#ifndef STANDALONE
@@ -95,6 +101,7 @@ static char *rcsid = "$Id: mkfs.c,v 1.3 1994/09/08 20:03:28 mib Exp $";
/*
* variables set up by front end.
*/
+#define extern
extern int mfs; /* run as the memory based filesystem */
extern int Nflag; /* run mkfs without writing file system */
extern int Oflag; /* format as an 4.3BSD file system */
@@ -125,6 +132,7 @@ extern int sbsize; /* superblock size */
extern u_long memleft; /* virtual memory available */
extern caddr_t membase; /* start address of memory based filesystem */
extern caddr_t malloc(), calloc();
+#undef extern
union {
struct fs fs;
@@ -144,6 +152,119 @@ struct dinode zino[MAXBSIZE / sizeof(struct dinode)];
int fsi, fso;
daddr_t alloc();
+main (int argc, char **argv)
+{
+ void usage ()
+ {
+ fprintf (stderr,
+ "Usage: %s [-N] special nsect ntrak npseck tskew ileave\n",
+ argv[0]);
+ exit (1);
+ }
+ /* Usage is
+ mkfs [-N] special nsect ntrak npsect tskew ileave
+
+ All other parameters are computed from defaults and the device itself. */
+ char **args;
+ int fdo, fdi;
+ char *device;
+ struct stat st;
+
+ if (argc == 8)
+ {
+ if (argv[1][0] != '-' || argv[1][1] != 'N' || argv[1][2] != '\0')
+ usage ();
+ Nflag = 1;
+ args = &argv[2];
+ }
+ else if (argc != 7)
+ usage ();
+ else
+ args = &argv[1];
+
+ /* Default computation taken from 4.4 BSD newfs.c */
+
+ device = args[0];
+ fdi = open (device, O_RDONLY);
+ if (fdi == -1)
+ {
+ perror (device);
+ exit (1);
+ }
+ fdo = open (device, O_WRONLY);
+ if (fdo == -1)
+ {
+ perror (device);
+ exit (1);
+ }
+ if (fstat (fdi, &st) == -1)
+ {
+ perror ("stat");
+ exit (1);
+ }
+
+ mfs = 0;
+ Oflag = 0;
+ fssize = st.st_size / DEV_BSIZE;
+
+ ntracks = atoi (args[2]);
+ if (ntracks == 0)
+ {
+ fprintf (stderr, "Bogus ntracks: %d\n", ntracks);
+ exit (1);
+ }
+
+ nsectors = atoi (args[1]);
+ if (nsectors == 0)
+ {
+ fprintf (stderr, "Bogus nsectors: %d\n", nsectors);
+ exit (1);
+ }
+
+ nphyssectors = atoi (args[3]);
+ if (nphyssectors == 0)
+ {
+ fprintf (stderr, "Bogus npsect: %d\n", nphyssectors);
+ exit (1);
+ }
+
+ secpercyl = nsectors * ntracks;
+
+ sectorsize = DEV_BSIZE;
+
+ rpm = 3600;
+
+ interleave = atoi (args[5]);
+
+ trackskew = atoi (args[4]);
+
+ /* These aren't used by the GNU ufs, so who cares? */
+ headswitch = 0;
+ trackseek = 0;
+
+ fsize = 1024;
+ bsize = 8192;
+
+ cpg = 16;
+ cpgflg = 0;
+ minfree = MINFREE;
+ opt = DEFAULTOPT ;
+ density = 4 * fsize;
+ maxcontig = MAX (1, MIN (MAXPHYS, MAXBSIZE) / bsize - 1);
+ rotdelay = 4;
+#define MAXBLKPG(bsize) ((bsize) / sizeof(daddr_t))
+ maxbpg = MAXBLKPG (bsize);
+ nrpos = 8;
+ bbsize = BBSIZE;
+ sbsize = SBSIZE;
+
+ mkfs (0, device, fdi, fdo);
+
+ exit (0);
+}
+
+
+
mkfs(pp, fsys, fi, fo)
struct partition *pp;
char *fsys;
@@ -638,6 +759,7 @@ next:
for (cylno = 0; cylno < sblock.fs_ncg; cylno++)
wtfs(fsbtodb(&sblock, cgsblock(&sblock, cylno)),
sbsize, (char *)&sblock);
+#if 0 /* Not in Hurd (yet) */
/*
* Update information about this partion in pack
* label, to that it may be updated on disk.
@@ -646,6 +768,7 @@ next:
pp->p_fsize = sblock.fs_fsize;
pp->p_frag = sblock.fs_frag;
pp->p_cpg = sblock.fs_cpg;
+#endif
/*
* Notify parent process of success.
* Dissociate from session and tty.
@@ -880,10 +1003,11 @@ fsinit(utime)
bcopy(&lost_found_dir[2], &buf[i],
DIRSIZ(0, &lost_found_dir[2]));
}
- node.di_mode = IFDIR | UMASK;
+ node.di_model = ifdir | UMASK;
+ node.di_modeh = 0;
node.di_nlink = 2;
node.di_size = sblock.fs_bsize;
- node.di_db[0] = alloc(node.di_size, node.di_mode);
+ node.di_db[0] = alloc(node.di_size, DI_MODE (&node));
node.di_blocks = btodb(fragroundup(&sblock, node.di_size));
wtfs(fsbtodb(&sblock, node.di_db[0]), node.di_size, buf);
iput(&node, LOSTFOUNDINO);
@@ -892,15 +1016,16 @@ fsinit(utime)
* create the root directory
*/
if (mfs)
- node.di_mode = IFDIR | 01777;
+ node.di_model = IFDIR | 01777;
else
- node.di_mode = IFDIR | UMASK;
+ node.di_model = IFDIR | UMASK;
+ node.di_modeh = 0;
node.di_nlink = PREDEFDIR;
if (Oflag)
node.di_size = makedir((struct direct *)oroot_dir, PREDEFDIR);
else
node.di_size = makedir(root_dir, PREDEFDIR);
- node.di_db[0] = alloc(sblock.fs_fsize, node.di_mode);
+ node.di_db[0] = alloc(sblock.fs_fsize, DI_MODE (&node));
node.di_blocks = btodb(fragroundup(&sblock, node.di_size));
wtfs(fsbtodb(&sblock, node.di_db[0]), sblock.fs_fsize, buf);
iput(&node, ROOTINO);