mirror of https://github.com/trapexit/mergerfs.git
Antonio SJ Musumeci
4 years ago
9 changed files with 17 additions and 170 deletions
-
1libfuse/Makefile
-
13libfuse/include/fuse.h
-
7libfuse/include/fuse_common.h
-
8libfuse/include/fuse_lowlevel.h
-
73libfuse/lib/fuse.c
-
1libfuse/lib/fuse_i.h
-
46libfuse/lib/fuse_loop.c
-
2libfuse/lib/fuse_mt.c
-
22libfuse/lib/helper.c
@ -1,46 +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 <stdio.h> |
|||
#include <stdlib.h> |
|||
#include <errno.h> |
|||
|
|||
int fuse_session_loop(struct fuse_session *se) |
|||
{ |
|||
int res = 0; |
|||
struct fuse_chan *ch = fuse_session_next_chan(se, NULL); |
|||
size_t bufsize = fuse_chan_bufsize(ch); |
|||
char *buf = (char*)calloc(bufsize,1); |
|||
if (!buf) { |
|||
fprintf(stderr, "fuse: failed to allocate read buffer\n"); |
|||
return -1; |
|||
} |
|||
|
|||
while (!fuse_session_exited(se)) { |
|||
struct fuse_chan *tmpch = ch; |
|||
struct fuse_buf fbuf = { |
|||
.mem = buf, |
|||
.size = bufsize, |
|||
}; |
|||
|
|||
res = fuse_session_receive_buf(se, &fbuf, &tmpch); |
|||
|
|||
if (res == -EINTR) |
|||
continue; |
|||
if (res <= 0) |
|||
break; |
|||
|
|||
fuse_session_process_buf(se, &fbuf, tmpch); |
|||
} |
|||
|
|||
free(buf); |
|||
fuse_session_reset(se); |
|||
return res < 0 ? -1 : 0; |
|||
} |
Write
Preview
Loading…
Cancel
Save
Reference in new issue