blob: cbf89d3f484c8132e7c79266df9bc80ec0326531 [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 Quynh26ee41a2013-11-27 12:11:31 +08005
Nguyen Anh Quynhd80cede2014-01-16 21:07:59 +08006ifeq ($(CROSS),)
7CC ?= cc
8AR ?= ar
9RANLIB ?= ranlib
10STRIP ?= strip
11else
12CC = $(CROSS)gcc
13AR = $(CROSS)ar
14RANLIB = $(CROSS)ranlib
15STRIP = $(CROSS)strip
16endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080017
Nguyen Anh Quynhc76d8d02014-03-06 23:19:26 +080018ifeq ($(CAPSTONE_DIET),yes)
19# remove string check & stack protector functions
20CFLAGS += -D_FORTIFY_SOURCE=0
21CFLAGS += -fno-stack-protector
22endif
23
pancakeca9f1b22013-12-06 17:03:41 +010024CFLAGS += -fPIC -O3 -Wall -Iinclude
Nguyen Anh Quynh59492c22014-01-05 23:41:31 +080025
26ifeq ($(USE_SYS_DYN_MEM),yes)
27CFLAGS += -DUSE_SYS_DYN_MEM
28endif
29
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080030LDFLAGS += -shared
31
pancake02cad6e2013-11-27 15:38:44 +010032PREFIX ?= /usr
33DESTDIR ?=
34INCDIR = $(DESTDIR)$(PREFIX)/include
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080035
pancake02cad6e2013-11-27 15:38:44 +010036LIBDIR = $(DESTDIR)$(PREFIX)/lib
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080037# on x86_64, we might have /usr/lib64 directory instead of /usr/lib
Nguyen Anh Quynh2844cc52014-03-05 23:49:14 +080038UNAME_M := $(shell uname -m)
39ifeq ($(UNAME_M), x86_64)
Nguyen Anh Quynhc0b63dc2014-01-01 21:40:49 +080040ifeq (,$(wildcard $(LIBDIR)))
41LIBDIR = $(DESTDIR)$(PREFIX)/lib64
42else
43LIBDIR = $(DESTDIR)$(PREFIX)/lib
44endif
Nguyen Anh Quynh9f0e6c22013-12-25 22:47:28 +080045endif
pancake02cad6e2013-11-27 15:38:44 +010046
Nguyen Anh Quynh64d40832014-01-17 20:55:21 +080047INSTALL_BIN ?= install
48INSTALL_DATA ?= $(INSTALL_BIN) -m0644
49INSTALL_LIBRARY ?= $(INSTALL_BIN) -m0755
pancake02cad6e2013-11-27 15:38:44 +010050
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +080051LIBNAME = capstone
pancakeca9f1b22013-12-06 17:03:41 +010052
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +080053
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +080054DEP_ARM =
55DEP_ARM += arch/ARM/ARMGenAsmWriter.inc
56DEP_ARM += arch/ARM/ARMGenDisassemblerTables.inc
57DEP_ARM += arch/ARM/ARMGenInstrInfo.inc
58DEP_ARM += arch/ARM/ARMGenRegisterInfo.inc
59DEP_ARM += arch/ARM/ARMGenSubtargetInfo.inc
60
61LIBOBJ_ARM =
Nguyen Anh Quynh9cc56a32014-01-15 16:01:55 +080062ifneq (,$(findstring arm,$(CAPSTONE_ARCHS)))
63 CFLAGS += -DCAPSTONE_HAS_ARM
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +080064 LIBOBJ_ARM += arch/ARM/ARMDisassembler.o
65 LIBOBJ_ARM += arch/ARM/ARMInstPrinter.o
66 LIBOBJ_ARM += arch/ARM/ARMMapping.o
67 LIBOBJ_ARM += arch/ARM/ARMModule.o
danghvu02db4882013-12-20 00:57:12 -060068endif
Nguyen Anh Quynh42c6b1a2013-12-30 00:15:25 +080069
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +080070DEP_ARM64 =
71DEP_ARM64 += arch/AArch64/AArch64GenAsmWriter.inc
72DEP_ARM64 += arch/AArch64/AArch64GenInstrInfo.inc
73DEP_ARM64 += arch/AArch64/AArch64GenSubtargetInfo.inc
74DEP_ARM64 += arch/AArch64/AArch64GenDisassemblerTables.inc
75DEP_ARM64 += arch/AArch64/AArch64GenRegisterInfo.inc
76
77LIBOBJ_ARM64 =
78ifneq (,$(findstring aarch64,$(CAPSTONE_ARCHS)))
79 CFLAGS += -DCAPSTONE_HAS_ARM64
80 LIBOBJ_ARM64 += arch/AArch64/AArch64BaseInfo.o
81 LIBOBJ_ARM64 += arch/AArch64/AArch64Disassembler.o
82 LIBOBJ_ARM64 += arch/AArch64/AArch64InstPrinter.o
83 LIBOBJ_ARM64 += arch/AArch64/AArch64Mapping.o
84 LIBOBJ_ARM64 += arch/AArch64/AArch64Module.o
85endif
86
87
88DEP_MIPS =
89DEP_MIPS += arch/Mips/MipsGenAsmWriter.inc
90DEP_MIPS += arch/Mips/MipsGenDisassemblerTables.inc
91DEP_MIPS += arch/Mips/MipsGenInstrInfo.inc
92DEP_MIPS += arch/Mips/MipsGenRegisterInfo.inc
93DEP_MIPS += arch/Mips/MipsGenSubtargetInfo.inc
94
95LIBOBJ_MIPS =
96ifneq (,$(findstring mips,$(CAPSTONE_ARCHS)))
97 CFLAGS += -DCAPSTONE_HAS_MIPS
98 LIBOBJ_MIPS += arch/Mips/MipsDisassembler.o
99 LIBOBJ_MIPS += arch/Mips/MipsInstPrinter.o
100 LIBOBJ_MIPS += arch/Mips/MipsMapping.o
101 LIBOBJ_MIPS += arch/Mips/MipsModule.o
102endif
103
104
105DEP_PPC =
106DEP_PPC += arch/PowerPC/PPCGenAsmWriter.inc
107DEP_PPC += arch/PowerPC/PPCGenInstrInfo.inc
108DEP_PPC += arch/PowerPC/PPCGenSubtargetInfo.inc
109DEP_PPC += arch/PowerPC/PPCGenDisassemblerTables.inc
110DEP_PPC += arch/PowerPC/PPCGenRegisterInfo.inc
111
112LIBOBJ_PPC =
113ifneq (,$(findstring powerpc,$(CAPSTONE_ARCHS)))
114 CFLAGS += -DCAPSTONE_HAS_POWERPC
115 LIBOBJ_PPC += arch/PowerPC/PPCDisassembler.o
116 LIBOBJ_PPC += arch/PowerPC/PPCInstPrinter.o
117 LIBOBJ_PPC += arch/PowerPC/PPCMapping.o
118 LIBOBJ_PPC += arch/PowerPC/PPCModule.o
119endif
120
121
122DEP_X86 =
123DEP_X86 += arch/X86/X86GenAsmWriter.inc
124DEP_X86 += arch/X86/X86GenAsmWriter1.inc
125DEP_X86 += arch/X86/X86GenDisassemblerTables.inc
126DEP_X86 += arch/X86/X86GenInstrInfo.inc
127DEP_X86 += arch/X86/X86GenRegisterInfo.inc
128
129LIBOBJ_X86 =
130ifneq (,$(findstring x86,$(CAPSTONE_ARCHS)))
131 CFLAGS += -DCAPSTONE_HAS_X86
132 LIBOBJ_X86 += arch/X86/X86DisassemblerDecoder.o
133 LIBOBJ_X86 += arch/X86/X86Disassembler.o
134 LIBOBJ_X86 += arch/X86/X86IntelInstPrinter.o
135 LIBOBJ_X86 += arch/X86/X86ATTInstPrinter.o
136 LIBOBJ_X86 += arch/X86/X86Mapping.o
137 LIBOBJ_X86 += arch/X86/X86Module.o
138endif
139
140LIBOBJ =
141LIBOBJ += cs.o utils.o SStream.o MCInstrDesc.o MCRegisterInfo.o
142LIBOBJ += $(LIBOBJ_ARM) $(LIBOBJ_ARM64) $(LIBOBJ_MIPS) $(LIBOBJ_PPC) $(LIBOBJ_X86)
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800143LIBOBJ += MCInst.o
144
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800145
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800146UNAME_S := $(shell uname -s)
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800147PKGCFCGDIR = $(LIBDIR)/pkgconfig
148
Nguyen Anh Quynh5e107ab2013-12-31 23:38:28 +0800149# OSX?
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800150ifeq ($(UNAME_S),Darwin)
151EXT = dylib
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800152AR_EXT = a
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800153# By default, suppose that Brew is installed & use Brew path for pkgconfig file
154PKGCFCGDIR = /usr/local/lib/pkgconfig
155# is Macport installed instead?
Nguyen Anh Quynh2b63b072014-02-24 15:26:20 +0800156ifneq (,$(wildcard /opt/local/bin/port))
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800157# then correct the path for pkgconfig file
158PKGCFCGDIR = /opt/local/lib/pkgconfig
159endif
pancake02cad6e2013-11-27 15:38:44 +0100160else
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000161# Cygwin?
162IS_CYGWIN := $(shell $(CC) -dumpmachine | grep -i cygwin | wc -l)
163ifeq ($(IS_CYGWIN),1)
164EXT = dll
165AR_EXT = dll.a
166# Cygwin doesn't like -fPIC
167CFLAGS := $(CFLAGS:-fPIC=)
168# On Windows we need the shared library to be executable
169else
170# mingw?
171IS_MINGW := $(shell $(CC) --version | grep -i mingw | wc -l)
172ifeq ($(IS_MINGW),1)
173EXT = dll
174AR_EXT = dll.a
175# mingw doesn't like -fPIC either
176CFLAGS := $(CFLAGS:-fPIC=)
177# On Windows we need the shared library to be executable
Nguyen Anh Quynh4ebdd212013-12-25 23:54:45 +0800178else
179# Linux, *BSD
180EXT = so
181AR_EXT = a
182LDFLAGS += -Wl,-soname,$(LIBRARY)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000183endif
184endif
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800185endif
186
pancakeca9f1b22013-12-06 17:03:41 +0100187LIBRARY = lib$(LIBNAME).$(EXT)
188ARCHIVE = lib$(LIBNAME).$(AR_EXT)
189PKGCFGF = $(LIBNAME).pc
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800190
Nguyen Anh Quynhe5c658c2013-12-13 09:24:41 +0800191VERSION=$(shell echo `grep -e PKG_MAJOR -e PKG_MINOR CONFIG | grep -v = | awk '{print $$3}'` | awk '{print $$1"."$$2}')
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800192
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800193.PHONY: all clean install uninstall dist
pancakeca9f1b22013-12-06 17:03:41 +0100194
Nguyen Anh Quynh80ff30b2013-12-09 00:38:44 +0800195all: $(LIBRARY) $(ARCHIVE) $(PKGCFGF)
pancake02cad6e2013-11-27 15:38:44 +0100196 $(MAKE) -C tests
197 $(INSTALL_DATA) lib$(LIBNAME).$(EXT) tests
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800198
pancakeaddb1922014-02-28 02:44:07 +0100199$(LIBRARY): $(LIBOBJ)
pancakeca9f1b22013-12-06 17:03:41 +0100200 $(CC) $(LDFLAGS) $(LIBOBJ) -o $(LIBRARY)
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800201
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800202$(LIBOBJ): include/diet.h
pancakeaddb1922014-02-28 02:44:07 +0100203
Nguyen Anh Quynh4a328ca2014-02-28 23:09:04 +0800204$(LIBOBJ_ARM): $(DEP_ARM)
205$(LIBOBJ_ARM64): $(DEP_ARM64)
206$(LIBOBJ_MIPS): $(DEP_MIPS)
207$(LIBOBJ_PPC): $(DEP_PPC)
208$(LIBOBJ_X86): $(DEP_X86)
209
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800210# auto-generate include/diet.h
Nguyen Anh Quynh86909592014-02-28 11:23:28 +0800211include/diet.h: config.mk
Nguyen Anh Quynha4f37e02014-02-28 10:23:14 +0800212 @echo "// File auto-generated by Makefile for Capstone framework. DO NOT MODIFY!" > include/diet.h
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800213 @echo "" >> include/diet.h
Nguyen Anh Quynha4f37e02014-02-28 10:23:14 +0800214 @echo "#ifndef CAPSTONE_DIET_H" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800215 @echo "#define CAPSTONE_DIET_H" >> include/diet.h
216 @echo "" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800217ifneq (,$(findstring yes,$(CAPSTONE_DIET)))
Nguyen Anh Quynha4f37e02014-02-28 10:23:14 +0800218 @echo "// Capstone is in DIET mode" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800219 @echo "#define CAPSTONE_DIET" >> include/diet.h
Nguyen Anh Quynha347d652014-02-24 15:31:41 +0800220else
Nguyen Anh Quynha4f37e02014-02-28 10:23:14 +0800221 @echo "// Capstone is in standard mode (NOT diet)" >> include/diet.h
Nguyen Anh Quynh3626a352014-02-24 15:34:11 +0800222 @echo "#undef CAPSTONE_DIET" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800223endif
Nguyen Anh Quynha347d652014-02-24 15:31:41 +0800224 @echo "" >> include/diet.h
Nguyen Anh Quynhfc83a432014-02-22 23:26:27 +0800225 @echo "#endif" >> include/diet.h
226
pancakeca9f1b22013-12-06 17:03:41 +0100227$(ARCHIVE): $(LIBOBJ)
228 rm -f $(ARCHIVE)
229 $(AR) q $(ARCHIVE) $(LIBOBJ)
230 $(RANLIB) $(ARCHIVE)
pancakef1cbce22013-11-27 15:31:26 +0100231
pancakeca9f1b22013-12-06 17:03:41 +0100232$(PKGCFGF):
Nguyen Anh Quynh0655fe42013-12-22 13:23:20 +0800233 echo 'Name: capstone' > $(PKGCFGF)
Nguyen Anh Quynh296a2312014-03-05 23:50:41 +0800234 echo 'Description: Capstone disassembly engine' >> $(PKGCFGF)
Nguyen Anh Quynh0655fe42013-12-22 13:23:20 +0800235 echo 'Version: $(VERSION)' >> $(PKGCFGF)
236 echo 'libdir=$(LIBDIR)' >> $(PKGCFGF)
237 echo 'includedir=$(PREFIX)/include/capstone' >> $(PKGCFGF)
238 echo 'archive=$${libdir}/libcapstone.a' >> $(PKGCFGF)
239 echo 'Libs: -L$${libdir} -lcapstone' >> $(PKGCFGF)
240 echo 'Cflags: -I$${includedir}' >> $(PKGCFGF)
pancake44ce0fb2013-12-03 04:11:37 +0100241
pancakeca9f1b22013-12-06 17:03:41 +0100242install: $(PKGCFGF) $(ARCHIVE) $(LIBRARY)
pancake02cad6e2013-11-27 15:38:44 +0100243 mkdir -p $(LIBDIR)
244 $(INSTALL_LIBRARY) lib$(LIBNAME).$(EXT) $(LIBDIR)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000245 $(INSTALL_DATA) lib$(LIBNAME).$(AR_EXT) $(LIBDIR)
pancake02cad6e2013-11-27 15:38:44 +0100246 mkdir -p $(INCDIR)/$(LIBNAME)
Nguyen Anh Quynh35240562014-01-04 09:18:48 +0800247 $(INSTALL_DATA) include/*.h $(INCDIR)/$(LIBNAME)
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800248 mkdir -p $(PKGCFCGDIR)
249 $(INSTALL_DATA) $(PKGCFGF) $(PKGCFCGDIR)/
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800250
251uninstall:
pancake02cad6e2013-11-27 15:38:44 +0100252 rm -rf $(INCDIR)/$(LIBNAME)
253 rm -f $(LIBDIR)/lib$(LIBNAME).$(EXT)
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000254 rm -f $(LIBDIR)/lib$(LIBNAME).$(AR_EXT)
Nguyen Anh Quynh8f856c72014-02-24 15:17:40 +0800255 rm -f $(PKGCFCGDIR)/$(LIBNAME).pc
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800256
257clean:
Daniel Godas-Lopez0f7c4322013-11-28 18:22:50 +0000258 rm -f $(LIBOBJ) lib$(LIBNAME).*
Nguyen Anh Quynhd63ddac2014-01-09 10:35:58 +0800259 rm -f $(PKGCFGF)
Nguyen Anh Quynh5bbbfce2014-02-28 10:49:46 +0800260 rm -f include/diet.h
pancake02cad6e2013-11-27 15:38:44 +0100261 $(MAKE) -C bindings/python clean
danghvu7545b9b2013-11-28 10:18:02 -0600262 $(MAKE) -C bindings/java clean
pancake02cad6e2013-11-27 15:38:44 +0100263 $(MAKE) -C bindings/ocaml clean
264 $(MAKE) -C tests clean
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800265
Nguyen Anh Quynha580d922014-01-18 12:47:15 +0800266
267TAG ?= HEAD
268ifeq ($(TAG), HEAD)
269DIST_VERSION = latest
270else
271DIST_VERSION = $(TAG)
272endif
273
pancake35cef7f2014-01-18 03:42:15 +0100274dist:
Nguyen Anh Quynh186d5012014-01-22 18:46:20 +0800275 git archive --format=tar.gz --prefix=capstone-$(DIST_VERSION)/ $(TAG) > capstone-$(DIST_VERSION).tgz
pancake35cef7f2014-01-18 03:42:15 +0100276
Nguyen Anh Quynh26ee41a2013-11-27 12:11:31 +0800277.c.o:
pancakeca9f1b22013-12-06 17:03:41 +0100278 $(CC) $(CFLAGS) -c $< -o $@