[hackers] [ubase] Don't print errors for already mounted filesystems || sin
commit 6505db4709b30a2ab85e12124e73238ac6ce07a6
Author: sin <sin_AT_2f30.org>
Date: Tue Mar 18 16:38:31 2014 +0200
Don't print errors for already mounted filesystems
diff --git a/mount.c b/mount.c
index 6e2a6ec..ea33125 100644
--- a/mount.c
+++ b/mount.c
_AT_@ -66,6 +66,29 @@ parseopts(char *popts, unsigned long *flags, char *data, size_t bufsiz)
}
}
+static int
+mounted(const char *dir)
+{
+ FILE *fp;
+ struct mntent *me;
+ struct stat st1, st2;
+
+ if (stat(dir, &st1) < 0)
+ eprintf("stat %s:", dir);
+ fp = setmntent("/proc/mounts", "r");
+ if (!fp)
+ eprintf("setmntent %s:", "/proc/mounts");
+ while ((me = getmntent(fp)) != NULL) {
+ if (stat(me->mnt_dir, &st2) < 0)
+ eprintf("stat %s:", me->mnt_dir);
+ if (st1.st_dev == st2.st_dev &&
+ st1.st_ino == st2.st_ino)
+ return 1;
+ }
+ endmntent(fp);
+ return 0;
+}
+
static void
usage(void)
{
_AT_@ -172,7 +195,8 @@ mountall:
flags = 0;
parseopts(me->mnt_opts, &flags, data, datasiz);
if(mount(me->mnt_fsname, me->mnt_dir, me->mnt_type, flags, data) < 0) {
- weprintf("mount: %s:", me->mnt_fsname);
+ if (mounted(me->mnt_dir) == 0)
+ weprintf("mount: %s:", me->mnt_fsname);
if(status != 64)
status = 32; /* all failed */
} else {
Received on Tue Mar 18 2014 - 15:46:39 CET
This archive was generated by hypermail 2.3.0
: Tue Mar 18 2014 - 15:48:14 CET