Miklos Szeredi [Tue, 10 Apr 2012 14:37:03 +0000 (16:37 +0200)]
 
Add 'flag_utime_omit_ok' flag to fuse_operations
If the filesystem sets this flag then ->utimens() will receive UTIME_OMIT and
UTIME_NOW values as specified in utimensat(2).
Miklos Szeredi [Tue, 10 Apr 2012 14:01:00 +0000 (16:01 +0200)]
 
Check protocol version before sending notifications
Check protocol version before sending notifications and return -ENOSYS if a
particular notification is not supported.
Miklos Szeredi [Fri, 6 Apr 2012 09:47:16 +0000 (11:47 +0200)]
 
test improvements
Miklos Szeredi [Fri, 27 Jan 2012 15:42:13 +0000 (16:42 +0100)]
 
Interpret octal escape codes in options
Requested by Jan Engelhardt
Miklos Szeredi [Thu, 26 Jan 2012 17:01:14 +0000 (18:01 +0100)]
 
clean up man page
Miklos Szeredi [Thu, 26 Jan 2012 16:44:35 +0000 (17:44 +0100)]
 
Add doc/Makefile.am
Miklos Szeredi [Thu, 26 Jan 2012 14:01:56 +0000 (15:01 +0100)]
 
Add man pages for fusermount, mount.fuse and ulockmgr_server
Lifted from the Debian package.  The man pages were written by Daniel Baumann
and Bastien Roucaries
Miklos Szeredi [Tue, 24 Jan 2012 12:01:39 +0000 (13:01 +0100)]
 
Revert "Add mmap() and munmap() methods to low level API"
This partially reverts commit 
4b2157c44e6ad7e692fcffb7450143e83151d36b.
Remove mmap/munmap suppor as this missed the interface changes for Linux-3.3
(API version 7.18).
Only revert the mmap/munmap bits and leave the retrieve_reply API fix in place
as well as the optimization in fuse_send_data_iov_fallback().
Anatol Pomozov [Fri, 6 Jan 2012 18:55:52 +0000 (10:55 -0800)]
 
Disable symbol versions on MacOSX
MacOSX uses MachO binary format that does not support symbols.
This change comes from fuse4x project (fuse implementation for macosx).
Miklos Szeredi [Mon, 2 Jan 2012 17:15:05 +0000 (18:15 +0100)]
 
Remove unnecessary mutex unlock at the end of multithreaded event loop
Miklos Szeredi [Fri, 9 Dec 2011 15:07:55 +0000 (16:07 +0100)]
 
Free request in fuse_reply_data()
Fix memory leak caused by a missing fuse_request_free() in fuse_reply_data().
Miklos Szeredi [Fri, 9 Dec 2011 15:07:55 +0000 (16:07 +0100)]
 
Don't unhash name in FORGET
This resulted in ENOENT being returned for unlinked but still open files if the
kernel sent a FORGET request for the parent directory.
Discovered with fs_racer in LTP.
Miklos Szeredi [Fri, 9 Dec 2011 15:07:55 +0000 (16:07 +0100)]
 
Fix hang in wait_on_path()
Ville Silventoinen reported that fs_racer in LTP triggered a hang in
wait_on_path().  This bug was caused by try_get_path() not resetting "ticket" on
permanent failure.
Emmanuel Dreyfus [Thu, 8 Dec 2011 10:55:27 +0000 (10:55 +0000)]
 
utimens availability check
fusexmp uses utimens and takes that function for granted. It is part of
POSIX exended API set 2 and some systems do not have it yet. Attached
patch checks for utimens availability and returns ENOSYS if unavailable.
Emmanuel Dreyfus [Thu, 8 Dec 2011 10:53:48 +0000 (10:53 +0000)]
 
FUSE_NODE_SLAB buildfix
When FUSE_NODE_SLAB is not defined, the build fails because of undefined
functions. Attached patch fixes the problem.
Nikolaus Rath [Wed, 7 Dec 2011 15:15:36 +0000 (10:15 -0500)]
 
fuse: documentation update for forget
Update documentation for forget and related methods
John Muir [Tue, 6 Dec 2011 20:56:34 +0000 (21:56 +0100)]
 
libfuse: Notifying the kernel of deletion.
libfuse part to allow a FUSE file-system to tell the kernel when a
file or directory is deleted. If the specified dentry has the
specified inode number, the kernel will unhash it.
Signed-off-by: John Muir <john@jmuir.com>
Signed-off-by: Miklos Szeredi <mszeredi@suse.cz>
Miklos Szeredi [Tue, 6 Dec 2011 17:06:18 +0000 (18:06 +0100)]
 
Add mmap() and munmap() methods to low level API
Currently this is only useful for CUSE.  Also update retrieve_reply()
method.
Miklos Szeredi [Mon, 5 Dec 2011 14:21:28 +0000 (15:21 +0100)]
 
Add support for ioctl on directories
Reported by Antonio SJ Musumeci
Miklos Szeredi [Mon, 5 Dec 2011 12:31:42 +0000 (13:31 +0100)]
 
Make lock argument of fuse_reply_lock const
Low level API: lock argument of fuse_reply_lock should have a
'const' qualifier.
Reported by Shachar Sharon
Miklos Szeredi [Thu, 17 Nov 2011 11:36:38 +0000 (12:36 +0100)]
 
Fix the following compile error
fusermount.c: In function 'clone_newns':
fusermount.c:315:2: warning: implicit declaration of function 'clone' [-Wimplicit-function-declaration]
fusermount.c:315:44: error: 'CLONE_NEWNS' undeclared (first use in this function)
fusermount.c:315:44: note: each undeclared identifier is reported only once for each function it appears in
fusermount.c:317:1: warning: control reaches end of non-void function [-Wreturn-type]
Miklos Szeredi [Sun, 23 Oct 2011 08:07:20 +0000 (10:07 +0200)]
 
Reply with ENOMEM in case of failure to allocate request
Reply to request with ENOMEM in case of failure to allocate request
structure.  Otherwise the task issuing the request will just freeze up
until the filesystem daemon is killed.  Reported by Stephan Kulow
Anatol Pomozov [Fri, 2 Sep 2011 23:26:09 +0000 (16:26 -0700)]
 
Replace daemon() function with fork()
daemon() is a BSD-ism. Although it is available on many platforms
it is not a standard function. Some platforms (e.g. MacOSX) deprecated
it.
It is safer just to use fork() function that is a part of POSIX.
Miklos Szeredi [Wed, 31 Aug 2011 10:55:06 +0000 (12:55 +0200)]
 
Don't ignore --disable-mtab
If configured with --disable-mtab then don't call mount(8) from
libfuse to update the mtab.
Reported by: James Sierp
therealneworld@gmail.com [Wed, 24 Aug 2011 16:01:17 +0000 (18:01 +0200)]
 
add lru for remember option
Use LRU list for cleaning up the cache if the "remember=T" option was
given.
Miklos Szeredi [Wed, 6 Jul 2011 10:12:01 +0000 (12:12 +0200)]
 
Add ->flock() operation to low and high level interfaces
This fixes problems with emulating flock() with POSIX locking.
Reported by Sebastian Pipping.
As with lock/setlk/getlk most filesystems don't need to implement
this, as the kernel takes care of file locking.  The only reason to
implement locking operations is for network filesystems which want
file locking to work between clients.
Sebastian Pipping [Sat, 25 Jun 2011 17:14:29 +0000 (19:14 +0200)]
 
utimens must not follow symlinks
Make xmp_utimens of examples "fusexmp" and "fusexmp_fh" not follow
symlinks as other layers do that already.
Miklos Szeredi [Thu, 2 Jun 2011 14:16:39 +0000 (16:16 +0200)]
 
In ./configure check if umount support --fake and --no-canonicalize
options and warn othewise
therealneworld@gmail.com [Thu, 2 Jun 2011 12:27:02 +0000 (14:27 +0200)]
 
add "remember" option
This works similar to "noforget" except that eventually the node will
be allowed to expire from the cache.
Miklos Szeredi [Fri, 27 May 2011 10:12:31 +0000 (12:12 +0200)]
 
Check if splice/vmsplice are supported
Miklos Szeredi [Thu, 26 May 2011 13:36:35 +0000 (15:36 +0200)]
 
Update COPYING*
Miklos Szeredi [Thu, 26 May 2011 12:07:12 +0000 (14:07 +0200)]
 
Update NEWS
Miklos Szeredi [Thu, 26 May 2011 11:57:57 +0000 (13:57 +0200)]
 
Fix lost ChangeLog entry.
Miklos Szeredi [Thu, 26 May 2011 09:17:51 +0000 (11:17 +0200)]
 
Remove -lrt -ldl from fuse.pc for dynamic linking
Remove -lrt -ldl from fuse.pc for dynamic linking since libfuse.so is
already linked with these libraries.
Reported by: Nikolaus Rath
Reuben Hawkins [Mon, 23 May 2011 15:17:09 +0000 (08:17 -0700)]
 
adding details to utimens doxygen comments
modified:   include/fuse.h
Reuben Hawkins [Mon, 23 May 2011 14:10:35 +0000 (07:10 -0700)]
 
Spell checking comments, etc...
...with the help of vim :set spell
modified:   FAQ
modified:   include/fuse.h
modified:   include/fuse_common.h
modified:   include/fuse_opt.h
modified:   lib/fuse_kern_chan.c
modified:   util/fusermount.c
Reuben Hawkins [Fri, 20 May 2011 14:01:38 +0000 (07:01 -0700)]
 
cleaning up warnings
fprintf(stderr, whatever); -> fprintf(stderr, "%s", whatever);
checking return values on chdir and lockf where we weren't already
modified:   example/cusexmp.c
modified:   example/fioclient.c
modified:   util/fusermount.c
Reuben Hawkins [Thu, 19 May 2011 20:28:04 +0000 (13:28 -0700)]
 
Cleaner build output
Add m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES(yes)]) for cleaner
build output.  The verbose output is still available with 'make V=1'
Miklos Szeredi [Thu, 19 May 2011 13:36:20 +0000 (15:36 +0200)]
 
Fix ioctl ABI
Fix the ambiguity of ioctl ABI on the kernel/userspace boundary
for 32bit vs. 64bit userspace
Miklos Szeredi [Thu, 19 May 2011 13:30:01 +0000 (15:30 +0200)]
 
Add ->forget_multi() operation
Add ->forget_multi() operation to the lowlevel API.  The filesystem
may implement this to process multiple forget requests in one call
Miklos Szeredi [Thu, 19 May 2011 13:26:37 +0000 (15:26 +0200)]
 
Allow batching of forget requests
This allows forget requests to be processed faster and doesn't require
a modification to fuse filesystems.  Reported by Terje Malmedal
Miklos Szeredi [Thu, 19 May 2011 13:09:43 +0000 (15:09 +0200)]
 
Fix splice_read
Miklos Szeredi [Thu, 19 May 2011 12:49:26 +0000 (14:49 +0200)]
 
Disable splice by default
Disable splice by default, add "splice_read", "splice_write" and
"splice_move" options.  Keep the "no_splice_*" variants, which can
disable splice even if the filesystem explicitly enables it.
Miklos Szeredi [Thu, 19 May 2011 11:03:56 +0000 (13:03 +0200)]
 
Don't hide output of /bin/mount
Max Krasnyansky [Fri, 15 Apr 2011 22:19:51 +0000 (15:19 -0700)]
 
Added changelog entry for the auto_unmount option
Max Krasnyansky [Sat, 12 Mar 2011 06:59:14 +0000 (22:59 -0800)]
 
fusermount: Added support for auto_unmount option
When this option is specified fusermount will become a daemon and wait for the
parent to exit or die, which causes control fd to get closed. It will then try
to unmount the original mountpoint.
Max Krasnyansky [Sat, 12 Mar 2011 04:49:18 +0000 (20:49 -0800)]
 
libfuse: Added support for auto_unmount option
This change adds support for "auto_unmount" option to libfuse.
auto_umount option unmounts the fs automatically on application
termination, whether normal or not (segfault, etc).
When auto_unmount option is specified libfuse will alway use
fusermount for mounting the fs. This change is selfcontained but
for complete functionaly it requires auto_unmount support in
fusermount tool.
Miklos Szeredi [Wed, 30 Mar 2011 17:38:22 +0000 (19:38 +0200)]
 
Update ChangeLog
Patches by Laszlo Papp fixing various issues found by the Coverity
checker.
Laszlo Papp [Mon, 7 Mar 2011 13:40:59 +0000 (15:40 +0200)]
 
Check the 'mtablock' for negative value
Laszlo Papp [Mon, 7 Mar 2011 12:49:36 +0000 (14:49 +0200)]
 
Fix a potential null pointer dereference issue
Laszlo Papp [Mon, 7 Mar 2011 12:33:38 +0000 (14:33 +0200)]
 
Fix a potential resource leak (newargv)
Laszlo Papp [Mon, 7 Mar 2011 09:32:22 +0000 (11:32 +0200)]
 
Initialize an allocated, but uninitialized memory
Laszlo Papp [Mon, 7 Mar 2011 09:30:07 +0000 (11:30 +0200)]
 
Initialize the variable properly before passing to any function
Miklos Szeredi [Wed, 30 Mar 2011 17:34:58 +0000 (19:34 +0200)]
 
fusermount: clean up do_mount() function
Miklos Szeredi [Wed, 30 Mar 2011 17:34:58 +0000 (19:34 +0200)]
 
Remove unnecessary variable assignment
Laszlo Papp [Mon, 7 Mar 2011 07:27:52 +0000 (09:27 +0200)]
 
Eliminate the unused value
Miklos Szeredi [Wed, 30 Mar 2011 17:34:58 +0000 (19:34 +0200)]
 
Fix use after free if fuse_reply...() returned ENOENT
Laszlo Papp [Mon, 14 Mar 2011 13:52:39 +0000 (15:52 +0200)]
 
Fix resource leaks in fusermount
Laszlo Papp [Mon, 14 Mar 2011 13:38:08 +0000 (15:38 +0200)]
 
Fix a possible resource leak (free the old up)
Laszlo Papp [Mon, 14 Mar 2011 16:45:39 +0000 (18:45 +0200)]
 
Do not pass NULL to xstrdup
Laszlo Papp [Tue, 15 Mar 2011 08:33:08 +0000 (10:33 +0200)]
 
Check the return value properly before passing it to any function
Laszlo Papp [Mon, 14 Mar 2011 12:58:16 +0000 (14:58 +0200)]
 
Fix a potential resource leak
Laszlo Papp [Tue, 22 Mar 2011 11:38:29 +0000 (13:38 +0200)]
 
Use the return value for error check
Laszlo Papp [Wed, 9 Mar 2011 16:01:30 +0000 (18:01 +0200)]
 
Check the return value after an open syscall
Laszlo Papp [Wed, 9 Mar 2011 15:22:07 +0000 (17:22 +0200)]
 
Check the negative return value after an open syscall
Miklos Szeredi [Fri, 11 Mar 2011 12:51:49 +0000 (13:51 +0100)]
 
In case of failure to add to /etc/mtab don't umount.
Reported by Marc Deslauriers
Miklos Szeredi [Fri, 11 Mar 2011 12:46:13 +0000 (13:46 +0100)]
 
Revert "Fix cleanup in case of failed mount"
This reverts commit 
bf5ffb5fd8558bd799791834def431c0cee5a11f.
Cleanup of mount doesn't work the way it was envisioned, because the
kernel doesn't follow mounts on the umount() call, hence it will find
a non-mounted directory.
Miklos Szeredi [Thu, 17 Feb 2011 13:22:38 +0000 (14:22 +0100)]
 
Add  -onoforget to help output
Miklos Szeredi [Wed, 2 Feb 2011 11:18:38 +0000 (12:18 +0100)]
 
libfuse: fuse_session_loop_mt() shouldn't pause when exiting worker threads
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
Miklos Szeredi [Mon, 31 Jan 2011 15:22:41 +0000 (16:22 +0100)]
 
fusermount: only allow mount and umount if util-linux suppports --no-canonicalize
Remove "legacy" util-linux support as missing --no-canonicalize cannot
be worked around in fuse.
Miklos Szeredi [Mon, 31 Jan 2011 11:36:32 +0000 (12:36 +0100)]
 
fusermount: chdir to / before performing mount/umount
Miklos Szeredi [Mon, 31 Jan 2011 15:32:46 +0000 (16:32 +0100)]
 
Fix cleanup in case of failed mount
In case of failure to add to /etc/mtab use same mountpoint for cleanup
as for mounting.  Reported by Marc Deslauriers
Miklos Szeredi [Mon, 31 Jan 2011 11:18:06 +0000 (12:18 +0100)]
 
Fix warning in hash calculation
Fix the following warning:
  fuse.c:436: warning: this decimal constant is unsigned only in ISO C90
Miklos Szeredi [Mon, 20 Dec 2010 17:50:13 +0000 (18:50 +0100)]
 
Highlevel lib: add slab allocation for node cache
This will allow the memory used by the filesystem to grow and shrink
depending on how many inodes are currently cached.
Miklos Szeredi [Mon, 20 Dec 2010 17:50:13 +0000 (18:50 +0100)]
 
inline short names
In the high level library store names shorter than 32 characters
inside "struct node".  Longer names are allocated as previously.
Miklos Szeredi [Mon, 20 Dec 2010 17:50:13 +0000 (18:50 +0100)]
 
Highlevel lib: allow hash tables to shrink
Allow hash tables to shrink as well as grow.
Miklos Szeredi [Mon, 13 Dec 2010 14:46:37 +0000 (15:46 +0100)]
 
Highlevel lib: use dynamically resized hash table
Use dynamically resized hash table for looking up by name and node ID.
The chosen implementation is linear hashing, which features gradual
rehashing when while the size of the table increases.
Miklos Szeredi [Fri, 12 Nov 2010 15:18:17 +0000 (16:18 +0100)]
 
Fix fuse_buf_copy_flags values
Reported-by: Goswin von Brederlow <goswin-v-b@web.de>
Miklos Szeredi [Fri, 12 Nov 2010 14:50:22 +0000 (15:50 +0100)]
 
update test/.gitignore
Miklos Szeredi [Wed, 10 Nov 2010 10:45:50 +0000 (11:45 +0100)]
 
fusexmp_fh: add read_buf and write_buf implementations
In fusexmp_fh implement the ->read_buf() and ->write_buf() methods.
Leave the ->read() and ->write() implementations for reference, even
though they are not necessary.
Miklos Szeredi [Wed, 10 Nov 2010 10:41:21 +0000 (11:41 +0100)]
 
add read_buf method to high level API
Add a new read_buf() method to the highlevel API.  This allows
returning a generic buffer from the read method, which in turn allows
zero copy reads.
Miklos Szeredi [Wed, 10 Nov 2010 10:41:21 +0000 (11:41 +0100)]
 
add write_buf method to high level API
Add new write_buf() method to the highlevel API.  Similarly to the
lowlevel write_buf() method, this allows implementing zero copy
writes.
Miklos Szeredi [Wed, 10 Nov 2010 10:41:21 +0000 (11:41 +0100)]
 
fuse_buf_copy: check if buffers are the same
When copying fuse buffers, check if the source and destination are the
same and omit the copy as appropriate.  Also check if the source and
destination memory regions overlap and use memmove in that case.
Miklos Szeredi [Wed, 10 Nov 2010 10:41:21 +0000 (11:41 +0100)]
 
store fuse_buf inside fuse_bufvec
Store the first fuse_buf inside fuse_bufvec.  This makes
initialization of fuse_bufvec simpler for the common case of a single
fuse_buf.  If multiple fuse_buf's are needed then fuse_bufvec needs to
be dynamically allocated.
Miklos Szeredi [Wed, 10 Nov 2010 10:41:21 +0000 (11:41 +0100)]
 
bump the API version as well to 2.9
Miklos Szeredi [Mon, 8 Nov 2010 20:13:32 +0000 (21:13 +0100)]
 
libfuse: add retrieve request
Retrieve data stored in the kernel buffers for a given inode.
Miklos Szeredi [Mon, 8 Nov 2010 20:11:36 +0000 (21:11 +0100)]
 
fix changelog
Miklos Szeredi [Mon, 8 Nov 2010 20:11:36 +0000 (21:11 +0100)]
 
fix pipe cleanup in do_write_buf()
Miklos Szeredi [Mon, 8 Nov 2010 18:43:41 +0000 (19:43 +0100)]
 
Fix st_nlink for unlinked but still open files
Fix st_nlink value in high level lib if file is unlinked but still open
Miklos Szeredi [Mon, 8 Nov 2010 18:43:41 +0000 (19:43 +0100)]
 
Add ctx->pid to debug output
Miklos Szeredi [Mon, 8 Nov 2010 17:38:23 +0000 (18:38 +0100)]
 
libfuse: add store request
Request data to be stored in the kernel buffers for a given inode.
Miklos Szeredi [Mon, 8 Nov 2010 16:53:47 +0000 (17:53 +0100)]
 
fusermount: don't save/restore cwd
Remove unnecessary restoring of current working directory in
"fusermount -u"
Miklos Szeredi [Mon, 8 Nov 2010 16:13:22 +0000 (17:13 +0100)]
 
bump version to 2.9.0-pre0
Miklos Szeredi [Mon, 8 Nov 2010 16:11:46 +0000 (17:11 +0100)]
 
libfuse: support zero copy writes in lowlevel interface
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.
Miklos Szeredi [Mon, 8 Nov 2010 15:06:37 +0000 (16:06 +0100)]
 
Fix fuse_buf_copy() if already at the end of the buffers
Miklos Szeredi [Mon, 8 Nov 2010 15:00:16 +0000 (16:00 +0100)]
 
update umount procedure
If umount(8) supports --fake and --no-canonicalize (util-linux-ng
version 2.18 or later), and umount(2) supports the UMOUNT_NOFOLLOW
flag (linux kernel version 2.6.35 or later) then, "fusermount -u" will
call the umount(2) system call and use "umount --fake ..." to update
/etc/mtab
Added --disable-legacy-umount option to configure.  This disables the
runtime checking of umount(8) version.  When built with this option
then "fusermount -u" will fail if umount(8) doesn't support the --fake
and --no-canonicalize options.
Miklos Szeredi [Mon, 8 Nov 2010 14:47:36 +0000 (15:47 +0100)]
 
Open /dev/null for write
Open /dev/null for write instead of read for redirecting stdout and
stderr
Miklos Szeredi [Mon, 8 Nov 2010 14:35:35 +0000 (15:35 +0100)]
 
Fix check for read-only fs in mtab update
Natanael Copa [Thu, 14 Oct 2010 08:36:26 +0000 (08:36 +0000)]
 
Use LTLIBICONV when linking libfuse
This fixes building against uclibc + libiconv.
Signed-off-by: Natanael Copa <ncopa@alpinelinux.org>
mkmm@gmx-topmail.de [Tue, 5 Oct 2010 11:00:06 +0000 (13:00 +0200)]
 
add missing argument check in ulockmgr.c
Add missing argument check in ulockmgr.c to prevent calling
ulockmgr_server with illegal arguments. This would cause an ever growing
list of ulockmgr_server processes with an endless list of open files which
finally exceeds the open file handle limit.
It appears samba is sometimes calling flock with illegal / weired values.