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
5 #-----------------------------------------------------------------------------
6 # Makefile for bootrom, see ../common/Makefile.common for common settings
7 #-----------------------------------------------------------------------------
9 # DO NOT use thumb mode in the phase 1 bootloader since that generates a section with glue code
14 ASMSRC
= ram-reset.s flash-reset.s
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
20 # ARMSRC := $(ARMSRC) $(THUMBSRC)
23 # stdint.h provided locally until GCC 4.5 becomes C99 compliant
24 APP_CFLAGS
= -I.
-fno-strict-aliasing
-ffunction-sections
-fdata-sections
26 # Do not move this inclusion before the definition of {THUMB,ASM,ARM}SRC
27 include ..
/common
/Makefile.common
29 OBJS
= $(OBJDIR
)/bootrom.s19
34 $(TAR
) $(TARFLAGS
) ..
/proxmark3-
$(platform
)-bin.
tar $(OBJS
:%=bootrom
/%) $(OBJS
:%.s19
=bootrom
/%.elf
)
36 $(OBJDIR
)/bootrom.elf
: $(VERSIONOBJ
) $(ASMOBJ
) $(ARMOBJ
) $(THUMBOBJ
)
37 $(CC
) $(LDFLAGS
) -Wl
,-T
,ldscript-flash
,-Map
,$(patsubst %.elf
,%.map
,$@
) -o
$@
$^
$(LIBS
)
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
47 .PHONY
: all clean help
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
)