| Age | Commit message (Collapse) | Author | Lines | 
|---|
|  | Commit 4dc7e675bb (Don't unhash name in FORGET) broke the forget logic in a
subtle way, resulting in "fuse internal error: node NNN not found" and causing
the filesystem daemon to abort.
Fix by incrementing the node refcount if nlookup goes from zero to one.
Reported by Kyle Lippincott | 
|  | This means that now NULL is a valid path for operations that take a file
descriptor if the file was unlinked and hard_remove option is specified. | 
|  |  | 
|  |  | 
|  | The failure path of try_get_path2() erronously tried to free the "path1" value
(an address on the stack) instead of the allocated string pointed to by "path1".
This caused the library to crash.
Reported by Itay Perl | 
|  | fallocate filesystem operation preallocates media space for the given file.
If fallocate returns success then any subsequent write to the given range
never fails with 'not enough space' error. | 
|  | If the filesystem sets this flag then ->utimens() will receive UTIME_OMIT and
UTIME_NOW values as specified in utimensat(2). | 
|  | 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. | 
|  | 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. | 
|  | When FUSE_NODE_SLAB is not defined, the build fails because of undefined
functions. Attached patch fixes the problem. | 
|  | Use LRU list for cleaning up the cache if the "remember=T" option was
given. | 
|  | 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. | 
|  | This works similar to "noforget" except that eventually the node will
be allowed to expire from the cache. | 
|  | Add ->forget_multi() operation to the lowlevel API.  The filesystem
may implement this to process multiple forget requests in one call | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | Fix the following warning:
  fuse.c:436: warning: this decimal constant is unsigned only in ISO C90 | 
|  | This will allow the memory used by the filesystem to grow and shrink
depending on how many inodes are currently cached. | 
|  | In the high level library store names shorter than 32 characters
inside "struct node".  Longer names are allocated as previously. | 
|  | Allow hash tables to shrink as well as grow. | 
|  | 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. | 
|  | 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. | 
|  | Add new write_buf() method to the highlevel API.  Similarly to the
lowlevel write_buf() method, this allows implementing zero copy
writes. | 
|  | Fix st_nlink value in high level lib if file is unlinked but still open | 
|  | The bulk of it is just about adding ifdef __NetBSD__ where there is
already an ifdef __FreeBSD__
Add a arch=netbsd to deal with NetBSD specifics. I suggests that
arch=bsd could be renamed to arch=freebsd
NetBSD specific linking with -lperfuse
NetBSD patches to lib/mount.c. It turned to be less itrusive to patch
mount;c than mount_bsd.c. I suggest mount_bsd.c could be renamed to 
mount_freebsd.c
Patch from Emmanuel Dreyfus | 
|  | need not be calculated for the following operations: read, write,
flush, release, fsync, readdir, releasedir, fsyncdir, ftruncate,
fgetattr, lock, ioctl and poll. | 
|  |  | 
|  | for mknod, mkdir and create requests by linux kernel version
2.6.31 or later, otherwise the umask is set to zero.  Also
introduce a new feature flag: FUSE_CAP_DONT_MASK.  If the kernel
supports this feature, then this flag will be set in conn->capable
in the ->init() method.  If the filesystem sets this flag in in
conn->want, then the create modes will not be masked.
* Add low level interfaces for lookup cache and attribute
invalidation.  This feature is available in linux kernels 2.6.31
or later.  Patch by John Muir
* Kernel interface version is now 7.12 | 
|  | level lib) functions to query the supplementary group IDs for the
current request.  Currently this is implemented on Linux by
reading from the /proc filesystem. | 
|  |  | 
|  |  | 
|  | for the reply returned ENOENT.  Reported by John Haxby | 
|  |  | 
|  |  | 
|  | "restricted" ioctls are supported (which are defined with the
_IO(), _IOR(), _IOW() or _IOWR() macros).  Unrestricted ioctls
will only be allwed to CUSE (Character Device in Userspace)
servers.  Patch by Tejun Heo | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  |  | 
|  | changing during operations | 
|  |  | 
|  | operations with a NULL path argument, if the filesystem supports it | 
|  |  | 
|  |  |