From a4a8568bd2e3300b5dc9d3deee5181a7db2a76c7 Mon Sep 17 00:00:00 2001 From: Omar Naji Date: Mon, 20 Oct 2014 18:03:55 -0400 Subject: mem: Fix DRAM activationlLimit bug Ensure that we do the proper event scheduling also when the activation limit is disabled. --- src/mem/dram_ctrl.cc | 49 ++++++++++++++++++++++++++----------------------- 1 file changed, 26 insertions(+), 23 deletions(-) (limited to 'src/mem') diff --git a/src/mem/dram_ctrl.cc b/src/mem/dram_ctrl.cc index c9d944faa..f65f7e1dd 100644 --- a/src/mem/dram_ctrl.cc +++ b/src/mem/dram_ctrl.cc @@ -917,35 +917,38 @@ DRAMCtrl::activateBank(Bank& bank, Tick act_tick, uint32_t row) } // next, we deal with tXAW, if the activation limit is disabled - // then we are done - if (actTicks[rank].empty()) - return; - - // sanity check - if (actTicks[rank].back() && (act_tick - actTicks[rank].back()) < tXAW) { - panic("Got %d activates in window %d (%llu - %llu) which is smaller " - "than %llu\n", activationLimit, act_tick - actTicks[rank].back(), - act_tick, actTicks[rank].back(), tXAW); - } - - // shift the times used for the book keeping, the last element - // (highest index) is the oldest one and hence the lowest value - actTicks[rank].pop_back(); - - // record an new activation (in the future) - actTicks[rank].push_front(act_tick); + // then we directly schedule an activate power event + if (!actTicks[rank].empty()) { + // sanity check + if (actTicks[rank].back() && + (act_tick - actTicks[rank].back()) < tXAW) { + panic("Got %d activates in window %d (%llu - %llu) which " + "is smaller than %llu\n", activationLimit, act_tick - + actTicks[rank].back(), act_tick, actTicks[rank].back(), + tXAW); + } - // cannot activate more than X times in time window tXAW, push the - // next one (the X + 1'st activate) to be tXAW away from the - // oldest in our window of X - if (actTicks[rank].back() && (act_tick - actTicks[rank].back()) < tXAW) { - DPRINTF(DRAM, "Enforcing tXAW with X = %d, next activate no earlier " - "than %llu\n", activationLimit, actTicks[rank].back() + tXAW); + // shift the times used for the book keeping, the last element + // (highest index) is the oldest one and hence the lowest value + actTicks[rank].pop_back(); + + // record an new activation (in the future) + actTicks[rank].push_front(act_tick); + + // cannot activate more than X times in time window tXAW, push the + // next one (the X + 1'st activate) to be tXAW away from the + // oldest in our window of X + if (actTicks[rank].back() && + (act_tick - actTicks[rank].back()) < tXAW) { + DPRINTF(DRAM, "Enforcing tXAW with X = %d, next activate " + "no earlier than %llu\n", activationLimit, + actTicks[rank].back() + tXAW); for(int j = 0; j < banksPerRank; j++) // next activate must not happen before end of window banks[rank][j].actAllowedAt = std::max(actTicks[rank].back() + tXAW, banks[rank][j].actAllowedAt); + } } // at the point when this activate takes place, make sure we -- cgit v1.2.3