32#ifndef __BASE_TRACE_HH__ 
   33#define __BASE_TRACE_HH__ 
   50const std::string &
name();
 
   73        if (ignore_match && activate_match)
 
   74            panic(
"%s in both ignore and activate.\n", 
name);
 
   77        if (!
activate.empty() && !activate_match)
 
 
   84    template <
typename ...Args>
 
   92    template <
typename ...Args>
 
   94            const std::string &flag,
 
   95            const char *fmt, 
const Args &...args)
 
   99        std::ostringstream line;
 
 
  106            const void *
d, 
int len, 
const std::string &flag);
 
  110            const std::string &flag, 
const std::string &message) = 0;
 
 
  146            const std::string &flag, 
const std::string &message) 
override;
 
 
  203#define DDUMP(x, data, count) do {               \ 
  204    if (GEM5_UNLIKELY(TRACING_ON && ::gem5::debug::x))     \ 
  205        ::gem5::trace::getDebugLogger()->dump(           \ 
  206            ::gem5::curTick(), name(), data, count, #x); \ 
 
  209#define DPRINTF(x, ...) do {                     \ 
  210    if (GEM5_UNLIKELY(TRACING_ON && ::gem5::debug::x)) {   \ 
  211        ::gem5::trace::getDebugLogger()->dprintf_flag(   \ 
  212            ::gem5::curTick(), name(), #x, __VA_ARGS__); \ 
 
  216#define DPRINTFS(x, s, ...) do {                        \ 
  217    if (GEM5_UNLIKELY(TRACING_ON && ::gem5::debug::x)) {          \ 
  218        ::gem5::trace::getDebugLogger()->dprintf_flag(          \ 
  219                ::gem5::curTick(), (s)->name(), #x, __VA_ARGS__); \ 
 
  223#define DPRINTFR(x, ...) do {                          \ 
  224    if (GEM5_UNLIKELY(TRACING_ON && ::gem5::debug::x)) {         \ 
  225        ::gem5::trace::getDebugLogger()->dprintf_flag(         \ 
  226            (::gem5::Tick)-1, std::string(), #x, __VA_ARGS__); \ 
 
  230#define DPRINTFV(x, ...) do {                          \ 
  231    if (GEM5_UNLIKELY(TRACING_ON && (x))) {              \ 
  232        ::gem5::trace::getDebugLogger()->dprintf_flag(         \ 
  233            ::gem5::curTick(), name(), x.name(), __VA_ARGS__); \ 
 
  237#define DPRINTFN(...) do {                                                \ 
  239        ::gem5::trace::getDebugLogger()->dprintf( \ 
  240            ::gem5::curTick(), name(), __VA_ARGS__); \ 
 
  244#define DPRINTFNR(...) do {                                          \ 
  246        ::gem5::trace::getDebugLogger()->dprintf( \ 
  247            (::gem5::Tick)-1, "", __VA_ARGS__); \ 
 
const std::string & name()
Defines global host-dependent types: Counter, Tick, and (indirectly) {int,uint}{8,...
ObjectMatch contains a vector of expressions.
Debug logging base class.
void setIgnore(ObjectMatch &ignore_)
Set objects to ignore.
ObjectMatch ignore
Name match for objects to ignore.
void addActivate(const ObjectMatch &activate_)
Add objects to activate.
void dprintf_flag(Tick when, const std::string &name, const std::string &flag, const char *fmt, const Args &...args)
Log a single message with a flag prefix.
bool isEnabled(const std::string &name) const
void addIgnore(const ObjectMatch &ignore_)
Add objects to ignore.
virtual std::ostream & getOstream()=0
Return an ostream that can be used to send messages to the 'same place' as formatted logMessage messa...
void setActivate(ObjectMatch &activate_)
Set objects to activate.
ObjectMatch activate
Name match for objects to activate log.
virtual void logMessage(Tick when, const std::string &name, const std::string &flag, const std::string &message)=0
Log formatted message.
void dprintf(Tick when, const std::string &name, const char *fmt, const Args &...args)
Log a single message.
void logMessage(Tick when, const std::string &name, const std::string &flag, const std::string &message) override
Log formatted message.
OstreamLogger(std::ostream &stream_)
std::ostream & getOstream() override
Return an ostream that can be used to send messages to the 'same place' as formatted logMessage messa...
#define panic(...)
This implements a cprintf based panic() function.
void dump()
Dump all statistics data to the registered outputs.
void enable()
Enable/disable debug logging.
void setDebugLogger(Logger *logger)
Delete the current global logger and assign a new one.
Logger * getDebugLogger()
Get the current global debug logger.
std::ostream & output()
Get the ostream from the current global logger.
Copyright (c) 2024 Arm Limited All rights reserved.
uint64_t Tick
Tick count type.
void ccprintf(cp::Print &print)
StringWrap(const std::string &s)
const std::string & operator()() const
const std::string & name()