/* $OpenBSD: fusebuf.c,v 1.10 2014/12/03 23:00:49 deraadt Exp $ */ /* * Copyright (c) 2012-2013 Sylvestre Gallon * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #include #include #include #include #include #include #include #include #include #include "fusefs_node.h" #include "fusefs.h" struct fusebuf * fb_setup(size_t len, ino_t ino, int op, struct proc *p) { struct fusebuf *fbuf; fbuf = pool_get(&fusefs_fbuf_pool, PR_WAITOK | PR_ZERO); fbuf->fb_len = len; fbuf->fb_err = 0; arc4random_buf(&fbuf->fb_uuid, sizeof fbuf->fb_uuid); fbuf->fb_type = op; fbuf->fb_ino = ino; if (len == 0) fbuf->fb_dat = NULL; else fbuf->fb_dat = (uint8_t *)malloc(len, M_FUSEFS, M_WAITOK | M_ZERO); return (fbuf); } int fb_queue(dev_t dev, struct fusebuf *fbuf) { int error = 0; fuse_device_queue_fbuf(dev, fbuf); if ((error = tsleep(fbuf, PWAIT, "fuse msg", TSLEEP_TIMEOUT * hz))) { fuse_device_cleanup(dev, fbuf); return (error); } return (fbuf->fb_err); } void fb_delete(struct fusebuf *fbuf) { if (fbuf != NULL) { free(fbuf->fb_dat, M_FUSEFS, 0); pool_put(&fusefs_fbuf_pool, fbuf); } }