diff options
author | Ali Saidi <saidi@eecs.umich.edu> | 2006-10-31 13:24:00 -0500 |
---|---|---|
committer | Ali Saidi <saidi@eecs.umich.edu> | 2006-10-31 13:24:00 -0500 |
commit | 7f39644609e19ada9e94c9bbb09c3e625fa6e8ed (patch) | |
tree | b849a7e39abf07fb9325a22e4f71053040adcfc9 /src/mem | |
parent | 79d4bede429bb5c3413fcd0cfe6f2d1790c8312d (diff) | |
parent | 17141a1be9c656d2bba77e8853dd3d4cbce01beb (diff) | |
download | gem5-7f39644609e19ada9e94c9bbb09c3e625fa6e8ed.tar.xz |
Merge zizzer:/bk/newmem
into zeep.pool:/z/saidi/work/m5.newmem.head
--HG--
extra : convert_revision : 42712a50ca46ebc891b78186f4b6d1412a35d374
Diffstat (limited to 'src/mem')
-rw-r--r-- | src/mem/tport.cc | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/src/mem/tport.cc b/src/mem/tport.cc index b9d5cbe4a..086d91279 100644 --- a/src/mem/tport.cc +++ b/src/mem/tport.cc @@ -44,6 +44,7 @@ SimpleTimingPort::recvFunctional(PacketPtr pkt) if (target->intersect(pkt)) done = fixPacket(pkt, target); + i++; } //Then just do an atomic access and throw away the returned latency @@ -98,11 +99,29 @@ SimpleTimingPort::recvRetry() void SimpleTimingPort::sendTiming(PacketPtr pkt, Tick time) { + // Nothing is on the list: add it and schedule an event if (transmitList.empty()) { assert(!sendEvent.scheduled()); sendEvent.schedule(curTick+time); + transmitList.push_back(std::pair<Tick,PacketPtr>(time+curTick,pkt)); + return; + } + + // something is on the list and this belongs at the end + if (time+curTick >= transmitList.back().first) { + transmitList.push_back(std::pair<Tick,PacketPtr>(time+curTick,pkt)); + return; + } + // Something is on the list and this belongs somewhere else + std::list<std::pair<Tick,PacketPtr> >::iterator i = transmitList.begin(); + std::list<std::pair<Tick,PacketPtr> >::iterator end = transmitList.end(); + bool done = false; + + while (i != end && !done) { + if (time+curTick < i->first) + transmitList.insert(i,std::pair<Tick,PacketPtr>(time+curTick,pkt)); + i++; } - transmitList.push_back(std::pair<Tick,PacketPtr>(time+curTick,pkt)); } void |