blob: cfd3c483c3b6ca51fe282e41b371a4a7223fb884 [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
pancake02cad6e2013-11-27 15:38:44 +010056PREFIX ?= /usr
57DESTDIR ?=
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020058ifndef BUILDDIR
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +080059BLDIR = .
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020060OBJDIR = .
61else
Ole André Vadla Ravnås7a734392014-04-30 00:06:41 +020062BLDIR = $(abspath $(BUILDDIR))
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +080063OBJDIR = $(BLDIR)/obj
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +020064endif
pancake91659c02015-11-08 12:05:41 +010065INCDIR ?= $(PREFIX)/include
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080066
Nguyen Anh Quynh235a2742014-03-29 21:09:35 +080067UNAME_S := $(shell uname -s)
Nguyen Anh Quynhad6cc982014-04-08 23:34:44 +080068
Nguyen Anh Quynh360bf1e2014-04-14 13:36:46 +080069LIBDIRARCH ?= lib
70# Uncomment the below line to installs x86_64 libs to lib64/ directory.
71# Or better, pass 'LIBDIRARCH=lib64' to 'make install/uninstall' via 'make.sh'.
72#LIBDIRARCH ?= lib64
pancake91659c02015-11-08 12:05:41 +010073LIBDIR ?= $(PREFIX)/$(LIBDIRARCH)
Nguyen Anh Quynhf36b3f42016-10-10 22:54:16 +080074BINDIR = $(PREFIX)/bin
pancake02cad6e2013-11-27 15:38:44 +010075
pancake63414a42015-02-27 17:57:53 +010076LIBDATADIR ?= $(LIBDIR)
Kamil Rytarowskib08f4612015-07-27 04:03:48 +020077
78# Don't redefine $LIBDATADIR when global environment variable
79# USE_GENERIC_LIBDATADIR is set. This is used by the pkgsrc framework.
80
81ifndef USE_GENERIC_LIBDATADIR
Oliver Pinterc5ecae52014-03-23 02:19:59 +010082ifeq ($(UNAME_S), FreeBSD)
pancake91659c02015-11-08 12:05:41 +010083LIBDATADIR = $(PREFIX)/libdata
Oliver Pinterc5ecae52014-03-23 02:19:59 +010084endif
Oliver Pinter25efded2014-03-23 19:10:13 +010085ifeq ($(UNAME_S), DragonFly)
pancake91659c02015-11-08 12:05:41 +010086LIBDATADIR = $(PREFIX)/libdata
Oliver Pinter25efded2014-03-23 19:10:13 +010087endif
Kamil Rytarowskib08f4612015-07-27 04:03:48 +020088endif
Oliver Pinterc5ecae52014-03-23 02:19:59 +010089
Nguyen Anh Quynh64d40832014-01-17 20:55:21 +080090INSTALL_BIN ?= install
91INSTALL_DATA ?= $(INSTALL_BIN) -m0644
Oliver Pinterc5ecae52014-03-23 02:19:59 +010092INSTALL_LIB ?= $(INSTALL_BIN) -m0755
pancake02cad6e2013-11-27 15:38:44 +010093
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080094LIBNAME = capstone
pancakeca9f1b22013-12-06 17:03:41 +010095
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +080096
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +080097DEP_ARM =
98DEP_ARM += arch/ARM/ARMGenAsmWriter.inc
99DEP_ARM += arch/ARM/ARMGenDisassemblerTables.inc
100DEP_ARM += arch/ARM/ARMGenInstrInfo.inc
101DEP_ARM += arch/ARM/ARMGenRegisterInfo.inc
102DEP_ARM += arch/ARM/ARMGenSubtargetInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800103DEP_ARM += arch/ARM/ARMMappingInsn.inc
Nguyen Anh Quynh29f777b2015-04-07 11:59:26 +0800104DEP_ARM += arch/ARM/ARMMappingInsnOp.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800105
106LIBOBJ_ARM =
Nguyen Anh Quynh9cc56a32014-01-15 16:01:55 +0800107ifneq (,$(findstring arm,$(CAPSTONE_ARCHS)))
108 CFLAGS += -DCAPSTONE_HAS_ARM
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200109 LIBOBJ_ARM += $(OBJDIR)/arch/ARM/ARMDisassembler.o
110 LIBOBJ_ARM += $(OBJDIR)/arch/ARM/ARMInstPrinter.o
111 LIBOBJ_ARM += $(OBJDIR)/arch/ARM/ARMMapping.o
112 LIBOBJ_ARM += $(OBJDIR)/arch/ARM/ARMModule.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 =
116DEP_ARM64 += arch/AArch64/AArch64GenAsmWriter.inc
117DEP_ARM64 += arch/AArch64/AArch64GenInstrInfo.inc
118DEP_ARM64 += arch/AArch64/AArch64GenSubtargetInfo.inc
119DEP_ARM64 += arch/AArch64/AArch64GenDisassemblerTables.inc
120DEP_ARM64 += arch/AArch64/AArch64GenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800121DEP_ARM64 += arch/AArch64/AArch64MappingInsn.inc
Nguyen Anh Quynh7c7a53c2016-03-01 12:39:42 +0800122DEP_ARM64 += arch/AArch64/AArch64MappingInsnOp.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800123
124LIBOBJ_ARM64 =
125ifneq (,$(findstring aarch64,$(CAPSTONE_ARCHS)))
126 CFLAGS += -DCAPSTONE_HAS_ARM64
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200127 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64BaseInfo.o
128 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64Disassembler.o
129 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64InstPrinter.o
130 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64Mapping.o
131 LIBOBJ_ARM64 += $(OBJDIR)/arch/AArch64/AArch64Module.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800132endif
133
134
Daniel Collin2ee675c2015-08-03 18:45:08 +0200135DEP_M68K =
Daniel Collin2ee675c2015-08-03 18:45:08 +0200136DEP_M68K += arch/M68K/M68KDisassembler.h
Nicolas PLANELf01e0c92015-10-10 19:37:31 +1100137DEP_M68K += arch/M68K/M68KInstPrinter.h
Daniel Collin2ee675c2015-08-03 18:45:08 +0200138
139LIBOBJ_M68K =
140ifneq (,$(findstring m68k,$(CAPSTONE_ARCHS)))
141 CFLAGS += -DCAPSTONE_HAS_M68K
Nguyen Anh Quynh7d5badd2015-10-04 21:45:50 +0800142 LIBOBJ_M68K += $(OBJDIR)/arch/M68K/M68KInstPrinter.o
Daniel Collin2ee675c2015-08-03 18:45:08 +0200143 LIBOBJ_M68K += $(OBJDIR)/arch/M68K/M68KDisassembler.o
144 LIBOBJ_M68K += $(OBJDIR)/arch/M68K/M68KModule.o
145endif
146
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800147DEP_MIPS =
148DEP_MIPS += arch/Mips/MipsGenAsmWriter.inc
149DEP_MIPS += arch/Mips/MipsGenDisassemblerTables.inc
150DEP_MIPS += arch/Mips/MipsGenInstrInfo.inc
151DEP_MIPS += arch/Mips/MipsGenRegisterInfo.inc
152DEP_MIPS += arch/Mips/MipsGenSubtargetInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800153DEP_MIPS += arch/Mips/MipsMappingInsn.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800154
155LIBOBJ_MIPS =
156ifneq (,$(findstring mips,$(CAPSTONE_ARCHS)))
157 CFLAGS += -DCAPSTONE_HAS_MIPS
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200158 LIBOBJ_MIPS += $(OBJDIR)/arch/Mips/MipsDisassembler.o
159 LIBOBJ_MIPS += $(OBJDIR)/arch/Mips/MipsInstPrinter.o
160 LIBOBJ_MIPS += $(OBJDIR)/arch/Mips/MipsMapping.o
161 LIBOBJ_MIPS += $(OBJDIR)/arch/Mips/MipsModule.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800162endif
163
164
165DEP_PPC =
166DEP_PPC += arch/PowerPC/PPCGenAsmWriter.inc
167DEP_PPC += arch/PowerPC/PPCGenInstrInfo.inc
168DEP_PPC += arch/PowerPC/PPCGenSubtargetInfo.inc
169DEP_PPC += arch/PowerPC/PPCGenDisassemblerTables.inc
170DEP_PPC += arch/PowerPC/PPCGenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800171DEP_PPC += arch/PowerPC/PPCMappingInsn.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800172
173LIBOBJ_PPC =
174ifneq (,$(findstring powerpc,$(CAPSTONE_ARCHS)))
175 CFLAGS += -DCAPSTONE_HAS_POWERPC
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200176 LIBOBJ_PPC += $(OBJDIR)/arch/PowerPC/PPCDisassembler.o
177 LIBOBJ_PPC += $(OBJDIR)/arch/PowerPC/PPCInstPrinter.o
178 LIBOBJ_PPC += $(OBJDIR)/arch/PowerPC/PPCMapping.o
179 LIBOBJ_PPC += $(OBJDIR)/arch/PowerPC/PPCModule.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800180endif
181
182
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800183DEP_SPARC =
184DEP_SPARC += arch/Sparc/SparcGenAsmWriter.inc
185DEP_SPARC += arch/Sparc/SparcGenInstrInfo.inc
186DEP_SPARC += arch/Sparc/SparcGenSubtargetInfo.inc
187DEP_SPARC += arch/Sparc/SparcGenDisassemblerTables.inc
188DEP_SPARC += arch/Sparc/SparcGenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800189DEP_SPARC += arch/Sparc/SparcMappingInsn.inc
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800190
191LIBOBJ_SPARC =
192ifneq (,$(findstring sparc,$(CAPSTONE_ARCHS)))
193 CFLAGS += -DCAPSTONE_HAS_SPARC
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200194 LIBOBJ_SPARC += $(OBJDIR)/arch/Sparc/SparcDisassembler.o
195 LIBOBJ_SPARC += $(OBJDIR)/arch/Sparc/SparcInstPrinter.o
196 LIBOBJ_SPARC += $(OBJDIR)/arch/Sparc/SparcMapping.o
197 LIBOBJ_SPARC += $(OBJDIR)/arch/Sparc/SparcModule.o
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800198endif
199
200
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800201DEP_SYSZ =
202DEP_SYSZ += arch/SystemZ/SystemZGenAsmWriter.inc
203DEP_SYSZ += arch/SystemZ/SystemZGenInstrInfo.inc
204DEP_SYSZ += arch/SystemZ/SystemZGenSubtargetInfo.inc
205DEP_SYSZ += arch/SystemZ/SystemZGenDisassemblerTables.inc
206DEP_SYSZ += arch/SystemZ/SystemZGenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800207DEP_SYSZ += arch/SystemZ/SystemZMappingInsn.inc
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800208
209LIBOBJ_SYSZ =
210ifneq (,$(findstring systemz,$(CAPSTONE_ARCHS)))
211 CFLAGS += -DCAPSTONE_HAS_SYSZ
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200212 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZDisassembler.o
213 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZInstPrinter.o
214 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZMapping.o
215 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZModule.o
216 LIBOBJ_SYSZ += $(OBJDIR)/arch/SystemZ/SystemZMCTargetDesc.o
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800217endif
218
219
Nguyen Anh Quynh95181482014-03-25 23:20:41 +0800220# by default, we compile full X86 instruction sets
Nguyen Anh Quynh59b54892014-03-27 10:54:44 +0800221X86_REDUCE =
222ifneq (,$(findstring yes,$(CAPSTONE_X86_REDUCE)))
223X86_REDUCE = _reduce
Nguyen Anh Quynh81d930a2014-03-28 10:28:57 +0800224CFLAGS += -DCAPSTONE_X86_REDUCE -Os
Nguyen Anh Quynh95181482014-03-25 23:20:41 +0800225endif
226
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800227DEP_X86 =
Nguyen Anh Quynh59b54892014-03-27 10:54:44 +0800228DEP_X86 += arch/X86/X86GenAsmWriter$(X86_REDUCE).inc
229DEP_X86 += arch/X86/X86GenAsmWriter1$(X86_REDUCE).inc
230DEP_X86 += arch/X86/X86GenDisassemblerTables$(X86_REDUCE).inc
231DEP_X86 += arch/X86/X86GenInstrInfo$(X86_REDUCE).inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800232DEP_X86 += arch/X86/X86GenRegisterInfo.inc
Nguyen Anh Quynh0d394aa2015-11-06 10:34:27 +0800233DEP_X86 += arch/X86/X86MappingInsn$(X86_REDUCE).inc
234DEP_X86 += arch/X86/X86MappingInsnOp$(X86_REDUCE).inc
235DEP_X86 += arch/X86/X86ImmSize.inc
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800236
237LIBOBJ_X86 =
238ifneq (,$(findstring x86,$(CAPSTONE_ARCHS)))
239 CFLAGS += -DCAPSTONE_HAS_X86
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200240 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86DisassemblerDecoder.o
241 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Disassembler.o
242 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86IntelInstPrinter.o
Nguyen Anh Quynh50689082014-05-14 12:26:53 +0800243# assembly syntax is irrelevant in Diet mode, when this info is suppressed
244ifeq (,$(findstring yes,$(CAPSTONE_DIET)))
baguette86e84502014-08-17 20:59:05 +0200245ifeq (,$(findstring yes,$(CAPSTONE_X86_ATT_DISABLE)))
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200246 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86ATTInstPrinter.o
Nguyen Anh Quynh50689082014-05-14 12:26:53 +0800247endif
baguette86e84502014-08-17 20:59:05 +0200248endif
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200249 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Mapping.o
250 LIBOBJ_X86 += $(OBJDIR)/arch/X86/X86Module.o
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800251endif
252
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800253
254DEP_XCORE =
255DEP_XCORE += arch/XCore/XCoreGenAsmWriter.inc
256DEP_XCORE += arch/XCore/XCoreGenInstrInfo.inc
257DEP_XCORE += arch/XCore/XCoreGenDisassemblerTables.inc
258DEP_XCORE += arch/XCore/XCoreGenRegisterInfo.inc
Nguyen Anh Quynhefffe782015-03-25 15:02:13 +0800259DEP_XCORE += arch/XCore/XCoreMappingInsn.inc
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800260
261LIBOBJ_XCORE =
262ifneq (,$(findstring xcore,$(CAPSTONE_ARCHS)))
263 CFLAGS += -DCAPSTONE_HAS_XCORE
264 LIBOBJ_XCORE += $(OBJDIR)/arch/XCore/XCoreDisassembler.o
265 LIBOBJ_XCORE += $(OBJDIR)/arch/XCore/XCoreInstPrinter.o
266 LIBOBJ_XCORE += $(OBJDIR)/arch/XCore/XCoreMapping.o
267 LIBOBJ_XCORE += $(OBJDIR)/arch/XCore/XCoreModule.o
268endif
269
270
Fotis Loukos0850d552016-05-03 15:52:11 +0300271DEP_TMS320C64X =
272DEP_TMS320C64X += arch/TMS320C64x/TMS320C64xGenAsmWriter.inc
273DEP_TMS320C64X += arch/TMS320C64x/TMS320C64xGenInstrInfo.inc
274DEP_TMS320C64X += arch/TMS320C64x/TMS320C64xGenDisassemblerTables.inc
275DEP_TMS320C64X += arch/TMS320C64x/TMS320C64xGenRegisterInfo.inc
276
277LIBOBJ_TMS320C64X =
278ifneq (,$(findstring tms320c64x,$(CAPSTONE_ARCHS)))
279 CFLAGS += -DCAPSTONE_HAS_TMS320C64X
280 LIBOBJ_TMS320C64X += $(OBJDIR)/arch/TMS320C64x/TMS320C64xDisassembler.o
281 LIBOBJ_TMS320C64X += $(OBJDIR)/arch/TMS320C64x/TMS320C64xInstPrinter.o
282 LIBOBJ_TMS320C64X += $(OBJDIR)/arch/TMS320C64x/TMS320C64xMapping.o
283 LIBOBJ_TMS320C64X += $(OBJDIR)/arch/TMS320C64x/TMS320C64xModule.o
284endif
285
286
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800287LIBOBJ =
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200288LIBOBJ += $(OBJDIR)/cs.o $(OBJDIR)/utils.o $(OBJDIR)/SStream.o $(OBJDIR)/MCInstrDesc.o $(OBJDIR)/MCRegisterInfo.o
Fotis Loukos0850d552016-05-03 15:52:11 +0300289LIBOBJ += $(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 +0200290LIBOBJ += $(OBJDIR)/MCInst.o
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800291
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800292
Nguyen Anh Quynhf0677ab2015-05-21 12:58:38 +0800293ifeq ($(PKG_EXTRA),)
294PKGCFGDIR = $(LIBDATADIR)/pkgconfig
295else
Nguyen Anh Quynhaf0e9372014-04-12 23:10:46 +0800296PKGCFGDIR ?= $(LIBDATADIR)/pkgconfig
Nguyen Anh Quynhd46a4f22017-04-14 18:43:06 +0800297ifeq ($(PKGCFGDIR),)
298PKGCFGDIR = $(LIBDATADIR)/pkgconfig
299endif
Nguyen Anh Quynhf0677ab2015-05-21 12:58:38 +0800300endif
301
pancake9c10ace2015-02-24 04:55:55 +0100302API_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 +0800303VERSION_EXT =
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800304
pancake5a4dabd2017-02-06 13:24:33 +0100305IS_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 +0200306ifeq ($(IS_APPLE),1)
Jonas7a274e22017-09-05 16:45:48 +0200307# on MacOS, compile in Universal format by default
308MACOS_UNIVERSAL ?= yes
309ifeq ($(MACOS_UNIVERSAL),yes)
310CFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
311LDFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
312endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800313EXT = dylib
pancake26943332014-02-04 08:37:55 +0100314VERSION_EXT = $(API_MAJOR).$(EXT)
danghvue1c7a212014-05-14 02:13:36 -0500315$(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 +0800316AR_EXT = a
Nguyen Anh Quynhe3606d92014-04-12 18:02:55 +0800317# Homebrew wants to make sure its formula does not disable FORTIFY_SOURCE
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +0800318# However, this is not really necessary because 'CAPSTONE_USE_SYS_DYN_MEM=yes' by default
Nguyen Anh Quynh189e83a2014-03-29 22:36:05 +0800319ifneq ($(HOMEBREW_CAPSTONE),1)
Nguyen Anh Quynhe31327d2014-04-29 14:25:15 +0800320ifneq ($(CAPSTONE_USE_SYS_DYN_MEM),yes)
Nguyen Anh Quynhc77cf3a2014-03-07 22:06:51 +0800321# remove string check because OSX kernel complains about missing symbols
322CFLAGS += -D_FORTIFY_SOURCE=0
323endif
Nguyen Anh Quynh189e83a2014-03-29 22:36:05 +0800324endif
pancake02cad6e2013-11-27 15:38:44 +0100325else
Jonas7a274e22017-09-05 16:45:48 +0200326CFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
327LDFLAGS += $(foreach arch,$(LIBARCHS),-arch $(arch))
danghvue1c7a212014-05-14 02:13:36 -0500328$(LIBNAME)_LDFLAGS += -shared
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000329# Cygwin?
pancake5a4dabd2017-02-06 13:24:33 +0100330IS_CYGWIN := $(shell $(CC) -dumpmachine 2>/dev/null | grep -i cygwin | wc -l)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000331ifeq ($(IS_CYGWIN),1)
332EXT = dll
Nguyen Anh Quynh76087d22014-05-14 14:53:51 +0800333AR_EXT = lib
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000334# Cygwin doesn't like -fPIC
335CFLAGS := $(CFLAGS:-fPIC=)
336# On Windows we need the shared library to be executable
337else
338# mingw?
pancake5a4dabd2017-02-06 13:24:33 +0100339IS_MINGW := $(shell $(CC) --version 2>/dev/null | grep -i mingw | wc -l)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000340ifeq ($(IS_MINGW),1)
341EXT = dll
Nguyen Anh Quynh76087d22014-05-14 14:53:51 +0800342AR_EXT = lib
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000343# mingw doesn't like -fPIC either
344CFLAGS := $(CFLAGS:-fPIC=)
345# On Windows we need the shared library to be executable
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800346else
347# Linux, *BSD
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800348EXT = so
349VERSION_EXT = $(EXT).$(API_MAJOR)
Nguyen Anh Quynh6d5381e2014-03-17 10:37:08 +0800350AR_EXT = a
danghvue1c7a212014-05-14 02:13:36 -0500351$(LIBNAME)_LDFLAGS += -Wl,-soname,lib$(LIBNAME).$(VERSION_EXT)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000352endif
353endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800354endif
355
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200356ifeq ($(CAPSTONE_SHARED),yes)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800357ifeq ($(IS_MINGW),1)
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400358LIBRARY = $(BLDIR)/$(LIBNAME).$(VERSION_EXT)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800359else ifeq ($(IS_CYGWIN),1)
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400360LIBRARY = $(BLDIR)/$(LIBNAME).$(VERSION_EXT)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800361else # *nix
Pranith Kumarfbf1cd72016-04-30 12:32:59 -0400362LIBRARY = $(BLDIR)/lib$(LIBNAME).$(VERSION_EXT)
Hilko Bengene0352d62015-02-26 18:37:32 +0100363CFLAGS += -fvisibility=hidden
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200364endif
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800365endif
366
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200367ifeq ($(CAPSTONE_STATIC),yes)
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800368ifeq ($(IS_MINGW),1)
369ARCHIVE = $(BLDIR)/$(LIBNAME).$(AR_EXT)
370else ifeq ($(IS_CYGWIN),1)
371ARCHIVE = $(BLDIR)/$(LIBNAME).$(AR_EXT)
372else
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800373ARCHIVE = $(BLDIR)/lib$(LIBNAME).$(AR_EXT)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200374endif
Nguyen Anh Quynh0936b562014-06-04 00:26:33 +0800375endif
376
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800377PKGCFGF = $(BLDIR)/$(LIBNAME).pc
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800378
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800379.PHONY: all clean install uninstall dist
pancakeca9f1b22013-12-06 17:03:41 +0100380
Nguyen Anh Quynh80ff30b2013-12-09 00:38:44 +0800381all: $(LIBRARY) $(ARCHIVE) $(PKGCFGF)
Nguyen Anh Quynh794a7062015-01-30 09:07:51 +0800382ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
Adrian Herrera1910fd52017-06-02 15:49:10 +0200383 @V=$(V) CC=$(CC) $(MAKE) -C cstool
Nguyen Anh Quynhc00bc352015-01-28 04:42:34 +0800384ifndef BUILDDIR
385 cd tests && $(MAKE)
386else
387 cd tests && $(MAKE) BUILDDIR=$(BLDIR)
388endif
Akihiko Odakiec407532016-09-11 09:00:32 +0900389 $(call install-library,$(BLDIR)/tests/)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200390endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800391
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200392ifeq ($(CAPSTONE_SHARED),yes)
pancakeaddb1922014-02-28 02:44:07 +0100393$(LIBRARY): $(LIBOBJ)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200394ifeq ($(V),0)
Nguyen Anh Quynh8c0ab862014-06-03 23:43:53 +0700395 $(call log,LINK,$(@:$(BLDIR)/%=%))
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200396 @$(create-library)
397else
398 $(create-library)
399endif
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200400endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800401
Nguyen Anh Quynh3ba8c4d2016-10-23 02:09:14 +0800402$(LIBOBJ): config.mk *.h include/capstone/*.h
Nguyen Anh Quynhaeb0c402014-03-27 17:54:27 +0800403
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800404$(LIBOBJ_ARM): $(DEP_ARM)
405$(LIBOBJ_ARM64): $(DEP_ARM64)
Daniel Collin2ee675c2015-08-03 18:45:08 +0200406$(LIBOBJ_M68K): $(DEP_M68K)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800407$(LIBOBJ_MIPS): $(DEP_MIPS)
408$(LIBOBJ_PPC): $(DEP_PPC)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800409$(LIBOBJ_SPARC): $(DEP_SPARC)
Nguyen Anh Quynh48a14ca2014-03-23 08:35:45 +0800410$(LIBOBJ_SYSZ): $(DEP_SYSZ)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800411$(LIBOBJ_X86): $(DEP_X86)
Nguyen Anh Quynhc80d8402014-05-26 23:02:48 +0800412$(LIBOBJ_XCORE): $(DEP_XCORE)
Fotis Loukos0850d552016-05-03 15:52:11 +0300413$(LIBOBJ_TMS320C64X): $(DEP_TMS320C64X)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800414
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200415ifeq ($(CAPSTONE_STATIC),yes)
pancakeca9f1b22013-12-06 17:03:41 +0100416$(ARCHIVE): $(LIBOBJ)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200417 @rm -f $(ARCHIVE)
418ifeq ($(V),0)
419 $(call log,AR,$(@:$(BLDIR)/%=%))
420 @$(create-archive)
421else
422 $(create-archive)
423endif
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200424endif
pancakef1cbce22013-11-27 15:31:26 +0100425
pancakeca9f1b22013-12-06 17:03:41 +0100426$(PKGCFGF):
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200427ifeq ($(V),0)
428 $(call log,GEN,$(@:$(BLDIR)/%=%))
429 @$(generate-pkgcfg)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800430else
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200431 $(generate-pkgcfg)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800432endif
pancake44ce0fb2013-12-03 04:11:37 +0100433
pancakeca9f1b22013-12-06 17:03:41 +0100434install: $(PKGCFGF) $(ARCHIVE) $(LIBRARY)
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800435 mkdir -p $(DESTDIR)$(LIBDIR)
436 $(call install-library,$(DESTDIR)$(LIBDIR))
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200437ifeq ($(CAPSTONE_STATIC),yes)
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800438 $(INSTALL_DATA) $(ARCHIVE) $(DESTDIR)$(LIBDIR)
Ole André Vadla Ravnås927fcbc2014-05-01 16:00:52 +0200439endif
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800440 mkdir -p $(DESTDIR)$(INCDIR)/$(LIBNAME)
441 $(INSTALL_DATA) include/capstone/*.h $(DESTDIR)$(INCDIR)/$(LIBNAME)
442 mkdir -p $(DESTDIR)$(PKGCFGDIR)
443 $(INSTALL_DATA) $(PKGCFGF) $(DESTDIR)$(PKGCFGDIR)
Hank Leininger1b4d8052016-12-10 20:52:08 -0500444 mkdir -p $(DESTDIR)$(BINDIR)
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800445 $(INSTALL_LIB) cstool/cstool $(DESTDIR)$(BINDIR)
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800446
447uninstall:
Nguyen Anh Quynhce7c9a82016-10-13 20:45:24 +0800448 rm -rf $(DESTDIR)$(INCDIR)/$(LIBNAME)
449 rm -f $(DESTDIR)$(LIBDIR)/lib$(LIBNAME).*
450 rm -f $(DESTDIR)$(PKGCFGDIR)/$(LIBNAME).pc
451 rm -f $(DESTDIR)$(BINDIR)/cstool
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800452
453clean:
Nguyen Anh Quynh5519a682014-04-29 16:24:30 +0800454 rm -f $(LIBOBJ)
Nguyen Anh Quynhcbc1c032017-05-05 09:46:46 +0800455 rm -f $(BLDIR)/lib$(LIBNAME).* $(BLDIR)/$(LIBNAME).pc
Nguyen Anh Quynhd63ddac2014-01-09 10:35:58 +0800456 rm -f $(PKGCFGF)
Nguyen Anh Quynhf36b3f42016-10-10 22:54:16 +0800457 $(MAKE) -C cstool clean
Nguyen Tan Cong39fd1542015-01-28 00:35:44 +0700458
Nguyen Anh Quynh794a7062015-01-30 09:07:51 +0800459ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
danghvuad664202014-05-12 14:27:38 -0500460 cd tests && $(MAKE) clean
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800461 rm -f $(BLDIR)/tests/lib$(LIBNAME).$(EXT)
Nguyen Tan Cong39fd1542015-01-28 00:35:44 +0700462endif
Nguyen Anh Quynh6ae472f2014-04-29 16:29:55 +0800463
464ifdef BUILDDIR
465 rm -rf $(BUILDDIR)
466endif
Nguyen Anh Quynh5519a682014-04-29 16:24:30 +0800467
Nguyen Anh Quynh794a7062015-01-30 09:07:51 +0800468ifeq (,$(findstring yes,$(CAPSTONE_BUILD_CORE_ONLY)))
danghvuad664202014-05-12 14:27:38 -0500469 cd bindings/python && $(MAKE) clean
470 cd bindings/java && $(MAKE) clean
471 cd bindings/ocaml && $(MAKE) clean
Nguyen Tan Cong39fd1542015-01-28 00:35:44 +0700472endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800473
Nguyen Anh Quynha580d922014-01-18 12:47:15 +0800474
475TAG ?= HEAD
476ifeq ($(TAG), HEAD)
477DIST_VERSION = latest
478else
479DIST_VERSION = $(TAG)
480endif
481
pancake35cef7f2014-01-18 03:42:15 +0100482dist:
Nguyen Anh Quynh186d5012014-01-22 18:46:20 +0800483 git archive --format=tar.gz --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).tgz
Nguyen Anh Quynhf4f72532014-03-11 12:29:16 +0800484 git archive --format=zip --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).zip
pancake35cef7f2014-01-18 03:42:15 +0100485
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800486
Pranith Kumar83fb35c2016-02-29 22:58:57 -0500487TESTS = test_basic test_detail test_arm test_arm64 test_m68k test_mips test_ppc test_sparc
Nguyen Anh Quynhb16dc852014-11-02 08:21:34 +0800488TESTS += test_systemz test_x86 test_xcore test_iter
Pranith Kumar83fb35c2016-02-29 22:58:57 -0500489TESTS += test_basic.static test_detail.static test_arm.static test_arm64.static
Daniel Collin2ee675c2015-08-03 18:45:08 +0200490TESTS += test_m68k.static test_mips.static test_ppc.static test_sparc.static
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800491TESTS += test_systemz.static test_x86.static test_xcore.static
Nguyen Anh Quynhb16dc852014-11-02 08:21:34 +0800492TESTS += test_skipdata test_skipdata.static test_iter.static
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800493check:
494 @for t in $(TESTS); do \
495 echo Check $$t ... ; \
Akihiko Odakiec407532016-09-11 09:00:32 +0900496 LD_LIBRARY_PATH=./tests ./tests/$$t > /dev/null && echo OK || echo FAILED; \
Nguyen Anh Quynh984d4502014-10-01 16:42:29 +0800497 done
498
Ole André Vadla Ravnås35f937d2014-04-29 09:00:34 +0200499$(OBJDIR)/%.o: %.c
500 @mkdir -p $(@D)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200501ifeq ($(V),0)
502 $(call log,CC,$(@:$(OBJDIR)/%=%))
503 @$(compile)
504else
505 $(compile)
506endif
507
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200508
Akihiko Odakiec407532016-09-11 09:00:32 +0900509ifeq ($(CAPSTONE_SHARED),yes)
510define install-library
511 $(INSTALL_LIB) $(LIBRARY) $1
512 $(if $(VERSION_EXT),
513 cd $1 && \
514 rm -f lib$(LIBNAME).$(EXT) && \
515 ln -s lib$(LIBNAME).$(VERSION_EXT) lib$(LIBNAME).$(EXT))
516endef
517else
518define install-library
519endef
520endif
521
522
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200523define create-archive
524 $(AR) q $(ARCHIVE) $(LIBOBJ)
525 $(RANLIB) $(ARCHIVE)
526endef
527
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +0800528
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200529define create-library
danghvue1c7a212014-05-14 02:13:36 -0500530 $(CC) $(LDFLAGS) $($(LIBNAME)_LDFLAGS) $(LIBOBJ) -o $(LIBRARY)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200531endef
532
Nguyen Anh Quynh58a00472014-05-01 22:53:52 +0800533
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200534define generate-pkgcfg
Ole André Vadla Ravnås495a4f52015-04-23 17:55:06 +0200535 mkdir -p $(BLDIR)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200536 echo 'Name: capstone' > $(PKGCFGF)
537 echo 'Description: Capstone disassembly engine' >> $(PKGCFGF)
538 echo 'Version: $(PKG_VERSION)' >> $(PKGCFGF)
539 echo 'libdir=$(LIBDIR)' >> $(PKGCFGF)
pancake9c10ace2015-02-24 04:55:55 +0100540 echo 'includedir=$(INCDIR)' >> $(PKGCFGF)
Ole André Vadla Ravnåsf536d402014-05-01 15:22:25 +0200541 echo 'archive=$${libdir}/libcapstone.a' >> $(PKGCFGF)
542 echo 'Libs: -L$${libdir} -lcapstone' >> $(PKGCFGF)
543 echo 'Cflags: -I$${includedir}' >> $(PKGCFGF)
544endef