mirror of
https://github.com/openhwgroup/cvw
synced 2025-01-26 06:25:20 +00:00
36 lines
1012 B
Makefile
36 lines
1012 B
Makefile
CEXT := c
|
|
CPPEXT := cpp
|
|
AEXT := s
|
|
SEXT := S
|
|
SRCEXT := \([$(CEXT)$(AEXT)$(SEXT)]\|$(CPPEXT)\)
|
|
#SRCS = $(wildcard *.S)
|
|
#PROGS = $(patsubst %.S,%,$(SRCS))
|
|
SRCDIR = .
|
|
SRCEXT = S
|
|
SOURCES ?= $(shell find $(SRCDIR) -type f -regex ".*\.$(SRCEXT)" | sort)
|
|
OBJEXT = elf
|
|
OBJECTS := $(SOURCES:.$(SEXT)=.$(OBJEXT))
|
|
|
|
all: $(OBJECTS)
|
|
|
|
%.elf.objdump: %.elf
|
|
|
|
# Change many things if bit width isn't 64
|
|
%.elf: $(SRCDIR)/%.$(SEXT) WALLY-init-lib.h Makefile
|
|
riscv64-unknown-elf-gcc -g -o $@ -march=rv64gc_zba_zbb_zbc_zbs -mabi=lp64 -mcmodel=medany \
|
|
-nostartfiles -T../../examples/link/link.ld $<
|
|
riscv64-unknown-elf-objdump -S $@ > $@.objdump
|
|
riscv64-unknown-elf-elf2hex --bit-width 64 --input $@ --output $@.memfile
|
|
extractFunctionRadix.sh $@.objdump
|
|
|
|
sim: %.elf
|
|
spike +signature=%.signature.output +signature-granularity=8 %.elf
|
|
diff --ignore-case %.signature.output %.reference_output || exit
|
|
echo "Signature matches! Success!"
|
|
|
|
clean:
|
|
rm -f *.elf *.objdump *.signature.output *.addr *.lab *.memfile
|
|
|
|
|
|
|