//----------------------------------------------------------------------------- // // File: Icecap.h // Copyright (C) 1997-1998 Microsoft Corporation // All rights reserved. // // This header file is part of IceCAP {{rmj}}.{{rmm}}.{{rup}}. It is // MICROSOFT CONFIDENTIAL, and should not be distributed except under NDA. // //----------------------------------------------------------------------------- // ICECAP.H // interface to the Datalocality APIs #ifndef __ICECAP_H__ #define __ICECAP_H__ #ifndef DONTUSEICECAPLIB #pragma comment(lib, "IceCAP.lib") #endif // USEICECAPLIB #ifdef __cplusplus extern "C" { #endif // Defines for Levels and Id's #define PROFILE_GLOBALLEVEL 1 #define PROFILE_PROCESSLEVEL 2 #define PROFILE_THREADLEVEL 3 #define PROFILE_FIBERLEVEL 4 #define PROFILE_CURRENTID ((unsigned long)0xFFFFFFFF) // Start/Stop Api's int _declspec(dllimport) _stdcall StopProfile(int nLevel, unsigned long dwId); int _declspec(dllimport) _stdcall StartProfile(int nLevel, unsigned long dwId); // Suspend/Resume Api's int _declspec(dllimport) _stdcall SuspendProfile(int nLevel, unsigned long dwId); int _declspec(dllimport) _stdcall ResumeProfile(int nLevel, unsigned long dwId); // Mark Api's int _declspec(dllimport) _stdcall MarkProfile(long lMarker); int _declspec(dllimport) _stdcall CommentMarkProfile(long lMarker, const char *szComment); int _declspec(dllimport) _stdcall CommentMarkAtProfile(__int64 dnTimestamp, long lMarker, const char *szComment); int _declspec(dllimport) _stdcall DlpMarkProfile(long lMarker0, long lMarker1); // Named Profiling Elements Api's int _declspec(dllimport) _stdcall NameProfile(const char *pszName, int nLevel, unsigned long dwId); // Security Api's // NOTE: please contact ICAPSUP before using this function int _declspec(dllimport) _stdcall ClearProcessSecurityAcl(int fImpersonatingUser); // xxxProfile return codes #define PROFILE_OK 0 // xxxProfile call successful #define PROFILE_ERROR_NOT_YET_IMPLEMENTED 1 // api or level,id combination not supported yet #define PROFILE_ERROR_MODE_NEVER 2 // mode was never when called #define PROFILE_ERROR_LEVEL_NOEXIST 3 // level doesn't exist #define PROFILE_ERROR_ID_NOEXIST 4 // id doesn't exist #define PROFILE_ERROR_NO_WMI_UPDATE 5 // failed to update the WMI (pagefault collection) state // MarkProfile return codes #define MARK_OK 0 // Mark was taken successfully #define MARK_ERROR_MODE_NEVER 1 // Profiling was never when MarkProfile called #define MARK_ERROR_MODE_OFF 2 // Profiling was off when MarkProfile called #define MARK_ERROR_MARKER_RESERVED 3 // Mark value passed is a reserved value #define MARK_TEXTTOOLONG 4 // Comment text was truncated #define MARK_ERROR_OUTOFMEMORY 6 // no memory was available in which to record the event // NameProfile return codes #define NAME_OK 0 // Name was registered sucessfullly #define NAME_ERROR_TEXTTRUNCATED 1 // The name text was too long and was therefore truncated #define NAME_ERROR_REDEFINITION 2 // The given profile element has already been named #define NAME_ERROR_LEVEL_NOEXIST 3 // level doesn't exist #define NAME_ERROR_ID_NOEXIST 4 // id doesn't exist #define NAME_ERROR_INVALID_NAME 5 // name does not meet the specification's requirements #define NAME_ERROR_OUTOFMEMORY 6 // no memory was available in which to record the event #define NAME_ERROR_NO_SUPPORT 7 // the given operation is not supported // Icecap 3.x Compatibility defines #define StartCAP() StartProfile(PROFILE_THREADLEVEL, PROFILE_CURRENTID) #define StopCAP() StopProfile(PROFILE_THREADLEVEL, PROFILE_CURRENTID) #define SuspendCAP() SuspendProfile(PROFILE_THREADLEVEL, PROFILE_CURRENTID) #define ResumeCAP() ResumeProfile(PROFILE_THREADLEVEL, PROFILE_CURRENTID) #define StartCAPAll() StartProfile(PROFILE_PROCESSLEVEL, PROFILE_CURRENTID) #define StopCAPAll() StopProfile(PROFILE_PROCESSLEVEL, PROFILE_CURRENTID) #define SuspendCAPAll() SuspendProfile(PROFILE_PROCESSLEVEL, PROFILE_CURRENTID) #define ResumeCAPAll() ResumeProfile(PROFILE_PROCESSLEVEL, PROFILE_CURRENTID) #define MarkCAP(mark) MarkProfile(mark) #define AllowCAP() // DataLocality 1.x Compatibility defines #define StartDLP() StartCAP() #define StopDLP() StopCAP() #define MarkDLP(mark) MarkCAP(mark) // // USER DEFINED COUNTER HELPERS AND TYPES // // COUNTER_FUNCTION_PROLOGE and EPILOGE // // These functions are supplied to protect the state of registers // that the IceCAP collection probes rely on. We did everything we // could to eliminate instructions during collection. Your mission, // if you choose to accept it, is the same. // #define COUNTER_FUNCTION_PROLOGE _asm push ecx _asm push ebx _asm push ebp #define COUNTER_FUNCTION_EPILOGE _asm pop ebp _asm pop ebx _asm pop ecx _asm ret #ifndef USER_COUNTER_INFO_DEFINED #define USER_COUNTER_INFO_DEFINED // CONSTS AND ENUMS // // UserCounterType // // These enumerations describe how the counter works. // // MonotonicallyIncreasing -- This describes a counter that will increment // by one each time some 'event' occurs. An // example would be a counter that tracks the // number of memory allocations. Each allocation // increments the number by one. // // MonotonicallyDecreasint -- This describes a counter that will decrement // by one each time some 'event' occurs. An // example would be a counter that tracks a limited // resource. Each use of the resource decrements // the number by one. // // RandomIncreasing -- This describes a counter that will increase for // each 'event' that occurs, but by an undetermined // amount. An example would be the total memory // allocated. Each allocation would add it's size // to the counter, but each allocation being potentially // different, causes the counter to go up by a random // amount each time. // // RandomDecreasing -- This describes a coutner that will decrease for // each 'event' that occurs, but by an undetermined // amount. An example would be a limited resource // that can be used in bunches. Each use fo the // the resource would cause the number to descrease // by a random amount. // // Random -- This number can either go up, or go down. An // example would be the total amount of available // memory, which can either go up (as memory is // free'd), or go down (as memory is allocated). // enum UserCounterType { MonotonicallyIncreasing, MonotonicallyDecreasing, RandomIncreasing, RandomDecreasing, Random }; // TYPEDEFS // typedef signed __int64 COUNTER, *PCOUNTER; /////////////////////////////////////////////////////////////// // USERCOUNTERINFO // // This structure descibes a user defined counter so that // IceCAP can use it during profiling runs. // // History: 9-21-98 BarryNo Created // /////////////////////////////////////////////////////////////// typedef struct _USERCOUNTERINFO { unsigned long dwSize; // Size of this structure (for version control) char szCounterFuncName[32]; // Name of the function enum UserCounterType ct; // Describes the type of number we will be collecting char szName[32]; // Name of user counter int bSynchronized; // Is this counter synchronized } USERCOUNTERINFO, *PUSERCOUNTERINFO; #endif // USER_COUNTER_INFO_DEFINED #ifdef __cplusplus } #endif #endif // __ICECAP_H__