summaryrefslogtreecommitdiff
path: root/ufs-utils/newfs.c
diff options
context:
space:
mode:
Diffstat (limited to 'ufs-utils/newfs.c')
-rw-r--r--ufs-utils/newfs.c44
1 files changed, 35 insertions, 9 deletions
diff --git a/ufs-utils/newfs.c b/ufs-utils/newfs.c
index f468ef24..efc7dbea 100644
--- a/ufs-utils/newfs.c
+++ b/ufs-utils/newfs.c
@@ -39,7 +39,7 @@ static char copyright[] =
#ifndef lint
/*static char sccsid[] = "from: @(#)newfs.c 8.8 (Berkeley) 4/18/94";*/
-static char *rcsid = "$Id: newfs.c,v 1.1 1994/08/23 19:30:43 mib Exp $";
+static char *rcsid = "$Id: newfs.c,v 1.2 1994/09/09 14:11:41 mib Exp $";
#endif /* not lint */
/*
@@ -48,12 +48,12 @@ static char *rcsid = "$Id: newfs.c,v 1.1 1994/08/23 19:30:43 mib Exp $";
#include <sys/param.h>
#include <sys/stat.h>
#include <sys/ioctl.h>
-#include <sys/disklabel.h>
+/* #include <sys/disklabel.h> */
#include <sys/file.h>
-#include <sys/mount.h>
+/* #include <sys/mount.h> */
-#include <ufs/ufs/dir.h>
-#include <ufs/ffs/fs.h>
+#include "../ufs/dir.h"
+#include "../ufs/fs.h"
#include <ctype.h>
#include <errno.h>
@@ -70,13 +70,21 @@ static char *rcsid = "$Id: newfs.c,v 1.1 1994/08/23 19:30:43 mib Exp $";
#include <varargs.h>
#endif
-#include "mntopts.h"
+/* #include "mntopts.h" */
+/* GNU Hurd additions */
+#define MAXPATHLEN 2048
+
+/* End GNU Hurd additions */
+
+
+#if 0
struct mntopt mopts[] = {
MOPT_STDOPTS,
MOPT_ASYNC,
{ NULL },
};
+#endif
#if __STDC__
void fatal(const char *fmt, ...);
@@ -168,7 +176,7 @@ int maxbpg; /* maximum blocks per file in a cyl group */
int nrpos = NRPOS; /* # of distinguished rotational positions */
int bbsize = BBSIZE; /* boot block size */
int sbsize = SBSIZE; /* superblock size */
-int mntflags = MNT_ASYNC; /* flags to be passed to mount */
+/* int mntflags = MNT_ASYNC;*/ /* flags to be passed to mount */
u_long memleft; /* virtual memory available */
caddr_t membase; /* start address of memory based filesystem */
#ifdef COMPAT
@@ -190,7 +198,7 @@ main(argc, argv)
register struct partition *pp;
register struct disklabel *lp;
struct disklabel *getdisklabel();
- struct partition oldpartition;
+/* struct partition oldpartition; */
struct stat st;
struct statfs *mp;
int fsi, fso, len, n;
@@ -201,10 +209,12 @@ main(argc, argv)
else
progname = *argv;
+#if 0
if (strstr(progname, "mfs")) {
mfs = 1;
Nflag++;
}
+#endif
opstring = mfs ?
"NT:a:b:c:d:e:f:i:m:o:s:" :
@@ -275,9 +285,12 @@ main(argc, argv)
optarg);
break;
case 'o':
+#if 0
if (mfs)
getmntopts(optarg, mopts, &mntflags);
- else {
+ else
+#endif
+ {
if (strcmp(optarg, "space") == 0)
opt = FS_OPTSPACE;
else if (strcmp(optarg, "time") == 0)
@@ -340,6 +353,7 @@ main(argc, argv)
if (fso < 0)
fatal("%s: %s", special, strerror(errno));
+#if 0
/* Bail if target special is mounted */
n = getmntinfo(&mp, MNT_NOWAIT);
if (n == 0)
@@ -361,7 +375,9 @@ main(argc, argv)
special, mp->f_mntonname);
++mp;
}
+#endif
}
+#if 0
if (mfs && disktype != NULL) {
lp = (struct disklabel *)getdiskbyname(disktype);
if (lp == NULL)
@@ -396,6 +412,16 @@ main(argc, argv)
fatal("%s: `%c' partition overlaps boot program",
argv[0], *cp);
}
+#endif
+ /* GNU Hurd specific here */
+ fsi = open (special, O_RDONLY);
+ if (fsi < 0)
+ fatal("%s: %s", special, strerror(errno));
+ if (fstat(fsi, &st) < 0)
+ fatal("%s: %s", special, strerror(errno));
+ fssize = st.st_size;
+ /* End GNU Hurd specific */
+
if (fssize == 0)
fssize = pp->p_size;
if (fssize > pp->p_size && !mfs)