blob: 2c347699b77c46e5af6191a159d77fb92cb2fe39 [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
11ifeq ($(PKG_EXTRA),)
12PKG_VERSION = $(PKG_MAJOR).$(PKG_MINOR)
13else
14PKG_VERSION = $(PKG_MAJOR).$(PKG_MINOR).$(PKG_EXTRA)
15endif
16
Nguyen Anh Quynhd80cede2014-01-16 21:07:59 +080017ifeq ($(CROSS),)
18CC ?= cc
19AR ?= ar
20RANLIB ?= ranlib
21STRIP ?= strip
22else
kevemueller82ceac52015-12-14 16:55:53 +010023CC = $(CROSS)gcc
24AR = $(CROSS)ar
25RANLIB = $(CROSS)ranlib
26STRIP = $(CROSS)strip
Nguyen Anh Quynhd80cede2014-01-16 21:07:59 +080027endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080028
Nguyen Anh Quynh77af9fb2014-04-29 07:11:55 +080029ifneq (,$(findstring yes,$(CAPSTONE_DIET)))
30CFLAGS ?= -Os
31CFLAGS += -DCAPSTONE_DIET
32else
33CFLAGS ?= -O3
34endif
35
baguette86e84502014-08-17 20:59:05 +020036ifneq (,$(findstring yes,$(CAPSTONE_X86_ATT_DISABLE)))
37CFLAGS += -DCAPSTONE_X86_ATT_DISABLE
38endif
39
Nguyen Anh Quynh77af9fb2014-04-29 07:11:55 +080040CFLAGS += -fPIC -Wall -Iinclude
Nguyen Anh Quynh59492c22014-01-05 23:41:31 +080041
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +080042ifeq ($(CAPSTONE_USE_SYS_DYN_MEM),yes)
Nguyen Anh Quynh87a3f692014-05-10 19:26:32 +080043CFLAGS += -DCAPSTONE_USE_SYS_DYN_MEM
Nguyen Anh Quynh59492c22014-01-05 23:41:31 +080044endif
45
reverser160e1982015-04-09 18:28:19 +010046ifeq ($(CAPSTONE_HAS_OSXKERNEL), yes)
47CFLAGS += -DCAPSTONE_HAS_OSXKERNEL
Pb2769c772015-11-06 14:44:55 +010048SDKROOT ?= $(shell xcodebuild -version -sdk macosx Path)
49CFLAGS += -mmacosx-version-min=10.5 \
50 -isysroot$(SDKROOT) \
51 -I$(SDKROOT)/System/Library/Frameworks/Kernel.framework/Headers \
52 -mkernel \
53 -fno-builtin
reverser160e1982015-04-09 18:28:19 +010054endif
55
Ole André Vadla Ravnås6583f062014-07-04 23:09:19 +020056CFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
Ole André Vadla Ravnåsb202b912014-07-04 23:38:20 +020057LDFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
Ole André Vadla Ravnås6583f062014-07-04 23:09:19 +020058
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
pancake91659c02015-11-08 12:05:41 +010076LIBDIR ?= $(PREFIX)/$(LIBDIRARCH)
Nguyen Anh Quynhf36b3f42016-10-10 22:54:16 +080077BINDIR = $(PREFIX)/bin
pancake02cad6e2013-11-27 15:38:44 +010078
pancake63414a42015-02-27 17:57:53 +010079LIBDATADIR ?= $(LIBDIR)
Kamil Rytarowskib08f4612015-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 Rytarowskib08f4612015-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 =
101DEP_ARM += arch/ARM/ARMGenAsmWriter.inc
102DEP_ARM += arch/ARM/ARMGenDisassemblerTables.inc
103DEP_ARM += arch/ARM/ARMGenInstrInfo.inc
104DEP_ARM += arch/ARM/ARMGenRegisterInfo.inc
105DEP_ARM += arch/ARM/ARMGenSubtargetInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800106DEP_ARM += arch/ARM/ARMMappingInsn.inc
Nguyen Anh Quynh29f777b2015-04-07 11:59:26 +0800107DEP_ARM += arch/ARM/ARMMappingInsnOp.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800108
109LIBOBJ_ARM =
Nguyen Anh Quynh9cc56a32014-01-15 16:01:55 +0800110ifneq (,$(findstring arm,$(CAPSTONE_ARCHS)))
111 CFLAGS += -DCAPSTONE_HAS_ARM
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200112 LIBOBJ_ARM += $(OBJDIR)/arch/ARM/ARMDisassembler.o
113 LIBOBJ_ARM += $(OBJDIR)/arch/ARM/ARMInstPrinter.o
114 LIBOBJ_ARM += $(OBJDIR)/arch/ARM/ARMMapping.o
115 LIBOBJ_ARM += $(OBJDIR)/arch/ARM/ARMModule.o
danghvu02db4882013-12-20 00:57:12 -0600116endif
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +0800117
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800118DEP_ARM64 =
119DEP_ARM64 += arch/AArch64/AArch64GenAsmWriter.inc
120DEP_ARM64 += arch/AArch64/AArch64GenInstrInfo.inc
121DEP_ARM64 += arch/AArch64/AArch64GenSubtargetInfo.inc
122DEP_ARM64 += arch/AArch64/AArch64GenDisassemblerTables.inc
123DEP_ARM64 += arch/AArch64/AArch64GenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800124DEP_ARM64 += arch/AArch64/AArch64MappingInsn.inc
Nguyen Anh Quynh7c7a53c2016-03-01 12:39:42 +0800125DEP_ARM64 += arch/AArch64/AArch64MappingInsnOp.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800126
127LIBOBJ_ARM64 =
128ifneq (,$(findstring aarch64,$(CAPSTONE_ARCHS)))
129 CFLAGS += -DCAPSTONE_HAS_ARM64
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200130 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64BaseInfo.o
131 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64Disassembler.o
132 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64InstPrinter.o
133 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64Mapping.o
134 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64Module.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800135endif
136
137
Daniel Collin2ee675c2015-08-03 18:45:08 +0200138DEP_M68K =
Daniel Collin2ee675c2015-08-03 18:45:08 +0200139DEP_M68K += arch/M68K/M68KDisassembler.h
Nicolas PLANELf01e0c92015-10-10 19:37:31 +1100140DEP_M68K += arch/M68K/M68KInstPrinter.h
Daniel Collin2ee675c2015-08-03 18:45:08 +0200141
142LIBOBJ_M68K =
143ifneq (,$(findstring m68k,$(CAPSTONE_ARCHS)))
144 CFLAGS += -DCAPSTONE_HAS_M68K
Nguyen Anh Quynh7d5badd2015-10-04 21:45:50 +0800145 LIBOBJ_M68K += $(OBJDIR)/arch/M68K/M68KInstPrinter.o
Daniel Collin2ee675c2015-08-03 18:45:08 +0200146 LIBOBJ_M68K += $(OBJDIR)/arch/M68K/M68KDisassembler.o
147 LIBOBJ_M68K += $(OBJDIR)/arch/M68K/M68KModule.o
148endif
149
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800150DEP_MIPS =
151DEP_MIPS += arch/Mips/MipsGenAsmWriter.inc
152DEP_MIPS += arch/Mips/MipsGenDisassemblerTables.inc
153DEP_MIPS += arch/Mips/MipsGenInstrInfo.inc
154DEP_MIPS += arch/Mips/MipsGenRegisterInfo.inc
155DEP_MIPS += arch/Mips/MipsGenSubtargetInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800156DEP_MIPS += arch/Mips/MipsMappingInsn.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800157
158LIBOBJ_MIPS =
159ifneq (,$(findstring mips,$(CAPSTONE_ARCHS)))
160 CFLAGS += -DCAPSTONE_HAS_MIPS
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200161 LIBOBJ_MIPS += $(OBJDIR)/arch/Mips/MipsDisassembler.o
162 LIBOBJ_MIPS += $(OBJDIR)/arch/Mips/MipsInstPrinter.o
163 LIBOBJ_MIPS += $(OBJDIR)/arch/Mips/MipsMapping.o
164 LIBOBJ_MIPS += $(OBJDIR)/arch/Mips/MipsModule.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800165endif
166
167
168DEP_PPC =
169DEP_PPC += arch/PowerPC/PPCGenAsmWriter.inc
170DEP_PPC += arch/PowerPC/PPCGenInstrInfo.inc
171DEP_PPC += arch/PowerPC/PPCGenSubtargetInfo.inc
172DEP_PPC += arch/PowerPC/PPCGenDisassemblerTables.inc
173DEP_PPC += arch/PowerPC/PPCGenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800174DEP_PPC += arch/PowerPC/PPCMappingInsn.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800175
176LIBOBJ_PPC =
177ifneq (,$(findstring powerpc,$(CAPSTONE_ARCHS)))
178 CFLAGS += -DCAPSTONE_HAS_POWERPC
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200179 LIBOBJ_PPC += $(OBJDIR)/arch/PowerPC/PPCDisassembler.o
180 LIBOBJ_PPC += $(OBJDIR)/arch/PowerPC/PPCInstPrinter.o
181 LIBOBJ_PPC += $(OBJDIR)/arch/PowerPC/PPCMapping.o
182 LIBOBJ_PPC += $(OBJDIR)/arch/PowerPC/PPCModule.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800183endif
184
185
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800186DEP_SPARC =
187DEP_SPARC += arch/Sparc/SparcGenAsmWriter.inc
188DEP_SPARC += arch/Sparc/SparcGenInstrInfo.inc
189DEP_SPARC += arch/Sparc/SparcGenSubtargetInfo.inc
190DEP_SPARC += arch/Sparc/SparcGenDisassemblerTables.inc
191DEP_SPARC += arch/Sparc/SparcGenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800192DEP_SPARC += arch/Sparc/SparcMappingInsn.inc
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800193
194LIBOBJ_SPARC =
195ifneq (,$(findstring sparc,$(CAPSTONE_ARCHS)))
196 CFLAGS += -DCAPSTONE_HAS_SPARC
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200197 LIBOBJ_SPARC += $(OBJDIR)/arch/Sparc/SparcDisassembler.o
198 LIBOBJ_SPARC += $(OBJDIR)/arch/Sparc/SparcInstPrinter.o
199 LIBOBJ_SPARC += $(OBJDIR)/arch/Sparc/SparcMapping.o
200 LIBOBJ_SPARC += $(OBJDIR)/arch/Sparc/SparcModule.o
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800201endif
202
203
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800204DEP_SYSZ =
205DEP_SYSZ += arch/SystemZ/SystemZGenAsmWriter.inc
206DEP_SYSZ += arch/SystemZ/SystemZGenInstrInfo.inc
207DEP_SYSZ += arch/SystemZ/SystemZGenSubtargetInfo.inc
208DEP_SYSZ += arch/SystemZ/SystemZGenDisassemblerTables.inc
209DEP_SYSZ += arch/SystemZ/SystemZGenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800210DEP_SYSZ += arch/SystemZ/SystemZMappingInsn.inc
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800211
212LIBOBJ_SYSZ =
213ifneq (,$(findstring systemz,$(CAPSTONE_ARCHS)))
214 CFLAGS += -DCAPSTONE_HAS_SYSZ
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200215 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZDisassembler.o
216 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZInstPrinter.o
217 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZMapping.o
218 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZModule.o
219 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZMCTargetDesc.o
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800220endif
221
222
Nguyen Anh Quynh95181482014-03-25 23:20:41 +0800223# by default, we compile full X86 instruction sets
Nguyen Anh Quynh59b54892014-03-27 10:54:44 +0800224X86_REDUCE =
225ifneq (,$(findstring yes,$(CAPSTONE_X86_REDUCE)))
226X86_REDUCE = _reduce
Nguyen Anh Quynh81d930a2014-03-28 10:28:57 +0800227CFLAGS += -DCAPSTONE_X86_REDUCE -Os
Nguyen Anh Quynh95181482014-03-25 23:20:41 +0800228endif
229
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800230DEP_X86 =
Nguyen Anh Quynh59b54892014-03-27 10:54:44 +0800231DEP_X86 += arch/X86/X86GenAsmWriter$(X86_REDUCE).inc
232DEP_X86 += arch/X86/X86GenAsmWriter1$(X86_REDUCE).inc
233DEP_X86 += arch/X86/X86GenDisassemblerTables$(X86_REDUCE).inc
234DEP_X86 += arch/X86/X86GenInstrInfo$(X86_REDUCE).inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800235DEP_X86 += arch/X86/X86GenRegisterInfo.inc
Nguyen Anh Quynh0d394aa2015-11-06 10:34:27 +0800236DEP_X86 += arch/X86/X86MappingInsn$(X86_REDUCE).inc
237DEP_X86 += arch/X86/X86MappingInsnOp$(X86_REDUCE).inc
238DEP_X86 += arch/X86/X86ImmSize.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800239
240LIBOBJ_X86 =
241ifneq (,$(findstring x86,$(CAPSTONE_ARCHS)))
242 CFLAGS += -DCAPSTONE_HAS_X86
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200243 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86DisassemblerDecoder.o
244 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Disassembler.o
245 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86IntelInstPrinter.o
Nguyen Anh Quynh50689082014-05-14 12:26:53 +0800246# assembly syntax is irrelevant in Diet mode, when this info is suppressed
247ifeq (,$(findstring yes,$(CAPSTONE_DIET)))
baguette86e84502014-08-17 20:59:05 +0200248ifeq (,$(findstring yes,$(CAPSTONE_X86_ATT_DISABLE)))
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200249 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86ATTInstPrinter.o
Nguyen Anh Quynh50689082014-05-14 12:26:53 +0800250endif
baguette86e84502014-08-17 20:59:05 +0200251endif
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200252 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Mapping.o
253 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Module.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800254endif
255
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800256
257DEP_XCORE =
258DEP_XCORE += arch/XCore/XCoreGenAsmWriter.inc
259DEP_XCORE += arch/XCore/XCoreGenInstrInfo.inc
260DEP_XCORE += arch/XCore/XCoreGenDisassemblerTables.inc
261DEP_XCORE += arch/XCore/XCoreGenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800262DEP_XCORE += arch/XCore/XCoreMappingInsn.inc
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800263
264LIBOBJ_XCORE =
265ifneq (,$(findstring xcore,$(CAPSTONE_ARCHS)))
266 CFLAGS += -DCAPSTONE_HAS_XCORE
267 LIBOBJ_XCORE += $(OBJDIR)/arch/XCore/XCoreDisassembler.o
268 LIBOBJ_XCORE += $(OBJDIR)/arch/XCore/XCoreInstPrinter.o
269 LIBOBJ_XCORE += $(OBJDIR)/arch/XCore/XCoreMapping.o
270 LIBOBJ_XCORE += $(OBJDIR)/arch/XCore/XCoreModule.o
271endif
272
273
Fotis Loukos0850d552016-05-03 15:52:11 +0300274DEP_TMS320C64X =
275DEP_TMS320C64X += arch/TMS320C64x/TMS320C64xGenAsmWriter.inc
276DEP_TMS320C64X += arch/TMS320C64x/TMS320C64xGenInstrInfo.inc
277DEP_TMS320C64X += arch/TMS320C64x/TMS320C64xGenDisassemblerTables.inc
278DEP_TMS320C64X += arch/TMS320C64x/TMS320C64xGenRegisterInfo.inc
279
280LIBOBJ_TMS320C64X =
281ifneq (,$(findstring tms320c64x,$(CAPSTONE_ARCHS)))
282 CFLAGS += -DCAPSTONE_HAS_TMS320C64X
283 LIBOBJ_TMS320C64X += $(OBJDIR)/arch/TMS320C64x/TMS320C64xDisassembler.o
284 LIBOBJ_TMS320C64X += $(OBJDIR)/arch/TMS320C64x/TMS320C64xInstPrinter.o
285 LIBOBJ_TMS320C64X += $(OBJDIR)/arch/TMS320C64x/TMS320C64xMapping.o
286 LIBOBJ_TMS320C64X += $(OBJDIR)/arch/TMS320C64x/TMS320C64xModule.o
287endif
288
289
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800290LIBOBJ =
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200291LIBOBJ += $(OBJDIR)/cs.o $(OBJDIR)/utils.o $(OBJDIR)/SStream.o $(OBJDIR)/MCInstrDesc.o $(OBJDIR)/MCRegisterInfo.o
Fotis Loukos0850d552016-05-03 15:52:11 +0300292LIBOBJ += $(LIBOBJ_ARM) $(LIBOBJ_ARM64) $(LIBOBJ_M68K) $(LIBOBJ_MIPS) $(LIBOBJ_PPC) $(LIBOBJ_SPARC) $(LIBOBJ_SYSZ) $(LIBOBJ_X86) $(LIBOBJ_XCORE) $(LIBOBJ_TMS320C64X)
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200293LIBOBJ += $(OBJDIR)/MCInst.o
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800294
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800295
Nguyen Anh Quynhf0677ab2015-05-21 12:58:38 +0800296ifeq ($(PKG_EXTRA),)
297PKGCFGDIR = $(LIBDATADIR)/pkgconfig
298else
Nguyen Anh Quynhaf0e9372014-04-12 23:10:46 +0800299PKGCFGDIR ?= $(LIBDATADIR)/pkgconfig
Nguyen Anh Quynhd46a4f22017-04-14 18:43:06 +0800300ifeq ($(PKGCFGDIR),)
301PKGCFGDIR = $(LIBDATADIR)/pkgconfig
302endif
Nguyen Anh Quynhf0677ab2015-05-21 12:58:38 +0800303endif
304
pancake9c10ace2015-02-24 04:55:55 +0100305API_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 +0800306VERSION_EXT =
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800307
pancake5a4dabd2017-02-06 13:24:33 +0100308IS_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 +0200309ifeq ($(IS_APPLE),1)
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800310EXT = dylib
pancake26943332014-02-04 08:37:55 +0100311VERSION_EXT = $(API_MAJOR).$(EXT)
danghvue1c7a212014-05-14 02:13:36 -0500312$(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 +0800313AR_EXT = a
Nguyen Anh Quynhe3606d92014-04-12 18:02:55 +0800314# Homebrew wants to make sure its formula does not disable FORTIFY_SOURCE
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +0800315# However, this is not really necessary because 'CAPSTONE_USE_SYS_DYN_MEM=yes' by default
Nguyen Anh Quynh189e83a2014-03-29 22:36:05 +0800316ifneq ($(HOMEBREW_CAPSTONE),1)
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +0800317ifneq ($(CAPSTONE_USE_SYS_DYN_MEM),yes)
Nguyen Anh Quynhc77cf3a2014-03-07 22:06:51 +0800318# remove string check because OSX kernel complains about missing symbols
319CFLAGS += -D_FORTIFY_SOURCE=0
320endif
Nguyen Anh Quynh189e83a2014-03-29 22:36:05 +0800321endif
pancake02cad6e2013-11-27 15:38:44 +0100322else
danghvue1c7a212014-05-14 02:13:36 -0500323$(LIBNAME)_LDFLAGS += -shared
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000324# Cygwin?
pancake5a4dabd2017-02-06 13:24:33 +0100325IS_CYGWIN := $(shell $(CC) -dumpmachine 2>/dev/null | grep -i cygwin | wc -l)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000326ifeq ($(IS_CYGWIN),1)
327EXT = dll
Nguyen Anh Quynh76087d22014-05-14 14:53:51 +0800328AR_EXT = lib
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000329# Cygwin doesn't like -fPIC
330CFLAGS := $(CFLAGS:-fPIC=)
331# On Windows we need the shared library to be executable
332else
333# mingw?
pancake5a4dabd2017-02-06 13:24:33 +0100334IS_MINGW := $(shell $(CC) --version 2>/dev/null | grep -i mingw | wc -l)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000335ifeq ($(IS_MINGW),1)
336EXT = dll
Nguyen Anh Quynh76087d22014-05-14 14:53:51 +0800337AR_EXT = lib
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000338# mingw doesn't like -fPIC either
339CFLAGS := $(CFLAGS:-fPIC=)
340# On Windows we need the shared library to be executable
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800341else
342# Linux, *BSD
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800343EXT = so
344VERSION_EXT = $(EXT).$(API_MAJOR)
Nguyen Anh Quynh6d5381e2014-03-17 10:37:08 +0800345AR_EXT = a
danghvue1c7a212014-05-14 02:13:36 -0500346$(LIBNAME)_LDFLAGS += -Wl,-soname,lib$(LIBNAME).$(VERSION_EXT)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000347endif
348endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800349endif
350
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200351ifeq ($(CAPSTONE_SHARED),yes)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800352ifeq ($(IS_MINGW),1)
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400353LIBRARY = $(BLDIR)/$(LIBNAME).$(VERSION_EXT)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800354else ifeq ($(IS_CYGWIN),1)
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400355LIBRARY = $(BLDIR)/$(LIBNAME).$(VERSION_EXT)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800356else # *nix
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400357LIBRARY = $(BLDIR)/lib$(LIBNAME).$(VERSION_EXT)
Hilko Bengene0352d62015-02-26 18:37:32 +0100358CFLAGS += -fvisibility=hidden
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200359endif
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800360endif
361
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200362ifeq ($(CAPSTONE_STATIC),yes)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800363ifeq ($(IS_MINGW),1)
364ARCHIVE = $(BLDIR)/$(LIBNAME).$(AR_EXT)
365else ifeq ($(IS_CYGWIN),1)
366ARCHIVE = $(BLDIR)/$(LIBNAME).$(AR_EXT)
367else
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800368ARCHIVE = $(BLDIR)/lib$(LIBNAME).$(AR_EXT)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200369endif
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800370endif
371
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800372PKGCFGF = $(BLDIR)/$(LIBNAME).pc
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800373
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800374.PHONY: all clean install uninstall dist
pancakeca9f1b22013-12-06 17:03:41 +0100375
Nguyen Anh Quynh80ff30b2013-12-09 00:38:44 +0800376all: $(LIBRARY) $(ARCHIVE) $(PKGCFGF)
Nguyen Anh Quynh794a7062015-01-30 09:07:51 +0800377ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Nguyen Anh Quynhf36b3f42016-10-10 22:54:16 +0800378 @V=$(V) $(MAKE) -C cstool
Nguyen Anh Quynhc00bc352015-01-28 04:42:34 +0800379ifndef BUILDDIR
380 cd tests && $(MAKE)
381else
382 cd tests && $(MAKE) BUILDDIR=$(BLDIR)
383endif
Akihiko Odakiec407532016-09-11 09:00:32 +0900384 $(call install-library,$(BLDIR)/tests/)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200385endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800386
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200387ifeq ($(CAPSTONE_SHARED),yes)
pancakeaddb1922014-02-28 02:44:07 +0100388$(LIBRARY): $(LIBOBJ)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200389ifeq ($(V),0)
Nguyen Anh Quynh8c0ab862014-06-03 23:43:53 +0700390 $(call log,LINK,$(@:$(BLDIR)/%=%))
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200391 @$(create-library)
392else
393 $(create-library)
394endif
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200395endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800396
Nguyen Anh Quynh3ba8c4d2016-10-23 02:09:14 +0800397$(LIBOBJ): config.mk *.h include/capstone/*.h
Nguyen Anh Quynhaeb0c402014-03-27 17:54:27 +0800398
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800399$(LIBOBJ_ARM): $(DEP_ARM)
400$(LIBOBJ_ARM64): $(DEP_ARM64)
Daniel Collin2ee675c2015-08-03 18:45:08 +0200401$(LIBOBJ_M68K): $(DEP_M68K)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800402$(LIBOBJ_MIPS): $(DEP_MIPS)
403$(LIBOBJ_PPC): $(DEP_PPC)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800404$(LIBOBJ_SPARC): $(DEP_SPARC)
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800405$(LIBOBJ_SYSZ): $(DEP_SYSZ)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800406$(LIBOBJ_X86): $(DEP_X86)
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800407$(LIBOBJ_XCORE): $(DEP_XCORE)
Fotis Loukos0850d552016-05-03 15:52:11 +0300408$(LIBOBJ_TMS320C64X): $(DEP_TMS320C64X)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800409
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200410ifeq ($(CAPSTONE_STATIC),yes)
pancakeca9f1b22013-12-06 17:03:41 +0100411$(ARCHIVE): $(LIBOBJ)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200412 @rm -f $(ARCHIVE)
413ifeq ($(V),0)
414 $(call log,AR,$(@:$(BLDIR)/%=%))
415 @$(create-archive)
416else
417 $(create-archive)
418endif
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200419endif
pancakef1cbce22013-11-27 15:31:26 +0100420
pancakeca9f1b22013-12-06 17:03:41 +0100421$(PKGCFGF):
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200422ifeq ($(V),0)
423 $(call log,GEN,$(@:$(BLDIR)/%=%))
424 @$(generate-pkgcfg)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800425else
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200426 $(generate-pkgcfg)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800427endif
pancake44ce0fb2013-12-03 04:11:37 +0100428
pancakeca9f1b22013-12-06 17:03:41 +0100429install: $(PKGCFGF) $(ARCHIVE) $(LIBRARY)
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800430 mkdir -p $(DESTDIR)$(LIBDIR)
431 $(call install-library,$(DESTDIR)$(LIBDIR))
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200432ifeq ($(CAPSTONE_STATIC),yes)
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800433 $(INSTALL_DATA) $(ARCHIVE) $(DESTDIR)$(LIBDIR)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200434endif
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800435 mkdir -p $(DESTDIR)$(INCDIR)/$(LIBNAME)
436 $(INSTALL_DATA) include/capstone/*.h $(DESTDIR)$(INCDIR)/$(LIBNAME)
437 mkdir -p $(DESTDIR)$(PKGCFGDIR)
438 $(INSTALL_DATA) $(PKGCFGF) $(DESTDIR)$(PKGCFGDIR)
Hank Leininger1b4d8052016-12-10 20:52:08 -0500439 mkdir -p $(DESTDIR)$(BINDIR)
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800440 $(INSTALL_LIB) cstool/cstool $(DESTDIR)$(BINDIR)
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800441
442uninstall:
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800443 rm -rf $(DESTDIR)$(INCDIR)/$(LIBNAME)
444 rm -f $(DESTDIR)$(LIBDIR)/lib$(LIBNAME).*
445 rm -f $(DESTDIR)$(PKGCFGDIR)/$(LIBNAME).pc
446 rm -f $(DESTDIR)$(BINDIR)/cstool
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800447
448clean:
Nguyen Anh Quynh5519a682014-04-29 16:24:30 +0800449 rm -f $(LIBOBJ)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800450 rm -f $(BLDIR)/lib$(LIBNAME).* $(BLDIR)/$(LIBNAME).*
Nguyen Anh Quynhd63ddac2014-01-09 10:35:58 +0800451 rm -f $(PKGCFGF)
Nguyen Anh Quynhf36b3f42016-10-10 22:54:16 +0800452 $(MAKE) -C cstool clean
Nguyen Tan Cong39fd1542015-01-28 00:35:44 +0700453
Nguyen Anh Quynh794a7062015-01-30 09:07:51 +0800454ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
danghvuad664202014-05-12 14:27:38 -0500455 cd tests && $(MAKE) clean
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800456 rm -f $(BLDIR)/tests/lib$(LIBNAME).$(EXT)
Nguyen Tan Cong39fd1542015-01-28 00:35:44 +0700457endif
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800458
459ifdef BUILDDIR
460 rm -rf $(BUILDDIR)
461endif
Nguyen Anh Quynh5519a682014-04-29 16:24:30 +0800462
Nguyen Anh Quynh794a7062015-01-30 09:07:51 +0800463ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
danghvuad664202014-05-12 14:27:38 -0500464 cd bindings/python && $(MAKE) clean
465 cd bindings/java && $(MAKE) clean
466 cd bindings/ocaml && $(MAKE) clean
Nguyen Tan Cong39fd1542015-01-28 00:35:44 +0700467endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800468
Nguyen Anh Quynha580d922014-01-18 12:47:15 +0800469
470TAG ?= HEAD
471ifeq ($(TAG), HEAD)
472DIST_VERSION = latest
473else
474DIST_VERSION = $(TAG)
475endif
476
pancake35cef7f2014-01-18 03:42:15 +0100477dist:
Nguyen Anh Quynh186d5012014-01-22 18:46:20 +0800478 git archive --format=tar.gz --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).tgz
Nguyen Anh Quynhf4f72532014-03-11 12:29:16 +0800479 git archive --format=zip --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).zip
pancake35cef7f2014-01-18 03:42:15 +0100480
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800481
Pranith Kumar83fb35c2016-02-29 22:58:57 -0500482TESTS = test_basic test_detail test_arm test_arm64 test_m68k test_mips test_ppc test_sparc
Nguyen Anh Quynhb16dc852014-11-02 08:21:34 +0800483TESTS += test_systemz test_x86 test_xcore test_iter
Pranith Kumar83fb35c2016-02-29 22:58:57 -0500484TESTS += test_basic.static test_detail.static test_arm.static test_arm64.static
Daniel Collin2ee675c2015-08-03 18:45:08 +0200485TESTS += test_m68k.static test_mips.static test_ppc.static test_sparc.static
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800486TESTS += test_systemz.static test_x86.static test_xcore.static
Nguyen Anh Quynhb16dc852014-11-02 08:21:34 +0800487TESTS += test_skipdata test_skipdata.static test_iter.static
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800488check:
489 @for t in $(TESTS); do \
490 echo Check $$t ... ; \
Akihiko Odakiec407532016-09-11 09:00:32 +0900491 LD_LIBRARY_PATH=./tests ./tests/$$t > /dev/null && echo OK || echo FAILED; \
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800492 done
493
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200494$(OBJDIR)/%.o: %.c
495 @mkdir -p $(@D)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200496ifeq ($(V),0)
497 $(call log,CC,$(@:$(OBJDIR)/%=%))
498 @$(compile)
499else
500 $(compile)
501endif
502
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200503
Akihiko Odakiec407532016-09-11 09:00:32 +0900504ifeq ($(CAPSTONE_SHARED),yes)
505define install-library
506 $(INSTALL_LIB) $(LIBRARY) $1
507 $(if $(VERSION_EXT),
508 cd $1 && \
509 rm -f lib$(LIBNAME).$(EXT) && \
510 ln -s lib$(LIBNAME).$(VERSION_EXT) lib$(LIBNAME).$(EXT))
511endef
512else
513define install-library
514endef
515endif
516
517
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200518define create-archive
519 $(AR) q $(ARCHIVE) $(LIBOBJ)
520 $(RANLIB) $(ARCHIVE)
521endef
522
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +0800523
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200524define create-library
danghvue1c7a212014-05-14 02:13:36 -0500525 $(CC) $(LDFLAGS) $($(LIBNAME)_LDFLAGS) $(LIBOBJ) -o $(LIBRARY)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200526endef
527
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +0800528
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200529define generate-pkgcfg
Ole André Vadla Ravnås495a4f52015-04-23 17:55:06 +0200530 mkdir -p $(BLDIR)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200531 echo 'Name: capstone' > $(PKGCFGF)
532 echo 'Description: Capstone disassembly engine' >> $(PKGCFGF)
533 echo 'Version: $(PKG_VERSION)' >> $(PKGCFGF)
534 echo 'libdir=$(LIBDIR)' >> $(PKGCFGF)
pancake9c10ace2015-02-24 04:55:55 +0100535 echo 'includedir=$(INCDIR)' >> $(PKGCFGF)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200536 echo 'archive=$${libdir}/libcapstone.a' >> $(PKGCFGF)
537 echo 'Libs: -L$${libdir} -lcapstone' >> $(PKGCFGF)
538 echo 'Cflags: -I$${includedir}' >> $(PKGCFGF)
539endef