From 5fef1b7f22ec0ee3730b80bbf972dbf9a8995091 Mon Sep 17 00:00:00 2001 From: Justus Winter Date: Wed, 5 Oct 2016 15:38:58 +0200 Subject: libfshelp: Add function to map over all active translators. * libdiskfs/file-syncfs.c (diskfs_S_file_syncfs): Use the new function. * libdiskfs/fsys-options.c (diskfs_S_fsys_set_options): Likewise. * libdiskfs/fsys-syncfs.c (diskfs_S_fsys_syncfs): Likewise. * libdiskfs/shutdown.c (diskfs_shutdown): Likewise. * libfshelp/fshelp.h (fshelp_map_active_translators): New declaration. * libfshelp/translator-list.c (fshelp_map_active_translators): New function. * libnetfs/file-syncfs.c (netfs_S_file_syncfs): Use the new function. * libnetfs/fsys-set-options.c (netfs_S_fsys_set_options): Likewise. * libnetfs/fsys-syncfs.c (netfs_S_fsys_syncfs): Likewise. * libnetfs/shutdown.c (netfs_shutdown): Likewise. --- libnetfs/file-syncfs.c | 23 ++++++++++++++++++++--- 1 file changed, 20 insertions(+), 3 deletions(-) (limited to 'libnetfs/file-syncfs.c') diff --git a/libnetfs/file-syncfs.c b/libnetfs/file-syncfs.c index 2302e926..0b14bb87 100644 --- a/libnetfs/file-syncfs.c +++ b/libnetfs/file-syncfs.c @@ -20,6 +20,21 @@ #include "netfs.h" #include "fs_S.h" +#include + +struct args +{ + int wait; +}; + +static error_t +helper (void *cookie, const char *name, mach_port_t control) +{ + struct args *args = cookie; + (void) name; + fsys_syncfs (control, args->wait, 1); + return 0; +} error_t netfs_S_file_syncfs (struct protid *user, @@ -27,11 +42,13 @@ netfs_S_file_syncfs (struct protid *user, int dochildren) { error_t err; - + struct args args = { wait }; + if (!user) return EOPNOTSUPP; - - /* Translators not yet supported by netfs. XXX */ + + if (dochildren) + fshelp_map_active_translators (helper, &args); pthread_mutex_lock (&user->po->np->lock); err = netfs_attempt_syncfs (user->user, wait); -- cgit v1.2.3