Blame SOURCES/postfix-3.2.0-large-fs.patch

8c23a1
diff --git a/src/util/fsspace.c b/src/util/fsspace.c
8c23a1
index 50a4aa7..beef3db 100644
8c23a1
--- a/src/util/fsspace.c
8c23a1
+++ b/src/util/fsspace.c
8c23a1
@@ -91,8 +91,15 @@ void    fsspace(const char *path, struct fsspace * sp)
8c23a1
 
8c23a1
     if (statvfs(path, &fsbuf) < 0)
8c23a1
 	msg_fatal("statvfs %s: %m", path);
8c23a1
-    sp->block_size = fsbuf.f_frsize;
8c23a1
-    sp->block_free = fsbuf.f_bavail;
8c23a1
+    if (fsbuf.f_frsize > 0)
8c23a1
+	sp->block_size = fsbuf.f_frsize;
8c23a1
+    else
8c23a1
+	sp->block_size = fsbuf.f_bsize;
8c23a1
+    /* 4G of FS blocks is surely enough space to put a mail in */
8c23a1
+    sp->block_free = 0;
8c23a1
+    sp->block_free = ~sp->block_free;
8c23a1
+    if (fsbuf.f_bavail < sp->block_free)
8c23a1
+	sp->block_free = fsbuf.f_bavail;
8c23a1
 #endif
8c23a1
     if (msg_verbose)
8c23a1
 	msg_info("%s: %s: block size %lu, blocks free %lu",
8c23a1
diff --git a/src/util/sys_defs.h b/src/util/sys_defs.h
8c23a1
index 3f570c4..611d9cd 100644
8c23a1
--- a/src/util/sys_defs.h
8c23a1
+++ b/src/util/sys_defs.h
8c23a1
@@ -768,8 +768,8 @@ extern int initgroups(const char *, int);
8c23a1
 #define GETTIMEOFDAY(t)	gettimeofday(t,(struct timezone *) 0)
8c23a1
 #define ROOT_PATH	"/bin:/usr/bin:/sbin:/usr/sbin"
8c23a1
 #define FIONREAD_IN_TERMIOS_H
8c23a1
-#define USE_STATFS
8c23a1
-#define STATFS_IN_SYS_VFS_H
8c23a1
+#define USE_STATVFS
8c23a1
+#define STATVFS_IN_SYS_STATVFS_H
8c23a1
 #define PREPEND_PLUS_TO_OPTSTRING
8c23a1
 #define HAS_POSIX_REGEXP
8c23a1
 #define HAS_DLOPEN