virt-selinux.m4 2.3 KB
Newer Older
1 2
dnl The libselinux.so library
dnl
3
dnl Copyright (C) 2012-2014 Red Hat, Inc.
4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
dnl
dnl This library is free software; you can redistribute it and/or
dnl modify it under the terms of the GNU Lesser General Public
dnl License as published by the Free Software Foundation; either
dnl version 2.1 of the License, or (at your option) any later version.
dnl
dnl This library is distributed in the hope that it will be useful,
dnl but WITHOUT ANY WARRANTY; without even the implied warranty of
dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
dnl Lesser General Public License for more details.
dnl
dnl You should have received a copy of the GNU Lesser General Public
dnl License along with this library.  If not, see
dnl <http://www.gnu.org/licenses/>.
dnl

AC_DEFUN([LIBVIRT_CHECK_SELINUX],[
  LIBVIRT_CHECK_LIB([SELINUX], [selinux],
                    [fgetfilecon_raw], [selinux/selinux.h])

  AC_ARG_WITH([selinux_mount],
25 26
    [AS_HELP_STRING([--with-selinux-mount],
      [set SELinux mount point @<:@default=check@:>@])],
27 28 29 30
    [],
    [with_selinux_mount=check])

  if test "$with_selinux" = "yes"; then
31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
    # libselinux changed signatures between 2.2 and 2.3
    AC_CACHE_CHECK([for selinux setcon parameter type], [gt_cv_setcon_param],
    [AC_COMPILE_IFELSE(
      [AC_LANG_PROGRAM(
         [[
#include <selinux/selinux.h>
int setcon(const security_context_t context);
         ]])],
         [gt_cv_setcon_param='security_context_t'],
         [gt_cv_setcon_param='const char*'])])
    if test "$gt_cv_setcon_param" = 'const char*'; then
       AC_DEFINE_UNQUOTED([SELINUX_CTX_CHAR_PTR], 1,
                          [SELinux uses newer char * for security context])
    fi

46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
    AC_MSG_CHECKING([SELinux mount point])
    if test "$with_selinux_mount" = "check" || test -z "$with_selinux_mount"; then
      if test -d /sys/fs/selinux ; then
        SELINUX_MOUNT=/sys/fs/selinux
      else
        SELINUX_MOUNT=/selinux
      fi
    else
      SELINUX_MOUNT=$with_selinux_mount
    fi
    AC_MSG_RESULT([$SELINUX_MOUNT])
    AC_DEFINE_UNQUOTED([SELINUX_MOUNT], ["$SELINUX_MOUNT"], [SELinux mount point])

    dnl We prefer to use <selinux/label.h> and selabel_open, but can fall
    dnl back to matchpathcon for the sake of RHEL 5's version of libselinux.
    AC_CHECK_HEADERS([selinux/label.h])
  fi
])

AC_DEFUN([LIBVIRT_RESULT_SELINUX],[
  LIBVIRT_RESULT_LIB([SELINUX])
])