Merge master fuse_chan into fuse_session.
authorNikolaus Rath <Nikolaus@rath.org>
Tue, 4 Oct 2016 03:27:02 +0000 (20:27 -0700)
committerNikolaus Rath <Nikolaus@rath.org>
Tue, 4 Oct 2016 06:01:46 +0000 (23:01 -0700)
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 :-).

lib/cuse_lowlevel.c
lib/fuse.c
lib/fuse_i.h
lib/fuse_loop.c
lib/fuse_loop_mt.c
lib/fuse_lowlevel.c

index 8f596cb953b1f2eb513bacdba27f9b46dfd0ac64..03ae9a6e11d4dc9e388b0854500caf429a44d05e 100644 (file)
@@ -275,7 +275,6 @@ struct fuse_session *cuse_lowlevel_setup(int argc, char *argv[],
        };
        struct fuse_args args = FUSE_ARGS_INIT(argc, argv);
        struct fuse_session *se;
-       struct fuse_chan *ch;
        struct fuse_cmdline_opts opts;
        int fd;
        int res;
@@ -312,14 +311,7 @@ struct fuse_session *cuse_lowlevel_setup(int argc, char *argv[],
                                devname, strerror(errno));
                goto err_se;
        }
-
-       ch = fuse_chan_new(fd);
-       if (!ch) {
-               close(fd);
-               goto err_se;
-       }
-
-       fuse_session_add_chan(se, ch);
+       se->fd = fd;
 
        res = fuse_set_signal_handlers(se);
        if (res == -1)
index 2b164a09ce0f34628f722721c9d779a4a244b6e0..8bc6b0a203412ff1c472cfd4980628967a4fe95f 100644 (file)
@@ -4321,9 +4321,8 @@ static int fuse_session_loop_remember(struct fuse *f)
        int res = 0;
        struct timespec now;
        time_t next_clean;
-       struct fuse_chan *ch = fuse_session_chan(se);
        struct pollfd fds = {
-               .fd = ch->fd,
+               .fd = se->fd,
                .events = POLLIN
        };
        struct fuse_buf fbuf = {
@@ -4348,14 +4347,14 @@ static int fuse_session_loop_remember(struct fuse *f)
                        else
                                break;
                } else if (res > 0) {
-                       res = fuse_session_receive_buf_int(se, &fbuf, ch);
+                       res = fuse_session_receive_buf_int(se, &fbuf, NULL);
 
                        if (res == -EINTR)
                                continue;
                        if (res <= 0)
                                break;
 
-                       fuse_session_process_buf_int(se, &fbuf, ch);
+                       fuse_session_process_buf_int(se, &fbuf, NULL);
                } else {
                        timeout = fuse_clean_cache(f);
                        curr_time(&now);
index 16a96d98699c83a21215bbb1fcc6f6fca60b969d..c968321e42b1937a2e288fadeb670c6a89704991 100644 (file)
@@ -9,23 +9,18 @@
 #include "fuse.h"
 #include "fuse_lowlevel.h"
 
-struct fuse_chan;
 struct fuse_ll;
 struct mount_opts;
 
 struct fuse_session {
        struct fuse_ll *f;
        char *mountpoint;
-
        volatile int exited;
-
-       struct fuse_chan *ch;
+       int fd;
        struct mount_opts *mo;
 };
 
 struct fuse_chan {
-       struct fuse_session *se;
-
        pthread_mutex_t lock;
        int ctr;
        int fd;
@@ -116,57 +111,10 @@ struct fuse_module {
        int ctr;
 };
 
-int fuse_chan_clearfd(struct fuse_chan *ch);
-void fuse_chan_close(struct fuse_chan *ch);
-
 /* ----------------------------------------------------------- *
- * Channel interface                                          *
+ * Channel interface (when using -o clone_fd)                 *
  * ----------------------------------------------------------- */
 
- /**
- * Create a new channel
- *
- * @param op channel operations
- * @param fd file descriptor of the channel
- * @return the new channel object, or NULL on failure
- */
-struct fuse_chan *fuse_chan_new(int fd);
-
-/**
- * Query the session to which this channel is assigned
- *
- * @param ch the channel
- * @return the session, or NULL if the channel is not assigned
- */
-struct fuse_session *fuse_chan_session(struct fuse_chan *ch);
-
-/**
- * Remove the channel from a session
- *
- * If the channel is not assigned to a session, then this is a no-op
- *
- * @param ch the channel to remove
- */
-void fuse_session_remove_chan(struct fuse_chan *ch);
-
-/**
- * Assign a channel to a session
- *
- * If a session is destroyed, the assigned channel is also destroyed
- *
- * @param se the session
- * @param ch the channel
- */
-void fuse_session_add_chan(struct fuse_session *se, struct fuse_chan *ch);
-
-/**
- * Return channel assigned to the session
- *
- * @param se the session
- * @return the channel
- */
-struct fuse_chan *fuse_session_chan(struct fuse_session *se);
-
 /**
  * Obtain counted reference to the channel
  *
@@ -182,7 +130,6 @@ struct fuse_chan *fuse_chan_get(struct fuse_chan *ch);
  */
 void fuse_chan_put(struct fuse_chan *ch);
 
-
 struct mount_opts *parse_mount_opts(struct fuse_args *args);
 void destroy_mount_opts(struct mount_opts *mo);
 void fuse_mount_help(void);
index 84142845f7ea29f3237eedde74bc92de9e06e474..4a85b1313912b677a3074bba220ec4bac70af014 100644 (file)
 int fuse_session_loop(struct fuse_session *se)
 {
        int res = 0;
-       struct fuse_chan *ch = fuse_session_chan(se);
        struct fuse_buf fbuf = {
                .mem = NULL,
        };
 
        while (!fuse_session_exited(se)) {
-               res = fuse_session_receive_buf_int(se, &fbuf, ch);
+               res = fuse_session_receive_buf_int(se, &fbuf, NULL);
 
                if (res == -EINTR)
                        continue;
                if (res <= 0)
                        break;
 
-               fuse_session_process_buf_int(se, &fbuf, ch);
+               fuse_session_process_buf_int(se, &fbuf, NULL);
        }
 
        free(fbuf.mem);
index 1d9a5f06e64b52dabefc43fbb60af70027c591fc..c925cd7a9d412677e37351ae5f00cb90ca438d14 100644 (file)
@@ -23,6 +23,7 @@
 #include <errno.h>
 #include <sys/time.h>
 #include <sys/ioctl.h>
+#include <assert.h>
 
 /* Environment var controlling the thread stack size */
 #define ENVNAME_THREAD_STACK "FUSE_THREAD_STACK"
@@ -42,13 +43,53 @@ struct fuse_mt {
        int numworker;
        int numavail;
        struct fuse_session *se;
-       struct fuse_chan *prevch;
        struct fuse_worker main;
        sem_t finish;
        int exit;
        int error;
 };
 
+static struct fuse_chan *fuse_chan_new(int fd)
+{
+       struct fuse_chan *ch = (struct fuse_chan *) malloc(sizeof(*ch));
+       if (ch == NULL) {
+               fprintf(stderr, "fuse: failed to allocate channel\n");
+               return NULL;
+       }
+
+       memset(ch, 0, sizeof(*ch));
+       ch->fd = fd;
+       ch->ctr = 1;
+       fuse_mutex_init(&ch->lock);
+
+       return ch;
+}
+
+struct fuse_chan *fuse_chan_get(struct fuse_chan *ch)
+{
+       assert(ch->ctr > 0);
+       pthread_mutex_lock(&ch->lock);
+       ch->ctr++;
+       pthread_mutex_unlock(&ch->lock);
+
+       return ch;
+}
+
+void fuse_chan_put(struct fuse_chan *ch)
+{
+       if (ch == NULL)
+               return;
+       pthread_mutex_lock(&ch->lock);
+       ch->ctr--;
+       if (!ch->ctr) {
+               pthread_mutex_unlock(&ch->lock);
+               close(ch->fd);
+               pthread_mutex_destroy(&ch->lock);
+               free(ch);
+       } else
+               pthread_mutex_unlock(&ch->lock);
+}
+
 static void list_add_worker(struct fuse_worker *w, struct fuse_worker *next)
 {
        struct fuse_worker *prev = next->prev;
@@ -195,15 +236,13 @@ static struct fuse_chan *fuse_clone_chan(struct fuse_mt *mt)
        }
        fcntl(clonefd, F_SETFD, FD_CLOEXEC);
 
-       masterfd = mt->prevch->fd;
+       masterfd = mt->se->fd;
        res = ioctl(clonefd, FUSE_DEV_IOC_CLONE, &masterfd);
        if (res == -1) {
                fprintf(stderr, "fuse: failed to clone device fd: %s\n",
                        strerror(errno));
                close(clonefd);
-               mt->se->f->clone_fd = 0;
-
-               return fuse_chan_get(mt->prevch);
+               return NULL;
        }
        newch = fuse_chan_new(clonefd);
        if (newch == NULL)
@@ -225,13 +264,15 @@ static int fuse_loop_start_thread(struct fuse_mt *mt)
        w->fbuf.mem = NULL;
        w->mt = mt;
 
-
+       w->ch = NULL;
        if (mt->se->f->clone_fd) {
                w->ch = fuse_clone_chan(mt);
-               if (!w->ch)
-                       return -1;
-       } else {
-               w->ch = fuse_chan_get(mt->prevch);
+               if(!w->ch) {
+                       /* Don't attempt this again */
+                       fprintf(stderr, "fuse: trying to continue "
+                               "without -o clone_fd.\n");
+                       mt->se->f->clone_fd = 0;
+               }
        }
 
        res = fuse_start_thread(&w->thread_id, fuse_do_work, w);
@@ -266,7 +307,6 @@ int fuse_session_loop_mt(struct fuse_session *se)
 
        memset(&mt, 0, sizeof(struct fuse_mt));
        mt.se = se;
-       mt.prevch = fuse_session_chan(se);
        mt.error = 0;
        mt.numworker = 0;
        mt.numavail = 0;
index d7b1fd1e465198d2e3cd990838a60d3e476f0e7b..7acc20663a66cb58ee43996ab4cff9c772419c07 100644 (file)
@@ -161,18 +161,12 @@ static struct fuse_req *fuse_ll_alloc_req(struct fuse_session *se)
        return req;
 }
 
-void fuse_chan_close(struct fuse_chan *ch)
-{
-       int fd = ch->fd;
-       if (fd != -1)
-           close(fd);
-}
-
-
-static int fuse_send_msg(struct fuse_ll *f, struct fuse_chan *ch,
+/* Send data. If *ch* is NULL, send via session master fd */
+static int fuse_send_msg(struct fuse_session *se, struct fuse_chan *ch,
                         struct iovec *iov, int count)
 {
        struct fuse_out_header *out = iov[0].iov_base;
+       struct fuse_ll *f = se->f;
 
        out->len = iov_length(iov, count);
        if (f->debug) {
@@ -191,12 +185,11 @@ static int fuse_send_msg(struct fuse_ll *f, struct fuse_chan *ch,
                }
        }
 
-       ssize_t res = writev(ch->fd, iov, count);
+       ssize_t res = writev(ch ? ch->fd : se->fd,
+                            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 */
@@ -225,7 +218,7 @@ int fuse_send_reply_iov_nofree(fuse_req_t req, int error, struct iovec *iov,
        iov[0].iov_base = &out;
        iov[0].iov_len = sizeof(struct fuse_out_header);
 
-       return fuse_send_msg(req->f, req->ch, iov, count);
+       return fuse_send_msg(req->se, req->ch, iov, count);
 }
 
 static int send_reply_iov(fuse_req_t req, int error, struct iovec *iov,
@@ -480,7 +473,8 @@ int fuse_reply_buf(fuse_req_t req, const char *buf, size_t size)
        return send_reply_ok(req, buf, size);
 }
 
-static int fuse_send_data_iov_fallback(struct fuse_ll *f, struct fuse_chan *ch,
+static int fuse_send_data_iov_fallback(struct fuse_session *se,
+                                      struct fuse_chan *ch,
                                       struct iovec *iov, int iov_count,
                                       struct fuse_bufvec *buf,
                                       size_t len)
@@ -498,7 +492,7 @@ static int fuse_send_data_iov_fallback(struct fuse_ll *f, struct fuse_chan *ch,
                iov[iov_count].iov_base = buf->buf[0].mem;
                iov[iov_count].iov_len = len;
                iov_count++;
-               return fuse_send_msg(f, ch, iov, iov_count);
+               return fuse_send_msg(se, ch, iov, iov_count);
        }
 
        res = posix_memalign(&mbuf, pagesize, len);
@@ -516,7 +510,7 @@ static int fuse_send_data_iov_fallback(struct fuse_ll *f, struct fuse_chan *ch,
        iov[iov_count].iov_base = mbuf;
        iov[iov_count].iov_len = len;
        iov_count++;
-       res = fuse_send_msg(f, ch, iov, iov_count);
+       res = fuse_send_msg(se, ch, iov, iov_count);
        free(mbuf);
 
        return res;
@@ -616,7 +610,7 @@ static int read_back(int fd, char *buf, size_t len)
        return 0;
 }
 
-static int fuse_send_data_iov(struct fuse_ll *f, struct fuse_chan *ch,
+static int fuse_send_data_iov(struct fuse_session *se, struct fuse_chan *ch,
                               struct iovec *iov, int iov_count,
                               struct fuse_bufvec *buf, unsigned int flags)
 {
@@ -624,6 +618,7 @@ static int fuse_send_data_iov(struct fuse_ll *f, struct fuse_chan *ch,
        size_t len = fuse_buf_size(buf);
        struct fuse_out_header *out = iov[0].iov_base;
        struct fuse_ll_pipe *llp;
+       struct fuse_ll *f = se->f;
        int splice_flags;
        size_t pipesize;
        size_t total_fd_size;
@@ -769,7 +764,7 @@ static int fuse_send_data_iov(struct fuse_ll *f, struct fuse_chan *ch,
                        iov[iov_count].iov_base = mbuf;
                        iov[iov_count].iov_len = len;
                        iov_count++;
-                       res = fuse_send_msg(f, ch, iov, iov_count);
+                       res = fuse_send_msg(se, ch, iov, iov_count);
                        free(mbuf);
                        return res;
                }
@@ -790,8 +785,8 @@ static int fuse_send_data_iov(struct fuse_ll *f, struct fuse_chan *ch,
            (f->conn.want & FUSE_CAP_SPLICE_MOVE))
                splice_flags |= SPLICE_F_MOVE;
 
-       res = splice(llp->pipe[0], NULL,
-                    ch->fd, NULL, out->len, splice_flags);
+       res = splice(llp->pipe[0], NULL, ch ? ch->fd : se->fd,
+                    NULL, out->len, splice_flags);
        if (res == -1) {
                res = -errno;
                perror("fuse: splice from pipe");
@@ -810,17 +805,17 @@ clear_pipe:
        return res;
 
 fallback:
-       return fuse_send_data_iov_fallback(f, ch, iov, iov_count, buf, len);
+       return fuse_send_data_iov_fallback(se, ch, iov, iov_count, buf, len);
 }
 #else
-static int fuse_send_data_iov(struct fuse_ll *f, struct fuse_chan *ch,
+static int fuse_send_data_iov(struct fuse_session *se, struct fuse_chan *ch,
                               struct iovec *iov, int iov_count,
                               struct fuse_bufvec *buf, unsigned int flags)
 {
        size_t len = fuse_buf_size(buf);
        (void) flags;
 
-       return fuse_send_data_iov_fallback(f, ch, iov, iov_count, buf, len);
+       return fuse_send_data_iov_fallback(se, ch, iov, iov_count, buf, len);
 }
 #endif
 
@@ -837,7 +832,7 @@ int fuse_reply_data(fuse_req_t req, struct fuse_bufvec *bufv,
        out.unique = req->unique;
        out.error = 0;
 
-       res = fuse_send_data_iov(req->f, req->ch, iov, 1, bufv, flags);
+       res = fuse_send_data_iov(req->se, req->ch, iov, 1, bufv, flags);
        if (res <= 0) {
                fuse_free_req(req);
                return res;
@@ -2081,12 +2076,12 @@ static void do_notify_reply(fuse_req_t req, fuse_ino_t nodeid,
                nreq->reply(nreq, req, nodeid, inarg, buf);
 }
 
-static int send_notify_iov(struct fuse_ll *f, struct fuse_chan *ch,
-                          int notify_code, struct iovec *iov, int count)
+static int send_notify_iov(struct fuse_session *se, int notify_code,
+                          struct iovec *iov, int count)
 {
        struct fuse_out_header out;
 
-       if (!f->got_init)
+       if (!se->f->got_init)
                return -ENOTCONN;
 
        out.unique = 0;
@@ -2094,7 +2089,7 @@ static int send_notify_iov(struct fuse_ll *f, struct fuse_chan *ch,
        iov[0].iov_base = &out;
        iov[0].iov_len = sizeof(struct fuse_out_header);
 
-       return fuse_send_msg(f, ch, iov, count);
+       return fuse_send_msg(se, NULL, iov, count);
 }
 
 int fuse_lowlevel_notify_poll(struct fuse_pollhandle *ph)
@@ -2108,8 +2103,7 @@ int fuse_lowlevel_notify_poll(struct fuse_pollhandle *ph)
                iov[1].iov_base = &outarg;
                iov[1].iov_len = sizeof(outarg);
 
-               return send_notify_iov(ph->se->f, ph->se->ch,
-                                      FUSE_NOTIFY_POLL, iov, 2);
+               return send_notify_iov(ph->se, FUSE_NOTIFY_POLL, iov, 2);
        } else {
                return 0;
        }
@@ -2136,7 +2130,7 @@ int fuse_lowlevel_notify_inval_inode(struct fuse_session *se, fuse_ino_t ino,
        iov[1].iov_base = &outarg;
        iov[1].iov_len = sizeof(outarg);
 
-       return send_notify_iov(f, se->ch, FUSE_NOTIFY_INVAL_INODE, iov, 2);
+       return send_notify_iov(se, FUSE_NOTIFY_INVAL_INODE, iov, 2);
 }
 
 int fuse_lowlevel_notify_inval_entry(struct fuse_session *se, fuse_ino_t parent,
@@ -2162,7 +2156,7 @@ int fuse_lowlevel_notify_inval_entry(struct fuse_session *se, fuse_ino_t parent,
        iov[2].iov_base = (void *)name;
        iov[2].iov_len = namelen + 1;
 
-       return send_notify_iov(f, se->ch, FUSE_NOTIFY_INVAL_ENTRY, iov, 3);
+       return send_notify_iov(se, FUSE_NOTIFY_INVAL_ENTRY, iov, 3);
 }
 
 int fuse_lowlevel_notify_delete(struct fuse_session *se,
@@ -2193,7 +2187,7 @@ int fuse_lowlevel_notify_delete(struct fuse_session *se,
        iov[2].iov_base = (void *)name;
        iov[2].iov_len = namelen + 1;
 
-       return send_notify_iov(f, se->ch, FUSE_NOTIFY_DELETE, iov, 3);
+       return send_notify_iov(se, FUSE_NOTIFY_DELETE, iov, 3);
 }
 
 int fuse_lowlevel_notify_store(struct fuse_session *se, fuse_ino_t ino,
@@ -2230,7 +2224,7 @@ int fuse_lowlevel_notify_store(struct fuse_session *se, fuse_ino_t ino,
        iov[1].iov_base = &outarg;
        iov[1].iov_len = sizeof(outarg);
 
-       res = fuse_send_data_iov(f, se->ch, iov, 2, bufv, flags);
+       res = fuse_send_data_iov(se, NULL, iov, 2, bufv, flags);
        if (res > 0)
                res = -res;
 
@@ -2319,7 +2313,7 @@ int fuse_lowlevel_notify_retrieve(struct fuse_session *se, fuse_ino_t ino,
        iov[1].iov_base = &outarg;
        iov[1].iov_len = sizeof(outarg);
 
-       err = send_notify_iov(f, se->ch, FUSE_NOTIFY_RETRIEVE, iov, 2);
+       err = send_notify_iov(se, FUSE_NOTIFY_RETRIEVE, iov, 2);
        if (err) {
                pthread_mutex_lock(&f->lock);
                list_del_nreq(&rreq->nreq);
@@ -2442,7 +2436,7 @@ static int fuse_ll_copy_from_pipe(struct fuse_bufvec *dst,
 void fuse_session_process_buf(struct fuse_session *se,
                              const struct fuse_buf *buf)
 {
-       fuse_session_process_buf_int(se,  buf, se->ch);
+       fuse_session_process_buf_int(se, buf, NULL);
 }
 
 void fuse_session_process_buf_int(struct fuse_session *se,
@@ -2499,7 +2493,7 @@ void fuse_session_process_buf_int(struct fuse_session *se,
                        .iov_len = sizeof(struct fuse_out_header),
                };
 
-               fuse_send_msg(f, ch, &iov, 1);
+               fuse_send_msg(se, ch, &iov, 1);
                goto clear_pipe;
        }
 
@@ -2507,7 +2501,7 @@ void fuse_session_process_buf_int(struct fuse_session *se,
        req->ctx.uid = in->uid;
        req->ctx.gid = in->gid;
        req->ctx.pid = in->pid;
-       req->ch = fuse_chan_get(ch);
+       req->ch = ch ? fuse_chan_get(ch) : NULL;
 
        err = EIO;
        if (!f->got_init) {
@@ -2684,7 +2678,7 @@ static void fuse_ll_destroy(struct fuse_ll *f)
 void fuse_session_destroy(struct fuse_session *se)
 {
        fuse_ll_destroy(se->f);
-       fuse_chan_put(se->ch);
+       close(se->fd);
        destroy_mount_opts(se->mo);
        free(se);
 }
@@ -2698,7 +2692,7 @@ static void fuse_ll_pipe_destructor(void *data)
 
 int fuse_session_receive_buf(struct fuse_session *se, struct fuse_buf *buf)
 {
-       return fuse_session_receive_buf_int(se, buf, se->ch);
+       return fuse_session_receive_buf_int(se, buf, NULL);
 }
 
 int fuse_session_receive_buf_int(struct fuse_session *se, struct fuse_buf *buf,
@@ -2732,7 +2726,8 @@ int fuse_session_receive_buf_int(struct fuse_session *se, struct fuse_buf *buf,
                        goto fallback;
        }
 
-       res = splice(ch->fd, NULL, llp->pipe[1], NULL, bufsize, 0);
+       res = splice(ch ? ch->fd : se->fd,
+                    NULL, llp->pipe[1], NULL, bufsize, 0);
        err = errno;
 
        if (fuse_session_exited(se))
@@ -2816,7 +2811,7 @@ fallback:
        }
 
 restart:
-       res = read(ch->fd, buf->mem, f->bufsize);
+       res = read(ch ? ch->fd : se->fd, buf->mem, f->bufsize);
        err = errno;
 
        if (fuse_session_exited(se))
@@ -2938,7 +2933,6 @@ out1:
 
 int fuse_session_mount(struct fuse_session *se, const char *mountpoint)
 {
-       struct fuse_chan *ch;
        int fd;
 
        /*
@@ -2955,13 +2949,7 @@ int fuse_session_mount(struct fuse_session *se, const char *mountpoint)
        fd = fuse_kern_mount(mountpoint, se->mo);
        if (fd == -1)
                return -1;
-
-       ch = fuse_chan_new(fd);
-       if (!ch)
-               goto error_out;
-
-       /* Add channel to session */
-       fuse_session_add_chan(se, ch);
+       se->fd = fd;
 
        /* Save mountpoint */
        se->mountpoint = strdup(mountpoint);
@@ -2977,19 +2965,14 @@ error_out:
 
 int fuse_session_fd(struct fuse_session *se)
 {
-       return fuse_session_chan(se)->fd;
+       return se->fd;
 }
 
 void fuse_session_unmount(struct fuse_session *se)
 {
-       fuse_session_remove_chan(se->ch);
-       if (se->mountpoint) {
-               int fd = se->ch ? fuse_chan_clearfd(se->ch) : -1;
-               fuse_kern_unmount(se->mountpoint, fd);
-               fuse_chan_put(se->ch);
-               free(se->mountpoint);
-               se->mountpoint = NULL;
-       }
+       fuse_kern_unmount(se->mountpoint, se->fd);
+       free(se->mountpoint);
+       se->mountpoint = NULL;
 }
 
 #ifdef linux
@@ -3061,36 +3044,6 @@ int fuse_req_getgroups(fuse_req_t req, int size, gid_t list[])
 }
 #endif
 
-void fuse_session_add_chan(struct fuse_session *se, struct fuse_chan *ch)
-{
-       assert(se->ch == NULL);
-       assert(ch->se == NULL);
-       se->ch = ch;
-       ch->se = se;
-}
-
-void fuse_session_remove_chan(struct fuse_chan *ch)
-{
-       struct fuse_session *se = ch->se;
-       if (se) {
-               assert(se->ch == ch);
-               se->ch = NULL;
-               ch->se = NULL;
-       }
-}
-
-struct fuse_chan *fuse_session_chan(struct fuse_session *se)
-{
-       return se->ch;
-}
-
-int fuse_chan_clearfd(struct fuse_chan *ch)
-{
-       int fd = ch->fd;
-       ch->fd = -1;
-       return fd;
-}
-
 void fuse_session_exit(struct fuse_session *se)
 {
        se->exited = 1;
@@ -3105,52 +3058,3 @@ int fuse_session_exited(struct fuse_session *se)
 {
        return se->exited;
 }
-
-struct fuse_chan *fuse_chan_new(int fd)
-{
-       struct fuse_chan *ch = (struct fuse_chan *) malloc(sizeof(*ch));
-       if (ch == NULL) {
-               fprintf(stderr, "fuse: failed to allocate channel\n");
-               return NULL;
-       }
-
-       memset(ch, 0, sizeof(*ch));
-       ch->fd = fd;
-       ch->ctr = 1;
-       fuse_mutex_init(&ch->lock);
-
-       return ch;
-}
-
-struct fuse_session *fuse_chan_session(struct fuse_chan *ch)
-{
-       return ch->se;
-}
-
-struct fuse_chan *fuse_chan_get(struct fuse_chan *ch)
-{
-       assert(ch->ctr > 0);
-       pthread_mutex_lock(&ch->lock);
-       ch->ctr++;
-       pthread_mutex_unlock(&ch->lock);
-
-       return ch;
-}
-
-void fuse_chan_put(struct fuse_chan *ch)
-{
-       if (ch) {
-               pthread_mutex_lock(&ch->lock);
-               ch->ctr--;
-               if (!ch->ctr) {
-                       pthread_mutex_unlock(&ch->lock);
-                       fuse_session_remove_chan(ch);
-                       fuse_chan_close(ch);
-                       pthread_mutex_destroy(&ch->lock);
-                       free(ch);
-               } else {
-                       pthread_mutex_unlock(&ch->lock);
-               }
-
-       }
-}