forked from verilator/verilator
-
Notifications
You must be signed in to change notification settings - Fork 3
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Signed-off-by: Krzysztof Boronski <[email protected]>
- Loading branch information
1 parent
970b5fc
commit 61f2b02
Showing
13 changed files
with
5,840 additions
and
24 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,228 @@ | ||
// SPDX-License-Identifier: Apache-2.0 | ||
// | ||
//---------------------------------------------------------------------- | ||
// Copyright 2007-2018 Mentor Graphics Corporation | ||
// Copyright 2007-2018 Cadence Design Systems, Inc. | ||
// Copyright 2011 AMD | ||
// Copyright 2015-2018 NVIDIA Corporation | ||
// Copyright 2012 Accellera Systems Initiative | ||
// All Rights Reserved Worldwide | ||
// | ||
// 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. | ||
//---------------------------------------------------------------------- | ||
|
||
//-!!!- NOTICE -------------------------------------------------------------!!!- | ||
// This is a non-production-ready modified version of UVM intended for coverage | ||
// testing purpouses | ||
//-!!!----------------------------------------------------------------------!!!- | ||
|
||
//UVM typedef class uvm_build_phase; | ||
//UVM typedef class uvm_connect_phase; | ||
//UVM typedef class uvm_end_of_elaboration_phase; | ||
//UVM typedef class uvm_start_of_simulation_phase; | ||
//UVM typedef class uvm_run_phase; | ||
//UVM typedef class uvm_extract_phase; | ||
//UVM typedef class uvm_check_phase; | ||
//UVM typedef class uvm_report_phase; | ||
//UVM typedef class uvm_final_phase; | ||
//UVM | ||
//UVM typedef class uvm_pre_reset_phase; | ||
//UVM typedef class uvm_reset_phase; | ||
//UVM typedef class uvm_post_reset_phase; | ||
//UVM typedef class uvm_pre_configure_phase; | ||
//UVM typedef class uvm_configure_phase; | ||
//UVM typedef class uvm_post_configure_phase; | ||
//UVM typedef class uvm_pre_main_phase; | ||
//UVM typedef class uvm_main_phase; | ||
//UVM typedef class uvm_post_main_phase; | ||
//UVM typedef class uvm_pre_shutdown_phase; | ||
//UVM typedef class uvm_shutdown_phase; | ||
//UVM typedef class uvm_post_shutdown_phase; | ||
//UVM | ||
//UVM uvm_phase build_ph; | ||
//UVM uvm_phase connect_ph; | ||
//UVM uvm_phase end_of_elaboration_ph; | ||
//UVM uvm_phase start_of_simulation_ph; | ||
//UVM uvm_phase run_ph; | ||
//UVM uvm_phase extract_ph; | ||
//UVM uvm_phase check_ph; | ||
//UVM uvm_phase report_ph; | ||
|
||
//------------------------------------------------------------------------------ | ||
// | ||
// Class -- NODOCS -- uvm_domain | ||
// | ||
//------------------------------------------------------------------------------ | ||
// | ||
// Phasing schedule node representing an independent branch of the schedule. | ||
// Handle used to assign domains to components or hierarchies in the testbench | ||
// | ||
|
||
// @uvm-ieee 1800.2-2017 auto 9.4.1 | ||
class uvm_domain extends uvm_phase; | ||
|
||
static local uvm_domain m_uvm_domain; // run-time phases | ||
static local uvm_domain m_domains[string]; | ||
static local uvm_phase m_uvm_schedule; | ||
|
||
//UVM | ||
static function uvmt_drop_globals(); | ||
m_uvm_domain = null; | ||
m_domains.delete(); | ||
m_uvm_schedule = null; | ||
endfunction | ||
//UVM | ||
|
||
// @uvm-ieee 1800.2-2017 auto 9.4.2.2 | ||
static function void get_domains(output uvm_domain domains[string]); | ||
domains = m_domains; | ||
endfunction | ||
|
||
|
||
// Function -- NODOCS -- get_uvm_schedule | ||
// | ||
// Get the "UVM" schedule, which consists of the run-time phases that | ||
// all components execute when participating in the "UVM" domain. | ||
// | ||
static function uvm_phase get_uvm_schedule(); | ||
void'(get_uvm_domain()); | ||
return m_uvm_schedule; | ||
endfunction | ||
|
||
|
||
// Function -- NODOCS -- get_common_domain | ||
// | ||
// Get the "common" domain, which consists of the common phases that | ||
// all components execute in sync with each other. Phases in the "common" | ||
// domain are build, connect, end_of_elaboration, start_of_simulation, run, | ||
// extract, check, report, and final. | ||
// | ||
static function uvm_domain get_common_domain(); | ||
|
||
uvm_domain domain; | ||
|
||
if(m_domains.exists("common")) | ||
domain = m_domains["common"]; | ||
|
||
if (domain != null) | ||
return domain; | ||
|
||
domain = new("common"); | ||
//UVM domain.add(uvm_build_phase::get()); | ||
//UVM domain.add(uvm_connect_phase::get()); | ||
//UVM domain.add(uvm_end_of_elaboration_phase::get()); | ||
//UVM domain.add(uvm_start_of_simulation_phase::get()); | ||
//UVM domain.add(uvm_run_phase::get()); | ||
//UVM domain.add(uvm_extract_phase::get()); | ||
//UVM domain.add(uvm_check_phase::get()); | ||
//UVM domain.add(uvm_report_phase::get()); | ||
//UVM domain.add(uvm_final_phase::get()); | ||
//UVM | ||
//UVM // for backward compatibility, make common phases visible; | ||
//UVM // same as uvm_<name>_phase::get(). | ||
//UVM build_ph = domain.find(uvm_build_phase::get()); | ||
//UVM connect_ph = domain.find(uvm_connect_phase::get()); | ||
//UVM end_of_elaboration_ph = domain.find(uvm_end_of_elaboration_phase::get()); | ||
//UVM start_of_simulation_ph = domain.find(uvm_start_of_simulation_phase::get()); | ||
//UVM run_ph = domain.find(uvm_run_phase::get()); | ||
//UVM extract_ph = domain.find(uvm_extract_phase::get()); | ||
//UVM check_ph = domain.find(uvm_check_phase::get()); | ||
//UVM report_ph = domain.find(uvm_report_phase::get()); | ||
|
||
domain = get_uvm_domain(); | ||
//UVM m_domains["common"].add(domain, | ||
//UVM .with_phase(m_domains["common"].find(uvm_run_phase::get()))); | ||
// Temporarily remove default run phase | ||
//UVM | ||
|
||
return m_domains["common"]; | ||
|
||
endfunction | ||
|
||
|
||
|
||
// @uvm-ieee 1800.2-2017 auto 9.4.2.3 | ||
static function void add_uvm_phases(uvm_phase schedule); | ||
//UVM | ||
$display("[uvm]: WARNING: add_uvm_phases is a stub"); | ||
//UVM | ||
//UVM schedule.add(uvm_pre_reset_phase::get()); | ||
//UVM schedule.add(uvm_reset_phase::get()); | ||
//UVM schedule.add(uvm_post_reset_phase::get()); | ||
//UVM schedule.add(uvm_pre_configure_phase::get()); | ||
//UVM schedule.add(uvm_configure_phase::get()); | ||
//UVM schedule.add(uvm_post_configure_phase::get()); | ||
//UVM schedule.add(uvm_pre_main_phase::get()); | ||
//UVM schedule.add(uvm_main_phase::get()); | ||
//UVM schedule.add(uvm_post_main_phase::get()); | ||
//UVM schedule.add(uvm_pre_shutdown_phase::get()); | ||
//UVM schedule.add(uvm_shutdown_phase::get()); | ||
//UVM schedule.add(uvm_post_shutdown_phase::get()); | ||
|
||
endfunction | ||
|
||
|
||
// Function -- NODOCS -- get_uvm_domain | ||
// | ||
// Get a handle to the singleton ~uvm~ domain | ||
// | ||
static function uvm_domain get_uvm_domain(); | ||
|
||
if (m_uvm_domain == null) begin | ||
m_uvm_domain = new("uvm"); | ||
m_uvm_schedule = new("uvm_sched", UVM_PHASE_SCHEDULE); | ||
add_uvm_phases(m_uvm_schedule); | ||
//UVM m_uvm_domain.add(m_uvm_schedule); | ||
end | ||
return m_uvm_domain; | ||
endfunction | ||
|
||
|
||
|
||
// @uvm-ieee 1800.2-2017 auto 9.4.2.1 | ||
function new(string name); | ||
super.new(name,UVM_PHASE_DOMAIN); | ||
if (m_domains.exists(name)) | ||
`uvm_error("UNIQDOMNAM", $sformatf("Domain created with non-unique name '%s'", name)) | ||
m_domains[name] = this; | ||
endfunction | ||
|
||
|
||
// @uvm-ieee 1800.2-2017 auto 9.4.2.4 | ||
function void jump(uvm_phase phase); | ||
uvm_phase phases[$]; | ||
|
||
m_get_transitive_children(phases); | ||
|
||
phases = phases.find(item) with (item.get_state() inside {[UVM_PHASE_STARTED:UVM_PHASE_CLEANUP]}); | ||
|
||
foreach(phases[idx]) | ||
if(phases[idx].is_before(phase) || phases[idx].is_after(phase)) | ||
phases[idx].jump(phase); | ||
|
||
endfunction | ||
|
||
// jump_all | ||
// -------- | ||
static function void jump_all(uvm_phase phase); | ||
uvm_domain domains[string]; | ||
|
||
uvm_domain::get_domains(domains); | ||
|
||
foreach(domains[idx]) | ||
domains[idx].jump(phase); | ||
|
||
endfunction | ||
endclass |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,46 @@ | ||
// SPDX-License-Identifier: Apache-2.0 | ||
// | ||
//------------------------------------------------------------------------------ | ||
// Copyright 2007-2011 Mentor Graphics Corporation | ||
// Copyright 2017 Intel Corporation | ||
// Copyright 2010 Synopsys, Inc. | ||
// Copyright 2007-2018 Cadence Design Systems, Inc. | ||
// Copyright 2010 AMD | ||
// Copyright 2015-2018 NVIDIA Corporation | ||
// All Rights Reserved Worldwide | ||
// | ||
// 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. | ||
//------------------------------------------------------------------------------ | ||
|
||
typedef enum { UVM_PHASE_UNINITIALIZED = 0, | ||
UVM_PHASE_DORMANT = 1, | ||
UVM_PHASE_SCHEDULED = 2, | ||
UVM_PHASE_SYNCING = 4, | ||
UVM_PHASE_STARTED = 8, | ||
UVM_PHASE_EXECUTING = 16, | ||
UVM_PHASE_READY_TO_END = 32, | ||
UVM_PHASE_ENDED = 64, | ||
UVM_PHASE_CLEANUP = 128, | ||
UVM_PHASE_DONE = 256, | ||
UVM_PHASE_JUMPING = 512 | ||
} uvm_phase_state; | ||
|
||
typedef enum { UVM_PHASE_IMP, | ||
UVM_PHASE_NODE, | ||
UVM_PHASE_TERMINAL, | ||
UVM_PHASE_SCHEDULE, | ||
UVM_PHASE_DOMAIN, | ||
UVM_PHASE_GLOBAL | ||
} uvm_phase_type; |
Oops, something went wrong.