s3: Fix bug 8777, sys_statvfs() wrapper support for OpenBSD/FreeBSD/DragonFly
authorBrad Smith <brad@comstyle.com>
Sat, 25 Feb 2012 08:28:43 +0000 (09:28 +0100)
committerVolker Lendecke <vl@samba.org>
Sat, 25 Feb 2012 08:42:24 +0000 (09:42 +0100)
source3/configure.in
source3/modules/vfs_default.c
source3/smbd/statvfs.c

index 7b90c8f075dcbe608a737dcebdb6e67872017cbb..dc47f13ff6772cfc10b22f9161bca81b33feccfe 100644 (file)
@@ -6838,13 +6838,21 @@ CFLAGS=$CFLAGS_SAVE
 # Start
 AC_CHECK_FUNC(getmntent)
 
-AC_CHECK_HEADERS(sys/statfs.h)
+AC_CHECK_HEADERS(sys/param.h sys/statfs.h sys/mount.h)
 
 AC_MSG_CHECKING([vfs_fileid: checking for statfs() and struct statfs.f_fsid)])
 AC_CACHE_VAL(vfsfileid_cv_statfs,[
             AC_TRY_RUN([
                #include <sys/types.h>
+               #ifdef HAVE_SYS_PARAM_H
+               #include <sys/param.h>
+               #endif
+               #ifdef HAVE_SYS_MOUNT_H
+               #include <sys/mount.h>
+               #endif
+               #ifdef HAVE_SYS_STATFS_H
                #include <sys/statfs.h>
+               #endif
                int main(void)
                {
                        struct statfs fsd;
index f556f1c49675f532339a4773fc6015b420d12515..d81adadfec7dff282224db6f554d6096c19d71cd 100644 (file)
@@ -111,7 +111,7 @@ static uint32_t vfswrap_fs_capabilities(struct vfs_handle_struct *handle,
        NTSTATUS status;
        int ret = -1;
 
-#if defined(DARWINOS)
+#if defined(DARWINOS) || (defined(BSD) && defined(MNT_RDONLY))
        struct vfs_statvfs_struct statbuf;
        ZERO_STRUCT(statbuf);
        sys_statvfs(conn->connectpath, &statbuf);
index 2de015a2df6a8a2aa70895e76d72d7941c2cf689..bcdcd91c8723a333c19936b722adba5e10fc1f76 100644 (file)
@@ -49,9 +49,7 @@ static int linux_statvfs(const char *path, vfs_statvfs_struct *statbuf)
        }
        return result;
 }
-#endif
-
-#if defined(DARWINOS)
+#elif defined(DARWINOS)
 
 #include <sys/attr.h>
 
@@ -125,6 +123,43 @@ static int darwin_statvfs(const char *path, vfs_statvfs_struct *statbuf)
 
        return 0;
 }
+#elif defined(BSD) && defined(MNT_RDONLY)
+static int bsd_statvfs(const char *path, vfs_statvfs_struct *statbuf)
+{
+       struct statfs statfs_buf;
+       int result;
+
+       result = statfs(path, &statfs_buf);
+       if (result != 0) {
+               return result;
+       }
+
+       statbuf->OptimalTransferSize = statfs_buf.f_iosize;
+       statbuf->BlockSize = statfs_buf.f_bsize;
+       statbuf->TotalBlocks = statfs_buf.f_blocks;
+       statbuf->BlocksAvail = statfs_buf.f_bfree;
+       statbuf->UserBlocksAvail = statfs_buf.f_bavail;
+       statbuf->TotalFileNodes = statfs_buf.f_files;
+       statbuf->FreeFileNodes = statfs_buf.f_ffree;
+       statbuf->FsIdentifier =
+               (((uint64_t) statfs_buf.f_fsid.val[0] << 32) & 0xffffffff00000000LL) |
+                   (uint64_t) statfs_buf.f_fsid.val[1];
+       /* Try to extrapolate some of the fs flags into the
+        * capabilities
+        */
+       statbuf->FsCapabilities =
+           FILE_CASE_SENSITIVE_SEARCH | FILE_CASE_PRESERVED_NAMES;
+#ifdef MNT_ACLS
+       if (statfs_buf.f_flags & MNT_ACLS)
+               statbuf->FsCapabilities |= FILE_PERSISTENT_ACLS;
+#endif
+       if (statfs_buf.f_flags & MNT_QUOTA)
+               statbuf->FsCapabilities |= FILE_VOLUME_QUOTAS;
+       if (statfs_buf.f_flags & MNT_RDONLY)
+               statbuf->FsCapabilities |= FILE_READ_ONLY_VOLUME;
+
+       return 0;
+}
 #endif
 
 /* 
@@ -139,6 +174,8 @@ int sys_statvfs(const char *path, vfs_statvfs_struct *statbuf)
        return linux_statvfs(path, statbuf);
 #elif defined(DARWINOS)
        return darwin_statvfs(path, statbuf);
+#elif defined(BSD) && defined(MNT_RDONLY)
+       return bsd_statvfs(path, statbuf);
 #else
        /* BB change this to return invalid level */
 #ifdef EOPNOTSUPP