Files
vortex/runtime/Makefile
2021-03-02 20:35:49 -05:00

39 lines
942 B
Makefile

RISCV_TOOLCHAIN_PATH ?= /opt/riscv-gnu-toolchain
CC = $(RISCV_TOOLCHAIN_PATH)/bin/riscv32-unknown-elf-gcc
AR = $(RISCV_TOOLCHAIN_PATH)/bin/riscv32-unknown-elf-gcc-ar
DP = $(RISCV_TOOLCHAIN_PATH)/bin/riscv32-unknown-elf-objdump
CP = $(RISCV_TOOLCHAIN_PATH)/bin/riscv32-unknown-elf-objcopy
CFLAGS += -O3 -march=rv32imf -mabi=ilp32f -fno-exceptions -fdata-sections -ffunction-sections
CFLAGS += -I./include -I../hw
PROJECT = libvortexrt
SRCS = ./src/vx_start.S ./src/vx_print.S ./src/vx_print.c ./src/vx_spawn.c
OBJS := $(SRCS:.S=.o) $(SRCS:.c=.o)
all: $(PROJECT).a $(PROJECT).dump
$(PROJECT).a: $(OBJS)
$(AR) rc $(PROJECT).a $^
$(PROJECT).dump: $(PROJECT).a
$(DP) -D $(PROJECT).a > $(PROJECT).dump
%.o: src/%.S
$(CC) $(CFLAGS) -c -o $@ $<
%.o: src/%.c
$(CC) $(CFLAGS) -c -o $@ $<
.depend: $(SRCS)
$(CC) $(CFLAGS) -MM $^ > .depend;
clean:
rm -rf *.a *.o *.dump .depend
ifneq ($(MAKECMDGOALS),clean)
-include .depend
endif