maint: refactor SMACK interface to a separate module 18/8318/1
authorPádraig Brady <P@draigBrady.com>
Tue, 2 Jul 2013 02:42:20 +0000 (03:42 +0100)
committerMichael Demeter <michael.demeter@intel.com>
Mon, 12 Aug 2013 22:55:31 +0000 (15:55 -0700)
Consolidate all smack routines and checks in a module.
We replace and wrap the most commonly used smack routines,
which allows removing ifdefs throughout the code.

* gl/lib/smack.h: A new header containing the implementation
of the wrapped and replacement routines.  Note the is_smack_enabled()
routine should be optimized out at compile time when compiled
on a system without libsmack.
* gl/modules/smack: Describe the new module and move the
configure time code here from ...
* m4/jm-macros.m4: ... here.
* bootstrap.conf: Reference the new module.
* src/id.c: Use the routines without ifdefs where possible.
* src/ls.c: Likewise.
* src/mkdir.c: Likewise.
* src/mkfifo.c: Likewise.
* src/mknod.c: Likewise.

bootstrap.conf
gl/lib/smack.h [new file with mode: 0644]
gl/modules/smack [new file with mode: 0644]
m4/jm-macros.m4
src/id.c
src/ls.c
src/mkdir.c
src/mkfifo.c
src/mknod.c

index 824adfb3c15be695e6f4b2c5f88ed6254d3b9427..8579743f71d9cc6cdc55e349778323ff4397ac6c 100644 (file)
@@ -211,6 +211,7 @@ gnulib_modules="
   settime
   sig2str
   sigaction
+  smack
   ssize_t
   statat
   stat-macros
diff --git a/gl/lib/smack.h b/gl/lib/smack.h
new file mode 100644 (file)
index 0000000..dea729e
--- /dev/null
@@ -0,0 +1,46 @@
+/* Include and determine availability of smack routines
+   Copyright (C) 2013 Free Software Foundation, Inc.
+
+   This program is free software: you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation, either version 3 of the License, or
+   (at your option) any later version.
+
+   This program is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+   GNU General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
+
+/* Here we replace or wrap the most common smack functions used by coreutils.
+   Others will need to be protected by HAVE_SMACK.  */
+
+#include <config.h>
+
+#ifdef HAVE_SMACK
+# include <sys/smack.h>
+#else
+static inline ssize_t
+smack_new_label_from_self (char **label)
+{
+  return -1;
+}
+
+static inline int
+smack_set_label_for_self (const char *label)
+{
+  return -1;
+}
+#endif
+
+static inline bool
+is_smack_enabled (void)
+{
+#ifdef HAVE_SMACK
+  return smack_smackfs_path () != NULL;
+#else
+  return false;
+#endif
+}
diff --git a/gl/modules/smack b/gl/modules/smack
new file mode 100644 (file)
index 0000000..a6dcbaa
--- /dev/null
@@ -0,0 +1,42 @@
+Description:
+Include and determine the availability of smack routines
+
+Files:
+lib/smack.h
+
+Depends-on:
+
+configure.ac:
+# Check whether libsmack is available
+LIB_SMACK=
+AC_ARG_ENABLE([libsmack],
+  AC_HELP_STRING([--disable-libsmack], [disable libsmack support]))
+if test "X$enable_libsmack" != "Xno"; then
+  AC_CHECK_LIB([smack], [smack_new_label_from_self],
+    [AC_CHECK_LIB([smack], [smack_new_label_from_path],
+      [AC_CHECK_HEADER([sys/smack.h],
+        [LIB_SMACK=-lsmack
+         AC_DEFINE([HAVE_SMACK], [1], [libsmack usability])]
+      )])])
+  if test "X$LIB_SMACK" = "X"; then
+    if test "X$enable_libsmack" = "Xyes"; then
+      AC_MSG_ERROR([libsmack library was not found or not usable])
+    fi
+  fi
+else
+  AC_MSG_WARN([libsmack support disabled by user])
+fi
+AC_SUBST([LIB_SMACK])
+
+
+Makefile.am:
+lib_SOURCES += smack.h
+
+Include:
+"smack.h"
+
+License:
+LGPL
+
+Maintainer:
+Pádraig Brady
index 649a3444c0b77a8ba788074eed55d5e8ace5efc1..3f95def860fefa6123172e3917587c33f5502a09 100644 (file)
@@ -141,27 +141,6 @@ AC_DEFUN([coreutils_MACROS],
   fi
   AC_SUBST([LIB_CAP])
 
-  # Check whether libsmack is available
-  LIB_SMACK=
-  AC_ARG_ENABLE([libsmack],
-    AC_HELP_STRING([--disable-libsmack], [disable libsmack support]))
-  if test "X$enable_libsmack" != "Xno"; then
-    AC_CHECK_LIB([smack], [smack_new_label_from_self],
-      [AC_CHECK_LIB([smack], [smack_new_label_from_path],
-        [AC_CHECK_HEADER([sys/smack.h],
-          [LIB_SMACK=-lsmack
-           AC_DEFINE([HAVE_SMACK], [1], [libsmack usability])]
-        )])])
-    if test "X$LIB_SMACK" = "X"; then
-      if test "X$enable_libsmack" = "Xyes"; then
-        AC_MSG_ERROR([libsmack library was not found or not usable])
-      fi
-    fi
-  else
-    AC_MSG_WARN([libsmack support disabled by user])
-  fi
-  AC_SUBST([LIB_SMACK])
-
   # See if linking 'seq' requires -lm.
   # It does on nearly every system.  The single exception (so far) is
   # BeOS which has all the math functions in the normal runtime library
index b7384a7cb988858d1046a8a0876bcc1dd8aa4a02..3e7016f7b34235bbf5e744f7065b5640752befb7 100644 (file)
--- a/src/id.c
+++ b/src/id.c
 #include <grp.h>
 #include <getopt.h>
 #include <selinux/selinux.h>
-#ifdef HAVE_SMACK
-# include <sys/smack.h>
-#endif
 
 #include "system.h"
 #include "error.h"
 #include "mgetgroups.h"
 #include "quote.h"
 #include "group-list.h"
+#include "smack.h"
 
 /* The official name of this program (e.g., no 'g' prefix).  */
 #define PROGRAM_NAME "id"
@@ -110,9 +108,7 @@ main (int argc, char **argv)
 {
   int optc;
   int selinux_enabled = (is_selinux_enabled () > 0);
-#ifdef HAVE_SMACK
-  int smack_enabled = (smack_smackfs_path () != NULL);
-#endif
+  bool smack_enabled = is_smack_enabled ();
 
   /* If true, output the list of all group IDs. -G */
   bool just_group_list = false;
@@ -207,14 +203,11 @@ main (int argc, char **argv)
           || (default_format && ! getenv ("POSIXLY_CORRECT"))))
     {
       /* Report failure only if --context (-Z) was explicitly requested.  */
-      if (selinux_enabled && getcon (&context) && just_context)
+      if ((selinux_enabled && getcon (&context) && just_context)
+          || (smack_enabled
+              && smack_new_label_from_self ((char **) &context) < 0
+              && just_context))
         error (EXIT_FAILURE, 0, _("can't get process context"));
-#ifdef HAVE_SMACK
-      else if (smack_enabled
-               && smack_new_label_from_self ((char **) &context) < 0
-               && just_context)
-        error (EXIT_FAILURE, 0, _("can't get process context"));
-#endif
     }
 
   if (n_ids == 1)
index af972941a3cb95c358cee528e9a29bbe15269bde..ae29bcc5db34694ce6155f1def1e83b322e0a3a2 100644 (file)
--- a/src/ls.c
+++ b/src/ls.c
 #include "obstack.h"
 #include "quote.h"
 #include "quotearg.h"
+#include "smack.h"
 #include "stat-size.h"
 #include "stat-time.h"
 #include "strftime.h"
 # include <sys/capability.h>
 #endif
 
-#ifdef HAVE_SMACK
-# include <sys/smack.h>
-#endif
-
 #define PROGRAM_NAME (ls_mode == LS_LS ? "ls" \
                       : (ls_mode == LS_MULTI_COL \
                          ? "dir" : "vdir"))
@@ -2754,11 +2751,9 @@ free_ent (struct fileinfo *f)
   free (f->linkname);
   if (f->scontext != UNKNOWN_SECURITY_CONTEXT)
     {
-#ifdef HAVE_SMACK
-      if (smack_smackfs_path ())
+      if (is_smack_enabled ())
         free (f->scontext);
       else
-#endif
         freecon (f->scontext);
     }
 }
@@ -2817,7 +2812,7 @@ getfilecon_cache (char const *file, struct fileinfo *f, bool deref)
     }
   int r = 0;
 #ifdef HAVE_SMACK
-  if (smack_smackfs_path ())
+  if (is_smack_enabled ())
     r = smack_new_label_from_path (file, "security.SMACK64", deref,
                                    &f->scontext);
   else
@@ -3022,11 +3017,9 @@ gobble_file (char const *name, enum filetype type, ino_t inode,
 
           if (err == 0)
             {
-#ifdef HAVE_SMACK
-              if (smack_smackfs_path ())
+              if (is_smack_enabled ())
                 have_scontext = ! STREQ ("_", f->scontext);
               else
-#endif
                 have_scontext = ! STREQ ("unlabeled", f->scontext);
             }
           else
index 3c4436006c1b1ee3f50fa73bcb38defeff58bddd..ad88bfa6d1bc3717a8fe535d54c45f98a550e719 100644 (file)
 #include <sys/types.h>
 #include <selinux/selinux.h>
 
-#ifdef HAVE_SMACK
-# include <sys/smack.h>
-#endif
-
 #include "system.h"
 #include "error.h"
 #include "mkdir-p.h"
@@ -33,6 +29,7 @@
 #include "prog-fprintf.h"
 #include "quote.h"
 #include "savewd.h"
+#include "smack.h"
 
 /* The official name of this program (e.g., no 'g' prefix).  */
 #define PROGRAM_NAME "mkdir"
@@ -190,11 +187,9 @@ main (int argc, char **argv)
 
   if (scontext)
     {
-#ifdef HAVE_SMACK
-      if (smack_smackfs_path ())
+      if (is_smack_enabled ())
         ret = smack_set_label_for_self (scontext);
       else
-#endif
         ret = setfscreatecon (scontext);
     }
 
index 731f6af62ecd4ba5891ff0d4a9f50aa48e6a468a..2147172769ce7439de9765b9bb5a179766054fac 100644 (file)
 #include <sys/types.h>
 #include <selinux/selinux.h>
 
-#ifdef HAVE_SMACK
-# include <sys/smack.h>
-#endif
-
 #include "system.h"
 #include "error.h"
 #include "modechange.h"
 #include "quote.h"
+#include "smack.h"
 
 /* The official name of this program (e.g., no 'g' prefix).  */
 #define PROGRAM_NAME "mkfifo"
@@ -115,11 +112,9 @@ main (int argc, char **argv)
 
   if (scontext)
     {
-#ifdef HAVE_SMACK
-      if (smack_smackfs_path ())
+      if (is_smack_enabled ())
         ret = smack_set_label_for_self (scontext);
       else
-#endif
         ret = setfscreatecon (scontext);
     }
 
index d771c38114eaf53a1cc5648b0f853da18198f910..291f002dae9ec8214b4050a62d481fb4ace5b1e6 100644 (file)
 #include <sys/types.h>
 #include <selinux/selinux.h>
 
-#ifdef HAVE_SMACK
-# include <sys/smack.h>
-#endif
-
 #include "system.h"
 #include "error.h"
 #include "modechange.h"
 #include "quote.h"
+#include "smack.h"
 #include "xstrtol.h"
 
 /* The official name of this program (e.g., no 'g' prefix).  */
@@ -168,11 +165,9 @@ main (int argc, char **argv)
 
   if (scontext)
     {
-#ifdef HAVE_SMACK
-      if (smack_smackfs_path ())
+      if (is_smack_enabled ())
         ret = smack_set_label_for_self (scontext);
       else
-#endif
         ret = setfscreatecon (scontext);
     }