X-Git-Url: http://cvs.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/70b1a685433e39f7d9715d5321a4464eecf68733..f9a6e84c56dcf9d200b29f30158f085239552257:/Makefile?ds=sidebyside diff --git a/Makefile b/Makefile index ae8e12c4..1ab83f9e 100644 --- a/Makefile +++ b/Makefile @@ -1,38 +1,73 @@ -include common/Makefile.common +GZIP=gzip +# Windows' echo echos its input verbatim, on Posix there is some +# amount of shell command line parsing going on. echo "" on +# Windows yields literal "", on Linux yields an empty line +ifeq ($(shell echo ""),) +# This is probably a proper system, so we can use uname +DELETE=rm -rf +FLASH_TOOL=client/flasher +platform=$(shell uname) +ifneq (,$(findstring MINGW,$(platform))) +FLASH_PORT=com3 +PATHSEP=\\# +else +FLASH_PORT=/dev/ttyACM0 +PATHSEP=/ +endif +else +# Assume that we are running on native Windows +DELETE=del /q +FLASH_TOOL=client/flasher.exe +platform=Windows +FLASH_PORT=com3 +PATHSEP=\\# +endif -all clean: %: bootrom/% armsrc/% client/% +all clean: %: client/% bootrom/% armsrc/% recovery/% mfkey/% bootrom/%: FORCE - $(MAKE) -C bootrom $(patsubst bootrom/%,%,$@) + $(MAKE) -C bootrom $(patsubst bootrom/%, %, $@) armsrc/%: FORCE - $(MAKE) -C armsrc $(patsubst armsrc/%,%,$@) + $(MAKE) -C armsrc $(patsubst armsrc/%, %, $@) client/%: FORCE - $(MAKE) -C client $(patsubst client/%,%,$@) + $(MAKE) -C client $(patsubst client/%, %, $@) +recovery/%: FORCE + $(MAKE) -C recovery $(patsubst recovery/%, %, $@) +mfkey/%: FORCE + $(MAKE) -C tools/mfkey $(patsubst mfkey/%, %, $@) FORCE: # Dummy target to force remake in the subdirectories, even if files exist (this Makefile doesn't know about the prerequisites) +.PHONY: all clean help _test flash-bootrom flash-os flash-all FORCE -.PHONY: all clean help _test flash-bootrom flash-os flash-both flash-all FORCE help: @echo Multi-OS Makefile, you are running on $(DETECTED_OS) @echo Possible targets: @echo + all - Make bootrom, armsrc and the OS-specific host directory + @echo + client - Make only the OS-specific host directory @echo + flash-bootrom - Make bootrom and flash it - @echo + flash-os - Make armsrc and flash os - @echo + flash-both - Make armsrc and flash os and fpga image - @echo + flash-all - Make bootrom and armsrc and flash bootrom, os and fpga image + @echo + flash-os - Make armsrc and flash os \(includes fpga\) + @echo + flash-all - Make bootrom and armsrc and flash bootrom and os image @echo + clean - Clean in bootrom, armsrc and the OS-specific host directory +client: client/all + +mfkey: mfkey/all + flash-bootrom: bootrom/obj/bootrom.elf $(FLASH_TOOL) - $(FLASH_TOOL) bootrom $(subst /,$(PATHSEP),$<) + $(FLASH_TOOL) $(FLASH_PORT) -b $(subst /,$(PATHSEP),$<) + +flash-os: armsrc/obj/fullimage.elf $(FLASH_TOOL) + $(FLASH_TOOL) $(FLASH_PORT) $(subst /,$(PATHSEP),$<) -flash-os: armsrc/obj/osimage.elf $(FLASH_TOOL) - $(FLASH_TOOL) os $(subst /,$(PATHSEP),$<) +flash-all: bootrom/obj/bootrom.elf armsrc/obj/fullimage.elf $(FLASH_TOOL) + $(FLASH_TOOL) $(FLASH_PORT) -b $(subst /,$(PATHSEP),$(filter-out $(FLASH_TOOL),$^)) -flash-both: armsrc/obj/osimage.elf armsrc/obj/fpgaimage.elf $(FLASH_TOOL) - $(FLASH_TOOL) os,fpga $(subst /,$(PATHSEP),$(filter-out $(FLASH_TOOL),$^)) +newtarbin: + $(DELETE) proxmark3-$(platform)-bin.tar proxmark3-$(platform)-bin.tar.gz + @touch proxmark3-$(platform)-bin.tar -flash-all: bootrom/obj/bootrom.elf armsrc/obj/osimage.elf armsrc/obj/fpgaimage.elf $(FLASH_TOOL) - $(FLASH_TOOL) bootrom,os,fpga $(subst /,$(PATHSEP),$(filter-out $(FLASH_TOOL),$^)) +tarbin: newtarbin client/tarbin armsrc/tarbin bootrom/tarbin + $(GZIP) proxmark3-$(platform)-bin.tar # Dummy target to test for GNU make availability _test: