]> git.zerfleddert.de Git - proxmark3-svn/blame - client/Makefile
fix: avoid SspClk overflow due to incomplete reset
[proxmark3-svn] / client / Makefile
CommitLineData
a553f267 1#-----------------------------------------------------------------------------
2# This code is licensed to you under the terms of the GNU GPL, version 2 or,
3# at your option, any later version. See the LICENSE.txt file for the text of
4# the license.
5#-----------------------------------------------------------------------------
bd846386 6
fb9acd45 7CC = gcc
8CXX = g++
9LD = g++
10TAR = tar
11TARFLAGS = -C .. --ignore-failed-read -rvf
12RM = rm -f
13MV = mv
806dc075 14
f53eb07d 15ENV_LDFLAGS := $(LDFLAGS)
16ENV_CFLAGS := $(CFLAGS)
067bfc8b 17VPATH = ../common ../zlib ../uart
46cd4046 18OBJDIR = obj
7fe9b0b7 19
94e27a09 20LDLIBS = -L/opt/local/lib -L/usr/local/lib -lreadline -lpthread -lm
e6153040 21LUALIB = ../liblua/liblua.a
f53eb07d 22LDFLAGS = $(ENV_LDFLAGS)
23CFLAGS = $(ENV_CFLAGS) -std=c99 -D_ISOC99_SOURCE -I. -I../include -I../common -I../zlib -I../uart -I/opt/local/include -I../liblua -Wall -g -O3
3851172d 24CXXFLAGS = -I../include -Wall -O3
8c04722d 25
3472ebe5 26LUAPLATFORM = generic
fb9acd45 27platform = $(shell uname)
8691f5b7 28ifneq (,$(findstring MINGW,$(platform)))
fb9acd45 29 LUAPLATFORM = mingw
8691f5b7 30else
fb9acd45 31 ifeq ($(platform),Darwin)
32 LUAPLATFORM = macosx
33 else
34 LUALIB += -ldl
35 LDLIBS += -ltermcap -lncurses
36 LUAPLATFORM = linux
37 endif
62b1302c 38endif
39
3472ebe5 40# Check for correctly configured Qt5
41QTINCLUDES = $(shell pkg-config --cflags Qt5Core Qt5Widgets 2>/dev/null)
42QTLDLIBS = $(shell pkg-config --libs Qt5Core Qt5Widgets 2>/dev/null)
43MOC = $(shell pkg-config --variable=host_bins Qt5Core)/moc
27882d37 44UIC = $(shell pkg-config --variable=host_bins Qt5Core)/uic
3472ebe5 45ifeq ($(QTINCLUDES), )
f9e2c24b 46# if Qt5 not found check for correctly configured Qt4
3472ebe5 47 QTINCLUDES = $(shell pkg-config --cflags QtCore QtGui 2>/dev/null)
48 QTLDLIBS = $(shell pkg-config --libs QtCore QtGui 2>/dev/null)
49 MOC = $(shell pkg-config --variable=moc_location QtCore)
27882d37 50 UIC = $(shell pkg-config --variable=uic_location QtCore)
f9e2c24b 51else
52 CXXFLAGS += -std=c++11 -fPIC
3472ebe5 53endif
54ifeq ($(QTINCLUDES), )
55# if both pkg-config commands failed, search in common places
56 ifneq ($(QTDIR), )
57 QTINCLUDES = -I$(QTDIR)/include -I$(QTDIR)/include/QtCore -I$(QTDIR)/include/QtGui
58 QTLDLIBS = -L$(QTDIR)/lib -lQtCore4 -lQtGui4
59 ifneq ($(wildcard $(QTDIR)/include/QtWidgets),)
60 QTINCLUDES += -I$(QTDIR)/include/QtWidgets
61 QTLDLIBS = -L$(QTDIR)/lib -lQt5Widgets -lQt5Gui -lQt5Core
f9e2c24b 62 CXXFLAGS += -std=c++11 -fPIC
3472ebe5 63 endif
64 MOC = $(QTDIR)/bin/moc
27882d37 65 UIC = $(QTDIR)/bin/uic
3472ebe5 66 endif
67endif
68
69
70ifneq ($(QTLDLIBS), )
fb9acd45 71 QTGUIOBJS = $(OBJDIR)/proxgui.o $(OBJDIR)/proxguiqt.o $(OBJDIR)/proxguiqt.moc.o
8c04722d 72 CFLAGS += -DHAVE_GUI
245e844e 73else
fb9acd45 74 QTGUIOBJS = $(OBJDIR)/guidummy.o
245e844e 75endif
62b1302c 76
fb9acd45 77# Flags to generate temporary dependency files
78DEPFLAGS = -MT $@ -MMD -MP -MF $(OBJDIR)/$*.Td
79# make temporary to final dependeny files after successful compilation
80POSTCOMPILE = $(MV) -f $(OBJDIR)/$*.Td $(OBJDIR)/$*.d
759c16b3 81
067bfc8b
MF
82CORESRCS = uart_posix.c \
83 uart_win32.c \
ec9c7112 84 util.c \
3851172d 85 util_posix.c
759c16b3 86
33443e7c 87CMDSRCS = crapto1/crapto1.c\
88 crapto1/crypto1.c\
930763e8 89 polarssl/des.c \
90 polarssl/aes.c\
4cb4b588 91 mfkey.c\
db2b81ba 92 loclass/cipher.c \
93 loclass/cipherutils.c \
db2b81ba 94 loclass/ikeys.c \
95 loclass/elite_crack.c\
96 loclass/fileutils.c\
4197a3f6 97 whereami.c\
f397b5cc 98 mifarehost.c\
1f065e1d 99 parity.c\
9f7bbd24 100 crc.c \
91c38cf7 101 crc16.c \
d730878d 102 crc64.c \
91c38cf7 103 iso14443crc.c \
9455b51c 104 iso15693tools.c \
3851172d 105 data.c \
7fe9b0b7 106 graph.c \
3851172d 107 ui.c \
7fe9b0b7 108 cmddata.c \
eb191de6 109 lfdemod.c \
fe346768 110 emv/apduinfo.c\
a2bb2735 111 emv/dump.c\
112 emv/tlv.c\
113 emv/emv_tags.c\
114 emv/emvcore.c\
7fe9b0b7 115 cmdhf.c \
116 cmdhf14a.c \
117 cmdhf14b.c \
118 cmdhf15.c \
5acd09bd 119 cmdhfepa.c \
7fe9b0b7 120 cmdhflegic.c \
cee5a30d 121 cmdhficlass.c \
9ca155ba 122 cmdhfmf.c \
fe81b478 123 cmdhfmfu.c \
c48c4d78 124 cmdhfmfhard.c \
125 hardnested/hardnested_bruteforce.c \
db2b81ba 126 cmdhftopaz.c \
7fe9b0b7 127 cmdhw.c \
128 cmdlf.c \
dbf6e824 129 cmdlfawid.c \
8b6abef5 130 cmdlfcotag.c\
28fdb04f 131 cmdlfem4x.c \
4db6f3bb 132 cmdlffdx.c \
946a84c3 133 cmdlfgproxii.c \
8b6abef5 134 cmdlfhid.c \
db09cb3a 135 cmdlfhitag.c \
8b6abef5 136 cmdlfio.c \
0fb65a26 137 cmdlfindala.c \
a9968da3 138 cmdlfjablotron.c \
5bce72d5 139 cmdlfnexwatch.c \
a9968da3 140 cmdlfnoralsy.c \
5bce72d5 141 cmdlfparadox.c \
c3caf040 142 cmdlfpcf7931.c \
143 cmdlfpresco.c \
144 cmdlfpyramid.c \
145 cmdlfsecurakey.c \
8b6abef5 146 cmdlft55xx.c \
147 cmdlfti.c \
148 cmdlfviking.c\
149 cmdlfvisa2000.c\
48d41dc3 150 cmdlfpac.c\
8b6abef5 151 cmdparser.c \
152 cmdmain.c \
a0655c45 153 scripting.c\
806dc075 154 cmdscript.c\
8b6abef5 155 pm3_binlib.c\
77cd612f 156 pm3_bitlib.c\
1defcf60 157 protocols.c\
1c4c0b06 158 sha1.c\
fe81b478 159 cmdcrc.c\
160 reveng/reveng.c\
161 reveng/cli.c\
162 reveng/bmpbit.c\
163 reveng/model.c\
164 reveng/poly.c\
165 reveng/getopt.c\
28fdb04f 166
af7a1f70 167cpu_arch = $(shell uname -m)
168ifneq ($(findstring 86, $(cpu_arch)), )
169 MULTIARCHSRCS = hardnested/hardnested_bf_core.c hardnested/hardnested_bitarray_core.c
170endif
6b758d65 171ifneq ($(findstring amd64, $(cpu_arch)), )
af7a1f70 172 MULTIARCHSRCS = hardnested/hardnested_bf_core.c hardnested/hardnested_bitarray_core.c
173endif
174ifeq ($(MULTIARCHSRCS), )
175 CMDSRCS += hardnested/hardnested_bf_core.c hardnested/hardnested_bitarray_core.c
176endif
c48c4d78 177
4b3f6d79 178ZLIBSRCS = deflate.c adler32.c trees.c zutil.c inflate.c inffast.c inftrees.c
fb9acd45 179ZLIBFLAGS = -DZ_SOLO -DZ_PREFIX -DNO_GZIP -DZLIB_PM3_TUNED
8e074056 180#-DDEBUG -Dverbose=1
0fa01ec7 181
fb9acd45 182QTGUISRCS = proxgui.cpp proxguiqt.cpp proxguiqt.moc.cpp guidummy.cpp
a0655c45 183
759c16b3 184COREOBJS = $(CORESRCS:%.c=$(OBJDIR)/%.o)
46cd4046 185CMDOBJS = $(CMDSRCS:%.c=$(OBJDIR)/%.o)
f3919878 186ZLIBOBJS = $(ZLIBSRCS:%.c=$(OBJDIR)/%.o)
c48c4d78 187MULTIARCHOBJS = $(MULTIARCHSRCS:%.c=$(OBJDIR)/%_NOSIMD.o) \
188 $(MULTIARCHSRCS:%.c=$(OBJDIR)/%_MMX.o) \
189 $(MULTIARCHSRCS:%.c=$(OBJDIR)/%_SSE2.o) \
190 $(MULTIARCHSRCS:%.c=$(OBJDIR)/%_AVX.o) \
5dd5bfb2 191 $(MULTIARCHSRCS:%.c=$(OBJDIR)/%_AVX2.o)
192
de1e68d3 193GCC_VERSION := $(shell gcc --version | awk '/gcc/{print $$NF;}' | sed -e 's/\.\([0-9][0-9]\)/\1/g' -e 's/\.\([0-9]\)/0\1/g' -e 's/^[0-9]\{3,4\}$$/&00/')
194CLANG_VERSION := $(shell gcc --version | awk '/Apple LLVM version/{print $$4;}' | sed -e 's/\.\([0-9][0-9]\)/\1/g' -e 's/\.\([0-9]\)/0\1/g' -e 's/^[0-9]\{3,4\}$$/&00/')
195ifneq ($(CLANG_VERSION), )
196 SUPPORTS_AVX512 := $(shell [ $(CLANG_VERSION) -ge 80000 ] && echo "True" )
197endif
198ifneq ($(GCC_VERSION), )
199 SUPPORTS_AVX512 := $(shell [ $(GCC_VERSION) -ge 40900 ] && echo "True" )
200endif
5dd5bfb2 201HARD_SWITCH_NOSIMD = -mno-mmx -mno-sse2 -mno-avx -mno-avx2
202HARD_SWITCH_MMX = -mmmx -mno-sse2 -mno-avx -mno-avx2
203HARD_SWITCH_SSE2 = -mmmx -msse2 -mno-avx -mno-avx2
204HARD_SWITCH_AVX = -mmmx -msse2 -mavx -mno-avx2
205HARD_SWITCH_AVX2 = -mmmx -msse2 -mavx -mavx2
206HARD_SWITCH_AVX512 = -mmmx -msse2 -mavx -mavx2 -mavx512f
de1e68d3 207ifeq "$(SUPPORTS_AVX512)" "True"
5dd5bfb2 208 HARD_SWITCH_NOSIMD += -mno-avx512f
209 HARD_SWITCH_MMX += -mno-avx512f
210 HARD_SWITCH_SSE2 += -mno-avx512f
211 HARD_SWITCH_AVX += -mno-avx512f
212 HARD_SWITCH_AVX2 += -mno-avx512f
213 MULTIARCHOBJS += $(MULTIARCHSRCS:%.c=$(OBJDIR)/%_AVX512.o)
214endif
c48c4d78 215
fb9acd45 216BINS = proxmark3 flasher fpga_compress
217WINBINS = $(patsubst %, %.exe, $(BINS))
c48c4d78 218CLEAN = $(BINS) $(WINBINS) $(COREOBJS) $(CMDOBJS) $(ZLIBOBJS) $(QTGUIOBJS) $(MULTIARCHOBJS) $(OBJDIR)/*.o *.moc.cpp ui/ui_overlays.h
940a2012 219
3fc4596f 220# need to assign dependancies to build these first...
5dd5bfb2 221all: lua_build $(BINS)
6658905f 222
709b784c 223all-static: LDLIBS:=-static $(LDLIBS)
fb9acd45 224all-static: proxmark3 flasher fpga_compress
f3919878 225
dc20a1f6 226proxmark3: LDLIBS+=$(LUALIB) $(QTLDLIBS)
7f9e4c25 227proxmark3: $(OBJDIR)/proxmark3.o $(COREOBJS) $(CMDOBJS) $(QTGUIOBJS) $(MULTIARCHOBJS) $(ZLIBOBJS) lualibs/usb_cmd.lua
228 $(LD) $(LDFLAGS) $(OBJDIR)/proxmark3.o $(COREOBJS) $(CMDOBJS) $(QTGUIOBJS) $(MULTIARCHOBJS) $(ZLIBOBJS) $(LDLIBS) -o $@
db917a16 229
759c16b3 230flasher: $(OBJDIR)/flash.o $(OBJDIR)/flasher.o $(COREOBJS)
fb9acd45 231 $(LD) $(LDFLAGS) $^ $(LDLIBS) -o $@
46cd4046 232
f3919878 233fpga_compress: $(OBJDIR)/fpga_compress.o $(ZLIBOBJS)
fb9acd45 234 $(LD) $(LDFLAGS) $(ZLIBFLAGS) $^ $(LDLIBS) -o $@
06735128 235
5dd5bfb2 236proxgui.cpp: ui/ui_overlays.h
237
6658905f 238proxguiqt.moc.cpp: proxguiqt.h
239 $(MOC) -o$@ $^
240
3fc4596f 241ui/ui_overlays.h: ui/overlays.ui
242 $(UIC) $^ > $@
27882d37 243
fb9acd45 244lualibs/usb_cmd.lua: ../include/usb_cmd.h
245 awk -f usb_cmd_h2lua.awk $^ > $@
246
6658905f 247clean:
940a2012 248 $(RM) $(CLEAN)
3a4c72fe 249 cd ../liblua && make clean
6658905f 250
bd846386 251tarbin: $(BINS)
fb9acd45 252 $(TAR) $(TARFLAGS) ../proxmark3-$(platform)-bin.tar $(BINS:%=client/%) $(WINBINS:%=client/%)
bd846386 253
806dc075 254lua_build:
30a46ed8 255 @echo Compiling liblua, using platform $(LUAPLATFORM)
256 cd ../liblua && make $(LUAPLATFORM)
806dc075 257
6658905f 258.PHONY: all clean
fb9acd45 259
c48c4d78 260$(OBJDIR)/%_NOSIMD.o : %.c $(OBJDIR)/%.d
5dd5bfb2 261 $(CC) $(DEPFLAGS) $(CFLAGS) $(HARD_SWITCH_NOSIMD) -c -o $@ $<
c48c4d78 262
263$(OBJDIR)/%_MMX.o : %.c $(OBJDIR)/%.d
5dd5bfb2 264 $(CC) $(DEPFLAGS) $(CFLAGS) $(HARD_SWITCH_MMX) -c -o $@ $<
c48c4d78 265
266$(OBJDIR)/%_SSE2.o : %.c $(OBJDIR)/%.d
5dd5bfb2 267 $(CC) $(DEPFLAGS) $(CFLAGS) $(HARD_SWITCH_SSE2) -c -o $@ $<
c48c4d78 268
269$(OBJDIR)/%_AVX.o : %.c $(OBJDIR)/%.d
5dd5bfb2 270 $(CC) $(DEPFLAGS) $(CFLAGS) $(HARD_SWITCH_AVX) -c -o $@ $<
c48c4d78 271
272$(OBJDIR)/%_AVX2.o : %.c $(OBJDIR)/%.d
5dd5bfb2 273 $(CC) $(DEPFLAGS) $(CFLAGS) $(HARD_SWITCH_AVX2) -c -o $@ $<
c48c4d78 274
275$(OBJDIR)/%_AVX512.o : %.c $(OBJDIR)/%.d
5dd5bfb2 276 $(CC) $(DEPFLAGS) $(CFLAGS) $(HARD_SWITCH_AVX512) -c -o $@ $<
c48c4d78 277
fb9acd45 278%.o: %.c
279$(OBJDIR)/%.o : %.c $(OBJDIR)/%.d
280 $(CC) $(DEPFLAGS) $(CFLAGS) $(ZLIBFLAGS) -c -o $@ $<
281 $(POSTCOMPILE)
282
283%.o: %.cpp
284$(OBJDIR)/%.o : %.cpp $(OBJDIR)/%.d
3472ebe5 285 $(CXX) $(DEPFLAGS) $(CXXFLAGS) $(QTINCLUDES) -c -o $@ $<
fb9acd45 286 $(POSTCOMPILE)
287
288
289#$(CMDOBJS) $(COREOBJS): $(notdir $(%.c)) %.d
290# $(CC) $(DEPFLAGS) $(CFLAGS) -c -o $@ $<
291# $(POSTCOMPILE)
292
293#$(ZLIBOBJS): $(notdir $(%.c)) %.d
294# $(CC) $(DEPFLAGS) $(CFLAGS) $(ZLIBFLAGS) -c -o $@ $<
295# $(POSTCOMPILE)
296
297#$(QTGUIOBJS): $(notdir $(%.cpp)) %.d
298# $(CXX) $(DEPFLAGS) $(CXXFLAGS) -c -o $@ $<
299# $(POSTCOMPILE)
300
1985eb7c 301DEPENDENCY_FILES = $(patsubst %.c, $(OBJDIR)/%.d, $(CORESRCS) $(CMDSRCS) $(ZLIBSRCS) $(MULTIARCHSRCS)) \
fb9acd45 302 $(patsubst %.cpp, $(OBJDIR)/%.d, $(QTGUISRCS)) \
303 $(OBJDIR)/proxmark3.d $(OBJDIR)/flash.d $(OBJDIR)/flasher.d $(OBJDIR)/fpga_compress.d
304
305$(DEPENDENCY_FILES): ;
306.PRECIOUS: $(DEPENDENCY_FILES)
307
308-include $(DEPENDENCY_FILES)
309
Impressum, Datenschutz