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
		
	
	
	
	
	
| arch_dir = ../../addins/riscv-arch-test
 | |
| wally_dir = ../wally-riscv-arch-test
 | |
| work_dir = ./riscof_work
 | |
| work = ./work
 | |
| arch_workdir = $(work)/riscv-arch-test
 | |
| wally_workdir = $(work)/wally-riscv-arch-test
 | |
| 
 | |
| current_dir = $(shell pwd)
 | |
| XLEN    ?= 64
 | |
| 
 | |
| all: root build_arch #build_wally memfile
 | |
| 
 | |
| root:
 | |
| 	mkdir -p $(work_dir)
 | |
| 	mkdir -p $(work)
 | |
| 	mkdir -p $(arch_workdir)
 | |
| 	mkdir -p $(wally_workdir)
 | |
| 	sed 's,{0},$(current_dir),g;s,{1},$(XLEN)$(if $(findstring 64,$(XLEN)),gc,imc),g' config.ini > config$(XLEN).ini
 | |
| 
 | |
| fsd_fld_tempfix:
 | |
|     # this is a temporary fix, there's a typo on the rv64i_m/D/src/d_fsd-align-01.S and rv64i_m/D/src/d_fld-align-01.S tests
 | |
|     # https://github.com/riscv-non-isa/riscv-arch-test/issues/266
 | |
| 	find ../../addins/riscv-arch-test/riscv-test-suite -type f -name "*d_fld-align*.S" | xargs -I{} sed -i 's,regex(\.\*32\.\*),regex(\.\*64\.\*),g' {}
 | |
| 	find ../../addins/riscv-arch-test/riscv-test-suite -type f -name "*d_fsd-align*.S" | xargs -I{} sed -i 's,regex(\.\*32\.\*),regex(\.\*64\.\*),g' {}
 | |
| 
 | |
| build_arch: fsd_fld_tempfix
 | |
| 	riscof run --work-dir=$(work_dir) --config=config$(XLEN).ini --suite=$(arch_dir)/riscv-test-suite/ --env=$(arch_dir)/riscv-test-suite/env --no-browser
 | |
| 	rm -rf $(arch_workdir)/rv$(XLEN)i_m
 | |
| 	mv -f $(work_dir)/rv$(XLEN)i_m $(arch_workdir)/
 | |
| 
 | |
| build_wally:
 | |
| 	riscof --verbose debug run --work-dir=$(work_dir) --config=config$(XLEN).ini --suite=$(wally_dir)/riscv-test-suite/ --env=$(wally_dir)/riscv-test-suite/env --no-browser --no-dut-run
 | |
| 	rm -rf $(wally_workdir)/rv$(XLEN)i_m
 | |
| 	mv -f $(work_dir)/rv$(XLEN)i_m $(wally_workdir)/
 | |
| 
 | |
| memfile: 
 | |
| 	find $(work) -type f -name "*.elf" | grep "rv64i_m" | while read f; do riscv64-unknown-elf-elf2hex --bit-width 64 --input "$$f" --output "$$f.memfile"; done
 | |
| 	find $(work) -type f -name "*.elf" | grep "rv32i_m" | while read f; do riscv64-unknown-elf-elf2hex --bit-width 32 --input "$$f" --output "$$f.memfile"; done
 | |
| 	find $(work) -type f -name "*.elf.objdump" | while read f; do extractFunctionRadix.sh $$f; done
 | |
| 
 | |
| clean:
 | |
| 	rm -f config64.ini
 | |
| 	rm -f config32.ini
 | |
| 	rm -rf $(work_dir)
 | |
| 	rm -rf $(wally_workdir)
 | |
| 	rm -rf $(arch_workdir)
 |