qemu-gpiodev/libfuse.git
3 years agoMerge pull request #649 from fdinoff/fix_clone_fd
Nikolaus Rath [Tue, 22 Mar 2022 08:46:33 +0000 (08:46 +0000)]
Merge pull request #649 from fdinoff/fix_clone_fd

Fix fd leak with clone_fd

3 years agoFix fd leak with clone_fd
Frank Dinoff [Mon, 21 Mar 2022 17:13:21 +0000 (13:13 -0400)]
Fix fd leak with clone_fd

do_interrupt would destroy_req on the request without decrementing the
channel's refcount. With clone_fd this could leak file descriptors if
the worker thread holding the cloned fd was destroyed. (Only
max_idle_threads are kept).

3 years agoMerge pull request #635 from amir73il/fopen_noflush
Nikolaus Rath [Mon, 14 Mar 2022 09:48:43 +0000 (09:48 +0000)]
Merge pull request #635 from amir73il/fopen_noflush

Add support for FOPEN_NOFLUSH flag

3 years agoMerge branch 'master' into fopen_noflush
Nikolaus Rath [Mon, 14 Mar 2022 09:25:00 +0000 (09:25 +0000)]
Merge branch 'master' into fopen_noflush

3 years agoRemoved duplicates code. (#642)
David Galeano [Fri, 11 Feb 2022 20:07:00 +0000 (20:07 +0000)]
Removed duplicates code. (#642)

The cap for FUSE_CAP_WRITEBACK_CACHE was printed twice.

3 years agoFixed returning an error condition to ioctl(2) (#641)
Jean-Pierre André [Wed, 9 Feb 2022 14:59:10 +0000 (15:59 +0100)]
Fixed returning an error condition to ioctl(2) (#641)

When returning a negative error code by ->ioctl() to the high level
interface, no error is propagated to the low level, and the reply
message to the kernel is shown as successful.

A negative result is however returned to kernel, so the kernel can
detect the bad condition, but this appears to not be the case since
kernel 5.15.

The proposed fix is more in line with the usual processing of errors
in fuse, taking into account that ioctl(2) always returns a non-negative
value in the absence of errors.

Co-authored-by: Jean-Pierre André <jpandre@users.sourceforge.net>
3 years agoFix ReST end-string nits (#638)
Andrew Gaul [Sun, 23 Jan 2022 10:17:03 +0000 (19:17 +0900)]
Fix ReST end-string nits (#638)

This makes the file more readable with syntax highlighting.

3 years agoAvoid ENOENT response when recently invalidated fuse_ino_t is received from the kerne...
Ken Schalk [Tue, 11 Jan 2022 19:56:36 +0000 (14:56 -0500)]
Avoid ENOENT response when recently invalidated fuse_ino_t is received from the kernel (#636)

3 years agoAdd test for FOPEN_NOFLUSH flag
Amir Goldstein [Mon, 3 Jan 2022 08:49:46 +0000 (10:49 +0200)]
Add test for FOPEN_NOFLUSH flag

Simulate write() delay and verify that close(rofd) does not
block waiting on pending writes.

The support for the flag was added in kernel v5.16-rc1.

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
3 years agoAdd no_rofd_flush mount option
Amir Goldstein [Sun, 5 Dec 2021 16:29:05 +0000 (18:29 +0200)]
Add no_rofd_flush mount option

To disable flush for read-only fd.

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
3 years agoAdd support for FOPEN_NOFLUSH flag
Amir Goldstein [Sun, 24 Oct 2021 11:01:23 +0000 (14:01 +0300)]
Add support for FOPEN_NOFLUSH flag

Allow requesting from kernel to avoid flush on close at file open
time.  If kernel does not support FOPEN_NOFLUSH flag, the request
will be ignored.

For passthrough_hp example, request to avoid flush on close when
writeback cache is disabled and file is opened O_RDONLY.

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
3 years agoDocument possible NULL paths when directories are removed (#633)
Maximilian Heinzler [Sun, 12 Dec 2021 16:28:57 +0000 (17:28 +0100)]
Document possible NULL paths when directories are removed (#633)

When directories with open handles are removed, the releasedir and
fsyncdir operations might be called with a NULL path. That is because
there is no hiding behavior like for regular files and the nodes get
removed immediately.

3 years agotest/test_syscalls.c: allow EBADF in fcheck_stat() (#631)
Luis Henriques [Sat, 20 Nov 2021 10:09:25 +0000 (10:09 +0000)]
test/test_syscalls.c: allow EBADF in fcheck_stat() (#631)

Test test/test_examples.py::test_passthrough_hp[False] fails because, on
kernels >= 5.14, fstat() will return -EBADF:

3 [check_unlinked_testfile] fcheck_stat() - fstat: Bad file descriptor
4 [check_unlinked_testfile] fcheck_stat() - fstat: Bad file descriptor
5 [check_unlinked_testfile] fcheck_stat() - fstat: Bad file descriptor
9 [check_unlinked_testfile] fcheck_stat() - fstat: Bad file descriptor
...

This patch simply whitelists the EBADF errno code.

Signed-off-by: Luís Henriques <lhenriques@suse.de>
Co-authored-by: Luís Henriques <lhenriques@suse.de>
4 years agoReleased 3.10.5 fuse-3.10.5
Nikolaus Rath [Mon, 6 Sep 2021 12:45:26 +0000 (13:45 +0100)]
Released 3.10.5

4 years agoFix: fd and memory leak in mount.fuse.c (#614)
lixiaokeng [Mon, 6 Sep 2021 12:37:45 +0000 (20:37 +0800)]
Fix: fd and memory leak in mount.fuse.c (#614)

The command isn't freed and the fuse_fd isn't
closed if execl failed. Fix it.

Signed-off-by: Lixiaokeng <lixiaokeng@huawei.com>
4 years agouse same hashbang as in rest of repository
a1346054 [Fri, 20 Aug 2021 17:50:14 +0000 (17:50 +0000)]
use same hashbang as in rest of repository

4 years agofix spelling
a1346054 [Fri, 20 Aug 2021 17:49:29 +0000 (17:49 +0000)]
fix spelling

4 years agoremove executable file mode bit from source files
a1346054 [Fri, 20 Aug 2021 17:47:43 +0000 (17:47 +0000)]
remove executable file mode bit from source files

4 years agomeson.build: fix wrong .symver detection
Giulio Benetti [Tue, 3 Aug 2021 21:39:46 +0000 (23:39 +0200)]
meson.build: fix wrong .symver detection

As pointed here [1] __has_attribute() is broken for many attributes and
if it doesn't support the specific attribute it returns true, so we
can't really rely on that for this check. This lead to Buildroot
libfuse3 build failure [2] where that shows up with:
```
error: symver is only supported on ELF platforms
```
Indeed Microblaze doesn't support ELF since it doesn't include elfos.h,
but __has_attribute(symver) returns true.

So let's substitute the #ifdef __has_attribute() with a stronger test on
a function foo() with __attribute__((symver ("test@TEST"))).

[1]: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=101766
[2]: http://autobuild.buildroot.net/results/d6c/d6cfaf2aafaeda3c12d127f6a2d2e175b25e654f/build-end.log

Signed-off-by: Giulio Benetti <giulio.benetti@benettiengineering.com>
4 years agoTravis-CI: Make sure lsan supppressions file can be read by root.
Nikolaus Rath [Thu, 24 Jun 2021 08:11:29 +0000 (09:11 +0100)]
Travis-CI: Make sure lsan supppressions file can be read by root.

4 years agoDo not run unlinked files test on passthrough_hp with old kernels
Amir Goldstein [Tue, 22 Jun 2021 11:03:22 +0000 (14:03 +0300)]
Do not run unlinked files test on passthrough_hp with old kernels

test_syscalls unlinked testfiles check fails on passthourhg_hp without
the kernel commit "fuse: fix illegal access to inode with reused nodeid"
queued for kernel 5.14 [1].

Make this check opt-in and do not run it with kernel version before 5.14.

[1] https://lore.kernel.org/linux-fsdevel/CAJfpegtGKjeK8E5QsHKF0=re1J9wVHuGRVgg9NDJ_OOwQdCUNg@mail.gmail.com/

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
4 years agoFix: a potential crash on failure to setlocale
lixiaokeng [Wed, 16 Jun 2021 08:57:16 +0000 (16:57 +0800)]
Fix: a potential crash on failure to setlocale

setlocale() can fail, returning NULL, which will lead
to a crash in iconv_new(). Fix it like in iconv_help().

Signed-off-by: Lixiaokeng <lixiaokeng@huawei.com>
4 years agopassthrough_hp: excercise reusing inode numbers
Amir Goldstein [Sat, 12 Jun 2021 14:37:13 +0000 (17:37 +0300)]
passthrough_hp: excercise reusing inode numbers

Before last unlink() release the reference on inode.fd to allow reuse
of underlying fs inode number, mark the server inode "deleted" and bump
it's generation counter.

When same inode number is found on lookup(), the server inode object will
be reused as well.

Skip this when inode has an open file and when writeback cache is enabled.

This will be used to verify inode reuse bug fix in the kernel.

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
4 years agotest/test_syscalls.c: check unlinked testfiles at the end of the test
Amir Goldstein [Wed, 9 Jun 2021 16:32:46 +0000 (19:32 +0300)]
test/test_syscalls.c: check unlinked testfiles at the end of the test

On some tests on regular files, open an O_PATH fd of the testfile and
record it along side the size and mode and inode.

At the end of all tests, use recorded testfiles info to re-check the size
mode and inode of the unlinked testfiles.

With O_PATH fd, the server does not have to keep the inode alive so FUSE
inode may be stale or bad.  Therefore, ESTALE and EIO are valid results
for fstat() on the old testfile fd's, but returning the wrong size or
mode is an invalid result.

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
4 years agotest/test_syscalls.c: refactor fcheck_* helpers
Amir Goldstein [Wed, 9 Jun 2021 16:04:29 +0000 (19:04 +0300)]
test/test_syscalls.c: refactor fcheck_* helpers

Avoid multiple fstat() calls and consolidate all fcheck_* helpers
into fcheck_stat().

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
4 years agotest/test_syscalls.c: use unique filename per test
Amir Goldstein [Wed, 9 Jun 2021 10:34:17 +0000 (13:34 +0300)]
test/test_syscalls.c: use unique filename per test

Generate unique filename per test (only for regular file for now).
Make sure to unlink the unique filename after each test.

realpath variable was renamed to basepath_r to fix build warning
on conflicting symbols with realpath() function.

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
4 years agoReleased 3.10.4 fuse-3.10.4
Nikolaus Rath [Wed, 9 Jun 2021 08:13:01 +0000 (09:13 +0100)]
Released 3.10.4

4 years agoAdd an option to disable building tests (#533)
asafkahlon [Wed, 9 Jun 2021 08:07:25 +0000 (11:07 +0300)]
Add an option to disable building tests (#533)

Signed-off-by: Asaf Kahlon <asafka7@gmail.com>
4 years agoCuse example: Fix memory leak (#607)
Christian Menges [Wed, 9 Jun 2021 08:04:41 +0000 (10:04 +0200)]
Cuse example: Fix memory leak (#607)

* cuse example: fix memory leak

* Travis CI: re-enable leak checking

4 years agofix typo in man (#609)
Sergey Fedoseev [Wed, 9 Jun 2021 08:04:08 +0000 (13:04 +0500)]
fix typo in man (#609)

4 years agotest/test_syscalls.c: fix test failure on xfs src dir (#611)
Amir Goldstein [Wed, 2 Jun 2021 09:23:06 +0000 (12:23 +0300)]
test/test_syscalls.c: fix test failure on xfs src dir (#611)

rename dir loop test fails when test tmp dir is xfs with an error
 test_rename_dir_loop() - rename : File exists

That is because xfs returns EEXIST for the case of renaming over
a non-empty directory.

According to rename(2) man page, EEXIST and ENOTEMPTY are both valid
error code in this case.

Signed-off-by: Amir Goldstein <amir73il@gmail.com>
4 years agoDefine FUSE_USE_VERSION in Doxygen. (#608)
Junichi Uekawa [Wed, 19 May 2021 08:32:14 +0000 (17:32 +0900)]
Define FUSE_USE_VERSION in Doxygen. (#608)

We currently do not pass anything in PREDEFINED and that means
FUSE_USE_VERSION is undefined.

Add that definition so that Doxygen built-in C pre-processor can use
FUSE_USE_VERSION value to find the correct comment to parse.

4 years agoFix memory leaks in examples (#604)
Christian Menges [Sun, 9 May 2021 10:12:01 +0000 (12:12 +0200)]
Fix memory leaks in examples (#604)

4 years agoBump cxxopts from 2.2.0 to 2.2.1 (#602)
Christian Menges [Sun, 9 May 2021 09:00:57 +0000 (11:00 +0200)]
Bump cxxopts from 2.2.0 to 2.2.1 (#602)

4 years agodoc: Add "fuse (4)" to SEE ALSO sections in man pages (#601)
rfjakob [Sat, 8 May 2021 13:15:55 +0000 (15:15 +0200)]
doc: Add "fuse (4)" to SEE ALSO sections in man pages (#601)

fuse (4) is an excellent introduction to the FUSE protocol,
and it lists fusermount (1) and mount.fuse (8) in its
SEE ALSO section.

I (the author of gocryptfs) was not aware of this man
page till March 2021, which suggest that it should be
made more discoverable.

So link back to fuse (4) in our SEE ALSO sections.

4 years agoFix doxygen warnings. (#600)
Junichi Uekawa [Fri, 7 May 2021 09:43:30 +0000 (18:43 +0900)]
Fix doxygen warnings. (#600)

Some parameters were undocumented, and @file does not mean to expand current file name.

4 years agofusermount3.1: refer to mount.fuse3 (#599)
Junichi Uekawa [Wed, 5 May 2021 09:51:08 +0000 (18:51 +0900)]
fusermount3.1: refer to mount.fuse3 (#599)

mount.fuse was renamed to mount.fuse3.

4 years agoAdd missing exceptions to fuse_reply_err() documentation. (#597)
Manuel Jacob [Fri, 23 Apr 2021 07:31:37 +0000 (09:31 +0200)]
Add missing exceptions to fuse_reply_err() documentation. (#597)

Co-authored-by: Manuel Jacob <test>
4 years agoFix a few meson warnings (#596)
Heiko Becker [Tue, 13 Apr 2021 17:54:10 +0000 (19:54 +0200)]
Fix a few meson warnings (#596)

* Use meson's warning_level instead of passing -Wflags

"-Wall" is included by default and level 2 adds "-Wextra". Avoids a
warning from meson.

Signed-off-by: Heiko Becker <heirecka@exherbo.org>
* Set the C++ language standard through a meson option

Avoids a warning from meson.

Signed-off-by: Heiko Becker <heirecka@exherbo.org>
4 years agoAdded ChangeLog template for next release.
Nikolaus Rath [Mon, 12 Apr 2021 10:21:11 +0000 (11:21 +0100)]
Added ChangeLog template for next release.

4 years agoReleased 3.10.3 fuse-3.10.3
Nikolaus Rath [Mon, 12 Apr 2021 10:18:08 +0000 (11:18 +0100)]
Released 3.10.3

4 years agoRemove unused fuse_worker bufsize (#590)
Hookey [Mon, 12 Apr 2021 10:08:50 +0000 (18:08 +0800)]
Remove unused fuse_worker bufsize (#590)

Not used since https://github.com/libfuse/libfuse/commit/561d7054d856eea6c2d634093546d6af773dada9

4 years agoFix typo in fuse_lowlevel.h (#593)
Tobias Nießen [Tue, 30 Mar 2021 12:37:30 +0000 (14:37 +0200)]
Fix typo in fuse_lowlevel.h (#593)

4 years agoFix typos (#592)
Andrew Gaul [Thu, 25 Mar 2021 08:40:27 +0000 (17:40 +0900)]
Fix typos (#592)

4 years agoFix returning d_ino and d_type by readdir(3) in non-plus mode
Jean-Pierre André [Thu, 18 Mar 2021 09:52:30 +0000 (10:52 +0100)]
Fix returning d_ino and d_type by readdir(3) in non-plus mode

When not using the readdir_plus mode, the d_type was not returned,
and the use_ino flag was not used for returning d_ino.

This patch fixes the returned values for d_ino and d_type by readdir(3)

The test for the returned value of d_ino has been adjusted to also
take the d_type into consideration and to check the returned values in
both basic readdir and readdir_plus modes. This is done by executing
the passthrough test twice.

Co-authored-by: Jean-Pierre André <jpandre@users.sourceforge.net>
4 years agoReleased 3.10.2 fuse-3.10.2
Nikolaus Rath [Fri, 5 Feb 2021 09:07:28 +0000 (09:07 +0000)]
Released 3.10.2

4 years agoFix returning inode numbers from readdir() in offset==0 mode. (#584)
Martin Pärtel [Wed, 3 Feb 2021 09:53:21 +0000 (11:53 +0200)]
Fix returning inode numbers from readdir() in offset==0 mode. (#584)

- Test added for all passthrough examples.
- passthrough.c uses offset==0 mode. The others don't.
- passthrough.c changed to set FUSE_FILL_DIR_PLUS to make the test pass.
- This fixes #583.

4 years agoIgnore "-o nonempty" (#582)
Stephen Kitt [Thu, 28 Jan 2021 21:51:10 +0000 (22:51 +0100)]
Ignore "-o nonempty" (#582)

Commit 0bef21e8543d removed "-o nonempty" since mounting over
non-empty directories is always allowed. But this broke tools which
specify "-o nonempty". Since the expected behaviour is the same
anyway, ignoring the "nonempty" option seems safe, and allows programs
specifying "-o nonempty" to continue working with fusermount3.

This would fix https://bugs.debian.org/939767

Signed-off-by: Stephen Kitt <steve@sk2.org>
4 years agoFix FTBFS on kfreebsd (#581)
Laurent Bigonville [Sun, 17 Jan 2021 10:49:07 +0000 (11:49 +0100)]
Fix FTBFS on kfreebsd (#581)

kfreebsd is a FreeBSD kernel and a GNU libc

The only macro defined in that case is __FreeBSD_kernel__

Fix #580

4 years agoFix a few typos in README.md. (#579)
John Baber-Lucero [Tue, 12 Jan 2021 10:41:35 +0000 (05:41 -0500)]
Fix a few typos in README.md. (#579)

* Fix a few typos in README.md.

* Change recommendation to mandate for meson and ninja

Co-authored-by: John Baber-Lucero <git@frundle.com>
4 years agoFix typo (#578)
Feverfew [Sun, 10 Jan 2021 11:50:28 +0000 (11:50 +0000)]
Fix typo (#578)

4 years agofusermount: Check for argv[0] being present (#577)
richardweinberger [Fri, 8 Jan 2021 10:07:02 +0000 (11:07 +0100)]
fusermount: Check for argv[0] being present (#577)

It is perfectly legal to execute a program with argc == 0 and therefore
no argv.
fusermount needs to check for this case, otherwise it will pass a NULL
poiunter to strdup() and cause undefined behavior.
Especially since fusermount is setuid root, we need to extra be careful.

Signed-off-by: Richard Weinberger <richard@nod.at>
4 years agoFix FUSE_COPY_FILE_RANGE in the passthrough example (#575)
Alan Somers [Fri, 1 Jan 2021 19:34:58 +0000 (12:34 -0700)]
Fix FUSE_COPY_FILE_RANGE in the passthrough example (#575)

Only close the file descriptors if they were just opened.  Otherwise,
the second FUSE_COPY_FILE_RANGE operation on any given file will fail
with EBADF.

4 years agoutil/fusermount.c: Assume the kernel supports UMOUNT_NOFOLLOW (#574)
Sargun Dhillon [Sun, 27 Dec 2020 11:17:46 +0000 (03:17 -0800)]
util/fusermount.c: Assume the kernel supports UMOUNT_NOFOLLOW (#574)

UMOUNT_NOFOLLOW was added in Kernel 2.6.34. It's been 10 years since it's been added
Kernel 5.9, and 5.10 break this check mechanism[1]. Let's deprecate it.

[1]: https://lore.kernel.org/linux-fsdevel/20201223102604.2078-1-sargun@sargun.me/

Signed-off-by: Sargun Dhillon <sargun@sargun.me>
4 years agoAdd exfat to whitelist (#573)
Kangjing "Chaser" Huang [Sat, 19 Dec 2020 10:43:19 +0000 (05:43 -0500)]
Add exfat to whitelist (#573)

4 years agoReleased 3.10.1 fuse-3.10.1
Nikolaus Rath [Mon, 7 Dec 2020 09:52:02 +0000 (09:52 +0000)]
Released 3.10.1

4 years agoexamples/cuse_client: add include file to eliminate compiler warning (#568)
Rethan [Tue, 24 Nov 2020 09:28:13 +0000 (17:28 +0800)]
examples/cuse_client: add include file to eliminate compiler warning (#568)

Compiler warning about close(fd), add include file to fix.

Signed-off-by: haoyixing <haoyixing@kuaishou.com>
Co-authored-by: haoyixing <haoyixing@kuaishou.com>
4 years agofix errno comparison
human [Mon, 16 Nov 2020 17:11:09 +0000 (19:11 +0200)]
fix errno comparison

this affected `-o remember` in single-thread mode, it could prematurely
exit if a signal was received

 # start an example filesystem from example/
 ./passthrough -f -s -o remember=5 ./mnt

 # make the poll() call return with EINTR
 pkill -PIPE passthrough

4 years agobuffer.c: correct return value when buf is NULL
Zhiqiang Liu [Wed, 11 Nov 2020 02:00:23 +0000 (10:00 +0800)]
buffer.c: correct return value when buf is NULL

In commit d614415a ("buffer.c: check whether buf is
NULL in fuse_bufvec_advance func"), if fuse_bufvec_current
func returns NULL, it returns 1 directly. Actually,
we should return 0 when buf is NULL.

Fixes: d614415a ("buffer.c: check whether buf is NULL in fuse_bufvec_advance func")
Signed-off-by: Zhiqiang Liu <liuzhiqiang26@huawei.com>
Signed-off-by: Haotian Li <lihaotian9@huawei.com>
4 years agotest/test_syscalls.c: fix potential fd leakage problems
Zhiqiang Liu [Thu, 5 Nov 2020 10:26:18 +0000 (18:26 +0800)]
test/test_syscalls.c: fix potential fd leakage problems

In test_syscalls.c, several funcs have potential fd leakage
problems. This patch will fix them.

Signed-off-by: Zhiqiang Liu <liuzhiqiang26@huawei.com>
Signed-off-by: Haotian Li <lihaotian9@huawei.com>
4 years agoexample/cuse_client.c: fix fd leakage problem
Zhiqiang Liu [Thu, 5 Nov 2020 10:16:58 +0000 (18:16 +0800)]
example/cuse_client.c: fix fd leakage problem

In cuse_client.c, fd should be closed before return.
Otherwise, it will cause fd leakage problem.

Signed-off-by: Zhiqiang Liu <liuzhiqiang26@huawei.com>
Signed-off-by: Haotian Li <lihaotian9@huawei.com>
4 years agoioctl_client.c: fix potential fd leakage problem
Zhiqiang Liu [Thu, 5 Nov 2020 10:00:32 +0000 (18:00 +0800)]
ioctl_client.c: fix potential fd leakage problem

In ioctl_client.c, fd is not closed before return, thus
it will cause fd leakage problem.

Signed-off-by: Zhiqiang Liu <liuzhiqiang26@huawei.com>
Signed-off-by: Haotian Li <lihaotian9@huawei.com>
4 years agomount.fuse.c: fix potential memory leak in main func
Zhiqiang Liu [Thu, 5 Nov 2020 09:24:12 +0000 (17:24 +0800)]
mount.fuse.c: fix potential memory leak in main func

In mount.fuse.c, there are several memory leak problems in
main func. For example, setuid_name is allocated by calling
xstrdup func, however it is not freed before calling execl func.

Signed-off-by: Zhiqiang Liu <liuzhiqiang26@huawei.com>
Signed-off-by: Haotian Li <lihaotian9@huawei.com>
4 years agomount.fuse.c: fix potential accessing NULL pointer
Zhiqiang Liu [Thu, 5 Nov 2020 08:39:52 +0000 (16:39 +0800)]
mount.fuse.c: fix potential accessing NULL pointer

In mount.fuse.c, pwd is set by calling getpwnam func.
If the matching entry is not found or an error occurs in
getpwnam func, pwd will be NULL. So we need to check
whether pwd is NULL before accessing it.

Signed-off-by: Zhiqiang Liu <liuzhiqiang26@huawei.com>
Signed-off-by: Haotian Li <lihaotian9@huawei.com>
4 years agobuffer.c: check whether buf is NULL in fuse_bufvec_advance func
Zhiqiang Liu [Thu, 5 Nov 2020 08:33:22 +0000 (16:33 +0800)]
buffer.c: check whether buf is NULL in fuse_bufvec_advance func

In fuse_bufvec_advance func, calling fuse_bufvec_current func
may return NULL, so we should check whether buf is NULL before
using it.

Signed-off-by: Zhiqiang Liu <liuzhiqiang26@huawei.com>
Signed-off-by: Haotian Liu <lihaotian9@huawei.com>
4 years agoFix incorrect date in Changelog
Lilo Huang [Wed, 4 Nov 2020 18:32:54 +0000 (02:32 +0800)]
Fix incorrect date in Changelog

It should be 2020 rather than 2010. Thanks.

4 years agoremove fuse_mutex_init
Rosen Penev [Thu, 29 Oct 2020 02:25:38 +0000 (19:25 -0700)]
remove fuse_mutex_init

This seems to have been added before 2006 to fix a uclibc bug. It
doesn't seem to be the case anymore so just get rid of it.

Signed-off-by: Rosen Penev <rosenp@gmail.com>
4 years agoremove old uclibc hack
Rosen Penev [Thu, 29 Oct 2020 02:20:35 +0000 (19:20 -0700)]
remove old uclibc hack

This actually prevents sshfs linking to it as fuse_new becomes
unavailable.

According to the git history, this seems to predate 2006.

Signed-off-by: Rosen Penev <rosenp@gmail.com>
5 years agoReleased 3.10.0 fuse-3.10.0
Nikolaus Rath [Fri, 9 Oct 2020 09:47:25 +0000 (10:47 +0100)]
Released 3.10.0

5 years agoFix typo "retuned" -> "returned" (#553)
ferivoz [Sat, 3 Oct 2020 12:14:00 +0000 (12:14 +0000)]
Fix typo "retuned" -> "returned" (#553)

5 years agoAllow caching symlinks in kernel page cache. (#551)
Etienne Dublé [Sun, 20 Sep 2020 18:08:15 +0000 (20:08 +0200)]
Allow caching symlinks in kernel page cache. (#551)

This commit defines a new capability called `FUSE_CAP_CACHE_SYMLINKS`.
It is off by default but you can now enable it by setting this flag in
in the `want` field of the `fuse_conn_info` structure.

When enabled, the kernel will save symlinks in its page cache,
by making use of the feature introduced in kernel 4.20:
https://github.com/torvalds/linux/commit/5571f1e65486be025f73fa6aa30fb03725d362a2

5 years agoFix compilation for compilers not supporting __has_attribute
Tom Callaway [Mon, 14 Sep 2020 08:45:02 +0000 (04:45 -0400)]
Fix compilation for compilers not supporting __has_attribute

5 years agoUpdate Travis to Ubuntu Bionic
Tom Callaway [Sat, 12 Sep 2020 08:28:27 +0000 (04:28 -0400)]
Update Travis to Ubuntu Bionic

5 years agoImplement GCC 10 style symbol versioning (#545)
Tom Callaway [Fri, 11 Sep 2020 09:15:43 +0000 (05:15 -0400)]
Implement GCC 10 style symbol versioning (#545)

5 years agoUpdated example code to work with new API (#547)
AKowshik [Wed, 9 Sep 2020 19:17:06 +0000 (00:47 +0530)]
Updated example code to work with new API (#547)

5 years agoAdded TSAN suppression file.
Nikolaus Rath [Fri, 28 Aug 2020 19:19:43 +0000 (20:19 +0100)]
Added TSAN suppression file.

5 years agoSuppress some bogus thread sanitizer warnings.
Nikolaus Rath [Fri, 28 Aug 2020 19:07:11 +0000 (20:07 +0100)]
Suppress some bogus thread sanitizer warnings.

5 years agoRemove pointer to professional consulting offers
Nikolaus Rath [Mon, 10 Aug 2020 18:39:27 +0000 (19:39 +0100)]
Remove pointer to professional consulting offers

I do not want to offer this actively anymore.

5 years agoFix-up changelog.
Nikolaus Rath [Sun, 9 Aug 2020 11:55:02 +0000 (12:55 +0100)]
Fix-up changelog.

5 years agoReleased 3.9.4 fuse-3.9.3 fuse-3.9.4
Nikolaus Rath [Sun, 9 Aug 2020 11:49:17 +0000 (12:49 +0100)]
Released 3.9.4

5 years agofuse_send_data_iov(): correctly calculate total buffer size.
Nikolaus Rath [Sun, 9 Aug 2020 11:39:07 +0000 (12:39 +0100)]
fuse_send_data_iov(): correctly calculate total buffer size.

Fixes: #538.
5 years agoDefine fuse_session_loop_mt as a macro on uclibc and MacOS (#532)
asafkahlon [Sun, 9 Aug 2020 11:37:26 +0000 (14:37 +0300)]
Define fuse_session_loop_mt as a macro on uclibc and MacOS (#532)

On uclibc and MacOS we don't use versioned symbols. Hence,
there's no definition for fuse_session_loop_mt on those cases
and the linker won't be able to resolve calls to fuse_session_loop_mt()

Signed-off-by: Asaf Kahlon <asafka7@gmail.com>
5 years agoFixed typo in command to compile program (#536)
AKowshik [Sun, 9 Aug 2020 11:35:43 +0000 (17:05 +0530)]
Fixed typo in command to compile program (#536)

5 years agoDoc fixes (#537)
Junichi Uekawa [Sun, 9 Aug 2020 11:35:28 +0000 (20:35 +0900)]
Doc fixes (#537)

* Add fallocate to list of operations that may omit path.

* earlier versions is 10+ years old.

Document is not obvious how old it is. Add it.

* Update manpage link

5 years agoFix FreeBSD CI (#539)
Li-Wen Hsu [Sun, 9 Aug 2020 11:34:58 +0000 (19:34 +0800)]
Fix FreeBSD CI (#539)

5 years agoFix: crash on failure to set locale (#529)
Jérémie Galarneau [Fri, 10 Jul 2020 18:59:57 +0000 (14:59 -0400)]
Fix: crash on failure to set locale (#529)

setlocale() can fail, returning NULL, if the user has an invalid (or
missing) locale set in the LANG environment variable.

In my case, this happens when using VS Code's integrated terminal to
launch a fuse-based filesystem. A bug (fix upcoming) results in VS Code
setting an invalid locale.

iconv_help() currently passes the return value of setlocale(...)
directly to strdup() without checking if it is NULL, resulting in a
crash.

To reproduce, simply set LANG="something_invalid" and call
fuse_lib_help().

Stack trace when the process receives `SIGSEGV`:

(gdb) bt
 #0  0x00007fabd0fcc4b5 in __strlen_avx2 () from /usr/lib/libc.so.6
 #1  0x00007fabd0ef9233 in strdup () from /usr/lib/libc.so.6
 #2  0x00007fabd13b8128 in iconv_help () at ../lib/modules/iconv.c:641
 #3  0x00007fabd13b81a8 in iconv_opt_proc (data=0x55580a6ee850, arg=0x55580a6edfb0 "-h", key=0, outargs=0x7ffeeb1a8ec8) at ../lib/modules/iconv.c:658
 #4  0x00007fabd13af7d5 in call_proc (ctx=0x7ffeeb1a8ea0, arg=0x55580a6edfb0 "-h", key=0, iso=0) at ../lib/fuse_opt.c:161
 #5  0x00007fabd13afaf1 in process_opt (ctx=0x7ffeeb1a8ea0, opt=0x7fabd13c3d40 <iconv_opts>, sep=0, arg=0x55580a6edfb0 "-h", iso=0) at ../lib/fuse_opt.c:233
 #6  0x00007fabd13afd5a in process_gopt (ctx=0x7ffeeb1a8ea0, arg=0x55580a6edfb0 "-h", iso=0) at ../lib/fuse_opt.c:285
 #7  0x00007fabd13b0117 in process_one (ctx=0x7ffeeb1a8ea0, arg=0x55580a6edfb0 "-h") at ../lib/fuse_opt.c:368
 #8  0x00007fabd13b0190 in opt_parse (ctx=0x7ffeeb1a8ea0) at ../lib/fuse_opt.c:379
 #9  0x00007fabd13b03d3 in fuse_opt_parse (args=0x7ffeeb1a8f70, data=0x55580a6ee850, opts=0x7fabd13c3d40 <iconv_opts>, proc=0x7fabd13b8186 <iconv_opt_proc>)
    at ../lib/fuse_opt.c:414
 #10 0x00007fabd13b8226 in iconv_new (args=0x7ffeeb1a8f70, next=0x0) at ../lib/modules/iconv.c:680
 #11 0x00007fabd13a5627 in print_module_help (name=0x7fabd13b9e1c "iconv", fac=0x7fabd13d48e0 <fuse_module_iconv_factory>) at ../lib/fuse.c:4692
 #12 0x00007fabd13a56aa in fuse_lib_help (args=0x7ffeeb1a9238) at ../lib/fuse.c:4721

iconv_help() is modified to print an error when setlocale() fails.
It then carries on printing the iconv module's help.

Reading setlocale(3), it seems that the strdup() of the result was
not necessary.

Signed-off-by: Jérémie Galarneau <jeremie.galarneau@gmail.com>
5 years agofuse_lowlevel: Move assert for se before dereferencing it with se->debug (#530)
winndows [Fri, 10 Jul 2020 18:58:07 +0000 (02:58 +0800)]
fuse_lowlevel: Move assert for se before dereferencing it with se->debug (#530)

Move assert for se before dereferencing it with se->debug.

Signed-off-by: Liao Pingfang <liao.pingfang@zte.com.cn>
Co-authored-by: Liao Pingfang <liao.pingfang@zte.com.cn>
5 years agoFixed minor print alignment issue in iconv_help(), replacing tab with space (#519)
Albert Chen [Fri, 3 Jul 2020 11:39:09 +0000 (04:39 -0700)]
Fixed minor print alignment issue in iconv_help(), replacing tab with space (#519)

5 years agoFix the typo "filed" -> "field" in fuse manpage (#524)
winndows [Fri, 3 Jul 2020 11:30:40 +0000 (19:30 +0800)]
Fix the typo "filed" -> "field" in fuse manpage (#524)

Fix the typo "filed" -> "field" in fuse manpage.

Signed-off-by: Liao Pingfang <liao.pingfang@zte.com.cn>
Co-authored-by: Liao Pingfang <liao.pingfang@zte.com.cn>
5 years agoREADME: Correct the directory name from 'examples' to 'example' (#526)
winndows [Fri, 3 Jul 2020 11:29:48 +0000 (19:29 +0800)]
README: Correct the directory name from 'examples' to 'example' (#526)

Correct the directory name from 'examples' to 'example' in readme.

Signed-off-by: Liao Pingfang <liao.pingfang@zte.com.cn>
Co-authored-by: Liao Pingfang <liao.pingfang@zte.com.cn>
5 years agodocs: Replace `mesonconf` with `meson configure` (#528)
Craig Chi [Fri, 3 Jul 2020 11:28:05 +0000 (04:28 -0700)]
docs: Replace `mesonconf` with `meson configure` (#528)

Fixes #527

5 years agolibfuse: Assign NULL to "old" to avoid free it twice (#522)
winndows [Wed, 1 Jul 2020 05:20:01 +0000 (13:20 +0800)]
libfuse: Assign NULL to "old" to avoid free it twice (#522)

Assign NULL to "old" at the first free(), to avoid the possible 2nd free() for it.

Signed-off-by: Liao Pingfang <liao.pingfang@zte.com.cn>
Co-authored-by: Liao Pingfang <liao.pingfang@zte.com.cn>
5 years agoTypo fixed. (#520)
Seunghoon Yeon [Mon, 22 Jun 2020 05:27:58 +0000 (14:27 +0900)]
Typo fixed. (#520)

5 years agoReleased 3.9.2 fuse-3.9.2
Nikolaus Rath [Fri, 12 Jun 2020 11:12:50 +0000 (12:12 +0100)]
Released 3.9.2

5 years agofix format in test (#515)
Rosen Penev [Fri, 15 May 2020 18:34:31 +0000 (11:34 -0700)]
fix format in test (#515)

Fixes warning under 32-bit.

5 years agoAvoid closing se->fd twice in fuse_lowlevel.c (#516)
Fabian Vogt [Fri, 15 May 2020 18:32:10 +0000 (20:32 +0200)]
Avoid closing se->fd twice in fuse_lowlevel.c (#516)

If fuse_session_unmount is called before fuse_session_destroy, both
would try to close(se->fd). Avoid that by resetting it in
fuse_session_unmount.

5 years agopassthrough_ll: remove symlink fallbacks (#514)
Miklos Szeredi [Thu, 14 May 2020 19:17:50 +0000 (21:17 +0200)]
passthrough_ll: remove symlink fallbacks (#514)

* passthrough_ll/hp: remove symlink fallbacks

Path lookup in the kernel has special rules for looking up magic symlinks
under /proc.  If a filesystem operation is instructed to follow symlinks
(e.g. via AT_SYMLINK_FOLLOW or lack of AT_SYMLINK_NOFOLLOW), and the final
component is such a proc symlink, then the target of the magic symlink is
used for the operation, even if the target itself is a symlink.  I.e. path
lookup is always terminated after following a final magic symlink.

I was erronously assuming that in the above case the target symlink would
also be followed, and so workarounds were added for a couple of operations
to handle the symlink case.  Since the symlink can be handled simply by
following the proc symlink, these workardouds are not needed.

Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
Co-authored-by: Miklos Szeredi <mszeredi@redhat.com>
5 years agoDo not require C++ compiler for building
Fabrice Fontaine [Mon, 20 Apr 2020 19:20:19 +0000 (21:20 +0200)]
Do not require C++ compiler for building

Fixes:
 - http://autobuild.buildroot.org/results/a6e64213f2910b2b81e79cb1e96e558413d7f70a

Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
5 years agoReleased 3.9.1 fuse-3.9.1
Nikolaus Rath [Thu, 19 Mar 2020 20:00:41 +0000 (20:00 +0000)]
Released 3.9.1

5 years agoFix issue preventing using splice with reads (#505)
Jean-Yves VET [Fri, 13 Mar 2020 19:02:41 +0000 (20:02 +0100)]
Fix issue preventing using splice with reads (#505)

Context: SPLICE_WRITE is not used with regular buffers
(i.e. when they are not file-descriptor backed buffers).
There is a bug which assumes file descriptors are used.
If the amount of data associated with those FD is lower
than twice the page size, SPLICE_WRITE is not utilized.
With regular buffers the aggregated size was always 0.
Because vmsplice (splice user pages to/from a pipe) is
called before splice in fuse_lowlevel.c, regular buffers
would also work with splice.

This patch prevents to fallback to non-splice enabled
copies when itheir is no FD involved.