s390: Add a few more test from olden times.
[ambi/valgrind.git] / Makefile.tool.am
index e985aecd5433408333d2ae239a0408b6473c3d70..6f5a6eab5335478fec6caf9bc1bac25cf830eddc 100644 (file)
 
-SUBDIRS = . tests docs
+SUBDIRS = . tests
 
 include $(top_srcdir)/Makefile.all.am
-include $(top_srcdir)/Makefile.install.am
-include $(top_srcdir)/Makefile.tool-flags.am
-include $(top_srcdir)/Makefile.tool-inplace.am
 
-LIBREPLACEMALLOC_X86_LINUX = \
-       $(top_builddir)/coregrind/libreplacemalloc_toolpreload_x86_linux.a
+#----------------------------------------------------------------------------
+# <tool>-<platform> stuff
+#----------------------------------------------------------------------------
 
-LIBREPLACEMALLOC_AMD64_LINUX = \
-       $(top_builddir)/coregrind/libreplacemalloc_toolpreload_amd64_linux.a
+TOOL_DEPENDENCIES_@VGCONF_PLATFORM_PRI_CAPS@ = \
+       $(top_builddir)/coregrind/libcoregrind-@VGCONF_ARCH_PRI@-@VGCONF_OS@.a \
+       $(top_builddir)/VEX/libvex-@VGCONF_ARCH_PRI@-@VGCONF_OS@.a
+if VGCONF_HAVE_PLATFORM_SEC
+TOOL_DEPENDENCIES_@VGCONF_PLATFORM_SEC_CAPS@ = \
+       $(top_builddir)/coregrind/libcoregrind-@VGCONF_ARCH_SEC@-@VGCONF_OS@.a \
+       $(top_builddir)/VEX/libvex-@VGCONF_ARCH_SEC@-@VGCONF_OS@.a
+endif
 
-LIBREPLACEMALLOC_PPC32_LINUX = \
-       $(top_builddir)/coregrind/libreplacemalloc_toolpreload_ppc32_linux.a
 
-LIBREPLACEMALLOC_PPC64_LINUX = \
-       $(top_builddir)/coregrind/libreplacemalloc_toolpreload_ppc64_linux.a
+TOOL_LDADD_COMMON = -lgcc
+TOOL_LDADD_@VGCONF_PLATFORM_PRI_CAPS@ = \
+       $(TOOL_DEPENDENCIES_@VGCONF_PLATFORM_PRI_CAPS@) $(TOOL_LDADD_COMMON)
+if VGCONF_HAVE_PLATFORM_SEC
+TOOL_LDADD_@VGCONF_PLATFORM_SEC_CAPS@ = \
+       $(TOOL_DEPENDENCIES_@VGCONF_PLATFORM_SEC_CAPS@) $(TOOL_LDADD_COMMON)
+endif
+
+
+# -Wl,--build-id=none is needed when linking tools on Linux. Without this
+# flag newer ld versions (2.20 and later) create a .note.gnu.build-id at the
+# default text segment address, which of course means the resulting executable
+# is unusable. So we have to tell ld not to generate that, with --build-id=none.
+TOOL_LDFLAGS_COMMON_LINUX = \
+       -static -nodefaultlibs -nostartfiles -u _start @FLAG_NO_BUILD_ID@
+TOOL_LDFLAGS_COMMON_DARWIN = \
+       -nodefaultlibs -nostartfiles -Wl,-u,__start -Wl,-e,__start
 
-COREGRIND_LIBS_X86_LINUX = \
-       $(top_builddir)/coregrind/libcoregrind_x86_linux.a \
-       @VEX_DIR@/libvex_x86_linux.a
+TOOL_LDFLAGS_X86_LINUX = \
+       $(TOOL_LDFLAGS_COMMON_LINUX) @FLAG_M32@
 
-COREGRIND_LIBS_AMD64_LINUX = \
-       $(top_builddir)/coregrind/libcoregrind_amd64_linux.a \
-       @VEX_DIR@/libvex_amd64_linux.a
+TOOL_LDFLAGS_AMD64_LINUX = \
+       $(TOOL_LDFLAGS_COMMON_LINUX) @FLAG_M64@
 
-COREGRIND_LIBS_PPC32_LINUX = \
-       $(top_builddir)/coregrind/libcoregrind_ppc32_linux.a \
-       @VEX_DIR@/libvex_ppc32_linux.a
+TOOL_LDFLAGS_PPC32_LINUX = \
+       $(TOOL_LDFLAGS_COMMON_LINUX) @FLAG_M32@
 
-COREGRIND_LIBS_PPC64_LINUX = \
-       $(top_builddir)/coregrind/libcoregrind_ppc64_linux.a \
-       @VEX_DIR@/libvex_ppc64_linux.a
+TOOL_LDFLAGS_PPC64_LINUX = \
+       $(TOOL_LDFLAGS_COMMON_LINUX) @FLAG_M64@
 
-##.PHONY:  @VEX_DIR@/libvex.a
+TOOL_LDFLAGS_ARM_LINUX = \
+       $(TOOL_LDFLAGS_COMMON_LINUX) @FLAG_M32@
 
-@VEX_DIR@/libvex_x86_linux.a: @VEX_DIR@/priv/main/vex_svnversion.h
-       $(MAKE) -C @VEX_DIR@ CC="$(CC)" libvex_x86_linux.a EXTRA_CFLAGS="$(AM_CFLAGS_X86_LINUX)"
+TOOL_LDFLAGS_S390X_LINUX = \
+       $(TOOL_LDFLAGS_COMMON_LINUX) @FLAG_M64@
 
-@VEX_DIR@/libvex_amd64_linux.a: @VEX_DIR@/priv/main/vex_svnversion.h
-       $(MAKE) -C @VEX_DIR@ CC="$(CC)" libvex_amd64_linux.a EXTRA_CFLAGS="$(AM_CFLAGS_AMD64_LINUX)"
+TOOL_LDFLAGS_X86_DARWIN = \
+       $(TOOL_LDFLAGS_COMMON_DARWIN) -arch i386
 
-@VEX_DIR@/libvex_ppc32_linux.a: @VEX_DIR@/priv/main/vex_svnversion.h
-       $(MAKE) -C @VEX_DIR@ CC="$(CC)" libvex_ppc32_linux.a EXTRA_CFLAGS="$(AM_CFLAGS_PPC32_LINUX)"
+TOOL_LDFLAGS_AMD64_DARWIN = \
+       $(TOOL_LDFLAGS_COMMON_DARWIN) -arch x86_64
 
-@VEX_DIR@/libvex_ppc64_linux.a: @VEX_DIR@/priv/main/vex_svnversion.h
-       $(MAKE) -C @VEX_DIR@ CC="$(CC)" libvex_ppc64_linux.a EXTRA_CFLAGS="$(AM_CFLAGS_PPC64_LINUX)"
+# MIPS Linux default start symbol is __start, not _start like on x86 or amd
+TOOL_LDFLAGS_MIPS32_LINUX = \
+       -static -nodefaultlibs -nostartfiles -u __start @FLAG_NO_BUILD_ID@ \
+       @FLAG_M32@
 
-@VEX_DIR@/priv/main/vex_svnversion.h:
-       $(MAKE) -C @VEX_DIR@ CC="$(CC)" version
+# On Android we must ask for non-executable stack, not sure why.
+if VGCONF_PLATFORMS_INCLUDE_ARM_LINUX
+if VGCONF_PLATVARIANT_IS_ANDROID
+TOOL_LDFLAGS_ARM_LINUX += -Wl,-z,noexecstack
+endif
+endif
 
-TOOL_LDADD_COMMON = -lgcc
-TOOL_LDFLAGS_COMMON = -static \
-       -Wl,-defsym,valt_load_address=@VALT_LOAD_ADDRESS@ \
-       -nodefaultlibs -nostartfiles -u _start
+# NB for 64-bit darwin.  We may want to set -Wl,-pagezero_size to
+# something smaller than the default of 4G, so as to facilitate
+# loading clients who are also linked thusly (currently m_ume.c
+# will fail to load them).  Although such setting is probably
+# better done in link_tool_exe.c.
+#
+#      -Wl,-pagezero_size,0x100000000
 
-TOOL_LDADD_X86_LINUX = $(COREGRIND_LIBS_X86_LINUX) $(TOOL_LDADD_COMMON)
-TOOL_LDFLAGS_X86_LINUX = \
-       $(TOOL_LDFLAGS_COMMON) @FLAG_M32@ \
-       -Wl,-T,$(top_builddir)/valt_load_address_x86_linux.lds
 
-TOOL_LDADD_AMD64_LINUX = $(COREGRIND_LIBS_AMD64_LINUX) $(TOOL_LDADD_COMMON)
-TOOL_LDFLAGS_AMD64_LINUX = \
-       $(TOOL_LDFLAGS_COMMON) -m64 \
-       -Wl,-T,$(top_builddir)/valt_load_address_amd64_linux.lds
+#----------------------------------------------------------------------------
+# vgpreload_<tool>-<platform>.a stuff
+#----------------------------------------------------------------------------
 
-TOOL_LDADD_PPC32_LINUX = $(COREGRIND_LIBS_PPC32_LINUX) $(TOOL_LDADD_COMMON)
-TOOL_LDFLAGS_PPC32_LINUX = \
-       $(TOOL_LDFLAGS_COMMON) @FLAG_M32@ \
-       -Wl,-T,$(top_builddir)/valt_load_address_ppc32_linux.lds
+LIBREPLACEMALLOC_X86_LINUX = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-x86-linux.a
 
-TOOL_LDADD_PPC64_LINUX = $(COREGRIND_LIBS_PPC64_LINUX) $(TOOL_LDADD_COMMON)
-TOOL_LDFLAGS_PPC64_LINUX = \
-       $(TOOL_LDFLAGS_COMMON) -m64 \
-       -Wl,-T,$(top_builddir)/valt_load_address_ppc64_linux.lds
+LIBREPLACEMALLOC_AMD64_LINUX = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-amd64-linux.a
+
+LIBREPLACEMALLOC_PPC32_LINUX = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-ppc32-linux.a
+
+LIBREPLACEMALLOC_PPC64_LINUX = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-ppc64-linux.a
+
+LIBREPLACEMALLOC_ARM_LINUX = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-arm-linux.a
+
+LIBREPLACEMALLOC_X86_DARWIN = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-x86-darwin.a
 
-PRELOAD_LDFLAGS_COMMON = -nostdlib -shared -Wl,-z,interpose,-z,initfirst
-PRELOAD_LDFLAGS_X86_LINUX = $(PRELOAD_LDFLAGS_COMMON) @FLAG_M32@
-PRELOAD_LDFLAGS_AMD64_LINUX = $(PRELOAD_LDFLAGS_COMMON) -m64
-PRELOAD_LDFLAGS_PPC32_LINUX = $(PRELOAD_LDFLAGS_COMMON) @FLAG_M32@
-PRELOAD_LDFLAGS_PPC64_LINUX = $(PRELOAD_LDFLAGS_COMMON) -m64
+LIBREPLACEMALLOC_AMD64_DARWIN = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-amd64-darwin.a
+
+LIBREPLACEMALLOC_S390X_LINUX = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-s390x-linux.a
+
+LIBREPLACEMALLOC_MIPS32_LINUX = \
+       $(top_builddir)/coregrind/libreplacemalloc_toolpreload-mips32-linux.a
 
 LIBREPLACEMALLOC_LDFLAGS_X86_LINUX = \
        -Wl,--whole-archive \
        $(LIBREPLACEMALLOC_X86_LINUX) \
        -Wl,--no-whole-archive
+
 LIBREPLACEMALLOC_LDFLAGS_AMD64_LINUX = \
        -Wl,--whole-archive \
        $(LIBREPLACEMALLOC_AMD64_LINUX) \
        -Wl,--no-whole-archive
+
 LIBREPLACEMALLOC_LDFLAGS_PPC32_LINUX = \
        -Wl,--whole-archive \
        $(LIBREPLACEMALLOC_PPC32_LINUX) \
        -Wl,--no-whole-archive
+
 LIBREPLACEMALLOC_LDFLAGS_PPC64_LINUX = \
        -Wl,--whole-archive \
        $(LIBREPLACEMALLOC_PPC64_LINUX) \
        -Wl,--no-whole-archive
+
+LIBREPLACEMALLOC_LDFLAGS_ARM_LINUX = \
+       -Wl,--whole-archive \
+       $(LIBREPLACEMALLOC_ARM_LINUX) \
+       -Wl,--no-whole-archive
+
+LIBREPLACEMALLOC_LDFLAGS_X86_DARWIN = \
+       $(LIBREPLACEMALLOC_X86_DARWIN)
+
+LIBREPLACEMALLOC_LDFLAGS_AMD64_DARWIN = \
+       $(LIBREPLACEMALLOC_AMD64_DARWIN)
+
+LIBREPLACEMALLOC_LDFLAGS_S390X_LINUX = \
+       -Wl,--whole-archive \
+       $(LIBREPLACEMALLOC_S390X_LINUX) \
+       -Wl,--no-whole-archive
+
+LIBREPLACEMALLOC_LDFLAGS_MIPS32_LINUX = \
+       -Wl,--whole-archive \
+       $(LIBREPLACEMALLOC_MIPS32_LINUX) \
+       -Wl,--no-whole-archive
+
+#----------------------------------------------------------------------------
+# General stuff
+#----------------------------------------------------------------------------
+
+all-local: inplace-noinst_PROGRAMS inplace-noinst_DSYMS
+
+clean-local: clean-noinst_DSYMS
+
+install-exec-local: install-noinst_PROGRAMS install-noinst_DSYMS
+