Nikolaus Rath [Tue, 18 Oct 2016 04:22:47 +0000 (21:22 -0700)]
 
Removed all "Introduced in..." comments
Since FUSE 3 is breaking backwards compatibility, this really does
not matter.
Nikolaus Rath [Tue, 18 Oct 2016 04:08:21 +0000 (21:08 -0700)]
 
mount.fuse(8): remove max_readahead, max_write, [a]sync_read
These are not mount options for FUSE file systems, but capabilites that
are worked out between libfuse and the fuse kernel module. For that
reason, they are also not accepted by fuse_session_new().
Consus [Thu, 20 Oct 2016 13:08:49 +0000 (16:08 +0300)]
 
Do not close stdout on fuse_session_destroy()
If fuse_session_mount() fails (or was never called in the first place)
we end up with the default fd value which happens to be 0. It hurts
long-running processes, which lifetime extends beyond session's
lifetime.
Nikolaus Rath [Wed, 19 Oct 2016 01:54:14 +0000 (18:54 -0700)]
 
Cast to void where we deliberately ignore return values
Mihail Konev [Tue, 18 Oct 2016 04:02:52 +0000 (04:02 +0000)]
 
Ignore some errors
Nikolaus Rath [Tue, 18 Oct 2016 03:20:21 +0000 (20:20 -0700)]
 
Update linker script
- Fixes commit 
d49f2e77b4.
- Fixes commit 
199fc0f833.
- Thanks to Github user mtheall for the review!
Nikolaus Rath [Tue, 18 Oct 2016 03:16:58 +0000 (20:16 -0700)]
 
fuse_session_new(): accept --debug
Fixes commit 
3e022acf4076.
Thanks to Github user mtheall for the review!
Nikolaus Rath [Tue, 18 Oct 2016 03:15:25 +0000 (20:15 -0700)]
 
Spelling fix
Thanks to (Github user) mtheall for the review!
Nikolaus Rath [Mon, 17 Oct 2016 02:51:40 +0000 (19:51 -0700)]
 
Ignore GNU Global tag files.
Nikolaus Rath [Sun, 16 Oct 2016 22:34:20 +0000 (15:34 -0700)]
 
Mention that low-level fs need to set FUSE_CAP_EXPORT_SUPPORT
Nikolaus Rath [Sun, 16 Oct 2016 22:31:54 +0000 (15:31 -0700)]
 
Default to FUSE_USE_VERSION 30
Nikolaus Rath [Sun, 16 Oct 2016 22:05:57 +0000 (15:05 -0700)]
 
Various documentation updates
Move README.NFS into doc/
Update project URL
Remove reference to non-existent INSTALL file
Remove outdated/obsolete NEWS and how-fuse-works files.
Update references to examples.
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.