blob: 826aeb856411491a1b1acf6ee2f1b1312fb12c59 [file] [log] [blame]
Nguyen Anh Quynh296a2312014-03-05 23:50:41 +08001# Capstone Disassembly Engine
Nguyen Anh Quynh1ed8bb62014-03-10 23:14:30 -07002# By Nguyen Anh Quynh <aquynh@gmail.com>, 2013-2014
Nguyen Anh Quynh5e107ab2013-12-31 23:38:28 +08003
danghvu6f52bf92013-12-19 22:43:01 -06004include config.mk
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +08005include pkgconfig.mk # package version
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +08006include functions.mk
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +08007
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +02008# Verbose output?
9V ?= 0
10
Stephen5e184ec2018-05-16 16:55:44 -070011OS := $(shell uname)
12ifeq ($(OS),Darwin)
Albert Long6f4fcff2019-01-25 12:36:37 +080013LIBARCHS ?= x86_64
Stephen5e184ec2018-05-16 16:55:44 -070014PREFIX ?= /usr/local
15endif
16
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +020017ifeq ($(PKG_EXTRA),)
18PKG_VERSION = $(PKG_MAJOR).$(PKG_MINOR)
19else
20PKG_VERSION = $(PKG_MAJOR).$(PKG_MINOR).$(PKG_EXTRA)
21endif
22
Nguyen Anh Quynhd80cede2014-01-16 21:07:59 +080023ifeq ($(CROSS),)
Nguyen Anh Quynhd80cede2014-01-16 21:07:59 +080024RANLIB ?= ranlib
Cen Zhangf6f87eb2019-07-27 00:16:01 +080025else ifeq ($(ANDROID), 1)
26CC = $(CROSS)/../../bin/clang
27AR = $(CROSS)/ar
28RANLIB = $(CROSS)/ranlib
29STRIP = $(CROSS)/strip
Nguyen Anh Quynhd80cede2014-01-16 21:07:59 +080030else
31CC = $(CROSS)gcc
32AR = $(CROSS)ar
33RANLIB = $(CROSS)ranlib
34STRIP = $(CROSS)strip
35endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080036
Nguyen Anh Quynh77af9fb2014-04-29 07:11:55 +080037ifneq (,$(findstring yes,$(CAPSTONE_DIET)))
38CFLAGS ?= -Os
39CFLAGS += -DCAPSTONE_DIET
40else
41CFLAGS ?= -O3
42endif
43
baguette86e84502014-08-17 20:59:05 +020044ifneq (,$(findstring yes,$(CAPSTONE_X86_ATT_DISABLE)))
45CFLAGS += -DCAPSTONE_X86_ATT_DISABLE
46endif
47
Marius Melzer171f28e2019-01-21 14:23:30 +010048CFLAGS += -fPIC -Wall -Wwrite-strings -Wmissing-prototypes -Iinclude
Nguyen Anh Quynh59492c22014-01-05 23:41:31 +080049
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +080050ifeq ($(CAPSTONE_USE_SYS_DYN_MEM),yes)
Nguyen Anh Quynh87a3f692014-05-10 19:26:32 +080051CFLAGS += -DCAPSTONE_USE_SYS_DYN_MEM
Nguyen Anh Quynh59492c22014-01-05 23:41:31 +080052endif
53
reverserbcf09f42015-04-09 18:28:19 +010054ifeq ($(CAPSTONE_HAS_OSXKERNEL), yes)
55CFLAGS += -DCAPSTONE_HAS_OSXKERNEL
Pbb8741bd2015-11-10 23:02:26 +010056SDKROOT ?= $(shell xcodebuild -version -sdk macosx Path)
57CFLAGS += -mmacosx-version-min=10.5 \
58 -isysroot$(SDKROOT) \
59 -I$(SDKROOT)/System/Library/Frameworks/Kernel.framework/Headers \
60 -mkernel \
61 -fno-builtin
reverserbcf09f42015-04-09 18:28:19 +010062endif
63
pancake02cad6e2013-11-27 15:38:44 +010064PREFIX ?= /usr
65DESTDIR ?=
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020066ifndef BUILDDIR
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +080067BLDIR = .
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020068OBJDIR = .
69else
Ole André Vadla Ravnås7a734392014-04-30 00:06:41 +020070BLDIR = $(abspath $(BUILDDIR))
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +080071OBJDIR = $(BLDIR)/obj
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020072endif
pancake91659c02015-11-08 12:05:41 +010073INCDIR ?= $(PREFIX)/include
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080074
Nguyen Anh Quynh235a2742014-03-29 21:09:35 +080075UNAME_S := $(shell uname -s)
Nguyen Anh Quynhad6cc982014-04-08 23:34:44 +080076
Nguyen Anh Quynh360bf1e2014-04-14 13:36:46 +080077LIBDIRARCH ?= lib
78# Uncomment the below line to installs x86_64 libs to lib64/ directory.
79# Or better, pass 'LIBDIRARCH=lib64' to 'make install/uninstall' via 'make.sh'.
80#LIBDIRARCH ?= lib64
81LIBDIR = $(DESTDIR)$(PREFIX)/$(LIBDIRARCH)
Nguyen Anh Quynh34603272016-10-10 22:54:16 +080082BINDIR = $(DESTDIR)$(PREFIX)/bin
pancake02cad6e2013-11-27 15:38:44 +010083
Oliver Pinterc5ecae52014-03-23 02:19:59 +010084LIBDATADIR = $(LIBDIR)
Kamil Rytarowski453b41a2015-07-27 04:03:48 +020085
86# Don't redefine $LIBDATADIR when global environment variable
87# USE_GENERIC_LIBDATADIR is set. This is used by the pkgsrc framework.
88
89ifndef USE_GENERIC_LIBDATADIR
Oliver Pinterc5ecae52014-03-23 02:19:59 +010090ifeq ($(UNAME_S), FreeBSD)
Mateusz Piotrowski1849fb22020-02-19 05:33:51 +010091LIBDATADIR = $(DESTDIR)$(PREFIX)/libdata
Oliver Pinterc5ecae52014-03-23 02:19:59 +010092endif
Oliver Pinter25efded2014-03-23 19:10:13 +010093ifeq ($(UNAME_S), DragonFly)
Mateusz Piotrowski1849fb22020-02-19 05:33:51 +010094LIBDATADIR = $(DESTDIR)$(PREFIX)/libdata
Oliver Pinter25efded2014-03-23 19:10:13 +010095endif
Kamil Rytarowski453b41a2015-07-27 04:03:48 +020096endif
Oliver Pinterc5ecae52014-03-23 02:19:59 +010097
Nguyen Anh Quynh64d40832014-01-17 20:55:21 +080098INSTALL_BIN ?= install
99INSTALL_DATA ?= $(INSTALL_BIN) -m0644
Oliver Pinterc5ecae52014-03-23 02:19:59 +0100100INSTALL_LIB ?= $(INSTALL_BIN) -m0755
pancake02cad6e2013-11-27 15:38:44 +0100101
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800102LIBNAME = capstone
pancakeca9f1b22013-12-06 17:03:41 +0100103
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +0800104
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800105DEP_ARM =
Stephen572a4ae2017-10-20 16:17:30 +0100106DEP_ARM += $(wildcard arch/ARM/ARM*.inc)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800107
108LIBOBJ_ARM =
Nguyen Anh Quynh9cc56a32014-01-15 16:01:55 +0800109ifneq (,$(findstring arm,$(CAPSTONE_ARCHS)))
110 CFLAGS += -DCAPSTONE_HAS_ARM
Stephen1ec30602017-10-21 14:47:38 +0100111 LIBSRC_ARM += $(wildcard arch/ARM/ARM*.c)
112 LIBOBJ_ARM += $(LIBSRC_ARM:%.c=$(OBJDIR)/%.o)
danghvu02db4882013-12-20 00:57:12 -0600113endif
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +0800114
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800115DEP_ARM64 =
Stephen572a4ae2017-10-20 16:17:30 +0100116DEP_ARM64 += $(wildcard arch/AArch64/AArch64*.inc)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800117
118LIBOBJ_ARM64 =
119ifneq (,$(findstring aarch64,$(CAPSTONE_ARCHS)))
120 CFLAGS += -DCAPSTONE_HAS_ARM64
Stephen1ec30602017-10-21 14:47:38 +0100121 LIBSRC_ARM64 += $(wildcard arch/AArch64/AArch64*.c)
122 LIBOBJ_ARM64 += $(LIBSRC_ARM64:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800123endif
124
125
Daniel Collin2ee675c2015-08-03 18:45:08 +0200126DEP_M68K =
Stephen572a4ae2017-10-20 16:17:30 +0100127DEP_M68K += $(wildcard arch/M68K/M68K*.h)
Daniel Collin2ee675c2015-08-03 18:45:08 +0200128
129LIBOBJ_M68K =
130ifneq (,$(findstring m68k,$(CAPSTONE_ARCHS)))
131 CFLAGS += -DCAPSTONE_HAS_M68K
Stephen1ec30602017-10-21 14:47:38 +0100132 LIBSRC_M68K += $(wildcard arch/M68K/M68K*.c)
133 LIBOBJ_M68K += $(LIBSRC_M68K:%.c=$(OBJDIR)/%.o)
Daniel Collin2ee675c2015-08-03 18:45:08 +0200134endif
135
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800136DEP_MIPS =
Stephen572a4ae2017-10-20 16:17:30 +0100137DEP_MIPS += $(wildcard arch/Mips/Mips*.inc)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800138
139LIBOBJ_MIPS =
140ifneq (,$(findstring mips,$(CAPSTONE_ARCHS)))
141 CFLAGS += -DCAPSTONE_HAS_MIPS
Stephen1ec30602017-10-21 14:47:38 +0100142 LIBSRC_MIPS += $(wildcard arch/Mips/Mips*.c)
143 LIBOBJ_MIPS += $(LIBSRC_MIPS:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800144endif
145
146
147DEP_PPC =
Stephen572a4ae2017-10-20 16:17:30 +0100148DEP_PPC += $(wildcard arch/PowerPC/PPC*.inc)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800149
150LIBOBJ_PPC =
151ifneq (,$(findstring powerpc,$(CAPSTONE_ARCHS)))
152 CFLAGS += -DCAPSTONE_HAS_POWERPC
Stephen1ec30602017-10-21 14:47:38 +0100153 LIBSRC_PPC += $(wildcard arch/PowerPC/PPC*.c)
154 LIBOBJ_PPC += $(LIBSRC_PPC:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800155endif
156
157
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800158DEP_SPARC =
Stephen572a4ae2017-10-20 16:17:30 +0100159DEP_SPARC += $(wildcard arch/Sparc/Sparc*.inc)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800160
161LIBOBJ_SPARC =
162ifneq (,$(findstring sparc,$(CAPSTONE_ARCHS)))
163 CFLAGS += -DCAPSTONE_HAS_SPARC
Stephen1ec30602017-10-21 14:47:38 +0100164 LIBSRC_SPARC += $(wildcard arch/Sparc/Sparc*.c)
165 LIBOBJ_SPARC += $(LIBSRC_SPARC:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800166endif
167
168
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800169DEP_SYSZ =
Stephen572a4ae2017-10-20 16:17:30 +0100170DEP_SYSZ += $(wildcard arch/SystemZ/SystemZ*.inc)
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800171
172LIBOBJ_SYSZ =
173ifneq (,$(findstring systemz,$(CAPSTONE_ARCHS)))
174 CFLAGS += -DCAPSTONE_HAS_SYSZ
Stephen1ec30602017-10-21 14:47:38 +0100175 LIBSRC_SYSZ += $(wildcard arch/SystemZ/SystemZ*.c)
176 LIBOBJ_SYSZ += $(LIBSRC_SYSZ:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800177endif
178
179
Nguyen Anh Quynh95181482014-03-25 23:20:41 +0800180# by default, we compile full X86 instruction sets
Nguyen Anh Quynh59b54892014-03-27 10:54:44 +0800181X86_REDUCE =
182ifneq (,$(findstring yes,$(CAPSTONE_X86_REDUCE)))
183X86_REDUCE = _reduce
Nguyen Anh Quynh81d930a2014-03-28 10:28:57 +0800184CFLAGS += -DCAPSTONE_X86_REDUCE -Os
Nguyen Anh Quynh95181482014-03-25 23:20:41 +0800185endif
186
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800187DEP_X86 =
Nguyen Anh Quynh59b54892014-03-27 10:54:44 +0800188DEP_X86 += arch/X86/X86GenAsmWriter$(X86_REDUCE).inc
189DEP_X86 += arch/X86/X86GenAsmWriter1$(X86_REDUCE).inc
190DEP_X86 += arch/X86/X86GenDisassemblerTables$(X86_REDUCE).inc
191DEP_X86 += arch/X86/X86GenInstrInfo$(X86_REDUCE).inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800192DEP_X86 += arch/X86/X86GenRegisterInfo.inc
Nguyen Anh Quynh0d394aa2015-11-06 10:34:27 +0800193DEP_X86 += arch/X86/X86MappingInsn$(X86_REDUCE).inc
194DEP_X86 += arch/X86/X86MappingInsnOp$(X86_REDUCE).inc
195DEP_X86 += arch/X86/X86ImmSize.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800196
197LIBOBJ_X86 =
198ifneq (,$(findstring x86,$(CAPSTONE_ARCHS)))
199 CFLAGS += -DCAPSTONE_HAS_X86
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200200 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86DisassemblerDecoder.o
201 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Disassembler.o
202 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86IntelInstPrinter.o
Nguyen Anh Quynh50689082014-05-14 12:26:53 +0800203# assembly syntax is irrelevant in Diet mode, when this info is suppressed
204ifeq (,$(findstring yes,$(CAPSTONE_DIET)))
baguette86e84502014-08-17 20:59:05 +0200205ifeq (,$(findstring yes,$(CAPSTONE_X86_ATT_DISABLE)))
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200206 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86ATTInstPrinter.o
Nguyen Anh Quynh50689082014-05-14 12:26:53 +0800207endif
baguette86e84502014-08-17 20:59:05 +0200208endif
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200209 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Mapping.o
210 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Module.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800211endif
212
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800213
214DEP_XCORE =
Stephen572a4ae2017-10-20 16:17:30 +0100215DEP_XCORE += $(wildcard arch/XCore/XCore*.inc)
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800216
217LIBOBJ_XCORE =
218ifneq (,$(findstring xcore,$(CAPSTONE_ARCHS)))
219 CFLAGS += -DCAPSTONE_HAS_XCORE
Stephen1ec30602017-10-21 14:47:38 +0100220 LIBSRC_XCORE += $(wildcard arch/XCore/XCore*.c)
221 LIBOBJ_XCORE += $(LIBSRC_XCORE:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800222endif
223
224
Fotis Loukos0850d552016-05-03 15:52:11 +0300225DEP_TMS320C64X =
Stephen572a4ae2017-10-20 16:17:30 +0100226DEP_TMS320C64X += $(wildcard arch/TMS320C64x/TMS320C64x*.inc)
Fotis Loukos0850d552016-05-03 15:52:11 +0300227
228LIBOBJ_TMS320C64X =
229ifneq (,$(findstring tms320c64x,$(CAPSTONE_ARCHS)))
230 CFLAGS += -DCAPSTONE_HAS_TMS320C64X
Stephen1ec30602017-10-21 14:47:38 +0100231 LIBSRC_TMS320C64X += $(wildcard arch/TMS320C64x/TMS320C64x*.c)
232 LIBOBJ_TMS320C64X += $(LIBSRC_TMS320C64X:%.c=$(OBJDIR)/%.o)
Fotis Loukos0850d552016-05-03 15:52:11 +0300233endif
234
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200235DEP_M680X =
Nguyen Anh Quynhd7281e92017-10-21 14:05:02 +0700236DEP_M680X += $(wildcard arch/M680X/*.inc)
237DEP_M680X += $(wildcard arch/M680X/M680X*.h)
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200238
239LIBOBJ_M680X =
240ifneq (,$(findstring m680x,$(CAPSTONE_ARCHS)))
241 CFLAGS += -DCAPSTONE_HAS_M680X
Nguyen Anh Quynhd7281e92017-10-21 14:05:02 +0700242 LIBSRC_M680X += $(wildcard arch/M680X/*.c)
243 LIBOBJ_M680X += $(LIBSRC_M680X:%.c=$(OBJDIR)/%.o)
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200244endif
Fotis Loukos0850d552016-05-03 15:52:11 +0300245
Nguyen Anh Quynhed1246d2018-03-31 17:29:22 +0800246
247DEP_EVM =
248DEP_EVM += $(wildcard arch/EVM/EVM*.inc)
249
250LIBOBJ_EVM =
251ifneq (,$(findstring evm,$(CAPSTONE_ARCHS)))
252 CFLAGS += -DCAPSTONE_HAS_EVM
253 LIBSRC_EVM += $(wildcard arch/EVM/EVM*.c)
254 LIBOBJ_EVM += $(LIBSRC_EVM:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800255endif
256
257
Sebastian Macke87221fa2018-12-02 21:39:41 +0100258DEP_MOS65XX =
259DEP_MOS65XX += $(wildcard arch/MOS65XX/MOS65XX*.inc)
260
261LIBOBJ_MOS65XX =
262ifneq (,$(findstring mos65xx,$(CAPSTONE_ARCHS)))
263 CFLAGS += -DCAPSTONE_HAS_MOS65XX
264 LIBSRC_MOS65XX += $(wildcard arch/MOS65XX/MOS65XX*.c)
265 LIBOBJ_MOS65XX += $(LIBSRC_MOS65XX:%.c=$(OBJDIR)/%.o)
266endif
267
268
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800269LIBOBJ =
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200270LIBOBJ += $(OBJDIR)/cs.o $(OBJDIR)/utils.o $(OBJDIR)/SStream.o $(OBJDIR)/MCInstrDesc.o $(OBJDIR)/MCRegisterInfo.o
Sebastian Macke87221fa2018-12-02 21:39:41 +0100271LIBOBJ += $(LIBOBJ_ARM) $(LIBOBJ_ARM64) $(LIBOBJ_M68K) $(LIBOBJ_MIPS) $(LIBOBJ_PPC) $(LIBOBJ_SPARC) $(LIBOBJ_SYSZ)
272LIBOBJ += $(LIBOBJ_X86) $(LIBOBJ_XCORE) $(LIBOBJ_TMS320C64X) $(LIBOBJ_M680X) $(LIBOBJ_EVM) $(LIBOBJ_MOS65XX)
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200273LIBOBJ += $(OBJDIR)/MCInst.o
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800274
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800275
Nguyen Anh Quynhf0677ab2015-05-21 12:58:38 +0800276ifeq ($(PKG_EXTRA),)
277PKGCFGDIR = $(LIBDATADIR)/pkgconfig
278else
Nguyen Anh Quynhaf0e9372014-04-12 23:10:46 +0800279PKGCFGDIR ?= $(LIBDATADIR)/pkgconfig
Nguyen Anh Quynhd46a4f22017-04-14 18:43:06 +0800280ifeq ($(PKGCFGDIR),)
281PKGCFGDIR = $(LIBDATADIR)/pkgconfig
282endif
Nguyen Anh Quynhf0677ab2015-05-21 12:58:38 +0800283endif
284
pancake9c10ace2015-02-24 04:55:55 +0100285API_MAJOR=$(shell echo `grep -e CS_API_MAJOR include/capstone/capstone.h | grep -v = | awk '{print $$3}'` | awk '{print $$1}')
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800286VERSION_EXT =
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800287
pancake5a4dabd2017-02-06 13:24:33 +0100288IS_APPLE := $(shell $(CC) -dM -E - < /dev/null 2> /dev/null | grep __apple_build_version__ | wc -l | tr -d " ")
Ole André Vadla Ravnåsc20b0492014-05-01 14:14:57 +0200289ifeq ($(IS_APPLE),1)
Nguyen Anh Quynh44bcb2f2018-07-28 00:24:14 +0800290# on MacOS, do not build in Universal format by default
291MACOS_UNIVERSAL ?= no
Jonas60f17f52017-09-05 16:45:48 +0200292ifeq ($(MACOS_UNIVERSAL),yes)
293CFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
294LDFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
295endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800296EXT = dylib
pancake26943332014-02-04 08:37:55 +0100297VERSION_EXT = $(API_MAJOR).$(EXT)
danghvue1c7a212014-05-14 02:13:36 -0500298$(LIBNAME)_LDFLAGS += -dynamiclib -install_name lib$(LIBNAME).$(VERSION_EXT) -current_version $(PKG_MAJOR).$(PKG_MINOR).$(PKG_EXTRA) -compatibility_version $(PKG_MAJOR).$(PKG_MINOR)
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800299AR_EXT = a
Nguyen Anh Quynhe3606d92014-04-12 18:02:55 +0800300# Homebrew wants to make sure its formula does not disable FORTIFY_SOURCE
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +0800301# However, this is not really necessary because 'CAPSTONE_USE_SYS_DYN_MEM=yes' by default
Nguyen Anh Quynh189e83a2014-03-29 22:36:05 +0800302ifneq ($(HOMEBREW_CAPSTONE),1)
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +0800303ifneq ($(CAPSTONE_USE_SYS_DYN_MEM),yes)
Nguyen Anh Quynhc77cf3a2014-03-07 22:06:51 +0800304# remove string check because OSX kernel complains about missing symbols
305CFLAGS += -D_FORTIFY_SOURCE=0
306endif
Nguyen Anh Quynh189e83a2014-03-29 22:36:05 +0800307endif
pancake02cad6e2013-11-27 15:38:44 +0100308else
Jonas60f17f52017-09-05 16:45:48 +0200309CFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
310LDFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
danghvue1c7a212014-05-14 02:13:36 -0500311$(LIBNAME)_LDFLAGS += -shared
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000312# Cygwin?
pancake5a4dabd2017-02-06 13:24:33 +0100313IS_CYGWIN := $(shell $(CC) -dumpmachine 2>/dev/null | grep -i cygwin | wc -l)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000314ifeq ($(IS_CYGWIN),1)
315EXT = dll
Nguyen Anh Quynh76087d22014-05-14 14:53:51 +0800316AR_EXT = lib
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000317# Cygwin doesn't like -fPIC
318CFLAGS := $(CFLAGS:-fPIC=)
319# On Windows we need the shared library to be executable
320else
321# mingw?
amirgon29893c62018-11-20 18:46:12 +0200322IS_MINGW := $(shell $(CC) --version 2>/dev/null | grep -i "\(mingw\|MSYS\)" | wc -l)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000323ifeq ($(IS_MINGW),1)
324EXT = dll
Nguyen Anh Quynh76087d22014-05-14 14:53:51 +0800325AR_EXT = lib
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000326# mingw doesn't like -fPIC either
327CFLAGS := $(CFLAGS:-fPIC=)
328# On Windows we need the shared library to be executable
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800329else
330# Linux, *BSD
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800331EXT = so
332VERSION_EXT = $(EXT).$(API_MAJOR)
Nguyen Anh Quynh6d5381e2014-03-17 10:37:08 +0800333AR_EXT = a
danghvue1c7a212014-05-14 02:13:36 -0500334$(LIBNAME)_LDFLAGS += -Wl,-soname,lib$(LIBNAME).$(VERSION_EXT)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000335endif
336endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800337endif
338
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200339ifeq ($(CAPSTONE_SHARED),yes)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800340ifeq ($(IS_MINGW),1)
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400341LIBRARY = $(BLDIR)/$(LIBNAME).$(VERSION_EXT)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800342else ifeq ($(IS_CYGWIN),1)
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400343LIBRARY = $(BLDIR)/$(LIBNAME).$(VERSION_EXT)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800344else # *nix
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400345LIBRARY = $(BLDIR)/lib$(LIBNAME).$(VERSION_EXT)
Hilko Bengend83bf842015-02-26 18:37:32 +0100346CFLAGS += -fvisibility=hidden
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200347endif
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800348endif
349
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200350ifeq ($(CAPSTONE_STATIC),yes)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800351ifeq ($(IS_MINGW),1)
352ARCHIVE = $(BLDIR)/$(LIBNAME).$(AR_EXT)
353else ifeq ($(IS_CYGWIN),1)
354ARCHIVE = $(BLDIR)/$(LIBNAME).$(AR_EXT)
355else
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800356ARCHIVE = $(BLDIR)/lib$(LIBNAME).$(AR_EXT)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200357endif
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800358endif
359
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800360PKGCFGF = $(BLDIR)/$(LIBNAME).pc
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800361
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800362.PHONY: all clean install uninstall dist
pancakeca9f1b22013-12-06 17:03:41 +0100363
Nguyen Anh Quynh80ff30b2013-12-09 00:38:44 +0800364all: $(LIBRARY) $(ARCHIVE) $(PKGCFGF)
Nguyen Anh Quynh19af3ec2015-01-30 09:07:51 +0800365ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Adrian Herrera229593d2017-06-02 15:49:10 +0200366 @V=$(V) CC=$(CC) $(MAKE) -C cstool
Nguyen Anh Quynh243d41e2015-01-28 04:42:34 +0800367ifndef BUILDDIR
Stephen4d388002018-05-11 20:36:10 -0700368 $(MAKE) -C tests
Catena cybera69f7882018-12-04 09:02:16 +0100369 $(MAKE) -C suite/fuzz
Nguyen Anh Quynh243d41e2015-01-28 04:42:34 +0800370else
Stephen4d388002018-05-11 20:36:10 -0700371 $(MAKE) -C tests BUILDDIR=$(BLDIR)
Catena cybera69f7882018-12-04 09:02:16 +0100372 $(MAKE) -C suite/fuzz BUILDDIR=$(BLDIR)
Nguyen Anh Quynh243d41e2015-01-28 04:42:34 +0800373endif
Akihiko Odaki798821f2016-09-03 10:54:56 +0900374 $(call install-library,$(BLDIR)/tests/)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200375endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800376
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200377ifeq ($(CAPSTONE_SHARED),yes)
pancakeaddb1922014-02-28 02:44:07 +0100378$(LIBRARY): $(LIBOBJ)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200379ifeq ($(V),0)
Nguyen Anh Quynh8c0ab862014-06-03 23:43:53 +0700380 $(call log,LINK,$(@:$(BLDIR)/%=%))
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200381 @$(create-library)
382else
383 $(create-library)
384endif
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200385endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800386
Nguyen Anh Quynh3ba8c4d2016-10-23 02:09:14 +0800387$(LIBOBJ): config.mk *.h include/capstone/*.h
Nguyen Anh Quynhaeb0c402014-03-27 17:54:27 +0800388
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800389$(LIBOBJ_ARM): $(DEP_ARM)
390$(LIBOBJ_ARM64): $(DEP_ARM64)
Daniel Collin2ee675c2015-08-03 18:45:08 +0200391$(LIBOBJ_M68K): $(DEP_M68K)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800392$(LIBOBJ_MIPS): $(DEP_MIPS)
393$(LIBOBJ_PPC): $(DEP_PPC)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800394$(LIBOBJ_SPARC): $(DEP_SPARC)
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800395$(LIBOBJ_SYSZ): $(DEP_SYSZ)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800396$(LIBOBJ_X86): $(DEP_X86)
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800397$(LIBOBJ_XCORE): $(DEP_XCORE)
Fotis Loukos0850d552016-05-03 15:52:11 +0300398$(LIBOBJ_TMS320C64X): $(DEP_TMS320C64X)
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200399$(LIBOBJ_M680X): $(DEP_M680X)
Nguyen Anh Quynhed1246d2018-03-31 17:29:22 +0800400$(LIBOBJ_EVM): $(DEP_EVM)
Sebastian Macke87221fa2018-12-02 21:39:41 +0100401$(LIBOBJ_MOS65XX): $(DEP_MOS65XX)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800402
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200403ifeq ($(CAPSTONE_STATIC),yes)
pancakeca9f1b22013-12-06 17:03:41 +0100404$(ARCHIVE): $(LIBOBJ)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200405 @rm -f $(ARCHIVE)
406ifeq ($(V),0)
407 $(call log,AR,$(@:$(BLDIR)/%=%))
408 @$(create-archive)
409else
410 $(create-archive)
411endif
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200412endif
pancakef1cbce22013-11-27 15:31:26 +0100413
pancakeca9f1b22013-12-06 17:03:41 +0100414$(PKGCFGF):
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200415ifeq ($(V),0)
416 $(call log,GEN,$(@:$(BLDIR)/%=%))
417 @$(generate-pkgcfg)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800418else
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200419 $(generate-pkgcfg)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800420endif
pancake44ce0fb2013-12-03 04:11:37 +0100421
pancakeca9f1b22013-12-06 17:03:41 +0100422install: $(PKGCFGF) $(ARCHIVE) $(LIBRARY)
Nguyen Anh Quynh4568e7c2018-12-19 09:41:34 +0800423 mkdir -p $(LIBDIR)
424 $(call install-library,$(LIBDIR))
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200425ifeq ($(CAPSTONE_STATIC),yes)
Nguyen Anh Quynh4568e7c2018-12-19 09:41:34 +0800426 $(INSTALL_DATA) $(ARCHIVE) $(LIBDIR)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200427endif
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800428 mkdir -p $(DESTDIR)$(INCDIR)/$(LIBNAME)
429 $(INSTALL_DATA) include/capstone/*.h $(DESTDIR)$(INCDIR)/$(LIBNAME)
Nguyen Anh Quynh9ecc20f2018-12-19 09:21:07 +0700430 mkdir -p $(PKGCFGDIR)
431 $(INSTALL_DATA) $(PKGCFGF) $(PKGCFGDIR)
Summusff859082020-05-04 19:11:16 +0200432ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Nguyen Anh Quynh9ecc20f2018-12-19 09:21:07 +0700433 mkdir -p $(BINDIR)
434 $(INSTALL_LIB) cstool/cstool $(BINDIR)
Summusff859082020-05-04 19:11:16 +0200435endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800436
437uninstall:
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800438 rm -rf $(DESTDIR)$(INCDIR)/$(LIBNAME)
Sergei Trofimovichf1d69522018-12-19 07:52:20 +0000439 rm -f $(LIBDIR)/lib$(LIBNAME).*
Nguyen Anh Quynh9ecc20f2018-12-19 09:21:07 +0700440 rm -f $(PKGCFGDIR)/$(LIBNAME).pc
Summusff859082020-05-04 19:11:16 +0200441ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Nguyen Anh Quynhf8552db2018-12-19 09:25:04 +0700442 rm -f $(BINDIR)/cstool
Summusff859082020-05-04 19:11:16 +0200443endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800444
445clean:
Nguyen Anh Quynh5519a682014-04-29 16:24:30 +0800446 rm -f $(LIBOBJ)
Nguyen Anh Quynhf4c5d5e2017-05-05 09:46:46 +0800447 rm -f $(BLDIR)/lib$(LIBNAME).* $(BLDIR)/$(LIBNAME).pc
Nguyen Anh Quynhd63ddac2014-01-09 10:35:58 +0800448 rm -f $(PKGCFGF)
Cen Zhangd6321692019-07-29 17:37:41 +0800449 [ "${ANDROID}" = "1" ] && rm -rf android-ndk-* || true
Nguyen Tan Cong3d6e56a2015-01-28 00:35:44 +0700450
Nguyen Anh Quynh19af3ec2015-01-30 09:07:51 +0800451ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Summusff859082020-05-04 19:11:16 +0200452 $(MAKE) -C cstool clean
Stephen4d388002018-05-11 20:36:10 -0700453 $(MAKE) -C tests clean
Catena cybera69f7882018-12-04 09:02:16 +0100454 $(MAKE) -C suite/fuzz clean
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800455 rm -f $(BLDIR)/tests/lib$(LIBNAME).$(EXT)
Nguyen Tan Cong3d6e56a2015-01-28 00:35:44 +0700456endif
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800457
458ifdef BUILDDIR
459 rm -rf $(BUILDDIR)
460endif
Nguyen Anh Quynh5519a682014-04-29 16:24:30 +0800461
Nguyen Anh Quynh19af3ec2015-01-30 09:07:51 +0800462ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Stephen4d388002018-05-11 20:36:10 -0700463 $(MAKE) -C bindings/python clean
464 $(MAKE) -C bindings/java clean
465 $(MAKE) -C bindings/ocaml clean
Nguyen Tan Cong3d6e56a2015-01-28 00:35:44 +0700466endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800467
Nguyen Anh Quynha580d922014-01-18 12:47:15 +0800468
469TAG ?= HEAD
470ifeq ($(TAG), HEAD)
471DIST_VERSION = latest
472else
473DIST_VERSION = $(TAG)
474endif
475
pancake35cef7f2014-01-18 03:42:15 +0100476dist:
Nguyen Anh Quynh186d5012014-01-22 18:46:20 +0800477 git archive --format=tar.gz --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).tgz
Nguyen Anh Quynhf4f72532014-03-11 12:29:16 +0800478 git archive --format=zip --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).zip
pancake35cef7f2014-01-18 03:42:15 +0100479
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800480
Pranith Kumar83fb35c2016-02-29 22:58:57 -0500481TESTS = test_basic test_detail test_arm test_arm64 test_m68k test_mips test_ppc test_sparc
Sebastian Macke87221fa2018-12-02 21:39:41 +0100482TESTS += test_systemz test_x86 test_xcore test_iter test_evm test_mos65xx
Nick Briggsce3f0d02017-05-11 08:58:12 -0700483TESTS += test_basic.static test_detail.static test_arm.static test_arm64.static
Daniel Collin2ee675c2015-08-03 18:45:08 +0200484TESTS += test_m68k.static test_mips.static test_ppc.static test_sparc.static
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200485TESTS += test_systemz.static test_x86.static test_xcore.static test_m680x.static
Nguyen Anh Quynhafffa5d2018-07-20 12:36:50 +0800486TESTS += test_skipdata test_skipdata.static test_iter.static test_evm.static
Sebastian Macke87221fa2018-12-02 21:39:41 +0100487TESTS += test_mos65xx.static
Catena cyber3a0467c2018-12-11 03:33:31 +0100488check: $(TESTS) fuzztest fuzzallcorp
Stephen93613782018-05-25 08:59:30 -0400489test_%:
490 ./tests/$@ > /dev/null && echo OK || echo FAILED
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800491
Catena cybera69f7882018-12-04 09:02:16 +0100492FUZZ_INPUTS = $(shell find suite/MC -type f -name '*.cs')
493
494fuzztest:
495 ./suite/fuzz/fuzz_disasm $(FUZZ_INPUTS)
496
Catena cyber3a0467c2018-12-11 03:33:31 +0100497fuzzallcorp:
Catena cyber4f6e6042018-12-19 08:43:31 +0100498ifneq ($(wildcard suite/fuzz/corpus-libFuzzer-capstone_fuzz_disasmnext-latest),)
Catena cyber3a0467c2018-12-11 03:33:31 +0100499 ./suite/fuzz/fuzz_bindisasm suite/fuzz/corpus-libFuzzer-capstone_fuzz_disasmnext-latest/
Catena cyber4f6e6042018-12-19 08:43:31 +0100500else
501 @echo "Skipping tests on whole corpus"
502endif
Catena cyber3a0467c2018-12-11 03:33:31 +0100503
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200504$(OBJDIR)/%.o: %.c
505 @mkdir -p $(@D)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200506ifeq ($(V),0)
507 $(call log,CC,$(@:$(OBJDIR)/%=%))
508 @$(compile)
509else
510 $(compile)
511endif
512
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200513
Akihiko Odaki798821f2016-09-03 10:54:56 +0900514ifeq ($(CAPSTONE_SHARED),yes)
515define install-library
516 $(INSTALL_LIB) $(LIBRARY) $1
517 $(if $(VERSION_EXT),
518 cd $1 && \
Akihiko Odakiec407532016-09-11 09:00:32 +0900519 rm -f lib$(LIBNAME).$(EXT) && \
Akihiko Odaki798821f2016-09-03 10:54:56 +0900520 ln -s lib$(LIBNAME).$(VERSION_EXT) lib$(LIBNAME).$(EXT))
521endef
522else
523define install-library
524endef
525endif
526
527
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200528define create-archive
529 $(AR) q $(ARCHIVE) $(LIBOBJ)
530 $(RANLIB) $(ARCHIVE)
531endef
532
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +0800533
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200534define create-library
danghvue1c7a212014-05-14 02:13:36 -0500535 $(CC) $(LDFLAGS) $($(LIBNAME)_LDFLAGS) $(LIBOBJ) -o $(LIBRARY)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200536endef
537
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +0800538
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200539define generate-pkgcfg
Ole André Vadla Ravnås495a4f52015-04-23 17:55:06 +0200540 mkdir -p $(BLDIR)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200541 echo 'Name: capstone' > $(PKGCFGF)
542 echo 'Description: Capstone disassembly engine' >> $(PKGCFGF)
543 echo 'Version: $(PKG_VERSION)' >> $(PKGCFGF)
544 echo 'libdir=$(LIBDIR)' >> $(PKGCFGF)
rwmjonesff11fa22019-01-12 06:07:02 +0000545 echo 'includedir=$(INCDIR)/capstone' >> $(PKGCFGF)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200546 echo 'archive=$${libdir}/libcapstone.a' >> $(PKGCFGF)
547 echo 'Libs: -L$${libdir} -lcapstone' >> $(PKGCFGF)
548 echo 'Cflags: -I$${includedir}' >> $(PKGCFGF)
549endef