mirror of
https://github.com/PiMaker/rvc.git
synced 2024-11-12 23:21:29 +00:00
134e85e485
honestly forgot what I added all over the last year or so, but here you go, enjoy more cursed code
132 lines
4.2 KiB
Makefile
132 lines
4.2 KiB
Makefile
TARGET ?= rvc
|
|
SRC_DIRS ?= ./src ./tinypngout
|
|
|
|
CC=clang
|
|
|
|
BUILDROOT := "buildroot-2022.02.1"
|
|
|
|
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))
|
|
|
|
Q=$(CURDIR)/$(BUILDROOT)/output/host/bin/riscv32-buildroot-linux-gnu-
|
|
|
|
CFLAGS ?= -g -O2
|
|
|
|
.PHONY: $(TARGET)
|
|
$(TARGET):
|
|
touch src/main.c
|
|
rm -f src/main.o
|
|
$(MAKE) $(TARGET)-real
|
|
|
|
$(TARGET)-real: $(OBJS)
|
|
$(CC) $(LDFLAGS) -I./elfy/elfy.h -I./tinypngout/TinyPngOut.h $(OBJS) -o $(TARGET) $(LOADLIBES) $(LDLIBS) -L./elfy/target/release/ -Wl,--no-as-needed -ldl -lpthread -lelfy -lm
|
|
|
|
-include $(DEPS)
|
|
|
|
# build device tree
|
|
dts.dtb: dts.dts
|
|
dtc -o $@ $<
|
|
|
|
OPENSBI_BUILD=opensbi/build/platform/generic/firmware
|
|
PAYLOAD=rust_payload/target/riscv32ima-unknown-none-elf/release/rust_payload.bin
|
|
LINUX_PAYLOAD=linux/arch/riscv/boot/Image
|
|
RAYTRACE_PAYLOAD=rust_raytrace/target/riscv32ima-unknown-none-elf/release/rust_raytrace.bin
|
|
|
|
BUILDROOT_MARKER=$(BUILDROOT)/build.marker
|
|
$(BUILDROOT_MARKER):
|
|
if [ ! -f $(BUILDROOT_MARKER) ]; then $(MAKE) -C $(BUILDROOT); fi
|
|
touch $@
|
|
|
|
$(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=$(Q)ld
|
|
$(Q)objcopy -O binary \
|
|
rust_payload/target/riscv32ima-unknown-none-elf/release/rust_payload $(PAYLOAD)
|
|
|
|
$(RAYTRACE_PAYLOAD): $(shell find rust_raytrace/src -type f)
|
|
cd rust_raytrace; \
|
|
cargo +riscv32ima rustc -Zbuild-std --release --target "riscv32ima-unknown-none-elf" -- -Clink-arg=-Tlinker.ld -Clinker=$(Q)ld
|
|
$(Q)objcopy -O binary \
|
|
rust_raytrace/target/riscv32ima-unknown-none-elf/release/rust_raytrace $(RAYTRACE_PAYLOAD)
|
|
|
|
rust_raytrace.bin: $(RAYTRACE_PAYLOAD)
|
|
cp $(RAYTRACE_PAYLOAD) $@
|
|
|
|
rust_payload.bin: rust_payload.elf
|
|
cp $(OPENSBI_BUILD)/fw_payload.bin ./rust_payload.bin
|
|
rust_payload.elf: $(PAYLOAD) $(BUILDROOT_MARKER)
|
|
$(MAKE) -C opensbi clean
|
|
env CROSS_COMPILE=$(Q) \
|
|
PLATFORM=generic \
|
|
PLATFORM_RISCV_XLEN=32 \
|
|
PLATFORM_RISCV_ISA=rv32ima \
|
|
PLATFORM_RISCV_ABI=ilp32 \
|
|
FW_PAYLOAD_PATH=../$(PAYLOAD) \
|
|
FW_PIC=n \
|
|
$(MAKE) -C opensbi all
|
|
cp $(OPENSBI_BUILD)/fw_payload.elf ./rust_payload.elf
|
|
|
|
.PHONY: $(LINUX_PAYLOAD)
|
|
$(LINUX_PAYLOAD): linux $(BUILDROOT_MARKER)
|
|
# cd linux && (git apply ../linux-_pi_-patches-for-rvc.patch || true)
|
|
cd linux && \
|
|
env CROSS_COMPILE=$(Q) \
|
|
CFLAGS="-march=rv32ima -mabi=ilp32" \
|
|
LDFLAGS="-march=rv32ima -mabi=ilp32" \
|
|
ARCH=riscv \
|
|
KCONFIG_ALLCONFIG=../linux.config \
|
|
make allnoconfig
|
|
cd linux && ./scripts/clang-tools/gen_compile_commands.py
|
|
cd linux && \
|
|
env CROSS_COMPILE=$(Q) \
|
|
CFLAGS="-march=rv32ima -mabi=ilp32" \
|
|
LDFLAGS="-march=rv32ima -mabi=ilp32" \
|
|
ARCH=riscv \
|
|
make -j$(shell nproc)
|
|
cd linux && ./scripts/clang-tools/gen_compile_commands.py
|
|
|
|
linux_payload.bin: linux_payload.elf
|
|
cp $(OPENSBI_BUILD)/fw_payload.bin ./linux_payload.bin
|
|
linux_payload.elf: $(LINUX_PAYLOAD) $(BUILDROOT_MARKER)
|
|
$(MAKE) -C opensbi clean
|
|
env CROSS_COMPILE=$(Q) \
|
|
PLATFORM=generic \
|
|
PLATFORM_RISCV_XLEN=32 \
|
|
PLATFORM_RISCV_ISA=rv32ima \
|
|
PLATFORM_RISCV_ABI=ilp32 \
|
|
FW_PAYLOAD_PATH=../$(LINUX_PAYLOAD) \
|
|
FW_PIC=n \
|
|
$(MAKE) -C opensbi all
|
|
cp $(OPENSBI_BUILD)/fw_payload.elf ./linux_payload.elf
|
|
|
|
.PHONY: run
|
|
run: fw_payload.bin $(TARGET) dts.dtb
|
|
./rvc -b fw_payload.bin -d dts.dtb
|
|
|
|
.PHONY: run-v1
|
|
run-v1: fw_payload.bin $(TARGET) dts.dtb
|
|
./rvc -b fw_payload.bin -d dts.dtb -v1
|
|
|
|
.PHONY: run-network
|
|
run-network: linux_payload.bin $(TARGET) dts.dtb
|
|
tmux new -s rvc-network -d "./rvc -b linux_payload.bin -d dts.dtb -n /tmp/rvc-test.sock -i ./$(BUILDROOT)/output/images/rootfs.romfs -f"
|
|
tmux split-window -t rvc-network "./rvc -b linux_payload.bin -d dts.dtb -N /tmp/rvc-test.sock -i ./$(BUILDROOT)/output/images/rootfs.romfs -f"
|
|
tmux select-layout -t rvc-network even-horizontal
|
|
tmux attach -t rvc-network
|
|
tmux kill-session -t rvc-network || true
|
|
|
|
.PHONY: clean
|
|
clean:
|
|
$(RM) $(TARGET) $(OBJS) $(DEPS)
|
|
|
|
.PHONY: distclean
|
|
distclean: clean
|
|
$(RM) $(TARGET) $(OBJS) $(DEPS) *_payload.*
|
|
$(MAKE) -C opensbi clean
|
|
$(MAKE) -C linux clean
|
|
$(RM) $(BUILDROOT_MARKER)
|