Nikolaus Rath [Tue, 11 Oct 2016 02:41:34 +0000 (19:41 -0700)]
 
Mention atomic_o_trunc capability in description of open() handler.
Nikolaus Rath [Tue, 11 Oct 2016 02:20:15 +0000 (19:20 -0700)]
 
Use NULL for option processing function where possible.
Nikolaus Rath [Mon, 10 Oct 2016 23:14:17 +0000 (16:14 -0700)]
 
Activate splice_read by default if write_buf is implemented.
Nikolaus Rath [Mon, 10 Oct 2016 22:52:15 +0000 (15:52 -0700)]
 
do_init(): treat command line options consistently
Previously, some command line options would change the FUSE defaults
but leave the final value to the file systems `init` handler while
others would override any changes made by `init`. Now, command line
options do both: they modify the default, *and* take precedence.
Nikolaus Rath [Mon, 10 Oct 2016 23:28:26 +0000 (16:28 -0700)]
 
Document when fuse_reply_data will use splice()
Nikolaus Rath [Mon, 10 Oct 2016 22:13:59 +0000 (15:13 -0700)]
 
Factored out LL_OPTIONS macro
Nikolaus Rath [Mon, 10 Oct 2016 21:53:57 +0000 (14:53 -0700)]
 
Removed 'async_read' field in fuse_conn_info
This is redundant with the capability flags in `wants` and `capable`.
Nikolaus Rath [Mon, 10 Oct 2016 18:57:50 +0000 (11:57 -0700)]
 
Make several -o NN options work again
In commit 2ed7af, we accidentally set the default values *after*
parsing the command line arguments.
Nikolaus Rath [Mon, 10 Oct 2016 18:18:00 +0000 (11:18 -0700)]
 
Fix race condition in notify_* examples
The fix in commit 
cf4159156b was incomplete. While some false positives
are caused by sleep() in the file system taking longer than expected,
there was also a race condition where the file system would run before
the contents are initialized properly.
Nikolaus Rath [Mon, 10 Oct 2016 17:49:21 +0000 (10:49 -0700)]
 
Added write cache tests.
Nikolaus Rath [Mon, 10 Oct 2016 16:49:45 +0000 (09:49 -0700)]
 
Use "se" instead of "f" for fuse_session pointer where possible.
These changes were generated with the following Coccinelle semantic
patch:
@@
symbol f, se; // avoid unneeded warnings from Coccinelle
@@
struct fuse_session *
-f
+se
 ;
<...
-f
+se
...>
@@
identifier fn;
@@
fn(...,struct fuse_session *
-f
+se
,...) { <...
-f
+se
...> }
Nikolaus Rath [Mon, 10 Oct 2016 16:38:20 +0000 (09:38 -0700)]
 
fuse_main(): extend support for printing help
There's now a way to inhibit the "usage" line (which actually got lost
in commit 
225c12aebf2d), which makes it easier for simply file-systems
to generate good-looking --help output.
Nikolaus Rath [Mon, 10 Oct 2016 05:56:51 +0000 (22:56 -0700)]
 
Use NULL as option processor where possible.
Nikolaus Rath [Mon, 10 Oct 2016 05:39:28 +0000 (22:39 -0700)]
 
fuse_main_real(): use fuse_parse_cmdline().
Nikolaus Rath [Mon, 10 Oct 2016 05:07:54 +0000 (22:07 -0700)]
 
Added ChangeLog entry for commit 
225c12aebf2d2f27e1d0.
Nikolaus Rath [Mon, 10 Oct 2016 04:46:39 +0000 (21:46 -0700)]
 
Added cuse unit test.
Nikolaus Rath [Mon, 10 Oct 2016 04:05:54 +0000 (21:05 -0700)]
 
Renamed cuses example and added test program
An earlier version of the fioclient.c example was intended to be
used together with cusexmp.c. The former has since evolved into
ioctl_client.c and no longer has the function necessary to test
CUSE. Therefore, we've added a new cuse_client.c that is clearly
associated with the cuse.c example file system.
Nikolaus Rath [Mon, 10 Oct 2016 03:49:41 +0000 (20:49 -0700)]
 
Increase timeouts in notify_* tests
When running under Valgrind, we otherwise get sporadic test failures.
Nikolaus Rath [Mon, 10 Oct 2016 03:38:24 +0000 (20:38 -0700)]
 
Don't confuse lookup count for mountpoint and file
I think this is the reason for a sporadic test failure, where
fuse_lowlevel_notify_store() fails.
Nikolaus Rath [Mon, 10 Oct 2016 03:29:04 +0000 (20:29 -0700)]
 
Renamed timefsN examples to fuse_notify_*
This should make it more obvious at first glance what the different
examples do.
Nikolaus Rath [Mon, 10 Oct 2016 03:18:38 +0000 (20:18 -0700)]
 
Include testfsN examples in Doxygen documentation.
Nikolaus Rath [Mon, 10 Oct 2016 02:50:51 +0000 (19:50 -0700)]
 
Renamed ioctl and poll examples
The new names should make it more obvious at first glance
what each example demonstrates.
Nikolaus Rath [Mon, 10 Oct 2016 02:22:57 +0000 (19:22 -0700)]
 
Renamed some examples to make their function more obvious
Also, added more comments for the same purpose.
Nikolaus Rath [Mon, 10 Oct 2016 00:08:29 +0000 (17:08 -0700)]
 
fuse_parse_cmdline(): do not print help/version text
The current behavior makes it difficult to add help for
additional options. With the change, this becomes a lot easier.
Nikolaus Rath [Sun, 9 Oct 2016 21:43:56 +0000 (14:43 -0700)]
 
Added missing export of fuse_pkgversion.
Nikolaus Rath [Sun, 9 Oct 2016 21:19:33 +0000 (14:19 -0700)]
 
Merge pull request #80 from libfuse/master-proposed
Nikolaus Rath [Sun, 9 Oct 2016 21:04:41 +0000 (14:04 -0700)]
 
Whitespace fix.
Nikolaus Rath [Sun, 9 Oct 2016 21:04:00 +0000 (14:04 -0700)]
 
Fix valgrind warning
If we don't assign a value to padding, we get a warning about reading
uninitialized data when sending the iovec to the kernel.
Nikolaus Rath [Sun, 9 Oct 2016 05:05:10 +0000 (22:05 -0700)]
 
Fix documentation of fuse_parse_cmdline().
For --help and --version, it returns -1.
Nikolaus Rath [Sun, 9 Oct 2016 04:47:53 +0000 (21:47 -0700)]
 
Dropped example/null.c
This does not seem to be working. Maybe because it tries to treat the
mountpoint as a file rather than a directory?
Nikolaus Rath [Sun, 9 Oct 2016 04:24:13 +0000 (21:24 -0700)]
 
Added timefs3 to test notify_inval_entry.
Fixes #32.
Nikolaus Rath [Sun, 9 Oct 2016 03:04:36 +0000 (20:04 -0700)]
 
Add background and multithreading support to hello_ll and fuse_lo-plus
Nikolaus Rath [Sun, 9 Oct 2016 03:02:09 +0000 (20:02 -0700)]
 
Update list of requests that can be answered with fuse_reply_none().
Nikolaus Rath [Sun, 9 Oct 2016 03:01:25 +0000 (20:01 -0700)]
 
testfs2: Also test fuse_notify_retrieve().
Nikolaus Rath [Sun, 9 Oct 2016 02:29:39 +0000 (19:29 -0700)]
 
Added timefs[12] examples.
These examplesdemonstrate the use of the `fuse_lowlevel_notify_store`
and `fuse_lowlevel_notify_inval_inode` functions.
Nikolaus Rath [Sun, 9 Oct 2016 02:26:32 +0000 (19:26 -0700)]
 
Added safe_sleep()
Nikolaus Rath [Sat, 8 Oct 2016 04:51:43 +0000 (21:51 -0700)]
 
Clarify that readdir() *may* report . and .. entries.
Nikolaus Rath [Sat, 8 Oct 2016 04:08:40 +0000 (21:08 -0700)]
 
Removed ``-o big_writes`` option
This option is obsolete and should always be enabled. File systems that
want to limit the size of write requests should use the
``-o max_write=<N>`` option instead.
Nikolaus Rath [Thu, 6 Oct 2016 03:03:18 +0000 (20:03 -0700)]
 
Test more combinations of low-level options.
Nikolaus Rath [Wed, 5 Oct 2016 16:34:27 +0000 (09:34 -0700)]
 
Remove pointless aliasing of fuse_session *se to *f
This is an overlooked artifact of the fuse_ll-fuse_session merge.
Nikolaus Rath [Wed, 5 Oct 2016 15:57:04 +0000 (08:57 -0700)]
 
Removed obsolete, unused *f member from struct fuse_session.
Nikolaus Rath [Wed, 5 Oct 2016 04:04:18 +0000 (21:04 -0700)]
 
Merge struct fuse_ll into struct fuse_session.
This merge merges struct fuse_ll into struct fuse_session. Since
there is always a one-to-one correspondence between the two,
there is little reason to keep them separate. By merging them,
we save pointers and lines of code.
Nikolaus Rath [Wed, 5 Oct 2016 04:02:40 +0000 (21:02 -0700)]
 
Merge fuse_ll into fuse_session (part 8)
Replaced "req->se" with "f" where the latter is already defined.
Nikolaus Rath [Wed, 5 Oct 2016 03:58:19 +0000 (20:58 -0700)]
 
Merge fuse_ll into fuse_session (part 7)
Remove pointless aliasing of "struct fuse_session *se" to "struct
fuse_session *f".
Nikolaus Rath [Wed, 5 Oct 2016 03:50:30 +0000 (20:50 -0700)]
 
Merge fuse_ll into fuse_session (part 6)
Fixup cuse_lowlevel_new().
Nikolaus Rath [Wed, 5 Oct 2016 03:44:09 +0000 (20:44 -0700)]
 
Merge fuse_ll into fuse_session (part 5)
Fixup fuse_session_new().
Nikolaus Rath [Wed, 5 Oct 2016 03:43:08 +0000 (20:43 -0700)]
 
Merge fuse_ll into fuse_session (part 4)
Merge fuse_ll_destroy() and fuse_session_destroy().
Nikolaus Rath [Wed, 5 Oct 2016 03:41:52 +0000 (20:41 -0700)]
 
Merge fuse_ll into fuse_session (part 3)
Replace se->f with se.
Nikolaus Rath [Wed, 5 Oct 2016 03:38:47 +0000 (20:38 -0700)]
 
Merge fuse_ll into fuse_session (part 2)
Replaced all references to req->f with req->se.
Nikolaus Rath [Wed, 5 Oct 2016 03:32:38 +0000 (20:32 -0700)]
 
Merge fuse_ll into fuse_session (part 1)
Merged the structures, and replaced fuse_ll with fuse_session
in all type definitions.
Nikolaus Rath [Wed, 5 Oct 2016 02:40:06 +0000 (19:40 -0700)]
 
fuse_mount_help(): clarify that listed options are FUSE specific
We also accept a number of mount options that are common to
all  file systems (nosuid, nodev, ro, etc).
Nikolaus Rath [Wed, 5 Oct 2016 02:34:19 +0000 (19:34 -0700)]
 
Clarified purpose of helper.c, moved *version() to fuse.c
Nikolaus Rath [Tue, 4 Oct 2016 17:58:54 +0000 (10:58 -0700)]
 
Merge branch 'fix-root-umount'
Commit 
e4015aca9b7 already fixed this problem in a different way, so
this is effectively a null-merge.
Nikolaus Rath [Tue, 4 Oct 2016 17:55:12 +0000 (10:55 -0700)]
 
fuse_session_unmount(): fix unmounting as root
We have to store the channel before removing it from the session,
otherwise we cannot use it to do the unmount.
This problem was introduced in commit 
5698ee09cf7.
Thanks to Michael Theall for reporting & debugging this.
Nikolaus Rath [Tue, 4 Oct 2016 03:27:02 +0000 (20:27 -0700)]
 
Merge master fuse_chan into fuse_session.
This is a code simplification patch.
- It confines most of the implementation channel implementation into
  fuse_loop_mt (which is its only user).
- It makes it more obvious in the code that channels are only ever used
  when using -o clone_fd and multi-threaded main loop.
- It simplies the definition of both struct fuse_session and struct
  fuse_chan.
- Theoretically it should result in (minuscule) performance
  improvements when not using -o clone_fd.
- Overall, it removes a lot more lines of source code than it adds :-).
Nikolaus Rath [Tue, 4 Oct 2016 03:23:42 +0000 (20:23 -0700)]
 
fuse_lowlevel_notify_poll(): use master channel
In theory, a poll handle could hang around much longer than the worker
thread that creates it. Furthermore, the thread that created the
pollhandle is no more likely to call fuse_lowlevel_notify_poll() than
any other thread.
In theory, this would have kept the channel alive for much longer than
necessary. In practice, there seems to have been a bug that prevented
this - and instead allowed the channel to be destroyed while there
was still a pollhandle referring to it.
Instead of fixing this by calling fuse_chan_get() and fuse_chan_put() in
do_poll() and fuse_pollhandle_destroy(), we simply transmit poll
notifications over the master channel now.
Nikolaus Rath [Tue, 4 Oct 2016 03:09:35 +0000 (20:09 -0700)]
 
Store struct fuse_session* in struct fuse_req
Nikolaus Rath [Tue, 4 Oct 2016 04:24:23 +0000 (21:24 -0700)]
 
fuse_session_process_buf(): improve documentation
Nikolaus Rath [Mon, 3 Oct 2016 16:04:48 +0000 (09:04 -0700)]
 
Released 3.0.0pre0
Nikolaus Rath [Mon, 3 Oct 2016 16:08:24 +0000 (09:08 -0700)]
 
Don't crash if valgrind or libtool are not installed.
Nikolaus Rath [Mon, 3 Oct 2016 05:31:13 +0000 (22:31 -0700)]
 
Run tests under valgrind when available.
Fixes #50.
Nikolaus Rath [Mon, 3 Oct 2016 05:11:16 +0000 (22:11 -0700)]
 
Import os.path.join as pjoin
Makes the code much shorter :-).
Nikolaus Rath [Mon, 3 Oct 2016 04:48:47 +0000 (21:48 -0700)]
 
Added fuse_session_fd()
Fixes #59.
Nikolaus Rath [Mon, 3 Oct 2016 04:36:12 +0000 (21:36 -0700)]
 
Document that client pid/gid/uid may be zero.
Fixes #67.
Nikolaus Rath [Mon, 3 Oct 2016 04:22:02 +0000 (21:22 -0700)]
 
Merged fuse_session.c into fuse_lowlevel.c
This distinction no longer makes sens. fuse_lowlevel.c already contains
several session related functions, and fuse_session.c contains various
stuff that is more related to the channel interface.
Nikolaus Rath [Mon, 3 Oct 2016 04:21:22 +0000 (21:21 -0700)]
 
Merged fuse_mt.c into fuse.c
There is no point in having a separate file for a 10 line function.
Nikolaus Rath [Mon, 3 Oct 2016 04:20:44 +0000 (21:20 -0700)]
 
Extended per-file comments.
This should make more clear what file contains code for what
purpose.
Nikolaus Rath [Mon, 3 Oct 2016 03:52:33 +0000 (20:52 -0700)]
 
Don't handle --help and --version in fuse_session_new().
Help and version messages can be generated using the new
fuse_lowlevel_help(), fuse_lowlevel_version(), fuse_mount_help(), and
fuse_mount_version() functions.
The fuse_parse_cmdline() function has been made more powerful
to do this automatically, and is now explicitly intended only
for low-level API users.
This is a code simplication patch. We don't have to parse for --help and
--version in quite as many places, and we no longer have a low-level
initialization function be responsible for the (super-high level) task
of printing a program usage message.
In the high-level API, we can now handle the command line parsing
earlier and avoid running other initialization code if we're just going
to abort later on.
Nikolaus Rath [Mon, 3 Oct 2016 03:44:00 +0000 (20:44 -0700)]
 
fuse_mount_opts: don't keep max_read= option.
There is no consumer of it down the line.
Nikolaus Rath [Mon, 3 Oct 2016 03:42:33 +0000 (20:42 -0700)]
 
Add section headings for --help output
Also, do not include "General options" in usage message.
Nikolaus Rath [Mon, 3 Oct 2016 03:40:02 +0000 (20:40 -0700)]
 
Edited comments for clarity.
Nikolaus Rath [Mon, 3 Oct 2016 03:37:07 +0000 (20:37 -0700)]
 
Added test for fuse_lo-plus.
Nikolaus Rath [Mon, 3 Oct 2016 03:34:31 +0000 (20:34 -0700)]
 
Run hello_ll single-threaded explicitly.
Nikolaus Rath [Mon, 3 Oct 2016 03:32:38 +0000 (20:32 -0700)]
 
Fixed permissions of source files.
Nikolaus Rath [Sun, 2 Oct 2016 18:30:43 +0000 (11:30 -0700)]
 
Turn struct fuse_chan into an implementation detail
The only struct fuse_chan that's accessible to the user application is
the "master" channel that is returned by fuse_mount and stored in struct
fuse_session.
When using the multi-threaded main loop with the "clone_fd" option, each
worker thread gets its own struct fuse_chan. However, none of these are
available to the user application, nor do they hold references to struct
fuse_session (the pointer is always null).
Therefore, any presence of struct fuse_chan can be removed
without loss of functionality by relying on struct fuse_session instead.
This reduces the number of API functions and removes a potential source
of confusion (since the new API no longer looks as if it might be
possible to add multiple channels to one session, or to share one
channel between multiple sessions).
Fixes issue #17.
Nikolaus Rath [Sun, 2 Oct 2016 17:44:16 +0000 (10:44 -0700)]
 
Renamed fuse_lowlevel_new() to fuse_session_new().
Nikolaus Rath [Sun, 2 Oct 2016 17:37:21 +0000 (10:37 -0700)]
 
Re-order declarations to reflect typical order of use
Nikolaus Rath [Sun, 2 Oct 2016 17:26:40 +0000 (10:26 -0700)]
 
Introduce separate mount/umount functions for low-level API.
Nikolaus Rath [Sun, 2 Oct 2016 17:10:29 +0000 (10:10 -0700)]
 
Tell emacs to use tabs for linkerscript.
Nikolaus Rath [Sun, 2 Oct 2016 16:38:06 +0000 (09:38 -0700)]
 
Turned fuse_session_{process,receive}_buf into wrapper functions.
Nikolaus Rath [Sun, 2 Oct 2016 16:32:02 +0000 (09:32 -0700)]
 
Inlined fuse_session_new()
This function is only used in one place.
Nikolaus Rath [Sat, 1 Oct 2016 18:24:46 +0000 (11:24 -0700)]
 
Improve documentation of argument parsing.
Nikolaus Rath [Sun, 18 Sep 2016 03:03:58 +0000 (20:03 -0700)]
 
Added notes for libfuse hackers.
Nikolaus Rath [Sun, 18 Sep 2016 03:10:21 +0000 (20:10 -0700)]
 
Documentation improvements.
Nikolaus Rath [Mon, 19 Sep 2016 02:45:53 +0000 (19:45 -0700)]
 
Added TAGS to .gitignore
Nikolaus Rath [Sun, 18 Sep 2016 02:35:59 +0000 (19:35 -0700)]
 
Fixed up permissions.
Nikolaus Rath [Sun, 18 Sep 2016 02:29:19 +0000 (19:29 -0700)]
 
fuse_lowlevel_notify_*: take struct fuse_session instead of struct fuse_chan
The only struct fuse_chan that's available to the user application is
the one that is returned by fuse_mount. However, this is also
permanently available from struct fuse_session.
A later patch will therefore remove struct fuse_chan from the
public API completely. This patch prepares for this by changing the
fuse_lowlevel_notify_* functions to take a struct fuse_session
parameter instead of a struct fuse_chan parameter.
Nikolaus Rath [Wed, 28 Sep 2016 03:38:59 +0000 (20:38 -0700)]
 
Dropped fuse_unmount_compat22
This function was for backwards compatibility in FUSE 2.x, and
is no longer exposed by FUSE 3.
Nikolaus Rath [Fri, 19 Aug 2016 22:07:39 +0000 (15:07 -0700)]
 
Fixed typo.
bobrofon [Thu, 4 Aug 2016 19:46:38 +0000 (02:46 +0700)]
 
Don't hardcode /sbin, /lib & /etc
Default values for MOUNT_FUSE_PATH, UDEV_RULES_PATH and INIT_D_PATH should be based on directory variables from GNU Coding Standarts.
Directory variables left unexpanded because installation directory options may be changed via "make install prefix=/foo".
Nikolaus Rath [Sat, 23 Jul 2016 16:58:03 +0000 (09:58 -0700)]
 
Disable thread sanitizer, use newer gcc.
There's no point in having tests failing all the time,
we will re-enable thread sanitizer once we have figured
out if the errors are bugs or false positives (and, if they
are bugs, fixed them).
Nikolaus Rath [Tue, 21 Jun 2016 00:23:42 +0000 (17:23 -0700)]
 
Updated ChangeLog
Started from most recent FUSE 2.9.7 ChangeLog, and added FUSE 3.0
changes based on inspection of total diff to master.
Nikolaus Rath [Mon, 20 Jun 2016 20:15:25 +0000 (13:15 -0700)]
 
Include test suite in tarball
Alex Richman [Thu, 21 Jul 2016 15:17:40 +0000 (16:17 +0100)]
 
add error checking to setuid calls (#66)
Hendrik Brueckner [Mon, 20 Jun 2016 18:12:23 +0000 (20:12 +0200)]
 
libfuse/fuse_daemonize:  wait until daemon child process is ready (#55)
Mounting a FUSE file system remotely using SSH in combination with
pseudo-terminal allocation (-t), results in "Transport endpoint is
not connected" errors when trying to access the file system contents.
For example:
  # ssh -t root@localhost  "cmsfs-fuse /dev/disk/by-path/ccw-0.0.0190 /CMSFS"
  Connection to localhost closed.
  # ls /CMSFS
  ls: cannot access '/CMSFS': Transport endpoint is not connected
The cmsfs-fuse main program (which can also be any other FUSE file
system) calls into the fuse_main() libfuse library function.
The fuse_main() function later calls fuse_daemonize() to fork the
daemon process to handle the FUSE file system I/O.
The fuse_daemonize() function calls fork() as usual.  The child
proceeds with setsid() and then redirecting its file descriptors
to /dev/null etc.  The parent process, simply exits.
The child's functions and the parent's exit creates a subtle race.
This is seen with an SSH connection.  The SSH command above calls
cmsfs-fuse on an allocated pseudo-terminal device (-t option).
If the parent exits, SSH receives the command completion and closes
the connection, that means, it closes the master side of the
pseudo-terminal.  This causes a HUP signal being sent to the process
group on the pseudo-terminal.  At this point in time, the child might
not have completed the setsid() call and, hence, becomes terminated.
Note that fuse daemon sets up its signal handlers after fuse_daemonize()
has completed.
Even if the child has the chance to disassociate from its parent process
group to become it's own process group with setsid(), the child still
has the pseudo-terminal opened as stdin, stdout, and stderr.  So the
pseudo-terminal still behave as controlling terminal and might cause a
SIGHUP at closing the the master side.
To solve the problem, the parent has to wait until the child (the fuse
daemon process) has completed its processing, that means, has become
its own process group with setsid() and closed any file descriptors
pointing to the pseudo-terminal.
Closes: #27
Reported-by: Ofer Baruch <oferba@il.ibm.com>
Reviewed-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
Signed-off-by: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
Nikolaus Rath [Sun, 5 Jun 2016 20:20:07 +0000 (16:20 -0400)]
 
Automatically run CI tests with clang
Fixes: #51
Nikolaus Rath [Sun, 5 Jun 2016 15:06:07 +0000 (11:06 -0400)]
 
Inlined calculate_dirent*_size functions
Nikolaus Rath [Sun, 5 Jun 2016 14:45:35 +0000 (10:45 -0400)]
 
Don't use IFTODT macro.
IFTODT is provided by libc to convert from mode_t (as included in e.g.
struct fstat) to d_type (unsigned char element of struct dirent, as
returned by e.g. readdir). However, fuse actually uses a different
struct fuse_dirent with a "type" field of type uint32.
In other words, the semantics of (struct fuse_dirent).type are
not necessarily the same as those of (struct dirent).d_type.
Nikolaus Rath [Sat, 4 Jun 2016 17:43:29 +0000 (13:43 -0400)]
 
Inlined fuse_add_dirent
Nikolaus Rath [Sat, 4 Jun 2016 17:07:14 +0000 (13:07 -0400)]
 
Merge branch 'add-dirent-strlen3' of git://github.com/trapexit/libfuse into trapexit-add-dirent-strlen3