From: Greg Kurz <groug@kaod.org>
To: keno@juliacomputing.com
Cc: qemu-devel@nongnu.org, Keno Fischer <keno@alumni.harvard.edu>
Subject: Re: [Qemu-devel] [PATCH 12/13] 9p: darwin: Provide a fallback implementation for utimensat
Date: Wed, 30 May 2018 14:14:39 +0200 [thread overview]
Message-ID: <20180530141439.24619dbc@bahia.lan> (raw)
In-Reply-To: <4e5e163637c9c696eb43d46a08a0aad5cd818d8a.1527310210.git.keno@alumni.harvard.edu>
On Sat, 26 May 2018 01:23:14 -0400
keno@juliacomputing.com wrote:
> From: Keno Fischer <keno@alumni.harvard.edu>
>
> This function is new in Mac OS 10.13. Provide a fallback implementation
> when building against older SDKs.
>
> Signed-off-by: Keno Fischer <keno@juliacomputing.com>
> ---
As with patch 10, this should go to 9p-util-darwin.c
> hw/9pfs/9p-local.c | 2 +-
> hw/9pfs/9p-util.c | 38 ++++++++++++++++++++++++++++++++++++++
> hw/9pfs/9p-util.h | 7 +++++++
> hw/9pfs/9p.c | 1 +
> 4 files changed, 47 insertions(+), 1 deletion(-)
>
> diff --git a/hw/9pfs/9p-local.c b/hw/9pfs/9p-local.c
> index 3e358b7..70ab541 100644
> --- a/hw/9pfs/9p-local.c
> +++ b/hw/9pfs/9p-local.c
> @@ -1082,7 +1082,7 @@ static int local_utimensat(FsContext *s, V9fsPath *fs_path,
> goto out;
> }
>
> - ret = utimensat(dirfd, name, buf, AT_SYMLINK_NOFOLLOW);
> + ret = utimensat_nofollow(dirfd, name, buf);
> close_preserve_errno(dirfd);
> out:
> g_free(dirpath);
> diff --git a/hw/9pfs/9p-util.c b/hw/9pfs/9p-util.c
> index 98004ac..8403f5f 100644
> --- a/hw/9pfs/9p-util.c
> +++ b/hw/9pfs/9p-util.c
> @@ -104,3 +104,41 @@ int fsetxattrat_nofollow(int dirfd, const char *filename, const char *name,
> #endif
> return ret;
> }
> +
> +#ifndef __has_builtin
> +#define __has_builtin(x) 0
> +#endif
> +
> +int utimensat_nofollow(int dirfd, const char *filename, const struct timespec times[2])
> +{
> +#ifdef CONFIG_DARWIN
> +#if defined(__MAC_10_13) /* Check whether we have an SDK version that defines utimensat */
> +#if __MAC_OS_X_VERSION_MIN_REQUIRED >= __MAC_10_13
> +#define UTIMENSAT_AVAILABLE 1
> +#elif __has_builtin(__builtin_available)
> +#define UTIMENSAT_AVAILABLE __builtin_available(macos 10.13, *)
> +#else
> +#define UTIMENSAT_AVAILABLE 0
> +#endif
> + if (UTIMENSAT_AVAILABLE)
> + {
> + return utimensat(dirfd, filename, times, AT_SYMLINK_NOFOLLOW);
> + }
> +#endif
> + // utimensat not available. Use futimes.
> + int fd = openat_file(dirfd, filename, O_PATH_9P_UTIL | O_NOFOLLOW, 0);
> + if (fd == -1)
> + return -1;
> +
> + struct timeval futimes_buf[2];
> + futimes_buf[0].tv_sec = times[0].tv_sec;
> + futimes_buf[0].tv_usec = times[0].tv_nsec * 1000;
> + futimes_buf[1].tv_sec = times[1].tv_sec;
> + futimes_buf[1].tv_usec = times[1].tv_nsec * 1000;
> + int ret = futimes(fd, futimes_buf);
> + close_preserve_errno(fd);
> + return ret;
> +#else
> + return utimensat(dirfd, filename, times, AT_SYMLINK_NOFOLLOW);
> +#endif
> +}
> diff --git a/hw/9pfs/9p-util.h b/hw/9pfs/9p-util.h
> index cb26343..2329c82 100644
> --- a/hw/9pfs/9p-util.h
> +++ b/hw/9pfs/9p-util.h
> @@ -19,6 +19,12 @@
> #define O_PATH_9P_UTIL 0
> #endif
>
> +/* Compatibility with OLD SDK Versions for Darwin */
> +#if defined(CONFIG_DARWIN) && !defined(UTIME_NOW)
> +#define UTIME_NOW -1
> +#define UTIME_OMIT -2
> +#endif
> +
> static inline void close_preserve_errno(int fd)
> {
> int serrno = errno;
> @@ -66,5 +72,6 @@ ssize_t flistxattrat_nofollow(int dirfd, const char *filename,
> char *list, size_t size);
> ssize_t fremovexattrat_nofollow(int dirfd, const char *filename,
> const char *name);
> +int utimensat_nofollow(int dirfd, const char *filename, const struct timespec times[2]);
>
> #endif
> diff --git a/hw/9pfs/9p.c b/hw/9pfs/9p.c
> index 4ae4da6..8e0594a 100644
> --- a/hw/9pfs/9p.c
> +++ b/hw/9pfs/9p.c
> @@ -21,6 +21,7 @@
> #include "virtio-9p.h"
> #include "fsdev/qemu-fsdev.h"
> #include "9p-xattr.h"
> +#include "9p-util.h"
> #include "coth.h"
> #include "trace.h"
> #include "migration/blocker.h"
next prev parent reply other threads:[~2018-05-30 12:14 UTC|newest]
Thread overview: 50+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-05-26 5:23 [Qemu-devel] [PATCH 00/13] 9p: Add support for Darwin keno
2018-05-26 5:23 ` [Qemu-devel] [PATCH 01/13] 9p: linux: Fix a couple Linux assumptions keno
2018-05-26 6:30 ` Philippe Mathieu-Daudé
2018-05-26 13:30 ` Peter Maydell
2018-05-26 16:17 ` Keno Fischer
2018-05-28 12:31 ` Greg Kurz
2018-05-26 5:23 ` [Qemu-devel] [PATCH 02/13] 9p: Avoid warning if FS_IOC_GETVERSION is not defined keno
2018-05-28 13:52 ` Greg Kurz
2018-05-26 5:23 ` [Qemu-devel] [PATCH 03/13] 9p: Move a couple xattr functions to 9p-util keno
2018-05-29 18:34 ` Greg Kurz
2018-05-31 16:14 ` Keno Fischer
2018-05-31 17:26 ` Greg Kurz
2018-05-31 17:39 ` Keno Fischer
2018-05-26 5:23 ` [Qemu-devel] [PATCH 04/13] 9p: darwin: Handle struct stat(fs) differences keno
2018-05-26 5:23 ` [Qemu-devel] [PATCH 05/13] 9p: darwin: Handle struct dirent differences keno
2018-05-29 20:25 ` Greg Kurz
2018-05-31 16:20 ` Keno Fischer
2018-05-31 19:16 ` Greg Kurz
2018-05-26 5:23 ` [Qemu-devel] [PATCH 06/13] 9p: darwin: Address minor differences keno
2018-05-29 21:09 ` Greg Kurz
2018-05-31 16:27 ` Keno Fischer
2018-05-31 19:22 ` Greg Kurz
2018-05-31 19:23 ` Keno Fischer
2018-05-31 19:49 ` Greg Kurz
2018-05-26 5:23 ` [Qemu-devel] [PATCH 07/13] 9p: darwin: Properly translate AT_REMOVEDIR flag keno
2018-05-29 20:43 ` Greg Kurz
2018-05-31 16:25 ` Keno Fischer
2018-05-31 19:44 ` Greg Kurz
2018-05-26 5:23 ` [Qemu-devel] [PATCH 08/13] 9p: darwin: Ignore O_{NOATIME, DIRECT} keno
2018-05-29 21:32 ` Greg Kurz
2018-05-31 16:35 ` Keno Fischer
2018-05-26 5:23 ` [Qemu-devel] [PATCH 09/13] 9p: darwin: Provide a compatibility definition for XATTR_SIZE_MAX keno
2018-05-26 13:34 ` Peter Maydell
2018-05-26 16:00 ` Keno Fischer
2018-05-26 5:23 ` [Qemu-devel] [PATCH 10/13] 9p: darwin: *xattr_nofollow implementations keno
2018-05-30 12:13 ` Greg Kurz
2018-05-26 5:23 ` [Qemu-devel] [PATCH 11/13] 9p: darwin: Mark mknod as unsupported keno
2018-05-30 12:20 ` Greg Kurz
2018-05-31 16:37 ` Keno Fischer
2018-05-31 19:56 ` Greg Kurz
2018-05-31 22:56 ` Keno Fischer
2018-05-31 23:06 ` Keno Fischer
2018-05-31 23:21 ` Keno Fischer
2018-05-26 5:23 ` [Qemu-devel] [PATCH 12/13] 9p: darwin: Provide a fallback implementation for utimensat keno
2018-05-30 12:14 ` Greg Kurz [this message]
2018-05-26 5:23 ` [Qemu-devel] [PATCH 13/13] 9p: darwin: configure: Allow VirtFS on Darwin keno
2018-05-28 12:59 ` Greg Kurz
2018-05-31 17:46 ` Keno Fischer
2018-05-31 19:57 ` Greg Kurz
2018-05-26 5:37 ` [Qemu-devel] [PATCH 00/13] 9p: Add support for Darwin no-reply
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20180530141439.24619dbc@bahia.lan \
--to=groug@kaod.org \
--cc=keno@alumni.harvard.edu \
--cc=keno@juliacomputing.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).