commit: fc0ba0fc7c93d56aeb421fbb8154fd57e7695623
Author: Fabian Groffen <grobian <AT> gentoo <DOT> org>
AuthorDate: Sun Oct 22 09:32:51 2017 +0000
Commit: Fabian Groffen <grobian <AT> gentoo <DOT> org>
CommitDate: Sun Oct 22 09:34:04 2017 +0000
URL: https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=fc0ba0fc
dev-python/pyblake2: fix and keyword for *-macos, bug #634936
Package-Manager: Portage-2.3.11-prefix, Repoman-2.3.3
dev-python/pyblake2/pyblake2-0.9.3.ebuild | 25 +++++++++++++++++++++++--
1 file changed, 23 insertions(+), 2 deletions(-)
diff --git a/dev-python/pyblake2/pyblake2-0.9.3.ebuild
b/dev-python/pyblake2/pyblake2-0.9.3.ebuild
index 10da95058c1..cdfe223ded1 100644
--- a/dev-python/pyblake2/pyblake2-0.9.3.ebuild
+++ b/dev-python/pyblake2/pyblake2-0.9.3.ebuild
@@ -4,7 +4,7 @@
EAPI=6
PYTHON_COMPAT=( python{2_7,3_4,3_5,3_6} pypy )
-inherit distutils-r1
+inherit distutils-r1 flag-o-matic
DESCRIPTION="BLAKE2 hash function extension module"
HOMEPAGE="https://github.com/dchest/pyblake2
https://pypi.python.org/pypi/pyblake2"
@@ -12,7 +12,7 @@ SRC_URI="mirror://pypi/${PN::1}/${PN}/${P}.tar.gz"
LICENSE="CC0-1.0"
SLOT="0"
-KEYWORDS="~amd64 ~ia64 ~ppc ~ppc64 ~x86 ~sparc-solaris ~sparc64-solaris
~x64-solaris ~x86-solaris"
+KEYWORDS="~amd64 ~ia64 ~ppc ~ppc64 ~x86 ~ppc-macos ~x64-macos ~x86-macos
~sparc-solaris ~sparc64-solaris ~x64-solaris ~x86-solaris"
IUSE="cpu_flags_x86_ssse3 cpu_flags_x86_avx cpu_flags_x86_xop"
python_prepare_all() {
@@ -26,6 +26,27 @@ python_prepare_all() {
# uncomment the implementation of choice
sed -i -e "/BLAKE2_COMPRESS_${impl}/s:^#::" setup.py || die
+ # avoid segfault due to over(?) optimisation
+ if [[ ${CHOST} == *86*-darwin* ]] ; then
+ local march=$(get-flag march)
+ # expand "native" into the used cpu optmisation
+ if [[ ${march} == native ]] ; then
+ # we're always on Clang here
+ march=$(llc --version | grep "Host CPU:")
+ march=${march##*: }
+ fi
+ # compiling for haswell cpu results in a segfault when used
+ # with optimisation >O1, since optimisation here benefits more
+ # than cpu specific instructions, reduce to ivybridge level
+ case ${march} in
+ haswell|broadwell|skylake*)
+ local opt=$(get-flag -O)
+ [[ ${opt#-O} -gt 1 ]] && \
+ replace-flags -march=* -march=ivybridge
+ ;;
+ esac
+ fi
+
distutils-r1_python_prepare_all
}