Zbigniew Jędrzejewski-Szmek 62fe94
From 27c64db6dff88ebe9761dfe3b0c073d2a9bf2e41 Mon Sep 17 00:00:00 2001
Zbigniew Jędrzejewski-Szmek 62fe94
From: =?UTF-8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= <zbyszek@in.waw.pl>
Zbigniew Jędrzejewski-Szmek 62fe94
Date: Sun, 5 Oct 2014 18:41:31 -0400
Zbigniew Jędrzejewski-Szmek 62fe94
Subject: [PATCH] build-sys: use linux/memfd.h if available
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
linux/memfd.h was added linux 3.17, so it might not be widely
Zbigniew Jędrzejewski-Szmek 62fe94
available for a while.
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Also, check if memfd_create is defined, for the HAVE_LINUX_MEMFD_H
Zbigniew Jędrzejewski-Szmek 62fe94
check to have a chance of succeeding.
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
Also, collapse all ifdefs for memfd-related stuff, because they
Zbigniew Jędrzejewski-Szmek 62fe94
were all added together so there's no need to check separately.
Zbigniew Jędrzejewski-Szmek 62fe94
---
Zbigniew Jędrzejewski-Szmek 62fe94
 configure.ac         |  2 ++
Zbigniew Jędrzejewski-Szmek 62fe94
 src/shared/memfd.c   |  6 +++++-
Zbigniew Jędrzejewski-Szmek 62fe94
 src/shared/missing.h | 14 --------------
Zbigniew Jędrzejewski-Szmek 62fe94
 3 files changed, 7 insertions(+), 15 deletions(-)
Zbigniew Jędrzejewski-Szmek 62fe94
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/configure.ac b/configure.ac
Zbigniew Jędrzejewski-Szmek 62fe94
index e33c8f75ac..caf1f0e54e 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/configure.ac
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/configure.ac
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -283,6 +283,7 @@ AM_CONDITIONAL([HAVE_PYTHON_DEVEL], [test "$have_python_devel" = "yes"])
Zbigniew Jędrzejewski-Szmek 62fe94
 AC_SEARCH_LIBS([dlsym], [dl], [], [AC_MSG_ERROR([*** Dynamic linking loader library not found])])
Zbigniew Jędrzejewski-Szmek 62fe94
 AC_CHECK_HEADERS([sys/capability.h], [], [AC_MSG_ERROR([*** POSIX caps headers not found])])
Zbigniew Jędrzejewski-Szmek 62fe94
 AC_CHECK_HEADERS([linux/btrfs.h], [], [])
Zbigniew Jędrzejewski-Szmek 62fe94
+AC_CHECK_HEADERS([linux/memfd.h], [], [])
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 # unconditionally pull-in librt with old glibc versions
Zbigniew Jędrzejewski-Szmek 62fe94
 AC_SEARCH_LIBS([clock_gettime], [rt], [], [])
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -300,6 +301,7 @@ AC_SUBST(RT_LIBS)
Zbigniew Jędrzejewski-Szmek 62fe94
 LIBS="$save_LIBS"
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 AC_CHECK_FUNCS([fanotify_init fanotify_mark])
Zbigniew Jędrzejewski-Szmek 62fe94
+AC_CHECK_FUNCS([memfd_create])
Zbigniew Jędrzejewski-Szmek 62fe94
 AC_CHECK_FUNCS([__secure_getenv secure_getenv])
Zbigniew Jędrzejewski-Szmek 62fe94
 AC_CHECK_DECLS([gettid, pivot_root, name_to_handle_at, setns, LO_FLAGS_PARTSCAN],
Zbigniew Jędrzejewski-Szmek 62fe94
                [], [], [[
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/shared/memfd.c b/src/shared/memfd.c
Zbigniew Jędrzejewski-Szmek 62fe94
index 1feca0c979..162c12f7a7 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/shared/memfd.c
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/shared/memfd.c
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -25,11 +25,15 @@
Zbigniew Jędrzejewski-Szmek 62fe94
 #include <sys/mman.h>
Zbigniew Jędrzejewski-Szmek 62fe94
 #include <sys/prctl.h>
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
+#ifdef HAVE_LINUX_MEMFD_H
Zbigniew Jędrzejewski-Szmek 62fe94
+#  include <linux/memfd.h>
Zbigniew Jędrzejewski-Szmek 62fe94
+#endif
Zbigniew Jędrzejewski-Szmek 62fe94
+
Zbigniew Jędrzejewski-Szmek 62fe94
 #include "util.h"
Zbigniew Jędrzejewski-Szmek 62fe94
 #include "bus-label.h"
Zbigniew Jędrzejewski-Szmek 62fe94
-#include "missing.h"
Zbigniew Jędrzejewski-Szmek 62fe94
 #include "memfd.h"
Zbigniew Jędrzejewski-Szmek 62fe94
 #include "utf8.h"
Zbigniew Jędrzejewski-Szmek 62fe94
+#include "missing.h"
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 int memfd_new(const char *name) {
Zbigniew Jędrzejewski-Szmek 62fe94
         _cleanup_free_ char *g = NULL;
Zbigniew Jędrzejewski-Szmek 62fe94
diff --git a/src/shared/missing.h b/src/shared/missing.h
Zbigniew Jędrzejewski-Szmek 62fe94
index 031fe2d1ce..656921d687 100644
Zbigniew Jędrzejewski-Szmek 62fe94
--- a/src/shared/missing.h
Zbigniew Jędrzejewski-Szmek 62fe94
+++ b/src/shared/missing.h
Zbigniew Jędrzejewski-Szmek 62fe94
@@ -65,25 +65,11 @@
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
 #ifndef F_ADD_SEALS
Zbigniew Jędrzejewski-Szmek 62fe94
 #define F_ADD_SEALS (F_LINUX_SPECIFIC_BASE + 9)
Zbigniew Jędrzejewski-Szmek 62fe94
-#endif
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-#ifndef F_GET_SEALS
Zbigniew Jędrzejewski-Szmek 62fe94
 #define F_GET_SEALS (F_LINUX_SPECIFIC_BASE + 10)
Zbigniew Jędrzejewski-Szmek 62fe94
-#endif
Zbigniew Jędrzejewski-Szmek 62fe94
 
Zbigniew Jędrzejewski-Szmek 62fe94
-#ifndef F_SEAL_SEAL
Zbigniew Jędrzejewski-Szmek 62fe94
 #define F_SEAL_SEAL     0x0001  /* prevent further seals from being set */
Zbigniew Jędrzejewski-Szmek 62fe94
-#endif
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-#ifndef F_SEAL_SHRINK
Zbigniew Jędrzejewski-Szmek 62fe94
 #define F_SEAL_SHRINK   0x0002  /* prevent file from shrinking */
Zbigniew Jędrzejewski-Szmek 62fe94
-#endif
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-#ifndef F_SEAL_GROW
Zbigniew Jędrzejewski-Szmek 62fe94
 #define F_SEAL_GROW     0x0004  /* prevent file from growing */
Zbigniew Jędrzejewski-Szmek 62fe94
-#endif
Zbigniew Jędrzejewski-Szmek 62fe94
-
Zbigniew Jędrzejewski-Szmek 62fe94
-#ifndef F_SEAL_WRITE
Zbigniew Jędrzejewski-Szmek 62fe94
 #define F_SEAL_WRITE    0x0008  /* prevent writes */
Zbigniew Jędrzejewski-Szmek 62fe94
 #endif
Zbigniew Jędrzejewski-Szmek 62fe94