X-Git-Url: https://www.flypig.org.uk/git/?a=blobdiff_plain;f=src%2FMakefile;h=182bdfad33baec76172d32769f212f4128c16e47;hb=aa78cf2c744c086c7cc6f5f54a9ead10cc42ee6b;hp=7c789f39e61d0cf6b991c3cfeaf78c2756e93dce;hpb=e2412c9b108abddef96f62860b46cc85d58cd780;p=hashcat.git diff --git a/src/Makefile b/src/Makefile index 7c789f3..182bdfa 100644 --- a/src/Makefile +++ b/src/Makefile @@ -1,69 +1,71 @@ ## -## Author......: Jens Steube +## Authors.....: Jens Steube +## Gabriele Gristina +## magnum +## ## License.....: MIT ## +PROG_NAME := hashcat + ## -## Detect number of processors +## Detect Operating System ## -NPROCS := $(shell grep -c ^processor /proc/cpuinfo) -OS := $(shell uname) +UNAME := $(shell uname -s) + +# we need to strip the windows version number to be able to build hashcat on cygwin hosts +UNAME := $(patsubst CYGWIN_NT-%,CYGWIN_NT-,$(UNAME)) + +ifeq (,$(filter $(UNAME),Linux Darwin CYGWIN_NT-)) +$(error "! Your Operating System ($(UNAME)) is not supported by $(PROG_NAME) Makefile") +endif + +ifeq ($(DEBUG),1) +$(warning "## Detected Operating System : $(UNAME)") +endif ## ## Makefile flags ## -MAKEFLAGS += -l -j $(NPROCS) -rR --no-print-directory +MAKEFLAGS += -l -j -rR --no-print-directory ifneq ($(findstring clean,$(MAKECMDGOALS)),) -MAKEFLAGS += -j 1 +MAKEFLAGS += -j 1 endif ## ## Installation paths (Linux only) ## -INSTALL_FOLDER ?= /opt/test/usr/bin -SHARED_FOLDER ?= /opt/test/usr/share/oclHashcat -DOCUMENT_FOLDER ?= /opt/test/usr/share/doc/oclHashcat +DESTDIR ?= +PREFIX ?= /usr/local -#INSTALL_FOLDER ?= /usr/bin -#SHARED_FOLDER ?= /usr/share/oclHashcat -#DOCUMENT_FOLDER ?= /usr/share/doc/oclHashcat +INSTALL_FOLDER ?= $(PREFIX)/bin +SHARED_FOLDER ?= $(PREFIX)/share/$(PROG_NAME) +DOCUMENT_FOLDER ?= $(PREFIX)/share/doc/$(PROG_NAME) ## -## Main SDK +## Dependencies +## You may ignore them if you're compiling only a native binary and +## You have your own headers somewhere, for example: apt-get install opencl-headers ## -FORCEWARELIBPATH32 := deps/NVIDIA-Linux-x86_64-352.21/32 -FORCEWARELIBPATH64 := deps/NVIDIA-Linux-x86_64-352.21 - -AMDAPP := deps/amd-app-sdk -AMDAPPLIBPATH32 := $(AMDAPP)/lib/x86 -AMDAPPLIBPATH64 := $(AMDAPP)/lib/x86_64 - -ADL := deps/adl-sdk -GDK := deps/nvidia-gdk -NVAPI := deps/R352-developer +OPENCL_HEADERS_KHRONOS := deps/OpenCL-Headers ## -## Library paths +## Native compiler paths ## -OCL := $(AMDAPP) -OCLLIBPATH32 := $(AMDAPPLIBPATH32) -OCLLIBPATH64 := $(AMDAPPLIBPATH64) - -NVML := $(GDK)/usr/include/nvidia/gdk -NVMLLIBPATH32 := $(FORCEWARELIBPATH32) -NVMLLIBPATH64 := $(FORCEWARELIBPATH64) - -CLCOMPILE_PATH := tools/clcompile -RULES_OPTIMIZE_PATH := tools/rules_optimize +CC := gcc +FIND := find +INSTALL := install +RM := rm +SED := sed ## -## Compiler paths +## Cross compiler paths ## CC_LINUX_32 := gcc @@ -72,141 +74,203 @@ CC_LINUX_64 := gcc CC_WIN_32 := i686-w64-mingw32-gcc CC_WIN_64 := x86_64-w64-mingw32-gcc -DLL_WIN_32 := i686-w64-mingw32-dlltool -DLL_WIN_64 := x86_64-w64-mingw32-dlltool - -CLCOMPILE := $(CLCOMPILE_PATH)/clcompile.bin - -BIN := . - -INSTALL := install -CP := cp - ## ## Misc stuff ## -NOW := $(shell perl -e 'print time') +COMPTIME := $(shell date +%s) + +VERSION_EXPORT := $Format:%D$ +VERSION_TAG := $(shell test -d .git && git describe --tags --dirty=+ || echo "$(VERSION_EXPORT)"|cut -d, -f2|sed -r 's|.* (\w+/)?([^ ]+)|\2|') ## ## Compiler flags ## -CFLAGS := -O2 -s -pipe -W -Wall -Iinclude/ -std=c99 -#CFLAGS := -g -pipe -W -Wall -Iinclude/ -std=c99 +CFLAGS := -pipe -W -Wall -std=c99 -Iinclude/ -IOpenCL/ -I$(OPENCL_HEADERS_KHRONOS)/ -CFLAGS_32 := -m32 -CFLAGS_64 := -m64 +ifndef DEBUG +CFLAGS += -O2 +else +CFLAGS += -DDEBUG -g -ggdb +ifeq ($(DEBUG),2) +CFLAGS += -fsanitize=address -fno-omit-frame-pointer +endif +endif -CFLAGS_LINUX := -D_POSIX -DLINUX -CFLAGS_WIN := -D_WIN -DWIN -D__MSVCRT__ -D__USE_MINGW_ANSI_STDIO=1 +## +## Native compilation target +## -CFLAGS_LINUX += -I$(OCL)/include/ -I$(ADL)/include/ -I$(NVML)/ -CFLAGS_WIN += -I$(OCL)/include/ -I$(ADL)/include/ -I$(NVAPI)/ +BINARY_NATIVE := $(PROG_NAME) -LFLAGS_LINUX := -lpthread -lOpenCL -ldl -LFLAGS_WIN := -lpsapi +ifeq ($(UNAME),Darwin) +export MACOSX_DEPLOYMENT_TARGET=10.9 +BINARY_NATIVE := $(BINARY_NATIVE).app +CFLAGS_NATIVE := -D_POSIX -DOSX +CFLAGS_NATIVE += $(CFLAGS) +LFLAGS_NATIVE := -lpthread +endif # darwin + +ifeq ($(UNAME),Linux) +CFLAGS_NATIVE := -D_POSIX -DLINUX +ifndef DEBUG +CFLAGS_NATIVE += -s +endif +CFLAGS_NATIVE += $(CFLAGS) +LFLAGS_NATIVE := -lpthread -ldl +CFLAGS_NATIVE += -DHAVE_HWMON +endif # linux ## -## Targets: Global +## Cross compilation target ## -all: binaries_all +CFLAGS_CROSS_LINUX := -D_POSIX -DLINUX +ifndef DEBUG +CFLAGS_CROSS_LINUX += -s +endif +CFLAGS_CROSS_LINUX += $(CFLAGS) +CFLAGS_CROSS_LINUX += -DHAVE_HWMON + +CFLAGS_CROSS_WIN := -D_WIN -DWIN -D__MSVCRT__ -D__USE_MINGW_ANSI_STDIO=1 +ifndef DEBUG +CFLAGS_CROSS_WIN += -s +endif +CFLAGS_CROSS_WIN += $(filter-out -fsanitize=address,$(CFLAGS)) +CFLAGS_CROSS_WIN += -DHAVE_HWMON + +CFLAGS_CROSS_32 := -m32 +CFLAGS_CROSS_64 := -m64 -binaries_all: linux32 linux64 win32 win64 rules_optimize +LFLAGS_CROSS_LINUX := -lpthread -ldl +LFLAGS_CROSS_WIN := -lpsapi -release: binaries +## +## Objects +## -linux: linux32 linux64 rules_optimize +NATIVE_OBJS := obj/ext_OpenCL.NATIVE.o obj/shared.NATIVE.o obj/rp_kernel_on_cpu.NATIVE.o -windows: win32 win64 rules_optimize +ifeq ($(UNAME),Linux) +NATIVE_OBJS += obj/ext_ADL.NATIVE.o +NATIVE_OBJS += obj/ext_nvapi.NATIVE.o +NATIVE_OBJS += obj/ext_nvml.NATIVE.o +endif -clean: clean_bin +LINUX_32_OBJS := obj/ext_OpenCL.LINUX.32.o obj/shared.LINUX.32.o obj/rp_kernel_on_cpu.LINUX.32.o obj/ext_ADL.LINUX.32.o obj/ext_nvml.LINUX.32.o obj/ext_nvapi.LINUX.32.o +LINUX_64_OBJS := obj/ext_OpenCL.LINUX.64.o obj/shared.LINUX.64.o obj/rp_kernel_on_cpu.LINUX.64.o obj/ext_ADL.LINUX.64.o obj/ext_nvml.LINUX.64.o obj/ext_nvapi.LINUX.64.o -clean_all: clean_bin clean_clcompile +## may need to adjust according to your mingw distribution +CRT_GLOB_32 := /usr/i686-w64-mingw32/lib/CRT_glob.o +CRT_GLOB_64 := /usr/x86_64-w64-mingw32/lib/CRT_glob.o -clean_bin: - rm -f obj/*.o lib/*.a $(BIN)/*.bin $(BIN)/*.exe $(BIN)/*.app *.restore *.out *.pot *.dictstat *.log - rm -rf *Hashcat.induct - rm -rf *Hashcat.outfiles - $(MAKE) -C $(RULES_OPTIMIZE_PATH) clean +WIN_32_OBJS := obj/ext_OpenCL.WIN.32.o obj/shared.WIN.32.o obj/rp_kernel_on_cpu.WIN.32.o obj/ext_ADL.WIN.32.o obj/ext_nvml.WIN.32.o obj/ext_nvapi.WIN.32.o $(CRT_GLOB_32) +WIN_64_OBJS := obj/ext_OpenCL.WIN.64.o obj/shared.WIN.64.o obj/rp_kernel_on_cpu.WIN.64.o obj/ext_ADL.WIN.64.o obj/ext_nvml.WIN.64.o obj/ext_nvapi.WIN.64.o $(CRT_GLOB_64) -clean_clcompile: - rm -f ${CLCOMPILE_PATH}/clcompile.bin +## +## Targets: Global +## -${CLCOMPILE}: ${CLCOMPILE_PATH}/clcompile.c - $(CC_LINUX_64) $(CFLAGS) -o $@ -I$(CFLAGS_LINUX) $< -L$(OCLLIBPATH64) $(LFLAGS_LINUX) +native: hashcat -rules_optimize: - $(MAKE) -C $(RULES_OPTIMIZE_PATH) +binaries: linux32 linux64 win32 win64 -linux32: oclHashcat32.bin -linux64: oclHashcat64.bin +clean: + $(RM) -f obj/*.o *.bin *.exe *.app *.restore *.out *.pot *.dictstat *.log hashcat core + $(RM) -rf *.induct + $(RM) -rf *.outfiles + $(RM) -rf *.dSYM + $(RM) -rf kernels -win32: oclHashcat32.exe -win64: oclHashcat64.exe +linux32: hashcat32.bin +linux64: hashcat64.bin + +win32: hashcat32.exe +win64: hashcat64.exe ## ## Targets: Linux install -## We need some better native compilation logic here, fixing it to 64 bit for now and AMD kernels ## How to make /usr/bin/install doing recursive?? ## -install: linux64 amd_all - $(INSTALL) -m 755 -d $(DOCUMENT_FOLDER) - $(CP) -a docs/* $(DOCUMENT_FOLDER)/ - $(INSTALL) -m 755 -d $(DOCUMENT_FOLDER)/extra - $(CP) -a extra/* $(DOCUMENT_FOLDER)/extra/ - $(INSTALL) -m 755 -d $(SHARED_FOLDER) - $(INSTALL) -m 755 -d $(SHARED_FOLDER)/charsets - $(CP) -a charsets/* $(SHARED_FOLDER)/charsets/ - $(INSTALL) -m 755 -d $(SHARED_FOLDER)/masks - $(CP) -a masks/* $(SHARED_FOLDER)/masks/ - $(INSTALL) -m 755 -d $(SHARED_FOLDER)/rules - $(CP) -a rules/* $(SHARED_FOLDER)/rules/ - $(INSTALL) -m 755 -T hashcat.hcstat $(SHARED_FOLDER)/hashcat.hcstat - $(INSTALL) -m 755 -s -T oclHashcat64.bin $(INSTALL_FOLDER)/oclHashcat - +install: native + $(INSTALL) -m 755 -d $(DESTDIR)$(DOCUMENT_FOLDER) + $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER) + $(INSTALL) -m 755 -d $(DESTDIR)$(INSTALL_FOLDER) + $(INSTALL) -m 755 -d $(DESTDIR)$(DOCUMENT_FOLDER)/docs + $(INSTALL) -m 755 -d $(DESTDIR)$(DOCUMENT_FOLDER)/extra + $(INSTALL) -m 755 -d $(DESTDIR)$(DOCUMENT_FOLDER)/extra/tab_completion + $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER)/charsets + $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER)/masks + $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER)/OpenCL + $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER)/rules + $(INSTALL) -m 644 example.dict $(DESTDIR)$(DOCUMENT_FOLDER)/ + $(INSTALL) -m 644 example0.hash $(DESTDIR)$(DOCUMENT_FOLDER)/ + $(INSTALL) -m 644 example400.hash $(DESTDIR)$(DOCUMENT_FOLDER)/ + $(INSTALL) -m 644 example500.hash $(DESTDIR)$(DOCUMENT_FOLDER)/ + $(INSTALL) -m 755 example0.sh $(DESTDIR)$(DOCUMENT_FOLDER)/ + $(INSTALL) -m 755 example400.sh $(DESTDIR)$(DOCUMENT_FOLDER)/ + $(INSTALL) -m 755 example500.sh $(DESTDIR)$(DOCUMENT_FOLDER)/ + $(INSTALL) -m 644 extra/tab_completion/hashcat.sh $(DESTDIR)$(DOCUMENT_FOLDER)/extra/tab_completion/ + $(INSTALL) -m 644 extra/tab_completion/howto.txt $(DESTDIR)$(DOCUMENT_FOLDER)/extra/tab_completion/ + $(INSTALL) -m 755 extra/tab_completion/install $(DESTDIR)$(DOCUMENT_FOLDER)/extra/tab_completion/ + $(INSTALL) -m 644 hashcat.hcstat $(DESTDIR)$(SHARED_FOLDER)/ + $(INSTALL) -m 644 hashcat.hctune $(DESTDIR)$(SHARED_FOLDER)/ + $(INSTALL) -m 755 $(BINARY_NATIVE) $(DESTDIR)$(INSTALL_FOLDER)/ + $(FIND) docs/ -type d -exec $(INSTALL) -m 755 -d $(DESTDIR)$(DOCUMENT_FOLDER)/{} \; + $(FIND) charsets/ -type d -exec $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER)/{} \; + $(FIND) masks/ -type d -exec $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER)/{} \; + $(FIND) OpenCL/ -type d -exec $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER)/{} \; + $(FIND) rules/ -type d -exec $(INSTALL) -m 755 -d $(DESTDIR)$(SHARED_FOLDER)/{} \; + $(FIND) docs/ -type f -exec $(INSTALL) -m 644 {} $(DESTDIR)$(DOCUMENT_FOLDER)/{} \; + $(FIND) charsets/ -type f -exec $(INSTALL) -m 644 {} $(DESTDIR)$(SHARED_FOLDER)/{} \; + $(FIND) masks/ -type f -exec $(INSTALL) -m 644 {} $(DESTDIR)$(SHARED_FOLDER)/{} \; + $(FIND) OpenCL/ -type f -exec $(INSTALL) -m 644 {} $(DESTDIR)$(SHARED_FOLDER)/{} \; + $(FIND) rules/ -type f -exec $(INSTALL) -m 644 {} $(DESTDIR)$(SHARED_FOLDER)/{} \; + $(SED) -i 's/\.\/hashcat/hashcat/' $(DESTDIR)$(DOCUMENT_FOLDER)/example0.sh + $(SED) -i 's/\.\/hashcat/hashcat/' $(DESTDIR)$(DOCUMENT_FOLDER)/example400.sh + $(SED) -i 's/\.\/hashcat/hashcat/' $(DESTDIR)$(DOCUMENT_FOLDER)/example500.sh uninstall: - $(RM) -f $(INSTALL_FOLDER)/oclHashcat - $(RM) -rf $(SHARED_FOLDER) - $(RM) -rf $(DOCUMENT_FOLDER) + $(RM) -f $(DESTDIR)$(INSTALL_FOLDER)/$(BINARY_NATIVE) + $(RM) -rf $(DESTDIR)$(SHARED_FOLDER) + $(RM) -rf $(DESTDIR)$(DOCUMENT_FOLDER) ## -## Targets: Libraries +## native compiled hashcat ## -lib/libOpenCL.a: - ${DLL_WIN_32} -A -k -l lib/libOpenCL.a -d lib/OpenCL.def +obj/%.NATIVE.o: src/%.c + $(CC) $(CFLAGS_NATIVE) -c -o $@ $< -lib/libOpenCL64.a: - ${DLL_WIN_64} -A -k -l lib/libOpenCL64.a -d lib/OpenCL64.def +hashcat: src/hashcat.c $(NATIVE_OBJS) + $(CC) $(CFLAGS_NATIVE) -o $(BINARY_NATIVE) $^ $(LFLAGS_NATIVE) -DCOMPTIME=$(COMPTIME) -DVERSION_TAG=\"$(VERSION_TAG)\" -DINSTALL_FOLDER=\"$(INSTALL_FOLDER)\" -DSHARED_FOLDER=\"$(SHARED_FOLDER)\" -DDOCUMENT_FOLDER=\"$(DOCUMENT_FOLDER)\" ## -## oclHashcat +## cross compiled hashcat for binary release version ## -obj/%.oclHashcat.LINUX.32.o: src/%.c - $(CC_LINUX_32) $(CFLAGS) $(CFLAGS_LINUX) $(CFLAGS_32) -c -o $@ $< +obj/%.LINUX.32.o: src/%.c + $(CC_LINUX_32) -D_LINUX32 $(CFLAGS_CROSS_LINUX) $(CFLAGS_CROSS_32) -c -o $@ $< -obj/%.oclHashcat.LINUX.64.o: src/%.c - $(CC_LINUX_64) $(CFLAGS) $(CFLAGS_LINUX) $(CFLAGS_64) -c -o $@ $< +obj/%.LINUX.64.o: src/%.c + $(CC_LINUX_64) -D_LINUX64 $(CFLAGS_CROSS_LINUX) $(CFLAGS_CROSS_64) -c -o $@ $< -obj/%.oclHashcat.WIN.32.o: src/%.c - $(CC_WIN_32) $(CFLAGS) $(CFLAGS_WIN) $(CFLAGS_32) -c -o $@ $< +obj/%.WIN.32.o: src/%.c + $(CC_WIN_32) -D_WIN32 $(CFLAGS_CROSS_WIN) $(CFLAGS_CROSS_32) -c -o $@ $< -obj/%.oclHashcat.WIN.64.o: src/%.c - $(CC_WIN_64) $(CFLAGS) $(CFLAGS_WIN) $(CFLAGS_64) -c -o $@ $< +obj/%.WIN.64.o: src/%.c + $(CC_WIN_64) -D_WIN64 $(CFLAGS_CROSS_WIN) $(CFLAGS_CROSS_64) -c -o $@ $< -oclHashcat32.bin: src/oclHashcat.c obj/ext_OpenCL.oclHashcat.LINUX.32.o obj/ext_nvml.oclHashcat.LINUX.32.o obj/ext_ADL.oclHashcat.LINUX.32.o obj/shared.oclHashcat.LINUX.32.o obj/rp_gpu_on_cpu.oclHashcat.LINUX.32.o - $(CC_LINUX_32) $(CFLAGS) $(CFLAGS_LINUX) $(CFLAGS_32) -o $@ -DCOMPTIME=$(NOW) $^ -L$(OCLLIBPATH32) $(LFLAGS_LINUX) -DINSTALL_FOLDER=\"$(INSTALL_FOLDER)\" -DSHARED_FOLDER=\"$(SHARED_FOLDER)\" -DDOCUMENT_FOLDER=\"$(DOCUMENT_FOLDER)\" +hashcat32.bin: src/hashcat.c $(LINUX_32_OBJS) + $(CC_LINUX_32) -D_LINUX32 $(CFLAGS_CROSS_LINUX) $(CFLAGS_CROSS_32) -o $@ $^ $(LFLAGS_CROSS_LINUX) -DCOMPTIME=$(COMPTIME) -DVERSION_TAG=\"$(VERSION_TAG)\" -DINSTALL_FOLDER=\"$(INSTALL_FOLDER)\" -DSHARED_FOLDER=\"$(SHARED_FOLDER)\" -DDOCUMENT_FOLDER=\"$(DOCUMENT_FOLDER)\" -oclHashcat64.bin: src/oclHashcat.c obj/ext_OpenCL.oclHashcat.LINUX.64.o obj/ext_nvml.oclHashcat.LINUX.64.o obj/ext_ADL.oclHashcat.LINUX.64.o obj/shared.oclHashcat.LINUX.64.o obj/rp_gpu_on_cpu.oclHashcat.LINUX.64.o - $(CC_LINUX_64) $(CFLAGS) $(CFLAGS_LINUX) $(CFLAGS_64) -o $@ -DCOMPTIME=$(NOW) $^ -L$(OCLLIBPATH64) $(LFLAGS_LINUX) -DINSTALL_FOLDER=\"$(INSTALL_FOLDER)\" -DSHARED_FOLDER=\"$(SHARED_FOLDER)\" -DDOCUMENT_FOLDER=\"$(DOCUMENT_FOLDER)\" +hashcat64.bin: src/hashcat.c $(LINUX_64_OBJS) + $(CC_LINUX_64) -D_LINUX64 $(CFLAGS_CROSS_LINUX) $(CFLAGS_CROSS_64) -o $@ $^ $(LFLAGS_CROSS_LINUX) -DCOMPTIME=$(COMPTIME) -DVERSION_TAG=\"$(VERSION_TAG)\" -DINSTALL_FOLDER=\"$(INSTALL_FOLDER)\" -DSHARED_FOLDER=\"$(SHARED_FOLDER)\" -DDOCUMENT_FOLDER=\"$(DOCUMENT_FOLDER)\" -oclHashcat32.exe: src/oclHashcat.c obj/ext_OpenCL.oclHashcat.WIN.32.o obj/ext_nvapi.oclHashcat.WIN.32.o obj/ext_ADL.oclHashcat.WIN.32.o obj/shared.oclHashcat.WIN.32.o obj/rp_gpu_on_cpu.oclHashcat.WIN.32.o lib/libOpenCL.a /usr/i686-w64-mingw32/lib/CRT_glob.o $(NVAPI)/x86/nvapi.lib - $(CC_WIN_32) $(CFLAGS) $(CFLAGS_WIN) $(CFLAGS_32) -o $@ -DCOMPTIME=$(NOW) $^ -L$(OCLLIBPATH32) $(LFLAGS_WIN) -static-libgcc +hashcat32.exe: src/hashcat.c $(WIN_32_OBJS) + $(CC_WIN_32) -D_WIN32 $(CFLAGS_CROSS_WIN) $(CFLAGS_CROSS_32) -o $@ $^ $(LFLAGS_CROSS_WIN) -DCOMPTIME=$(COMPTIME) -DVERSION_TAG=\"$(VERSION_TAG)\" -static-libgcc -oclHashcat64.exe: src/oclHashcat.c obj/ext_OpenCL.oclHashcat.WIN.64.o obj/ext_nvapi.oclHashcat.WIN.64.o obj/ext_ADL.oclHashcat.WIN.64.o obj/shared.oclHashcat.WIN.64.o obj/rp_gpu_on_cpu.oclHashcat.WIN.64.o lib/libOpenCL64.a /usr/x86_64-w64-mingw32/lib/CRT_glob.o $(NVAPI)/amd64/nvapi64.lib - $(CC_WIN_64) $(CFLAGS) $(CFLAGS_WIN) $(CFLAGS_64) -o $@ -DCOMPTIME=$(NOW) $^ -L$(OCLLIBPATH64) $(LFLAGS_WIN) -static-libgcc +hashcat64.exe: src/hashcat.c $(WIN_64_OBJS) + $(CC_WIN_64) -D_WIN64 $(CFLAGS_CROSS_WIN) $(CFLAGS_CROSS_64) -o $@ $^ $(LFLAGS_CROSS_WIN) -DCOMPTIME=$(COMPTIME) -DVERSION_TAG=\"$(VERSION_TAG)\" -static-libgcc