sim_events.cc
来自「M5,一个功能强大的多处理器系统模拟器.很多针对处理器架构,性能的研究都使用它作」· CC 代码 · 共 160 行
CC
160 行
/* * Copyright (c) 2002, 2003, 2004, 2005 * The Regents of The University of Michigan * All Rights Reserved * * This code is part of the M5 simulator. * * Permission is granted to use, copy, create derivative works and * redistribute this software and such derivative works for any * purpose, so long as the copyright notice above, this grant of * permission, and the disclaimer below appear in all copies made; and * so long as the name of The University of Michigan is not used in * any advertising or publicity pertaining to the use or distribution * of this software without specific, written prior authorization. * * THIS SOFTWARE IS PROVIDED AS IS, WITHOUT REPRESENTATION FROM THE * UNIVERSITY OF MICHIGAN AS TO ITS FITNESS FOR ANY PURPOSE, AND * WITHOUT WARRANTY BY THE UNIVERSITY OF MICHIGAN OF ANY KIND, EITHER * EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE. THE REGENTS OF THE UNIVERSITY OF MICHIGAN SHALL NOT BE * LIABLE FOR ANY DAMAGES, INCLUDING DIRECT, SPECIAL, INDIRECT, * INCIDENTAL, OR CONSEQUENTIAL DAMAGES, WITH RESPECT TO ANY CLAIM * ARISING OUT OF OR IN CONNECTION WITH THE USE OF THE SOFTWARE, EVEN * IF IT HAS BEEN OR IS HEREAFTER ADVISED OF THE POSSIBILITY OF SUCH * DAMAGES. * * Authors: Nathan L. Binkert */#include <string>#include "base/callback.hh"#include "base/hostinfo.hh"#include "sim/eventq.hh"#include "sim/sim_events.hh"#include "sim/sim_exit.hh"#include "sim/startup.hh"#include "sim/stats.hh"using namespace std;//// handle termination event//voidSimLoopExitEvent::process(){ // if this got scheduled on a different queue (e.g. the committed // instruction queue) then make a corresponding event on the main // queue. if (theQueue() != &mainEventQueue) { exitSimLoop(cause, code); delete this; } // otherwise do nothing... the IsExitEvent flag takes care of // exiting the simulation loop and returning this object to Python // but if you are doing this on intervals, don't forget to make another if (repeat) { schedule(curTick + repeat); }}const char *SimLoopExitEvent::description() const{ return "simulation loop exit";}SimLoopExitEvent *schedExitSimLoop(const std::string &message, Tick when, Tick repeat, EventQueue *q, int exit_code){ if (q == NULL) q = &mainEventQueue; return new SimLoopExitEvent(q, when, repeat, message, exit_code);}voidexitSimLoop(const std::string &message, int exit_code){ schedExitSimLoop(message, curTick, 0, NULL, exit_code);}voidCountedDrainEvent::process(){ if (--count == 0) { exitSimLoop("Finished drain"); }}//// constructor: automatically schedules at specified time//CountedExitEvent::CountedExitEvent(EventQueue *q, const std::string &_cause, Tick _when, int &_downCounter) : Event(q, Sim_Exit_Pri), cause(_cause), downCounter(_downCounter){ // catch stupid mistakes assert(downCounter > 0); schedule(_when);}//// handle termination event//voidCountedExitEvent::process(){ if (--downCounter == 0) { exitSimLoop(cause, 0); }}const char *CountedExitEvent::description() const{ return "counted exit";}#ifdef CHECK_SWAP_CYCLESnew CheckSwapEvent(&mainEventQueue, CHECK_SWAP_CYCLES);#endifvoidCheckSwapEvent::process(){ /* Check the amount of free swap space */ long swap; /* returns free swap in KBytes */ swap = procInfo("/proc/meminfo", "SwapFree:"); if (swap < 1000) ccprintf(cerr, "\a\a\aWarning! Swap space is low (%d)\n", swap); if (swap < 100) { cerr << "\a\aAborting Simulation! Inadequate swap space!\n\n"; exitSimLoop("Lack of swap space"); } schedule(curTick + interval);}const char *CheckSwapEvent::description() const{ return "check swap";}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?