blob: 378f2feac3c586ff0b585fc439d9f722cf1079e4 [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)
blacktop0999ad12018-10-03 03:21:54 -040013LIBARCHS = 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
Nguyen Anh Quynhd80cede2014-01-16 21:07:59 +080025else
26CC = $(CROSS)gcc
27AR = $(CROSS)ar
28RANLIB = $(CROSS)ranlib
29STRIP = $(CROSS)strip
30endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080031
Nguyen Anh Quynh77af9fb2014-04-29 07:11:55 +080032ifneq (,$(findstring yes,$(CAPSTONE_DIET)))
33CFLAGS ?= -Os
34CFLAGS += -DCAPSTONE_DIET
35else
36CFLAGS ?= -O3
37endif
38
baguette86e84502014-08-17 20:59:05 +020039ifneq (,$(findstring yes,$(CAPSTONE_X86_ATT_DISABLE)))
40CFLAGS += -DCAPSTONE_X86_ATT_DISABLE
41endif
42
Richard Henderson22ead3e2017-10-21 17:45:40 -070043CFLAGS += -fPIC -Wall -Wwrite-strings -Iinclude
Nguyen Anh Quynh59492c22014-01-05 23:41:31 +080044
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +080045ifeq ($(CAPSTONE_USE_SYS_DYN_MEM),yes)
Nguyen Anh Quynh87a3f692014-05-10 19:26:32 +080046CFLAGS += -DCAPSTONE_USE_SYS_DYN_MEM
Nguyen Anh Quynh59492c22014-01-05 23:41:31 +080047endif
48
reverserbcf09f42015-04-09 18:28:19 +010049ifeq ($(CAPSTONE_HAS_OSXKERNEL), yes)
50CFLAGS += -DCAPSTONE_HAS_OSXKERNEL
Pbb8741bd2015-11-10 23:02:26 +010051SDKROOT ?= $(shell xcodebuild -version -sdk macosx Path)
52CFLAGS += -mmacosx-version-min=10.5 \
53 -isysroot$(SDKROOT) \
54 -I$(SDKROOT)/System/Library/Frameworks/Kernel.framework/Headers \
55 -mkernel \
56 -fno-builtin
reverserbcf09f42015-04-09 18:28:19 +010057endif
58
pancake02cad6e2013-11-27 15:38:44 +010059PREFIX ?= /usr
60DESTDIR ?=
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020061ifndef BUILDDIR
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +080062BLDIR = .
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020063OBJDIR = .
64else
Ole André Vadla Ravnås7a734392014-04-30 00:06:41 +020065BLDIR = $(abspath $(BUILDDIR))
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +080066OBJDIR = $(BLDIR)/obj
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020067endif
pancake91659c02015-11-08 12:05:41 +010068INCDIR ?= $(PREFIX)/include
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080069
Nguyen Anh Quynh235a2742014-03-29 21:09:35 +080070UNAME_S := $(shell uname -s)
Nguyen Anh Quynhad6cc982014-04-08 23:34:44 +080071
Nguyen Anh Quynh360bf1e2014-04-14 13:36:46 +080072LIBDIRARCH ?= lib
73# Uncomment the below line to installs x86_64 libs to lib64/ directory.
74# Or better, pass 'LIBDIRARCH=lib64' to 'make install/uninstall' via 'make.sh'.
75#LIBDIRARCH ?= lib64
76LIBDIR = $(DESTDIR)$(PREFIX)/$(LIBDIRARCH)
Nguyen Anh Quynh34603272016-10-10 22:54:16 +080077BINDIR = $(DESTDIR)$(PREFIX)/bin
pancake02cad6e2013-11-27 15:38:44 +010078
Oliver Pinterc5ecae52014-03-23 02:19:59 +010079LIBDATADIR = $(LIBDIR)
Kamil Rytarowski453b41a2015-07-27 04:03:48 +020080
81# Don't redefine $LIBDATADIR when global environment variable
82# USE_GENERIC_LIBDATADIR is set. This is used by the pkgsrc framework.
83
84ifndef USE_GENERIC_LIBDATADIR
Oliver Pinterc5ecae52014-03-23 02:19:59 +010085ifeq ($(UNAME_S), FreeBSD)
pancake91659c02015-11-08 12:05:41 +010086LIBDATADIR = $(PREFIX)/libdata
Oliver Pinterc5ecae52014-03-23 02:19:59 +010087endif
Oliver Pinter25efded2014-03-23 19:10:13 +010088ifeq ($(UNAME_S), DragonFly)
pancake91659c02015-11-08 12:05:41 +010089LIBDATADIR = $(PREFIX)/libdata
Oliver Pinter25efded2014-03-23 19:10:13 +010090endif
Kamil Rytarowski453b41a2015-07-27 04:03:48 +020091endif
Oliver Pinterc5ecae52014-03-23 02:19:59 +010092
Nguyen Anh Quynh64d40832014-01-17 20:55:21 +080093INSTALL_BIN ?= install
94INSTALL_DATA ?= $(INSTALL_BIN) -m0644
Oliver Pinterc5ecae52014-03-23 02:19:59 +010095INSTALL_LIB ?= $(INSTALL_BIN) -m0755
pancake02cad6e2013-11-27 15:38:44 +010096
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080097LIBNAME = capstone
pancakeca9f1b22013-12-06 17:03:41 +010098
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +080099
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800100DEP_ARM =
Stephen572a4ae2017-10-20 16:17:30 +0100101DEP_ARM += $(wildcard arch/ARM/ARM*.inc)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800102
103LIBOBJ_ARM =
Nguyen Anh Quynh9cc56a32014-01-15 16:01:55 +0800104ifneq (,$(findstring arm,$(CAPSTONE_ARCHS)))
105 CFLAGS += -DCAPSTONE_HAS_ARM
Stephen1ec30602017-10-21 14:47:38 +0100106 LIBSRC_ARM += $(wildcard arch/ARM/ARM*.c)
107 LIBOBJ_ARM += $(LIBSRC_ARM:%.c=$(OBJDIR)/%.o)
danghvu02db4882013-12-20 00:57:12 -0600108endif
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +0800109
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800110DEP_ARM64 =
Stephen572a4ae2017-10-20 16:17:30 +0100111DEP_ARM64 += $(wildcard arch/AArch64/AArch64*.inc)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800112
113LIBOBJ_ARM64 =
114ifneq (,$(findstring aarch64,$(CAPSTONE_ARCHS)))
115 CFLAGS += -DCAPSTONE_HAS_ARM64
Stephen1ec30602017-10-21 14:47:38 +0100116 LIBSRC_ARM64 += $(wildcard arch/AArch64/AArch64*.c)
117 LIBOBJ_ARM64 += $(LIBSRC_ARM64:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800118endif
119
120
Daniel Collin2ee675c2015-08-03 18:45:08 +0200121DEP_M68K =
Stephen572a4ae2017-10-20 16:17:30 +0100122DEP_M68K += $(wildcard arch/M68K/M68K*.h)
Daniel Collin2ee675c2015-08-03 18:45:08 +0200123
124LIBOBJ_M68K =
125ifneq (,$(findstring m68k,$(CAPSTONE_ARCHS)))
126 CFLAGS += -DCAPSTONE_HAS_M68K
Stephen1ec30602017-10-21 14:47:38 +0100127 LIBSRC_M68K += $(wildcard arch/M68K/M68K*.c)
128 LIBOBJ_M68K += $(LIBSRC_M68K:%.c=$(OBJDIR)/%.o)
Daniel Collin2ee675c2015-08-03 18:45:08 +0200129endif
130
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800131DEP_MIPS =
Stephen572a4ae2017-10-20 16:17:30 +0100132DEP_MIPS += $(wildcard arch/Mips/Mips*.inc)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800133
134LIBOBJ_MIPS =
135ifneq (,$(findstring mips,$(CAPSTONE_ARCHS)))
136 CFLAGS += -DCAPSTONE_HAS_MIPS
Stephen1ec30602017-10-21 14:47:38 +0100137 LIBSRC_MIPS += $(wildcard arch/Mips/Mips*.c)
138 LIBOBJ_MIPS += $(LIBSRC_MIPS:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800139endif
140
141
142DEP_PPC =
Stephen572a4ae2017-10-20 16:17:30 +0100143DEP_PPC += $(wildcard arch/PowerPC/PPC*.inc)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800144
145LIBOBJ_PPC =
146ifneq (,$(findstring powerpc,$(CAPSTONE_ARCHS)))
147 CFLAGS += -DCAPSTONE_HAS_POWERPC
Stephen1ec30602017-10-21 14:47:38 +0100148 LIBSRC_PPC += $(wildcard arch/PowerPC/PPC*.c)
149 LIBOBJ_PPC += $(LIBSRC_PPC:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800150endif
151
152
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800153DEP_SPARC =
Stephen572a4ae2017-10-20 16:17:30 +0100154DEP_SPARC += $(wildcard arch/Sparc/Sparc*.inc)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800155
156LIBOBJ_SPARC =
157ifneq (,$(findstring sparc,$(CAPSTONE_ARCHS)))
158 CFLAGS += -DCAPSTONE_HAS_SPARC
Stephen1ec30602017-10-21 14:47:38 +0100159 LIBSRC_SPARC += $(wildcard arch/Sparc/Sparc*.c)
160 LIBOBJ_SPARC += $(LIBSRC_SPARC:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800161endif
162
163
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800164DEP_SYSZ =
Stephen572a4ae2017-10-20 16:17:30 +0100165DEP_SYSZ += $(wildcard arch/SystemZ/SystemZ*.inc)
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800166
167LIBOBJ_SYSZ =
168ifneq (,$(findstring systemz,$(CAPSTONE_ARCHS)))
169 CFLAGS += -DCAPSTONE_HAS_SYSZ
Stephen1ec30602017-10-21 14:47:38 +0100170 LIBSRC_SYSZ += $(wildcard arch/SystemZ/SystemZ*.c)
171 LIBOBJ_SYSZ += $(LIBSRC_SYSZ:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800172endif
173
174
Nguyen Anh Quynh95181482014-03-25 23:20:41 +0800175# by default, we compile full X86 instruction sets
Nguyen Anh Quynh59b54892014-03-27 10:54:44 +0800176X86_REDUCE =
177ifneq (,$(findstring yes,$(CAPSTONE_X86_REDUCE)))
178X86_REDUCE = _reduce
Nguyen Anh Quynh81d930a2014-03-28 10:28:57 +0800179CFLAGS += -DCAPSTONE_X86_REDUCE -Os
Nguyen Anh Quynh95181482014-03-25 23:20:41 +0800180endif
181
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800182DEP_X86 =
Nguyen Anh Quynh59b54892014-03-27 10:54:44 +0800183DEP_X86 += arch/X86/X86GenAsmWriter$(X86_REDUCE).inc
184DEP_X86 += arch/X86/X86GenAsmWriter1$(X86_REDUCE).inc
185DEP_X86 += arch/X86/X86GenDisassemblerTables$(X86_REDUCE).inc
186DEP_X86 += arch/X86/X86GenInstrInfo$(X86_REDUCE).inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800187DEP_X86 += arch/X86/X86GenRegisterInfo.inc
Nguyen Anh Quynh0d394aa2015-11-06 10:34:27 +0800188DEP_X86 += arch/X86/X86MappingInsn$(X86_REDUCE).inc
189DEP_X86 += arch/X86/X86MappingInsnOp$(X86_REDUCE).inc
190DEP_X86 += arch/X86/X86ImmSize.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800191
192LIBOBJ_X86 =
193ifneq (,$(findstring x86,$(CAPSTONE_ARCHS)))
194 CFLAGS += -DCAPSTONE_HAS_X86
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200195 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86DisassemblerDecoder.o
196 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Disassembler.o
197 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86IntelInstPrinter.o
Nguyen Anh Quynh50689082014-05-14 12:26:53 +0800198# assembly syntax is irrelevant in Diet mode, when this info is suppressed
199ifeq (,$(findstring yes,$(CAPSTONE_DIET)))
baguette86e84502014-08-17 20:59:05 +0200200ifeq (,$(findstring yes,$(CAPSTONE_X86_ATT_DISABLE)))
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200201 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86ATTInstPrinter.o
Nguyen Anh Quynh50689082014-05-14 12:26:53 +0800202endif
baguette86e84502014-08-17 20:59:05 +0200203endif
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200204 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Mapping.o
205 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Module.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800206endif
207
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800208
209DEP_XCORE =
Stephen572a4ae2017-10-20 16:17:30 +0100210DEP_XCORE += $(wildcard arch/XCore/XCore*.inc)
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800211
212LIBOBJ_XCORE =
213ifneq (,$(findstring xcore,$(CAPSTONE_ARCHS)))
214 CFLAGS += -DCAPSTONE_HAS_XCORE
Stephen1ec30602017-10-21 14:47:38 +0100215 LIBSRC_XCORE += $(wildcard arch/XCore/XCore*.c)
216 LIBOBJ_XCORE += $(LIBSRC_XCORE:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800217endif
218
219
Fotis Loukos0850d552016-05-03 15:52:11 +0300220DEP_TMS320C64X =
Stephen572a4ae2017-10-20 16:17:30 +0100221DEP_TMS320C64X += $(wildcard arch/TMS320C64x/TMS320C64x*.inc)
Fotis Loukos0850d552016-05-03 15:52:11 +0300222
223LIBOBJ_TMS320C64X =
224ifneq (,$(findstring tms320c64x,$(CAPSTONE_ARCHS)))
225 CFLAGS += -DCAPSTONE_HAS_TMS320C64X
Stephen1ec30602017-10-21 14:47:38 +0100226 LIBSRC_TMS320C64X += $(wildcard arch/TMS320C64x/TMS320C64x*.c)
227 LIBOBJ_TMS320C64X += $(LIBSRC_TMS320C64X:%.c=$(OBJDIR)/%.o)
Fotis Loukos0850d552016-05-03 15:52:11 +0300228endif
229
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200230DEP_M680X =
Nguyen Anh Quynhd7281e92017-10-21 14:05:02 +0700231DEP_M680X += $(wildcard arch/M680X/*.inc)
232DEP_M680X += $(wildcard arch/M680X/M680X*.h)
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200233
234LIBOBJ_M680X =
235ifneq (,$(findstring m680x,$(CAPSTONE_ARCHS)))
236 CFLAGS += -DCAPSTONE_HAS_M680X
Nguyen Anh Quynhd7281e92017-10-21 14:05:02 +0700237 LIBSRC_M680X += $(wildcard arch/M680X/*.c)
238 LIBOBJ_M680X += $(LIBSRC_M680X:%.c=$(OBJDIR)/%.o)
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200239endif
Fotis Loukos0850d552016-05-03 15:52:11 +0300240
Nguyen Anh Quynhed1246d2018-03-31 17:29:22 +0800241
242DEP_EVM =
243DEP_EVM += $(wildcard arch/EVM/EVM*.inc)
244
245LIBOBJ_EVM =
246ifneq (,$(findstring evm,$(CAPSTONE_ARCHS)))
247 CFLAGS += -DCAPSTONE_HAS_EVM
248 LIBSRC_EVM += $(wildcard arch/EVM/EVM*.c)
249 LIBOBJ_EVM += $(LIBSRC_EVM:%.c=$(OBJDIR)/%.o)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800250endif
251
252
253LIBOBJ =
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200254LIBOBJ += $(OBJDIR)/cs.o $(OBJDIR)/utils.o $(OBJDIR)/SStream.o $(OBJDIR)/MCInstrDesc.o $(OBJDIR)/MCRegisterInfo.o
Nguyen Anh Quynhed1246d2018-03-31 17:29:22 +0800255LIBOBJ += $(LIBOBJ_ARM) $(LIBOBJ_ARM64) $(LIBOBJ_M68K) $(LIBOBJ_MIPS) $(LIBOBJ_PPC) $(LIBOBJ_SPARC) $(LIBOBJ_SYSZ) $(LIBOBJ_X86) $(LIBOBJ_XCORE) $(LIBOBJ_TMS320C64X) $(LIBOBJ_M680X) $(LIBOBJ_EVM)
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200256LIBOBJ += $(OBJDIR)/MCInst.o
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800257
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800258
Nguyen Anh Quynhf0677ab2015-05-21 12:58:38 +0800259ifeq ($(PKG_EXTRA),)
260PKGCFGDIR = $(LIBDATADIR)/pkgconfig
261else
Nguyen Anh Quynhaf0e9372014-04-12 23:10:46 +0800262PKGCFGDIR ?= $(LIBDATADIR)/pkgconfig
Nguyen Anh Quynhd46a4f22017-04-14 18:43:06 +0800263ifeq ($(PKGCFGDIR),)
264PKGCFGDIR = $(LIBDATADIR)/pkgconfig
265endif
Nguyen Anh Quynhf0677ab2015-05-21 12:58:38 +0800266endif
267
pancake9c10ace2015-02-24 04:55:55 +0100268API_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 +0800269VERSION_EXT =
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800270
pancake5a4dabd2017-02-06 13:24:33 +0100271IS_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 +0200272ifeq ($(IS_APPLE),1)
Nguyen Anh Quynh44bcb2f2018-07-28 00:24:14 +0800273# on MacOS, do not build in Universal format by default
274MACOS_UNIVERSAL ?= no
Jonas60f17f52017-09-05 16:45:48 +0200275ifeq ($(MACOS_UNIVERSAL),yes)
276CFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
277LDFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
278endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800279EXT = dylib
pancake26943332014-02-04 08:37:55 +0100280VERSION_EXT = $(API_MAJOR).$(EXT)
danghvue1c7a212014-05-14 02:13:36 -0500281$(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 +0800282AR_EXT = a
Nguyen Anh Quynhe3606d92014-04-12 18:02:55 +0800283# Homebrew wants to make sure its formula does not disable FORTIFY_SOURCE
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +0800284# However, this is not really necessary because 'CAPSTONE_USE_SYS_DYN_MEM=yes' by default
Nguyen Anh Quynh189e83a2014-03-29 22:36:05 +0800285ifneq ($(HOMEBREW_CAPSTONE),1)
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +0800286ifneq ($(CAPSTONE_USE_SYS_DYN_MEM),yes)
Nguyen Anh Quynhc77cf3a2014-03-07 22:06:51 +0800287# remove string check because OSX kernel complains about missing symbols
288CFLAGS += -D_FORTIFY_SOURCE=0
289endif
Nguyen Anh Quynh189e83a2014-03-29 22:36:05 +0800290endif
pancake02cad6e2013-11-27 15:38:44 +0100291else
Jonas60f17f52017-09-05 16:45:48 +0200292CFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
293LDFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
danghvue1c7a212014-05-14 02:13:36 -0500294$(LIBNAME)_LDFLAGS += -shared
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000295# Cygwin?
pancake5a4dabd2017-02-06 13:24:33 +0100296IS_CYGWIN := $(shell $(CC) -dumpmachine 2>/dev/null | grep -i cygwin | wc -l)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000297ifeq ($(IS_CYGWIN),1)
298EXT = dll
Nguyen Anh Quynh76087d22014-05-14 14:53:51 +0800299AR_EXT = lib
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000300# Cygwin doesn't like -fPIC
301CFLAGS := $(CFLAGS:-fPIC=)
302# On Windows we need the shared library to be executable
303else
304# mingw?
amirgon29893c62018-11-20 18:46:12 +0200305IS_MINGW := $(shell $(CC) --version 2>/dev/null | grep -i "\(mingw\|MSYS\)" | wc -l)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000306ifeq ($(IS_MINGW),1)
307EXT = dll
Nguyen Anh Quynh76087d22014-05-14 14:53:51 +0800308AR_EXT = lib
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000309# mingw doesn't like -fPIC either
310CFLAGS := $(CFLAGS:-fPIC=)
311# On Windows we need the shared library to be executable
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800312else
313# Linux, *BSD
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800314EXT = so
315VERSION_EXT = $(EXT).$(API_MAJOR)
Nguyen Anh Quynh6d5381e2014-03-17 10:37:08 +0800316AR_EXT = a
danghvue1c7a212014-05-14 02:13:36 -0500317$(LIBNAME)_LDFLAGS += -Wl,-soname,lib$(LIBNAME).$(VERSION_EXT)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000318endif
319endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800320endif
321
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200322ifeq ($(CAPSTONE_SHARED),yes)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800323ifeq ($(IS_MINGW),1)
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400324LIBRARY = $(BLDIR)/$(LIBNAME).$(VERSION_EXT)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800325else ifeq ($(IS_CYGWIN),1)
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400326LIBRARY = $(BLDIR)/$(LIBNAME).$(VERSION_EXT)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800327else # *nix
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400328LIBRARY = $(BLDIR)/lib$(LIBNAME).$(VERSION_EXT)
Hilko Bengend83bf842015-02-26 18:37:32 +0100329CFLAGS += -fvisibility=hidden
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200330endif
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800331endif
332
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200333ifeq ($(CAPSTONE_STATIC),yes)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800334ifeq ($(IS_MINGW),1)
335ARCHIVE = $(BLDIR)/$(LIBNAME).$(AR_EXT)
336else ifeq ($(IS_CYGWIN),1)
337ARCHIVE = $(BLDIR)/$(LIBNAME).$(AR_EXT)
338else
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800339ARCHIVE = $(BLDIR)/lib$(LIBNAME).$(AR_EXT)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200340endif
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800341endif
342
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800343PKGCFGF = $(BLDIR)/$(LIBNAME).pc
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800344
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800345.PHONY: all clean install uninstall dist
pancakeca9f1b22013-12-06 17:03:41 +0100346
Nguyen Anh Quynh80ff30b2013-12-09 00:38:44 +0800347all: $(LIBRARY) $(ARCHIVE) $(PKGCFGF)
Nguyen Anh Quynh19af3ec2015-01-30 09:07:51 +0800348ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Adrian Herrera229593d2017-06-02 15:49:10 +0200349 @V=$(V) CC=$(CC) $(MAKE) -C cstool
Nguyen Anh Quynh243d41e2015-01-28 04:42:34 +0800350ifndef BUILDDIR
Stephen4d388002018-05-11 20:36:10 -0700351 $(MAKE) -C tests
Catena cybera69f7882018-12-04 09:02:16 +0100352 $(MAKE) -C suite/fuzz
Nguyen Anh Quynh243d41e2015-01-28 04:42:34 +0800353else
Stephen4d388002018-05-11 20:36:10 -0700354 $(MAKE) -C tests BUILDDIR=$(BLDIR)
Catena cybera69f7882018-12-04 09:02:16 +0100355 $(MAKE) -C suite/fuzz BUILDDIR=$(BLDIR)
Nguyen Anh Quynh243d41e2015-01-28 04:42:34 +0800356endif
Akihiko Odaki798821f2016-09-03 10:54:56 +0900357 $(call install-library,$(BLDIR)/tests/)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200358endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800359
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200360ifeq ($(CAPSTONE_SHARED),yes)
pancakeaddb1922014-02-28 02:44:07 +0100361$(LIBRARY): $(LIBOBJ)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200362ifeq ($(V),0)
Nguyen Anh Quynh8c0ab862014-06-03 23:43:53 +0700363 $(call log,LINK,$(@:$(BLDIR)/%=%))
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200364 @$(create-library)
365else
366 $(create-library)
367endif
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200368endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800369
Nguyen Anh Quynh3ba8c4d2016-10-23 02:09:14 +0800370$(LIBOBJ): config.mk *.h include/capstone/*.h
Nguyen Anh Quynhaeb0c402014-03-27 17:54:27 +0800371
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800372$(LIBOBJ_ARM): $(DEP_ARM)
373$(LIBOBJ_ARM64): $(DEP_ARM64)
Daniel Collin2ee675c2015-08-03 18:45:08 +0200374$(LIBOBJ_M68K): $(DEP_M68K)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800375$(LIBOBJ_MIPS): $(DEP_MIPS)
376$(LIBOBJ_PPC): $(DEP_PPC)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800377$(LIBOBJ_SPARC): $(DEP_SPARC)
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800378$(LIBOBJ_SYSZ): $(DEP_SYSZ)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800379$(LIBOBJ_X86): $(DEP_X86)
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800380$(LIBOBJ_XCORE): $(DEP_XCORE)
Fotis Loukos0850d552016-05-03 15:52:11 +0300381$(LIBOBJ_TMS320C64X): $(DEP_TMS320C64X)
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200382$(LIBOBJ_M680X): $(DEP_M680X)
Nguyen Anh Quynhed1246d2018-03-31 17:29:22 +0800383$(LIBOBJ_EVM): $(DEP_EVM)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800384
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200385ifeq ($(CAPSTONE_STATIC),yes)
pancakeca9f1b22013-12-06 17:03:41 +0100386$(ARCHIVE): $(LIBOBJ)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200387 @rm -f $(ARCHIVE)
388ifeq ($(V),0)
389 $(call log,AR,$(@:$(BLDIR)/%=%))
390 @$(create-archive)
391else
392 $(create-archive)
393endif
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200394endif
pancakef1cbce22013-11-27 15:31:26 +0100395
pancakeca9f1b22013-12-06 17:03:41 +0100396$(PKGCFGF):
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200397ifeq ($(V),0)
398 $(call log,GEN,$(@:$(BLDIR)/%=%))
399 @$(generate-pkgcfg)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800400else
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200401 $(generate-pkgcfg)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800402endif
pancake44ce0fb2013-12-03 04:11:37 +0100403
pancakeca9f1b22013-12-06 17:03:41 +0100404install: $(PKGCFGF) $(ARCHIVE) $(LIBRARY)
Nguyen Anh Quynh4568e7c2018-12-19 09:41:34 +0800405 mkdir -p $(LIBDIR)
406 $(call install-library,$(LIBDIR))
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200407ifeq ($(CAPSTONE_STATIC),yes)
Nguyen Anh Quynh4568e7c2018-12-19 09:41:34 +0800408 $(INSTALL_DATA) $(ARCHIVE) $(LIBDIR)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200409endif
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800410 mkdir -p $(DESTDIR)$(INCDIR)/$(LIBNAME)
411 $(INSTALL_DATA) include/capstone/*.h $(DESTDIR)$(INCDIR)/$(LIBNAME)
Nguyen Anh Quynh9ecc20f2018-12-19 09:21:07 +0700412 mkdir -p $(PKGCFGDIR)
413 $(INSTALL_DATA) $(PKGCFGF) $(PKGCFGDIR)
414 mkdir -p $(BINDIR)
415 $(INSTALL_LIB) cstool/cstool $(BINDIR)
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800416
417uninstall:
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800418 rm -rf $(DESTDIR)$(INCDIR)/$(LIBNAME)
Sergei Trofimovichf1d69522018-12-19 07:52:20 +0000419 rm -f $(LIBDIR)/lib$(LIBNAME).*
Nguyen Anh Quynh9ecc20f2018-12-19 09:21:07 +0700420 rm -f $(PKGCFGDIR)/$(LIBNAME).pc
Nguyen Anh Quynhf8552db2018-12-19 09:25:04 +0700421 rm -f $(BINDIR)/cstool
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800422
423clean:
Nguyen Anh Quynh5519a682014-04-29 16:24:30 +0800424 rm -f $(LIBOBJ)
Nguyen Anh Quynhf4c5d5e2017-05-05 09:46:46 +0800425 rm -f $(BLDIR)/lib$(LIBNAME).* $(BLDIR)/$(LIBNAME).pc
Nguyen Anh Quynhd63ddac2014-01-09 10:35:58 +0800426 rm -f $(PKGCFGF)
Nguyen Anh Quynh34603272016-10-10 22:54:16 +0800427 $(MAKE) -C cstool clean
Nguyen Tan Cong3d6e56a2015-01-28 00:35:44 +0700428
Nguyen Anh Quynh19af3ec2015-01-30 09:07:51 +0800429ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Stephen4d388002018-05-11 20:36:10 -0700430 $(MAKE) -C tests clean
Catena cybera69f7882018-12-04 09:02:16 +0100431 $(MAKE) -C suite/fuzz clean
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800432 rm -f $(BLDIR)/tests/lib$(LIBNAME).$(EXT)
Nguyen Tan Cong3d6e56a2015-01-28 00:35:44 +0700433endif
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800434
435ifdef BUILDDIR
436 rm -rf $(BUILDDIR)
437endif
Nguyen Anh Quynh5519a682014-04-29 16:24:30 +0800438
Nguyen Anh Quynh19af3ec2015-01-30 09:07:51 +0800439ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Stephen4d388002018-05-11 20:36:10 -0700440 $(MAKE) -C bindings/python clean
441 $(MAKE) -C bindings/java clean
442 $(MAKE) -C bindings/ocaml clean
Nguyen Tan Cong3d6e56a2015-01-28 00:35:44 +0700443endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800444
Nguyen Anh Quynha580d922014-01-18 12:47:15 +0800445
446TAG ?= HEAD
447ifeq ($(TAG), HEAD)
448DIST_VERSION = latest
449else
450DIST_VERSION = $(TAG)
451endif
452
pancake35cef7f2014-01-18 03:42:15 +0100453dist:
Nguyen Anh Quynh186d5012014-01-22 18:46:20 +0800454 git archive --format=tar.gz --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).tgz
Nguyen Anh Quynhf4f72532014-03-11 12:29:16 +0800455 git archive --format=zip --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).zip
pancake35cef7f2014-01-18 03:42:15 +0100456
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800457
Pranith Kumar83fb35c2016-02-29 22:58:57 -0500458TESTS = test_basic test_detail test_arm test_arm64 test_m68k test_mips test_ppc test_sparc
Nguyen Anh Quynhafffa5d2018-07-20 12:36:50 +0800459TESTS += test_systemz test_x86 test_xcore test_iter test_evm
Nick Briggsce3f0d02017-05-11 08:58:12 -0700460TESTS += test_basic.static test_detail.static test_arm.static test_arm64.static
Daniel Collin2ee675c2015-08-03 18:45:08 +0200461TESTS += test_m68k.static test_mips.static test_ppc.static test_sparc.static
Wolfgang Schwotzer22b4d0e2017-10-21 15:44:36 +0200462TESTS += test_systemz.static test_x86.static test_xcore.static test_m680x.static
Nguyen Anh Quynhafffa5d2018-07-20 12:36:50 +0800463TESTS += test_skipdata test_skipdata.static test_iter.static test_evm.static
Catena cyber3a0467c2018-12-11 03:33:31 +0100464check: $(TESTS) fuzztest fuzzallcorp
Stephen93613782018-05-25 08:59:30 -0400465test_%:
466 ./tests/$@ > /dev/null && echo OK || echo FAILED
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800467
Catena cybera69f7882018-12-04 09:02:16 +0100468FUZZ_INPUTS = $(shell find suite/MC -type f -name '*.cs')
469
470fuzztest:
471 ./suite/fuzz/fuzz_disasm $(FUZZ_INPUTS)
472
Catena cyber3a0467c2018-12-11 03:33:31 +0100473fuzzallcorp:
474 ./suite/fuzz/fuzz_bindisasm suite/fuzz/corpus-libFuzzer-capstone_fuzz_disasmnext-latest/
475
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200476$(OBJDIR)/%.o: %.c
477 @mkdir -p $(@D)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200478ifeq ($(V),0)
479 $(call log,CC,$(@:$(OBJDIR)/%=%))
480 @$(compile)
481else
482 $(compile)
483endif
484
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200485
Akihiko Odaki798821f2016-09-03 10:54:56 +0900486ifeq ($(CAPSTONE_SHARED),yes)
487define install-library
488 $(INSTALL_LIB) $(LIBRARY) $1
489 $(if $(VERSION_EXT),
490 cd $1 && \
Akihiko Odakiec407532016-09-11 09:00:32 +0900491 rm -f lib$(LIBNAME).$(EXT) && \
Akihiko Odaki798821f2016-09-03 10:54:56 +0900492 ln -s lib$(LIBNAME).$(VERSION_EXT) lib$(LIBNAME).$(EXT))
493endef
494else
495define install-library
496endef
497endif
498
499
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200500define create-archive
501 $(AR) q $(ARCHIVE) $(LIBOBJ)
502 $(RANLIB) $(ARCHIVE)
503endef
504
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +0800505
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200506define create-library
danghvue1c7a212014-05-14 02:13:36 -0500507 $(CC) $(LDFLAGS) $($(LIBNAME)_LDFLAGS) $(LIBOBJ) -o $(LIBRARY)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200508endef
509
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +0800510
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200511define generate-pkgcfg
Ole André Vadla Ravnås495a4f52015-04-23 17:55:06 +0200512 mkdir -p $(BLDIR)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200513 echo 'Name: capstone' > $(PKGCFGF)
514 echo 'Description: Capstone disassembly engine' >> $(PKGCFGF)
515 echo 'Version: $(PKG_VERSION)' >> $(PKGCFGF)
516 echo 'libdir=$(LIBDIR)' >> $(PKGCFGF)
pancake9c10ace2015-02-24 04:55:55 +0100517 echo 'includedir=$(INCDIR)' >> $(PKGCFGF)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200518 echo 'archive=$${libdir}/libcapstone.a' >> $(PKGCFGF)
519 echo 'Libs: -L$${libdir} -lcapstone' >> $(PKGCFGF)
520 echo 'Cflags: -I$${includedir}' >> $(PKGCFGF)
521endef