Joseph Dodge [Thu, 24 Aug 2017 12:37:10 +0000 (14:37 +0200)]
 
Add idle_threads mount option.
Nikolaus Rath [Thu, 24 Aug 2017 12:23:13 +0000 (14:23 +0200)]
 
Renamed notify_inval_inode_fh to invalidate_path
The previous name didn't make much sense.
Sławek Rudnicki [Mon, 7 Aug 2017 10:41:33 +0000 (12:41 +0200)]
 
Allow inode cache invalidation in high-level API
We re-introduce the functionality of invalidating the caches for an
inode specified by path by adding a new routine
fuse_invalidate_path. This is useful for network-based file systems
which use the high-level API, enabling them to notify the kernel about
external changes.
This is a revival of Miklos Szeredi's original code for the
fuse_invalidate routine.
Nikolaus Rath [Wed, 23 Aug 2017 21:39:27 +0000 (23:39 +0200)]
 
Added examples/printcap
Nikolaus Rath [Wed, 23 Aug 2017 21:37:40 +0000 (23:37 +0200)]
 
fuse_loop_mt(): on error, return errno rather than -1.
Nikolaus Rath [Wed, 23 Aug 2017 21:36:22 +0000 (23:36 +0200)]
 
fuse_loop(): don't return non-zero if there was no error
Nikolaus Rath [Tue, 22 Aug 2017 15:05:26 +0000 (17:05 +0200)]
 
Document and unify error codes of fuse_lowlevel_notify_*
Nikolaus Rath [Tue, 22 Aug 2017 11:46:14 +0000 (13:46 +0200)]
 
Make passthrough_fh work under FreeBSD.
Nikolaus Rath [Tue, 22 Aug 2017 11:50:14 +0000 (13:50 +0200)]
 
Fix two compiler warnings.
Nikolaus Rath [Tue, 22 Aug 2017 11:45:41 +0000 (13:45 +0200)]
 
Document meaning of zero telldir() offset.
Nikolaus Rath [Tue, 22 Aug 2017 10:10:50 +0000 (12:10 +0200)]
 
Allow building without iconv.
cfg.has('HAVE_ICONV') was always true.
Nikolaus Rath [Tue, 22 Aug 2017 09:10:00 +0000 (11:10 +0200)]
 
Use 'buildtype' to set debug/optimization options
Until now, running `mesonconf -D buildtype=debug` didn't have any
effect - which was confusing.
userwithuid [Mon, 14 Aug 2017 15:08:41 +0000 (15:08 +0000)]
 
directly call fuse_new_31() instead of fuse_new() internally
this fixes building with lto, which failed since commit 
503e32d01e4db00e90d7acfd81ab05386559069f
Nikolaus Rath [Mon, 14 Aug 2017 08:26:51 +0000 (10:26 +0200)]
 
Fixed udev rules directory.
Nikolaus Rath [Fri, 11 Aug 2017 18:15:27 +0000 (20:15 +0200)]
 
Skip tests that aren't supported under FreeBSD.
Nikolaus Rath [Fri, 11 Aug 2017 18:14:55 +0000 (20:14 +0200)]
 
fuse_lib_init(): don't set FUSE_CAP_EXPORT_SUPPORT unconditionally
FreeBSD kernel does not support this.
Nikolaus Rath [Fri, 11 Aug 2017 08:53:56 +0000 (10:53 +0200)]
 
Don't attempt to run fusermount3 under BSD.
Nikolaus Rath [Fri, 11 Aug 2017 08:46:07 +0000 (10:46 +0200)]
 
Call cp with -p instead of --preserve=mode
Preserving other attributes doesn't hurt, and --preserve
is not supported under FreeBSD.
Nikolaus Rath [Fri, 11 Aug 2017 08:42:58 +0000 (10:42 +0200)]
 
Don't pass --update to cp
Doesn't work on FreeBSD, and not strictly necessary.
Nikolaus Rath [Fri, 11 Aug 2017 08:41:58 +0000 (10:41 +0200)]
 
Don't build passthrough_ll under BSD.
Nikolaus Rath [Fri, 11 Aug 2017 08:31:24 +0000 (10:31 +0200)]
 
fuse_kern_unmount(): fix variable type.
Nikolaus Rath [Fri, 11 Aug 2017 08:26:28 +0000 (10:26 +0200)]
 
Fix unused variable warnings under FreeBSD.
Nikolaus Rath [Tue, 8 Aug 2017 13:40:09 +0000 (15:40 +0200)]
 
Fix FreeBSD platform detection.
Marcin Sulikowski [Thu, 3 Aug 2017 14:24:39 +0000 (16:24 +0200)]
 
Fix support for FUSE_POSIX_ACL
The kernel may set the FUSE_POSIX_ACL flag in the FUSE_INIT request to
notify the userspace daemon that the OS does support POSIX ACLs for FUSE
file systems. If the filesystem implementation wants to enable POSIX
ACLs, it has to reply with the FUSE_POSIX_ACL flag set. However, the
reply to the kernel never includes this flag, even if the implementation
expresses the need by setting the FUSE_CAP_POSIX_ACL flag in the
fuse_conn_info::want variable passed to its init callback. We modify the
library to handle requests for FUSE_CAP_POSIX_ACL correctly, i.e., set
the FUSE_POSIX_ACL flag in the FUSE_INIT reply to the kernel.
Signed-off-by: Marcin Sulikowski <marcin.sulikowski@editshare.com>
Nikolaus Rath [Sun, 6 Aug 2017 11:24:40 +0000 (13:24 +0200)]
 
Released 3.1.1
Nikolaus Rath [Sun, 6 Aug 2017 11:24:20 +0000 (13:24 +0200)]
 
os_open(): don't attempt to close fd if open failed.
Nikolaus Rath [Fri, 4 Aug 2017 20:38:03 +0000 (22:38 +0200)]
 
Added writeback cache to passthrough_ll
This fixes issue #191 (where the test was done by simply adding
FUSE_CAP_WRITEBACK_CACHE without adjusting the flags in the
open() call).
Fixes: #191.
Nikolaus Rath [Fri, 4 Aug 2017 20:38:29 +0000 (22:38 +0200)]
 
Clarified documentation for fuse_parse_cmdline()
Nikolaus Rath [Fri, 4 Aug 2017 20:17:06 +0000 (22:17 +0200)]
 
Removed compat stuff in passthrough_ll
As the comment says, this made it compile but not work. If there is a
need, we can add these checks to meson.build to only build this file
if the prerequisites are satisfied.
Nikolaus Rath [Fri, 4 Aug 2017 20:12:36 +0000 (22:12 +0200)]
 
Clarify how the filesystem should handle open/create flags
Nikolaus Rath [Fri, 4 Aug 2017 19:56:45 +0000 (21:56 +0200)]
 
passthrough_ll: added more debugging output
Nikolaus Rath [Fri, 4 Aug 2017 18:13:08 +0000 (20:13 +0200)]
 
Added append and seek tests
Nikolaus Rath [Fri, 4 Aug 2017 18:12:58 +0000 (20:12 +0200)]
 
Include ChangeLog in tarball
Nikolaus Rath [Thu, 3 Aug 2017 15:19:22 +0000 (17:19 +0200)]
 
Simplify and fix FreeBSD fsname handling
This should simplify the code a lot. It also corrects a bug in
that the (former) add_default_fsname() function actually set
the -osubtype option.
Nikolaus Rath [Thu, 3 Aug 2017 15:13:23 +0000 (17:13 +0200)]
 
Simply #ifdefs
mount_bsd.c is only used when compiling for *BSD, and FreeBSD
is the only BSD that supports FUSE. So there really is no need
to check if this file is compiled under FreeBSD.
Nikolaus Rath [Thu, 3 Aug 2017 15:12:25 +0000 (17:12 +0200)]
 
Fix FreeBSD detection in meson.build
Nikolaus Rath [Thu, 3 Aug 2017 15:12:15 +0000 (17:12 +0200)]
 
Added ChangeLog entry for FreeBSD commits.
Baptiste Daroussin [Thu, 3 Aug 2017 12:37:07 +0000 (14:37 +0200)]
 
FreeBSD: supprt fsname= option
Baptiste Daroussin [Thu, 3 Aug 2017 12:24:22 +0000 (14:24 +0200)]
 
FreeBSD: use unmount(2) and add missing FreeBSD mount option
Baptiste Daroussin [Thu, 3 Aug 2017 12:04:36 +0000 (14:04 +0200)]
 
FreeBSD: do not build utilities
Nikolaus Rath [Thu, 3 Aug 2017 11:44:32 +0000 (13:44 +0200)]
 
Produce more helpful message on OS-X and Windows.
Fixes: #186.
Nikolaus Rath [Thu, 3 Aug 2017 11:07:30 +0000 (13:07 +0200)]
 
Don't check st_nlink value for mkdir
Some filesystems don't track this for directories.
Fixes: #180.
Nikolaus Rath [Thu, 3 Aug 2017 11:01:12 +0000 (13:01 +0200)]
 
Added changelog entry for symbol versioning fixes.
Nikolaus Rath [Thu, 3 Aug 2017 11:00:09 +0000 (13:00 +0200)]
 
Added changelog entry for commit f0ecf.
Nikolaus Rath [Thu, 3 Aug 2017 10:56:02 +0000 (12:56 +0200)]
 
Fix compilation on 32bit systems
Fixes: #185.
Heiko Becker [Fri, 28 Jul 2017 15:33:56 +0000 (17:33 +0200)]
 
Ask pkgconfig where we should install udev rules
Banglang [Tue, 1 Aug 2017 09:10:32 +0000 (17:10 +0800)]
 
Fix compiler warnings of gcc-5.4.x
Signed-off-by: Banglang <banglang.huang@foxmail.com>
Nikolaus Rath [Thu, 13 Jul 2017 11:23:32 +0000 (13:23 +0200)]
 
Only declare fuse_new_30() when FUSE_USE_VERSION == 30
This function shouldn't be called when using a newer fuse
version, so we should not define it in that case.
Nikolaus Rath [Thu, 13 Jul 2017 11:22:12 +0000 (13:22 +0200)]
 
fuse_new_30(): call fuse_new_31(), not fuse_new()
I believe this function call is resolved by the compiler, not
the linker, so this seems safer.
Thanks to Chris Clayton for spotting this.
Nikolaus Rath [Sat, 8 Jul 2017 11:11:47 +0000 (13:11 +0200)]
 
Fixup symbol versioning for GCC 4.x
GCC 4.8 doesn't like to rename fuse_new_30 to fuse_new, if we
also define an implementation for fuse_new.
Nikolaus Rath [Sat, 8 Jul 2017 10:11:01 +0000 (12:11 +0200)]
 
Released 3.1.0
Nikolaus Rath [Fri, 7 Jul 2017 13:25:41 +0000 (15:25 +0200)]
 
Added public fuse_lib_help(), bumped minor version
Nikolaus Rath [Fri, 7 Jul 2017 23:12:59 +0000 (01:12 +0200)]
 
Fixed description of struct fuse_conn_info->time_gran
At least on Linux kernel 4.9, a value of zero gives more
than 1-sec accuracy.
Nikolaus Rath [Fri, 7 Jul 2017 13:34:32 +0000 (15:34 +0200)]
 
Error out if FUSE_USE_VERSION is not defined
This is safer than making assumptions.
Nikolaus Rath [Fri, 7 Jul 2017 13:29:30 +0000 (15:29 +0200)]
 
Don't use emacs' python-mode for meson files
There is a proper meson-mode now.
Nikolaus Rath [Fri, 7 Jul 2017 13:27:17 +0000 (15:27 +0200)]
 
Fixed typo in Changelog
Nikolaus Rath [Thu, 6 Jul 2017 16:29:53 +0000 (18:29 +0200)]
 
Don't redefine FUSE_USE_VERSION
It's already set in meson.build as compiler flag.
Nikolaus Rath [Thu, 6 Jul 2017 11:13:42 +0000 (13:13 +0200)]
 
Travis: use sudo-enabled environment.
Nikolaus Rath [Thu, 6 Jul 2017 10:40:31 +0000 (12:40 +0200)]
 
Added information about professional support.
Nikolaus Rath [Thu, 6 Jul 2017 10:40:16 +0000 (12:40 +0200)]
 
Fixed bug in code example in ChangeLog.
Nikolaus Rath [Wed, 21 Jun 2017 22:41:37 +0000 (15:41 -0700)]
 
Install init script in $DESTDIR/etc, not $prefix/$sysconfdir
Fixes: #178.
Nikolaus Rath [Tue, 20 Jun 2017 23:37:51 +0000 (16:37 -0700)]
 
tst_readdir(): actually go through FUSE
The previous code didn't actually go through the mountpoint at all.
Nikolaus Rath [Thu, 8 Jun 2017 17:32:46 +0000 (13:32 -0400)]
 
Clarify *_timeout semantics
When changes always come through kernel, timeouts
should be large.
Nikolaus Rath [Tue, 6 Jun 2017 13:31:50 +0000 (09:31 -0400)]
 
Describe supported platforms.
Nikolaus Rath [Mon, 5 Jun 2017 11:27:31 +0000 (07:27 -0400)]
 
getgroups(): clarify code
read() return value should always be positive or -1. However,
since we cast to unsigned a little later, it's clearer
to check for non-negativity.
Angelo G. Del Regno [Sun, 4 Jun 2017 09:02:07 +0000 (11:02 +0200)]
 
Fix comparison of integers of different signs
Some variables of different size and sign were getting compared
without any safe casting.
The build system also throws warnings at this and, being this
library used for filesystems, it's really important to ensure
stability.
Nikolaus Rath [Mon, 5 Jun 2017 11:00:56 +0000 (07:00 -0400)]
 
examples/passthrough_ll: added support for create()
Nikolaus Rath [Mon, 5 Jun 2017 10:57:36 +0000 (06:57 -0400)]
 
example/passthrough_ll: added write support
Nikolaus Rath [Wed, 31 May 2017 20:43:54 +0000 (13:43 -0700)]
 
notify_store_retrieve(): fix race on unmount
update_fs_loop() is still running when the filesystem unmounts,
but it that case calls to fuse_lowlevel_notify_* will fail.
Fixes: #105.
Nikolaus Rath [Wed, 31 May 2017 20:36:08 +0000 (13:36 -0700)]
 
Clarify that destroy() is called without kernel connection
Nikolaus Rath [Wed, 31 May 2017 19:54:19 +0000 (12:54 -0700)]
 
example/notify_store_retrieve: add debugging code for issue #105.
Nikolaus Rath [Wed, 31 May 2017 19:35:16 +0000 (12:35 -0700)]
 
Revert "example/passthrough.c: add debugging code for issue #157."
This reverts commit 
179fa13b40387645e722089873079488f9dbe3d8.
Nikolaus Rath [Wed, 31 May 2017 16:34:40 +0000 (09:34 -0700)]
 
tst_link(): wait for RELEASE request
Since RELEASE requests are asynchronous, it is possible that libfuse
still considers the file to be open when userspace has closed it, so
that a successive unlink() call from userspace actually triggers
a rename(). We avoid the resulting test failure by re-trying a few
times.
Fixes: #157.
Nikolaus Rath [Thu, 25 May 2017 20:22:43 +0000 (13:22 -0700)]
 
Factored out C-based tests
Nikolaus Rath [Thu, 25 May 2017 20:12:20 +0000 (13:12 -0700)]
 
Fix typo in comment.
Nikolaus Rath [Thu, 25 May 2017 20:12:06 +0000 (13:12 -0700)]
 
Document RENAME_EXCHANGE and RENAME_NOREPLACE flags.
Nikolaus Rath [Thu, 25 May 2017 19:48:27 +0000 (12:48 -0700)]
 
passthrough_ll: document that fuse_ino_t and uintptr_t sizes must match
We can consider changing the code to drop the requirement if it
turns out that there's a system where this isn't given.
Fixes issue #167.
Nikolaus Rath [Thu, 25 May 2017 19:26:52 +0000 (12:26 -0700)]
 
example/passthrough.c: add debugging code for issue #157.
Nikolaus Rath [Thu, 25 May 2017 19:15:17 +0000 (12:15 -0700)]
 
tst_link(): add more assertions
Hopefully this helps debugging issue #157.
pablomh [Tue, 23 May 2017 13:41:31 +0000 (15:41 +0200)]
 
Remove fuse_fs_fgetattr and fuse_fs_ftruncate from linker script
They were removed from source here: https://github.com/libfuse/libfuse/commit/
73b6ff4b75cf1228ea61262c293fcb2fda5dfeea
Nikolaus Rath [Wed, 24 May 2017 23:53:14 +0000 (16:53 -0700)]
 
Travis-CI: Don't abort on first failed test
This should help debugging issue #157.
Nikolaus Rath [Wed, 24 May 2017 23:20:04 +0000 (16:20 -0700)]
 
Added tst_open_read()
Slightly increases coverage of examples/passthrough_ll.c (which
supports open for reading, but not for writing).
Nikolaus Rath [Wed, 24 May 2017 23:12:41 +0000 (16:12 -0700)]
 
lib/meson.build: don't crash if there's no libdl
For example, FreeBSD doesn't have it.
Fixes: #173.
Nikolaus Rath [Wed, 24 May 2017 22:56:41 +0000 (15:56 -0700)]
 
fuse_signals.c: use new do_nothing function instead of SIG_IGN
Fixes: #160.
Nikolaus Rath [Wed, 24 May 2017 20:56:11 +0000 (13:56 -0700)]
 
Released libfuse 3.0.2
Brian Naylor [Wed, 24 May 2017 15:38:49 +0000 (11:38 -0400)]
 
Make tests build on bsd
Carlos Maiolino [Thu, 20 Apr 2017 12:53:01 +0000 (14:53 +0200)]
 
make buffer size match kernel max transfer size
Currently libfuse has a hardcoded buffer limit to 128kib, while fuse
kernel module has a limit up to 32 pages.
This patch changes buffer limit to match the current page size, instead
of assuming 4096 bytes pages, enabling architectures with bigger pages
to use larger buffers, improving performance.
Also, add a new macro (HEADER_SIZE) to specify the space needed to
accommodate the header, making it easier to understand why those extra
4096 bytes are needed
Signed-off-by: Carlos Maiolino <cmaiolino-H+wXaHxf7aLQT0dZR+AlfA@public.gmane.org>
Tej Chajed [Thu, 13 Apr 2017 21:23:33 +0000 (17:23 -0400)]
 
Set default options before parsing
Nikolaus Rath [Wed, 12 Apr 2017 16:33:22 +0000 (09:33 -0700)]
 
Improved documentation of fuse_context.private_data
In particular, don't call it "user_data" in one place and
"private_data" elsewhere.
Changing the name of the variable in the prototype should not affect
backwards compatibility.
Fixes: #155.
Nikolaus Rath [Tue, 11 Apr 2017 00:28:41 +0000 (17:28 -0700)]
 
Released 3.0.1
Nikolaus Rath [Tue, 11 Apr 2017 00:23:28 +0000 (17:23 -0700)]
 
Fix travis build script. Broken in e372d.
Nikolaus Rath [Tue, 11 Apr 2017 00:11:30 +0000 (17:11 -0700)]
 
Added ChangeLog for commits c24cc to eb972.
Nikolaus Rath [Tue, 11 Apr 2017 00:08:58 +0000 (17:08 -0700)]
 
Remove 'tests' target in favor of calling py.test directly.
Together with the previous commit, this fixes #156.
Nikolaus Rath [Mon, 10 Apr 2017 23:46:35 +0000 (16:46 -0700)]
 
Build tests by default.
Nikolaus Rath [Mon, 10 Apr 2017 23:39:01 +0000 (16:39 -0700)]
 
Only build test/*.py if out of date.
Nikolaus Rath [Wed, 5 Apr 2017 23:49:39 +0000 (16:49 -0700)]
 
Actually test passthrough* examples
Since os.path.join() interprets leading slashes, we were
actually never accessing the mountpoint and doing all the
tests in the source directory.
Fixes: #139
Nikolaus Rath [Fri, 7 Apr 2017 23:36:52 +0000 (16:36 -0700)]
 
passthrough: implemented create()
This allows calls like open(file, O_CREAT|O_RDONLY, 0200) which would
otherwise fail because we cannot open the file after mknod() has
created it with 0200 permissions.
Nikolaus Rath [Fri, 7 Apr 2017 23:31:07 +0000 (16:31 -0700)]
 
example/passthrough: use fi->fh for read, write, fallocate
No reason not to use it. May even be a little faster and will
consume less resources :-).
Nikolaus Rath [Fri, 7 Apr 2017 23:27:59 +0000 (16:27 -0700)]
 
passthrough:truncate(): work on file descriptor when possible
This allows truncating an open file even if write permission
was removed after open() (which is the expected behavior).
Nikolaus Rath [Fri, 7 Apr 2017 23:27:33 +0000 (16:27 -0700)]
 
example/passthrough: close open files in release()
That way we can use the file descriptor for other operations.