/* * Copyright (c) 1999-2008 Mark D. Hill and David A. Wood * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are * met: redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer; * redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution; * neither the name of the copyright holders nor the names of its * contributors may be used to endorse or promote products derived from * this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. */ /* * $Id$ * */ #include #include #include "mem/ruby/common/Global.hh" #include "mem/ruby/common/Debug.hh" #include "mem/ruby/eventqueue/RubyEventQueue.hh" #include "mem/gems_common/util.hh" #include "base/misc.hh" using namespace std; class Debug; extern Debug* g_debug_ptr; ostream *debug_cout_ptr; bool Debug::m_protocol_trace = false; struct DebugComponentData { const char *desc; const char ch; }; // component character list DebugComponentData debugComponents[] = { {"System", 's' }, {"Node", 'N' }, {"Queue", 'q' }, {"Event Queue", 'e' }, {"Network", 'n' }, {"Sequencer", 'S' }, {"Tester", 't' }, {"Generated", 'g' }, {"SLICC", 'l' }, {"Network Queues", 'Q' }, {"Time", 'T' }, {"Network Internals", 'i' }, {"Store Buffer", 'b' }, {"Cache", 'c' }, {"Predictor", 'p' }, {"Allocator", 'a' }, {"Memory", 'M' }, }; extern "C" void changeDebugVerbosity(VerbosityLevel vb); extern "C" void changeDebugFilter(int filter); void changeDebugVerbosity(VerbosityLevel vb) { g_debug_ptr->setVerbosity(vb); } void changeDebugFilter(int filter) { g_debug_ptr->setFilter(filter); } Debug::Debug(const Params *p) : SimObject(p) { clearFilter(); debug_cout_ptr = &cout; setFilterString(p->filter_string.c_str()); setVerbosityString(p->verbosity_string.c_str()); setDebugOutputFile(p->output_filename.c_str()); m_starting_cycle = p->start_time; m_protocol_trace = p->protocol_trace; g_debug_ptr = this; } Debug::~Debug() { } void Debug::printVerbosity(ostream& out) const { switch (getVerbosity()) { case No_Verb: out << "verbosity = No_Verb" << endl; break; case Low_Verb: out << "verbosity = Low_Verb" << endl; break; case Med_Verb: out << "verbosity = Med_Verb" << endl; break; case High_Verb: out << "verbosity = High_Verb" << endl; break; default: out << "verbosity = unknown" << endl; } } bool Debug::validDebug(int module, PriorityLevel priority) { int local_module = (1 << module); if(m_filter & local_module) { if (g_eventQueue_ptr == NULL || g_eventQueue_ptr->getTime() >= m_starting_cycle) { switch(m_verbosityLevel) { case No_Verb: return false; break; case Low_Verb: if(priority == HighPrio) { return true; }else{ return false; } break; case Med_Verb: if(priority == HighPrio || priority == MedPrio ) { return true; }else{ return false; } break; case High_Verb: return true; break; } } } return false; } void Debug::setDebugTime(Time t) { m_starting_cycle = t; } void Debug::setVerbosity(VerbosityLevel vb) { m_verbosityLevel = vb; } void Debug::setFilter(int filter) { m_filter = filter; } bool Debug::checkVerbosityString(const char *verb_str) { if (verb_str == NULL) { cerr << "Error: unrecognized verbosity (use none, low, med, high): NULL" << endl; return true; // error } else if ( (string(verb_str) == "none") || (string(verb_str) == "low") || (string(verb_str) == "med") || (string(verb_str) == "high") ) { return false; } cerr << "Error: unrecognized verbosity (use none, low, med, high): NULL" << endl; return true; // error } bool Debug::setVerbosityString(const char *verb_str) { bool check_fails = checkVerbosityString(verb_str); if (check_fails) { return true; // error } if (string(verb_str) == "none") { setVerbosity(No_Verb); } else if (string(verb_str) == "low") { setVerbosity(Low_Verb); } else if (string(verb_str) == "med") { setVerbosity(Med_Verb); } else if (string(verb_str) == "high") { setVerbosity(High_Verb); } else { cerr << "Error: unrecognized verbosity (use none, low, med, high): " << verb_str << endl; return true; // error } return false; // no error } bool Debug::checkFilter(char ch) { for (int i=0; i