Nikolaus Rath [Tue, 19 Sep 2017 19:37:46 +0000 (20:37 +0100)]
 
Correctly define fusermount3 path.
Nikolaus Rath [Tue, 19 Sep 2017 19:33:26 +0000 (20:33 +0100)]
 
Make *_loop_mt() available in version 3.0 again
The old versions of these symbols were defined with version
tag FUSE_3.0, so this is what we have to use in the .symver
directive.
Nikolaus Rath [Tue, 19 Sep 2017 19:26:51 +0000 (20:26 +0100)]
 
Fix versioned symbols in version script
According to "How to Write Shared Libraries" by Ulrich Drepper
(https://www.akkadia.org/drepper/dsohowto.pdf), the version script
should contain the exported name of the versioned symbol once in each
tag for which it has been defined by .symver.
Nikolaus Rath [Tue, 19 Sep 2017 15:24:37 +0000 (16:24 +0100)]
 
Don't use external symbol names in internal files
The fuse_session_loop_mt() and fuse_loop_mt() symbols are only visible
when linking against the shared object. The code in lib/, however, is
compiled *into* the shared object and should thus use the internal
names of these functions.
Surprisingly enough, the code still worked before - but only when link
time optimization was disabled.
Unfortunately, we still can't compile with LTO because it seems that
enabling LTO somehow makes the tagged symbols vanish.
Without lto, we have:
$ nm lib/libfuse3.so | grep fuse_new
0000000000011070 T fuse_new_30
0000000000010a00 t fuse_new_31
0000000000011070 T fuse_new@FUSE_3.0
0000000000010a00 T fuse_new@@FUSE_3.1
and with LTO:
$ nm lib/libfuse3.so | grep fuse_new
0000000000019a70 T fuse_new_30
0000000000019270 t fuse_new_31
See also issue #198.
Nikolaus Rath [Sun, 17 Sep 2017 08:39:47 +0000 (09:39 +0100)]
 
Include source code in documentation.
Nikolaus Rath [Sun, 17 Sep 2017 08:35:52 +0000 (09:35 +0100)]
 
make_release_tarball.sh: be less verbose
Nikolaus Rath [Sun, 17 Sep 2017 08:35:43 +0000 (09:35 +0100)]
 
Added some documentation of fuse internals.
Nikolaus Rath [Tue, 12 Sep 2017 13:03:31 +0000 (14:03 +0100)]
 
Released 3.2.0
Nikolaus Rath [Tue, 12 Sep 2017 13:46:00 +0000 (14:46 +0100)]
 
Add script to create release tarball.
Nikolaus Rath [Tue, 12 Sep 2017 13:01:04 +0000 (14:01 +0100)]
 
Use "mkdir" instead of "md" in instructions.
Fixes: #205.
Nikolaus Rath [Mon, 11 Sep 2017 10:19:06 +0000 (11:19 +0100)]
 
fuse_kern_unmount(): close fd before calling umount
This is what the Linux version does, and it fixes a
timeout under FreeBSD when the kernel sends a FUSE_DESTROY
request that is never answered.
Nikolaus Rath [Fri, 25 Aug 2017 08:48:09 +0000 (10:48 +0200)]
 
example/ioctl: build on FreeBSD, but add protocol check instead.
Nikolaus Rath [Fri, 25 Aug 2017 08:38:43 +0000 (10:38 +0200)]
 
do_init(): print missing capabilities if there are any.
Nikolaus Rath [Fri, 25 Aug 2017 07:49:23 +0000 (09:49 +0200)]
 
Fix writeback capability check.
Nikolaus Rath [Fri, 25 Aug 2017 07:46:50 +0000 (09:46 +0200)]
 
examples/{ioctl,null}: don't build under FreeBSD instead of skipping tests.
Nikolaus Rath [Thu, 24 Aug 2017 19:47:38 +0000 (21:47 +0200)]
 
printcap: use temporary directory, not file
Mounting a file doesn't seem to work under FreeBSD.
Nikolaus Rath [Thu, 24 Aug 2017 19:50:30 +0000 (21:50 +0200)]
 
Skip testing null and ioctl examples under FreeBSD.
This seems to be unsupported. However, me may also be
doing it wrong. I've asked on the freebsd-fs list for help.
Nikolaus Rath [Thu, 24 Aug 2017 19:50:23 +0000 (21:50 +0200)]
 
Removed unused import.
Nikolaus Rath [Thu, 24 Aug 2017 19:08:25 +0000 (21:08 +0200)]
 
passthrough_ll: only active EXPORT_SUPPORT of supported by kernel.
Nikolaus Rath [Thu, 24 Aug 2017 15:09:41 +0000 (17:09 +0200)]
 
Don't use -o auto_unmount under FreeBSD.
Nikolaus Rath [Thu, 24 Aug 2017 15:07:57 +0000 (17:07 +0200)]
 
Dropped support for building with autotools
It's just too much pain to keep it working.
Nikolaus Rath [Thu, 24 Aug 2017 15:00:15 +0000 (17:00 +0200)]
 
Use printcap() to control test execution
That way, we run only tests that are supported by the running kernel.
Nikolaus Rath [Thu, 24 Aug 2017 14:51:34 +0000 (16:51 +0200)]
 
Added testcase for examples/printcap
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.