aboutsummaryrefslogtreecommitdiffstats
path: root/lib/fuse.c
diff options
context:
space:
mode:
authorMiklos Szeredi <miklos@szeredi.hu>2004-03-25 11:17:52 +0000
committerMiklos Szeredi <miklos@szeredi.hu>2004-03-25 11:17:52 +0000
commit77f39949dc5174bc42be9ecf2dda6119e1dd506b (patch)
tree8a4ee5b0dfbf9e67c02a3a8bea0d9a4bd7bcc2e4 /lib/fuse.c
parent4df9cf273fcda4483641af1b1ed4b7d9dc99bee6 (diff)
downloadlibfuse-77f39949dc5174bc42be9ecf2dda6119e1dd506b.tar.gz
default statfs
Diffstat (limited to 'lib/fuse.c')
-rw-r--r--lib/fuse.c21
1 files changed, 14 insertions, 7 deletions
diff --git a/lib/fuse.c b/lib/fuse.c
index 27e331a..2ca30bb 100644
--- a/lib/fuse.c
+++ b/lib/fuse.c
@@ -914,6 +914,13 @@ static void do_write(struct fuse *f, struct fuse_in_header *in,
send_reply(f, in, res, NULL, 0);
}
+static int default_statfs(struct statfs *buf)
+{
+ buf->f_namelen = 255;
+ buf->f_bsize = 512;
+ return 0;
+}
+
static void convert_statfs(struct statfs *statfs, struct fuse_kstatfs *kstatfs)
{
kstatfs->bsize = statfs->f_bsize;
@@ -931,14 +938,14 @@ static void do_statfs(struct fuse *f, struct fuse_in_header *in)
struct fuse_statfs_out arg;
struct statfs buf;
- res = -ENOSYS;
- if(f->op.statfs) {
+ memset(&buf, 0, sizeof(struct statfs));
+ if(f->op.statfs)
res = f->op.statfs("/", &buf);
- if(res == 0) {
- memset(&arg, 0, sizeof(struct fuse_statfs_out));
- convert_statfs(&buf, &arg.st);
- }
- }
+ else
+ res = default_statfs(&buf);
+
+ if(res == 0)
+ convert_statfs(&buf, &arg.st);
send_reply(f, in, res, &arg, sizeof(arg));
}