-
Notifications
You must be signed in to change notification settings - Fork 44
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Fix PC setup after waking from clock gating in Verilator #380
base: main
Are you sure you want to change the base?
Conversation
@robertszczepanski - Is this change an enhancement or a bug? |
@Nitsirks - can u plz paste the waveform too showing the necessary signals? |
@robertszczepanski - I am inclined to reject this in the current generation of HW as we don't want to take any enhancements at this stage. Plz review the waveform that Mike pasted above and let us know if you have any questions. |
Thank you for your feedback @Nitsirks @bharatpillilli. As pointed out as a reference in chipsalliance/Cores-VeeR-EL2#88, I was testing this using src/integration/test_suites/smoke_test_cg_wdt and I was able to reproduce a bug in the Verilator simulation. From my understanding it's a bug caused by the usage of @Nitsirks can you please point me to the test that you've run in order to verify the described behavior in simulation and get the waveforms, so I can reproduce it? |
It's the same test in VCS. Mike can correct me if I am wrong. |
I ran smoke_test_clk_gating to verify the behavior. I see why Verilator is failing now. The code in `TEC_RV_ICG is wrong for VERILATOR.
The VERILATOR code is modeling a negedge flop, while the real code is modeling a latch. In simulation the enable passes through the open latch to get captured by the first rising edge of the flop. In VERILATOR the enable can't propagate until the clock arrives, so it's 1 clock late. |
28bfc71
to
4ce5f4d
Compare
4ce5f4d
to
b59a04e
Compare
Internal-tag: [#53905] Signed-off-by: Robert Szczepanski <[email protected]>
Internal-tag: [#53905] Signed-off-by: Robert Szczepanski <[email protected]>
b59a04e
to
137a8da
Compare
I've removed different RTL for Verilator simulation and uncommented few additional tests that now successfully pass in CI. This resolves issues in simulation, waveform analysis confirms the correct behavior of PC after waking up from clock gating. PR description has been accordingly updated. |
@Nitsirks - if you can also confirm that we need these changes and they look good, I will approve/merge the PR. |
I think allowing verilator to implement the latch fixed the issue Kiran filed. Do we know if verilator runs take longer now? The quote above mentioned disabled performance optimizations around latches. |
Worth rebasing for conflict resolution |
This PR addresses issues reported in caliptra-sw#1220 and VeeR-EL2#88.
The
TEC_RV_ICG
module used inrvdffpcie
operates on different logic for Verilator,enable
signal is only sampled on negative clock edge. This change removes such exception and makes it possible to correctly simulate clock gating tests in Verilator. It resolves an issue with incorrect PC after waking up from clock gating and ensures proper CPU behavior. In the same time it keeps usage of the dff dedicated for PC related signals.