diff options
author | peter <peter@FreeBSD.org> | 1999-12-30 16:32:40 +0000 |
---|---|---|
committer | peter <peter@FreeBSD.org> | 1999-12-30 16:32:40 +0000 |
commit | cbb9d1f6aeb80a0256c7e135ae433c3c0cd88768 (patch) | |
tree | 1812f7d9bf0d5ab3dff66c2f32badbee08467058 /sbin/fsck | |
parent | 1b64aef9dd86be50db069a17914ff24f904af3f4 (diff) | |
download | FreeBSD-src-cbb9d1f6aeb80a0256c7e135ae433c3c0cd88768.zip FreeBSD-src-cbb9d1f6aeb80a0256c7e135ae433c3c0cd88768.tar.gz |
Make fsck(8) do a MNT_RELOAD after cleaning for all read-only mounted
filesystems, not just for the root fs.
Reviewed by: mckusick
Submitted by: Paul Saab <ps@yahoo-inc.com>
Diffstat (limited to 'sbin/fsck')
-rw-r--r-- | sbin/fsck/main.c | 90 | ||||
-rw-r--r-- | sbin/fsck/preen.c | 8 |
2 files changed, 63 insertions, 35 deletions
diff --git a/sbin/fsck/main.c b/sbin/fsck/main.c index 8d9afdb..0f55498 100644 --- a/sbin/fsck/main.c +++ b/sbin/fsck/main.c @@ -46,6 +46,7 @@ static const char rcsid[] = #endif /* not lint */ #include <sys/param.h> +#include <sys/stat.h> #include <sys/time.h> #include <sys/mount.h> #include <sys/resource.h> @@ -63,6 +64,7 @@ static int argtoi __P((int flag, char *req, char *str, int base)); static int docheck __P((struct fstab *fsp)); static int checkfilesys __P((char *filesys, char *mntpt, long auxdata, int child)); +static struct statfs *getmntpt __P((const char *)); int main __P((int argc, char *argv[])); int @@ -201,7 +203,8 @@ checkfilesys(filesys, mntpt, auxdata, child) ufs_daddr_t n_ffree, n_bfree; struct dups *dp; struct zlncnt *zlnp; - int cylno, flags; + struct statfs *mntbuf; + int cylno; if (preen && child) (void)signal(SIGQUIT, voidquit); @@ -223,6 +226,12 @@ checkfilesys(filesys, mntpt, auxdata, child) } /* + * get the mount point information of the filesystem, if + * it is available. + */ + mntbuf = getmntpt(filesys); + + /* * Cleared if any questions answered no. Used to decide if * the superblock should be marked clean. */ @@ -232,7 +241,7 @@ checkfilesys(filesys, mntpt, auxdata, child) */ if (preen == 0) { printf("** Last Mounted on %s\n", sblock.fs_fsmnt); - if (hotroot) + if (mntbuf != NULL && mntbuf->f_flags & MNT_ROOTFS) printf("** Root file system\n"); printf("** Phase 1 - Check Blocks and Sizes\n"); } @@ -326,17 +335,10 @@ checkfilesys(filesys, mntpt, auxdata, child) } if (rerun) resolved = 0; - flags = 0; - if (hotroot) { - struct statfs stfs_buf; - /* - * Check to see if root is mounted read-write. - */ - if (statfs("/", &stfs_buf) == 0) - flags = stfs_buf.f_flags; - if ((flags & MNT_RDONLY) == 0) - resolved = 0; - } + + /* Check to see if the filesystem if mounted read-write */ + if (mntbuf != NULL && (mntbuf->f_flags & MNT_RDONLY) == 0) + resolved = 0; ckfini(resolved); for (cylno = 0; cylno < sblock.fs_ncg; cylno++) @@ -348,22 +350,24 @@ checkfilesys(filesys, mntpt, auxdata, child) printf("\n***** FILE SYSTEM WAS MODIFIED *****\n"); if (rerun) printf("\n***** PLEASE RERUN FSCK *****\n"); - if (hotroot) { + + /* + * Always do a mount update if the current filesystem + * is mounted read-only. + */ + if (mntbuf != NULL && mntbuf->f_flags & MNT_RDONLY) { struct ufs_args args; int ret; - /* - * We modified the root. Do a mount update on - * it, unless it is read-write, so we can continue. - */ - if (flags & MNT_RDONLY) { - args.fspec = 0; - args.export.ex_flags = 0; - args.export.ex_root = 0; - flags |= MNT_UPDATE | MNT_RELOAD; - ret = mount("ufs", "/", flags, &args); - if (ret == 0) - return (0); - } + + args.fspec = 0; + args.export.ex_flags = 0; + args.export.ex_root = 0; + mntbuf->f_flags |= MNT_UPDATE | MNT_RELOAD; + ret = mount("ufs", mntbuf->f_mntonname , mntbuf->f_flags, &args); + if (ret < 0) + perror("mount"); + if (ret == 0) + return 0; if (!fsmodified) return (0); if (!preen) @@ -373,3 +377,35 @@ checkfilesys(filesys, mntpt, auxdata, child) } return (0); } + +/* + * get the directory the device is mounted on. + */ +static struct statfs * +getmntpt(name) + const char *name; +{ + struct statfs *mntbuf; + struct stat devstat, mntdevstat; + char device[MAXPATHLEN]; + int i, mntsize; + + if (realpath(name, device) == NULL) + return (NULL); + + if (stat(device, &devstat) != 0 || + !(S_ISCHR(devstat.st_mode) || S_ISBLK(devstat.st_mode))) + return (NULL); + + mntsize = getmntinfo(&mntbuf, MNT_NOWAIT); + for (i = 0; i < mntsize; i++) { + if (realpath(mntbuf[i].f_mntfromname, device) == NULL || + stat(device, &mntdevstat) != 0 || + !(S_ISCHR(mntdevstat.st_mode) || + S_ISBLK(mntdevstat.st_mode))) + continue; + if (mntdevstat.st_rdev == devstat.st_rdev) + return (&mntbuf[i]); + } + return (NULL); +} diff --git a/sbin/fsck/preen.c b/sbin/fsck/preen.c index fc6dd23..e43aada 100644 --- a/sbin/fsck/preen.c +++ b/sbin/fsck/preen.c @@ -67,7 +67,6 @@ struct disk { } *disks; int nrun, ndisks; -char hotroot; static void addpart __P((char *name, char *fsname, long auxdata)); static struct disk *finddisk __P((char *name)); @@ -298,11 +297,6 @@ blockcheck(origname) struct fstab *fsinfo; int retried = 0, len; - hotroot = 0; - if (stat("/", &stslash) < 0) { - printf("Can't stat /: %s\n", strerror(errno)); - return (origname); - } newname = origname; retry: if (stat(newname, &stblock) < 0) { @@ -312,8 +306,6 @@ retry: switch(stblock.st_mode & S_IFMT) { case S_IFCHR: case S_IFBLK: - if (stslash.st_dev == stblock.st_rdev) - hotroot++; return(newname); case S_IFDIR: if (retried) |