# # Generic and Simple GNU ARM Makefile # # Desinged for the gnu-arm-none-eabi tool chain # # Features # - create hex file # - create assembler listing (.dis) # # Limitations # - only C-files supported # - no automatic dependency checking (call 'make clean' if any .h files are changed) # # Targets: # make # create hex file, no upload # make upload # create and upload hex file # make clean # delete all generated files # # Note: # Display list make database: make -p -f/dev/null | less # #================================================ # External tools # The base directory of gcc-arm-none-eabi # Can be empty on Ubuntu and installed gcc-arm-none-eabi # If set, GCCBINPATH must contain a "/" at the end. GCCBINPATH:=/usr/bin/ #================================================ # Project Information # The name for the project TARGETNAME:=hello_world # The source files of the project SRC:=$(wildcard *.c) # The CPU architecture (will be used for -mcpu) # for the LPC824, can we use "cortex-m0plus"? #MCPU:=cortex-m0 MCPU:=cortex-m0plus # Include directory for the system include files SYSINC:=../lpc_chip_82x/inc SYSSRC:=$(wildcard ../lpc_chip_82x/src/*.c) # Include directory for the u8g2 include files U8G2INC:=../../../../csrc/ U8G2SRC:=$(wildcard ../../../../csrc/*.c) # directory for FatFS #FFINC:=../fatfs #FFSRC:=$(wildcard ../fatfs/*.c) # Directory for the linker script LDSCRIPTDIR:=. # Name of the linker script (must be the "keep" script, because the other script is not always working) LDSCRIPT:=lpc824.ld #================================================ # Main part of the Makefile starts here. Usually no changes are needed. # Internal Variable Names LIBNAME:=$(TARGETNAME).a ELFNAME:=$(TARGETNAME).elf HEXNAME:=$(TARGETNAME).hex BINNAME:=firmware.bin DISNAME:=$(TARGETNAME).dis MAPNAME:=$(TARGETNAME).map OBJ:=$(SRC:.c=.o) $(SYSSRC:.c=.o) $(U8G2SRC:.c=.o) $(FFSRC:.c=.o) # Replace standard build tools by avr tools CC:=$(GCCBINPATH)arm-none-eabi-gcc AR:=$(GCCBINPATH)arm-none-eabi-ar OBJCOPY:=$(GCCBINPATH)arm-none-eabi-objcopy OBJDUMP:=$(GCCBINPATH)arm-none-eabi-objdump SIZE:=$(GCCBINPATH)arm-none-eabi-size # Common flags COMMON_FLAGS = -mthumb -mcpu=$(MCPU) COMMON_FLAGS += -Wall -I. -I$(SYSINC) -I$(U8G2INC) # define stack size (defaults to 0x0100) # COMMON_FLAGS += -D__STACK_SIZE=0x0100 # define constant for lpcopen library COMMON_FLAGS += -DCORE_M0PLUS # instruct LPC8xx lib procedures to use the ROM API COMMON_FLAGS += -DUSE_ROM_API # do not make a call to SystemInit() # COMMON_FLAGS += -Os -flto COMMON_FLAGS += -Os # COMMON_FLAGS += -fstack-protector # COMMON_FLAGS += -finstrument-functions # Do not use stand libs startup code. Uncomment this for gcclib procedures # memcpy still works, but might be required for __aeabi_uidiv # COMMON_FLAGS += -nostdlib # remove unused data and function COMMON_FLAGS += -ffunction-sections -fdata-sections # COMMON_FLAGS += -fshort-wchar # C flags CFLAGS:=$(COMMON_FLAGS) -std=gnu99 # LD flags # remove unreferenced procedures and variables, but keep "arm_stack_area" and __isr_vector GC:=-Wl,--gc-sections -Wl,--undefined=arm_stack_area -Wl,--undefined=__isr_vector MAP:=-Wl,-Map=$(MAPNAME) LFLAGS:=$(COMMON_FLAGS) $(GC) $(MAP) #LDLIBS:=--specs=nano.specs -lc -lc -lnosys -L$(LDSCRIPTDIR) -T $(LDSCRIPT) LDLIBS:=--specs=nosys.specs -lc -lc -lnosys -L$(LDSCRIPTDIR) -T $(LDSCRIPT) # Additional Suffixes .SUFFIXES: .elf .hex .bin .dis # Targets .PHONY: all all: $(DISNAME) $(HEXNAME) $(BINNAME) $(SIZE) $(ELFNAME) .PHONY: upload upload: $(DISNAME) $(HEXNAME) $(ELFNAME) $(BINNAME) #dd bs=1024 conv=nocreat,notrunc if=$(BINNAME) of="/media/$(shell echo $$USER)/CRP DISABLD/firmware.bin" ../hex2lpc/hex2lpc -s 2 -f $(HEXNAME) -x $(SIZE) $(ELFNAME) .PHONY: clean clean: $(RM) $(OBJ) $(HEXNAME) $(ELFNAME) $(LIBNAME) $(DISNAME) $(MAPNAME) $(BINNAME) libssp.a libssp_nonshared.a # implicit rules .elf.hex: $(OBJCOPY) -O ihex $< $@ # explicit rules $(ELFNAME): $(LIBNAME)($(OBJ)) libssp.a libssp_nonshared.a $(LINK.o) $(LFLAGS) $(LIBNAME) $(LDLIBS) -o $@ $(DISNAME): $(ELFNAME) $(OBJDUMP) -D -S $< > $@ # not required for this project $(BINNAME): $(ELFNAME) $(OBJCOPY) -O binary --gap-fill 255 --pad-to 32768 $< $@ # create empty ssp libs for -fstack-protector-all -fstack-protector libssp.a: $(AR) rcs $@ libssp_nonshared.a: $(AR) rcs $@