qemu-gpiodev/libfuse.git
7 years agofusermount: Fix memory leaks
Rostislav Skudnov [Sat, 21 Jul 2018 21:14:06 +0000 (21:14 +0000)]
fusermount: Fix memory leaks

7 years agoFix readdir() bug when a non-zero offset is specified in filler (#269)
Rostislav [Sat, 21 Jul 2018 09:57:09 +0000 (12:57 +0300)]
Fix readdir() bug when a non-zero offset is specified in filler (#269)

The bug occurs when a filesystem client reads a directory until the end,
seeks using seekdir() to some valid non-zero position and calls
readdir(). A valid 'struct dirent *' is expected, but NULL is returned
instead. Pseudocode demonstrating the bug:

DIR *dp = opendir("some_dir");
struct dirent *de = readdir(dp);

/* Get offset of the second entry */
long offset = telldir(dp);

/* Read directory until the end */
while (de)
de = readdir(de);

seekdir(dp, offset);
de = readdir(dp);
/* de must contain the second entry, but NULL is returned instead */

The reason of the bug is that when the end of directory is reached, the
kernel calls FUSE_READDIR op with an offset at the end of directory, so
the filesystem's .readdir callback never calls the filler function, and
we end up with dh->filled set to 1. After seekdir(), FUSE_READDIR is
called again with a new offset, but this time the filesystem's .readdir
callback is never called, and an empty reply is returned.

Fix by setting dh->filled to 1 only when zero offsets are given to
filler function.

7 years agofusermount: whitelist known-good filesystems for mountpoints
Jann Horn [Sat, 14 Jul 2018 11:37:41 +0000 (13:37 +0200)]
fusermount: whitelist known-good filesystems for mountpoints

Before:

$ _FUSE_COMMFD=1 priv_strace -s8000 -e trace=mount util/fusermount3 /proc/self/fd
mount("/dev/fuse", ".", "fuse", MS_NOSUID|MS_NODEV, "fd=3,rootmode=40000,user_id=379777,group_id=5001") = 0
sending file descriptor: Socket operation on non-socket
+++ exited with 1 +++

After:

$ _FUSE_COMMFD=1 priv_strace -s8000 -e trace=mount util/fusermount3 /proc/self/fd
util/fusermount3: mounting over filesystem type 0x009fa0 is forbidden
+++ exited with 1 +++

This patch could potentially have security
impact on some systems that are configured with allow_other;
see https://launchpad.net/bugs/1530566 for an example of how a similar
issue in the ecryptfs mount helper was exploitable. However, the FUSE
mount helper performs slightly different security checks, so that exact
attack doesn't work with fusermount; I don't know of any specific attack
you could perform using this, apart from faking the SELinux context of your
process when someone's looking at a process listing. Potential targets for
overwrite are (looking on a system with a 4.9 kernel):

writable only for the current process:
/proc/self/{fd,map_files}
(Yes, "ls -l" claims that you don't have write access, but that's not true;
"find -writable" will show you what access you really have.)

writable also for other owned processes:
/proc/$pid/{sched,autogroup,comm,mem,clear_refs,attr/*,oom_adj,
oom_score_adj,loginuid,coredump_filter,uid_map,gid_map,projid_map,
setgroups,timerslack_ns}

7 years agofusermount: refuse unknown options
Jann Horn [Sat, 14 Jul 2018 10:47:50 +0000 (03:47 -0700)]
fusermount: refuse unknown options

Blacklists are notoriously fragile; especially if the kernel wishes to add
some security-critical mount option at a later date, all existing systems
with older versions of fusermount installed will suddenly have a security
problem.
Additionally, if the kernel's option parsing became a tiny bit laxer, the
blacklist could probably be bypassed.

Whitelist known-harmless flags instead, even if it's slightly more
inconvenient.

7 years agofusermount: bail out on transient config read failure
Jann Horn [Fri, 13 Jul 2018 22:50:50 +0000 (15:50 -0700)]
fusermount: bail out on transient config read failure

If an attacker wishes to use the default configuration instead of the
system's actual configuration, they can attempt to trigger a failure in
read_conf(). This only permits increasing mount_max if it is lower than the
default, so it's not particularly interesting. Still, this should probably
be prevented robustly; bail out if funny stuff happens when we're trying to
read the config.

Note that the classic attack trick of opening so many files that the
system-wide limit is reached won't work here - because fusermount only
drops the fsuid, not the euid, the process is running with euid=0 and
CAP_SYS_ADMIN, so it bypasses the number-of-globally-open-files check in
get_empty_filp() (unless you're inside a user namespace).

7 years agofusermount: don't feed "escaped commas" into mount options
Jann Horn [Fri, 13 Jul 2018 22:15:36 +0000 (15:15 -0700)]
fusermount: don't feed "escaped commas" into mount options

The old code permits the following behavior:

$ _FUSE_COMMFD=10000 priv_strace -etrace=mount -s200 fusermount -o 'foobar=\,allow_other' mount
mount("/dev/fuse", ".", "fuse", MS_NOSUID|MS_NODEV, "foobar=\\,allow_other,fd=3,rootmode=40000,user_id=1000,group_id=1000") = -1 EINVAL (Invalid argument)

However, backslashes do not have any special meaning for the kernel here.

As it happens, you can't abuse this because there is no FUSE mount option
that takes a string value that can contain backslashes; but this is very
brittle. Don't interpret "escape characters" in places where they don't
work.

7 years agofusermount: prevent silent truncation of mount options
Jann Horn [Fri, 13 Jul 2018 21:51:17 +0000 (14:51 -0700)]
fusermount: prevent silent truncation of mount options

Currently, in the kernel, copy_mount_options() copies in one page of
userspace memory (or less if some of that memory area is not mapped).
do_mount() then writes a null byte to the last byte of the copied page.
This means that mount option strings longer than PAGE_SIZE-1 bytes get
truncated silently.

Therefore, this can happen:

user@d9-ut:~$ _FUSE_COMMFD=10000 fusermount -o "$(perl -e 'print ","x4000')" mount
sending file descriptor: Bad file descriptor
user@d9-ut:~$ grep /mount /proc/mounts
/dev/fuse /home/user/mount fuse rw,nosuid,nodev,relatime,user_id=1000,group_id=1000 0 0
user@d9-ut:~$ fusermount -u mount
user@d9-ut:~$ _FUSE_COMMFD=10000 fusermount -o "$(perl -e 'print ","x4050')" mount
sending file descriptor: Bad file descriptor
user@d9-ut:~$ grep /mount /proc/mounts
/dev/fuse /home/user/mount fuse rw,nosuid,nodev,relatime,user_id=1000,group_id=100 0 0
user@d9-ut:~$ fusermount -u mount
user@d9-ut:~$ _FUSE_COMMFD=10000 fusermount -o "$(perl -e 'print ","x4051')" mount
sending file descriptor: Bad file descriptor
user@d9-ut:~$ grep /mount /proc/mounts
/dev/fuse /home/user/mount fuse rw,nosuid,nodev,relatime,user_id=1000,group_id=10 0 0
user@d9-ut:~$ fusermount -u mount
user@d9-ut:~$ _FUSE_COMMFD=10000 fusermount -o "$(perl -e 'print ","x4052')" mount
sending file descriptor: Bad file descriptor
user@d9-ut:~$ grep /mount /proc/mounts
/dev/fuse /home/user/mount fuse rw,nosuid,nodev,relatime,user_id=1000,group_id=1 0 0
user@d9-ut:~$ fusermount -u mount

I'm not aware of any context in which this is actually exploitable - you'd
still need the UIDs to fit, and you can't do it if the three GIDs of the
process don't match (in the case of a typical setgid binary), but it does
look like something that should be fixed.

I also plan to try to get this fixed on the kernel side.

7 years agoReleased 3.2.4 fuse-3.2.4
Nikolaus Rath [Wed, 11 Jul 2018 09:34:38 +0000 (10:34 +0100)]
Released 3.2.4

7 years agoDon't assume sub-second resolution for st_atime/st_mtime.
Nikolaus Rath [Wed, 11 Jul 2018 09:33:16 +0000 (10:33 +0100)]
Don't assume sub-second resolution for st_atime/st_mtime.

Fixes: #224
7 years agoUse triple quotes for multiline string.
Nikolaus Rath [Wed, 4 Jul 2018 18:43:23 +0000 (19:43 +0100)]
Use triple quotes for multiline string.

Single quotes will become an error in a future meson release.

7 years agoDocument that access() is also called on chdir().
Nikolaus Rath [Wed, 4 Jul 2018 18:40:20 +0000 (19:40 +0100)]
Document that access() is also called on chdir().

Source: Miklos Szeredi on fuse-devel, Wednesday, 4 July 2018 15:29.

7 years agoSource LSB init functions
Laszlo Boszormenyi (GCS) [Wed, 27 Jun 2018 15:02:07 +0000 (15:02 +0000)]
Source LSB init functions

7 years agoFix manpage filename for mount.fuse3
Laszlo Boszormenyi (GCS) [Wed, 27 Jun 2018 14:59:19 +0000 (14:59 +0000)]
Fix manpage filename for mount.fuse3

7 years agofuse.h: fix typo (currenlty -> currently)
William Woodruff [Mon, 2 Jul 2018 02:11:58 +0000 (22:11 -0400)]
fuse.h: fix typo (currenlty -> currently)

7 years agofix documentation for opendir in fuse_operations
Carl Edquist [Tue, 22 May 2018 22:04:07 +0000 (17:04 -0500)]
fix documentation for opendir in fuse_operations

the filehandle from opendir is passed to releasedir - there is no
closedir function in fuse_operations

7 years agorename: perform user mode dir loop check when not done in kernel
Bill Zissimooulos [Wed, 16 May 2018 19:36:19 +0000 (12:36 -0700)]
rename: perform user mode dir loop check when not done in kernel

    Fix conditionals as per maintainer's request.

7 years agochangelog: add info on rename deadlock fix
Bill Zissimopoulos [Wed, 16 May 2018 19:05:28 +0000 (12:05 -0700)]
changelog: add info on rename deadlock fix

7 years agorename: perform user mode dir loop check when not done in kernel
Bill Zissimooulos [Sun, 13 May 2018 01:51:44 +0000 (18:51 -0700)]
rename: perform user mode dir loop check when not done in kernel

    Linux performs the dir loop check (rename(a, a/b/c)
    or rename(a/b/c, a), etc.) in kernel. Unfortunately
    other systems do not perform this check (e.g. FreeBSD).
    This results in a deadlock in get_path2, because libfuse
    did not expect to handle such cases.

    We add a check_dir_loop function that performs the dir
    loop check in user mode and enable it on systems that
    need it.

7 years agoReleased 3.2.3 fuse-3.2.3
Nikolaus Rath [Fri, 11 May 2018 14:01:09 +0000 (15:01 +0100)]
Released 3.2.3

7 years agoadd_arg(): check for overflow
Nikolaus Rath [Fri, 11 May 2018 13:56:45 +0000 (14:56 +0100)]
add_arg(): check for overflow

Fixes: #222.
7 years agoFix compile-time warnings on IGNORE_MTAB
Tomohiro Kusumi [Tue, 8 May 2018 05:57:00 +0000 (22:57 -0700)]
Fix compile-time warnings on IGNORE_MTAB

Silence below warnings which appear if IGNORE_MTAB is defined.

[59/64] Compiling C object 'util/fusermount3@exe/fusermount.c.o'.
../util/fusermount.c:493:12: warning: function declaration isn't a prototype [-Wstrict-prototypes]
 static int count_fuse_fs()
            ^~~~~~~~~~~~~
../util/fusermount.c: In function 'unmount_fuse':
../util/fusermount.c:508:46: warning: unused parameter 'quiet' [-Wunused-parameter]
 static int unmount_fuse(const char *mnt, int quiet, int lazy)
                                              ^~~~~

7 years agoFix path to pytest cache directory.
Nikolaus Rath [Fri, 13 Apr 2018 17:28:27 +0000 (10:28 -0700)]
Fix path to pytest cache directory.

7 years agoInvert calloc(3) argument order (`nmemb` comes first)
Tomohiro Kusumi [Wed, 11 Apr 2018 16:40:13 +0000 (01:40 +0900)]
Invert calloc(3) argument order (`nmemb` comes first)

No functional difference expected, but should still follow the standard.
http://pubs.opengroup.org/onlinepubs/009695399/functions/calloc.html

7 years agoDrop unneeded void cast for actually used local variable
Tomohiro Kusumi [Wed, 11 Apr 2018 16:39:46 +0000 (01:39 +0900)]
Drop unneeded void cast for actually used local variable

`int sig` is acutually used, so `(void) sig;` is unneeded.

7 years agoDrop redundant ; from FUSE_REGISTER_MODULE()
Tomohiro Kusumi [Wed, 11 Apr 2018 16:39:27 +0000 (01:39 +0900)]
Drop redundant ; from FUSE_REGISTER_MODULE()

Callers do (and should) use ;.

7 years agoTravis: remove root-owned cache files.
Nikolaus Rath [Sat, 31 Mar 2018 12:33:05 +0000 (13:33 +0100)]
Travis: remove root-owned cache files.

7 years agoFix Travis build environment
Nikolaus Rath [Sat, 31 Mar 2018 12:21:08 +0000 (13:21 +0100)]
Fix Travis build environment

Newest Meson requires Python 3.5 which isn't available in Trusty.
Pip version pin no longer necessary.

7 years agoFixed up duplicate ChangeLog entry.
Nikolaus Rath [Sat, 31 Mar 2018 12:16:48 +0000 (13:16 +0100)]
Fixed up duplicate ChangeLog entry.

7 years agoReleased 3.2.2 fuse-3.2.2
Nikolaus Rath [Sat, 31 Mar 2018 12:08:08 +0000 (13:08 +0100)]
Released 3.2.2

7 years agoAdd example configuration file (#216)
admorgan [Wed, 28 Mar 2018 19:38:26 +0000 (14:38 -0500)]
Add example configuration file (#216)

Add a configuration file with all options disabled that includes
all valid options and their description.

7 years agoFix build error on DragonFlyBSD (sync with other *BSD) (#240)
Tomohiro Kusumi [Wed, 28 Mar 2018 19:32:59 +0000 (04:32 +0900)]
Fix build error on DragonFlyBSD (sync with other *BSD) (#240)

DragonFlyBSD has no "bsd" in uname, so add 'dragonfly' to conditionals.

-- e.g. uname(1) in DragonFlyBSD
[root@ ~]# uname
DragonFly
[root@ ~]# python -c "import sys; print(sys.platform)"
dragonfly5

7 years agoFix uninitialised read in fuse_new_30() (#231) (#234)
Ashley Pittman [Fri, 9 Feb 2018 13:42:12 +0000 (13:42 +0000)]
Fix uninitialised read in fuse_new_30() (#231) (#234)

Ensure that conf is always zero before it's read from to prevent
sporadic failure at startup if higher layers were build against
version 3.0

Signed-off-by: Ashley Pittman <ashley.m.pittman@intel.com>
7 years agoFix typo in "passthrough" docstring (#229)
Mateusz Urbańczyk [Mon, 15 Jan 2018 20:45:54 +0000 (21:45 +0100)]
Fix typo in "passthrough" docstring (#229)

7 years agoHandle mount ... -o nofail (#221)
Josh Soref [Fri, 1 Dec 2017 19:18:49 +0000 (14:18 -0500)]
Handle mount ... -o nofail (#221)

Accept (and ignore) nofail mount option

7 years agofix "Rath Consulting" link (#225)
divinity76 [Mon, 27 Nov 2017 19:53:09 +0000 (20:53 +0100)]
fix "Rath Consulting" link (#225)

7 years agoSpelling (#223)
Josh Soref [Mon, 27 Nov 2017 10:23:20 +0000 (05:23 -0500)]
Spelling (#223)

Fix spelling errors

7 years agoReleased 3.2.1 fuse-3.2.1
Nikolaus Rath [Tue, 14 Nov 2017 20:48:15 +0000 (20:48 +0000)]
Released 3.2.1

7 years agoUpdated professional support information.
Nikolaus Rath [Mon, 13 Nov 2017 20:10:13 +0000 (20:10 +0000)]
Updated professional support information.

7 years agoBacked out d92bf83
Nikolaus Rath [Fri, 3 Nov 2017 10:51:06 +0000 (10:51 +0000)]
Backed out d92bf83

This change is bogus. fuse_module_factory_t is already a pointer
type. Additionally, if dlsym returns NULL, then you will be
dereferencing it causing a segfault. In my testing, a segfault will
happen even if dlsym returns successfully.

Thanks to Michael Theall for spotting!

8 years agoDon't install manpages under *BSD
Nikolaus Rath [Fri, 20 Oct 2017 08:20:39 +0000 (09:20 +0100)]
Don't install manpages under *BSD

Were not installing the corresponding binaries either, since those
are provided by the BSD base system.

8 years agoDon't use Python mode for meson.build
Nikolaus Rath [Fri, 20 Oct 2017 08:19:16 +0000 (09:19 +0100)]
Don't use Python mode for meson.build

Emacs now has a proper meson mode :-).

8 years agomake udevrulesdir configurable
Joerg Thalheim [Thu, 19 Oct 2017 12:09:06 +0000 (13:09 +0100)]
make udevrulesdir configurable

on nixos we install fuse in its own hierarchy independent from systemd.

8 years agoAdding pointer dereferencing after calling dlsym()
Sangwoo Moon [Wed, 27 Sep 2017 07:25:15 +0000 (16:25 +0900)]
Adding pointer dereferencing after calling dlsym()
dlsym() resolves the location of the loaded symbol,
therefore dlsym() returns the type (fuse_module_factory_t *), not (fuse_module_factory_t).
Added pinter dereferencing to correctly refer the factory function.

8 years agofuse_lib_ioctl(): don't call memcpy with NULL argument
Nikolaus Rath [Mon, 25 Sep 2017 09:34:07 +0000 (10:34 +0100)]
fuse_lib_ioctl(): don't call memcpy with NULL argument

This was detected by using clang's undefined behavior sanitizer, but
didn't seem to cause problems in practice.

8 years agoLink with -lrt to support ancient libc
Nikolaus Rath [Mon, 25 Sep 2017 09:23:38 +0000 (10:23 +0100)]
Link with -lrt to support ancient libc

Fixes: #207.
8 years agoRemoved unneccessary #include <config.h> from examples
Nikolaus Rath [Mon, 25 Sep 2017 09:17:11 +0000 (10:17 +0100)]
Removed unneccessary #include <config.h> from examples

Fixes: #208.
8 years agoAutomatically print list of contributors when generating tarball
Nikolaus Rath [Wed, 20 Sep 2017 17:17:49 +0000 (18:17 +0100)]
Automatically print list of contributors when generating tarball

8 years agoTravis CI: Don't use deprecated environment
Nikolaus Rath [Wed, 20 Sep 2017 11:38:35 +0000 (12:38 +0100)]
Travis CI: Don't use deprecated environment

Travis support recommends to install specific pip
version to work around problems in new environment.

8 years agoCorrectly define fusermount3 path.
Nikolaus Rath [Tue, 19 Sep 2017 19:37:46 +0000 (20:37 +0100)]
Correctly define fusermount3 path.

8 years agoMake *_loop_mt() available in version 3.0 again
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.

8 years agoFix versioned symbols in version script
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.

8 years agoDon't use external symbol names in internal files
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.

8 years agoInclude source code in documentation.
Nikolaus Rath [Sun, 17 Sep 2017 08:39:47 +0000 (09:39 +0100)]
Include source code in documentation.

8 years agomake_release_tarball.sh: be less verbose
Nikolaus Rath [Sun, 17 Sep 2017 08:35:52 +0000 (09:35 +0100)]
make_release_tarball.sh: be less verbose

8 years agoAdded some documentation of fuse internals.
Nikolaus Rath [Sun, 17 Sep 2017 08:35:43 +0000 (09:35 +0100)]
Added some documentation of fuse internals.

8 years agoReleased 3.2.0 fuse-3.2.0
Nikolaus Rath [Tue, 12 Sep 2017 13:03:31 +0000 (14:03 +0100)]
Released 3.2.0

8 years agoAdd script to create release tarball.
Nikolaus Rath [Tue, 12 Sep 2017 13:46:00 +0000 (14:46 +0100)]
Add script to create release tarball.

8 years agoUse "mkdir" instead of "md" in instructions.
Nikolaus Rath [Tue, 12 Sep 2017 13:01:04 +0000 (14:01 +0100)]
Use "mkdir" instead of "md" in instructions.

Fixes: #205.
8 years agofuse_kern_unmount(): close fd before calling umount
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.

8 years agoexample/ioctl: build on FreeBSD, but add protocol check instead.
Nikolaus Rath [Fri, 25 Aug 2017 08:48:09 +0000 (10:48 +0200)]
example/ioctl: build on FreeBSD, but add protocol check instead.

8 years agodo_init(): print missing capabilities if there are any.
Nikolaus Rath [Fri, 25 Aug 2017 08:38:43 +0000 (10:38 +0200)]
do_init(): print missing capabilities if there are any.

8 years agoFix writeback capability check.
Nikolaus Rath [Fri, 25 Aug 2017 07:49:23 +0000 (09:49 +0200)]
Fix writeback capability check.

8 years agoexamples/{ioctl,null}: don't build under FreeBSD instead of skipping tests.
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.

8 years agoprintcap: use temporary directory, not file
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.

8 years agoSkip testing null and ioctl examples 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.

8 years agoRemoved unused import.
Nikolaus Rath [Thu, 24 Aug 2017 19:50:23 +0000 (21:50 +0200)]
Removed unused import.

8 years agopassthrough_ll: only active EXPORT_SUPPORT of supported by kernel.
Nikolaus Rath [Thu, 24 Aug 2017 19:08:25 +0000 (21:08 +0200)]
passthrough_ll: only active EXPORT_SUPPORT of supported by kernel.

8 years agoDon't use -o auto_unmount under FreeBSD.
Nikolaus Rath [Thu, 24 Aug 2017 15:09:41 +0000 (17:09 +0200)]
Don't use -o auto_unmount under FreeBSD.

8 years agoDropped support for building with autotools
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.

8 years agoUse printcap() to control test execution
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.

8 years agoAdded testcase for examples/printcap
Nikolaus Rath [Thu, 24 Aug 2017 14:51:34 +0000 (16:51 +0200)]
Added testcase for examples/printcap

8 years agoAdd idle_threads mount option.
Joseph Dodge [Thu, 24 Aug 2017 12:37:10 +0000 (14:37 +0200)]
Add idle_threads mount option.

8 years agoRenamed notify_inval_inode_fh to invalidate_path
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.

8 years agoAllow inode cache invalidation in high-level API
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.

8 years agoAdded examples/printcap
Nikolaus Rath [Wed, 23 Aug 2017 21:39:27 +0000 (23:39 +0200)]
Added examples/printcap

8 years agofuse_loop_mt(): on error, return errno rather than -1.
Nikolaus Rath [Wed, 23 Aug 2017 21:37:40 +0000 (23:37 +0200)]
fuse_loop_mt(): on error, return errno rather than -1.

8 years agofuse_loop(): don't return non-zero if there was no error
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

8 years agoDocument and unify error codes of fuse_lowlevel_notify_*
Nikolaus Rath [Tue, 22 Aug 2017 15:05:26 +0000 (17:05 +0200)]
Document and unify error codes of fuse_lowlevel_notify_*

8 years agoMake passthrough_fh work under FreeBSD.
Nikolaus Rath [Tue, 22 Aug 2017 11:46:14 +0000 (13:46 +0200)]
Make passthrough_fh work under FreeBSD.

8 years agoFix two compiler warnings.
Nikolaus Rath [Tue, 22 Aug 2017 11:50:14 +0000 (13:50 +0200)]
Fix two compiler warnings.

8 years agoDocument meaning of zero telldir() offset.
Nikolaus Rath [Tue, 22 Aug 2017 11:45:41 +0000 (13:45 +0200)]
Document meaning of zero telldir() offset.

8 years agoAllow building without iconv.
Nikolaus Rath [Tue, 22 Aug 2017 10:10:50 +0000 (12:10 +0200)]
Allow building without iconv.

cfg.has('HAVE_ICONV') was always true.

8 years agoUse 'buildtype' to set debug/optimization options
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.

8 years agodirectly call fuse_new_31() instead of fuse_new() internally
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

8 years agoFixed udev rules directory.
Nikolaus Rath [Mon, 14 Aug 2017 08:26:51 +0000 (10:26 +0200)]
Fixed udev rules directory.

8 years agoSkip tests that aren't supported under FreeBSD.
Nikolaus Rath [Fri, 11 Aug 2017 18:15:27 +0000 (20:15 +0200)]
Skip tests that aren't supported under FreeBSD.

8 years agofuse_lib_init(): don't set FUSE_CAP_EXPORT_SUPPORT unconditionally
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.

8 years agoDon't attempt to run fusermount3 under BSD.
Nikolaus Rath [Fri, 11 Aug 2017 08:53:56 +0000 (10:53 +0200)]
Don't attempt to run fusermount3 under BSD.

8 years agoCall cp with -p instead of --preserve=mode
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.

8 years agoDon't pass --update to cp
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.

8 years agoDon't build passthrough_ll under BSD.
Nikolaus Rath [Fri, 11 Aug 2017 08:41:58 +0000 (10:41 +0200)]
Don't build passthrough_ll under BSD.

8 years agofuse_kern_unmount(): fix variable type.
Nikolaus Rath [Fri, 11 Aug 2017 08:31:24 +0000 (10:31 +0200)]
fuse_kern_unmount(): fix variable type.

8 years agoFix unused variable warnings under FreeBSD.
Nikolaus Rath [Fri, 11 Aug 2017 08:26:28 +0000 (10:26 +0200)]
Fix unused variable warnings under FreeBSD.

8 years agoFix FreeBSD platform detection.
Nikolaus Rath [Tue, 8 Aug 2017 13:40:09 +0000 (15:40 +0200)]
Fix FreeBSD platform detection.

8 years agoFix support for FUSE_POSIX_ACL
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>
8 years agoReleased 3.1.1 fuse-3.1.1
Nikolaus Rath [Sun, 6 Aug 2017 11:24:40 +0000 (13:24 +0200)]
Released 3.1.1

8 years agoos_open(): don't attempt to close fd if open failed.
Nikolaus Rath [Sun, 6 Aug 2017 11:24:20 +0000 (13:24 +0200)]
os_open(): don't attempt to close fd if open failed.

8 years agoAdded writeback cache to passthrough_ll
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.
8 years agoClarified documentation for fuse_parse_cmdline()
Nikolaus Rath [Fri, 4 Aug 2017 20:38:29 +0000 (22:38 +0200)]
Clarified documentation for fuse_parse_cmdline()

8 years agoRemoved compat stuff in passthrough_ll
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.