|
@@ -1,8 +1,9 @@
|
|
|
#include <sys/statvfs.h>
|
|
|
+#include <sys/statfs.h>
|
|
|
#include "syscall.h"
|
|
|
#include "libc.h"
|
|
|
|
|
|
-int statvfs(const char *path, struct statvfs *buf)
|
|
|
+int __statfs(const char *path, struct statfs *buf)
|
|
|
{
|
|
|
#ifdef SYS_statfs64
|
|
|
return syscall(SYS_statfs64, path, sizeof *buf, buf);
|
|
@@ -11,7 +12,50 @@ int statvfs(const char *path, struct statvfs *buf)
|
|
|
#endif
|
|
|
}
|
|
|
|
|
|
-weak_alias(statvfs, statfs);
|
|
|
+int __fstatfs(int fd, struct statfs *buf)
|
|
|
+{
|
|
|
+#ifdef SYS_fstatfs64
|
|
|
+ return syscall(SYS_fstatfs64, fd, sizeof *buf, buf);
|
|
|
+#else
|
|
|
+ return syscall(SYS_fstatfs, fd, buf);
|
|
|
+#endif
|
|
|
+}
|
|
|
+
|
|
|
+weak_alias(__statfs, statfs);
|
|
|
+weak_alias(__fstatfs, fstatfs);
|
|
|
+
|
|
|
+static void fixup(struct statvfs *out, const struct statfs *in)
|
|
|
+{
|
|
|
+ out->f_bsize = in->f_bsize;
|
|
|
+ out->f_frsize = in->f_bsize;
|
|
|
+ out->f_blocks = in->f_blocks;
|
|
|
+ out->f_bfree = in->f_bfree;
|
|
|
+ out->f_bavail = in->f_bavail;
|
|
|
+ out->f_files = in->f_files;
|
|
|
+ out->f_ffree = in->f_ffree;
|
|
|
+ out->f_favail = 0;
|
|
|
+ out->f_fsid = in->f_fsid.val[0];
|
|
|
+ out->f_flag = in->f_flags;
|
|
|
+ out->f_namemax = in->f_namelen;
|
|
|
+}
|
|
|
+
|
|
|
+int statvfs(const char *path, struct statvfs *buf)
|
|
|
+{
|
|
|
+ struct statfs kbuf;
|
|
|
+ if (__statfs(path, &kbuf)<0) return -1;
|
|
|
+ fixup(buf, &kbuf);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
+
|
|
|
+int fstatvfs(int fd, struct statvfs *buf)
|
|
|
+{
|
|
|
+ struct statfs kbuf;
|
|
|
+ if (__fstatfs(fd, &kbuf)<0) return -1;
|
|
|
+ fixup(buf, &kbuf);
|
|
|
+ return 0;
|
|
|
+}
|
|
|
|
|
|
LFS64(statvfs);
|
|
|
LFS64(statfs);
|
|
|
+LFS64(fstatvfs);
|
|
|
+LFS64(fstatfs);
|