blob: 3737e69b34b5e0041c90c926df283d2e4b8c8da4 [file] [log] [blame]
Nguyen Anh Quynh296a2312014-03-05 23:50:41 +08001# Capstone Disassembly Engine
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +08002# By Nguyen Anh Quynh <aquynh@gmail.com>, 2013>
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 Quynh26ee41a2013-11-27 12:11:31 +08006
Nguyen Anh Quynhd80cede2014-01-16 21:07:59 +08007ifeq ($(CROSS),)
8CC ?= cc
9AR ?= ar
10RANLIB ?= ranlib
11STRIP ?= strip
12else
13CC = $(CROSS)gcc
14AR = $(CROSS)ar
15RANLIB = $(CROSS)ranlib
16STRIP = $(CROSS)strip
17endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080018
pancakeca9f1b22013-12-06 17:03:41 +010019CFLAGS += -fPIC -O3 -Wall -Iinclude
Nguyen Anh Quynh59492c22014-01-05 23:41:31 +080020
21ifeq ($(USE_SYS_DYN_MEM),yes)
22CFLAGS += -DUSE_SYS_DYN_MEM
23endif
24
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080025LDFLAGS += -shared
26
pancake02cad6e2013-11-27 15:38:44 +010027PREFIX ?= /usr
28DESTDIR ?=
29INCDIR = $(DESTDIR)$(PREFIX)/include
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080030
pancake02cad6e2013-11-27 15:38:44 +010031LIBDIR = $(DESTDIR)$(PREFIX)/lib
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080032# on x86_64, we might have /usr/lib64 directory instead of /usr/lib
Nguyen Anh Quynh2844cc52014-03-05 23:49:14 +080033UNAME_M := $(shell uname -m)
34ifeq ($(UNAME_M), x86_64)
Nguyen Anh Quynhc0b63dc2014-01-01 21:40:49 +080035ifeq (,$(wildcard $(LIBDIR)))
36LIBDIR = $(DESTDIR)$(PREFIX)/lib64
Nguyen Anh Quynhc0b63dc2014-01-01 21:40:49 +080037endif
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080038endif
pancake02cad6e2013-11-27 15:38:44 +010039
Oliver Pinterc5ecae52014-03-23 02:19:59 +010040LIBDATADIR = $(LIBDIR)
41UNAME_S := $(shell uname -s)
42ifeq ($(UNAME_S), FreeBSD)
43LIBDATADIR = $(DESTDIR)$(PREFIX)/libdata
Oliver Pinterc5ecae52014-03-23 02:19:59 +010044endif
Oliver Pinter25efded2014-03-23 19:10:13 +010045ifeq ($(UNAME_S), DragonFly)
46LIBDATADIR = $(DESTDIR)$(PREFIX)/libdata
47endif
Oliver Pinterc5ecae52014-03-23 02:19:59 +010048
Nguyen Anh Quynh64d40832014-01-17 20:55:21 +080049INSTALL_BIN ?= install
50INSTALL_DATA ?= $(INSTALL_BIN) -m0644
Oliver Pinterc5ecae52014-03-23 02:19:59 +010051INSTALL_LIB ?= $(INSTALL_BIN) -m0755
pancake02cad6e2013-11-27 15:38:44 +010052
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080053LIBNAME = capstone
pancakeca9f1b22013-12-06 17:03:41 +010054
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +080055
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +080056DEP_ARM =
57DEP_ARM += arch/ARM/ARMGenAsmWriter.inc
58DEP_ARM += arch/ARM/ARMGenDisassemblerTables.inc
59DEP_ARM += arch/ARM/ARMGenInstrInfo.inc
60DEP_ARM += arch/ARM/ARMGenRegisterInfo.inc
61DEP_ARM += arch/ARM/ARMGenSubtargetInfo.inc
62
63LIBOBJ_ARM =
Nguyen Anh Quynh9cc56a32014-01-15 16:01:55 +080064ifneq (,$(findstring arm,$(CAPSTONE_ARCHS)))
65 CFLAGS += -DCAPSTONE_HAS_ARM
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +080066 LIBOBJ_ARM += arch/ARM/ARMDisassembler.o
67 LIBOBJ_ARM += arch/ARM/ARMInstPrinter.o
68 LIBOBJ_ARM += arch/ARM/ARMMapping.o
69 LIBOBJ_ARM += arch/ARM/ARMModule.o
danghvu02db4882013-12-20 00:57:12 -060070endif
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +080071
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +080072DEP_ARM64 =
73DEP_ARM64 += arch/AArch64/AArch64GenAsmWriter.inc
74DEP_ARM64 += arch/AArch64/AArch64GenInstrInfo.inc
75DEP_ARM64 += arch/AArch64/AArch64GenSubtargetInfo.inc
76DEP_ARM64 += arch/AArch64/AArch64GenDisassemblerTables.inc
77DEP_ARM64 += arch/AArch64/AArch64GenRegisterInfo.inc
78
79LIBOBJ_ARM64 =
80ifneq (,$(findstring aarch64,$(CAPSTONE_ARCHS)))
81 CFLAGS += -DCAPSTONE_HAS_ARM64
82 LIBOBJ_ARM64 += arch/AArch64/AArch64BaseInfo.o
83 LIBOBJ_ARM64 += arch/AArch64/AArch64Disassembler.o
84 LIBOBJ_ARM64 += arch/AArch64/AArch64InstPrinter.o
85 LIBOBJ_ARM64 += arch/AArch64/AArch64Mapping.o
86 LIBOBJ_ARM64 += arch/AArch64/AArch64Module.o
87endif
88
89
90DEP_MIPS =
91DEP_MIPS += arch/Mips/MipsGenAsmWriter.inc
92DEP_MIPS += arch/Mips/MipsGenDisassemblerTables.inc
93DEP_MIPS += arch/Mips/MipsGenInstrInfo.inc
94DEP_MIPS += arch/Mips/MipsGenRegisterInfo.inc
95DEP_MIPS += arch/Mips/MipsGenSubtargetInfo.inc
96
97LIBOBJ_MIPS =
98ifneq (,$(findstring mips,$(CAPSTONE_ARCHS)))
99 CFLAGS += -DCAPSTONE_HAS_MIPS
100 LIBOBJ_MIPS += arch/Mips/MipsDisassembler.o
101 LIBOBJ_MIPS += arch/Mips/MipsInstPrinter.o
102 LIBOBJ_MIPS += arch/Mips/MipsMapping.o
103 LIBOBJ_MIPS += arch/Mips/MipsModule.o
104endif
105
106
107DEP_PPC =
108DEP_PPC += arch/PowerPC/PPCGenAsmWriter.inc
109DEP_PPC += arch/PowerPC/PPCGenInstrInfo.inc
110DEP_PPC += arch/PowerPC/PPCGenSubtargetInfo.inc
111DEP_PPC += arch/PowerPC/PPCGenDisassemblerTables.inc
112DEP_PPC += arch/PowerPC/PPCGenRegisterInfo.inc
113
114LIBOBJ_PPC =
115ifneq (,$(findstring powerpc,$(CAPSTONE_ARCHS)))
116 CFLAGS += -DCAPSTONE_HAS_POWERPC
117 LIBOBJ_PPC += arch/PowerPC/PPCDisassembler.o
118 LIBOBJ_PPC += arch/PowerPC/PPCInstPrinter.o
119 LIBOBJ_PPC += arch/PowerPC/PPCMapping.o
120 LIBOBJ_PPC += arch/PowerPC/PPCModule.o
121endif
122
123
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800124DEP_SPARC =
125DEP_SPARC += arch/Sparc/SparcGenAsmWriter.inc
126DEP_SPARC += arch/Sparc/SparcGenInstrInfo.inc
127DEP_SPARC += arch/Sparc/SparcGenSubtargetInfo.inc
128DEP_SPARC += arch/Sparc/SparcGenDisassemblerTables.inc
129DEP_SPARC += arch/Sparc/SparcGenRegisterInfo.inc
130
131LIBOBJ_SPARC =
132ifneq (,$(findstring sparc,$(CAPSTONE_ARCHS)))
133 CFLAGS += -DCAPSTONE_HAS_SPARC
134 LIBOBJ_SPARC += arch/Sparc/SparcDisassembler.o
135 LIBOBJ_SPARC += arch/Sparc/SparcInstPrinter.o
136 LIBOBJ_SPARC += arch/Sparc/SparcMapping.o
137 LIBOBJ_SPARC += arch/Sparc/SparcModule.o
138endif
139
140
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800141DEP_X86 =
142DEP_X86 += arch/X86/X86GenAsmWriter.inc
143DEP_X86 += arch/X86/X86GenAsmWriter1.inc
144DEP_X86 += arch/X86/X86GenDisassemblerTables.inc
145DEP_X86 += arch/X86/X86GenInstrInfo.inc
146DEP_X86 += arch/X86/X86GenRegisterInfo.inc
147
148LIBOBJ_X86 =
149ifneq (,$(findstring x86,$(CAPSTONE_ARCHS)))
150 CFLAGS += -DCAPSTONE_HAS_X86
151 LIBOBJ_X86 += arch/X86/X86DisassemblerDecoder.o
152 LIBOBJ_X86 += arch/X86/X86Disassembler.o
153 LIBOBJ_X86 += arch/X86/X86IntelInstPrinter.o
154 LIBOBJ_X86 += arch/X86/X86ATTInstPrinter.o
155 LIBOBJ_X86 += arch/X86/X86Mapping.o
156 LIBOBJ_X86 += arch/X86/X86Module.o
157endif
158
159LIBOBJ =
160LIBOBJ += cs.o utils.o SStream.o MCInstrDesc.o MCRegisterInfo.o
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800161LIBOBJ += $(LIBOBJ_ARM) $(LIBOBJ_ARM64) $(LIBOBJ_MIPS) $(LIBOBJ_PPC) $(LIBOBJ_SPARC) $(LIBOBJ_X86)
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800162LIBOBJ += MCInst.o
163
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800164
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800165UNAME_S := $(shell uname -s)
Oliver Pinterc5ecae52014-03-23 02:19:59 +0100166PKGCFCGDIR = $(LIBDATADIR)/pkgconfig
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800167VERSION_EXT =
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800168
Nguyen Anh Quynh5e107ab2013-12-31 23:38:28 +0800169# OSX?
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800170ifeq ($(UNAME_S),Darwin)
171EXT = dylib
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800172AR_EXT = a
Nguyen Anh Quynhc77cf3a2014-03-07 22:06:51 +0800173ifneq ($(USE_SYS_DYN_MEM),yes)
174# remove string check because OSX kernel complains about missing symbols
175CFLAGS += -D_FORTIFY_SOURCE=0
176endif
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800177# By default, suppose that Brew is installed & use Brew path for pkgconfig file
178PKGCFCGDIR = /usr/local/lib/pkgconfig
179# is Macport installed instead?
Nguyen Anh Quynh2b63b072014-02-24 15:26:20 +0800180ifneq (,$(wildcard /opt/local/bin/port))
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800181# then correct the path for pkgconfig file
182PKGCFCGDIR = /opt/local/lib/pkgconfig
183endif
pancake02cad6e2013-11-27 15:38:44 +0100184else
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000185# Cygwin?
186IS_CYGWIN := $(shell $(CC) -dumpmachine | grep -i cygwin | wc -l)
187ifeq ($(IS_CYGWIN),1)
188EXT = dll
189AR_EXT = dll.a
190# Cygwin doesn't like -fPIC
191CFLAGS := $(CFLAGS:-fPIC=)
192# On Windows we need the shared library to be executable
193else
194# mingw?
195IS_MINGW := $(shell $(CC) --version | grep -i mingw | wc -l)
196ifeq ($(IS_MINGW),1)
197EXT = dll
198AR_EXT = dll.a
199# mingw doesn't like -fPIC either
200CFLAGS := $(CFLAGS:-fPIC=)
201# On Windows we need the shared library to be executable
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800202else
203# Linux, *BSD
Nguyen Anh Quynha5f42cf2014-03-11 11:34:28 +0800204API_MAJOR=$(shell echo `grep -e CS_API_MAJOR include/capstone.h | grep -v = | awk '{print $$3}'` | awk '{print $$1}')
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800205EXT = so
206VERSION_EXT = $(EXT).$(API_MAJOR)
Nguyen Anh Quynh6d5381e2014-03-17 10:37:08 +0800207AR_EXT = a
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800208LDFLAGS += -Wl,-soname,lib$(LIBNAME).$(VERSION_EXT)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000209endif
210endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800211endif
212
pancakeca9f1b22013-12-06 17:03:41 +0100213LIBRARY = lib$(LIBNAME).$(EXT)
214ARCHIVE = lib$(LIBNAME).$(AR_EXT)
215PKGCFGF = $(LIBNAME).pc
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800216
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800217.PHONY: all clean install uninstall dist
pancakeca9f1b22013-12-06 17:03:41 +0100218
Nguyen Anh Quynh80ff30b2013-12-09 00:38:44 +0800219all: $(LIBRARY) $(ARCHIVE) $(PKGCFGF)
pancake02cad6e2013-11-27 15:38:44 +0100220 $(MAKE) -C tests
221 $(INSTALL_DATA) lib$(LIBNAME).$(EXT) tests
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800222
pancakeaddb1922014-02-28 02:44:07 +0100223$(LIBRARY): $(LIBOBJ)
pancakeca9f1b22013-12-06 17:03:41 +0100224 $(CC) $(LDFLAGS) $(LIBOBJ) -o $(LIBRARY)
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800225
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800226$(LIBOBJ): include/diet.h
pancakeaddb1922014-02-28 02:44:07 +0100227
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800228$(LIBOBJ_ARM): $(DEP_ARM)
229$(LIBOBJ_ARM64): $(DEP_ARM64)
230$(LIBOBJ_MIPS): $(DEP_MIPS)
231$(LIBOBJ_PPC): $(DEP_PPC)
Nguyen Anh Quynh05e27132014-03-10 11:58:57 +0800232$(LIBOBJ_SPARC): $(DEP_SPARC)
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800233$(LIBOBJ_X86): $(DEP_X86)
234
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800235# auto-generate include/diet.h
Nguyen Anh Quynh86909592014-02-28 11:23:28 +0800236include/diet.h: config.mk
Nguyen Anh Quynha4f37e02014-02-28 10:23:14 +0800237 @echo "// File auto-generated by Makefile for Capstone framework. DO NOT MODIFY!" > include/diet.h
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800238 @echo "" >> include/diet.h
Nguyen Anh Quynha4f37e02014-02-28 10:23:14 +0800239 @echo "#ifndef CAPSTONE_DIET_H" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800240 @echo "#define CAPSTONE_DIET_H" >> include/diet.h
241 @echo "" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800242ifneq (,$(findstring yes,$(CAPSTONE_DIET)))
Nguyen Anh Quynha4f37e02014-02-28 10:23:14 +0800243 @echo "// Capstone is in DIET mode" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800244 @echo "#define CAPSTONE_DIET" >> include/diet.h
Nguyen Anh Quynha347d652014-02-24 15:31:41 +0800245else
Nguyen Anh Quynha4f37e02014-02-28 10:23:14 +0800246 @echo "// Capstone is in standard mode (NOT diet)" >> include/diet.h
Nguyen Anh Quynh3626a352014-02-24 15:34:11 +0800247 @echo "#undef CAPSTONE_DIET" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800248endif
Nguyen Anh Quynha347d652014-02-24 15:31:41 +0800249 @echo "" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800250 @echo "#endif" >> include/diet.h
251
pancakeca9f1b22013-12-06 17:03:41 +0100252$(ARCHIVE): $(LIBOBJ)
253 rm -f $(ARCHIVE)
254 $(AR) q $(ARCHIVE) $(LIBOBJ)
255 $(RANLIB) $(ARCHIVE)
pancakef1cbce22013-11-27 15:31:26 +0100256
pancakeca9f1b22013-12-06 17:03:41 +0100257$(PKGCFGF):
Nguyen Anh Quynh0655fe42013-12-22 13:23:20 +0800258 echo 'Name: capstone' > $(PKGCFGF)
Nguyen Anh Quynh296a2312014-03-05 23:50:41 +0800259 echo 'Description: Capstone disassembly engine' >> $(PKGCFGF)
Nguyen Anh Quynh3ff259c2014-03-07 17:11:18 +0800260ifeq ($(PKG_EXTRA),)
261 echo 'Version: $(PKG_MAJOR).$(PKG_MINOR)' >> $(PKGCFGF)
262else
263 echo 'Version: $(PKG_MAJOR).$(PKG_MINOR).$(PKG_EXTRA)' >> $(PKGCFGF)
264endif
Nguyen Anh Quynh0655fe42013-12-22 13:23:20 +0800265 echo 'libdir=$(LIBDIR)' >> $(PKGCFGF)
266 echo 'includedir=$(PREFIX)/include/capstone' >> $(PKGCFGF)
267 echo 'archive=$${libdir}/libcapstone.a' >> $(PKGCFGF)
268 echo 'Libs: -L$${libdir} -lcapstone' >> $(PKGCFGF)
269 echo 'Cflags: -I$${includedir}' >> $(PKGCFGF)
pancake44ce0fb2013-12-03 04:11:37 +0100270
pancakeca9f1b22013-12-06 17:03:41 +0100271install: $(PKGCFGF) $(ARCHIVE) $(LIBRARY)
pancake02cad6e2013-11-27 15:38:44 +0100272 mkdir -p $(LIBDIR)
Nguyen Anh Quynh7df338c2014-03-18 09:28:48 +0800273 # remove potential broken old libs
274 rm -f $(LIBDIR)/lib$(LIBNAME).*
Oliver Pinterc5ecae52014-03-23 02:19:59 +0100275 $(INSTALL_LIB) lib$(LIBNAME).$(EXT) $(LIBDIR)
Nguyen Anh Quynhc0c0d522014-03-17 17:31:33 +0800276ifneq ($(VERSION_EXT),)
277 ln -s $(LIBDIR)/lib$(LIBNAME).$(EXT) $(LIBDIR)/lib$(LIBNAME).$(VERSION_EXT)
278endif
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000279 $(INSTALL_DATA) lib$(LIBNAME).$(AR_EXT) $(LIBDIR)
pancake02cad6e2013-11-27 15:38:44 +0100280 mkdir -p $(INCDIR)/$(LIBNAME)
Nguyen Anh Quynh35240562014-01-04 09:18:48 +0800281 $(INSTALL_DATA) include/*.h $(INCDIR)/$(LIBNAME)
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800282 mkdir -p $(PKGCFCGDIR)
283 $(INSTALL_DATA) $(PKGCFGF) $(PKGCFCGDIR)/
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800284
285uninstall:
pancake02cad6e2013-11-27 15:38:44 +0100286 rm -rf $(INCDIR)/$(LIBNAME)
Nguyen Anh Quynh6d5381e2014-03-17 10:37:08 +0800287 rm -f $(LIBDIR)/lib$(LIBNAME).*
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800288 rm -f $(PKGCFCGDIR)/$(LIBNAME).pc
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800289
290clean:
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000291 rm -f $(LIBOBJ) lib$(LIBNAME).*
Nguyen Anh Quynhd63ddac2014-01-09 10:35:58 +0800292 rm -f $(PKGCFGF)
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800293 rm -f include/diet.h
pancake02cad6e2013-11-27 15:38:44 +0100294 $(MAKE) -C bindings/python clean
danghvu7545b9b2013-11-28 10:18:02 -0600295 $(MAKE) -C bindings/java clean
pancake02cad6e2013-11-27 15:38:44 +0100296 $(MAKE) -C bindings/ocaml clean
297 $(MAKE) -C tests clean
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800298
Nguyen Anh Quynha580d922014-01-18 12:47:15 +0800299
300TAG ?= HEAD
301ifeq ($(TAG), HEAD)
302DIST_VERSION = latest
303else
304DIST_VERSION = $(TAG)
305endif
306
pancake35cef7f2014-01-18 03:42:15 +0100307dist:
Nguyen Anh Quynh186d5012014-01-22 18:46:20 +0800308 git archive --format=tar.gz --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).tgz
Nguyen Anh Quynhf4f72532014-03-11 12:29:16 +0800309 git archive --format=zip --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).zip
pancake35cef7f2014-01-18 03:42:15 +0100310
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800311.c.o:
pancakeca9f1b22013-12-06 17:03:41 +0100312 $(CC) $(CFLAGS) -c $< -o $@