74 lines
2.5 KiB
Makefile
74 lines
2.5 KiB
Makefile
CC := clang-11
|
|
CFLAGS += -nostdlib -fno-inline-functions -fno-unroll-loops -mcmodel=medium -gdwarf-5
|
|
LDFLAGS += -nostdlib -nostartfiles -static -fuse-ld=lld -Wl,-nostdlib -Wl,--script=arch/riscv/linker.ld
|
|
|
|
|
|
${BUILD_DIR}/startup.o: arch/riscv/bootcode/${ARCH}.c
|
|
@mkdir -p $(dir $@)
|
|
${CC} ${CFLAGS} -o $@ -c $^
|
|
|
|
${BUILD_DIR}/%/system.o: %.c
|
|
@mkdir -p $(dir $@)
|
|
${CC} ${CFLAGS} -o $@ -c $^
|
|
|
|
${BUILD_DIR}/%/system.elf: ${BUILD_DIR}/startup.o ${BUILD_DIR}/%/system.o
|
|
${CC} ${CFLAGS} ${LDFLAGS} -o $@ $^
|
|
|
|
|
|
${BUILD_DIR}/%/trace.pb: ${BUILD_DIR}/%/system.elf
|
|
${FAIL_TRACE} \
|
|
-Wf,--full-trace \
|
|
-Wf,--elf-file -Wf,$< \
|
|
-Wf,--start-symbol -Wf,start_trace \
|
|
-Wf,--end-symbol -Wf,stop_trace \
|
|
-Wf,--check-bounds \
|
|
-Wf,--state-file=$(dir $<)/state \
|
|
-Wf,--trace-file=$(dir $<)/trace.pb \
|
|
-V $<
|
|
|
|
client-%:
|
|
${BOCHS_RUNNER} --mode riscv \
|
|
-f ${FAIL_INJECT} \
|
|
-e ${BUILD_DIR}/$(subst client-,,$@)/system.elf \
|
|
-j $(shell getconf _NPROCESSORS_ONLN) \
|
|
-- \
|
|
-Wf,--state-dir=${BUILD_DIR}/$(subst client-,,$@)/state \
|
|
-Wf,--trap \
|
|
-Wf,--timeout=100000 \
|
|
-Wf,--ok-marker=ok_marker \
|
|
-Wf,--fail-marker=fail_marker \
|
|
-Wf,--catch-write-textsegment \
|
|
-Wf,--catch-outerspace \
|
|
-V 2>/dev/null | grep -B 2 -A 8 'INJECT'
|
|
|
|
inject-%:
|
|
${BOCHS_RUNNER} --mode riscv -1 -j 1 \
|
|
-f ${FAIL_INJECT} \
|
|
-e ${BUILD_DIR}/$(subst inject-,,$@)/system.elf \
|
|
-- \
|
|
-Wf,--state-dir=${BUILD_DIR}/$(subst inject-,,$@)/state \
|
|
-Wf,--trap \
|
|
-Wf,--timeout=100000 \
|
|
-Wf,--ok-marker=ok_marker \
|
|
-Wf,--fail-marker=fail_marker \
|
|
-Wf,--catch-write-textsegment \
|
|
-Wf,--catch-outerspace -V
|
|
|
|
|
|
import-arch-%: ${BUILD_DIR}/%/trace.pb ${HOME}/.my.cnf
|
|
${FAIL_IMPORT} -v ${ARCH}/$(patsubst import-arch-%,%,$@) -b mem -t $< -e $(shell dirname $<)/system.elf -i mem --memory-type ram
|
|
${FAIL_IMPORT} -v ${ARCH}/$(patsubst import-arch-%,%,$@) -b regs-trace -t $< -e $(shell dirname $<)/system.elf -i mem --memory-type register
|
|
${FAIL_IMPORT} -v ${ARCH}/$(patsubst import-arch-%,%,$@) -b regs -t $< -e $(shell dirname $<)/system.elf -i regs
|
|
${FAIL_IMPORT} -v ${ARCH}/$(patsubst import-arch-%,%,$@) -b ip -t $< -e $(shell dirname $<)/system.elf -i regs --no-gp --ip
|
|
${FAIL_PRUNE} -v ${ARCH}/$(patsubst import-arch-%,%,$@) -b %% --overwrite
|
|
|
|
define arch-make-targets
|
|
build-$1: ${BUILD_DIR}/$1/system.elf
|
|
|
|
trace-$1: ${BUILD_DIR}/$1/trace.pb
|
|
|
|
|
|
endef
|
|
|
|
|