blob: 9b9b9b53eb3dca1196f2071712d65b3c2bbb3989 [file] [log] [blame]
njn8b68b642009-06-24 00:37:09 +00001# VEX/Makefile is generated from this file at configure-time.
2
3include $(top_srcdir)/Makefile.all.am
4
5#----------------------------------------------------------------------------
6# Headers, etc
7#----------------------------------------------------------------------------
8
9EXTRA_DIST = \
10 HACKING.README \
11 LICENSE.README \
12 LICENSE.GPL \
njn8b68b642009-06-24 00:37:09 +000013 auxprogs/genoffsets.c
14
15pkginclude_HEADERS = \
16 pub/libvex.h \
17 pub/libvex_basictypes.h \
florian7452db82012-08-25 21:48:22 +000018 pub/libvex_emnote.h \
njn8b68b642009-06-24 00:37:09 +000019 pub/libvex_guest_offsets.h \
20 pub/libvex_guest_x86.h \
21 pub/libvex_guest_amd64.h \
22 pub/libvex_guest_ppc32.h \
23 pub/libvex_guest_ppc64.h \
24 pub/libvex_guest_arm.h \
sewardjf0c12502014-01-12 12:54:00 +000025 pub/libvex_guest_arm64.h \
sewardjb5b87402011-03-07 16:05:35 +000026 pub/libvex_guest_s390x.h \
sewardj5db15402012-06-07 09:13:21 +000027 pub/libvex_guest_mips32.h \
floriane42cca52013-08-29 17:59:27 +000028 pub/libvex_guest_mips64.h \
sewardj57300312011-03-07 16:42:02 +000029 pub/libvex_s390x_common.h \
njn8b68b642009-06-24 00:37:09 +000030 pub/libvex_ir.h \
31 pub/libvex_trc_values.h
32
33noinst_HEADERS = \
sewardj27824a72009-07-02 12:23:16 +000034 priv/main_globals.h \
35 priv/main_util.h \
36 priv/ir_match.h \
37 priv/ir_opt.h \
38 priv/guest_generic_bb_to_IR.h \
39 priv/guest_generic_x87.h \
40 priv/guest_x86_defs.h \
41 priv/guest_amd64_defs.h \
42 priv/guest_ppc_defs.h \
43 priv/guest_arm_defs.h \
sewardjf0c12502014-01-12 12:54:00 +000044 priv/guest_arm64_defs.h \
sewardjb5b87402011-03-07 16:05:35 +000045 priv/guest_s390_defs.h \
sewardj5db15402012-06-07 09:13:21 +000046 priv/guest_mips_defs.h \
sewardj27824a72009-07-02 12:23:16 +000047 priv/host_generic_regs.h \
48 priv/host_generic_simd64.h \
sewardjb823b852010-06-18 08:18:38 +000049 priv/host_generic_simd128.h \
sewardjfda50af2013-03-27 11:43:20 +000050 priv/host_generic_simd256.h \
51 priv/host_generic_maddf.h \
sewardj27824a72009-07-02 12:23:16 +000052 priv/host_x86_defs.h \
53 priv/host_amd64_defs.h \
54 priv/host_ppc_defs.h \
sewardjb5b87402011-03-07 16:05:35 +000055 priv/host_arm_defs.h \
sewardjf0c12502014-01-12 12:54:00 +000056 priv/host_arm64_defs.h \
sewardjb5b87402011-03-07 16:05:35 +000057 priv/host_s390_defs.h \
florian4b2e2df2012-09-20 01:22:53 +000058 priv/s390_disasm.h \
florian142a4ba2012-12-24 00:16:23 +000059 priv/s390_defs.h \
Elliott Hughesed398002017-06-21 14:41:24 -070060 priv/host_mips_defs.h
njn8b68b642009-06-24 00:37:09 +000061
62BUILT_SOURCES = pub/libvex_guest_offsets.h
63CLEANFILES = pub/libvex_guest_offsets.h
64
floriana6b17282014-09-05 14:08:51 +000065if COMPILER_IS_CLANG
66CFLAGS_FOR_GENOFFSETS = $(CFLAGS) -no-integrated-as
67else
68CFLAGS_FOR_GENOFFSETS = $(CFLAGS)
69endif
70
njn8b68b642009-06-24 00:37:09 +000071# This is very uggerly. Need to sed out both "xyzzyN" and
72# "xyzzy$N" since gcc on different targets emits the constants
73# differently -- with a leading $ on x86/amd64 but none on ppc32/64.
florian4e94bda2014-10-29 13:57:49 +000074# ICC also emits the constants differently with a leading # #define
sewardjf3d5c6e2010-09-28 15:09:47 +000075pub/libvex_guest_offsets.h: auxprogs/genoffsets.c \
76 pub/libvex_basictypes.h \
77 pub/libvex_guest_x86.h \
78 pub/libvex_guest_amd64.h \
79 pub/libvex_guest_ppc32.h \
80 pub/libvex_guest_ppc64.h \
sewardjb5b87402011-03-07 16:05:35 +000081 pub/libvex_guest_arm.h \
sewardjf0c12502014-01-12 12:54:00 +000082 pub/libvex_guest_arm64.h \
sewardj5db15402012-06-07 09:13:21 +000083 pub/libvex_guest_s390x.h \
floriane42cca52013-08-29 17:59:27 +000084 pub/libvex_guest_mips32.h \
Elliott Hughesed398002017-06-21 14:41:24 -070085 pub/libvex_guest_mips64.h
njn8b68b642009-06-24 00:37:09 +000086 rm -f auxprogs/genoffsets.s
mjwe2990202014-05-09 13:34:13 +000087 $(mkdir_p) auxprogs pub
floriana6b17282014-09-05 14:08:51 +000088 $(CC) $(CFLAGS_FOR_GENOFFSETS) \
sewardj51331e12011-07-07 14:05:39 +000089 $(LIBVEX_CFLAGS) \
sewardj76cd8d72010-08-22 11:51:26 +000090 $(AM_CFLAGS_@VGCONF_PLATFORM_PRI_CAPS@) \
91 -O -S -o auxprogs/genoffsets.s \
mjwe2990202014-05-09 13:34:13 +000092 $(srcdir)/auxprogs/genoffsets.c
florian4e94bda2014-10-29 13:57:49 +000093 grep xyzzy auxprogs/genoffsets.s | grep "^[# ]*#define" \
94 | sed "s/# #define/#define/g" \
sewardj59570ff2010-01-01 11:59:33 +000095 | sed "s/xyzzy\\$$//g" \
96 | sed "s/xyzzy#//g" \
97 | sed "s/xyzzy//g" \
njn8b68b642009-06-24 00:37:09 +000098 > pub/libvex_guest_offsets.h
99 rm -f auxprogs/genoffsets.s
100
101#----------------------------------------------------------------------------
philipped7065d52015-04-01 20:06:26 +0000102# libvex-<platform>-<os>.a : containing all VEX objects, including
103# a main_main.o compiled in single arch (guest==host).
104# libvexmultiarch-<platform>-<os>.a, only containing multiarch_main_main.o,
105# which is main_main.c compiled so that any guest/host combination
106# can be done at runtime.
njn8b68b642009-06-24 00:37:09 +0000107#----------------------------------------------------------------------------
108
philipped7065d52015-04-01 20:06:26 +0000109pkglib_LIBRARIES = libvex-@VGCONF_ARCH_PRI@-@VGCONF_OS@.a \
110 libvexmultiarch-@VGCONF_ARCH_PRI@-@VGCONF_OS@.a
njn8b68b642009-06-24 00:37:09 +0000111if VGCONF_HAVE_PLATFORM_SEC
philipped7065d52015-04-01 20:06:26 +0000112pkglib_LIBRARIES += libvex-@VGCONF_ARCH_SEC@-@VGCONF_OS@.a \
113 libvexmultiarch-@VGCONF_ARCH_SEC@-@VGCONF_OS@.a
njn8b68b642009-06-24 00:37:09 +0000114endif
115
njn8b68b642009-06-24 00:37:09 +0000116LIBVEX_SOURCES_COMMON = \
sewardj27824a72009-07-02 12:23:16 +0000117 priv/main_globals.c \
118 priv/main_main.c \
119 priv/main_util.c \
120 priv/ir_defs.c \
florianbb913cd2012-08-28 16:50:39 +0000121 priv/ir_inject.c \
sewardj27824a72009-07-02 12:23:16 +0000122 priv/ir_match.c \
123 priv/ir_opt.c \
124 priv/guest_generic_bb_to_IR.c \
125 priv/guest_generic_x87.c \
126 priv/guest_x86_helpers.c \
127 priv/guest_x86_toIR.c \
128 priv/guest_amd64_helpers.c \
129 priv/guest_amd64_toIR.c \
130 priv/guest_ppc_helpers.c \
131 priv/guest_ppc_toIR.c \
132 priv/guest_arm_helpers.c \
133 priv/guest_arm_toIR.c \
sewardjf0c12502014-01-12 12:54:00 +0000134 priv/guest_arm64_helpers.c \
135 priv/guest_arm64_toIR.c \
sewardjb5b87402011-03-07 16:05:35 +0000136 priv/guest_s390_helpers.c \
137 priv/guest_s390_toIR.c \
sewardj5db15402012-06-07 09:13:21 +0000138 priv/guest_mips_helpers.c \
139 priv/guest_mips_toIR.c \
sewardj27824a72009-07-02 12:23:16 +0000140 priv/host_generic_regs.c \
141 priv/host_generic_simd64.c \
sewardjb823b852010-06-18 08:18:38 +0000142 priv/host_generic_simd128.c \
sewardjfda50af2013-03-27 11:43:20 +0000143 priv/host_generic_simd256.c \
144 priv/host_generic_maddf.c \
sewardj27824a72009-07-02 12:23:16 +0000145 priv/host_generic_reg_alloc2.c \
146 priv/host_x86_defs.c \
147 priv/host_x86_isel.c \
148 priv/host_amd64_defs.c \
149 priv/host_amd64_isel.c \
150 priv/host_ppc_defs.c \
151 priv/host_ppc_isel.c \
152 priv/host_arm_defs.c \
sewardjb5b87402011-03-07 16:05:35 +0000153 priv/host_arm_isel.c \
sewardjf0c12502014-01-12 12:54:00 +0000154 priv/host_arm64_defs.c \
155 priv/host_arm64_isel.c \
sewardjb5b87402011-03-07 16:05:35 +0000156 priv/host_s390_defs.c \
157 priv/host_s390_isel.c \
florian4b2e2df2012-09-20 01:22:53 +0000158 priv/s390_disasm.c \
sewardj5db15402012-06-07 09:13:21 +0000159 priv/host_mips_defs.c \
Elliott Hughesed398002017-06-21 14:41:24 -0700160 priv/host_mips_isel.c
njn8b68b642009-06-24 00:37:09 +0000161
philipped7065d52015-04-01 20:06:26 +0000162LIBVEXMULTIARCH_SOURCES = priv/multiarch_main_main.c
163
njn8b68b642009-06-24 00:37:09 +0000164LIBVEX_CFLAGS = \
165 -Wbad-function-cast \
njn8b68b642009-06-24 00:37:09 +0000166 -fstrict-aliasing
167
168libvex_@VGCONF_ARCH_PRI@_@VGCONF_OS@_a_SOURCES = $(LIBVEX_SOURCES_COMMON)
169libvex_@VGCONF_ARCH_PRI@_@VGCONF_OS@_a_CPPFLAGS = \
170 $(AM_CPPFLAGS_@VGCONF_PLATFORM_PRI_CAPS@) -Ipriv
171libvex_@VGCONF_ARCH_PRI@_@VGCONF_OS@_a_CFLAGS = \
172 $(AM_CFLAGS_@VGCONF_PLATFORM_PRI_CAPS@) $(LIBVEX_CFLAGS)
173if VGCONF_HAVE_PLATFORM_SEC
174libvex_@VGCONF_ARCH_SEC@_@VGCONF_OS@_a_SOURCES = $(LIBVEX_SOURCES_COMMON)
175libvex_@VGCONF_ARCH_SEC@_@VGCONF_OS@_a_CPPFLAGS = \
176 $(AM_CPPFLAGS_@VGCONF_PLATFORM_SEC_CAPS@) -Ipriv
177libvex_@VGCONF_ARCH_SEC@_@VGCONF_OS@_a_CFLAGS = \
178 $(AM_CFLAGS_@VGCONF_PLATFORM_SEC_CAPS@) $(LIBVEX_CFLAGS)
179endif
180
philipped7065d52015-04-01 20:06:26 +0000181libvexmultiarch_@VGCONF_ARCH_PRI@_@VGCONF_OS@_a_SOURCES = \
182 $(LIBVEXMULTIARCH_SOURCES)
183libvexmultiarch_@VGCONF_ARCH_PRI@_@VGCONF_OS@_a_CPPFLAGS = \
184 $(AM_CPPFLAGS_@VGCONF_PLATFORM_PRI_CAPS@) -Ipriv
185libvexmultiarch_@VGCONF_ARCH_PRI@_@VGCONF_OS@_a_CFLAGS = \
186 $(AM_CFLAGS_@VGCONF_PLATFORM_PRI_CAPS@) $(LIBVEX_CFLAGS)
187if VGCONF_HAVE_PLATFORM_SEC
188libvexmultiarch_@VGCONF_ARCH_SEC@_@VGCONF_OS@_a_SOURCES = \
189 $(LIBVEXMULTIARCH_SOURCES)
190libvexmultiarch_@VGCONF_ARCH_SEC@_@VGCONF_OS@_a_CPPFLAGS = \
191 $(AM_CPPFLAGS_@VGCONF_PLATFORM_SEC_CAPS@) -Ipriv
192libvexmultiarch_@VGCONF_ARCH_SEC@_@VGCONF_OS@_a_CFLAGS = \
193 $(AM_CFLAGS_@VGCONF_PLATFORM_SEC_CAPS@) $(LIBVEX_CFLAGS)
194endif
195