From: Karel Zak Date: Fri, 29 Oct 2010 18:04:00 +0000 (+0200) Subject: mount: use utimensat(AT_FDCWD) rather than open()+futimens() X-Git-Url: https://err.no/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a21640baec08b7b20e7d829c3aae87e35d5dbf04;p=util-linux mount: use utimensat(AT_FDCWD) rather than open()+futimens() Thanks to Kay Sievers. Signed-off-by: Karel Zak --- diff --git a/mount/mount.c b/mount/mount.c index 0567418d..1c8a55fd 100644 --- a/mount/mount.c +++ b/mount/mount.c @@ -1313,8 +1313,6 @@ cdrom_setspeed(const char *spec) { static int is_readonly(const char *path) { - int fd; - if (access(path, W_OK) == 0) return 0; if (errno == EROFS) @@ -1332,19 +1330,14 @@ is_readonly(const char *path) * * - for read-write filesystem with read-only VFS node (aka -o remount,ro,bind) */ - fd = open(path, O_RDONLY); - if (fd >= 0) { + { struct timespec times[2]; - int errsv = 0; times[0].tv_nsec = UTIME_NOW; /* atime */ times[1].tv_nsec = UTIME_OMIT; /* mtime */ - if (futimens(fd, times) == -1) - errsv = errno; - close(fd); - - return errsv == EROFS; + if (utimensat(AT_FDCWD, path, times, 0) == -1) + return errno == EROFS; } #endif return 0;