Trace.h 4.32 KB
Newer Older
Simon Marlow's avatar
Simon Marlow committed
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123
/* -----------------------------------------------------------------------------
 *
 * (c) The GHC Team 2006
 *
 * Debug and performance tracing.  
 *
 * This is a layer over RtsMessages, which provides for generating
 * trace messages with timestamps and thread Ids attached
 * automatically.  Also, multiple classes of messages are supported,
 * which can be enabled separately via RTS flags.
 *
 * All debug trace messages go through here.  Additionally, we
 * generate timestamped trace messages for consumption by profiling
 * tools using this API.
 *
 * ---------------------------------------------------------------------------*/

#ifndef TRACE_H
#define TRACE_H

// -----------------------------------------------------------------------------
// Tracing functions
// -----------------------------------------------------------------------------

void initTracing (void);

// The simple way:
void trace (StgWord32 class, const char *str, ...)
    GNUC3_ATTRIBUTE(format (printf, 2, 3));

// The harder way: sometimes we want to generate a trace message that
// consists of multiple components generated by different functions.
// So we provide the functionality of trace() split into 3 parts: 
//   - traceClass(): a check that the required class is enabled
//   - traceBegin(): print the beginning of the trace message
//   - traceEnd(): complete the trace message (release the lock too).
// 
INLINE_HEADER rtsBool traceClass (StgWord32 class);

void traceBegin (const char *str, ...)
    GNUC3_ATTRIBUTE(format (printf, 1, 2));

void traceEnd (void);

#ifdef DEBUG
#define debugTrace(class, str, ...) trace(class,str, ## __VA_ARGS__)
// variable arg macros are C99, and supported by gcc.
#define debugTraceBegin(class, str, ...) traceBegin(class,str, ## __VA_ARGS__)
#define debugTraceEnd() traceEnd()
#else
#define debugTrace(class, str, ...) /* nothing */
#define debugTraceBegin(class, str, ...) /* nothing */
#define debugTraceEnd() /* nothing */
#endif


// -----------------------------------------------------------------------------
// Message classes, these may be OR-ed together
// -----------------------------------------------------------------------------

// debugging flags, set with +RTS -D<something>
#define DEBUG_sched		   (1<<0)
#define DEBUG_interp		   (1<<1)
#define DEBUG_weak		   (1<<2)
#define DEBUG_gccafs		   (1<<3) 
#define DEBUG_gc		   (1<<4) 
#define DEBUG_block_alloc	   (1<<5) 
#define DEBUG_sanity		   (1<<6) 
#define DEBUG_stable		   (1<<7) 
#define DEBUG_stm   		   (1<<8) 
#define DEBUG_prof		   (1<<9) 
#define DEBUG_gran		   (1<<10)
#define DEBUG_par		   (1<<11)
#define DEBUG_linker		   (1<<12)
#define DEBUG_squeeze              (1<<13)

// PAR debugging flags, set with +RTS -qD<something>
#define PAR_DEBUG_verbose	   (1<<14)
#define PAR_DEBUG_bq		   (1<<15)
#define PAR_DEBUG_schedule         (1<<16)
#define PAR_DEBUG_free       	   (1<<17)
#define PAR_DEBUG_resume     	   (1<<18)
#define PAR_DEBUG_weight     	   (1<<19)
#define PAR_DEBUG_fetch      	   (1<<21)
#define PAR_DEBUG_fish       	   (1<<22)
#define PAR_DEBUG_tables     	   (1<<23)
#define PAR_DEBUG_packet     	   (1<<24)
#define PAR_DEBUG_pack       	   (1<<25)
#define PAR_DEBUG_paranoia         (1<<26)

// GRAN and PAR don't coexist, so we re-use the PAR values for GRAN.
#define GRAN_DEBUG_event_trace     (1<<14)  
#define GRAN_DEBUG_event_stats     (1<<15)
#define GRAN_DEBUG_bq              (1<<16)
#define GRAN_DEBUG_pack            (1<<17)
#define GRAN_DEBUG_checkSparkQ     (1<<18)
#define GRAN_DEBUG_thunkStealing   (1<<19)
#define GRAN_DEBUG_randomSteal     (1<<20)	
#define GRAN_DEBUG_findWork        (1<<21)	
#define GRAN_DEBUG_unused     	   (1<<22)
#define GRAN_DEBUG_pri     	   (1<<23)
#define GRAN_DEBUG_checkLight      (1<<24)	
#define GRAN_DEBUG_sortedQ         (1<<25)	
#define GRAN_DEBUG_blockOnFetch    (1<<26)
#define GRAN_DEBUG_packBuffer      (1<<27)
#define GRAN_DEBUG_BOF_sanity      (1<<28)

// Profiling flags
#define TRACE_sched                (1<<29)


// -----------------------------------------------------------------------------
// PRIVATE below here
// -----------------------------------------------------------------------------

extern StgWord32 classes_enabled;

INLINE_HEADER rtsBool
traceClass (StgWord32 class) { return (classes_enabled & class); }

// -----------------------------------------------------------------------------

#endif /* TRACE_H */