blob: 15a256b41276392eb1a814a5e10a9593daacd339 [file] [log] [blame]
// Copyright lowRISC contributors.
// Licensed under the Apache License, Version 2.0, see LICENSE for details.
// SPDX-License-Identifier: Apache-2.0
class chip_env extends dv_base_env #(
.CFG_T (chip_env_cfg),
.COV_T (chip_env_cov),
.VIRTUAL_SEQUENCER_T(chip_virtual_sequencer),
.SCOREBOARD_T (chip_scoreboard)
);
`uvm_component_utils(chip_env)
uart_agent m_uart_agent;
jtag_agent m_jtag_agent;
tl_agent m_cpu_d_tl_agent;
chip_tl_reg_adapter m_cpu_d_tl_reg_adapter;
`uvm_component_new
function void build_phase(uvm_phase phase);
super.build_phase(phase);
// configure the cpu d tl agent
if (cfg.m_cpu_d_tl_agent_cfg.is_active && cfg.zero_delays) begin
cfg.m_cpu_d_tl_agent_cfg.a_valid_delay_min = 0;
cfg.m_cpu_d_tl_agent_cfg.a_valid_delay_max = 0;
cfg.m_cpu_d_tl_agent_cfg.d_valid_delay_min = 0;
cfg.m_cpu_d_tl_agent_cfg.d_valid_delay_max = 0;
cfg.m_cpu_d_tl_agent_cfg.a_ready_delay_min = 0;
cfg.m_cpu_d_tl_agent_cfg.a_ready_delay_max = 0;
cfg.m_cpu_d_tl_agent_cfg.d_ready_delay_min = 0;
cfg.m_cpu_d_tl_agent_cfg.d_ready_delay_max = 0;
end
// get the vifs from config db
if (!uvm_config_db#(gpio_vif)::get(this, "", "gpio_vif", cfg.gpio_vif)) begin
`uvm_fatal(`gfn, "failed to get gpio_vif from uvm_config_db")
end
foreach (cfg.mem_bkdr_vifs[mem]) begin
if (!uvm_config_db#(mem_bkdr_vif)::get(this, "", $sformatf("mem_bkdr_vifs[%0s]", mem.name),
cfg.mem_bkdr_vifs[mem])) begin
`uvm_fatal(`gfn, $sformatf("failed to get mem_bkdr_vifs[%0s] from uvm_config_db", mem.name))
end
end
if (!uvm_config_db#(sw_msg_monitor_vif)::get(this, "", "sw_msg_monitor_vif",
cfg.sw_msg_monitor_vif)) begin
`uvm_fatal(`gfn, "failed to get sw_msg_monitor_vif from uvm_config_db")
end
// create components
m_uart_agent = uart_agent::type_id::create("m_uart_agent", this);
uvm_config_db#(uart_agent_cfg)::set(this, "m_uart_agent*", "cfg", cfg.m_uart_agent_cfg);
m_jtag_agent = jtag_agent::type_id::create("m_jtag_agent", this);
uvm_config_db#(jtag_agent_cfg)::set(this, "m_jtag_agent*", "cfg", cfg.m_jtag_agent_cfg);
m_cpu_d_tl_agent = tl_agent::type_id::create("m_cpu_d_tl_agent", this);
m_cpu_d_tl_reg_adapter = chip_tl_reg_adapter::type_id::create("m_cpu_d_tl_reg_adapter");
uvm_config_db#(tl_agent_cfg)::set(this, "m_cpu_d_tl_agent*", "cfg", cfg.m_cpu_d_tl_agent_cfg);
endfunction
function void connect_phase(uvm_phase phase);
super.connect_phase(phase);
if (cfg.en_scb) begin
m_uart_agent.monitor.tx_analysis_port.connect(scoreboard.uart_tx_fifo.analysis_export);
m_uart_agent.monitor.rx_analysis_port.connect(scoreboard.uart_rx_fifo.analysis_export);
m_jtag_agent.monitor.analysis_port.connect(scoreboard.jtag_fifo.analysis_export);
// TODO: add scoreboard connections for monitoring tl accesses
// m_cpu_d_tl_agent.mon.a_chan_port.connect(scoreboard.tl_a_chan_fifo.analysis_export);
// m_cpu_d_tl_agent.mon.d_chan_port.connect(scoreboard.tl_d_chan_fifo.analysis_export);
end
if (cfg.is_active && cfg.m_uart_agent_cfg.is_active) begin
virtual_sequencer.uart_sequencer_h = m_uart_agent.sequencer;
end
if (cfg.is_active && cfg.m_jtag_agent_cfg.is_active) begin
virtual_sequencer.jtag_sequencer_h = m_jtag_agent.sequencer;
end
if (cfg.is_active && cfg.m_cpu_d_tl_agent_cfg.is_active) begin
virtual_sequencer.cpu_d_tl_sequencer_h = m_cpu_d_tl_agent.sequencer;
end
endfunction
virtual function void end_of_elaboration_phase(uvm_phase phase);
super.end_of_elaboration_phase(phase);
if (cfg.stub_cpu) begin
// Set the TL adapter / sequencer to the default_map.
cfg.ral.default_map.set_sequencer(m_cpu_d_tl_agent.sequencer, m_cpu_d_tl_reg_adapter);
end
endfunction : end_of_elaboration_phase
endclass