2022-05-08 06:00:22 +00:00
|
|
|
CC = arm-none-eabi-gcc
|
2022-05-17 03:26:37 +00:00
|
|
|
LD = arm-none-eabi-g++
|
2022-05-08 06:00:22 +00:00
|
|
|
CXX = arm-none-eabi-g++
|
|
|
|
OBJCOPY = arm-none-eabi-objcopy
|
|
|
|
|
|
|
|
linker_script = bootloader.ld
|
2022-05-09 03:55:58 +00:00
|
|
|
includes =
|
|
|
|
sources =
|
2022-05-08 06:00:22 +00:00
|
|
|
|
2022-05-17 03:28:24 +00:00
|
|
|
CFLAGS = -march=armv6-m -g -ffunction-sections -fdata-sections -Os -Werror -Wall -flto
|
|
|
|
CXXFLAGS = $(CFLAGS) -std=c++20 -fno-exceptions -fcoroutines
|
|
|
|
CPPFLAGS = -MD -MP
|
2022-05-09 03:55:58 +00:00
|
|
|
LDFLAGS = -march=armv6-m \
|
|
|
|
-g --specs=nano.specs --specs=nosys.specs \
|
2022-05-17 03:28:24 +00:00
|
|
|
-Wl,--gc-sections -Os \
|
|
|
|
-Wl,--print-memory-usage -flto
|
2022-05-08 06:00:22 +00:00
|
|
|
|
2022-05-17 03:56:25 +00:00
|
|
|
includes += -Ihal/cmsis
|
|
|
|
|
2022-05-09 03:55:58 +00:00
|
|
|
sources += hal/lib/common/xil_assert.c
|
|
|
|
includes += -Ihal/lib/common
|
|
|
|
|
2022-05-17 03:56:25 +00:00
|
|
|
sources += hal/uart/xuartlite.c hal/uart/xuartlite_stats.c hal/uart/xuartlite_intr.c
|
2022-05-09 03:55:58 +00:00
|
|
|
includes += -Ihal/uart
|
|
|
|
|
2022-05-17 17:17:56 +00:00
|
|
|
bootloader_objects = bootloader.o vector_table.o $(sources:.c=.o)
|
2022-05-17 03:56:25 +00:00
|
|
|
app_objects = app_init.o crash.o main.o uart.o stdlib.o async.o trace.o $(sources:.c=.o)
|
2022-05-09 03:55:58 +00:00
|
|
|
|
2022-05-17 03:28:24 +00:00
|
|
|
CPPFLAGS += $(includes)
|
2022-05-09 03:55:58 +00:00
|
|
|
|
2022-05-10 18:20:02 +00:00
|
|
|
all: bootloader.elf app.bin
|
2022-05-08 06:00:22 +00:00
|
|
|
|
|
|
|
%.bin: %.elf
|
|
|
|
$(OBJCOPY) -O binary $< $@
|
|
|
|
|
2022-05-17 03:28:24 +00:00
|
|
|
bootloader.elf: $(bootloader_objects) bootloader.ld
|
|
|
|
$(LD) -Wl,-Tbootloader.ld $(LDFLAGS) -o $@ $(bootloader_objects)
|
2022-05-10 18:20:02 +00:00
|
|
|
|
2022-05-17 03:28:24 +00:00
|
|
|
app.elf: $(app_objects) app.ld
|
|
|
|
$(LD) -Wl,-Tapp.ld $(LDFLAGS) -o $@ $(app_objects)
|
2022-05-08 06:00:22 +00:00
|
|
|
|
2022-05-17 03:56:25 +00:00
|
|
|
.PHONY: clean test
|
2022-05-08 06:00:22 +00:00
|
|
|
|
2022-05-17 03:56:25 +00:00
|
|
|
deps = $(app_objects:.o=.d) $(bootloader_objects:.o=.d)
|
2022-05-08 06:00:22 +00:00
|
|
|
|
|
|
|
clean:
|
2022-05-17 03:56:25 +00:00
|
|
|
rm -rf *.elf *.bin $(tests) $(app_objects) $(bootloader_objects) $(deps)
|
|
|
|
|
2022-06-19 07:41:17 +00:00
|
|
|
HOSTCXX = /usr/local/opt/llvm/bin/clang++
|
|
|
|
HOSTLDFLAGS = -lgmock -lgtest -lgtest_main -L/usr/local/opt/llvm/lib -L/usr/local/lib
|
|
|
|
HOSTCFLAGS = -std=c++20 -g\
|
|
|
|
-I/usr/local/opt/llvm/include \
|
|
|
|
-I/usr/local/include \
|
|
|
|
-I/usr/local/include \
|
|
|
|
-MP -MD
|
2022-05-17 03:56:25 +00:00
|
|
|
|
2022-06-19 07:41:17 +00:00
|
|
|
TSAN_CFLAGS = $(HOSTCFLAGS) -fsanitize=thread
|
|
|
|
ASAN_CFLAGS = $(HOSTCFLAGS) -fsanitize=address -fsanitize=leak
|
|
|
|
|
|
|
|
tests = ring_buffer_test async_test_asan async_test_tsan
|
|
|
|
|
|
|
|
.PRECIOUS: $(tests)
|
2022-05-17 03:56:25 +00:00
|
|
|
|
|
|
|
test: $(tests)
|
|
|
|
|
|
|
|
ring_buffer_test: ring_buffer_test.cc
|
2022-06-19 07:41:17 +00:00
|
|
|
mkdir test
|
|
|
|
$(HOSTCXX) $(HOSTCFLAGS) -o test/$@ $< $(HOSTLDFLAGS)
|
|
|
|
./test/$@
|
|
|
|
|
|
|
|
%.host.o: %.cc
|
|
|
|
$(HOSTCXX) $(HOSTCFLAGS) -c -o $@ $<
|
|
|
|
|
|
|
|
async_test_tsan: async_test.cc async.host.o
|
|
|
|
mkdir -p test
|
|
|
|
$(HOSTCXX) $(TSAN_CFLAGS) -o test/$@ $^ $(HOSTLDFLAGS)
|
|
|
|
TSAN_OPTIONS='suppressions=tsan.suppressions' ./test/$@
|
|
|
|
|
|
|
|
async_test_asan: async_test.cc async.host.o
|
|
|
|
mkdir -p test
|
|
|
|
$(HOSTCXX) $(ASAN_CFLAGS) -o test/$@ $^ $(HOSTLDFLAGS)
|
|
|
|
ASAN_OPTIONS=detect_leaks=1 ./test/$@
|
|
|
|
|
|
|
|
test_deps = async.host.d
|
2022-05-17 03:56:25 +00:00
|
|
|
|
|
|
|
-include $(deps)
|
2022-06-19 07:41:17 +00:00
|
|
|
-include $(test_deps)
|