windows-nt/Source/XPSP1/NT/inetsrv/iis/iisrearc/ul/drv/reftrace.h
2020-09-26 16:20:57 +08:00

171 lines
4.8 KiB
C

/*++
Copyright (c) 1998-2001 Microsoft Corporation
Module Name:
reftrace.h
Abstract:
This module contains public declarations and definitions for tracing
and debugging reference count problems. This module uses the generic
TRACE_LOG facility in tracelog.h.
The REF_ACTION_* codes are declared separately in refaction.h
Author:
Keith Moore (keithmo) 10-Jun-1998
Revision History:
--*/
#ifndef _REFTRACE_H_
#define _REFTRACE_H_
#if defined(__cplusplus)
extern "C" {
#endif // __cplusplus
//
// Pull in the action codes
//
#include "refaction.h"
#define REF_TRACE_PROCESSOR_BITS 6 // MAXIMUM_PROCESSORS == 64 on Win64
#define REF_TRACE_ACTION_BITS (16 - REF_TRACE_PROCESSOR_BITS)
C_ASSERT((1 << REF_TRACE_PROCESSOR_BITS) >= MAXIMUM_PROCESSORS);
C_ASSERT((1 << REF_TRACE_ACTION_BITS) >= REF_ACTION_MAX);
//
// This defines the entry written to the trace log.
//
typedef struct _REF_TRACE_LOG_ENTRY
{
PVOID pContext;
PVOID pFileName;
PEPROCESS pProcess;
PETHREAD pThread;
PVOID pCaller;
PVOID pCallersCaller;
LONG NewRefCount;
USHORT LineNumber;
USHORT Action : REF_TRACE_ACTION_BITS;
USHORT Processor : REF_TRACE_PROCESSOR_BITS;
} REF_TRACE_LOG_ENTRY, *PREF_TRACE_LOG_ENTRY;
#define REF_TRACELOG_SIGNATURE ((ULONG) 'gLfR')
//
// Subtract REF_TRACE_OVERHEAD from a power of 2 when calculating the
// number of entries in a reftrace log, to ensure that overall size is
// a nice power of 2 and doesn't spill onto another page. This accounts
// for the size of the TRACE_LOG struct itself and the overhead
// imposed by the pool and the verifier. On x86, a REF_TRACE_LOG_ENTRY
// is currently 32 bytes. If you modify the struct, please recalculate
// REF_TRACE_OVERHEAD and *change the per-object* reftrace logs (in
// UL_CONNECTION, UL_HTTP_CONNECTION, and UL_INTERNAL_REQUEST) accordingly.
//
#define REF_TRACE_OVERHEAD 2 // entries
//
// Manipulators.
//
PTRACE_LOG
CreateRefTraceLog(
IN ULONG LogSize,
IN ULONG ExtraBytesInHeader
);
VOID
DestroyRefTraceLog(
IN PTRACE_LOG pLog
);
VOID
ResetRefTraceLog(
IN PTRACE_LOG pLog
);
LONGLONG
WriteRefTraceLog(
IN PTRACE_LOG pLog,
IN PTRACE_LOG pLog2,
IN USHORT Action,
IN LONG NewRefCount,
IN PVOID pContext,
IN PVOID pFileName,
IN USHORT LineNumber
);
#if REFERENCE_DEBUG
#define CREATE_REF_TRACE_LOG( ptr, size, extra ) \
(ptr) = CreateRefTraceLog( (size), (extra) )
#define DESTROY_REF_TRACE_LOG( ptr ) \
do \
{ \
DestroyRefTraceLog( ptr ); \
(ptr) = NULL; \
} while (FALSE)
#define RESET_REF_TRACE_LOG( ptr ) \
ResetRefTraceLog( ptr )
#define WRITE_REF_TRACE_LOG( plog, act, ref, pctx, pfile, line ) \
WriteRefTraceLog( \
(plog), \
NULL, \
(act), \
(ref), \
(pctx), \
(pfile), \
(line) \
)
#define WRITE_REF_TRACE_LOG2( plog1, plog2, act, ref, pctx, pfile, line ) \
WriteRefTraceLog( \
(plog1), \
(plog2), \
(act), \
(ref), \
(pctx), \
(pfile), \
(line) \
)
#else // !REFERENCE_DEBUG
#define CREATE_REF_TRACE_LOG( ptr, size, extra )
#define DESTROY_REF_TRACE_LOG( ptr )
#define RESET_REF_TRACE_LOG( ptr )
#define WRITE_REF_TRACE_LOG( plog, act, ref, pctx, pfile, line )
#define WRITE_REF_TRACE_LOG2( plog1, plog2 , act, ref, pctx, pfile, line )
#endif // !REFERENCE_DEBUG
#if defined(__cplusplus)
} // extern "C"
#endif // __cplusplus
#endif // _REFTRACE_H_