Add device_is_mounted() support for NetBSD
[fio.git] / lib / mountcheck.c
index 2eedcc718c1300add44d1b425a2a3ba641af0648..0aec7441f91d412a01fc17d1ec083415f3f58e26 100644 (file)
@@ -4,6 +4,8 @@
 #ifdef CONFIG_GETMNTENT
 #include <mntent.h>
 
 #ifdef CONFIG_GETMNTENT
 #include <mntent.h>
 
+#include "lib/mountcheck.h"
+
 #define MTAB   "/etc/mtab"
 
 int device_is_mounted(const char *dev)
 #define MTAB   "/etc/mtab"
 
 int device_is_mounted(const char *dev)
@@ -30,7 +32,7 @@ int device_is_mounted(const char *dev)
 }
 
 #elif defined(CONFIG_GETMNTINFO)
 }
 
 #elif defined(CONFIG_GETMNTINFO)
-/* for BSDs */
+/* for most BSDs */
 #include <sys/param.h>
 #include <sys/mount.h>
 
 #include <sys/param.h>
 #include <sys/mount.h>
 
@@ -51,4 +53,33 @@ int device_is_mounted(const char *dev)
        return 0;
 }
 
        return 0;
 }
 
+#elif defined(CONFIG_GETMNTINFO_STATVFS)
+/* for NetBSD */
+#include <sys/statvfs.h>
+
+int device_is_mounted(const char *dev)
+{
+       struct statvfs *st;
+       int i, ret;
+
+       ret = getmntinfo(&st, MNT_NOWAIT);
+       if (ret <= 0)
+               return 0;
+
+       for (i = 0; i < ret; i++) {
+               if (!strcmp(st[i].f_mntfromname, dev))
+                       return 1;
+       }
+
+       return 0;
+}
+
+#else
+/* others */
+
+int device_is_mounted(const char *dev)
+{
+       return 0;
+}
+
 #endif
 #endif