tstellar / rpms / ceph

Forked from rpms/ceph 3 years ago
Clone
9b4d322
From 2f0a7153460acc3f21462236f470ec3471fa2ee1 Mon Sep 17 00:00:00 2001
9b4d322
From: Boris Ranto <branto@redhat.com>
9b4d322
Date: Mon, 31 Jul 2017 19:50:23 +0200
9b4d322
Subject: [PATCH] cmake: Support ppc64
9b4d322
9b4d322
The ppc64 support requires a couple of changes:
9b4d322
- adding the ppc64 support to cmake
9b4d322
- changing optimized crc32 code to compile on ppc64le only
9b4d322
- moving ifdef condition before crc32_align to avoid defined but not
9b4d322
used warning
9b4d322
9b4d322
Signed-off-by: Boris Ranto <branto@redhat.com>
9b4d322
---
9b4d322
 cmake/modules/SIMDExt.cmake | 15 ++++++++++++++-
9b4d322
 src/CMakeLists.txt          |  4 +++-
9b4d322
 src/arch/ppc.c              |  8 ++++----
9b4d322
 src/common/crc32c_ppc.c     |  6 +++---
9b4d322
 4 files changed, 24 insertions(+), 9 deletions(-)
9b4d322
9b4d322
diff --git a/cmake/modules/SIMDExt.cmake b/cmake/modules/SIMDExt.cmake
9b4d322
index 5330835..c47667d 100644
9b4d322
--- a/cmake/modules/SIMDExt.cmake
9b4d322
+++ b/cmake/modules/SIMDExt.cmake
9b4d322
@@ -109,7 +109,20 @@ elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "i386|i686|amd64|x86_64|AMD64")
9b4d322
   endif(CMAKE_SYSTEM_PROCESSOR MATCHES "i686|amd64|x86_64|AMD64")
9b4d322
 elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "(powerpc|ppc)64le")
9b4d322
   set(HAVE_PPC64LE 1)
9b4d322
-  message(STATUS " we are ppc64le")
9b4d322
+  message(STATUS " we are ppc64")
9b4d322
+  CHECK_C_COMPILER_FLAG("-maltivec" HAS_ALTIVEC)
9b4d322
+  if(HAS_ALTIVEC)
9b4d322
+    message(STATUS " HAS_ALTIVEC yes")
9b4d322
+    set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -maltivec")
9b4d322
+    set(CMAKE_CXX_FLAGS "${CMAKE_C_FLAGS} -maltivec")
9b4d322
+  endif()
9b4d322
+  CHECK_C_COMPILER_FLAG("-mcpu=power8" HAVE_POWER8)
9b4d322
+  if(HAVE_POWER8)
9b4d322
+    message(STATUS " HAVE_POWER8 yes")
9b4d322
+  endif()
9b4d322
+elseif(CMAKE_SYSTEM_PROCESSOR MATCHES "(power|ppc)64")
9b4d322
+  set(HAVE_PPC64 1)
9b4d322
+  message(STATUS " we are ppc64")
9b4d322
   CHECK_C_COMPILER_FLAG("-maltivec" HAS_ALTIVEC)
9b4d322
   if(HAS_ALTIVEC)
9b4d322
     message(STATUS " HAS_ALTIVEC yes")
9b4d322
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
9b4d322
index 66f0c14..38d1913 100644
9b4d322
--- a/src/CMakeLists.txt
9b4d322
+++ b/src/CMakeLists.txt
9b4d322
@@ -568,7 +568,9 @@ if(HAVE_INTEL)
9b4d322
   endif(HAVE_GOOD_YASM_ELF64)
9b4d322
 elseif(HAVE_POWER8)
9b4d322
   list(APPEND libcommon_files
9b4d322
-    common/crc32c_ppc.c
9b4d322
+    common/crc32c_ppc.c)
9b4d322
+elseif(HAVE_PPC64LE)
9b4d322
+  list(APPEND libcommon_files
9b4d322
     common/crc32c_ppc_asm.S
9b4d322
     common/crc32c_ppc_fast_zero_asm.S)
9b4d322
 endif(HAVE_INTEL)
9b4d322
diff --git a/src/arch/ppc.c b/src/arch/ppc.c
9b4d322
index f21e2fe..11d3a49 100644
9b4d322
--- a/src/arch/ppc.c
9b4d322
+++ b/src/arch/ppc.c
9b4d322
@@ -14,10 +14,10 @@ int ceph_arch_ppc_crc32 = 0;
9b4d322
 
9b4d322
 #include <stdio.h>
9b4d322
 
9b4d322
-#if __linux__ && __powerpc64__
9b4d322
+#ifdef HAVE_PPC64LE
9b4d322
 #include <sys/auxv.h>
9b4d322
 #include <asm/cputable.h>
9b4d322
-#endif /* __linux__ && __powerpc64__ */
9b4d322
+#endif /* HAVE_PPC64LE */
9b4d322
 
9b4d322
 #ifndef PPC_FEATURE2_VEC_CRYPTO
9b4d322
 #define PPC_FEATURE2_VEC_CRYPTO		0x02000000
9b4d322
@@ -31,9 +31,9 @@ int ceph_arch_ppc_probe(void)
9b4d322
 {
9b4d322
   ceph_arch_ppc_crc32 = 0;
9b4d322
 
9b4d322
-#if __linux__ && __powerpc64__
9b4d322
+#ifdef HAVE_PPC64LE
9b4d322
   if (getauxval(AT_HWCAP2) & PPC_FEATURE2_VEC_CRYPTO) ceph_arch_ppc_crc32 = 1;
9b4d322
-#endif /* __linux__ && __powerpc64__ */
9b4d322
+#endif /* HAVE_PPC64LE */
9b4d322
 
9b4d322
   return 0;
9b4d322
 }
9b4d322
diff --git a/src/common/crc32c_ppc.c b/src/common/crc32c_ppc.c
9b4d322
index 43756e2..52fd1c4 100644
9b4d322
--- a/src/common/crc32c_ppc.c
9b4d322
+++ b/src/common/crc32c_ppc.c
9b4d322
@@ -20,6 +20,7 @@
9b4d322
 #define VMX_ALIGN	16
9b4d322
 #define VMX_ALIGN_MASK	(VMX_ALIGN-1)
9b4d322
 
9b4d322
+#ifdef HAVE_PPC64LE
9b4d322
 #ifdef REFLECT
9b4d322
 static unsigned int crc32_align(unsigned int crc, unsigned char const *p,
9b4d322
                                 unsigned long len)
9b4d322
@@ -38,7 +39,6 @@ static unsigned int crc32_align(unsigned int crc, unsigned char const *p,
9b4d322
 }
9b4d322
 #endif
9b4d322
 
9b4d322
-#ifdef HAVE_POWER8
9b4d322
 static inline unsigned long polynomial_multiply(unsigned int a, unsigned int b) {
9b4d322
         vector unsigned int va = {a, 0, 0, 0};
9b4d322
         vector unsigned int vb = {b, 0, 0, 0};
9b4d322
@@ -134,7 +134,7 @@ uint32_t ceph_crc32c_ppc(uint32_t crc, unsigned char const *data, unsigned len)
9b4d322
   return crc;
9b4d322
 }
9b4d322
 
9b4d322
-#else /* HAVE_POWER8 */
9b4d322
+#else /* HAVE_PPC64LE */
9b4d322
 
9b4d322
 /* This symbol has to exist on non-ppc architectures (and on legacy
9b4d322
  * ppc systems using power7 or below) in order to compile properly
9b4d322
@@ -145,4 +145,4 @@ uint32_t ceph_crc32c_ppc(uint32_t crc, unsigned char const *data, unsigned len)
9b4d322
   return 0;
9b4d322
 }
9b4d322
 
9b4d322
-#endif /* HAVE_POWER8 */
9b4d322
+#endif /* HAVE_PPC64LE */
9b4d322
-- 
9b4d322
2.9.4
9b4d322