On Tuesday 10 November 2009 07:50:21 Tobias Brunner wrote:
> When setting the timestamps of a file using e.g. futimens the flag
> HOSTFS_ATTR_(A|M)TIME_SET is set only if explicit timestamps were
> specified. If futimens is called without timestamps (i.e. parameter
> times is set to NULL), only HOSTFS_ATTR_(A|M)TIME is set. On the other
> hand, the latter flag is also set if the timestamps were explicitly
> specified.
>
> Signed-off-by: Tobias Brunner <tob...@strongswan.org>

I hit this bug too, and this patch fixed it for me, so:

Acked-by: Rob Landley <r...@landley.net>

Speaking of which, here's a pending patch of my own reparented on top of this
one:

From: Rob Landley <r...@landley.net>

Switch futimes() usage to Posix 2008 futimens(), and while I'm at migrate
utimes() to utimensat() and eliminate use of timeval.

This is required to build UML against uClibc.

Signed-off-by: Rob Landley <r...@landley.net>
---

 fs/hostfs/hostfs_user.c |   32 +++++++++++++++++---------------
 1 file changed, 17 insertions(+), 15 deletions(-)

--- temp2/fs/hostfs/hostfs_user.c       2009-11-22 17:52:21.000000000 -0600
+++ temp/fs/hostfs/hostfs_user.c        2009-11-29 05:51:57.000000000 -0600
@@ -3,6 +3,12 @@
  * Licensed under the GPL
  */
 
+/* These two #defines are needed for futimens and utimensat until glibc
+   catches up with posix 2008. */
+
+#define __USE_ATFILE
+#define __USE_GNU
+
 #include <stdio.h>
 #include <stddef.h>
 #include <unistd.h>
@@ -235,8 +241,7 @@
 
 int set_attr(const char *file, struct hostfs_iattr *attrs, int fd)
 {
-       struct timeval times[2];
-       struct timespec atime_ts, mtime_ts;
+       struct timespec time_ts[2];
        int err, ma;
 
        if (attrs->ia_valid & HOSTFS_ATTR_MODE) {
@@ -280,29 +285,26 @@
        ma = (HOSTFS_ATTR_ATIME | HOSTFS_ATTR_MTIME);
        if (attrs->ia_valid & ma) {
                err = stat_file(file, NULL, NULL, NULL, NULL, NULL, NULL,
-                               &atime_ts, &mtime_ts, NULL, NULL, NULL, fd);
+                               time_ts, time_ts+1, NULL, NULL, NULL, fd);
                if (err != 0)
                        return err;
 
-               times[0].tv_sec = atime_ts.tv_sec;
-               times[0].tv_usec = atime_ts.tv_nsec / 1000;
-               times[1].tv_sec = mtime_ts.tv_sec;
-               times[1].tv_usec = mtime_ts.tv_nsec / 1000;
-
                if (attrs->ia_valid & HOSTFS_ATTR_ATIME) {
-                       times[0].tv_sec = attrs->ia_atime.tv_sec;
-                       times[0].tv_usec = attrs->ia_atime.tv_nsec / 1000;
+                       time_ts[0].tv_sec = attrs->ia_atime.tv_sec;
+                       time_ts[0].tv_nsec = attrs->ia_atime.tv_nsec;
                }
                if (attrs->ia_valid & HOSTFS_ATTR_MTIME) {
-                       times[1].tv_sec = attrs->ia_mtime.tv_sec;
-                       times[1].tv_usec = attrs->ia_mtime.tv_nsec / 1000;
+                       time_ts[1].tv_sec = attrs->ia_mtime.tv_sec;
+                       time_ts[1].tv_nsec = attrs->ia_mtime.tv_nsec;
                }
 
                if (fd >= 0) {
-                       if (futimes(fd, times) != 0)
+                       if (futimens(fd, time_ts) != 0)
                                return -errno;
-               } else if (utimes(file, times) != 0) {
-                       return -errno;
+               } else {
+                       if (utimensat(AT_FDCWD, file, time_ts, 0) != 0) {
+                               return -errno;
+                       }
                }
        }
 

-- 
Latency is more important than throughput. It's that simple. - Linus Torvalds

------------------------------------------------------------------------------
Return on Information:
Google Enterprise Search pays you back
Get the facts.
http://p.sf.net/sfu/google-dev2dev
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel

Reply via email to