00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028 #ifndef PXFOUNDATION_PXPROFILER_H
00029 #define PXFOUNDATION_PXPROFILER_H
00030
00031 #include "foundation/PxFoundation.h"
00032
00033 namespace physx
00034 {
00035
00040 class PxProfilerCallback
00041 {
00042 protected:
00043 virtual ~PxProfilerCallback() {}
00044
00045 public:
00046
00047
00048
00049
00057 virtual void* zoneStart(const char* eventName, bool detached, uint64_t contextId) = 0;
00058
00068 virtual void zoneEnd(void* profilerData, const char* eventName, bool detached, uint64_t contextId) = 0;
00069 };
00070
00071 class PxProfileScoped
00072 {
00073 public:
00074 PX_FORCE_INLINE PxProfileScoped(const char* eventName, bool detached, uint64_t contextId) : mCallback(PxGetProfilerCallback()), mProfilerData(NULL)
00075 {
00076 if(mCallback)
00077 {
00078 mEventName = eventName;
00079 mContextId = contextId;
00080 mDetached = detached;
00081 mProfilerData = mCallback->zoneStart(eventName, detached, contextId);
00082 }
00083 }
00084
00085 PX_FORCE_INLINE ~PxProfileScoped()
00086 {
00087 if(mCallback)
00088 mCallback->zoneEnd(mProfilerData, mEventName, mDetached, mContextId);
00089 }
00090 physx::PxProfilerCallback* mCallback;
00091 const char* mEventName;
00092 void* mProfilerData;
00093 uint64_t mContextId;
00094 bool mDetached;
00095 };
00096
00097 }
00098
00099 #if PX_DEBUG || PX_CHECKED || PX_PROFILE
00100 #define PX_PROFILE_ZONE(x, y) \
00101 physx::PxProfileScoped PX_CONCAT(_scoped, __LINE__)(x, false, y)
00102 #define PX_PROFILE_START_CROSSTHREAD(x, y) \
00103 if(PxGetProfilerCallback()) \
00104 PxGetProfilerCallback()->zoneStart(x, true, y)
00105 #define PX_PROFILE_STOP_CROSSTHREAD(x, y) \
00106 if(PxGetProfilerCallback()) \
00107 PxGetProfilerCallback()->zoneEnd(NULL, x, true, y)
00108 #else
00109 #define PX_PROFILE_ZONE(x, y)
00110 #define PX_PROFILE_START_CROSSTHREAD(x, y)
00111 #define PX_PROFILE_STOP_CROSSTHREAD(x, y)
00112 #endif
00113
00114 #define PX_PROFILE_POINTER_TO_U64(pointer) static_cast<uint64_t>(reinterpret_cast<size_t>(pointer))
00115
00116 #endif // PXFOUNDATION_PXPROFILER_H