Stefan Hajnoczi [Tue, 10 Sep 2019 10:45:43 +0000 (12:45 +0200)]
 
passthrough_ll: use fuse_log() instead of err()/errx()
Send everything through fuse_log() instead of writing directly to
stderr.
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Stefan Hajnoczi [Tue, 10 Sep 2019 10:39:34 +0000 (12:39 +0200)]
 
passthrough_ll: use fuse_log()
Make use of fuse_log() instead of printing directly to stderr.  This
demonstrates unified logging and also caught the fact that I forgot to
add fuse_log APIs to lib/fuse_versionscript.  So it's basically a test
case :).
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Stefan Hajnoczi [Tue, 10 Sep 2019 10:36:56 +0000 (12:36 +0200)]
 
log: move fuse_log() to the public header file
Applications may wish to call fuse_log() for unified logging.  This way
they don't need to define their own wrappers to invoke the log message
handler function installed by fuse_set_log_func().
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Dr. David Alan Gilbert [Mon, 9 Sep 2019 09:14:02 +0000 (10:14 +0100)]
 
passthrough_ll: fix fallocate variant ifdefs (#449)
If fallocate isn't available we incorrectly check for the value of
HAVE_POSIX_FALLOCATE rather than it being defined.
We also fail to initialise 'err' in the case where neither are defined.
Fixes: 5fc562c90d7925963467 ("Add fallocate and use it instead of ...")
Signed-off-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
Stefan Hajnoczi [Wed, 4 Sep 2019 14:59:18 +0000 (15:59 +0100)]
 
Introduce callback for logging
Introduce an API for custom log handler functions.  This allows libfuse
applications to send messages to syslog(3) or other logging systems.
See include/fuse_log.h for details.
Convert libfuse from fprintf(stderr, ...) to log_fuse(level, ...).  Most
messages are error messages with FUSE_LOG_ERR log level.  There are also
some debug messages which now use the FUSE_LOG_DEBUG log level.
Note that lib/mount_util.c is used by both libfuse and fusermount3.
Since fusermount3 does not link against libfuse, we cannot call
fuse_log() from lib/mount_util.c.  This file will continue to use
fprintf(stderr, ...) until someone figures out how to split it up.
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Stefan Hajnoczi [Thu, 29 Aug 2019 19:28:29 +0000 (20:28 +0100)]
 
Avoid gcc 9.1 strncpy(3) warnings (#447)
Recent GCC releases have warnings related to common strncpy(3) bugs.
These warnings can be avoided by explicitly NUL-terminating the buffer
or using memcpy(3) when the intention is to copy just the characters
without the NUL terminator.
This commit fixes the following warnings:
  [1/27] Compiling C object 'test/
9f86d08@@test_syscalls@exe/test_syscalls.c.o'.
  In function ‘test_socket’,
      inlined from ‘main’ at ../test/test_syscalls.c:1899:9:
  ../test/test_syscalls.c:1760:2: warning: ‘strncpy’ output may be truncated copying 108 bytes from a string of length 1023 [-Wstringop-truncation]
   1760 |  strncpy(su.sun_path, testsock, sizeof(su.sun_path));
        |  ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  [2/27] Compiling C object 'lib/
76b5a35@@fuse3@sha/fuse.c.o'.
  ../lib/fuse.c: In function ‘add_name’:
  ../lib/fuse.c:968:2: warning: ‘strncpy’ output truncated before terminating nul copying as many bytes from a string as its length [-Wstringop-truncation]
    968 |  strncpy(s, name, len);
        |  ^~~~~~~~~~~~~~~~~~~~~
  ../lib/fuse.c:944:15: note: length computed here
    944 |  size_t len = strlen(name);
        |               ^~~~~~~~~~~~
  [3/27] Compiling C object 'lib/
76b5a35@@fuse3@sha/fuse_lowlevel.c.o'.
  ../lib/fuse_lowlevel.c: In function ‘fuse_add_direntry’:
  ../lib/fuse_lowlevel.c:288:2: warning: ‘strncpy’ output truncated before terminating nul copying as many bytes from a string as its length [-Wstringop-truncation]
    288 |  strncpy(dirent->name, name, namelen);
        |  ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  ../lib/fuse_lowlevel.c:276:12: note: length computed here
    276 |  namelen = strlen(name);
        |            ^~~~~~~~~~~~
  ../lib/fuse_lowlevel.c: In function ‘fuse_add_direntry_plus’:
  ../lib/fuse_lowlevel.c:381:2: warning: ‘strncpy’ output truncated before terminating nul copying as many bytes from a string as its length [-Wstringop-truncation]
    381 |  strncpy(dirent->name, name, namelen);
        |  ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  ../lib/fuse_lowlevel.c:366:12: note: length computed here
    366 |  namelen = strlen(name);
        |            ^~~~~~~~~~~~
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
Nikolaus Rath [Fri, 23 Aug 2019 19:58:54 +0000 (20:58 +0100)]
 
Shorten comment.
Nikolaus Rath [Sat, 13 Jul 2019 00:58:59 +0000 (17:58 -0700)]
 
Improve description of READDIRPLUS_AUTO.
AsumFace [Fri, 23 Aug 2019 19:58:06 +0000 (21:58 +0200)]
 
Clarify bitfield padding issue (#445)
* Clarify bitfield padding issue
* Add a more elaborate note to fuse_file_info
Giuseppe Scrivano [Tue, 23 Jul 2019 19:52:16 +0000 (21:52 +0200)]
 
fuse-lowlevel: set pipe size to max (#438)
on failure to set the pipe size, set it to the maximum allowed by the
kernel.
If the first request required more than the maximum allowed, the
can_grow flag would be reset thus preventing any further resize.
Grow the pipe to the maximum allowed to increase the likelihood of
using splice for successive requests instead of falling back to
read/write.
Signed-off-by: Giuseppe Scrivano <gscrivan@redhat.com>
Kirill Smelkov [Tue, 9 Jul 2019 20:54:09 +0000 (23:54 +0300)]
 
Sync fuse_kernel.h with Linux 5.2 (#433)
Nikolaus Rath [Tue, 9 Jul 2019 12:36:50 +0000 (05:36 -0700)]
 
Released 3.6.2
Nikolaus Rath [Tue, 9 Jul 2019 12:29:49 +0000 (05:29 -0700)]
 
Do not run passthrough test when caching is active.
Readdir caching means that direct modifications to the source
directory will not be seen immediately, so the test becomes flaky.
Fixes: #416.
Nikolaus Rath [Tue, 9 Jul 2019 12:13:50 +0000 (05:13 -0700)]
 
Install init script in /etc/ instead of $sysconfdir
sysconfdir defaults to /usr/local/etc which is almost always the wrong
choice.
Fixes: #427
Nikolaus Rath [Fri, 5 Jul 2019 10:03:31 +0000 (11:03 +0100)]
 
test_cuse: fix runtime error
We are no longer using the capfd mechanism.
Nikolaus Rath [Thu, 4 Jul 2019 20:20:41 +0000 (21:20 +0100)]
 
Fix output checking in test cases
py.test's capture plugin does not work reliably when used by
other fixtures. Therefore, implement our own version.
DrDaveD [Thu, 4 Jul 2019 08:01:19 +0000 (03:01 -0500)]
 
Add build option to skip steps requiring root permissions
Michael Forney [Sat, 15 Jun 2019 10:16:45 +0000 (03:16 -0700)]
 
Fix build with IGNORE_MTAB (#425)
chdir_to_parent and check_is_mount are used by should_auto_mount, added
in fuse-3.3.0, regardless of whether IGNORE_MTAB is defined.
Nikolaus Rath [Thu, 13 Jun 2019 14:25:07 +0000 (15:25 +0100)]
 
Released 3.6.1
Nikolaus Rath [Thu, 13 Jun 2019 12:01:10 +0000 (13:01 +0100)]
 
Released 3.6.0
scosu [Thu, 13 Jun 2019 11:59:10 +0000 (13:59 +0200)]
 
fuse_lowlevel: Add max_pages support (#384)
Starting with kernel version 4.20 fuse supports a new property
'max_pages' which is the maximum number of pages that can be used per
request. This can be set via an argument during initialization.
This new property allows writes to be larger than 128k.
This patch sets the property if the matching capability is set
(FUSE_MAX_PAGES). It will also set max_write to 1MiB. Filesystems have
the possibility to decrease this size by setting max_write to a smaller
size. The max_pages and bufsize fields are adjusted accordingly.
Cc: Constantine Shulyupin <const@MakeLinux.com>
Signed-off-by: Markus Pargmann <scosu@quobyte.com>
Michael Forney [Tue, 4 Jun 2019 19:33:17 +0000 (12:33 -0700)]
 
Avoid pointer arithmetic with `void *`
The pointer operand to the binary `+` operator must be to a complete
object type. Since we are working with byte sizes, use `char *` instead.
Michael Forney [Tue, 4 Jun 2019 19:30:04 +0000 (12:30 -0700)]
 
Don't return expression in function returning void
This is a constraint violation in ISO C[0].
[0] http://port70.net/~nsz/c/c11/n1570.html#6.8.6.4p1
Michael Forney [Tue, 4 Jun 2019 19:26:38 +0000 (12:26 -0700)]
 
Don't omit second operand to `?` operator
This is a GNU C extension.
Alan Somers [Fri, 24 May 2019 07:54:42 +0000 (01:54 -0600)]
 
Remove incorrect comment about fuse_entry_param.generation (#420)
A comment said that fuse_entry_param.generation must be non-zero.
However, I can't find anything in the kernel that requires that, and
real-world file systems don't seem to follow that advice, either.
Alan Somers [Wed, 15 May 2019 20:35:57 +0000 (14:35 -0600)]
 
passthrough: fix unix-domain sockets on FreeBSD (#413)
FreeBSD doesn't allow creating sockets using mknod(2). Instead, one has to use socket(2)
and bind(2).  Add appropriate logic to the examples and add a test case.
Nikolaus Rath [Sun, 12 May 2019 10:00:15 +0000 (11:00 +0100)]
 
Fix includes of non-system headers.
Fixes: #415.
Nikolaus Rath [Sun, 5 May 2019 17:11:03 +0000 (13:11 -0400)]
 
Added new example filesystem
passthrough_hp puts emphasis and performance and correctness, rather
than simplicity.
DrDaveD [Sun, 5 May 2019 17:36:14 +0000 (12:36 -0500)]
 
add defines for missing SECBITs on older kernels (#409)
Nikolaus Rath [Sun, 5 May 2019 17:32:59 +0000 (13:32 -0400)]
 
Fixed type of ioctl command parameter.
Nikolaus Rath [Fri, 3 May 2019 21:45:29 +0000 (14:45 -0700)]
 
Fixed permissions.
Fedor Korotkov [Wed, 1 May 2019 15:19:11 +0000 (11:19 -0400)]
 
Fixed Cirrus Config (#405)
Alan Somers [Wed, 1 May 2019 15:04:26 +0000 (09:04 -0600)]
 
Add CI for FreeBSD (#404)
Fixes #403
Nikolaus Rath [Tue, 30 Apr 2019 13:14:58 +0000 (06:14 -0700)]
 
Added issue template.
Nikolaus Rath [Mon, 29 Apr 2019 18:55:56 +0000 (11:55 -0700)]
 
Added information about development status.
Liu Bo [Thu, 18 Apr 2019 08:55:42 +0000 (01:55 -0700)]
 
Add fallocate and use it instead of posix_fallocate if possible (#398)
fuse.ko has supported FALLOC_FL_KEEP_SIZE and FALLOC_FL_PUNCH_HOLE at this
moment and more modes may be supported in the future.
fallocate(2) supports modes while posix_fallocate(2) does not, so this
makes lo_fallocate use fallocate(2) instead.
Signed-off-by: Liu Bo <bo.liu@linux.alibaba.com>
Nikolaus Rath [Tue, 16 Apr 2019 18:46:20 +0000 (19:46 +0100)]
 
Released 3.5.0
Chad Austin [Tue, 16 Apr 2019 18:44:59 +0000 (11:44 -0700)]
 
Add documentation for opting out of opendir and releasedir (#391)
Nikolaus Rath [Sun, 7 Apr 2019 14:05:00 +0000 (15:05 +0100)]
 
Bump minor version
cache_readdir flag is a new feature.
Nikolaus Rath [Sat, 6 Apr 2019 17:34:57 +0000 (18:34 +0100)]
 
Add support for in-kernel readdir caching.
Fixes: #394.
Nikolaus Rath [Sat, 6 Apr 2019 16:57:44 +0000 (17:57 +0100)]
 
Synchronize fuse_kernel.h with current kernel 
Nikolaus Rath [Sat, 6 Apr 2019 16:56:14 +0000 (17:56 +0100)]
 
Delete FUSE_FSYNC_FDATASYNC
This constant is not defined in the kernel, so it will be lost when
fuse_kernel.h is not synchronized. Instead, the kernel just passes a
flag value of "1", so for now we also use a literal in userspace.
Alan Somers [Thu, 4 Apr 2019 17:04:57 +0000 (11:04 -0600)]
 
Various documentation improvements
See issue #389 for some related discussions.
Peter Lemenkov [Wed, 3 Apr 2019 20:43:48 +0000 (22:43 +0200)]
 
Whitelist smb2 (#392)
See also https://bugzilla.redhat.com/
1694552#c7
Signed-off-by: Peter Lemenkov <lemenkov@gmail.com>
Jean-Pierre André [Mon, 11 Mar 2019 17:35:23 +0000 (18:35 +0100)]
 
Defined the (*ioctl)() commands as unsigned int (#381)
Instead of the Posix ioctl(2) command, Linux uses its own variant of ioctl()
in which the commands are requested as "unsigned long" and truncated to
32 bits by the fuse kernel module. Transmitting the commands to user space
file systems as "unsigned int" is a workaround for processing ioctl()
commands which do not fit into a signed int.
maxice8 [Mon, 11 Mar 2019 17:32:45 +0000 (14:32 -0300)]
 
Define ALLPERMS for musl libc systems. (#379)
Alan Somers [Sun, 10 Mar 2019 19:35:30 +0000 (13:35 -0600)]
 
Improve documentation for the flush method (#378)
Fixes: #373
Nikolaus Rath [Sat, 9 Mar 2019 11:16:00 +0000 (11:16 +0000)]
 
Released 3.4.2
Chad Austin [Sat, 9 Mar 2019 11:02:24 +0000 (03:02 -0800)]
 
Improve readdir() and file handle documentation
Fixes: #333
1c7718e7 [Sat, 9 Mar 2019 10:39:32 +0000 (12:39 +0200)]
 
Add HFS+ to filesystem whitelist (#347)
Tomohiro Kusumi [Sat, 9 Mar 2019 10:39:02 +0000 (19:39 +0900)]
 
Work around -Wformat-truncation=/-Wformat-overflow= warnings (#356)
sprintf(3)/snprintf(3) destination buffers need to be large enough
so that gcc doesn't warn -Wformat-truncation= or -Wformat-overflow=
when source buffer size is 1024 bytes.
--
../test/test_syscalls.c:1445:47: warning: '%s' directive output may be truncated writing 1 byte into a region of size between 0 and 1023 [-Wformat-truncation=]
 #define PATH(p)  (snprintf(path, sizeof path, "%s/%s", testdir, p), path)
                                               ^~~~~~~
../test/test_syscalls.c:1458:19:
  res = mkdir(PATH("a"), 0755);
                   ~~~
Signed-off-by: Tomohiro Kusumi <kusumi.tomohiro@gmail.com>
Nikolaus Rath [Sat, 9 Mar 2019 10:30:41 +0000 (10:30 +0000)]
 
Correctly include config.h ("" vs <>)
This isn't a system header.
Fixes: #349
Alan Somers [Sat, 9 Mar 2019 09:50:22 +0000 (02:50 -0700)]
 
Fix the changelog entry for protocol version 7.12 (#374)
Commit 
24b35c3d97ffdbf0a1f8e8b4e94ed892343603a6 had a simple mistake in
its changelog entry.
Sam Huffman [Fri, 8 Mar 2019 21:26:31 +0000 (13:26 -0800)]
 
fusermount: drop privileges for chdir()
cd to mountpoint's parent directory using unprivileged rather than
privileged access. This is to ensure that unmount works on mountpoints
where root may not have privileged access.
Fixes: #376
Alan Somers [Fri, 8 Mar 2019 21:24:50 +0000 (14:24 -0700)]
 
Document fuse_fsync_in.fsync_flags and remove magic numbers (#375)
HazelFZ [Mon, 4 Mar 2019 09:43:22 +0000 (17:43 +0800)]
 
Link against libiconv when possible (#372)
Nikolaus Rath [Wed, 27 Feb 2019 21:06:38 +0000 (21:06 +0000)]
 
Travis CI: Use Xenial instead of Trusty.
Forty-Bot [Mon, 25 Feb 2019 21:06:42 +0000 (16:06 -0500)]
 
hello_ll: Fix null pointer dereference (#363)
If hello_ll is invoked without a mountpoint, it will try to call
fuse_session_mount anyway with the NULL mountpoint (which then causes a
segfault). Print out a short help message instead (taken from
passthrough_ll.c).
Albert Chen [Wed, 13 Feb 2019 09:42:15 +0000 (01:42 -0800)]
 
fuse_free_buf(): to check flags of each buffer, rather than only 0th
Fixes: #360
Miklos Szeredi [Tue, 22 Jan 2019 20:03:00 +0000 (21:03 +0100)]
 
passthrough_ll: lo_create() should honor CACHE_NEVER (#345)
lo_create() did not honour CACHE_NEVER in lo_create(), which has an effect
on how I/O is performed after the open.
The value of CACHE_ALWAYS, which results in setting fi->keep_cache, only
has an effect for the state of the cache at open, and since the file was
just created the cache is always empty.  Hence setting this doesn't have an
effect on lo_create(), but keep it for symmetry with lo_open().
Nikolaus Rath [Mon, 21 Jan 2019 20:10:10 +0000 (20:10 +0000)]
 
Clarify documentation of fuse_lowlevel_inval_inode
Fixes: #341.
Tomohiro Kusumi [Mon, 14 Jan 2019 20:28:41 +0000 (05:28 +0900)]
 
Add support for buildin under DragonFly BSD
70e25ea74e("Fix build on non-Linux") broke build on DragonFly BSD,
or likely anything other than FreeBSD and NetBSD that is not Linux.
Signed-off-by: Tomohiro Kusumi <kusumi.tomohiro@gmail.com>
Nikolaus Rath [Fri, 4 Jan 2019 13:33:01 +0000 (13:33 +0000)]
 
Added OpenAFS to type whitelist
Fixes: #336.
Nikolaus Rath [Sat, 29 Dec 2018 14:52:42 +0000 (14:52 +0000)]
 
Fixed memory leak.
Fixes: #338.
Nikolaus Rath [Sat, 22 Dec 2018 14:48:37 +0000 (14:48 +0000)]
 
Added missing date to Changelog.
Nikolaus Rath [Sat, 22 Dec 2018 14:45:30 +0000 (14:45 +0000)]
 
Released 3.4.1
alex [Thu, 20 Dec 2018 17:32:10 +0000 (18:32 +0100)]
 
fix memory leak in print_module_help method
Nikolaus Rath [Tue, 27 Nov 2018 20:58:36 +0000 (20:58 +0000)]
 
Fix fd/inode leak
If do_readdir() calls do_lookup(), but the latter fails, we still have
to return any entries that we already stored in the readdir buffer to
avoid leaking inodes.
do_lookup() may fail if e.g. we reach the file descriptor limit.
Nikolaus Rath [Sat, 24 Nov 2018 20:27:12 +0000 (20:27 +0000)]
 
Avoid needless telldir() call.
Nikolaus Rath [Sat, 24 Nov 2018 20:24:10 +0000 (20:24 +0000)]
 
Fixed lookup-count leak in do_readdir().
Nikolaus Rath [Sat, 24 Nov 2018 20:24:45 +0000 (20:24 +0000)]
 
Added testcase for "big" readdir.
Nikolaus Rath [Fri, 23 Nov 2018 17:12:43 +0000 (17:12 +0000)]
 
Don't segfault when called with -h.
Fixes: #327
Nikolaus Rath [Sun, 18 Nov 2018 17:11:30 +0000 (17:11 +0000)]
 
Added .ackrc
Nikolaus Rath [Sun, 18 Nov 2018 17:11:13 +0000 (17:11 +0000)]
 
Kill filesystem process on test cleanup.
Niels de Vos [Tue, 26 Jun 2018 19:40:43 +0000 (21:40 +0200)]
 
tests: add copy_file_range() to the syscall tests
Niels de Vos [Tue, 26 Jun 2018 19:40:21 +0000 (21:40 +0200)]
 
examples: add copy_file_range() support to passthrough(_fh)
The passthrough example filesystem can be used for validating the API
and the implementation in the FUSE kernel module.
Niels de Vos [Mon, 18 Jun 2018 17:31:43 +0000 (19:31 +0200)]
 
libfuse: add copy_file_range() support
Add support for the relatively new copy_file_range() syscall. Backend
filesystems can now implement an efficient way of cloning/duplicating
data ranges within files. See 'man 2 copy_file_range' for more details.
Niels de Vos [Mon, 18 Jun 2018 11:41:07 +0000 (13:41 +0200)]
 
Update kernel API headers
Taken from Linux kernel commit 
3b7008b226f3.
Roman Bogorodskiy [Sun, 11 Nov 2018 10:46:14 +0000 (14:46 +0400)]
 
Fix mounting on FreeBSD
Currently, mounting on FreeBSD fails like this:
 mount_fusefs: ZZZZ<snip> on /mountpoint: No such file or directory
This happens because right after doing argv[a++] = fdnam it's
getting freed before calling execvp().
So move this free() call after execvp(). Also, when asprintf()
fails for fdnam, close device fd before calling exit().
Roman Bogorodskiy [Sun, 11 Nov 2018 14:31:15 +0000 (18:31 +0400)]
 
Fix build on non-Linux
 * Update meson.build to add mount_util.c to libfuse_sources
   unconditionally, it's non Linux-only
 * FreeBSD, like NetBSD, doesn't have mntent.h, so don't include
   that and define IGNORE_MTAB for both
 * FreeBSD, like NetBSD, has no umount2() sysctl, so similarly define
   it to unmount()
Nikolaus Rath [Fri, 9 Nov 2018 10:45:27 +0000 (10:45 +0000)]
 
Don't crash if mountpoint is not specified.
Fixes: #319.
Nikolaus Rath [Tue, 6 Nov 2018 18:57:47 +0000 (18:57 +0000)]
 
Released 3.3.0
Nikolaus Rath [Tue, 6 Nov 2018 18:54:06 +0000 (18:54 +0000)]
 
Update CI build script
There is no gcc-6 package anymore.
Nikolaus Rath [Tue, 6 Nov 2018 18:52:15 +0000 (18:52 +0000)]
 
Revert "Do not include struct fuse_buf in struct fuse_worker"
This reverts commit 
161983e2416bc6e26bbbe89664fff62c48c70858,
because this causes resource leaks when threads are terminated
by pthread_cancel().
Fixes: #313.
Kevin Vigor [Tue, 16 Oct 2018 23:23:07 +0000 (17:23 -0600)]
 
Avoid double unmount on normal unmount in auto_unmount mode.
If a fuse filesystem was mounted in auto_unmount mode on top of an
already mounted filesystem, we would end up doing a double-unmount
when the fuse filesystem was unmounted properly.
Make the auto_unmount code less eager: unmount only if the mounted
filesystem has proper type and is returning 'Transport endpoint not
connected'.
Nikolaus Rath [Tue, 6 Nov 2018 18:41:58 +0000 (18:41 +0000)]
 
Document when  `fuse_lowlevel_notify_*` functions may block.
Valentin Plugaru [Fri, 19 Oct 2018 21:19:28 +0000 (23:19 +0200)]
 
Add SpectrumScale/GPFS and Lustre to FS whitelist
Fixes: #304
Signed-off-by: Valentin Plugaru <valentin.plugaru@uni.lu>
Ahmed Masud [Fri, 19 Oct 2018 21:17:48 +0000 (17:17 -0400)]
 
Do not fail "ninja test" when running as subproject
Nikolaus Rath [Tue, 16 Oct 2018 13:06:19 +0000 (06:06 -0700)]
 
Bump minimum Meson version
According to user reports (https://github.com/libfuse/libfuse/pull/300),
we need at least version 0.42.
Nikolaus Rath [Thu, 11 Oct 2018 07:52:31 +0000 (08:52 +0100)]
 
Clarified licensing terms.
Fixes: #213.
Nikolaus Rath [Mon, 1 Oct 2018 10:10:36 +0000 (11:10 +0100)]
 
Enable more tests for passthrough_ll
Miklos Szeredi [Wed, 15 Aug 2018 08:36:31 +0000 (10:36 +0200)]
 
passthrough_ll: initialize unused memory
For '.' and '..' entries only the file type in e.attr.st_mode and the inode
number in e.attr.st_ino are used.  But it's prudent to at least initialize
the other fields of struct fuse_entry_param as well, instead of using
random values from the stack.
Miklos Szeredi [Tue, 14 Aug 2018 19:37:02 +0000 (21:37 +0200)]
 
passthrough_ll: allow configuring caching
Caching can be controlled with the following options:
 "cache=never": disable caching
 "cache=normal": enable caching but also refresh after the timeout
 "cache=always": never refresh cache
The timeout can be controlled with the "timeout=SEC" option, where SEC is
the number of seconds and can be an arbitrary non-negative floating point
number.
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Miklos Szeredi [Tue, 14 Aug 2018 19:37:02 +0000 (21:37 +0200)]
 
passthrough_ll: add *xattr() operations
The extended attribute functionality is enabled with the "xattr" option
(default) and disabled with the "no_xatt" option.
New operations added:
 - getxattr
 - listxattr
 - setxattr
 - removexattr
Caveat: none of these operations will work on a symbolic link, because it's
difficult to implement that without races that can result in incorrect
operation.
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Miklos Szeredi [Tue, 14 Aug 2018 19:37:02 +0000 (21:37 +0200)]
 
passthrough_ll: add flock()
Conditionally enable flock() locking on underlying filesystem, based on the
flock/no_flock options.  Default is "no_flock", meaning locking will be
local to the fuse filesystem and won't be propagated to the filesystem
passed through.
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Miklos Szeredi [Tue, 14 Aug 2018 19:37:02 +0000 (21:37 +0200)]
 
passthrough_ll: whitespace cleanup
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Vivek Goyal [Tue, 14 Aug 2018 19:37:02 +0000 (21:37 +0200)]
 
passthrough_ll: add forget_multi()
Add method forget_multi() to forget multiple inodes in a single message.
Signed-off-by: Vivek Goyal <vgoyal@redhat.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Vivek Goyal [Tue, 14 Aug 2018 19:37:02 +0000 (21:37 +0200)]
 
passthrough_ll: add source option
Right now, passthrough_ll will use "/" as source directory for passthrough.
We need more flexibility where user can specify path of directory to be
passed through.  Hence add an option "source=<source-dir>".
Signed-off-by: Vivek Goyal <vgoyal@redhat.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Miklos Szeredi [Tue, 19 Jun 2018 18:33:21 +0000 (14:33 -0400)]
 
passthrough_ll: add some of the missing operations
New operations added:
 - mkdir
 - mknod
 - symlink
 - link
 - unlink
 - rmdir
 - rename
 - setattr
 - fsyncdir
 - flush
 - fsync
 - statfs
 - fallocate
Caveats:
 - The utimes(2) family of syscalls will fail on symlinks on 4.18 and
   earlier kernels.  Hoping to add support to later kernels.
 - The link(2) and linkat(2) system calls will fail on symlinks unless running
   with privileges (CAP_DAC_READ_SEARCH).
Signed-off-by: Vivek Goyal <vgoyal@redhat.com>
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Miklos Szeredi [Tue, 14 Aug 2018 19:37:02 +0000 (21:37 +0200)]
 
passthrough_ll: add is_symlink to lo_inode
Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>