2023-10-21 13:57:58 +00:00
|
|
|
`timescale 1ns / 1ps
|
2023-10-23 08:34:37 +00:00
|
|
|
`include "tb_tools.vh"
|
2023-10-21 13:57:58 +00:00
|
|
|
|
|
|
|
module tb_risc_v_cpu ();
|
2023-10-23 05:15:21 +00:00
|
|
|
reg clk;
|
|
|
|
reg reset;
|
|
|
|
integer i;
|
|
|
|
wire [31:0] out;
|
|
|
|
|
|
|
|
risc_v_cpu risc_v_cpu (
|
|
|
|
.clock(clk),
|
|
|
|
.reset(reset),
|
|
|
|
.out(out)
|
|
|
|
);
|
|
|
|
|
|
|
|
initial begin
|
2023-10-24 12:19:24 +00:00
|
|
|
/* Reset */
|
2023-10-23 05:15:21 +00:00
|
|
|
reset = 1'b1;
|
|
|
|
#10
|
|
|
|
reset = 1'b0;
|
2023-10-22 13:41:39 +00:00
|
|
|
|
2023-10-23 05:15:21 +00:00
|
|
|
clk = 1'b0;
|
2023-10-24 12:19:24 +00:00
|
|
|
|
|
|
|
/* Fibonacci */
|
|
|
|
|
|
|
|
/* ADDi $1, R[0], R[6] - R[6] = 1 */
|
|
|
|
/* "000000000001_00000_000_00110_0010000" */
|
2023-10-24 12:52:07 +00:00
|
|
|
risc_v_cpu.uut_instruction.memory[0] = 8'b00010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[1] = 8'b00000011;
|
|
|
|
risc_v_cpu.uut_instruction.memory[2] = 8'b00010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[3] = 8'b00000000;
|
2023-10-24 12:19:24 +00:00
|
|
|
|
|
|
|
/* ADDi $0, R[0], R[7] - R[7] = 0 */
|
|
|
|
/* "000000000000_00000_000_00111_0010000" */
|
2023-10-24 12:52:07 +00:00
|
|
|
risc_v_cpu.uut_instruction.memory[4] = 8'b10010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[5] = 8'b00000011;
|
|
|
|
risc_v_cpu.uut_instruction.memory[6] = 8'b00000000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[7] = 8'b00000000;
|
2023-10-24 12:19:24 +00:00
|
|
|
|
|
|
|
/* ADDi $0, R[6], R[8] - R[8] = R[6] */
|
|
|
|
/* "000000000000_00110_000_01000_0010000" */
|
2023-10-24 12:52:07 +00:00
|
|
|
risc_v_cpu.uut_instruction.memory[8] = 8'b00010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[9] = 8'b00000100;
|
|
|
|
risc_v_cpu.uut_instruction.memory[10] = 8'b00000011;
|
|
|
|
risc_v_cpu.uut_instruction.memory[11] = 8'b00000000;
|
2023-10-24 12:19:24 +00:00
|
|
|
|
|
|
|
/* ADD R[7], R[6], R[6] - R[6] = R[7] + R[6] */
|
|
|
|
/* "0000000_00111_00110_000_00110_0110000" */
|
2023-10-24 12:52:07 +00:00
|
|
|
risc_v_cpu.uut_instruction.memory[12] = 8'b00110000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[13] = 8'b00000011;
|
|
|
|
risc_v_cpu.uut_instruction.memory[14] = 8'b01110011;
|
|
|
|
risc_v_cpu.uut_instruction.memory[15] = 8'b00000000;
|
2023-10-24 12:19:24 +00:00
|
|
|
|
|
|
|
/* ADDi $0, R[8], R[7] - R[7] = R[8] */
|
|
|
|
/* "000000000000_01000_000_00111_0010000" */
|
2023-10-24 12:52:07 +00:00
|
|
|
risc_v_cpu.uut_instruction.memory[16] = 8'b10010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[17] = 8'b00000011;
|
|
|
|
risc_v_cpu.uut_instruction.memory[18] = 8'b00000100;
|
|
|
|
risc_v_cpu.uut_instruction.memory[19] = 8'b00000000;
|
2023-10-24 12:19:24 +00:00
|
|
|
|
|
|
|
/* JUMP - 12 */
|
|
|
|
/* 11111111111111111101_00111_1101100 */
|
2023-10-24 12:52:07 +00:00
|
|
|
risc_v_cpu.uut_instruction.memory[20] = 8'b11101100;
|
|
|
|
risc_v_cpu.uut_instruction.memory[21] = 8'b01000010;
|
|
|
|
risc_v_cpu.uut_instruction.memory[22] = 8'b11111111;
|
|
|
|
risc_v_cpu.uut_instruction.memory[23] = 8'b11111111;
|
2023-10-24 12:19:24 +00:00
|
|
|
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO INIT: ADDi $1, R[0], R[6] - R[6] = 1", risc_v_cpu.registers_bank.registers[6], 1)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO INIT: ADDi $0, R[0], R[7] - R[7] = 0", risc_v_cpu.registers_bank.registers[7], 0)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 1: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 1)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 1: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 1)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 1: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 1)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 1: 1", risc_v_cpu.registers_bank.registers[7], 1)
|
|
|
|
`assert_no_wait("FIBO CYCLE 1: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 2: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 1)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 2: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 2)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 2: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 1)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 2: 1", risc_v_cpu.registers_bank.registers[7], 1)
|
|
|
|
`assert_no_wait("FIBO CYCLE 2: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 3: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 2)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 3: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 3)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 3: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 2)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 3: 2", risc_v_cpu.registers_bank.registers[7], 2)
|
|
|
|
`assert_no_wait("FIBO CYCLE 3: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 4: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 3)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 4: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 5)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 4: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 3)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 4: 3", risc_v_cpu.registers_bank.registers[7], 3)
|
|
|
|
`assert_no_wait("FIBO CYCLE 4: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 5: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 5)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 5: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 5: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 5)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 5: 5", risc_v_cpu.registers_bank.registers[7], 5)
|
|
|
|
`assert_no_wait("FIBO CYCLE 5: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 6: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 6: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 13)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 6: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 6: 8", risc_v_cpu.registers_bank.registers[7], 8)
|
|
|
|
`assert_no_wait("FIBO CYCLE 6: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 7: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 13)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 7: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 21)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 7: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 13)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 7: 13", risc_v_cpu.registers_bank.registers[7], 13)
|
|
|
|
`assert_no_wait("FIBO CYCLE 7: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 8: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 21)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 8: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 34)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 8: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 21)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 8: 21", risc_v_cpu.registers_bank.registers[7], 21)
|
|
|
|
`assert_no_wait("FIBO CYCLE 8: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 9: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 34)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 9: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 55)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 9: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 34)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 9: 34", risc_v_cpu.registers_bank.registers[7], 34)
|
|
|
|
`assert_no_wait("FIBO CYCLE 9: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 10: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 55)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 10: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 89)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 10: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 55)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 10: 55", risc_v_cpu.registers_bank.registers[7], 55)
|
|
|
|
`assert_no_wait("FIBO CYCLE 10: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 11: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 89)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 11: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 144)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 11: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 89)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 11: 89", risc_v_cpu.registers_bank.registers[7], 89)
|
|
|
|
`assert_no_wait("FIBO CYCLE 11: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 12: ADDi $0, R[6], R[8] - R[8] = R[6]", risc_v_cpu.registers_bank.registers[8], 144)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 12: ADD R[7], R[6], R[6] - R[6] = R[7] + R[6]", risc_v_cpu.registers_bank.registers[6], 233)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO CYCLE 12: ADDi $0, R[8], R[7] - R[7] = R[8]", risc_v_cpu.registers_bank.registers[7], 144)
|
|
|
|
`next_cycle
|
|
|
|
`assert_no_wait("FIBO VALUE 12: 144", risc_v_cpu.registers_bank.registers[7], 144)
|
|
|
|
`assert_no_wait("FIBO CYCLE 12: JUMP - 12", risc_v_cpu.program_counter.pc_addr, 8)
|
|
|
|
|
2023-10-25 02:07:19 +00:00
|
|
|
/* Reset */
|
|
|
|
reset = 1'b1;
|
|
|
|
#10
|
|
|
|
reset = 1'b0;
|
|
|
|
|
|
|
|
clk = 1'b0;
|
|
|
|
|
|
|
|
/* BUBBLE SORT
|
|
|
|
int len = 10;
|
|
|
|
int array[] = {10, 9, 8, 7, 6, 5, 4, 3, 2, 1};
|
|
|
|
|
|
|
|
for (int i = len - 1; i > 0; i--)
|
|
|
|
{
|
|
|
|
for (int j = 0; j < i; j++)
|
|
|
|
{
|
|
|
|
if (array[j] > array[j + 1])
|
|
|
|
{
|
|
|
|
int temp = array[j];
|
|
|
|
array[j] = array[j + 1];
|
|
|
|
array[j + 1] = temp;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* BUBBLE SORT */
|
|
|
|
|
|
|
|
/* ADDi $10, R[0], R[1] - R[1] = 10 */
|
|
|
|
/* "000000001010_00000_000_00001_0010000" */
|
|
|
|
risc_v_cpu.uut_instruction.memory[0] = 8'b10010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[1] = 8'b00000000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[2] = 8'b10100000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[3] = 8'b00000000;
|
|
|
|
|
|
|
|
/* ADDi $10, R[0], R[2] - R[2] = 10 */
|
|
|
|
/* "000000001010_00000_000_00010_0010000" */
|
|
|
|
risc_v_cpu.uut_instruction.memory[4] = 8'b00010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[5] = 8'b00000001;
|
|
|
|
risc_v_cpu.uut_instruction.memory[6] = 8'b10100000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[7] = 8'b00000000;
|
|
|
|
|
|
|
|
/* ADDi $0, R[0], R[3] - R[2] = 10 */
|
|
|
|
/* "000000000000_00000_000_00011_0010000" */
|
|
|
|
risc_v_cpu.uut_instruction.memory[8] = 8'b10010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[9] = 8'b00000001;
|
|
|
|
risc_v_cpu.uut_instruction.memory[10] = 8'b00000000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[11] = 8'b00000000;
|
|
|
|
|
|
|
|
/* STR $0, R[0], R[2], MEM[0] = 10 */
|
|
|
|
/* "0000000_00010_00000_000_00000_0100000" */
|
|
|
|
risc_v_cpu.uut_instruction.memory[12] = 8'b00100000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[13] = 8'b00000000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[14] = 8'b00100000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[15] = 8'b00000000;
|
|
|
|
|
|
|
|
/* ADDi $-1, R[2], R[2] - R[2] = 9 */
|
|
|
|
/* "111111111111_00010_000_00010_0010000" */
|
|
|
|
risc_v_cpu.uut_instruction.memory[16] = 8'b00010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[17] = 8'b00000001;
|
|
|
|
risc_v_cpu.uut_instruction.memory[18] = 8'b11110001;
|
|
|
|
risc_v_cpu.uut_instruction.memory[19] = 8'b11111111;
|
|
|
|
|
|
|
|
/* ADDi $1, R[3], R[3] - R[3] = 1 */
|
|
|
|
/* "000000000001_00011_000_00011_0010000" */
|
|
|
|
risc_v_cpu.uut_instruction.memory[20] = 8'b10010000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[21] = 8'b10000001;
|
|
|
|
risc_v_cpu.uut_instruction.memory[22] = 8'b00010001;
|
|
|
|
risc_v_cpu.uut_instruction.memory[23] = 8'b00000000;
|
|
|
|
|
|
|
|
/* BNE -8, R[0], R[2] - R[2] = 9 */
|
|
|
|
/* "1111111_00010_00000_001_10111_1100000" */
|
|
|
|
risc_v_cpu.uut_instruction.memory[24] = 8'b01100000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[25] = 8'b00011100;
|
|
|
|
risc_v_cpu.uut_instruction.memory[26] = 8'b00100000;
|
|
|
|
risc_v_cpu.uut_instruction.memory[27] = 8'b11111110;
|
|
|
|
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
`next_cycle
|
|
|
|
|
2023-10-24 12:19:24 +00:00
|
|
|
`end_message
|
2023-10-22 13:41:39 +00:00
|
|
|
end
|
|
|
|
|
2023-10-21 13:57:58 +00:00
|
|
|
endmodule : tb_risc_v_cpu
|