Skip to content

Commit

Permalink
Merge pull request #2346 from MikeOpenHWGroup/cv32e40p/dev-mt1084-2
Browse files Browse the repository at this point in the history
Flag duplicate properties for future FIXME
  • Loading branch information
MikeOpenHWGroup authored Jan 3, 2024
2 parents 35b217d + 17a96c9 commit 6288aff
Showing 1 changed file with 17 additions and 2 deletions.
19 changes: 17 additions & 2 deletions cv32e40p/tb/uvmt/uvmt_cv32e40p_debug_assert.sv
Original file line number Diff line number Diff line change
Expand Up @@ -116,6 +116,18 @@ module uvmt_cv32e40p_debug_assert
else
`uvm_error(info_tag,$sformatf("Debug mode with wrong cause after ebreak, case = %d",cov_assert_if.dcsr_q[8:6]));

////////////////////////////////////////////////////////////////////////////
// FIXME: start
// It appears that the properties "p_cebreak_exception" and
// "p_ebreak_exception" are identical in all but name. However, at
// the time of this writting (2024-01-03) it has been deemed too
// risky to clean this up as the CV32E40P v2.0.0 is driving toward
// closing coverage.
//
// Before conducting any future maintenance of this code, refactor with <name of other property>.
// See GitHub issue #1084.


// c.ebreak without dcsr.ebreakm results in exception at mtvec
// Exclude single stepping as the sequence gets very complicated
property p_cebreak_exception;
Expand All @@ -126,7 +138,7 @@ module uvmt_cv32e40p_debug_assert
&& (cov_assert_if.mepc_q == pc_at_ebreak) &&
(cov_assert_if.id_stage_pc == cov_assert_if.mtvec);
endproperty

a_cebreak_exception: assert property(p_cebreak_exception)
else
`uvm_error(info_tag,$sformatf("Exception not entered correctly after c.ebreak with dcsr.ebreak=0"));
Expand All @@ -141,13 +153,16 @@ module uvmt_cv32e40p_debug_assert
&& (cov_assert_if.mepc_q == pc_at_ebreak) &&
(cov_assert_if.id_stage_pc == cov_assert_if.mtvec);
endproperty

// TODO: Fails formal as above
a_ebreak_exception: assert property(p_ebreak_exception)
else
`uvm_error(info_tag,$sformatf("Exception not entered correctly after ebreak with dcsr.ebreak=0"));
// c.ebreak during debug mode results in relaunch of debug mode

// FIXME: end
////////////////////////////////////////////////////////////////////////////

property p_cebreak_during_debug_mode;
$rose(cov_assert_if.is_cebreak) ##0 cov_assert_if.debug_mode_q |-> decode_valid [->2] ##0 cov_assert_if.debug_mode_q &&
(cov_assert_if.id_stage_pc == halt_addr_at_entry); // TODO should check no change in dpc and dcsr
Expand Down

0 comments on commit 6288aff

Please sign in to comment.