Skip to content

Commit

Permalink
Update instruction cache with injection testing
Browse files Browse the repository at this point in the history
  • Loading branch information
micprog authored and Andrea Belano committed Dec 19, 2024
1 parent c1f176f commit 1eb04b0
Show file tree
Hide file tree
Showing 4 changed files with 39 additions and 3 deletions.
2 changes: 1 addition & 1 deletion Bender.lock
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ packages:
dependencies:
- common_cells
cluster_icache:
revision: 8114ab36fd446f76cd1e9f139f12a62ab1fb9a6a
revision: dd0e8f3497903a9ca99fc9f349d5a4f688ceb3ae
version: null
source:
Git: https://github.com/pulp-platform/cluster_icache.git
Expand Down
2 changes: 1 addition & 1 deletion Bender.yml
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ dependencies:
mchan: { git: "https://github.com/pulp-platform/mchan.git", rev: 7f064f205a3e0203e959b14773c4afecf56681ab } # branch: yt/fix-parametrization
idma: { git: "https://github.com/pulp-platform/iDMA.git", rev: 437ffa9dac5dea0daccfd3e8ae604d4f6ae2cdf1 } # branch: master
hier-icache: { git: "https://github.com/pulp-platform/hier-icache.git", rev: "2886cb2a46cea3e2bd2d979b505d88fadfbe150c" } # branch: astral
cluster_icache: { git: "https://github.com/pulp-platform/cluster_icache.git", rev: "8114ab36fd446f76cd1e9f139f12a62ab1fb9a6a" } # michaero/branch: astral_cut_path
cluster_icache: { git: "https://github.com/pulp-platform/cluster_icache.git", rev: "dd0e8f3497903a9ca99fc9f349d5a4f688ceb3ae" } # branch: michaero/astral_reliability
cluster_peripherals: { git: "https://github.com/pulp-platform/cluster_peripherals.git", rev: 0b8e8ab } # branch: fc/hci-v2
fpu_interco: { git: "https://github.com/pulp-platform/fpu_interco.git", rev: "b5f7a315929308823cacd81e1e4898f1eeecfc64" } # branch: astral
axi: { git: "https://github.com/pulp-platform/axi.git", version: 0.39.3 }
Expand Down
2 changes: 1 addition & 1 deletion Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ fault_injection_sim:

## Clone regression tests
REGRESSION_TESTS_REMOTE ?= https://github.com/pulp-platform/regression_tests.git
REGRESSION_TESTS_COMMIT ?= a61fc85 # branch: upstream-features
REGRESSION_TESTS_COMMIT ?= 799c996 # branch: upstream-features

regression_tests:
git clone $(REGRESSION_TESTS_REMOTE) $@
Expand Down
36 changes: 36 additions & 0 deletions scripts/fault_injection_utils/pulp_extract_nets.tcl
Original file line number Diff line number Diff line change
Expand Up @@ -245,6 +245,42 @@ proc get_all_core_nets {core} {
return $all_signals
}

##########################
# Get all icache state #
##########################

proc get_all_icache_state {} {
set icache_base /pulp_cluster_tb/cluster_i/icache_top_i/i_snitch_icache

set l1_data_base $icache_base/gen_serial_lookup/i_lookup/i_data/i_tc_sram
set l1_tag_base $icache_base/gen_serial_lookup/i_lookup/gen_scm

set l1_data [list]
for {set i 0} {$i < [examine -radix dec $l1_data_base/NumWords]} {incr i} {
lappend l1_data $l1_data_base/sram\[$i\]
}
set l1_tag [list]
for {set i 0} {$i < [examine -radix dec $icache_base/SET_COUNT]} {incr i} {
for {set j 0} {$j < [examine -radix dec $l1_tag_base/g_sets\[$i\]/i_tag/N_SCM_REGISTERS]} {incr j} {
lappend l1_tag $l1_tag_base/g_sets\[$i\]/i_tag/block_ram_gen/MemContent_int\[$j\]
}
}

set l0_data [list]
set l0_tag [list]
for {set i 0} {$i < [examine -radix dec $icache_base/NR_FETCH_PORTS]} {incr i} {
for {set j 0} {$j < [examine -radix dec $icache_base/L0_LINE_COUNT]} {incr j} {
lappend l0_data $icache_base/gen_prefetcher\[$i\]/i_snitch_icache_l0/data\[$j\]
}
# Questa force does not work properly on arrays of structs, always forcing the first element instead of the one specified.
# Therefore, we limit our injections as well.
lappend l0_tag $icache_base/gen_prefetcher\[$i\]/i_snitch_icache_l0/tag\[0\].tag
lappend l0_tag $icache_base/gen_prefetcher\[$i\]/i_snitch_icache_l0/tag\[0\].vld
}

return [concat $l1_data $l1_tag $l0_data $l0_tag]
}

##################
# Memory signals #
##################
Expand Down

0 comments on commit 1eb04b0

Please sign in to comment.