2021-05-28 13:08:21 +00:00
|
|
|
TARGET ?= rvc
|
|
|
|
SRC_DIRS ?= ./src
|
|
|
|
|
|
|
|
CC=clang
|
|
|
|
|
|
|
|
SRCS := $(shell find $(SRC_DIRS) -name '*.cpp' -or -name '*.c' -or -name '*.s')
|
|
|
|
OBJS := $(addsuffix .o,$(basename $(SRCS)))
|
|
|
|
DEPS := $(OBJS:.o=.d)
|
|
|
|
|
|
|
|
INC_DIRS := $(shell find $(SRC_DIRS) -type d)
|
|
|
|
INC_FLAGS := $(addprefix -I,$(INC_DIRS))
|
|
|
|
|
|
|
|
$(TARGET): $(OBJS)
|
2021-06-03 20:42:59 +00:00
|
|
|
$(CC) $(LDFLAGS) -I./elfy/elfy.h $(OBJS) -o $@ $(LOADLIBES) $(LDLIBS) -L./elfy/target/release/ -Wl,--no-as-needed -ldl -lpthread -lelfy
|
2021-05-28 13:08:21 +00:00
|
|
|
|
|
|
|
.PHONY: clean
|
|
|
|
clean:
|
2021-06-09 16:38:46 +00:00
|
|
|
$(RM) $(TARGET) $(OBJS) $(DEPS) fw_payload.*
|
|
|
|
$(MAKE) -C opensbi clean
|
2021-05-28 13:08:21 +00:00
|
|
|
|
|
|
|
-include $(DEPS)
|
|
|
|
|
2021-06-03 20:42:59 +00:00
|
|
|
# build device tree
|
|
|
|
dts.dtb: dts.dts
|
|
|
|
dtc -o $@ $<
|
|
|
|
|
|
|
|
OPENSBI_BUILD="opensbi/build/platform/generic/firmware"
|
2021-06-09 16:38:46 +00:00
|
|
|
PAYLOAD="rust_payload/target/riscv32ima-unknown-none-elf/release/rust_payload.bin"
|
|
|
|
|
|
|
|
$(PAYLOAD): $(shell find rust_payload/src -type f)
|
|
|
|
cd rust_payload; \
|
|
|
|
cargo +riscv32ima rustc -Zbuild-std --release --target "riscv32ima-unknown-none-elf" -- -Clink-arg=-Tlinker.ld -Clinker=riscv32-elf-ld
|
|
|
|
riscv32-elf-objcopy -O binary \
|
|
|
|
rust_payload/target/riscv32ima-unknown-none-elf/release/rust_payload $(PAYLOAD)
|
2021-06-03 20:42:59 +00:00
|
|
|
|
|
|
|
fw_payload.bin: fw_payload.elf
|
|
|
|
cp $(OPENSBI_BUILD)/fw_payload.bin .
|
2021-06-09 16:38:46 +00:00
|
|
|
fw_payload.elf: $(PAYLOAD)
|
2021-06-03 20:42:59 +00:00
|
|
|
env CROSS_COMPILE=riscv64-elf- \
|
|
|
|
PLATFORM=generic \
|
|
|
|
PLATFORM_RISCV_XLEN=32 \
|
|
|
|
PLATFORM_RISCV_ISA=rv32ima \
|
|
|
|
PLATFORM_RISCV_ABI=ilp32 \
|
2021-06-09 16:38:46 +00:00
|
|
|
FW_PAYLOAD_PATH=../$(PAYLOAD) \
|
2021-06-03 20:42:59 +00:00
|
|
|
FW_PIC=n \
|
|
|
|
ELFFLAGS=-L/usr/lib/gcc/riscv64-elf/10.2.0/rv32im/ilp32 \
|
|
|
|
$(MAKE) -C opensbi all
|
|
|
|
cp $(OPENSBI_BUILD)/fw_payload.elf .
|
2021-06-09 16:38:46 +00:00
|
|
|
|
|
|
|
.PHONY: run
|
|
|
|
run: fw_payload.bin $(TARGET) dts.dtb
|
|
|
|
./rvc -b fw_payload.bin -d dts.dtb
|
|
|
|
|
|
|
|
run-v1: fw_payload.bin $(TARGET) dts.dtb
|
|
|
|
./rvc -b fw_payload.bin -d dts.dtb -v1
|