Add: generate file on make

This commit is contained in:
brice.boisson 2023-11-21 18:45:25 +09:00
parent 7d60960831
commit e2ca11548c
5 changed files with 12 additions and 10 deletions

View File

@ -17,3 +17,4 @@ clean:
rm -rf tb/test_source_code/**/*.bin rm -rf tb/test_source_code/**/*.bin
rm -rf tb/test_source_code/**/*.elf rm -rf tb/test_source_code/**/*.elf
rm -rf tb/test_source_code/**/*.o rm -rf tb/test_source_code/**/*.o
rm -rf tb/test_source_code/**/*.tmp

View File

@ -1,6 +1,11 @@
import re import re
import sys
source_code = open('test.S', 'r') if len(sys.argv) != 3:
print("Usage: python3 gen_test.py <path> <filename>")
exit(1)
source_code = open(sys.argv[1] + "/" + sys.argv[2], 'r')
Lines = source_code.readlines() Lines = source_code.readlines()
test_file = [] test_file = []
@ -47,7 +52,7 @@ for line in Lines:
# save test_file to a file named test.tmp # save test_file to a file named test.tmp
with open('test.tmp', 'w') as f: with open(sys.argv[1] + '/test.tmp', 'w') as f:
for item in test_file: for item in test_file:
f.write("%s\n" % item) f.write("%s\n" % item)
@ -66,6 +71,6 @@ for line in reversed(Lines):
break break
# save test_file to a file named test.tmp # save test_file to a file named test.tmp
with open('test.final.tmp', 'w') as f: with open(sys.argv[1] + '/test.final.tmp', 'w') as f:
for item in final_test_file: for item in final_test_file:
f.write("%s\n" % item) f.write("%s\n" % item)

View File

@ -1,5 +1,6 @@
all: all:
./../scripts/get_bin.sh ../tb/test_source_code/tb_riscv_cpu/test ./../scripts/get_bin.sh ../tb/test_source_code/tb_riscv_cpu/test
python3 ./../scripts/gen_test.py ../tb/test_source_code/tb_riscv_cpu test.S
vsim -c -do "do simu.do; quit -f" vsim -c -do "do simu.do; quit -f"
debug: debug:

View File

@ -53,7 +53,6 @@ module tb_risc_v_cpu ();
read_instruction_2 = $fgetc(bin_file_inputs); read_instruction_2 = $fgetc(bin_file_inputs);
read_instruction_3 = $fgetc(bin_file_inputs); read_instruction_3 = $fgetc(bin_file_inputs);
read_instruction_4 = $fgetc(bin_file_inputs); read_instruction_4 = $fgetc(bin_file_inputs);
$display("read_instruction_1: %b", read_instruction_1);
if ( if (
read_instruction_1[8] != 1'b1 && read_instruction_1[8] != 1'b1 &&
@ -91,8 +90,6 @@ module tb_risc_v_cpu ();
$finish; $finish;
end end
$display ("Line %d: %d:%b=%b ]", res, instruction_addr, reg_number, reg_test_value);
if (test[instruction_addr][5:0] == 6'b111111) begin if (test[instruction_addr][5:0] == 6'b111111) begin
test[instruction_addr][5:0] = reg_number; test[instruction_addr][5:0] = reg_number;
test[instruction_addr][37:6] = reg_test_value; test[instruction_addr][37:6] = reg_test_value;
@ -156,7 +153,6 @@ module tb_risc_v_cpu ();
while (!$feof(code_file_inputs)) while (!$feof(code_file_inputs))
begin begin
res = $fscanf(code_file_inputs, "%d=%d\n", reg_number, reg_test_value); res = $fscanf(code_file_inputs, "%d=%d\n", reg_number, reg_test_value);
$display ("Line %d: %b=%b ]", res, reg_number, reg_test_value);
if (res != 2) begin // If fscanf failed, the test file structure is wrong, then exit if (res != 2) begin // If fscanf failed, the test file structure is wrong, then exit
$display("Parsing test file failed"); $display("Parsing test file failed");
$finish; $finish;

View File

@ -1,11 +1,10 @@
# t0 = 0 # t0 = 0
li t0, 0 li t0, 0 # R[5]=0
li t2, 10 # R[2]=10, MEM[1]=6 li t2, 10 # R[7]=10
loop_head: loop_head:
bge t0, t2, loop_end bge t0, t2, loop_end
# Repeated code goes here # Repeated code goes here
addi t0, t0, 1 # PC=16 addi t0, t0, 1 # PC=16
j loop_head j loop_head
loop_end: loop_end:
# R[0]=0 # R[0]=0