qemu-gpiodev/libfuse.git
9 years agoMake several -o NN options work again
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.

9 years agoFix race condition in notify_* examples
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.

9 years agoAdded write cache tests.
Nikolaus Rath [Mon, 10 Oct 2016 17:49:21 +0000 (10:49 -0700)]
Added write cache tests.

9 years agoUse "se" instead of "f" for fuse_session pointer where possible.
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
...> }

9 years agofuse_main(): extend support for printing help
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.

9 years agoUse NULL as option processor where possible.
Nikolaus Rath [Mon, 10 Oct 2016 05:56:51 +0000 (22:56 -0700)]
Use NULL as option processor where possible.

9 years agofuse_main_real(): use fuse_parse_cmdline().
Nikolaus Rath [Mon, 10 Oct 2016 05:39:28 +0000 (22:39 -0700)]
fuse_main_real(): use fuse_parse_cmdline().

9 years agoAdded ChangeLog entry for commit 225c12aebf2d2f27e1d0.
Nikolaus Rath [Mon, 10 Oct 2016 05:07:54 +0000 (22:07 -0700)]
Added ChangeLog entry for commit 225c12aebf2d2f27e1d0.

9 years agoAdded cuse unit test.
Nikolaus Rath [Mon, 10 Oct 2016 04:46:39 +0000 (21:46 -0700)]
Added cuse unit test.

9 years agoRenamed cuses example and added test program
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.

9 years agoIncrease timeouts in notify_* tests
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.

9 years agoDon't confuse lookup count for mountpoint and file
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.

9 years agoRenamed timefsN examples to fuse_notify_*
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.

9 years agoInclude testfsN examples in Doxygen documentation.
Nikolaus Rath [Mon, 10 Oct 2016 03:18:38 +0000 (20:18 -0700)]
Include testfsN examples in Doxygen documentation.

9 years agoRenamed ioctl and poll examples
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.

9 years agoRenamed some examples to make their function more obvious
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.

9 years agofuse_parse_cmdline(): do not print help/version text
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.

9 years agoAdded missing export of fuse_pkgversion.
Nikolaus Rath [Sun, 9 Oct 2016 21:43:56 +0000 (14:43 -0700)]
Added missing export of fuse_pkgversion.

9 years agoMerge pull request #80 from libfuse/master-proposed
Nikolaus Rath [Sun, 9 Oct 2016 21:19:33 +0000 (14:19 -0700)]
Merge pull request #80 from libfuse/master-proposed

9 years agoWhitespace fix.
Nikolaus Rath [Sun, 9 Oct 2016 21:04:41 +0000 (14:04 -0700)]
Whitespace fix.

9 years agoFix valgrind warning
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.

9 years agoFix documentation of fuse_parse_cmdline().
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.

9 years agoDropped example/null.c
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?

9 years agoAdded timefs3 to test notify_inval_entry.
Nikolaus Rath [Sun, 9 Oct 2016 04:24:13 +0000 (21:24 -0700)]
Added timefs3 to test notify_inval_entry.

Fixes #32.

9 years agoAdd background and multithreading support to hello_ll and fuse_lo-plus
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

9 years agoUpdate list of requests that can be answered with fuse_reply_none().
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().

9 years agotestfs2: Also test fuse_notify_retrieve().
Nikolaus Rath [Sun, 9 Oct 2016 03:01:25 +0000 (20:01 -0700)]
testfs2: Also test fuse_notify_retrieve().

9 years agoAdded timefs[12] examples.
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.

9 years agoAdded safe_sleep()
Nikolaus Rath [Sun, 9 Oct 2016 02:26:32 +0000 (19:26 -0700)]
Added safe_sleep()

9 years agoClarify that readdir() *may* report . and .. entries.
Nikolaus Rath [Sat, 8 Oct 2016 04:51:43 +0000 (21:51 -0700)]
Clarify that readdir() *may* report . and .. entries.

9 years agoRemoved ``-o big_writes`` option
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.

9 years agoTest more combinations of low-level options.
Nikolaus Rath [Thu, 6 Oct 2016 03:03:18 +0000 (20:03 -0700)]
Test more combinations of low-level options.

9 years agoRemove pointless aliasing of fuse_session *se to *f
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.

9 years agoRemoved obsolete, unused *f member from struct fuse_session.
Nikolaus Rath [Wed, 5 Oct 2016 15:57:04 +0000 (08:57 -0700)]
Removed obsolete, unused *f member from struct fuse_session.

9 years agoMerge struct fuse_ll into 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.

9 years agoMerge fuse_ll into fuse_session (part 8)
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.

9 years agoMerge fuse_ll into fuse_session (part 7)
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".

9 years agoMerge fuse_ll into fuse_session (part 6)
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().

9 years agoMerge fuse_ll into fuse_session (part 5)
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().

9 years agoMerge fuse_ll into fuse_session (part 4)
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().

9 years agoMerge fuse_ll into fuse_session (part 3)
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.

9 years agoMerge fuse_ll into fuse_session (part 2)
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.

9 years agoMerge fuse_ll into fuse_session (part 1)
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.

9 years agofuse_mount_help(): clarify that listed options are FUSE specific
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).

9 years agoClarified purpose of helper.c, moved *version() to fuse.c
Nikolaus Rath [Wed, 5 Oct 2016 02:34:19 +0000 (19:34 -0700)]
Clarified purpose of helper.c, moved *version() to fuse.c

9 years agoMerge branch 'fix-root-umount'
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.

9 years agofuse_session_unmount(): fix unmounting as root
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.

9 years agoMerge master fuse_chan into fuse_session.
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 :-).

9 years agofuse_lowlevel_notify_poll(): use master channel
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.

9 years agoStore struct fuse_session* in struct fuse_req
Nikolaus Rath [Tue, 4 Oct 2016 03:09:35 +0000 (20:09 -0700)]
Store struct fuse_session* in struct fuse_req

9 years agofuse_session_process_buf(): improve documentation
Nikolaus Rath [Tue, 4 Oct 2016 04:24:23 +0000 (21:24 -0700)]
fuse_session_process_buf(): improve documentation

9 years agoReleased 3.0.0pre0 fuse-3.0.0pre0
Nikolaus Rath [Mon, 3 Oct 2016 16:04:48 +0000 (09:04 -0700)]
Released 3.0.0pre0

9 years agoDon't crash if valgrind or libtool are not installed.
Nikolaus Rath [Mon, 3 Oct 2016 16:08:24 +0000 (09:08 -0700)]
Don't crash if valgrind or libtool are not installed.

9 years agoRun tests under valgrind when available.
Nikolaus Rath [Mon, 3 Oct 2016 05:31:13 +0000 (22:31 -0700)]
Run tests under valgrind when available.

Fixes #50.

9 years agoImport os.path.join as pjoin
Nikolaus Rath [Mon, 3 Oct 2016 05:11:16 +0000 (22:11 -0700)]
Import os.path.join as pjoin

Makes the code much shorter :-).

9 years agoAdded fuse_session_fd()
Nikolaus Rath [Mon, 3 Oct 2016 04:48:47 +0000 (21:48 -0700)]
Added fuse_session_fd()

Fixes #59.

9 years agoDocument that client pid/gid/uid may be zero.
Nikolaus Rath [Mon, 3 Oct 2016 04:36:12 +0000 (21:36 -0700)]
Document that client pid/gid/uid may be zero.

Fixes #67.

9 years agoMerged fuse_session.c into fuse_lowlevel.c
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.

9 years agoMerged fuse_mt.c into fuse.c
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.

9 years agoExtended per-file comments.
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.

9 years agoDon't handle --help and --version in fuse_session_new().
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.

9 years agofuse_mount_opts: don't keep max_read= option.
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.

9 years agoAdd section headings for --help output
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.

9 years agoEdited comments for clarity.
Nikolaus Rath [Mon, 3 Oct 2016 03:40:02 +0000 (20:40 -0700)]
Edited comments for clarity.

9 years agoAdded test for fuse_lo-plus.
Nikolaus Rath [Mon, 3 Oct 2016 03:37:07 +0000 (20:37 -0700)]
Added test for fuse_lo-plus.

9 years agoRun hello_ll single-threaded explicitly.
Nikolaus Rath [Mon, 3 Oct 2016 03:34:31 +0000 (20:34 -0700)]
Run hello_ll single-threaded explicitly.

9 years agoFixed permissions of source files.
Nikolaus Rath [Mon, 3 Oct 2016 03:32:38 +0000 (20:32 -0700)]
Fixed permissions of source files.

9 years agoTurn struct fuse_chan into an implementation detail
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.

9 years agoRenamed fuse_lowlevel_new() to fuse_session_new().
Nikolaus Rath [Sun, 2 Oct 2016 17:44:16 +0000 (10:44 -0700)]
Renamed fuse_lowlevel_new() to fuse_session_new().

9 years agoRe-order declarations to reflect typical order of use
Nikolaus Rath [Sun, 2 Oct 2016 17:37:21 +0000 (10:37 -0700)]
Re-order declarations to reflect typical order of use

9 years agoIntroduce separate mount/umount functions for low-level API.
Nikolaus Rath [Sun, 2 Oct 2016 17:26:40 +0000 (10:26 -0700)]
Introduce separate mount/umount functions for low-level API.

9 years agoTell emacs to use tabs for linkerscript.
Nikolaus Rath [Sun, 2 Oct 2016 17:10:29 +0000 (10:10 -0700)]
Tell emacs to use tabs for linkerscript.

9 years agoTurned fuse_session_{process,receive}_buf into wrapper functions.
Nikolaus Rath [Sun, 2 Oct 2016 16:38:06 +0000 (09:38 -0700)]
Turned fuse_session_{process,receive}_buf into wrapper functions.

9 years agoInlined fuse_session_new()
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.

9 years agoImprove documentation of argument parsing.
Nikolaus Rath [Sat, 1 Oct 2016 18:24:46 +0000 (11:24 -0700)]
Improve documentation of argument parsing.

9 years agoAdded notes for libfuse hackers.
Nikolaus Rath [Sun, 18 Sep 2016 03:03:58 +0000 (20:03 -0700)]
Added notes for libfuse hackers.

9 years agoDocumentation improvements.
Nikolaus Rath [Sun, 18 Sep 2016 03:10:21 +0000 (20:10 -0700)]
Documentation improvements.

9 years agoAdded TAGS to .gitignore
Nikolaus Rath [Mon, 19 Sep 2016 02:45:53 +0000 (19:45 -0700)]
Added TAGS to .gitignore

9 years agoFixed up permissions.
Nikolaus Rath [Sun, 18 Sep 2016 02:35:59 +0000 (19:35 -0700)]
Fixed up permissions.

9 years agofuse_lowlevel_notify_*: take struct fuse_session instead of struct fuse_chan
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.

9 years agoDropped fuse_unmount_compat22
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.

9 years agoFixed typo.
Nikolaus Rath [Fri, 19 Aug 2016 22:07:39 +0000 (15:07 -0700)]
Fixed typo.

9 years agoDon't hardcode /sbin, /lib & /etc
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".

9 years agoDisable thread sanitizer, use newer gcc.
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).

9 years agoUpdated ChangeLog
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.

9 years agoInclude test suite in tarball
Nikolaus Rath [Mon, 20 Jun 2016 20:15:25 +0000 (13:15 -0700)]
Include test suite in tarball

9 years agoadd error checking to setuid calls (#66)
Alex Richman [Thu, 21 Jul 2016 15:17:40 +0000 (16:17 +0100)]
add error checking to setuid calls (#66)

9 years agolibfuse/fuse_daemonize: wait until daemon child process is ready (#55)
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>
9 years agoAutomatically run CI tests with clang
Nikolaus Rath [Sun, 5 Jun 2016 20:20:07 +0000 (16:20 -0400)]
Automatically run CI tests with clang

Fixes: #51
9 years agoInlined calculate_dirent*_size functions
Nikolaus Rath [Sun, 5 Jun 2016 15:06:07 +0000 (11:06 -0400)]
Inlined calculate_dirent*_size functions

9 years agoDon't use IFTODT macro.
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.

9 years agoInlined fuse_add_dirent
Nikolaus Rath [Sat, 4 Jun 2016 17:43:29 +0000 (13:43 -0400)]
Inlined fuse_add_dirent

9 years agoMerge branch 'add-dirent-strlen3' of git://github.com/trapexit/libfuse into trapexit...
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

9 years agoAdd 'traceback' as suspicious test output pattern.
Nikolaus Rath [Fri, 13 May 2016 22:20:17 +0000 (15:20 -0700)]
Add 'traceback' as suspicious test output pattern.

9 years agoAdded Travis integration
Nikolaus Rath [Fri, 13 May 2016 20:24:52 +0000 (13:24 -0700)]
Added Travis integration

9 years agoMerge remote-tracking branch 'origin/master'
Nikolaus Rath [Fri, 13 May 2016 20:14:11 +0000 (13:14 -0700)]
Merge remote-tracking branch 'origin/master'

9 years agoMerge branch 'ioctl-test'
Nikolaus Rath [Fri, 13 May 2016 20:13:18 +0000 (13:13 -0700)]
Merge branch 'ioctl-test'

9 years agoAdd ioctl tests.
Nikolaus Rath [Fri, 13 May 2016 20:11:54 +0000 (13:11 -0700)]
Add ioctl tests.

9 years agoFix ioctl example
Nikolaus Rath [Fri, 13 May 2016 20:12:14 +0000 (13:12 -0700)]
Fix ioctl example

Fixes issue #39.

9 years agoremove double calculation of filename length and dirent size
Antonio SJ Musumeci [Tue, 9 Feb 2016 13:27:54 +0000 (08:27 -0500)]
remove double calculation of filename length and dirent size