X-Git-Url: https://www.flypig.org.uk/git/?a=blobdiff_plain;f=src%2FMakefile;h=4e4da2d887f05901a314f1c10cc858d31318b607;hb=51e1d11b2d6dff4ae331cff6098169455733c412;hp=8da8b1f6640219f3c0ad18b0127dc4aa84fbb595;hpb=829289b10980ce34089998d2decf5bb151b54fa0;p=hashcat.git diff --git a/src/Makefile b/src/Makefile index 8da8b1f..4e4da2d 100644 --- a/src/Makefile +++ b/src/Makefile @@ -14,7 +14,10 @@ PROG_NAME := hashcat UNAME := $(shell uname -s) -ifeq (,$(filter $(UNAME),Linux Darwin)) +# 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- FreeBSD)) $(error "! Your Operating System ($(UNAME)) is not supported by $(PROG_NAME) Makefile") endif @@ -36,6 +39,7 @@ endif ## Installation paths (Linux only) ## +DESTDIR ?= PREFIX ?= /usr/local INSTALL_FOLDER ?= $(PREFIX)/bin @@ -44,7 +48,8 @@ DOCUMENT_FOLDER ?= $(PREFIX)/share/doc/$(PROG_NAME) ## ## Dependencies -## You may ignore them if you have your own headers somewhere +## 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 ## OPENCL_HEADERS_KHRONOS := deps/OpenCL-Headers @@ -53,11 +58,18 @@ OPENCL_HEADERS_KHRONOS := deps/OpenCL-Headers ## Native compiler paths ## -CP := cp -RM := rm +CC := gcc +FIND := find INSTALL := install - -CC_NATIVE := gcc +RM := rm +SED := sed +ifeq ($(UNAME),Darwin) +SED := gsed +endif +ifeq ($(UNAME),FreeBSD) +CC := cc +SED := gsed +endif ## ## Cross compiler paths @@ -74,14 +86,15 @@ CC_WIN_64 := x86_64-w64-mingw32-gcc ## 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|') +VERSION_TAG := $(shell test -d .git && git describe --tags --dirty=+ || echo "$(VERSION_EXPORT)"|cut -d, -f2|$(SED) -r 's|.* (\w+/)?([^ ]+)|\2|') ## ## Compiler flags ## -CFLAGS := -pipe -W -Wall -std=c99 -Iinclude/ -IOpenCL/ -I$(OPENCL_HEADERS_KHRONOS)/ +CFLAGS += -pipe -W -Wall -std=c99 -Iinclude/ -IOpenCL/ -I$(OPENCL_HEADERS_KHRONOS)/ ifndef DEBUG CFLAGS += -O2 @@ -100,41 +113,45 @@ BINARY_NATIVE := $(PROG_NAME) ifeq ($(UNAME),Darwin) export MACOSX_DEPLOYMENT_TARGET=10.9 -BINARY_NATIVE := $(BINARY_NATIVE).app -CFLAGS_NATIVE := -D_POSIX -DOSX +CFLAGS_NATIVE := -D_POSIX CFLAGS_NATIVE += $(CFLAGS) LFLAGS_NATIVE := -lpthread +LFLAGS_NATIVE += $(LDFLAGS) endif # darwin ifeq ($(UNAME),Linux) -CFLAGS_NATIVE := -D_POSIX -DLINUX +CFLAGS_NATIVE := -D_POSIX ifndef DEBUG CFLAGS_NATIVE += -s endif CFLAGS_NATIVE += $(CFLAGS) LFLAGS_NATIVE := -lpthread -ldl CFLAGS_NATIVE += -DHAVE_HWMON +LFLAGS_NATIVE += $(LDFLAGS) endif # linux +ifeq ($(UNAME),FreeBSD) +CFLAGS_NATIVE := -D_POSIX +CFLAGS_NATIVE += $(CFLAGS) +LFLAGS_NATIVE := -lpthread +LFLAGS_NATIVE += $(LDFLAGS) +endif # freebsd + ## ## Cross compilation target ## -CFLAGS_CROSS_LINUX := -D_POSIX -DLINUX - +CFLAGS_CROSS_LINUX := -D_POSIX 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 @@ -154,14 +171,19 @@ ifeq ($(UNAME),Linux) NATIVE_OBJS += obj/ext_ADL.NATIVE.o NATIVE_OBJS += obj/ext_nvapi.NATIVE.o NATIVE_OBJS += obj/ext_nvml.NATIVE.o +NATIVE_OBJS += obj/ext_xnvctrl.NATIVE.o endif -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 +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 obj/ext_xnvctrl.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 obj/ext_xnvctrl.LINUX.64.o + +## 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 + +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 obj/ext_xnvctrl.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 obj/ext_xnvctrl.WIN.64.o $(CRT_GLOB_64) -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 -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 - ## ## Targets: Global ## @@ -171,7 +193,7 @@ native: hashcat binaries: linux32 linux64 win32 win64 clean: - $(RM) -f obj/*.o *.bin *.exe *.app *.restore *.out *.pot *.dictstat *.log hashcat core + $(RM) -f obj/*.o *.bin *.exe *.restore *.out *.pot *.log hashcat core $(RM) -rf *.induct $(RM) -rf *.outfiles $(RM) -rf *.dSYM @@ -189,45 +211,57 @@ win64: hashcat64.exe ## install: native - $(INSTALL) -m 755 -d $(DOCUMENT_FOLDER) - $(CP) -a docs/* $(DOCUMENT_FOLDER)/ - $(CP) -a example*.sh $(DOCUMENT_FOLDER)/ - $(CP) -a example*.hash $(DOCUMENT_FOLDER)/ - $(INSTALL) -m 644 example.dict $(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)/include - $(INSTALL) -m 644 include/constants.h $(SHARED_FOLDER)/include/ - $(INSTALL) -m 644 include/kernel_functions.c $(SHARED_FOLDER)/include/ - $(INSTALL) -m 644 include/kernel_vendor.h $(SHARED_FOLDER)/include/ - $(INSTALL) -m 644 include/rp_kernel.h $(SHARED_FOLDER)/include/ - $(INSTALL) -m 755 -d $(SHARED_FOLDER)/OpenCL - $(CP) -a OpenCL/* $(SHARED_FOLDER)/OpenCL/ - $(INSTALL) -m 755 -d $(SHARED_FOLDER)/rules - $(CP) -a rules/* $(SHARED_FOLDER)/rules/ - $(INSTALL) -m 644 hashcat.hcstat $(SHARED_FOLDER)/ - $(INSTALL) -m 644 hashcat.hctune $(SHARED_FOLDER)/ - $(INSTALL) -m 755 $(BINARY_NATIVE) $(INSTALL_FOLDER)/ + $(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)/$(BINARY_NATIVE) - $(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) ## ## native compiled hashcat ## obj/%.NATIVE.o: src/%.c - $(CC_NATIVE) $(CFLAGS_NATIVE) -c -o $@ $< + $(CC) $(CFLAGS_NATIVE) -c -o $@ $< hashcat: src/hashcat.c $(NATIVE_OBJS) - $(CC_NATIVE) $(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)\" + $(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)\" ## ## cross compiled hashcat for binary release version @@ -240,10 +274,10 @@ obj/%.LINUX.64.o: src/%.c $(CC_LINUX_64) -D_LINUX64 $(CFLAGS_CROSS_LINUX) $(CFLAGS_CROSS_64) -c -o $@ $< obj/%.WIN.32.o: src/%.c - $(CC_WIN_32) -D_WIN32 $(CFLAGS_CROSS_WIN) $(CFLAGS_CROSS_32) -c -o $@ $< + $(CC_WIN_32) -D_WIN32 $(CFLAGS_CROSS_WIN) $(CFLAGS_CROSS_32) -c -o $@ $< obj/%.WIN.64.o: src/%.c - $(CC_WIN_64) -D_WIN64 $(CFLAGS_CROSS_WIN) $(CFLAGS_CROSS_64) -c -o $@ $< + $(CC_WIN_64) -D_WIN64 $(CFLAGS_CROSS_WIN) $(CFLAGS_CROSS_64) -c -o $@ $< 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)\"