aboutsummaryrefslogtreecommitdiffstats
AgeCommit message (Collapse)AuthorLines
2016-10-04Merge fuse_ll into fuse_session (part 8)Nikolaus Rath-6/+6
Replaced "req->se" with "f" where the latter is already defined.
2016-10-04Merge fuse_ll into fuse_session (part 7)Nikolaus Rath-34/+30
Remove pointless aliasing of "struct fuse_session *se" to "struct fuse_session *f".
2016-10-04Merge fuse_ll into fuse_session (part 6)Nikolaus Rath-3/+1
Fixup cuse_lowlevel_new().
2016-10-04Merge fuse_ll into fuse_session (part 5)Nikolaus Rath-13/+3
Fixup fuse_session_new().
2016-10-04Merge fuse_ll into fuse_session (part 4)Nikolaus Rath-9/+3
Merge fuse_ll_destroy() and fuse_session_destroy().
2016-10-04Merge fuse_ll into fuse_session (part 3)Nikolaus Rath-16/+15
Replace se->f with se.
2016-10-04Merge fuse_ll into fuse_session (part 2)Nikolaus Rath-117/+117
Replaced all references to req->f with req->se.
2016-10-04Merge fuse_ll into fuse_session (part 1)Nikolaus Rath-76/+72
Merged the structures, and replaced fuse_ll with fuse_session in all type definitions.
2016-10-04fuse_mount_help(): clarify that listed options are FUSE specificNikolaus Rath-2/+2
We also accept a number of mount options that are common to all file systems (nosuid, nodev, ro, etc).
2016-10-04Clarified purpose of helper.c, moved *version() to fuse.cNikolaus Rath-10/+14
2016-10-04Merge branch 'fix-root-umount'Nikolaus Rath-0/+0
Commit e4015aca9b7 already fixed this problem in a different way, so this is effectively a null-merge.
2016-10-04fuse_session_unmount(): fix unmounting as rootNikolaus Rath-3/+4
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.
2016-10-03Merge master fuse_chan into fuse_session.Nikolaus Rath-220/+101
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 :-).
2016-10-03fuse_lowlevel_notify_poll(): use master channelNikolaus Rath-5/+4
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.
2016-10-03Store struct fuse_session* in struct fuse_reqNikolaus Rath-5/+6
2016-10-03fuse_session_process_buf(): improve documentationNikolaus Rath-3/+4
2016-10-03Released 3.0.0pre0Nikolaus Rath-4/+16
2016-10-03Don't crash if valgrind or libtool are not installed.Nikolaus Rath-3/+7
2016-10-02Run tests under valgrind when available.Nikolaus Rath-20/+46
Fixes #50.
2016-10-02Import os.path.join as pjoinNikolaus Rath-26/+27
Makes the code much shorter :-).
2016-10-02Added fuse_session_fd()Nikolaus Rath-1/+26
Fixes #59.
2016-10-02Document that client pid/gid/uid may be zero.Nikolaus Rath-2/+9
Fixes #67.
2016-10-02Merged fuse_session.c into fuse_lowlevel.cNikolaus Rath-114/+95
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.
2016-10-02Merged fuse_mt.c into fuse.cNikolaus Rath-26/+14
There is no point in having a separate file for a 10 line function.
2016-10-02Extended per-file comments.Nikolaus Rath-0/+24
This should make more clear what file contains code for what purpose.
2016-10-02Don't handle --help and --version in fuse_session_new().Nikolaus Rath-290/+317
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.
2016-10-02fuse_mount_opts: don't keep max_read= option.Nikolaus Rath-2/+0
There is no consumer of it down the line.
2016-10-02Add section headings for --help outputNikolaus Rath-13/+13
Also, do not include "General options" in usage message.
2016-10-02Edited comments for clarity.Nikolaus Rath-12/+9
2016-10-02Added test for fuse_lo-plus.Nikolaus Rath-0/+31
2016-10-02Run hello_ll single-threaded explicitly.Nikolaus Rath-0/+3
2016-10-02Fixed permissions of source files.Nikolaus Rath-0/+0
2016-10-02Turn struct fuse_chan into an implementation detailNikolaus Rath-327/+363
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.
2016-10-02Renamed fuse_lowlevel_new() to fuse_session_new().Nikolaus Rath-17/+21
2016-10-02Re-order declarations to reflect typical order of useNikolaus Rath-71/+73
2016-10-02Introduce separate mount/umount functions for low-level API.Nikolaus Rath-66/+111
2016-10-02Tell emacs to use tabs for linkerscript.Nikolaus Rath-0/+4
2016-10-02Turned fuse_session_{process,receive}_buf into wrapper functions.Nikolaus Rath-7/+26
2016-10-02Inlined fuse_session_new()Nikolaus Rath-23/+5
This function is only used in one place.
2016-10-01Improve documentation of argument parsing.Nikolaus Rath-3/+38
2016-09-27Added notes for libfuse hackers.Nikolaus Rath-0/+35
2016-09-27Documentation improvements.Nikolaus Rath-6/+10
2016-09-27Added TAGS to .gitignoreNikolaus Rath-0/+1
2016-09-27Fixed up permissions.Nikolaus Rath-0/+0
2016-09-27fuse_lowlevel_notify_*: take struct fuse_session instead of struct fuse_chanNikolaus Rath-30/+33
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.
2016-09-27Dropped fuse_unmount_compat22Nikolaus Rath-47/+0
This function was for backwards compatibility in FUSE 2.x, and is no longer exposed by FUSE 3.
2016-08-24Fixed typo.Nikolaus Rath-1/+1
2016-08-04Don't hardcode /sbin, /lib & /etcbobrofon-3/+3
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".
2016-07-23Disable thread sanitizer, use newer gcc.Nikolaus Rath-11/+18
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).
2016-07-23Updated ChangeLogNikolaus Rath-3690/+116
Started from most recent FUSE 2.9.7 ChangeLog, and added FUSE 3.0 changes based on inspection of total diff to master.