static void delete_node(struct fuse *f, struct node *node)
{
- if (f->conf.debug) {
- printf("delete: %llu\n", (unsigned long long) node->nodeid);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "delete: %llu\n", (unsigned long long) node->nodeid);
+
assert(!node->name);
unhash_id(f, node);
free_node(node);
pthread_mutex_unlock(&f->lock);
}
set_stat(f, e->ino, &e->attr);
- if (f->conf.debug) {
- printf(" NODEID: %lu\n", (unsigned long) e->ino);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, " NODEID: %lu\n", (unsigned long) e->ino);
}
}
return res;
path = get_path_name(f, parent, name);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("LOOKUP %s\n", path);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "LOOKUP %s\n", path);
fuse_prepare_interrupt(f, req, &d);
err = lookup_path(f, parent, name, path, &e, NULL);
if (err == -ENOENT && f->conf.negative_timeout != 0.0) {
unsigned long nlookup)
{
struct fuse *f = req_fuse(req);
- if (f->conf.debug) {
- printf("FORGET %llu/%lu\n", (unsigned long long) ino, nlookup);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "FORGET %llu/%lu\n", (unsigned long long)ino, nlookup);
forget_node(f, ino, nlookup);
fuse_reply_none(req);
}
path = get_path(f, ino);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("ACCESS %s 0%o\n", path, mask);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "ACCESS %s 0%o\n", path, mask);
fuse_prepare_interrupt(f, req, &d);
err = fuse_fs_access(f->fs, path, mask);
fuse_finish_interrupt(f, req, &d);
path = get_path_name(f, parent, name);
if (path) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("MKNOD %s\n", path);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "MKNOD %s\n", path);
fuse_prepare_interrupt(f, req, &d);
err = -ENOSYS;
if (S_ISREG(mode)) {
path = get_path_name(f, parent, name);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("MKDIR %s\n", path);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "MKDIR %s\n", path);
fuse_prepare_interrupt(f, req, &d);
err = fuse_fs_mkdir(f->fs, path, mode);
if (!err)
path = get_path_name(f, parent, name);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("UNLINK %s\n", path);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "UNLINK %s\n", path);
fuse_prepare_interrupt(f, req, &d);
if (!f->conf.hard_remove && is_open(f, parent, name))
err = hide_node(f, path, parent, name);
path = get_path_name(f, parent, name);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("RMDIR %s\n", path);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "RMDIR %s\n", path);
fuse_prepare_interrupt(f, req, &d);
err = fuse_fs_rmdir(f->fs, path);
fuse_finish_interrupt(f, req, &d);
path = get_path_name(f, parent, name);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("SYMLINK %s\n", path);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "SYMLINK %s\n", path);
fuse_prepare_interrupt(f, req, &d);
err = fuse_fs_symlink(f->fs, linkname, path);
if (!err)
newpath = get_path_name(f, newdir, newname);
if (newpath != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("RENAME %s -> %s\n", oldpath, newpath);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "RENAME %s -> %s\n", oldpath, newpath);
err = 0;
fuse_prepare_interrupt(f, req, &d);
if (!f->conf.hard_remove && is_open(f, newdir, newname))
newpath = get_path_name(f, newparent, newname);
if (newpath != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("LINK %s\n", newpath);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "LINK %s\n", newpath);
fuse_prepare_interrupt(f, req, &d);
err = fuse_fs_link(f->fs, oldpath, newpath);
if (!err)
fuse_finish_interrupt(f, req, &d);
forget_node(f, e.ino, 1);
} else if (f->conf.debug) {
- printf(" CREATE[%llu] flags: 0x%x %s\n",
- (unsigned long long) fi->fh, fi->flags, path);
- fflush(stdout);
+ fprintf(stderr, " CREATE[%llu] flags: 0x%x %s\n",
+ (unsigned long long) fi->fh, fi->flags, path);
}
} else
reply_err(req, err);
fuse_do_release(f, ino, path, fi);
fuse_finish_interrupt(f, req, &d);
} else if (f->conf.debug) {
- printf("OPEN[%llu] flags: 0x%x %s\n",
- (unsigned long long) fi->fh, fi->flags, path);
- fflush(stdout);
+ fprintf(stderr, "OPEN[%llu] flags: 0x%x %s\n",
+ (unsigned long long) fi->fh, fi->flags, path);
}
} else
reply_err(req, err);
path = get_path(f, ino);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("READ[%llu] %lu bytes from %llu\n",
- (unsigned long long) fi->fh, (unsigned long) size,
- (unsigned long long) off);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "READ[%llu] %lu bytes from %llu\n",
+ (unsigned long long) fi->fh, (unsigned long) size,
+ (unsigned long long) off);
fuse_prepare_interrupt(f, req, &d);
res = fuse_fs_read(f->fs, path, buf, size, off, fi);
pthread_rwlock_unlock(&f->tree_lock);
if (res >= 0) {
- if (f->conf.debug) {
- printf(" READ[%llu] %u bytes\n", (unsigned long long) fi->fh,
- res);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, " READ[%llu] %u bytes\n",
+ (unsigned long long)fi->fh, res);
if ((size_t) res > size)
fprintf(stderr, "fuse: read too many bytes");
fuse_reply_buf(req, buf, res);
path = get_path(f, ino);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("WRITE%s[%llu] %lu bytes to %llu\n",
- fi->writepage ? "PAGE" : "", (unsigned long long) fi->fh,
- (unsigned long) size, (unsigned long long) off);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "WRITE%s[%llu] %lu bytes to %llu\n",
+ fi->writepage ? "PAGE" : "", (unsigned long long) fi->fh,
+ (unsigned long) size, (unsigned long long) off);
fuse_prepare_interrupt(f, req, &d);
res = fuse_fs_write(f->fs, path, buf, size, off, fi);
pthread_rwlock_unlock(&f->tree_lock);
if (res >= 0) {
- if (f->conf.debug) {
- printf(" WRITE%s[%llu] %u bytes\n",
- fi->writepage ? "PAGE" : "", (unsigned long long) fi->fh,
- res);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, " WRITE%s[%llu] %u bytes\n",
+ fi->writepage ? "PAGE" : "", (unsigned long long) fi->fh,
+ res);
if ((size_t) res > size)
fprintf(stderr, "fuse: wrote too many bytes");
fuse_reply_write(req, res);
path = get_path(f, ino);
if (path != NULL) {
struct fuse_intr_data d;
- if (f->conf.debug) {
- printf("FSYNC[%llu]\n", (unsigned long long) fi->fh);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "FSYNC[%llu]\n", (unsigned long long) fi->fh);
fuse_prepare_interrupt(f, req, &d);
err = fuse_fs_fsync(f->fs, path, datasync, fi);
fuse_finish_interrupt(f, req, &d);
pthread_rwlock_rdlock(&f->tree_lock);
path = get_path(f, ino);
- if (f->conf.debug) {
- printf("RELEASE%s[%llu] flags: 0x%x\n", fi->flush ? "+FLUSH" : "",
- (unsigned long long) fi->fh, fi->flags);
- fflush(stdout);
- }
+ if (f->conf.debug)
+ fprintf(stderr, "RELEASE%s[%llu] flags: 0x%x\n",
+ fi->flush ? "+FLUSH" : "",
+ (unsigned long long) fi->fh, fi->flags);
if (fi->flush) {
err = fuse_flush_common(f, req, ino, path, fi);
pthread_rwlock_rdlock(&f->tree_lock);
path = get_path(f, ino);
- if (path && f->conf.debug) {
- printf("FLUSH[%llu]\n", (unsigned long long) fi->fh);
- fflush(stdout);
- }
+ if (path && f->conf.debug)
+ fprintf(stderr, "FLUSH[%llu]\n", (unsigned long long) fi->fh);
err = fuse_flush_common(f, req, ino, path, fi);
free(path);
pthread_rwlock_unlock(&f->tree_lock);
iov[0].iov_len = sizeof(struct fuse_out_header);
out.len = iov_length(iov, count);
- if (req->f->debug) {
- printf(" unique: %llu, error: %i (%s), outsize: %i\n",
- (unsigned long long) out.unique, out.error,
- strerror(-out.error), out.len);
- fflush(stdout);
- }
+ if (req->f->debug)
+ fprintf(stderr, " unique: %llu, error: %i (%s), outsize: %i\n",
+ (unsigned long long) out.unique, out.error,
+ strerror(-out.error), out.len);
res = fuse_chan_send(req->ch, iov, count);
free_req(req);
struct fuse_ll *f = req->f;
(void) nodeid;
- if (f->debug) {
- printf("INTERRUPT: %llu\n", (unsigned long long) arg->unique);
- fflush(stdout);
- }
+ if (f->debug)
+ fprintf(stderr, "INTERRUPT: %llu\n", (unsigned long long) arg->unique);
req->u.i.unique = arg->unique;
(void) nodeid;
if (f->debug) {
- printf("INIT: %u.%u\n", arg->major, arg->minor);
+ fprintf(stderr, "INIT: %u.%u\n", arg->major, arg->minor);
if (arg->major > 7 || (arg->major == 7 && arg->minor >= 6)) {
- printf("flags=0x%08x\n", arg->flags);
- printf("max_readahead=0x%08x\n", arg->max_readahead);
+ fprintf(stderr, "flags=0x%08x\n", arg->flags);
+ fprintf(stderr, "max_readahead=0x%08x\n", arg->max_readahead);
}
- fflush(stdout);
}
f->conn.proto_major = arg->major;
f->conn.proto_minor = arg->minor;
outarg.max_write = f->conn.max_write;
if (f->debug) {
- printf(" INIT: %u.%u\n", outarg.major, outarg.minor);
- printf(" flags=0x%08x\n", outarg.flags);
- printf(" max_readahead=0x%08x\n", outarg.max_readahead);
- printf(" max_write=0x%08x\n", outarg.max_write);
- fflush(stdout);
+ fprintf(stderr, " INIT: %u.%u\n", outarg.major, outarg.minor);
+ fprintf(stderr, " flags=0x%08x\n", outarg.flags);
+ fprintf(stderr, " max_readahead=0x%08x\n", outarg.max_readahead);
+ fprintf(stderr, " max_write=0x%08x\n", outarg.max_write);
}
send_reply_ok(req, &outarg, arg->minor < 5 ? 8 : sizeof(outarg));
const void *inarg = buf + sizeof(struct fuse_in_header);
struct fuse_req *req;
- if (f->debug) {
- printf("unique: %llu, opcode: %s (%i), nodeid: %lu, insize: %zu\n",
- (unsigned long long) in->unique,
- opname((enum fuse_opcode) in->opcode), in->opcode,
- (unsigned long) in->nodeid, len);
- fflush(stdout);
- }
+ if (f->debug)
+ fprintf(stderr, "unique: %llu, opcode: %s (%i), nodeid: %lu, insize: %zu\n",
+ (unsigned long long) in->unique,
+ opname((enum fuse_opcode) in->opcode), in->opcode,
+ (unsigned long) in->nodeid, len);
req = (struct fuse_req *) calloc(1, sizeof(struct fuse_req));
if (req == NULL) {