From abb94bfc7b17a4c85a05f304de229fbfe8d3c078 Mon Sep 17 00:00:00 2001 From: Jiuyang Liu Date: Fri, 26 Jul 2024 14:12:21 +0800 Subject: [PATCH] fix replacement --- rocketv/src/Replacement.scala | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/rocketv/src/Replacement.scala b/rocketv/src/Replacement.scala index de23a27b77..fabb2f331e 100644 --- a/rocketv/src/Replacement.scala +++ b/rocketv/src/Replacement.scala @@ -213,7 +213,7 @@ class PseudoLRU(n_ways: Int) extends ReplacementPolicy { val right_nways: Int = 1 << (log2Ceil(tree_nways) - 1) // number of ways in the right sub-tree val left_nways: Int = tree_nways - right_nways // number of ways in the left sub-tree val set_left_older = !touch_way(log2Ceil(tree_nways)-1) - val left_subtree_state = state(tree_nways-3, right_nways-1) + val left_subtree_state = if(tree_nways - 1 == right_nways) 0.U else state(tree_nways-3, right_nways-1) val right_subtree_state = state(right_nways-2, 0) if (left_nways > 1) { @@ -265,7 +265,7 @@ class PseudoLRU(n_ways: Int) extends ReplacementPolicy { val right_nways: Int = 1 << (log2Ceil(tree_nways) - 1) // number of ways in the right sub-tree val left_nways: Int = tree_nways - right_nways // number of ways in the left sub-tree val left_subtree_older = state(tree_nways-2) - val left_subtree_state = state(tree_nways-3, right_nways-1) + val left_subtree_state = if(tree_nways - 1 == right_nways) 0.U else state(tree_nways-3, right_nways-1) val right_subtree_state = state(right_nways-2, 0) if (left_nways > 1) {