Nikolaus Rath [Sun, 16 Oct 2016 21:28:47 +0000 (14:28 -0700)]
 
Inlined fuse_mount_help() into fuse_lowlevel_help().
Both the BSD and Linux implementation actually accept mostly the same
FUSE-specific mount options. Up to now, the BSD help function appended
the output of ``mount_fusefs --help``, but looking at
http://www.unix.com/man-page/freebsd/8/mount_fusefs/ this is likely more
confusing than helpful (since the user is not actually invoking
mount_fusefs directly, most of the options don't make sense).
Nikolaus Rath [Sun, 16 Oct 2016 21:18:36 +0000 (14:18 -0700)]
 
fuse_new(): instead of listing options, refer to mount.fuse(8)
Nikolaus Rath [Sun, 16 Oct 2016 21:18:07 +0000 (14:18 -0700)]
 
fuse_session_new(): instead of listing options, refer to mount.fuse(8)
Nikolaus Rath [Sun, 16 Oct 2016 21:17:30 +0000 (14:17 -0700)]
 
fuse_session_new: accept -o debug as synonym for -d
Nikolaus Rath [Sun, 16 Oct 2016 21:12:39 +0000 (14:12 -0700)]
 
Updated man-pages.
* Removed -o nonempty
* Added -o noforget
* Split into high-level / low-level
* Added warning that most options should be chosen by file system
  internally.
* Updated maintainer.
Nikolaus Rath [Sun, 16 Oct 2016 02:46:57 +0000 (19:46 -0700)]
 
Make --help output more suitable for end-user
We now only list options that are potentially useful for an
end-user (and unlikely to accidentally break a file system). The full
list of FUSE options has been moved to the documentation of the
fuse_new() and fuse_session_new() functions.
Nikolaus Rath [Sun, 16 Oct 2016 02:07:57 +0000 (19:07 -0700)]
 
Removed -o nopath - it never did anything
We are overriding this setting with the flag in struct fuse_operations:
$ example/hello -f -d  ~/tmp/mnt
FUSE library version: 3.0.0pre0
nopath: 0
unique: 1, opcode: INIT (26), nodeid: 0, insize: 56, pid: 0
INIT: 7.25
flags=0x0007fffb
max_readahead=0x00020000
   INIT: 7.23
   flags=0x00006031
   max_readahead=0x00020000
   max_write=0x00020000
   max_background=0
   congestion_threshold=0
   time_gran=0
   unique: 1, success, outsize: 80
$ example/hello -f -d  ~/tmp/mnt -o nopath
FUSE library version: 3.0.0pre0
nopath: 0
unique: 1, opcode: INIT (26), nodeid: 0, insize: 56, pid: 0
INIT: 7.25
flags=0x0007fffb
max_readahead=0x00020000
   INIT: 7.23
   flags=0x00006031
   max_readahead=0x00020000
   max_write=0x00020000
   max_background=0
   congestion_threshold=0
   time_gran=0
   unique: 1, success, outsize: 80
Nikolaus Rath [Sat, 8 Oct 2016 03:57:53 +0000 (20:57 -0700)]
 
Removed -o nonempty option
This brings the default behavior in-line with that of the
regular `mount` command.
Nikolaus Rath [Sun, 16 Oct 2016 01:51:00 +0000 (18:51 -0700)]
 
Fix documentation of -o max_write=
big_writes has been available for some time, and is the default in FUSE
3. So max_write now actually takes effect.
(This really should have gone into commit 
97f4a9cb4fc69)
Nikolaus Rath [Sun, 16 Oct 2016 01:49:52 +0000 (18:49 -0700)]
 
Drop -o large_read mount option
This was only relevant for 2.4 kernels. Fixes #92.
Nikolaus Rath [Sun, 16 Oct 2016 01:46:27 +0000 (18:46 -0700)]
 
Pass fuse_file_info to getattr, chown, chmod, truncate, utimens handlers
This obsoletes the ftruncate & fgetattr handlers.
Fixes #58.
Nikolaus Rath [Sat, 15 Oct 2016 23:09:16 +0000 (16:09 -0700)]
 
Unify handling of fuse_conn_info options
Instead of using command line options to modify struct fuse_conn_info
before and after calling the init() handler, we now give the file system
explicit control over this.
Nikolaus Rath [Sat, 15 Oct 2016 23:24:02 +0000 (16:24 -0700)]
 
Merge branch 'fixup-lock-options'
Nikolaus Rath [Sat, 15 Oct 2016 23:17:12 +0000 (16:17 -0700)]
 
Re-activated lost no_remote_*lock options.
Nikolaus Rath [Thu, 13 Oct 2016 16:07:55 +0000 (09:07 -0700)]
 
tests: use freshly-build fusermount (instead of system version)
When running tests as non-root, make fusermount setuid root.
Nikolaus Rath [Thu, 13 Oct 2016 17:49:03 +0000 (10:49 -0700)]
 
Travis: use "make test" instead of calling pytest directly
Nikolaus Rath [Tue, 11 Oct 2016 04:45:47 +0000 (21:45 -0700)]
 
Only test writeback cache if kernel is recent enough.
Nikolaus Rath [Tue, 11 Oct 2016 04:53:01 +0000 (21:53 -0700)]
 
Added lost ChangeLog entries for -o writeback_cache and -o async_dio.
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 [Tue, 11 Oct 2016 04:29:36 +0000 (21:29 -0700)]
 
Make -o clone_fd into a parameter of session_loop_mt().
This option really affects the behavior of the session loop, not the
low-level interface. Therefore, it does not belong in the fuse_session
object.
Nikolaus Rath [Tue, 11 Oct 2016 03:21:45 +0000 (20:21 -0700)]
 
Move session options into sub-struct
The session options are used only once to determine the proper
conn->want flags. It is nice to have them clearly separated from the
other struct fuse_session members that are used throughout the life of
the file system.
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 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.