Skip to content

Commit

Permalink
[chip,dv] Adjust reset and external clock location for rom_raw_unlock…
Browse files Browse the repository at this point in the history
… test

`apply_reset` turned off bypass_enable.
After reset, test needs to re-enable bypass clock to supply external clock.

Signed-off-by: Jaedon Kim <jdonjdon@opentitan.org>
  • Loading branch information
jdonjdon committed Jun 28, 2023
1 parent fd9a3c1 commit 21ce4e9
Showing 1 changed file with 17 additions and 3 deletions.
20 changes: 17 additions & 3 deletions hw/top_earlgrey/dv/env/seq_lib/chip_sw_lc_raw_unlock_vseq.sv
Original file line number Diff line number Diff line change
Expand Up @@ -62,15 +62,29 @@ class chip_sw_lc_raw_unlock_vseq extends chip_sw_base_vseq;
// Since super.body only does backdoor operation,
// add wait for clock task before the test uses jtag polling task.
wait_rom_check_done();
wait_lc_ready(1);
wait_lc_ready();

// Switch to external clock via lc_ctrl TAP, and perform RAW unlock. This
// requires a reset to apply the transition.
switch_to_external_clock();
jtag_lc_state_transition(DecLcStRaw, DecLcStTestUnlocked0);

cfg.chip_vif.tap_straps_if.drive(JtagTapRvDm);
// Complete state transition
apply_reset();
wait_lc_ready();

// After reset, clock bypass back to 'off'.
// Resume external clock before switch jtag_tap, otherwise,
// external clock is disconnected.
claim_transition_interface();
jtag_riscv_agent_pkg::jtag_write_csr(
ral.lc_ctrl.transition_ctrl.get_offset(),
p_sequencer.jtag_sequencer_h,
1);
// Add some delay until clock bypass is turned on.
cfg.chip_vif.ext_clk_if.wait_clks(10);

// Switch tap to rvdm
cfg.chip_vif.tap_straps_if.drive(JtagTapRvDm);
reset_jtag_tap();

if (rom_prod_mode) begin
Expand Down

0 comments on commit 21ce4e9

Please sign in to comment.