Consumer.cc (9230:33eb3c8a98b9) | Consumer.cc (9465:4ae4f3f4b870) |
---|---|
1/* 2 * Copyright (c) 2012 Mark D. Hill and David A. Wood 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions are 7 * met: redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer; --- 13 unchanged lines hidden (view full) --- 22 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 26 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 */ 28 29#include "mem/ruby/common/Consumer.hh" | 1/* 2 * Copyright (c) 2012 Mark D. Hill and David A. Wood 3 * All rights reserved. 4 * 5 * Redistribution and use in source and binary forms, with or without 6 * modification, are permitted provided that the following conditions are 7 * met: redistributions of source code must retain the above copyright 8 * notice, this list of conditions and the following disclaimer; --- 13 unchanged lines hidden (view full) --- 22 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, 23 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY 24 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT 25 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE 26 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 27 */ 28 29#include "mem/ruby/common/Consumer.hh" |
30#include "mem/ruby/common/Global.hh" 31#include "mem/ruby/system/System.hh" | |
32 33void 34Consumer::scheduleEvent(Time timeDelta) 35{ | 30 31void 32Consumer::scheduleEvent(Time timeDelta) 33{ |
36 scheduleEventAbsolute(timeDelta + g_system_ptr->getTime()); | 34 scheduleEventAbsolute(timeDelta + em->curCycle()); |
37} 38 39void 40Consumer::scheduleEventAbsolute(Time timeAbs) 41{ | 35} 36 37void 38Consumer::scheduleEventAbsolute(Time timeAbs) 39{ |
42 Tick evt_time = g_system_ptr->clockPeriod() * timeAbs; | 40 Tick evt_time = em->clockPeriod() * timeAbs; |
43 if (!alreadyScheduled(evt_time)) { 44 // This wakeup is not redundant 45 ConsumerEvent *evt = new ConsumerEvent(this); | 41 if (!alreadyScheduled(evt_time)) { 42 // This wakeup is not redundant 43 ConsumerEvent *evt = new ConsumerEvent(this); |
46 assert(timeAbs > g_system_ptr->getTime()); | 44 assert(timeAbs > em->curCycle()); |
47 48 em->schedule(evt, evt_time); 49 insertScheduledWakeupTime(evt_time); 50 } 51} | 45 46 em->schedule(evt, evt_time); 47 insertScheduledWakeupTime(evt_time); 48 } 49} |