summaryrefslogtreecommitdiff
path: root/kern/tru64/tru64_system.hh
diff options
context:
space:
mode:
authorLisa Hsu <hsul@eecs.umich.edu>2004-03-04 21:57:09 -0500
committerLisa Hsu <hsul@eecs.umich.edu>2004-03-04 21:57:09 -0500
commitf3861d0cc7d3574f985b3aeb37ddf6038b6c9a11 (patch)
treec9def05ce48ab4f92db1d26414ae5f34667e09ab /kern/tru64/tru64_system.hh
parenteabc59ca2d130cb4069a3cfa20ce30ff46bab0c9 (diff)
downloadgem5-f3861d0cc7d3574f985b3aeb37ddf6038b6c9a11.tar.xz
Overall gist of this is to 'dynamicize' the tracking of functions so you can choose them at the .ini stage rather than at compile time.
to do it: in .ini file set binned_fns=foo null bar foo what this says is, track foo when it is called by null (i.e. anything). bin bar only when it is called by foo. essentially, if you have a path of functions to track, the 0th, 2nd, 4th fn listed are the fns to track, and the 1st, 3rd, 5th are their respective callers. base/statistics.hh: turn it back to FS_MEASURE since we already have a build in place kern/tru64/tru64_events.cc: remove FS_MEASURE #defs. add more DPRINTF's. manage an anomaly that happens when tracking idle_thread. kern/tru64/tru64_events.hh: remove FS_MEASURE #defs kern/tru64/tru64_system.cc: make DumpState print all the time, but only with DPRINTF. add a new parameter to tru64System a vector<string> binned_fns, to read in from .ini file. now all this binning stuff is dynamically generated. kern/tru64/tru64_system.hh: remove all static binning stuff, add support for dynamic sim/system.cc: change nonPath bin name to Kernel, remove FS_MEASURE sim/system.hh: change nonPath to Kernel --HG-- extra : convert_revision : 9ee813c0a64273bab4125815b7bc8145c5897ec1
Diffstat (limited to 'kern/tru64/tru64_system.hh')
-rw-r--r--kern/tru64/tru64_system.hh80
1 files changed, 7 insertions, 73 deletions
diff --git a/kern/tru64/tru64_system.hh b/kern/tru64/tru64_system.hh
index bedf1f383..34569664d 100644
--- a/kern/tru64/tru64_system.hh
+++ b/kern/tru64/tru64_system.hh
@@ -57,42 +57,6 @@ class Tru64System : public System
SymbolTable *kernelSymtab;
SymbolTable *consoleSymtab;
-#ifdef FS_MEASURE
- //INSTRUMENTATION CODEGEN BEGIN ONE
- Statistics::MainBin *esIntrBin;
- Statistics::MainBin *esRxeofBin;
- Statistics::MainBin *esNewbufBin;
- Statistics::MainBin *esDmaLoadBin;
- Statistics::MainBin *dmaMapLoadBin;
- Statistics::MainBin *etherInputBin;
- Statistics::MainBin *netisrInputBin;
- Statistics::MainBin *schednetisrIsrBin;
- Statistics::MainBin *ipintrBin;
- Statistics::MainBin *ipDooptionsBin;
- Statistics::MainBin *ipReassBin;
- Statistics::MainBin *tcpInputBin;
- Statistics::MainBin *sbappendBin;
- Statistics::MainBin *readBin;
- Statistics::MainBin *sooReadBin;
- Statistics::MainBin *orecvBin;
- Statistics::MainBin *recvitBin;
- Statistics::MainBin *soreceiveBin;
- Statistics::MainBin *osendBin;
- Statistics::MainBin *writeBin;
- Statistics::MainBin *sooWriteBin;
- Statistics::MainBin *senditBin;
- Statistics::MainBin *sosendBin;
- Statistics::MainBin *tcpSosendBin;
- Statistics::MainBin *tcpOutputBin;
- Statistics::MainBin *ipOutputBin;
- Statistics::MainBin *etherOutputBin;
- Statistics::MainBin *esStartBin;
- Statistics::MainBin *esTransmitBin;
- Statistics::MainBin *esTxeofBin;
- Statistics::MainBin *idleThreadBin;
- //INSTRUMENTATION CODEGEN END
-#endif //FS_MEASURE
-
BreakPCEvent *kernelPanicEvent;
BreakPCEvent *consolePanicEvent;
BadAddrEvent *badaddrEvent;
@@ -102,41 +66,8 @@ class Tru64System : public System
DebugPrintfEvent *debugPrintfEvent;
DebugPrintfEvent *debugPrintfrEvent;
DumpMbufEvent *dumpMbufEvent;
-#ifdef FS_MEASURE
- //INSTRUMENTATION CODEGEN BEGIN TWO
- FnEvent *esIntrEvent;
- FnEvent *esRxeofEvent;
- FnEvent *esNewbufEvent;
- FnEvent *esDmaLoadEvent;
- FnEvent *dmaMapLoadEvent;
- FnEvent *etherInputEvent;
- FnEvent *netisrInputEvent;
- FnEvent *schednetisrIsrEvent;
- FnEvent *ipintrEvent;
- FnEvent *ipDooptionsEvent;
- FnEvent *ipReassEvent;
- FnEvent *tcpInputEvent;
- FnEvent *sbappendEvent;
- FnEvent *readEvent;
- FnEvent *sooReadEvent;
- FnEvent *orecvEvent;
- FnEvent *recvitEvent;
- FnEvent *soreceiveEvent;
- FnEvent *osendEvent;
- FnEvent *writeEvent;
- FnEvent *sooWriteEvent;
- FnEvent *senditEvent;
- FnEvent *sosendEvent;
- FnEvent *tcpSosendEvent;
- FnEvent *tcpOutputEvent;
- FnEvent *ipOutputEvent;
- FnEvent *etherOutputEvent;
- FnEvent *esStartEvent;
- FnEvent *esTransmitEvent;
- FnEvent *esTxeofEvent;
- FnEvent *idleThreadEvent;
- //INSTRUMENTATION CODEGEN END
-#endif //FS_MEASURE
+
+ std::vector<FnEvent *> fnEvents;
private:
@@ -144,6 +75,7 @@ class Tru64System : public System
Addr kernelEnd;
Addr kernelEntry;
bool bin;
+ std::vector<string> binned_fns;
public:
std::vector<RemoteGDB *> remoteGDB;
@@ -158,7 +90,8 @@ class Tru64System : public System
const std::string &console_path,
const std::string &palcode,
const std::string &boot_osflags,
- const bool _bin);
+ const bool _bin,
+ const std::vector<string> &binned_fns);
~Tru64System();
int registerExecContext(ExecContext *xc);
@@ -173,7 +106,7 @@ class Tru64System : public System
static void DumpMbuf(AlphaArguments args);
- // Lisa's fs measure stuff
+ // Lisa's binning stuff
private:
std::multimap<const std::string, std::string> callerMap;
void populateMap(std::string caller, std::string callee);
@@ -181,6 +114,7 @@ class Tru64System : public System
public:
bool findCaller(std::string callee, std::string caller) const;
void dumpState(ExecContext *xc) const;
+ //
};
#endif // __TRU64_SYSTEM_HH__