blob: 52f5261b736226917481602638a72d1d67e9b022 [file] [log] [blame]
nethercote4388a402004-09-01 23:20:49 +00001
njn8b68b642009-06-24 00:37:09 +00002# This file should be included (directly or indirectly) by every
3# Makefile.am that builds programs. And also the top-level Makefile.am.
nethercote4388a402004-09-01 23:20:49 +00004
njn8b68b642009-06-24 00:37:09 +00005#----------------------------------------------------------------------------
6# Global stuff
7#----------------------------------------------------------------------------
8
nethercote4388a402004-09-01 23:20:49 +00009inplacedir = $(top_builddir)/.in_place
10
njn8b68b642009-06-24 00:37:09 +000011# This used to be required when Vex had a handwritten Makefile. It
12# shouldn't be needed any more, though.
13##.NOTPARALLEL:
nethercote4388a402004-09-01 23:20:49 +000014
njn8b68b642009-06-24 00:37:09 +000015#----------------------------------------------------------------------------
16# noinst_PROGRAMS and noinst_DSYMS targets
17#----------------------------------------------------------------------------
18
19# On Darwin, for a program 'p', the DWARF debug info is stored in the
20# directory 'p.dSYM'. This must be generated after the executable is
21# created, with 'dsymutil p'. We could redefine LINK with a script that
22# executes 'dsymutil' after linking, but that's a pain. Instead we use this
23# hook so that every time "make check" is run, we subsequently invoke
24# 'dsymutil' on all the executables that lack a .dSYM directory, or that are
25# newer than their corresponding .dSYM directory.
26build-noinst_DSYMS: $(noinst_DSYMS)
27 for f in $(noinst_DSYMS); do \
28 if [ ! -e $$f.dSYM -o $$f -nt $$f.dSYM ] ; then \
29 echo "dsymutil $$f"; \
30 dsymutil $$f; \
31 fi; \
32 done
33
34# This is used by coregrind/Makefile.am and Makefile.tool.am for doing
35# "in-place" installs. It copies $(noinst_PROGRAMS) into $inplacedir.
36# It needs to be depended on by an 'all-local' rule.
37inplace-noinst_PROGRAMS: $(noinst_PROGRAMS)
njn609f25d2009-06-24 08:32:07 +000038 mkdir -p $(inplacedir); \
39 for f in $(noinst_PROGRAMS) ; do \
njnb169a8c2010-06-22 06:46:15 +000040 rm -f $(inplacedir)/$$f; \
41 ln -f -s ../$(subdir)/$$f $(inplacedir); \
njn609f25d2009-06-24 08:32:07 +000042 done
njn8b68b642009-06-24 00:37:09 +000043
44# Similar to inplace-noinst_PROGRAMS
45inplace-noinst_DSYMS: build-noinst_DSYMS
njn609f25d2009-06-24 08:32:07 +000046 mkdir -p $(inplacedir); \
47 for f in $(noinst_DSYMS); do \
48 rm -f $(inplacedir)/$$f.dSYM; \
49 ln -f -s ../$(subdir)/$$f.dSYM $(inplacedir); \
50 done
njn8b68b642009-06-24 00:37:09 +000051
52# This is used by coregrind/Makefile.am and by <tool>/Makefile.am for doing
53# "make install". It copies $(noinst_PROGRAMS) into $prefix/lib/valgrind/.
54# It needs to be depended on by an 'install-exec-local' rule.
55install-noinst_PROGRAMS: $(noinst_PROGRAMS)
njn609f25d2009-06-24 08:32:07 +000056 $(mkinstalldirs) $(DESTDIR)$(pkglibdir); \
57 for f in $(noinst_PROGRAMS); do \
njnb169a8c2010-06-22 06:46:15 +000058 $(INSTALL_PROGRAM) $$f $(DESTDIR)$(pkglibdir); \
njn609f25d2009-06-24 08:32:07 +000059 done
njn8b68b642009-06-24 00:37:09 +000060
mjwfbde9cf2014-05-09 14:25:39 +000061# This is used by coregrind/Makefile.am and by <tool>/Makefile.am for doing
62# "make uninstall". It removes $(noinst_PROGRAMS) from $prefix/lib/valgrind/.
63# It needs to be depended on by an 'uninstall-local' rule.
64uninstall-noinst_PROGRAMS:
65 for f in $(noinst_PROGRAMS); do \
66 rm -f $(DESTDIR)$(pkglibdir)/$$f; \
67 done
68
njn8b68b642009-06-24 00:37:09 +000069# Similar to install-noinst_PROGRAMS.
70# Nb: we don't use $(INSTALL_PROGRAM) here because it doesn't work with
71# directories. XXX: not sure whether the resulting permissions will be
72# correct when using 'cp -R'...
73install-noinst_DSYMS: build-noinst_DSYMS
njn609f25d2009-06-24 08:32:07 +000074 $(mkinstalldirs) $(DESTDIR)$(pkglibdir); \
75 for f in $(noinst_DSYMS); do \
76 cp -R $$f.dSYM $(DESTDIR)$(pkglibdir); \
77 done
njn8b68b642009-06-24 00:37:09 +000078
mjwfbde9cf2014-05-09 14:25:39 +000079# Similar to uninstall-noinst_PROGRAMS.
80uninstall-noinst_DSYMS:
81 for f in $(noinst_DSYMS); do \
82 rm -f $(DESTDIR)$(pkglibdir)/$$f.dSYM; \
83 done
84
njn8b68b642009-06-24 00:37:09 +000085# This needs to be depended on by a 'clean-local' rule.
86clean-noinst_DSYMS:
87 for f in $(noinst_DSYMS); do \
88 rm -rf $$f.dSYM; \
89 done
90
91#----------------------------------------------------------------------------
92# Flags
93#----------------------------------------------------------------------------
94
95# Baseline flags for all compilations. Aim here is to maximise
96# performance and get whatever useful warnings we can out of gcc.
sewardjbd9b7312011-09-29 17:29:53 +000097# -fno-builtin is important for defeating LLVM's idiom recognition
98# that somehow causes VG_(memset) to get into infinite recursion.
njn8b68b642009-06-24 00:37:09 +000099AM_CFLAGS_BASE = \
100 -O2 -g \
101 -Wall \
102 -Wmissing-prototypes \
103 -Wshadow \
104 -Wpointer-arith \
105 -Wstrict-prototypes \
106 -Wmissing-declarations \
107 @FLAG_W_NO_FORMAT_ZERO_LENGTH@ \
sewardj57f767c2014-07-08 07:40:56 +0000108 @FLAG_W_NO_TAUTOLOGICAL_COMPARE@ \
sewardjbd9b7312011-09-29 17:29:53 +0000109 -fno-strict-aliasing \
110 -fno-builtin
njn8b68b642009-06-24 00:37:09 +0000111
112# These flags are used for building the preload shared objects.
113# The aim is to give reasonable performance but also to have good
114# stack traces, since users often see stack traces extending
115# into (and through) the preloads.
116if VGCONF_OS_IS_DARWIN
njnea2d6fd2010-07-01 00:20:20 +0000117AM_CFLAGS_PIC = -dynamic -O -g -fno-omit-frame-pointer -fno-strict-aliasing \
sewardjec66ad52014-06-20 11:48:38 +0000118 -fpic -fPIC \
sewardjbd9b7312011-09-29 17:29:53 +0000119 -fno-builtin
njn8b68b642009-06-24 00:37:09 +0000120else
sewardjbd9b7312011-09-29 17:29:53 +0000121AM_CFLAGS_PIC = -fpic -O -g -fno-omit-frame-pointer -fno-strict-aliasing \
122 -fno-builtin
njn8b68b642009-06-24 00:37:09 +0000123endif
124
125
126# Flags for specific targets.
127#
128# Nb: the AM_CPPFLAGS_* values are suitable for building tools and auxprogs.
129# For building the core, coregrind/Makefile.am files add some extra things.
njn8b68b642009-06-24 00:37:09 +0000130
131AM_CPPFLAGS_@VGCONF_PLATFORM_PRI_CAPS@ = \
sewardj59570ff2010-01-01 11:59:33 +0000132 -I$(top_srcdir) \
133 -I$(top_srcdir)/include \
njn8b68b642009-06-24 00:37:09 +0000134 -I$(top_srcdir)/VEX/pub \
mjwe2990202014-05-09 13:34:13 +0000135 -I$(top_builddir)/VEX/pub \
njn8b68b642009-06-24 00:37:09 +0000136 -DVGA_@VGCONF_ARCH_PRI@=1 \
137 -DVGO_@VGCONF_OS@=1 \
sewardjcb495c82011-07-11 20:42:34 +0000138 -DVGP_@VGCONF_ARCH_PRI@_@VGCONF_OS@=1 \
139 -DVGPV_@VGCONF_ARCH_PRI@_@VGCONF_OS@_@VGCONF_PLATVARIANT@=1
njn8b68b642009-06-24 00:37:09 +0000140if VGCONF_HAVE_PLATFORM_SEC
141AM_CPPFLAGS_@VGCONF_PLATFORM_SEC_CAPS@ = \
sewardj59570ff2010-01-01 11:59:33 +0000142 -I$(top_srcdir) \
143 -I$(top_srcdir)/include \
njn8b68b642009-06-24 00:37:09 +0000144 -I$(top_srcdir)/VEX/pub \
mjwe2990202014-05-09 13:34:13 +0000145 -I$(top_builddir)/VEX/pub \
njn8b68b642009-06-24 00:37:09 +0000146 -DVGA_@VGCONF_ARCH_SEC@=1 \
147 -DVGO_@VGCONF_OS@=1 \
sewardjcb495c82011-07-11 20:42:34 +0000148 -DVGP_@VGCONF_ARCH_SEC@_@VGCONF_OS@=1 \
149 -DVGPV_@VGCONF_ARCH_SEC@_@VGCONF_OS@_@VGCONF_PLATVARIANT@=1
njn8b68b642009-06-24 00:37:09 +0000150endif
151
152AM_FLAG_M3264_X86_LINUX = @FLAG_M32@
philippea5e13e52012-05-15 21:04:31 +0000153AM_CFLAGS_X86_LINUX = @FLAG_M32@ @PREFERRED_STACK_BOUNDARY@ \
154 $(AM_CFLAGS_BASE) -fomit-frame-pointer
florianef0bca62012-05-06 03:37:25 +0000155AM_CCASFLAGS_X86_LINUX = @FLAG_M32@ -g
njn8b68b642009-06-24 00:37:09 +0000156
157AM_FLAG_M3264_AMD64_LINUX = @FLAG_M64@
philippea5e13e52012-05-15 21:04:31 +0000158AM_CFLAGS_AMD64_LINUX = @FLAG_M64@ @PREFERRED_STACK_BOUNDARY@ \
159 $(AM_CFLAGS_BASE) -fomit-frame-pointer
florianef0bca62012-05-06 03:37:25 +0000160AM_CCASFLAGS_AMD64_LINUX = @FLAG_M64@ -g
njn8b68b642009-06-24 00:37:09 +0000161
162AM_FLAG_M3264_PPC32_LINUX = @FLAG_M32@
163AM_CFLAGS_PPC32_LINUX = @FLAG_M32@ $(AM_CFLAGS_BASE)
florianef0bca62012-05-06 03:37:25 +0000164AM_CCASFLAGS_PPC32_LINUX = @FLAG_M32@ -g
njn8b68b642009-06-24 00:37:09 +0000165
carll65f83bf2014-08-08 22:29:10 +0000166AM_FLAG_M3264_PPC64BE_LINUX = @FLAG_M64@
167AM_CFLAGS_PPC64BE_LINUX = @FLAG_M64@ $(AM_CFLAGS_BASE)
168AM_CCASFLAGS_PPC64BE_LINUX = @FLAG_M64@ -g
169
170AM_FLAG_M3264_PPC64LE_LINUX = @FLAG_M64@
171AM_CFLAGS_PPC64LE_LINUX = @FLAG_M64@ $(AM_CFLAGS_BASE)
172AM_CCASFLAGS_PPC64LE_LINUX = @FLAG_M64@ -g
njn8b68b642009-06-24 00:37:09 +0000173
sewardj59570ff2010-01-01 11:59:33 +0000174AM_FLAG_M3264_ARM_LINUX = @FLAG_M32@
175AM_CFLAGS_ARM_LINUX = @FLAG_M32@ @PREFERRED_STACK_BOUNDARY@ \
sewardjfc5ff1f2011-05-31 07:17:54 +0000176 $(AM_CFLAGS_BASE) -marm -mcpu=cortex-a8
florianef0bca62012-05-06 03:37:25 +0000177AM_CCASFLAGS_ARM_LINUX = @FLAG_M32@ \
sewardjfc5ff1f2011-05-31 07:17:54 +0000178 -marm -mcpu=cortex-a8 -g
sewardj59570ff2010-01-01 11:59:33 +0000179
sewardjf0c12502014-01-12 12:54:00 +0000180AM_FLAG_M3264_ARM64_LINUX = @FLAG_M64@
181AM_CFLAGS_ARM64_LINUX = @FLAG_M64@ $(AM_CFLAGS_BASE)
182AM_CCASFLAGS_ARM64_LINUX = @FLAG_M64@ -g
183
njn8b68b642009-06-24 00:37:09 +0000184AM_FLAG_M3264_X86_DARWIN = -arch i386
185AM_CFLAGS_X86_DARWIN = $(WERROR) -arch i386 $(AM_CFLAGS_BASE) \
njnea2d6fd2010-07-01 00:20:20 +0000186 -mmacosx-version-min=10.5 \
187 -fno-stack-protector -fno-pic -fno-PIC
188
florianef0bca62012-05-06 03:37:25 +0000189AM_CCASFLAGS_X86_DARWIN = -arch i386 -g
njn8b68b642009-06-24 00:37:09 +0000190
191AM_FLAG_M3264_AMD64_DARWIN = -arch x86_64
192AM_CFLAGS_AMD64_DARWIN = $(WERROR) -arch x86_64 $(AM_CFLAGS_BASE) \
193 -mmacosx-version-min=10.5 -fno-stack-protector
florianef0bca62012-05-06 03:37:25 +0000194AM_CCASFLAGS_AMD64_DARWIN = -arch x86_64 -g
njn8b68b642009-06-24 00:37:09 +0000195
sewardjb5b87402011-03-07 16:05:35 +0000196AM_FLAG_M3264_S390X_LINUX = @FLAG_M64@
florian88430312012-05-21 16:18:23 +0000197AM_CFLAGS_S390X_LINUX = @FLAG_M64@ $(AM_CFLAGS_BASE) -fomit-frame-pointer
florianef0bca62012-05-06 03:37:25 +0000198AM_CCASFLAGS_S390X_LINUX = @FLAG_M64@ -g -mzarch -march=z900
199
sewardj5db15402012-06-07 09:13:21 +0000200AM_FLAG_M3264_MIPS32_LINUX = @FLAG_M32@
dejanjf674e382014-02-18 16:40:25 +0000201AM_CFLAGS_MIPS32_LINUX = @FLAG_M32@ $(AM_CFLAGS_BASE) @FLAG_MIPS32@
202AM_CCASFLAGS_MIPS32_LINUX = @FLAG_M32@ -g @FLAG_MIPS32@
sewardj5db15402012-06-07 09:13:21 +0000203
petarj4df0bfc2013-02-27 23:17:33 +0000204AM_FLAG_M3264_MIPS64_LINUX = @FLAG_M64@
dejanjf674e382014-02-18 16:40:25 +0000205AM_CFLAGS_MIPS64_LINUX = @FLAG_M64@ $(AM_CFLAGS_BASE) @FLAG_MIPS64@
206AM_CCASFLAGS_MIPS64_LINUX = @FLAG_M64@ -g @FLAG_MIPS64@
sewardjb5b87402011-03-07 16:05:35 +0000207
njn8b68b642009-06-24 00:37:09 +0000208# Flags for the primary target. These must be used to build the
209# regtests and performance tests. In fact, these must be used to
210# build anything which is built only once on a dual-arch build.
211#
212AM_FLAG_M3264_PRI = $(AM_FLAG_M3264_@VGCONF_PLATFORM_PRI_CAPS@)
213AM_CPPFLAGS_PRI = $(AM_CPPFLAGS_@VGCONF_PLATFORM_PRI_CAPS@)
214AM_CFLAGS_PRI = $(AM_CFLAGS_@VGCONF_PLATFORM_PRI_CAPS@)
215AM_CCASFLAGS_PRI = $(AM_CCASFLAGS_@VGCONF_PLATFORM_PRI_CAPS@)
216
217if VGCONF_HAVE_PLATFORM_SEC
218 AM_FLAG_M3264_SEC = $(AM_FLAG_M3264_@VGCONF_PLATFORM_SEC_CAPS@)
219else
220 AM_FLAG_M3264_SEC =
221endif
222
223
224# Baseline link flags for making vgpreload shared objects.
225#
226PRELOAD_LDFLAGS_COMMON_LINUX = -nodefaultlibs -shared -Wl,-z,interpose,-z,initfirst
njn8b68b642009-06-24 00:37:09 +0000227PRELOAD_LDFLAGS_COMMON_DARWIN = -dynamic -dynamiclib -all_load
228
philippe5d5dd8e2012-08-05 00:08:25 +0000229if VGCONF_PLATVARIANT_IS_ANDROID
230# The Android toolchain includes all kinds of stdlib helpers present in
231# bionic which is bad because we are not linking with it and the Android
232# linker will panic.
233PRELOAD_LDFLAGS_COMMON_LINUX += -nostdlib
234endif
235
carllcae0cc22014-08-07 23:17:29 +0000236PRELOAD_LDFLAGS_X86_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M32@
237PRELOAD_LDFLAGS_AMD64_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@
238PRELOAD_LDFLAGS_PPC32_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M32@
239PRELOAD_LDFLAGS_PPC64BE_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@
240PRELOAD_LDFLAGS_PPC64LE_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@
241PRELOAD_LDFLAGS_ARM_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M32@
242PRELOAD_LDFLAGS_ARM64_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@
243PRELOAD_LDFLAGS_X86_DARWIN = $(PRELOAD_LDFLAGS_COMMON_DARWIN) -arch i386
244PRELOAD_LDFLAGS_AMD64_DARWIN = $(PRELOAD_LDFLAGS_COMMON_DARWIN) -arch x86_64
245PRELOAD_LDFLAGS_S390X_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@
246PRELOAD_LDFLAGS_MIPS32_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M32@
247PRELOAD_LDFLAGS_MIPS64_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@
sewardjf5cc6b32005-11-11 18:35:32 +0000248