40 lines
844 B
Makefile
40 lines
844 B
Makefile
CC = arm-none-eabi-gcc
|
|
LD = arm-none-eabi-gcc
|
|
CXX = arm-none-eabi-g++
|
|
OBJCOPY = arm-none-eabi-objcopy
|
|
|
|
linker_script = bootloader.ld
|
|
includes =
|
|
sources =
|
|
|
|
CFLAGS = -march=armv6-m -g -ffunction-sections -fdata-sections -O2 -Werror -Wall
|
|
CXXFLAGS = $(CFLAGS) -std=c++20 -fno-exceptions
|
|
LDFLAGS = -march=armv6-m \
|
|
-g --specs=nano.specs --specs=nosys.specs \
|
|
-Wl,--gc-sections -Wl,-T$(linker_script) -O2 \
|
|
-Wl,--print-memory-usage
|
|
|
|
sources += hal/lib/common/xil_assert.c
|
|
includes += -Ihal/lib/common
|
|
|
|
sources += hal/uart/xuartlite.c hal/uart/xuartlite_stats.c
|
|
includes += -Ihal/uart
|
|
|
|
objects = main.o vector_table.o $(sources:.c=.o)
|
|
|
|
CFLAGS += $(includes)
|
|
|
|
all: bootloader.elf
|
|
|
|
%.bin: %.elf
|
|
$(OBJCOPY) -O binary $< $@
|
|
|
|
bootloader.elf: $(objects)
|
|
|
|
%.elf:
|
|
$(LD) $(LDFLAGS) -o $@ $^
|
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
|
rm -rf *.elf *.bin $(objects)
|