|
|
cb8e9e |
From 1397ddaf3a9c75717677b6ee7ca2c7ec096e7f66 Mon Sep 17 00:00:00 2001
|
|
|
cb8e9e |
From: Niels de Vos <ndevos@redhat.com>
|
|
|
cb8e9e |
Date: Wed, 10 Jun 2015 10:09:02 +0200
|
|
|
cb8e9e |
Subject: [PATCH 40/57] build: fix compiling on older distributions
|
|
|
cb8e9e |
|
|
|
cb8e9e |
data-tiering is disabled on RHEL-5 because it depends on a too new
|
|
|
cb8e9e |
SQLite version.
|
|
|
cb8e9e |
|
|
|
cb8e9e |
This change also prevents installing some of files that are used by
|
|
|
cb8e9e |
geo-replication, which is also not available on RHEL-5. geo-replication
|
|
|
cb8e9e |
depends on a too recent version of Python.
|
|
|
cb8e9e |
|
|
|
cb8e9e |
Due to an older version of OpenSSL, some of the newer functions can not
|
|
|
cb8e9e |
be used. A fallback to previous functions is done. Unfortunately RHEL-5
|
|
|
cb8e9e |
does not seem to have TLSv1.2 support, so only older versions can be
|
|
|
cb8e9e |
used.
|
|
|
cb8e9e |
|
|
|
cb8e9e |
Backport of the upstream commits from http://review.gluster.org/11096:
|
|
|
cb8e9e |
> Cherry picked from commit 0209b18fd65f9df5ebd0a8764ebf864d0d392998:
|
|
|
cb8e9e |
> > Change-Id: I672264a673f5432358d2e83b17e2a34efd9fd913
|
|
|
cb8e9e |
> > BUG: 1222317
|
|
|
cb8e9e |
> > Signed-off-by: Niels de Vos <ndevos@redhat.com>
|
|
|
cb8e9e |
> > Reviewed-on: http://review.gluster.org/10803
|
|
|
cb8e9e |
> > Tested-by: NetBSD Build System <jenkins@build.gluster.org>
|
|
|
cb8e9e |
> > Tested-by: Gluster Build System <jenkins@build.gluster.com>
|
|
|
cb8e9e |
> > Reviewed-by: Kaleb KEITHLEY <kkeithle@redhat.com>
|
|
|
cb8e9e |
> > Reviewed-by: Vijay Bellur <vbellur@redhat.com>
|
|
|
cb8e9e |
>
|
|
|
cb8e9e |
> Also including the changes from http://review.gluster.org/11140:
|
|
|
cb8e9e |
>
|
|
|
cb8e9e |
> > build: improve detection of new OpenSSL features
|
|
|
cb8e9e |
> >
|
|
|
cb8e9e |
> > Building on Mac OS X revealed that the current check for
|
|
|
cb8e9e |
> > CRYPTO_THREADID_set_callback() availability in OpenSSL is not correct.
|
|
|
cb8e9e |
> >
|
|
|
cb8e9e |
> > There also does not seem to be a guarantee that TLSv1_2_method() is
|
|
|
cb8e9e |
> > available when TLS1_2_VERSION is #define'd.
|
|
|
cb8e9e |
> >
|
|
|
cb8e9e |
> > Change-Id: I21508065fc181a1c74bee4fd6d23bb5bdf7cea7a
|
|
|
cb8e9e |
> > BUG: 1222317
|
|
|
cb8e9e |
> > Reviewed-on: http://review.gluster.org/11140
|
|
|
cb8e9e |
> > Original-author: Kaleb KEITHLEY <kkeithle@redhat.com>
|
|
|
cb8e9e |
> > Signed-off-by: Niels de Vos <ndevos@redhat.com>
|
|
|
cb8e9e |
>
|
|
|
cb8e9e |
> Change-Id: I672264a673f5432358d2e83b17e2a34efd9fd913
|
|
|
cb8e9e |
> BUG: 1228510
|
|
|
cb8e9e |
> Signed-off-by: Niels de Vos <ndevos@redhat.com>
|
|
|
cb8e9e |
|
|
|
cb8e9e |
Change-Id: I672264a673f5432358d2e83b17e2a34efd9fd913
|
|
|
cb8e9e |
BUG: 1230114
|
|
|
cb8e9e |
Signed-off-by: Niels de Vos <ndevos@redhat.com>
|
|
|
cb8e9e |
Reviewed-on: https://code.engineering.redhat.com/gerrit/50445
|
|
|
cb8e9e |
Reviewed-by: Atin Mukherjee <amukherj@redhat.com>
|
|
|
cb8e9e |
---
|
|
|
cb8e9e |
Makefile.am | 5 ++-
|
|
|
cb8e9e |
configure.ac | 50 ++++++++++++++++++++------------
|
|
|
cb8e9e |
extras/Makefile.am | 4 +-
|
|
|
cb8e9e |
extras/geo-rep/Makefile.am | 2 +-
|
|
|
cb8e9e |
extras/hook-scripts/Makefile.am | 2 +
|
|
|
cb8e9e |
geo-replication/src/Makefile.am | 2 +-
|
|
|
cb8e9e |
glusterfs.spec.in | 47 +++++++++++++++++++++++++------
|
|
|
cb8e9e |
rpc/rpc-transport/socket/src/socket.c | 18 ++++++++++++
|
|
|
cb8e9e |
8 files changed, 97 insertions(+), 33 deletions(-)
|
|
|
cb8e9e |
|
|
|
cb8e9e |
diff --git a/Makefile.am b/Makefile.am
|
|
|
cb8e9e |
index 82175ee..628bc48 100644
|
|
|
cb8e9e |
--- a/Makefile.am
|
|
|
cb8e9e |
+++ b/Makefile.am
|
|
|
cb8e9e |
@@ -15,7 +15,10 @@ SUBDIRS = $(ARGP_STANDALONE_DIR) libglusterfs rpc api xlators glusterfsd \
|
|
|
cb8e9e |
@UMOUNTD_SUBDIR@ tools
|
|
|
cb8e9e |
|
|
|
cb8e9e |
pkgconfigdir = @pkgconfigdir@
|
|
|
cb8e9e |
-pkgconfig_DATA = glusterfs-api.pc libgfchangelog.pc libgfdb.pc
|
|
|
cb8e9e |
+pkgconfig_DATA = glusterfs-api.pc libgfchangelog.pc
|
|
|
cb8e9e |
+if USE_GFDB
|
|
|
cb8e9e |
+pkgconfig_DATA += libgfdb.pc
|
|
|
cb8e9e |
+endif
|
|
|
cb8e9e |
|
|
|
cb8e9e |
CLEANFILES =
|
|
|
cb8e9e |
CONFIG_CLEAN_FILES = $(CONTRIB_BUILDDIR)/uuid/uuid_types.h
|
|
|
cb8e9e |
diff --git a/configure.ac b/configure.ac
|
|
|
cb8e9e |
index 1a09854..a93c1cd 100644
|
|
|
cb8e9e |
--- a/configure.ac
|
|
|
cb8e9e |
+++ b/configure.ac
|
|
|
cb8e9e |
@@ -388,14 +388,7 @@ AC_CHECK_HEADERS([sys/ioctl.h], AC_DEFINE(HAVE_IOCTL_IN_SYS_IOCTL_H, 1, [have sy
|
|
|
cb8e9e |
AC_CHECK_HEADERS([sys/extattr.h])
|
|
|
cb8e9e |
|
|
|
cb8e9e |
dnl Math library
|
|
|
cb8e9e |
-case $host_os in
|
|
|
cb8e9e |
- linux*)
|
|
|
cb8e9e |
- MATH_LIB=''
|
|
|
cb8e9e |
- ;;
|
|
|
cb8e9e |
- *)
|
|
|
cb8e9e |
- MATH_LIB='-lm'
|
|
|
cb8e9e |
- ;;
|
|
|
cb8e9e |
-esac
|
|
|
cb8e9e |
+AC_CHECK_LIB([m], [pow], [MATH_LIB='-lm'], [MATH_LIB=''])
|
|
|
cb8e9e |
AC_SUBST(MATH_LIB)
|
|
|
cb8e9e |
|
|
|
cb8e9e |
dnl use libuuid.so or fall-back to contrib/uuid
|
|
|
cb8e9e |
@@ -406,6 +399,16 @@ PKG_CHECK_MODULES([UUID], [uuid],
|
|
|
cb8e9e |
[HAVE_LIBUUID=no
|
|
|
cb8e9e |
UUID_CFLAGS='-I$(CONTRIBDIR)/uuid'])
|
|
|
cb8e9e |
AM_CONDITIONAL([HAVE_LIBUUID], [test x$HAVE_LIBUUID = xyes])
|
|
|
cb8e9e |
+
|
|
|
cb8e9e |
+dnl older version of libuuid (from e2fsprogs) require including uuid/uuid.h
|
|
|
cb8e9e |
+saved_CFLAGS=${CFLAGS}
|
|
|
cb8e9e |
+CFLAGS="${CFLAGS} ${UUID_CFLAGS}"
|
|
|
cb8e9e |
+AC_CHECK_HEADER([uuid.h], [], [AC_CHECK_HEADER([uuid/uuid.h])])
|
|
|
cb8e9e |
+CFLAGS=${saved_CFLAGS}
|
|
|
cb8e9e |
+if test "x$ac_cv_header_uuid_uuid_h" = "xyes"; then
|
|
|
cb8e9e |
+ UUID_CFLAGS="${UUID_CFLAGS} -I$(pkg-config --variable=includedir uuid)/uuid"
|
|
|
cb8e9e |
+fi
|
|
|
cb8e9e |
+
|
|
|
cb8e9e |
dnl libglusterfs needs uuid.h, practically everything depends on it
|
|
|
cb8e9e |
GF_CPPFLAGS="${GF_CPPFLAGS} ${UUID_CFLAGS}"
|
|
|
cb8e9e |
dnl PKGCONFIG_UUID is used for the dependency in *.pc.in files
|
|
|
cb8e9e |
@@ -530,6 +533,11 @@ fi
|
|
|
cb8e9e |
|
|
|
cb8e9e |
AM_CONDITIONAL([ENABLE_BD_XLATOR], [test x$BUILD_BD_XLATOR = xyes])
|
|
|
cb8e9e |
|
|
|
cb8e9e |
+dnl check for old openssl
|
|
|
cb8e9e |
+AC_CHECK_LIB([crypto], CRYPTO_THREADID_set_callback, [AC_DEFINE([HAVE_CRYPTO_THREADID], [1], [use new OpenSSL functions])])
|
|
|
cb8e9e |
+
|
|
|
cb8e9e |
+AC_CHECK_LIB([ssl], TLSv1_2_method, [AC_DEFINE([HAVE_TLSV1_2_METHOD], [1], [use new OpenSSL functions])])
|
|
|
cb8e9e |
+
|
|
|
cb8e9e |
# start encryption/crypt section
|
|
|
cb8e9e |
|
|
|
cb8e9e |
AC_CHECK_HEADERS([openssl/cmac.h], [have_cmac_h=yes], [have_cmac_h=no])
|
|
|
cb8e9e |
@@ -705,6 +713,7 @@ if test "x$enable_georeplication" != "xno"; then
|
|
|
cb8e9e |
GEOREP_EXTRAS_SUBDIR=geo-rep
|
|
|
cb8e9e |
fi
|
|
|
cb8e9e |
AC_SUBST(GEOREP_EXTRAS_SUBDIR)
|
|
|
cb8e9e |
+AM_CONDITIONAL(USE_GEOREP, test "x$enable_georeplication" != "xno")
|
|
|
cb8e9e |
|
|
|
cb8e9e |
# CDC xlator - check if libz is present if so enable HAVE_LIB_Z
|
|
|
cb8e9e |
BUILD_CDC=yes
|
|
|
cb8e9e |
@@ -808,11 +817,8 @@ AC_SUBST(HAVE_BACKTRACE)
|
|
|
cb8e9e |
|
|
|
cb8e9e |
if test "x${have_backtrace}" != "xyes"; then
|
|
|
cb8e9e |
AC_TRY_COMPILE([#include <math.h>], [double x=0.0; x=ceil(0.0);],
|
|
|
cb8e9e |
- [have_math_h=yes],
|
|
|
cb8e9e |
+ [],
|
|
|
cb8e9e |
AC_MSG_ERROR([need math library for libexecinfo]))
|
|
|
cb8e9e |
-if test "x${have_math_h}" = "xyes"; then
|
|
|
cb8e9e |
- LIBS="$LIBS -lm"
|
|
|
cb8e9e |
-fi
|
|
|
cb8e9e |
fi
|
|
|
cb8e9e |
|
|
|
cb8e9e |
dnl glusterfs prints memory usage to stderr by sending it SIGUSR1
|
|
|
cb8e9e |
@@ -905,26 +911,29 @@ GF_HOST_OS=""
|
|
|
cb8e9e |
GF_LDFLAGS="-rdynamic"
|
|
|
cb8e9e |
|
|
|
cb8e9e |
dnl check for gcc -Werror=format-security
|
|
|
cb8e9e |
-saved_GF_CFLAGS="-Wformat -Werror=format-security"
|
|
|
cb8e9e |
+saved_CFLAGS=$CFLAGS
|
|
|
cb8e9e |
+CFLAGS="-Wformat -Werror=format-security"
|
|
|
cb8e9e |
AC_MSG_CHECKING([whether $CC accepts -Werror=format-security])
|
|
|
cb8e9e |
AC_COMPILE_IFELSE([AC_LANG_PROGRAM()], [cc_werror_format_security=yes], [cc_werror_format_security=no])
|
|
|
cb8e9e |
echo $cc_werror_format_security
|
|
|
cb8e9e |
if test "x$cc_werror_format_security" = "xno"; then
|
|
|
cb8e9e |
- GF_CFLAGS="$GF_CFLAGS"
|
|
|
cb8e9e |
+ CFLAGS="$saved_CFLAGS"
|
|
|
cb8e9e |
else
|
|
|
cb8e9e |
- GF_CFLAGS="$saved_GF_CFLAGS $GF_CFLAGS"
|
|
|
cb8e9e |
+ CFLAGS="$saved_CFLAGS $CFLAGS"
|
|
|
cb8e9e |
+ GF_CFLAGS="$GF_CFLAGS $CFLAGS"
|
|
|
cb8e9e |
fi
|
|
|
cb8e9e |
|
|
|
cb8e9e |
dnl check for gcc -Werror=implicit-function-declaration
|
|
|
cb8e9e |
-saved_GF_CFLAGS=$GF_CFLAGS
|
|
|
cb8e9e |
-GF_CFLAGS="-Werror=implicit-function-declaration"
|
|
|
cb8e9e |
+saved_CFLAGS=$CFLAGS
|
|
|
cb8e9e |
+CFLAGS="-Werror=implicit-function-declaration"
|
|
|
cb8e9e |
AC_MSG_CHECKING([whether $CC accepts -Werror=implicit-function-declaration])
|
|
|
cb8e9e |
AC_COMPILE_IFELSE([AC_LANG_PROGRAM()], [cc_werror_implicit=yes], [cc_werror_implicit=no])
|
|
|
cb8e9e |
echo $cc_werror_implicit
|
|
|
cb8e9e |
if test "x$cc_werror_implicit" = "xno"; then
|
|
|
cb8e9e |
- GF_CFLAGS="$saved_GF_CFLAGS"
|
|
|
cb8e9e |
+ CFLAGS="$saved_CFLAGS"
|
|
|
cb8e9e |
else
|
|
|
cb8e9e |
- GF_CFLAGS="$saved_GF_CFLAGS $GF_CFLAGS"
|
|
|
cb8e9e |
+ CFLAGS="$saved_CFLAGS $CFLAGS"
|
|
|
cb8e9e |
+ GF_CFLAGS="$GF_CFLAGS $CFLAGS"
|
|
|
cb8e9e |
fi
|
|
|
cb8e9e |
|
|
|
cb8e9e |
dnl clang is mostly GCC-compatible, but its version is much lower,
|
|
|
cb8e9e |
@@ -1242,6 +1251,9 @@ AC_SUBST(UNITTEST_LDFLAGS)
|
|
|
cb8e9e |
AC_SUBST(CFLAGS)
|
|
|
cb8e9e |
# end enable debug section
|
|
|
cb8e9e |
|
|
|
cb8e9e |
+dnl libglusterfs.so uses math functions
|
|
|
cb8e9e |
+GF_LDADD="${GF_LDADD} ${MATH_LIB}"
|
|
|
cb8e9e |
+
|
|
|
cb8e9e |
AC_SUBST(GF_HOST_OS)
|
|
|
cb8e9e |
AC_SUBST(GF_CFLAGS)
|
|
|
cb8e9e |
AC_SUBST(GF_LDFLAGS)
|
|
|
cb8e9e |
diff --git a/extras/Makefile.am b/extras/Makefile.am
|
|
|
cb8e9e |
index d54f750..ba2bef3 100644
|
|
|
cb8e9e |
--- a/extras/Makefile.am
|
|
|
cb8e9e |
+++ b/extras/Makefile.am
|
|
|
cb8e9e |
@@ -1,5 +1,5 @@
|
|
|
cb8e9e |
-gsyncddir = $(libexecdir)/glusterfs
|
|
|
cb8e9e |
-gsyncd_SCRIPTS = peer_add_secret_pub
|
|
|
cb8e9e |
+addonexecdir = $(libexecdir)/glusterfs
|
|
|
cb8e9e |
+addonexec_SCRIPTS = peer_add_secret_pub
|
|
|
cb8e9e |
|
|
|
cb8e9e |
EditorModedir = $(docdir)
|
|
|
cb8e9e |
EditorMode_DATA = glusterfs-mode.el glusterfs.vim
|
|
|
cb8e9e |
diff --git a/extras/geo-rep/Makefile.am b/extras/geo-rep/Makefile.am
|
|
|
cb8e9e |
index e0aab77..7ebede3 100644
|
|
|
cb8e9e |
--- a/extras/geo-rep/Makefile.am
|
|
|
cb8e9e |
+++ b/extras/geo-rep/Makefile.am
|
|
|
cb8e9e |
@@ -5,7 +5,7 @@ scripts_DATA = gsync-upgrade.sh generate-gfid-file.sh get-gfid.sh \
|
|
|
cb8e9e |
scripts_PROGRAMS = gsync-sync-gfid
|
|
|
cb8e9e |
gsync_sync_gfid_CFLAGS = $(GF_CFLAGS) -Wall -I$(top_srcdir)/libglusterfs/src
|
|
|
cb8e9e |
gsync_sync_gfid_LDFLAGS = $(GF_LDFLAGS)
|
|
|
cb8e9e |
-gsync_sync_gfid_LDADD = $(GF_LIBS) $(top_builddir)/libglusterfs/src/libglusterfs.la
|
|
|
cb8e9e |
+gsync_sync_gfid_LDADD = $(GF_LDADD) $(top_builddir)/libglusterfs/src/libglusterfs.la
|
|
|
cb8e9e |
gsync_sync_gfid_SOURCES = gsync-sync-gfid.c
|
|
|
cb8e9e |
gsync_sync_gfid_CPPFLAGS = $(GF_CPPFLAGS) -I$(top_srcdir)/libglusterfs/src
|
|
|
cb8e9e |
|
|
|
cb8e9e |
diff --git a/extras/hook-scripts/Makefile.am b/extras/hook-scripts/Makefile.am
|
|
|
cb8e9e |
index fa126f9..771b37e 100644
|
|
|
cb8e9e |
--- a/extras/hook-scripts/Makefile.am
|
|
|
cb8e9e |
+++ b/extras/hook-scripts/Makefile.am
|
|
|
cb8e9e |
@@ -2,4 +2,6 @@ EXTRA_DIST = S40ufo-stop.py S56glusterd-geo-rep-create-post.sh
|
|
|
cb8e9e |
SUBDIRS = add-brick set start stop reset
|
|
|
cb8e9e |
|
|
|
cb8e9e |
scriptsdir = $(GLUSTERD_WORKDIR)/hooks/1/gsync-create/post/
|
|
|
cb8e9e |
+if USE_GEOREP
|
|
|
cb8e9e |
scripts_SCRIPTS = S56glusterd-geo-rep-create-post.sh
|
|
|
cb8e9e |
+endif
|
|
|
cb8e9e |
diff --git a/geo-replication/src/Makefile.am b/geo-replication/src/Makefile.am
|
|
|
cb8e9e |
index e9d6bc1..1572698 100644
|
|
|
cb8e9e |
--- a/geo-replication/src/Makefile.am
|
|
|
cb8e9e |
+++ b/geo-replication/src/Makefile.am
|
|
|
cb8e9e |
@@ -11,7 +11,7 @@ gsyncd_PROGRAMS = gsyncd
|
|
|
cb8e9e |
|
|
|
cb8e9e |
gsyncd_SOURCES = gsyncd.c procdiggy.c
|
|
|
cb8e9e |
|
|
|
cb8e9e |
-gsyncd_LDADD = $(top_builddir)/libglusterfs/src/libglusterfs.la
|
|
|
cb8e9e |
+gsyncd_LDADD = $(GF_LDADD) $(top_builddir)/libglusterfs/src/libglusterfs.la
|
|
|
cb8e9e |
|
|
|
cb8e9e |
gsyncd_LDFLAGS = $(GF_LDFLAGS)
|
|
|
cb8e9e |
|
|
|
cb8e9e |
diff --git a/glusterfs.spec.in b/glusterfs.spec.in
|
|
|
cb8e9e |
index dc87e83..0e69bc6 100644
|
|
|
cb8e9e |
--- a/glusterfs.spec.in
|
|
|
cb8e9e |
+++ b/glusterfs.spec.in
|
|
|
cb8e9e |
@@ -89,6 +89,11 @@
|
|
|
cb8e9e |
%global _without_extra_xlators 1
|
|
|
cb8e9e |
%global _without_regression_tests 1
|
|
|
cb8e9e |
|
|
|
cb8e9e |
+# Disable data-tiering on EL5, sqlite is too old
|
|
|
cb8e9e |
+%if ( 0%{?rhel} && 0%{?rhel} < 6 )
|
|
|
cb8e9e |
+%global _without_tiering --disable-tiering
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
+
|
|
|
cb8e9e |
##-----------------------------------------------------------------------------
|
|
|
cb8e9e |
## All %global definitions should be placed here and keep them sorted
|
|
|
cb8e9e |
##
|
|
|
cb8e9e |
@@ -213,11 +218,17 @@ BuildRequires: libaio-devel libacl-devel
|
|
|
cb8e9e |
BuildRequires: python-devel
|
|
|
cb8e9e |
BuildRequires: python-ctypes
|
|
|
cb8e9e |
BuildRequires: userspace-rcu-devel >= 0.7
|
|
|
cb8e9e |
+%if ( 0%{?rhel} && 0%{?rhel} <= 5 )
|
|
|
cb8e9e |
+BuildRequires: e2fsprogs-devel
|
|
|
cb8e9e |
+%else
|
|
|
cb8e9e |
BuildRequires: libuuid-devel
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
%if ( 0%{?_with_cmocka:1} )
|
|
|
cb8e9e |
BuildRequires: libcmocka-devel >= 1.0.1
|
|
|
cb8e9e |
%endif
|
|
|
cb8e9e |
+%if ( 0%{!?_without_tiering:1} )
|
|
|
cb8e9e |
BuildRequires: sqlite-devel
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
%if ( 0%{!?_without_systemtap:1} )
|
|
|
cb8e9e |
BuildRequires: systemtap-sdt-devel
|
|
|
cb8e9e |
%endif
|
|
|
cb8e9e |
@@ -604,17 +615,19 @@ This package provides the translators needed on any GlusterFS client.
|
|
|
cb8e9e |
# there is no need to run ./autogen or have a BuildRequires for automake.
|
|
|
cb8e9e |
./autogen.sh
|
|
|
cb8e9e |
%configure \
|
|
|
cb8e9e |
+./autogen.sh && %configure \
|
|
|
cb8e9e |
+ %{?_with_cmocka} \
|
|
|
cb8e9e |
%{?_with_tmpfilesdir} \
|
|
|
cb8e9e |
- %{?_without_rdma} \
|
|
|
cb8e9e |
+ %{?_without_bd} \
|
|
|
cb8e9e |
%{?_without_epoll} \
|
|
|
cb8e9e |
%{?_without_fusermount} \
|
|
|
cb8e9e |
%{?_without_georeplication} \
|
|
|
cb8e9e |
%{?_without_ocf} \
|
|
|
cb8e9e |
- %{?_without_syslog} \
|
|
|
cb8e9e |
- %{?_without_bd} \
|
|
|
cb8e9e |
%{?_without_qemu_block} \
|
|
|
cb8e9e |
+ %{?_without_rdma} \
|
|
|
cb8e9e |
+ %{?_without_syslog} \
|
|
|
cb8e9e |
%{?_without_systemtap} \
|
|
|
cb8e9e |
- %{?_with_cmocka}
|
|
|
cb8e9e |
+ %{?_without_tiering}
|
|
|
cb8e9e |
|
|
|
cb8e9e |
# fix hardening and remove rpath in shlibs
|
|
|
cb8e9e |
%if ( 0%{?fedora} && 0%{?fedora} > 17 ) || ( 0%{?rhel} && 0%{?rhel} > 6 )
|
|
|
cb8e9e |
@@ -1032,7 +1045,10 @@ fi
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/error-gen.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/io-stats.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/debug/trace.so
|
|
|
cb8e9e |
+%if ( ! ( 0%{?rhel} && 0%{?rhel} < 6 ) )
|
|
|
cb8e9e |
+# RHEL-5 based distributions have a too old openssl
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/encryption/crypt.so
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/access-control.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/barrier.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/cdc.so
|
|
|
cb8e9e |
@@ -1063,8 +1079,6 @@ fi
|
|
|
cb8e9e |
|
|
|
cb8e9e |
%files api-devel
|
|
|
cb8e9e |
%{_libdir}/pkgconfig/glusterfs-api.pc
|
|
|
cb8e9e |
-%{_libdir}/pkgconfig/libgfchangelog.pc
|
|
|
cb8e9e |
-%{_libdir}/pkgconfig/libgfdb.pc
|
|
|
cb8e9e |
%{_libdir}/libgfapi.so
|
|
|
cb8e9e |
%{_includedir}/glusterfs/api/*
|
|
|
cb8e9e |
|
|
|
cb8e9e |
@@ -1083,12 +1097,18 @@ fi
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/glupy/debug-trace.*
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/glupy/helloworld.*
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/glupy/negative.*
|
|
|
cb8e9e |
+%{_libdir}/pkgconfig/libgfchangelog.pc
|
|
|
cb8e9e |
+%if ( 0%{!?_without_tiering:1} )
|
|
|
cb8e9e |
+%{_libdir}/pkgconfig/libgfdb.pc
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
|
|
|
cb8e9e |
%files client-xlators
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/cluster/*.so
|
|
|
cb8e9e |
%exclude %{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/cluster/pump.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/ganesha.so
|
|
|
cb8e9e |
+%if ( 0%{!?_without_qemu_block:1} )
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/qemu-block.so
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/protocol/client.so
|
|
|
cb8e9e |
|
|
|
cb8e9e |
%if ( 0%{!?_without_extra_xlators:1} )
|
|
|
cb8e9e |
@@ -1151,18 +1171,18 @@ fi
|
|
|
cb8e9e |
%{_datadir}/glusterfs/scripts/generate-gfid-file.sh
|
|
|
cb8e9e |
%{_datadir}/glusterfs/scripts/gsync-sync-gfid
|
|
|
cb8e9e |
%ghost %attr(0644,-,-) %{_sharedstatedir}/glusterd/geo-replication/gsyncd_template.conf
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
%{_libexecdir}/glusterfs/gfind_missing_files
|
|
|
cb8e9e |
%{_sbindir}/gfind_missing_files
|
|
|
cb8e9e |
-%exclude %{_libexecdir}/glusterfs/gfind_missing_files/gfid_to_path.pyo
|
|
|
cb8e9e |
-%exclude %{_libexecdir}/glusterfs/gfind_missing_files/gfid_to_path.pyc
|
|
|
cb8e9e |
-%endif
|
|
|
cb8e9e |
%endif
|
|
|
cb8e9e |
|
|
|
cb8e9e |
%files libs
|
|
|
cb8e9e |
%{_libdir}/*.so.*
|
|
|
cb8e9e |
%exclude %{_libdir}/libgfapi.*
|
|
|
cb8e9e |
+%if ( 0%{!?_without_tiering:1} )
|
|
|
cb8e9e |
# libgfdb is only needed server-side
|
|
|
cb8e9e |
%exclude %{_libdir}/libgfdb.*
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
|
|
|
cb8e9e |
%files -n python-gluster
|
|
|
cb8e9e |
# introducing glusterfs module in site packages.
|
|
|
cb8e9e |
@@ -1234,7 +1254,9 @@ fi
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/arbiter.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/bit-rot.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/bitrot-stub.so
|
|
|
cb8e9e |
+%if ( 0%{!?_without_tiering:1} )
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/changetimerecorder.so
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/index.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/locks.so
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/features/posix*
|
|
|
cb8e9e |
@@ -1247,7 +1269,9 @@ fi
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/nfs*
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/protocol/server*
|
|
|
cb8e9e |
%{_libdir}/glusterfs/%{version}%{?prereltag}/xlator/storage*
|
|
|
cb8e9e |
+%if ( 0%{!?_without_tiering:1} )
|
|
|
cb8e9e |
%{_libdir}/libgfdb.so.*
|
|
|
cb8e9e |
+%endif
|
|
|
cb8e9e |
|
|
|
cb8e9e |
#snap_scheduler
|
|
|
cb8e9e |
%{_sbindir}/snap_scheduler.py
|
|
|
cb8e9e |
@@ -1709,6 +1733,11 @@ end
|
|
|
cb8e9e |
%endif
|
|
|
cb8e9e |
|
|
|
cb8e9e |
%changelog
|
|
|
cb8e9e |
+* Wed Jun 10 2015 Niels de Vos <ndevos@redhat.com>
|
|
|
cb8e9e |
+- Fix building on RHEL-5 based distributions
|
|
|
cb8e9e |
+
|
|
|
cb8e9e |
+* Wed Jun 3 2015 Kaleb S. KEITHLEY <kkeithle@redhat.com>
|
|
|
cb8e9e |
+- move libgf{db,changelog}.pc from -api-devel to -devel (#1223390)
|
|
|
cb8e9e |
* Sun May 31 2015 Milind Changire <mchangir@redhat.com>
|
|
|
cb8e9e |
- Move file peer_add_secret_pub to the server RPM to support glusterfind (#1225552)
|
|
|
cb8e9e |
|
|
|
cb8e9e |
diff --git a/rpc/rpc-transport/socket/src/socket.c b/rpc/rpc-transport/socket/src/socket.c
|
|
|
cb8e9e |
index e30e231..a39c16d 100644
|
|
|
cb8e9e |
--- a/rpc/rpc-transport/socket/src/socket.c
|
|
|
cb8e9e |
+++ b/rpc/rpc-transport/socket/src/socket.c
|
|
|
cb8e9e |
@@ -3714,6 +3714,7 @@ locking_func (int mode, int type, const char *file, int line)
|
|
|
cb8e9e |
}
|
|
|
cb8e9e |
}
|
|
|
cb8e9e |
|
|
|
cb8e9e |
+#if HAVE_CRYPTO_THREADID
|
|
|
cb8e9e |
static void
|
|
|
cb8e9e |
threadid_func (CRYPTO_THREADID *id)
|
|
|
cb8e9e |
{
|
|
|
cb8e9e |
@@ -3729,6 +3730,14 @@ threadid_func (CRYPTO_THREADID *id)
|
|
|
cb8e9e |
*/
|
|
|
cb8e9e |
CRYPTO_THREADID_set_numeric (id, (unsigned long)pthread_self());
|
|
|
cb8e9e |
}
|
|
|
cb8e9e |
+#else /* older openssl */
|
|
|
cb8e9e |
+static unsigned long
|
|
|
cb8e9e |
+legacy_threadid_func (void)
|
|
|
cb8e9e |
+{
|
|
|
cb8e9e |
+ /* See comments above, it applies here too. */
|
|
|
cb8e9e |
+ return (unsigned long)pthread_self();
|
|
|
cb8e9e |
+}
|
|
|
cb8e9e |
+#endif
|
|
|
cb8e9e |
|
|
|
cb8e9e |
static void __attribute__((constructor))
|
|
|
cb8e9e |
init_openssl_mt (void)
|
|
|
cb8e9e |
@@ -3743,7 +3752,11 @@ init_openssl_mt (void)
|
|
|
cb8e9e |
pthread_mutex_init (&lock_array[i], NULL);
|
|
|
cb8e9e |
}
|
|
|
cb8e9e |
CRYPTO_set_locking_callback (locking_func);
|
|
|
cb8e9e |
+#if HAVE_CRYPTO_THREADID
|
|
|
cb8e9e |
CRYPTO_THREADID_set_callback (threadid_func);
|
|
|
cb8e9e |
+#else /* older openssl */
|
|
|
cb8e9e |
+ CRYPTO_set_id_callback (legacy_threadid_func);
|
|
|
cb8e9e |
+#endif
|
|
|
cb8e9e |
constructor_ok = _gf_true;
|
|
|
cb8e9e |
}
|
|
|
cb8e9e |
|
|
|
cb8e9e |
@@ -3992,7 +4005,12 @@ socket_init (rpc_transport_t *this)
|
|
|
cb8e9e |
goto err;
|
|
|
cb8e9e |
}
|
|
|
cb8e9e |
|
|
|
cb8e9e |
+#if HAVE_TLSV1_2_METHOD
|
|
|
cb8e9e |
priv->ssl_meth = (SSL_METHOD *)TLSv1_2_method();
|
|
|
cb8e9e |
+#else /* old openssl */
|
|
|
cb8e9e |
+#warning TLSv1.2 is not available, using insecure TLSv1 support
|
|
|
cb8e9e |
+ priv->ssl_meth = (SSL_METHOD *)TLSv1_method();
|
|
|
cb8e9e |
+#endif
|
|
|
cb8e9e |
priv->ssl_ctx = SSL_CTX_new(priv->ssl_meth);
|
|
|
cb8e9e |
|
|
|
cb8e9e |
if (SSL_CTX_set_cipher_list(priv->ssl_ctx, cipher_list) == 0) {
|
|
|
cb8e9e |
--
|
|
|
cb8e9e |
1.7.1
|
|
|
cb8e9e |
|