mirror of https://github.com/trapexit/mergerfs.git
Antonio SJ Musumeci
2 years ago
11 changed files with 193 additions and 4159 deletions
-
3547libfuse/ChangeLog
-
1libfuse/Makefile
-
257libfuse/include/fuse_lowlevel.h
-
14libfuse/lib/fuse.c
-
14libfuse/lib/fuse_i.h
-
103libfuse/lib/fuse_kern_chan.c
-
17libfuse/lib/fuse_loop_mt.c
-
48libfuse/lib/fuse_lowlevel.c
-
94libfuse/lib/fuse_mt.c
-
216libfuse/lib/fuse_session.c
-
15libfuse/lib/helper.c
3547
libfuse/ChangeLog
File diff suppressed because it is too large
View File
File diff suppressed because it is too large
View File
@ -1,103 +0,0 @@ |
|||||
/* |
|
||||
FUSE: Filesystem in Userspace |
|
||||
Copyright (C) 2001-2007 Miklos Szeredi <miklos@szeredi.hu> |
|
||||
|
|
||||
This program can be distributed under the terms of the GNU LGPLv2. |
|
||||
See the file COPYING.LIB |
|
||||
*/ |
|
||||
|
|
||||
#include "fuse_lowlevel.h" |
|
||||
#include "fuse_kernel.h" |
|
||||
#include "fuse_i.h" |
|
||||
|
|
||||
#include <stdio.h> |
|
||||
#include <errno.h> |
|
||||
#include <unistd.h> |
|
||||
#include <assert.h> |
|
||||
|
|
||||
static int fuse_kern_chan_receive(struct fuse_chan **chp, char *buf, |
|
||||
size_t size) |
|
||||
{ |
|
||||
struct fuse_chan *ch = *chp; |
|
||||
int err; |
|
||||
ssize_t res; |
|
||||
struct fuse_session *se = fuse_chan_session(ch); |
|
||||
assert(se != NULL); |
|
||||
|
|
||||
restart: |
|
||||
res = read(fuse_chan_fd(ch), buf, size); |
|
||||
err = errno; |
|
||||
|
|
||||
if (fuse_session_exited(se)) |
|
||||
return 0; |
|
||||
if (res == -1) { |
|
||||
/* ENOENT means the operation was interrupted, it's safe |
|
||||
to restart */ |
|
||||
if (err == ENOENT) |
|
||||
goto restart; |
|
||||
|
|
||||
if (err == ENODEV) { |
|
||||
fuse_session_exit(se); |
|
||||
return 0; |
|
||||
} |
|
||||
/* Errors occurring during normal operation: EINTR (read |
|
||||
interrupted), EAGAIN (nonblocking I/O), ENODEV (filesystem |
|
||||
umounted) */ |
|
||||
if (err != EINTR && err != EAGAIN) |
|
||||
perror("fuse: reading device"); |
|
||||
return -err; |
|
||||
} |
|
||||
if ((size_t) res < sizeof(struct fuse_in_header)) { |
|
||||
fprintf(stderr, "short read on fuse device\n"); |
|
||||
return -EIO; |
|
||||
} |
|
||||
return res; |
|
||||
} |
|
||||
|
|
||||
static int fuse_kern_chan_send(struct fuse_chan *ch, const struct iovec iov[], |
|
||||
size_t count) |
|
||||
{ |
|
||||
if (iov) { |
|
||||
ssize_t res = writev(fuse_chan_fd(ch), iov, count); |
|
||||
int err = errno; |
|
||||
|
|
||||
if (res == -1) { |
|
||||
struct fuse_session *se = fuse_chan_session(ch); |
|
||||
|
|
||||
assert(se != NULL); |
|
||||
|
|
||||
/* ENOENT means the operation was interrupted */ |
|
||||
if (!fuse_session_exited(se) && err != ENOENT) |
|
||||
perror("fuse: writing device"); |
|
||||
return -err; |
|
||||
} |
|
||||
} |
|
||||
return 0; |
|
||||
} |
|
||||
|
|
||||
static void fuse_kern_chan_destroy(struct fuse_chan *ch) |
|
||||
{ |
|
||||
int fd = fuse_chan_fd(ch); |
|
||||
|
|
||||
if (fd != -1) |
|
||||
close(fd); |
|
||||
} |
|
||||
|
|
||||
struct fuse_chan * |
|
||||
fuse_kern_chan_new(int fd_) |
|
||||
{ |
|
||||
long pagesize; |
|
||||
size_t bufsize; |
|
||||
struct fuse_chan_ops op = |
|
||||
{ |
|
||||
.receive = fuse_kern_chan_receive, |
|
||||
.send = fuse_kern_chan_send, |
|
||||
.destroy = fuse_kern_chan_destroy, |
|
||||
}; |
|
||||
|
|
||||
pagesize = sysconf(_SC_PAGESIZE); |
|
||||
|
|
||||
bufsize = ((FUSE_MAX_MAX_PAGES * pagesize) + 0x1000); |
|
||||
|
|
||||
return fuse_chan_new(&op, fd_, bufsize, NULL); |
|
||||
} |
|
Write
Preview
Loading…
Cancel
Save
Reference in new issue