From ac1362559f5f84d43e121b0899927e8b9a15b741 Mon Sep 17 00:00:00 2001 From: Alon Bar-Lev Date: Wed, 3 Jul 2019 21:58:19 +0300 Subject: [PATCH] dev-libs/crypto++: fix amd64 asm Closes: https://bugs.gentoo.org/show_bug.cgi?id=689162 Signed-off-by: Alon Bar-Lev Package-Manager: Portage-2.3.66, Repoman-2.3.11 --- ...2.0-r1.ebuild => crypto++-8.2.0-r2.ebuild} | 0 dev-libs/crypto++/crypto++-8.2.0.ebuild | 4 + .../crypto++/files/crypto++-8.2.0-build.patch | 260 ++++++++++++++++++ 3 files changed, 264 insertions(+) rename dev-libs/crypto++/{crypto++-8.2.0-r1.ebuild => crypto++-8.2.0-r2.ebuild} (100%) diff --git a/dev-libs/crypto++/crypto++-8.2.0-r1.ebuild b/dev-libs/crypto++/crypto++-8.2.0-r2.ebuild similarity index 100% rename from dev-libs/crypto++/crypto++-8.2.0-r1.ebuild rename to dev-libs/crypto++/crypto++-8.2.0-r2.ebuild diff --git a/dev-libs/crypto++/crypto++-8.2.0.ebuild b/dev-libs/crypto++/crypto++-8.2.0.ebuild index bc8c3cb23df2..25541d774a79 100644 --- a/dev-libs/crypto++/crypto++-8.2.0.ebuild +++ b/dev-libs/crypto++/crypto++-8.2.0.ebuild @@ -18,6 +18,10 @@ BDEPEND="app-arch/unzip" S="${WORKDIR}" +PATCHES=( + "${FILESDIR}/${P}-build.patch" +) + config_uncomment() { sed -i -e "s://\s*\(#define\s*$1\):\1:" config.h || die } diff --git a/dev-libs/crypto++/files/crypto++-8.2.0-build.patch b/dev-libs/crypto++/files/crypto++-8.2.0-build.patch index 903c6817e86f..7c7e8a9c1b66 100644 --- a/dev-libs/crypto++/files/crypto++-8.2.0-build.patch +++ b/dev-libs/crypto++/files/crypto++-8.2.0-build.patch @@ -9,3 +9,263 @@ #define CRYPTOPP_SSE2_INTRIN_AVAILABLE 1 #endif +From fbbf0a08e8cf4faca661b0f75f806ea652abea70 Mon Sep 17 00:00:00 2001 +From: Jeffrey Walton +Date: Tue, 2 Jul 2019 16:55:00 -0400 +Subject: [PATCH] Add missing XOP header for blake2b_simd.cpp (GH #859) The + Gentoo folks caught a bug at https://bugs.gentoo.org/689162. The 689162 bug + uses -march=bdver1 -msse4.1 on a AMD Bulldozer machine. + +Investigating the issue we are missing the XOP header blake2b_simd.cpp. However, adding the XOP header is not enough for this particular config. Four source files fail to compile with the expected headers. We are waiting on the GCC folks to get back to us with a fix. +--- + blake2b_simd.cpp | 5 +++++ + keccak_simd.cpp | 5 +++++ + simon128_simd.cpp | 1 + + speck128_simd.cpp | 1 + + 4 files changed, 12 insertions(+) + +diff --git a/blake2b_simd.cpp b/blake2b_simd.cpp +index ff138321..b246824c 100644 +--- a/blake2b_simd.cpp ++++ b/blake2b_simd.cpp +@@ -32,6 +32,11 @@ + # undef CRYPTOPP_ALTIVEC_AVAILABLE + #endif + ++#if defined(__XOP__) ++# include ++# include ++#endif ++ + #if (CRYPTOPP_SSE41_AVAILABLE) + # include + # include +diff --git a/keccak_simd.cpp b/keccak_simd.cpp +index 45674ac2..ae2f2095 100644 +--- a/keccak_simd.cpp ++++ b/keccak_simd.cpp +@@ -26,6 +26,11 @@ + # include + #endif + ++#if defined(__XOP__) ++# include ++# include ++#endif ++ + // Squash MS LNK4221 and libtool warnings + extern const char KECCAK_SIMD_FNAME[] = __FILE__; + +diff --git a/simon128_simd.cpp b/simon128_simd.cpp +index 5331c351..4b551f8f 100644 +--- a/simon128_simd.cpp ++++ b/simon128_simd.cpp +@@ -23,6 +23,7 @@ + #endif + + #if defined(__XOP__) ++# include + # include + #endif + +diff --git a/speck128_simd.cpp b/speck128_simd.cpp +index 2c356346..fb3eb1e6 100644 +--- a/speck128_simd.cpp ++++ b/speck128_simd.cpp +@@ -23,6 +23,7 @@ + #endif + + #if defined(__XOP__) ++# include + # include + #endif + +-- +2.21.0 + +From eeb7dadc76572b7061922ca6ac5f247bdfd985ad Mon Sep 17 00:00:00 2001 +From: Jeffrey Walton +Date: Tue, 2 Jul 2019 19:10:11 -0400 +Subject: [PATCH] Fix missing _mm_roti_epi32 and _mm_roti_epi64 under GCC (GH + #859) + +--- + blake2b_simd.cpp | 4 +++- + blake2s_simd.cpp | 7 +++++++ + chacha_simd.cpp | 3 +++ + cham_simd.cpp | 3 +++ + keccak_simd.cpp | 4 +++- + lea_simd.cpp | 3 +++ + simeck_simd.cpp | 3 +++ + simon128_simd.cpp | 4 +++- + simon64_simd.cpp | 3 +++ + speck128_simd.cpp | 4 +++- + speck64_simd.cpp | 3 +++ + 11 files changed, 37 insertions(+), 4 deletions(-) + +diff --git a/blake2b_simd.cpp b/blake2b_simd.cpp +index b246824c..6803d0ae 100644 +--- a/blake2b_simd.cpp ++++ b/blake2b_simd.cpp +@@ -33,8 +33,10 @@ + #endif + + #if defined(__XOP__) +-# include + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + #if (CRYPTOPP_SSE41_AVAILABLE) +diff --git a/blake2s_simd.cpp b/blake2s_simd.cpp +index f02b9771..4b6d1bd6 100644 +--- a/blake2s_simd.cpp ++++ b/blake2s_simd.cpp +@@ -42,6 +42,13 @@ + # undef CRYPTOPP_ALTIVEC_AVAILABLE + #endif + ++#if defined(__XOP__) ++# include ++# if defined(__GNUC__) ++# include ++# endif ++#endif ++ + #if (CRYPTOPP_SSE41_AVAILABLE) + # include + # include +diff --git a/chacha_simd.cpp b/chacha_simd.cpp +index a983ab69..5a63ecee 100644 +--- a/chacha_simd.cpp ++++ b/chacha_simd.cpp +@@ -46,6 +46,9 @@ + + #if defined(__XOP__) + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + // C1189: error: This header is specific to ARM targets +diff --git a/cham_simd.cpp b/cham_simd.cpp +index 7fcaece1..e102a877 100644 +--- a/cham_simd.cpp ++++ b/cham_simd.cpp +@@ -24,6 +24,9 @@ + + #if defined(__XOP__) + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + #if defined(__AVX512F__) +diff --git a/keccak_simd.cpp b/keccak_simd.cpp +index ae2f2095..194291a0 100644 +--- a/keccak_simd.cpp ++++ b/keccak_simd.cpp +@@ -27,8 +27,10 @@ + #endif + + #if defined(__XOP__) +-# include + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + // Squash MS LNK4221 and libtool warnings +diff --git a/lea_simd.cpp b/lea_simd.cpp +index b4180e34..ee2a5697 100644 +--- a/lea_simd.cpp ++++ b/lea_simd.cpp +@@ -24,6 +24,9 @@ + + #if defined(__XOP__) + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + #if defined(__AVX512F__) +diff --git a/simeck_simd.cpp b/simeck_simd.cpp +index 2a9efc99..f92a53d7 100644 +--- a/simeck_simd.cpp ++++ b/simeck_simd.cpp +@@ -24,6 +24,9 @@ + + #if defined(__XOP__) + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + // Squash MS LNK4221 and libtool warnings +diff --git a/simon128_simd.cpp b/simon128_simd.cpp +index 4b551f8f..cb16fa8d 100644 +--- a/simon128_simd.cpp ++++ b/simon128_simd.cpp +@@ -23,8 +23,10 @@ + #endif + + #if defined(__XOP__) +-# include + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + #if defined(__AVX512F__) +diff --git a/simon64_simd.cpp b/simon64_simd.cpp +index eb5a1757..fcbe1342 100644 +--- a/simon64_simd.cpp ++++ b/simon64_simd.cpp +@@ -25,6 +25,9 @@ + + #if defined(__XOP__) + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + // C1189: error: This header is specific to ARM targets +diff --git a/speck128_simd.cpp b/speck128_simd.cpp +index fb3eb1e6..0c0f389e 100644 +--- a/speck128_simd.cpp ++++ b/speck128_simd.cpp +@@ -23,8 +23,10 @@ + #endif + + #if defined(__XOP__) +-# include + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + #if defined(__AVX512F__) +diff --git a/speck64_simd.cpp b/speck64_simd.cpp +index 0a720fb3..0b43c175 100644 +--- a/speck64_simd.cpp ++++ b/speck64_simd.cpp +@@ -25,6 +25,9 @@ + + #if defined(__XOP__) + # include ++# if defined(__GNUC__) ++# include ++# endif + #endif + + // C1189: error: This header is specific to ARM targets -- 2.26.2