blob: 5a506ed4194a509ce0d1be2f9544b41c1c99a689 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
# Copyright 1999-2010 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
# $Header: /var/cvsroot/gentoo-x86/dev-util/valgrind/valgrind-3.5.0-r1.ebuild,v 1.1 2010/10/28 17:39:53 blueness Exp $
inherit autotools eutils flag-o-matic toolchain-funcs multilib pax-utils
DESCRIPTION="An open-source memory debugger for GNU/Linux"
HOMEPAGE="http://www.valgrind.org"
SRC_URI="http://www.valgrind.org/downloads/${P}.tar.bz2"
LICENSE="GPL-2"
SLOT="0"
KEYWORDS="-* ~amd64 ~ppc ~ppc64 ~x86 ~amd64-linux ~x86-linux"
IUSE="mpi"
DEPEND="mpi? ( virtual/mpi )"
RDEPEND="${DEPEND}
!dev-util/callgrind"
src_unpack() {
unpack ${A}
cd "${S}"
# make sure our CFLAGS are respected
einfo "Changing configure.in to respect CFLAGS"
sed -i -e 's:^CFLAGS="-Wno-long-long":CFLAGS="$CFLAGS -Wno-long-long":' configure.in
# undefined references to __guard and __stack_smash_handler in VEX (bug #114347)
einfo "Changing Makefile.all.am to disable SSP"
sed -i -e 's:^AM_CFLAGS_BASE = :AM_CFLAGS_BASE = -fno-stack-protector :' Makefile.all.am
# Correct hard coded doc location
sed -i -e "s:doc/valgrind:doc/${P}:" docs/Makefile.am
# Fix up some suppressions that were not general enough for glibc versions
# with more than just a major and minor number.
epatch "${FILESDIR}/valgrind-3.4.1-glibc-2.10.1.patch"
# Respect LDFLAGS also for libmpiwrap.so (bug #279194)
epatch "${FILESDIR}/valgrind-3.5.0-respect-LDFLAGS.patch"
# Yet more local labels, this time for ppc32 & ppc64
epatch "${FILESDIR}/valgrind-3.5.0-local-labels.patch"
# Don't just reject glibc-2.11
epatch "${FILESDIR}/valgrind-3.5.0-glibc-2.11.patch"
# Don't build in empty assembly files for other platforms or we'll get a QA
# warning about executable stacks.
epatch "${FILESDIR}/valgrind-3.5.0-non-exec-stack.patch"
# Minimal fixes required for glibc-2.12
epatch "${FILESDIR}/valgrind-3.5.0-glibc-2.12.patch"
epatch "${FILESDIR}/valgrind-3.5.0-stat_h.patch"
# Regenerate autotools files
eautoreconf
}
src_compile() {
local myconf
# -fomit-frame-pointer "Assembler messages: Error: junk `8' after expression"
# while compiling insn_sse.c in none/tests/x86
# -fpie valgrind seemingly hangs when built with pie on
# amd64 (bug #102157)
# -fstack-protector more undefined references to __guard and __stack_smash_handler
# because valgrind doesn't link to glibc (bug #114347)
# -ggdb3 segmentation fault on startup
filter-flags -fomit-frame-pointer
filter-flags -fpie
filter-flags -fstack-protector
replace-flags -ggdb3 -ggdb2
# gcc 3.3.x fails to compile valgrind with -O3 (bug #129776)
if [ "$(gcc-version)" == "3.3" ] && is-flagq -O3; then
ewarn "GCC 3.3 cannot compile valgrind with -O3 in CFLAGS, using -O2 instead."
replace-flags -O3 -O2
fi
if use amd64 || use ppc64; then
! has_multilib_profile && myconf="${myconf} --enable-only64bit"
fi
# Don't use mpicc unless the user asked for it (bug #258832)
if ! use mpi; then
myconf="${myconf} --without-mpicc"
fi
econf ${myconf} || die "Configure failed!"
emake || die "Make failed!"
}
src_install() {
emake DESTDIR="${D}" install || die "Install failed!"
dodoc AUTHORS FAQ.txt NEWS README*
pax-mark m "${D}"/usr/$(get_libdir)/valgrind/*-*-linux
}
pkg_postinst() {
if use ppc || use ppc64 || use amd64 ; then
ewarn "Valgrind will not work on ppc, ppc64 or amd64 if glibc does not have"
ewarn "debug symbols (see https://bugs.gentoo.org/show_bug.cgi?id=214065"
ewarn "and http://bugs.gentoo.org/show_bug.cgi?id=274771)."
ewarn "To fix this you can add splitdebug to FEATURES in make.conf and"
ewarn "remerge glibc."
fi
}
|