// SPDX-FileCopyrightText: 2020 Efabless Corporation // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // SPDX-License-Identifier: Apache-2.0 `default_nettype none `timescale 1 ns / 1 ps `include "defines.v" `include "housekeeping_spi.v" `include "housekeeping.v" module sysctrl_wb_tb; reg wb_clk_i; reg wb_rst_i; reg wb_stb_i; reg wb_cyc_i; reg wb_we_i; reg [3:0] wb_sel_i; reg [31:0] wb_dat_i; reg [31:0] wb_adr_i; wire wb_ack_o; wire [31:0] wb_dat_o; initial begin wb_clk_i = 0; wb_rst_i = 0; wb_stb_i = 0; wb_cyc_i = 0; wb_sel_i = 0; wb_we_i = 0; wb_dat_i = 0; wb_adr_i = 0; end always #1 wb_clk_i = ~wb_clk_i; initial begin $dumpfile("sysctrl_wb_tb.vcd"); $dumpvars(0, sysctrl_wb_tb); repeat (50) begin repeat (1000) @(posedge wb_clk_i); end $display("%c[1;31m",27); $display ("Monitor: Timeout, Test System Control Failed"); $display("%c[0m",27); $finish; end integer i; // System Control Default Register Addresses wire [31:0] clk_out_adr = uut.SYS_BASE_ADR | 8'h1b; wire [31:0] trap_out_adr = uut.SYS_BASE_ADR | 8'h1b; wire [31:0] irq_src_adr = uut.SYS_BASE_ADR | 8'h1c; reg clk1_output_dest; reg clk2_output_dest; reg trap_output_dest; reg irq_7_inputsrc; reg irq_8_inputsrc; initial begin // Reset Operation wb_rst_i = 1; #2; wb_rst_i = 0; #2; clk1_output_dest = 1'b1; clk2_output_dest = 1'b1; trap_output_dest = 1'b1; irq_7_inputsrc = 1'b1; irq_8_inputsrc = 1'b1; // Write to System Control Registers write(clk_out_adr, clk1_output_dest); write(trap_out_adr, trap_output_dest); write(irq_src_adr, irq_7_inputsrc); #2; read(clk_out_adr); if (wb_dat_o !== clk1_output_dest) begin $display("Error reading CLK1 output destination register."); $finish; end read(trap_out_adr); if (wb_dat_o !== trap_output_dest) begin $display("Error reading trap output destination register."); $finish; end read(irq_src_adr); if (wb_dat_o !== irq_7_inputsrc) begin $display("Error reading IRQ7 input source register."); $finish; end $display("Success!"); $display ("Monitor: Test System Control Passed!"); $finish; end task write; input [32:0] addr; input [32:0] data; begin @(posedge wb_clk_i) begin wb_stb_i = 1; wb_cyc_i = 1; wb_sel_i = 4'hF; wb_we_i = 1; wb_adr_i = addr; wb_dat_i = data; $display("Monitor: Write Cycle Started."); end // Wait for an ACK wait(wb_ack_o == 1); wait(wb_ack_o == 0); wb_cyc_i = 0; wb_stb_i = 0; $display("Monitor: Write Cycle Ended."); end endtask task read; input [32:0] addr; begin @(posedge wb_clk_i) begin wb_stb_i = 1; wb_cyc_i = 1; wb_we_i = 0; wb_adr_i = addr; $display("Monitor: Read Cycle Started."); end // Wait for an ACK wait(wb_ack_o == 1); wait(wb_ack_o == 0); wb_cyc_i = 0; wb_stb_i = 0; $display("Monitor: Read Cycle Ended."); end endtask housekeeping uut( .wb_clk_i(wb_clk_i), .wb_rst_i(wb_rst_i), .wb_stb_i(wb_stb_i), .wb_cyc_i(wb_cyc_i), .wb_sel_i(wb_sel_i), .wb_we_i(wb_we_i), .wb_dat_i(wb_dat_i), .wb_adr_i(wb_adr_i), .wb_ack_o(wb_ack_o), .wb_dat_o(wb_dat_o) ); endmodule