]> git.zerfleddert.de Git - proxmark3-svn/blame - bootrom/Makefile
Merge pull request #89 from angelsl/mfsetmod
[proxmark3-svn] / bootrom / Makefile
CommitLineData
bd20f8f4 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#-----------------------------------------------------------------------------
15c4dc5a 6# Makefile for bootrom, see ../common/Makefile.common for common settings
bd20f8f4 7#-----------------------------------------------------------------------------
15c4dc5a 8
9# DO NOT use thumb mode in the phase 1 bootloader since that generates a section with glue code
86d31955 10ARMSRC =
0de8e387 11THUMBSRC = cmd.c \
12 usb_cdc.c \
13 bootrom.c
15c4dc5a 14ASMSRC = ram-reset.s flash-reset.s
15
16## There is a strange bug with the linker: Sometimes it will not emit the glue to call
17## BootROM from ARM mode. The symbol is emitted, but the section will be filled with
18## zeroes. As a temporary workaround, do not use thumb for the phase 2 bootloader
19## -- Henryk Plötz <henryk@ploetzli.ch> 2009-09-01
28fdb04f 20# ARMSRC := $(ARMSRC) $(THUMBSRC)
21# THUMBSRC :=
15c4dc5a 22
23# stdint.h provided locally until GCC 4.5 becomes C99 compliant
9932c55a 24APP_CFLAGS = -I. -fno-strict-aliasing -ffunction-sections -fdata-sections
15c4dc5a 25
26# Do not move this inclusion before the definition of {THUMB,ASM,ARM}SRC
27include ../common/Makefile.common
28
bd846386 29OBJS = $(OBJDIR)/bootrom.s19
30
31all: $(OBJS)
32
33tarbin: $(OBJS)
34 $(TAR) $(TARFLAGS) ../proxmark3-$(platform)-bin.tar $(OBJS:%=bootrom/%) $(OBJS:%.s19=bootrom/%.elf)
15c4dc5a 35
36$(OBJDIR)/bootrom.elf: $(VERSIONOBJ) $(ASMOBJ) $(ARMOBJ) $(THUMBOBJ)
86d31955 37 $(CC) $(LDFLAGS) -Wl,-T,ldscript-flash,-Map,$(patsubst %.elf,%.map,$@) -o $@ $^ $(LIBS)
15c4dc5a 38
39clean:
40 $(DELETE) $(OBJDIR)$(PATHSEP)*.o
41 $(DELETE) $(OBJDIR)$(PATHSEP)*.elf
42 $(DELETE) $(OBJDIR)$(PATHSEP)*.s19
43 $(DELETE) $(OBJDIR)$(PATHSEP)*.map
44 $(DELETE) $(OBJDIR)$(PATHSEP)*.d
45 $(DELETE) version.c
46
47.PHONY: all clean help
48help:
49 @echo Multi-OS Makefile, you are running on $(DETECTED_OS)
50 @echo Possible targets:
51 @echo + all - Make $(OBJDIR)/bootrom.s19, the main bootrom
52 @echo + clean - Clean $(OBJDIR)
Impressum, Datenschutz