nethercote | 4388a40 | 2004-09-01 23:20:49 +0000 | [diff] [blame] | 1 | |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 2 | # This file should be included (directly or indirectly) by every |
| 3 | # Makefile.am that builds programs. And also the top-level Makefile.am. |
nethercote | 4388a40 | 2004-09-01 23:20:49 +0000 | [diff] [blame] | 4 | |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 5 | #---------------------------------------------------------------------------- |
| 6 | # Global stuff |
| 7 | #---------------------------------------------------------------------------- |
| 8 | |
nethercote | 4388a40 | 2004-09-01 23:20:49 +0000 | [diff] [blame] | 9 | inplacedir = $(top_builddir)/.in_place |
| 10 | |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 11 | # This used to be required when Vex had a handwritten Makefile. It |
| 12 | # shouldn't be needed any more, though. |
| 13 | ##.NOTPARALLEL: |
nethercote | 4388a40 | 2004-09-01 23:20:49 +0000 | [diff] [blame] | 14 | |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 15 | #---------------------------------------------------------------------------- |
| 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. |
| 26 | build-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. |
| 37 | inplace-noinst_PROGRAMS: $(noinst_PROGRAMS) |
njn | 609f25d | 2009-06-24 08:32:07 +0000 | [diff] [blame] | 38 | mkdir -p $(inplacedir); \ |
| 39 | for f in $(noinst_PROGRAMS) ; do \ |
njn | b169a8c | 2010-06-22 06:46:15 +0000 | [diff] [blame] | 40 | rm -f $(inplacedir)/$$f; \ |
| 41 | ln -f -s ../$(subdir)/$$f $(inplacedir); \ |
njn | 609f25d | 2009-06-24 08:32:07 +0000 | [diff] [blame] | 42 | done |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 43 | |
| 44 | # Similar to inplace-noinst_PROGRAMS |
| 45 | inplace-noinst_DSYMS: build-noinst_DSYMS |
njn | 609f25d | 2009-06-24 08:32:07 +0000 | [diff] [blame] | 46 | 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 |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 51 | |
| 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. |
| 55 | install-noinst_PROGRAMS: $(noinst_PROGRAMS) |
njn | 609f25d | 2009-06-24 08:32:07 +0000 | [diff] [blame] | 56 | $(mkinstalldirs) $(DESTDIR)$(pkglibdir); \ |
| 57 | for f in $(noinst_PROGRAMS); do \ |
njn | b169a8c | 2010-06-22 06:46:15 +0000 | [diff] [blame] | 58 | $(INSTALL_PROGRAM) $$f $(DESTDIR)$(pkglibdir); \ |
njn | 609f25d | 2009-06-24 08:32:07 +0000 | [diff] [blame] | 59 | done |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 60 | |
| 61 | # Similar to install-noinst_PROGRAMS. |
| 62 | # Nb: we don't use $(INSTALL_PROGRAM) here because it doesn't work with |
| 63 | # directories. XXX: not sure whether the resulting permissions will be |
| 64 | # correct when using 'cp -R'... |
| 65 | install-noinst_DSYMS: build-noinst_DSYMS |
njn | 609f25d | 2009-06-24 08:32:07 +0000 | [diff] [blame] | 66 | $(mkinstalldirs) $(DESTDIR)$(pkglibdir); \ |
| 67 | for f in $(noinst_DSYMS); do \ |
| 68 | cp -R $$f.dSYM $(DESTDIR)$(pkglibdir); \ |
| 69 | done |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 70 | |
| 71 | # This needs to be depended on by a 'clean-local' rule. |
| 72 | clean-noinst_DSYMS: |
| 73 | for f in $(noinst_DSYMS); do \ |
| 74 | rm -rf $$f.dSYM; \ |
| 75 | done |
| 76 | |
| 77 | #---------------------------------------------------------------------------- |
| 78 | # Flags |
| 79 | #---------------------------------------------------------------------------- |
| 80 | |
| 81 | # Baseline flags for all compilations. Aim here is to maximise |
| 82 | # performance and get whatever useful warnings we can out of gcc. |
sewardj | bd9b731 | 2011-09-29 17:29:53 +0000 | [diff] [blame] | 83 | # -fno-builtin is important for defeating LLVM's idiom recognition |
| 84 | # that somehow causes VG_(memset) to get into infinite recursion. |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 85 | AM_CFLAGS_BASE = \ |
| 86 | -O2 -g \ |
| 87 | -Wall \ |
| 88 | -Wmissing-prototypes \ |
| 89 | -Wshadow \ |
| 90 | -Wpointer-arith \ |
| 91 | -Wstrict-prototypes \ |
| 92 | -Wmissing-declarations \ |
| 93 | @FLAG_W_NO_FORMAT_ZERO_LENGTH@ \ |
sewardj | bd9b731 | 2011-09-29 17:29:53 +0000 | [diff] [blame] | 94 | -fno-strict-aliasing \ |
| 95 | -fno-builtin |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 96 | |
| 97 | # These flags are used for building the preload shared objects. |
| 98 | # The aim is to give reasonable performance but also to have good |
| 99 | # stack traces, since users often see stack traces extending |
| 100 | # into (and through) the preloads. |
| 101 | if VGCONF_OS_IS_DARWIN |
njn | ea2d6fd | 2010-07-01 00:20:20 +0000 | [diff] [blame] | 102 | AM_CFLAGS_PIC = -dynamic -O -g -fno-omit-frame-pointer -fno-strict-aliasing \ |
sewardj | bd9b731 | 2011-09-29 17:29:53 +0000 | [diff] [blame] | 103 | -mno-dynamic-no-pic -fpic -fPIC \ |
| 104 | -fno-builtin |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 105 | else |
sewardj | bd9b731 | 2011-09-29 17:29:53 +0000 | [diff] [blame] | 106 | AM_CFLAGS_PIC = -fpic -O -g -fno-omit-frame-pointer -fno-strict-aliasing \ |
| 107 | -fno-builtin |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 108 | endif |
| 109 | |
| 110 | |
| 111 | # Flags for specific targets. |
| 112 | # |
| 113 | # Nb: the AM_CPPFLAGS_* values are suitable for building tools and auxprogs. |
| 114 | # For building the core, coregrind/Makefile.am files add some extra things. |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 115 | |
| 116 | AM_CPPFLAGS_@VGCONF_PLATFORM_PRI_CAPS@ = \ |
sewardj | 59570ff | 2010-01-01 11:59:33 +0000 | [diff] [blame] | 117 | -I$(top_srcdir) \ |
| 118 | -I$(top_srcdir)/include \ |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 119 | -I$(top_srcdir)/VEX/pub \ |
| 120 | -DVGA_@VGCONF_ARCH_PRI@=1 \ |
| 121 | -DVGO_@VGCONF_OS@=1 \ |
sewardj | cb495c8 | 2011-07-11 20:42:34 +0000 | [diff] [blame] | 122 | -DVGP_@VGCONF_ARCH_PRI@_@VGCONF_OS@=1 \ |
| 123 | -DVGPV_@VGCONF_ARCH_PRI@_@VGCONF_OS@_@VGCONF_PLATVARIANT@=1 |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 124 | if VGCONF_HAVE_PLATFORM_SEC |
| 125 | AM_CPPFLAGS_@VGCONF_PLATFORM_SEC_CAPS@ = \ |
sewardj | 59570ff | 2010-01-01 11:59:33 +0000 | [diff] [blame] | 126 | -I$(top_srcdir) \ |
| 127 | -I$(top_srcdir)/include \ |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 128 | -I$(top_srcdir)/VEX/pub \ |
| 129 | -DVGA_@VGCONF_ARCH_SEC@=1 \ |
| 130 | -DVGO_@VGCONF_OS@=1 \ |
sewardj | cb495c8 | 2011-07-11 20:42:34 +0000 | [diff] [blame] | 131 | -DVGP_@VGCONF_ARCH_SEC@_@VGCONF_OS@=1 \ |
| 132 | -DVGPV_@VGCONF_ARCH_SEC@_@VGCONF_OS@_@VGCONF_PLATVARIANT@=1 |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 133 | endif |
| 134 | |
| 135 | AM_FLAG_M3264_X86_LINUX = @FLAG_M32@ |
philippe | a5e13e5 | 2012-05-15 21:04:31 +0000 | [diff] [blame] | 136 | AM_CFLAGS_X86_LINUX = @FLAG_M32@ @PREFERRED_STACK_BOUNDARY@ \ |
| 137 | $(AM_CFLAGS_BASE) -fomit-frame-pointer |
florian | ef0bca6 | 2012-05-06 03:37:25 +0000 | [diff] [blame] | 138 | AM_CCASFLAGS_X86_LINUX = @FLAG_M32@ -g |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 139 | |
| 140 | AM_FLAG_M3264_AMD64_LINUX = @FLAG_M64@ |
philippe | a5e13e5 | 2012-05-15 21:04:31 +0000 | [diff] [blame] | 141 | AM_CFLAGS_AMD64_LINUX = @FLAG_M64@ @PREFERRED_STACK_BOUNDARY@ \ |
| 142 | $(AM_CFLAGS_BASE) -fomit-frame-pointer |
florian | ef0bca6 | 2012-05-06 03:37:25 +0000 | [diff] [blame] | 143 | AM_CCASFLAGS_AMD64_LINUX = @FLAG_M64@ -g |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 144 | |
| 145 | AM_FLAG_M3264_PPC32_LINUX = @FLAG_M32@ |
| 146 | AM_CFLAGS_PPC32_LINUX = @FLAG_M32@ $(AM_CFLAGS_BASE) |
florian | ef0bca6 | 2012-05-06 03:37:25 +0000 | [diff] [blame] | 147 | AM_CCASFLAGS_PPC32_LINUX = @FLAG_M32@ -g |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 148 | |
| 149 | AM_FLAG_M3264_PPC64_LINUX = @FLAG_M64@ |
| 150 | AM_CFLAGS_PPC64_LINUX = @FLAG_M64@ $(AM_CFLAGS_BASE) |
florian | ef0bca6 | 2012-05-06 03:37:25 +0000 | [diff] [blame] | 151 | AM_CCASFLAGS_PPC64_LINUX = @FLAG_M64@ -g |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 152 | |
sewardj | 59570ff | 2010-01-01 11:59:33 +0000 | [diff] [blame] | 153 | AM_FLAG_M3264_ARM_LINUX = @FLAG_M32@ |
| 154 | AM_CFLAGS_ARM_LINUX = @FLAG_M32@ @PREFERRED_STACK_BOUNDARY@ \ |
sewardj | fc5ff1f | 2011-05-31 07:17:54 +0000 | [diff] [blame] | 155 | $(AM_CFLAGS_BASE) -marm -mcpu=cortex-a8 |
florian | ef0bca6 | 2012-05-06 03:37:25 +0000 | [diff] [blame] | 156 | AM_CCASFLAGS_ARM_LINUX = @FLAG_M32@ \ |
sewardj | fc5ff1f | 2011-05-31 07:17:54 +0000 | [diff] [blame] | 157 | -marm -mcpu=cortex-a8 -g |
sewardj | 59570ff | 2010-01-01 11:59:33 +0000 | [diff] [blame] | 158 | |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 159 | AM_FLAG_M3264_X86_DARWIN = -arch i386 |
| 160 | AM_CFLAGS_X86_DARWIN = $(WERROR) -arch i386 $(AM_CFLAGS_BASE) \ |
njn | ea2d6fd | 2010-07-01 00:20:20 +0000 | [diff] [blame] | 161 | -mmacosx-version-min=10.5 \ |
| 162 | -fno-stack-protector -fno-pic -fno-PIC |
| 163 | |
florian | ef0bca6 | 2012-05-06 03:37:25 +0000 | [diff] [blame] | 164 | AM_CCASFLAGS_X86_DARWIN = -arch i386 -g |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 165 | |
| 166 | AM_FLAG_M3264_AMD64_DARWIN = -arch x86_64 |
| 167 | AM_CFLAGS_AMD64_DARWIN = $(WERROR) -arch x86_64 $(AM_CFLAGS_BASE) \ |
| 168 | -mmacosx-version-min=10.5 -fno-stack-protector |
florian | ef0bca6 | 2012-05-06 03:37:25 +0000 | [diff] [blame] | 169 | AM_CCASFLAGS_AMD64_DARWIN = -arch x86_64 -g |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 170 | |
sewardj | b5b8740 | 2011-03-07 16:05:35 +0000 | [diff] [blame] | 171 | AM_FLAG_M3264_S390X_LINUX = @FLAG_M64@ |
florian | 8843031 | 2012-05-21 16:18:23 +0000 | [diff] [blame] | 172 | AM_CFLAGS_S390X_LINUX = @FLAG_M64@ $(AM_CFLAGS_BASE) -fomit-frame-pointer |
florian | ef0bca6 | 2012-05-06 03:37:25 +0000 | [diff] [blame] | 173 | AM_CCASFLAGS_S390X_LINUX = @FLAG_M64@ -g -mzarch -march=z900 |
| 174 | |
sewardj | 5db1540 | 2012-06-07 09:13:21 +0000 | [diff] [blame] | 175 | AM_FLAG_M3264_MIPS32_LINUX = @FLAG_M32@ |
| 176 | AM_CFLAGS_MIPS32_LINUX = @FLAG_M32@ $(AM_CFLAGS_BASE) -mips32 |
| 177 | AM_CCASFLAGS_MIPS32_LINUX = @FLAG_M32@ -mips32 -g |
| 178 | |
petarj | 4df0bfc | 2013-02-27 23:17:33 +0000 | [diff] [blame] | 179 | AM_FLAG_M3264_MIPS64_LINUX = @FLAG_M64@ |
| 180 | AM_CFLAGS_MIPS64_LINUX = @FLAG_M64@ $(AM_CFLAGS_BASE) -mips64 |
| 181 | AM_CCASFLAGS_MIPS64_LINUX = @FLAG_M64@ -mips64 -g |
sewardj | b5b8740 | 2011-03-07 16:05:35 +0000 | [diff] [blame] | 182 | |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 183 | # Flags for the primary target. These must be used to build the |
| 184 | # regtests and performance tests. In fact, these must be used to |
| 185 | # build anything which is built only once on a dual-arch build. |
| 186 | # |
| 187 | AM_FLAG_M3264_PRI = $(AM_FLAG_M3264_@VGCONF_PLATFORM_PRI_CAPS@) |
| 188 | AM_CPPFLAGS_PRI = $(AM_CPPFLAGS_@VGCONF_PLATFORM_PRI_CAPS@) |
| 189 | AM_CFLAGS_PRI = $(AM_CFLAGS_@VGCONF_PLATFORM_PRI_CAPS@) |
| 190 | AM_CCASFLAGS_PRI = $(AM_CCASFLAGS_@VGCONF_PLATFORM_PRI_CAPS@) |
| 191 | |
| 192 | if VGCONF_HAVE_PLATFORM_SEC |
| 193 | AM_FLAG_M3264_SEC = $(AM_FLAG_M3264_@VGCONF_PLATFORM_SEC_CAPS@) |
| 194 | else |
| 195 | AM_FLAG_M3264_SEC = |
| 196 | endif |
| 197 | |
| 198 | |
| 199 | # Baseline link flags for making vgpreload shared objects. |
| 200 | # |
| 201 | PRELOAD_LDFLAGS_COMMON_LINUX = -nodefaultlibs -shared -Wl,-z,interpose,-z,initfirst |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 202 | PRELOAD_LDFLAGS_COMMON_DARWIN = -dynamic -dynamiclib -all_load |
| 203 | |
philippe | 5d5dd8e | 2012-08-05 00:08:25 +0000 | [diff] [blame] | 204 | if VGCONF_PLATVARIANT_IS_ANDROID |
| 205 | # The Android toolchain includes all kinds of stdlib helpers present in |
| 206 | # bionic which is bad because we are not linking with it and the Android |
| 207 | # linker will panic. |
| 208 | PRELOAD_LDFLAGS_COMMON_LINUX += -nostdlib |
| 209 | endif |
| 210 | |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 211 | PRELOAD_LDFLAGS_X86_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M32@ |
| 212 | PRELOAD_LDFLAGS_AMD64_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@ |
| 213 | PRELOAD_LDFLAGS_PPC32_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M32@ |
| 214 | PRELOAD_LDFLAGS_PPC64_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@ |
sewardj | 59570ff | 2010-01-01 11:59:33 +0000 | [diff] [blame] | 215 | PRELOAD_LDFLAGS_ARM_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M32@ |
njn | 8b68b64 | 2009-06-24 00:37:09 +0000 | [diff] [blame] | 216 | PRELOAD_LDFLAGS_X86_DARWIN = $(PRELOAD_LDFLAGS_COMMON_DARWIN) -arch i386 |
| 217 | PRELOAD_LDFLAGS_AMD64_DARWIN = $(PRELOAD_LDFLAGS_COMMON_DARWIN) -arch x86_64 |
sewardj | b5b8740 | 2011-03-07 16:05:35 +0000 | [diff] [blame] | 218 | PRELOAD_LDFLAGS_S390X_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@ |
sewardj | 5db1540 | 2012-06-07 09:13:21 +0000 | [diff] [blame] | 219 | PRELOAD_LDFLAGS_MIPS32_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M32@ |
petarj | 4df0bfc | 2013-02-27 23:17:33 +0000 | [diff] [blame] | 220 | PRELOAD_LDFLAGS_MIPS64_LINUX = $(PRELOAD_LDFLAGS_COMMON_LINUX) @FLAG_M64@ |
sewardj | f5cc6b3 | 2005-11-11 18:35:32 +0000 | [diff] [blame] | 221 | |