]> git.ipfire.org Git - thirdparty/xfsprogs-dev.git/blobdiff - include/linux.h
configure: don't check for fallocate
[thirdparty/xfsprogs-dev.git] / include / linux.h
index 6ce344c5ec3f543139be5b451d3fd234fc1e0c9d..95a0deee25945cf00a6339964e438acd04f4a481 100644 (file)
@@ -1,22 +1,15 @@
+// SPDX-License-Identifier: LGPL-2.1
 /*
  * Copyright (c) 2004-2005 Silicon Graphics, Inc.  All Rights Reserved.
- *
- * This program is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Lesser General Public License
- * as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it would be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
- * GNU Lesser General Public License for more details.
- *
- * You should have received a copy of the GNU Lesser General Public License
- * along with this program; if not, write the Free Software Foundation,
- * Inc.,  51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
  */
 #ifndef __XFS_LINUX_H__
 #define __XFS_LINUX_H__
 
+/*
+ * Reminder: anything added to this file will be compiled into downstream
+ * userspace projects!
+ */
+
 #include <uuid/uuid.h>
 #include <sys/vfs.h>
 #include <sys/ioctl.h>
 #include <endian.h>
 #include <stdbool.h>
 #include <stdio.h>
+#include <signal.h>
 #include <asm/types.h>
 #include <mntent.h>
+#include <fcntl.h>
+#include <linux/falloc.h>
 #ifdef OVERRIDE_SYSTEM_FSXATTR
 # define fsxattr sys_fsxattr
 #endif
@@ -39,6 +35,8 @@
 #ifdef OVERRIDE_SYSTEM_FSXATTR
 # undef fsxattr
 #endif
+#include <unistd.h>
+#include <assert.h>
 
 static __inline__ int xfsctl(const char *path, int fd, int cmd, void *p)
 {
@@ -100,7 +98,7 @@ static __inline__ void platform_uuid_unparse(uuid_t *uu, char *buffer)
        uuid_unparse(*uu, buffer);
 }
 
-static __inline__ int platform_uuid_parse(char *buffer, uuid_t *uu)
+static __inline__ int platform_uuid_parse(const char *buffer, uuid_t *uu)
 {
        return uuid_parse(buffer, *uu);
 }
@@ -176,6 +174,35 @@ static inline void platform_mntent_close(struct mntent_cursor * cursor)
        endmntent(cursor->mtabp);
 }
 
+#if defined(FALLOC_FL_ZERO_RANGE)
+static inline int
+platform_zero_range(
+       int             fd,
+       xfs_off_t       start,
+       size_t          len)
+{
+       int ret;
+
+       ret = fallocate(fd, FALLOC_FL_ZERO_RANGE, start, len);
+       if (!ret)
+               return 0;
+       return -errno;
+}
+#else
+#define platform_zero_range(fd, s, l)  (-EOPNOTSUPP)
+#endif
+
+/*
+ * Use SIGKILL to simulate an immediate program crash, without a chance to run
+ * atexit handlers.
+ */
+static inline void
+platform_crash(void)
+{
+       kill(getpid(), SIGKILL);
+       assert(0);
+}
+
 /*
  * Check whether we have to define FS_IOC_FS[GS]ETXATTR ourselves. These
  * are a copy of the definitions moved to linux/uapi/fs.h in the 4.5 kernel,
@@ -222,109 +249,9 @@ struct fsxattr {
 #define FS_XFLAG_COWEXTSIZE    0x00010000      /* CoW extent size allocator hint */
 #endif
 
-#ifdef HAVE_GETFSMAP
-# include <linux/fsmap.h>
-#else
 /*
- *     Structure for FS_IOC_GETFSMAP.
- *
- *     The memory layout for this call are the scalar values defined in
- *     struct fsmap_head, followed by two struct fsmap that describe
- *     the lower and upper bound of mappings to return, followed by an
- *     array of struct fsmap mappings.
- *
- *     fmh_iflags control the output of the call, whereas fmh_oflags report
- *     on the overall record output.  fmh_count should be set to the
- *     length of the fmh_recs array, and fmh_entries will be set to the
- *     number of entries filled out during each call.  If fmh_count is
- *     zero, the number of reverse mappings will be returned in
- *     fmh_entries, though no mappings will be returned.  fmh_reserved
- *     must be set to zero.
- *
- *     The two elements in the fmh_keys array are used to constrain the
- *     output.  The first element in the array should represent the
- *     lowest disk mapping ("low key") that the user wants to learn
- *     about.  If this value is all zeroes, the filesystem will return
- *     the first entry it knows about.  For a subsequent call, the
- *     contents of fsmap_head.fmh_recs[fsmap_head.fmh_count - 1] should be
- *     copied into fmh_keys[0] to have the kernel start where it left off.
- *
- *     The second element in the fmh_keys array should represent the
- *     highest disk mapping ("high key") that the user wants to learn
- *     about.  If this value is all ones, the filesystem will not stop
- *     until it runs out of mapping to return or runs out of space in
- *     fmh_recs.
- *
- *     fmr_device can be either a 32-bit cookie representing a device, or
- *     a 32-bit dev_t if the FMH_OF_DEV_T flag is set.  fmr_physical,
- *     fmr_offset, and fmr_length are expressed in units of bytes.
- *     fmr_owner is either an inode number, or a special value if
- *     FMR_OF_SPECIAL_OWNER is set in fmr_flags.
+ * Reminder: anything added to this file will be compiled into downstream
+ * userspace projects!
  */
-struct fsmap {
-       __u32           fmr_device;     /* device id */
-       __u32           fmr_flags;      /* mapping flags */
-       __u64           fmr_physical;   /* device offset of segment */
-       __u64           fmr_owner;      /* owner id */
-       __u64           fmr_offset;     /* file offset of segment */
-       __u64           fmr_length;     /* length of segment */
-       __u64           fmr_reserved[3];        /* must be zero */
-};
-
-struct fsmap_head {
-       __u32           fmh_iflags;     /* control flags */
-       __u32           fmh_oflags;     /* output flags */
-       __u32           fmh_count;      /* # of entries in array incl. input */
-       __u32           fmh_entries;    /* # of entries filled in (output). */
-       __u64           fmh_reserved[6];        /* must be zero */
-
-       struct fsmap    fmh_keys[2];    /* low and high keys for the mapping search */
-       struct fsmap    fmh_recs[];     /* returned records */
-};
-
-/* Size of an fsmap_head with room for nr records. */
-static inline size_t
-fsmap_sizeof(
-       unsigned int    nr)
-{
-       return sizeof(struct fsmap_head) + nr * sizeof(struct fsmap);
-}
-
-/* Start the next fsmap query at the end of the current query results. */
-static inline void
-fsmap_advance(
-       struct fsmap_head       *head)
-{
-       head->fmh_keys[0] = head->fmh_recs[head->fmh_entries - 1];
-}
-
-/*     fmh_iflags values - set by XFS_IOC_GETFSMAP caller in the header. */
-/* no flags defined yet */
-#define FMH_IF_VALID           0
-
-/*     fmh_oflags values - returned in the header segment only. */
-#define FMH_OF_DEV_T           0x1     /* fmr_device values will be dev_t */
-
-/*     fmr_flags values - returned for each non-header segment */
-#define FMR_OF_PREALLOC                0x1     /* segment = unwritten pre-allocation */
-#define FMR_OF_ATTR_FORK       0x2     /* segment = attribute fork */
-#define FMR_OF_EXTENT_MAP      0x4     /* segment = extent map */
-#define FMR_OF_SHARED          0x8     /* segment = shared with another file */
-#define FMR_OF_SPECIAL_OWNER   0x10    /* owner is a special value */
-#define FMR_OF_LAST            0x20    /* segment is the last in the FS */
-
-/* Each FS gets to define its own special owner codes. */
-#define FMR_OWNER(type, code)  (((__u64)type << 32) | \
-                                ((__u64)code & 0xFFFFFFFFULL))
-#define FMR_OWNER_TYPE(owner)  ((__u32)((__u64)owner >> 32))
-#define FMR_OWNER_CODE(owner)  ((__u32)(((__u64)owner & 0xFFFFFFFFULL)))
-#define FMR_OWN_FREE           FMR_OWNER(0, 1) /* free space */
-#define FMR_OWN_UNKNOWN                FMR_OWNER(0, 2) /* unknown owner */
-#define FMR_OWN_METADATA       FMR_OWNER(0, 3) /* metadata */
-
-#define FS_IOC_GETFSMAP                _IOWR('X', 59, struct fsmap_head)
-
-#define HAVE_GETFSMAP
-#endif /* HAVE_GETFSMAP */
 
 #endif /* __XFS_LINUX_H__ */