PxProfiler.h

Go to the documentation of this file.
00001 //
00002 // Redistribution and use in source and binary forms, with or without
00003 // modification, are permitted provided that the following conditions
00004 // are met:
00005 //  * Redistributions of source code must retain the above copyright
00006 //    notice, this list of conditions and the following disclaimer.
00007 //  * Redistributions in binary form must reproduce the above copyright
00008 //    notice, this list of conditions and the following disclaimer in the
00009 //    documentation and/or other materials provided with the distribution.
00010 //  * Neither the name of NVIDIA CORPORATION nor the names of its
00011 //    contributors may be used to endorse or promote products derived
00012 //    from this software without specific prior written permission.
00013 //
00014 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY
00015 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00016 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
00017 // PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR
00018 // CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
00019 // EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
00020 // PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
00021 // PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
00022 // OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
00023 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
00024 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
00025 //
00026 // Copyright (c) 2008-2018 NVIDIA Corporation. All rights reserved.
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     Instrumented profiling events
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 } // end of physx namespace
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


Copyright © 2008-2018 NVIDIA Corporation, 2701 San Tomas Expressway, Santa Clara, CA 95050 U.S.A. All rights reserved. www.nvidia.com