default statfs
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 @@
     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 @@
     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));
 }