diff options
author | Nathan Binkert <binkertn@umich.edu> | 2003-10-14 16:53:52 -0400 |
---|---|---|
committer | Nathan Binkert <binkertn@umich.edu> | 2003-10-14 16:53:52 -0400 |
commit | 638a07d15a149b48c854b58e2b3f4df097aa5e2e (patch) | |
tree | 82ac6aa2e2df719eeb2c8b6d319c4c7956bbc6b1 /cpu/pc_event.hh | |
parent | 2ac3dc5aa184da9fa08a304c67d646197ed9a7c5 (diff) | |
parent | 4759c203c774ef42a2a35832e220a95cffb5fa7b (diff) | |
download | gem5-638a07d15a149b48c854b58e2b3f4df097aa5e2e.tar.xz |
Merge
cpu/pc_event.cc:
SCCS merged
--HG--
extra : convert_revision : f7046f2bf6053be9b00150390fabe3d4f82b0981
Diffstat (limited to 'cpu/pc_event.hh')
-rw-r--r-- | cpu/pc_event.hh | 57 |
1 files changed, 9 insertions, 48 deletions
diff --git a/cpu/pc_event.hh b/cpu/pc_event.hh index 08c6fa59a..645138fdd 100644 --- a/cpu/pc_event.hh +++ b/cpu/pc_event.hh @@ -98,13 +98,21 @@ class PCEventQueue protected: map_t pc_map; + bool doService(ExecContext *xc); + public: PCEventQueue(); ~PCEventQueue(); bool remove(PCEvent *event); bool schedule(PCEvent *event); - bool service(ExecContext *xc); + bool service(ExecContext *xc) + { + if (pc_map.empty()) + return false; + + return doService(xc); + } range_t equal_range(Addr pc); range_t equal_range(PCEvent *event) { return equal_range(event->pc()); } @@ -155,52 +163,6 @@ PCEvent::schedule(PCEventQueue *q, Addr pc) return schedule(); } - -#ifdef FULL_SYSTEM -class SkipFuncEvent : public PCEvent -{ - public: - SkipFuncEvent(PCEventQueue *q, const std::string &desc) - : PCEvent(q, desc) {} - virtual void process(ExecContext *xc); -}; - -class BadAddrEvent : public SkipFuncEvent -{ - public: - BadAddrEvent(PCEventQueue *q, const std::string &desc) - : SkipFuncEvent(q, desc) {} - virtual void process(ExecContext *xc); -}; - -class PrintfEvent : public PCEvent -{ - public: - PrintfEvent(PCEventQueue *q, const std::string &desc) - : PCEvent(q, desc) {} - virtual void process(ExecContext *xc); -}; - -class DebugPrintfEvent : public PCEvent -{ - private: - bool raw; - - public: - DebugPrintfEvent(PCEventQueue *q, const std::string &desc, bool r = false) - : PCEvent(q, desc), raw(r) {} - virtual void process(ExecContext *xc); -}; - -class DumpMbufEvent : public PCEvent -{ - public: - DumpMbufEvent(PCEventQueue *q, const std::string &desc) - : PCEvent(q, desc) {} - virtual void process(ExecContext *xc); -}; -#endif - class BreakPCEvent : public PCEvent { protected: @@ -211,5 +173,4 @@ class BreakPCEvent : public PCEvent virtual void process(ExecContext *xc); }; - #endif // __PC_EVENT_HH__ |