mirror of
				https://github.com/openhwgroup/cvw
				synced 2025-02-11 06:05:49 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			2.0 KiB
		
	
	
	
		
			Makefile
		
	
	
	
	
	
| # Wally Coremark Makefile
 | |
| # Daniel Torres & David Harris 28 July 2022
 | |
| # SPDX-License-Identifier: Apache-2.0 WITH SHL-2.1
 | |
| 
 | |
| PORT_DIR = $(CURDIR)/riscv64-baremetal
 | |
| cmbase=../../addins/coremark
 | |
| work_dir= ../../benchmarks/coremark/work
 | |
| XLEN ?=64
 | |
| sources=$(cmbase)/core_main.c $(cmbase)/core_list_join.c $(cmbase)/coremark.h  \
 | |
| 	$(cmbase)/core_matrix.c $(cmbase)/core_state.c $(cmbase)/core_util.c \
 | |
| 	$(PORT_DIR)/core_portme.h $(PORT_DIR)/core_portme.c $(PORT_DIR)/core_portme.mak \
 | |
| 	$(PORT_DIR)/crt.S $(PORT_DIR)/encoding.h $(PORT_DIR)/util.h $(PORT_DIR)/syscalls.c
 | |
| ABI := $(if $(findstring "64","$(XLEN)"),lp64,ilp32)
 | |
| ARCH := rv$(XLEN)im
 | |
| PORT_CFLAGS = -g -mabi=$(ABI) -march=$(ARCH) -static -falign-functions=16 \
 | |
| 	-mbranch-cost=1 -DSKIP_DEFAULT_MEMSET -mtune=sifive-3-series -O3 -finline-functions -falign-jumps=4 \
 | |
| 	-fno-delete-null-pointer-checks -fno-rename-registers --param=loop-max-datarefs-for-datadeps=0 \
 | |
| 	-funroll-all-loops --param=uninlined-function-insns=8 -fno-tree-vrp -fwrapv -fipa-pta \
 | |
| 	-nostdlib -nostartfiles -ffreestanding -mstrict-align \
 | |
| 	-DTOTAL_DATA_SIZE=2000 -DMAIN_HAS_NOARGC=1 -DPERFORMANCE_RUN=1 -DITERATIONS=10 -DXLEN=$(XLEN) 
 | |
| 
 | |
| all: $(work_dir)/coremark.bare.riscv.elf.memfile
 | |
| 
 | |
| run:
 | |
| 	(cd ../../sim && (time vsim -c -do "do wally-batch.do rv$(XLEN)gc coremark" 2>&1 | tee $(work_dir)/coremark.sim.log))
 | |
| 	cd ../benchmarks/coremark/
 | |
| #	KMG: added post processing script to give out branch miss proportion along with other stats to the coremark test
 | |
| 	python3 coremark-postprocess.py
 | |
| 
 | |
| $(work_dir)/coremark.bare.riscv.elf.memfile: $(work_dir)/coremark.bare.riscv
 | |
| 	riscv64-unknown-elf-objdump -D $< > $<.elf.objdump
 | |
| 	riscv64-unknown-elf-elf2hex --bit-width $(XLEN) --input $< --output $@
 | |
| 	extractFunctionRadix.sh $<.elf.objdump
 | |
| 
 | |
| $(work_dir)/coremark.bare.riscv: $(sources) Makefile
 | |
| 	make -C $(cmbase) PORT_DIR=$(PORT_DIR) compile RISCV=$(RISCV)/riscv-gnu-toolchain XCFLAGS="$(PORT_CFLAGS)"
 | |
| 	mkdir -p $(work_dir)
 | |
| 	mv $(cmbase)/coremark.bare.riscv $(work_dir)
 | |
| 
 | |
| .PHONY: clean
 | |
| 
 | |
| clean:
 | |
| 	rm -f $(work_dir)/*
 | |
| 
 | |
| 
 |