| Age | Commit message (Collapse) | Author | Lines | 
|---|
|  | Introduce an API for custom log handler functions.  This allows libfuse
applications to send messages to syslog(3) or other logging systems.
See include/fuse_log.h for details.
Convert libfuse from fprintf(stderr, ...) to log_fuse(level, ...).  Most
messages are error messages with FUSE_LOG_ERR log level.  There are also
some debug messages which now use the FUSE_LOG_DEBUG log level.
Note that lib/mount_util.c is used by both libfuse and fusermount3.
Since fusermount3 does not link against libfuse, we cannot call
fuse_log() from lib/mount_util.c.  This file will continue to use
fprintf(stderr, ...) until someone figures out how to split it up.
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> | 
|  | This reverts commit 161983e2416bc6e26bbbe89664fff62c48c70858,
because this causes resource leaks when threads are terminated
by pthread_cancel().
Fixes: #313. | 
|  | This is only used in fuse_do_work(), so we can put it on
the stack. | 
|  | The old versions of these symbols were defined with version
tag FUSE_3.0, so this is what we have to use in the .symver
directive. | 
|  | The fuse_session_loop_mt() and fuse_loop_mt() symbols are only visible
when linking against the shared object. The code in lib/, however, is
compiled *into* the shared object and should thus use the internal
names of these functions.
Surprisingly enough, the code still worked before - but only when link
time optimization was disabled.
Unfortunately, we still can't compile with LTO because it seems that
enabling LTO somehow makes the tagged symbols vanish.
Without lto, we have:
$ nm lib/libfuse3.so | grep fuse_new
0000000000011070 T fuse_new_30
0000000000010a00 t fuse_new_31
0000000000011070 T fuse_new@FUSE_3.0
0000000000010a00 T fuse_new@@FUSE_3.1
and with LTO:
$ nm lib/libfuse3.so | grep fuse_new
0000000000019a70 T fuse_new_30
0000000000019270 t fuse_new_31
See also issue #198. | 
|  |  | 
|  |  | 
|  |  | 
|  | 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. | 
|  | Replace se->f with se. | 
|  | 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 :-). | 
|  | This should make more clear what file contains code for what
purpose. | 
|  |  | 
|  |  | 
|  | This creates a separate device file descriptor for each processing thread,
which might improve performance. | 
|  | add AC_SYS_LARGEFILE to your configure.ac instead. | 
|  |  | 
|  | Remove fuse_chan_bufsize() from the lowlevel API.
fuse_session_receive_buf() is now responsible for allocating memory for the
buffer. | 
|  | Move the fuse_chan_ops.send and .receive implementations to fuse_lowlevel.c.  The abstraction wasn't actually useful and made the the splice implementation more difficult.
Remove fuse_chan_ops.send and fuse_chan_ops.receive. | 
|  | Replace fuse_session_next_chan() with fuse_session_chan(), as multiple
channels per session were never actually supported and probably never will. | 
|  | - modified all examples to be included in doxygen
- modified the API documentation to have more details
- added the 490px_FUSE_structure.svg.png (c) wikipedia | 
|  | Exiting a worker my race with cancelling that same worker.  This caused a
segmenation fault.
Reported and tested by Anatol Pomozov | 
|  |  | 
|  | This works similar to "noforget" except that eventually the node will
be allowed to expire from the cache. | 
|  | This allows forget requests to be processed faster and doesn't require
a modification to fuse filesystems.  Reported by Terje Malmedal | 
|  | In fuse_session_loop_mt() don't pause when exiting the worker threads.
The pause() was added in 2.2.1 to prevent segfault on pthread_cancel()
on an exited, detached thread.  Now worker threads are not detached
and pthread_cancel() should work fine even after the thread exited.
Reported by Boris Protopopov | 
|  | Add new ->write_buf() method to low level interface.  This
allows passig a generic buffer, either containing a memory buffer
or a file descriptor.  This allows implementing zero copy writes.
Add fuse_session_receive_buf() and fuse_session_process_buf()
which may be used in event loop implementations to replace
fuse_chan_recv() and fuse_session_process() respectively. | 
|  |  | 
|  | threads by this value | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  |