From: Nathan Binkert Date: Tue, 14 Oct 2003 02:19:43 +0000 (-0400) Subject: Small optimization X-Git-Tag: m5_1.0_beta1~25^2~1 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=481aaf03cf933c13c3d9bf294629c6740726025e;p=gem5.git Small optimization cpu/pc_event.cc: cpu/pc_event.hh: Do a quick check to see if there is anything to service before the function is called --HG-- extra : convert_revision : 16e9b6284ece8b7a53ccf0ca200fab9ba780c50c --- diff --git a/cpu/pc_event.cc b/cpu/pc_event.cc index 7b72f5c08..8c584a492 100644 --- a/cpu/pc_event.cc +++ b/cpu/pc_event.cc @@ -84,7 +84,7 @@ PCEventQueue::schedule(PCEvent *event) } bool -PCEventQueue::service(ExecContext *xc) +PCEventQueue::doService(ExecContext *xc) { Addr pc = xc->regs.pc; int serviced = 0; diff --git a/cpu/pc_event.hh b/cpu/pc_event.hh index 08c6fa59a..d452bc030 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()); }