30a629ca21
* Tracy profiler integration. * Cleanup URHO3D_TRACY_PROFILING macro. * Fix comment of Tracy build option. * Decouple URHO3D_TRACY_PROFILING exclusively from URHO3D_PROFILING. * Comment explains URHO3D_TRACY_PROFILING * Update * Update CMakeLists.txt * Update CMakeLists.txt * Update CMakeLists.txt * Update CMakeLists.txt * Update * Update TracyCallstack.cpp * Update * Update CMakeLists.txt * Update TracyCallstack.cpp * Update TracyCallstack.cpp Co-authored-by: 1vanK <1vanK@users.noreply.github.com>
256 lines
16 KiB
C++
256 lines
16 KiB
C++
#ifndef __TRACY_HPP__
|
|
#define __TRACY_HPP__
|
|
|
|
#include "common/TracyColor.hpp"
|
|
#include "common/TracySystem.hpp"
|
|
|
|
#ifndef TRACY_ENABLE
|
|
|
|
#define ZoneNamed(x,y)
|
|
#define ZoneNamedN(x,y,z)
|
|
#define ZoneNamedC(x,y,z)
|
|
#define ZoneNamedNC(x,y,z,w)
|
|
|
|
#define ZoneTransient(x,y)
|
|
#define ZoneTransientN(x,y,z)
|
|
|
|
#define ZoneScoped
|
|
#define ZoneScopedN(x)
|
|
#define ZoneScopedC(x)
|
|
#define ZoneScopedNC(x,y)
|
|
|
|
#define ZoneText(x,y)
|
|
#define ZoneTextV(x,y,z)
|
|
#define ZoneName(x,y)
|
|
#define ZoneNameV(x,y,z)
|
|
#define ZoneColor(x)
|
|
#define ZoneColorV(x,y)
|
|
#define ZoneValue(x)
|
|
#define ZoneValueV(x,y)
|
|
|
|
#define FrameMark
|
|
#define FrameMarkNamed(x)
|
|
#define FrameMarkStart(x)
|
|
#define FrameMarkEnd(x)
|
|
|
|
#define FrameImage(x,y,z,w,a)
|
|
|
|
#define TracyLockable( type, varname ) type varname;
|
|
#define TracyLockableN( type, varname, desc ) type varname;
|
|
#define TracySharedLockable( type, varname ) type varname;
|
|
#define TracySharedLockableN( type, varname, desc ) type varname;
|
|
#define LockableBase( type ) type
|
|
#define SharedLockableBase( type ) type
|
|
#define LockMark(x) (void)x;
|
|
#define LockableName(x,y,z);
|
|
|
|
#define TracyPlot(x,y)
|
|
#define TracyPlotConfig(x,y)
|
|
|
|
#define TracyMessage(x,y)
|
|
#define TracyMessageL(x)
|
|
#define TracyMessageC(x,y,z)
|
|
#define TracyMessageLC(x,y)
|
|
#define TracyAppInfo(x,y)
|
|
|
|
#define TracyAlloc(x,y)
|
|
#define TracyFree(x)
|
|
#define TracySecureAlloc(x,y)
|
|
#define TracySecureFree(x)
|
|
|
|
#define TracyAllocN(x,y,z)
|
|
#define TracyFreeN(x,y)
|
|
#define TracySecureAllocN(x,y,z)
|
|
#define TracySecureFreeN(x,y)
|
|
|
|
#define ZoneNamedS(x,y,z)
|
|
#define ZoneNamedNS(x,y,z,w)
|
|
#define ZoneNamedCS(x,y,z,w)
|
|
#define ZoneNamedNCS(x,y,z,w,a)
|
|
|
|
#define ZoneTransientS(x,y,z)
|
|
#define ZoneTransientNS(x,y,z,w)
|
|
|
|
#define ZoneScopedS(x)
|
|
#define ZoneScopedNS(x,y)
|
|
#define ZoneScopedCS(x,y)
|
|
#define ZoneScopedNCS(x,y,z)
|
|
|
|
#define TracyAllocS(x,y,z)
|
|
#define TracyFreeS(x,y)
|
|
#define TracySecureAllocS(x,y,z)
|
|
#define TracySecureFreeS(x,y)
|
|
|
|
#define TracyAllocNS(x,y,z,w)
|
|
#define TracyFreeNS(x,y,z)
|
|
#define TracySecureAllocNS(x,y,z,w)
|
|
#define TracySecureFreeNS(x,y,z)
|
|
|
|
#define TracyMessageS(x,y,z)
|
|
#define TracyMessageLS(x,y)
|
|
#define TracyMessageCS(x,y,z,w)
|
|
#define TracyMessageLCS(x,y,z)
|
|
|
|
#define TracyParameterRegister(x)
|
|
#define TracyParameterSetup(x,y,z,w)
|
|
#define TracyIsConnected false
|
|
|
|
#else
|
|
|
|
#include <string.h>
|
|
|
|
#include "client/TracyLock.hpp"
|
|
#include "client/TracyProfiler.hpp"
|
|
#include "client/TracyScoped.hpp"
|
|
|
|
#if defined TRACY_HAS_CALLSTACK && defined TRACY_CALLSTACK
|
|
# define ZoneNamed( varname, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { nullptr, __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), TRACY_CALLSTACK, active );
|
|
# define ZoneNamedN( varname, name, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { name, __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), TRACY_CALLSTACK, active );
|
|
# define ZoneNamedC( varname, color, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { nullptr, __FUNCTION__, __FILE__, (uint32_t)__LINE__, color }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), TRACY_CALLSTACK, active );
|
|
# define ZoneNamedNC( varname, name, color, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { name, __FUNCTION__, __FILE__, (uint32_t)__LINE__, color }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), TRACY_CALLSTACK, active );
|
|
|
|
# define ZoneTransient( varname, active ) tracy::ScopedZone varname( __LINE__, __FILE__, strlen( __FILE__ ), __FUNCTION__, strlen( __FUNCTION__ ), nullptr, 0, TRACY_CALLSTACK, active );
|
|
# define ZoneTransientN( varname, name, active ) tracy::ScopedZone varname( __LINE__, __FILE__, strlen( __FILE__ ), __FUNCTION__, strlen( __FUNCTION__ ), name, strlen( name ), TRACY_CALLSTACK, active );
|
|
#else
|
|
# define ZoneNamed( varname, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { nullptr, __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), active );
|
|
# define ZoneNamedN( varname, name, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { name, __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), active );
|
|
# define ZoneNamedC( varname, color, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { nullptr, __FUNCTION__, __FILE__, (uint32_t)__LINE__, color }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), active );
|
|
# define ZoneNamedNC( varname, name, color, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { name, __FUNCTION__, __FILE__, (uint32_t)__LINE__, color }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), active );
|
|
|
|
# define ZoneTransient( varname, active ) tracy::ScopedZone varname( __LINE__, __FILE__, strlen( __FILE__ ), __FUNCTION__, strlen( __FUNCTION__ ), nullptr, 0, active );
|
|
# define ZoneTransientN( varname, name, active ) tracy::ScopedZone varname( __LINE__, __FILE__, strlen( __FILE__ ), __FUNCTION__, strlen( __FUNCTION__ ), name, strlen( name ), active );
|
|
#endif
|
|
|
|
#define ZoneScoped ZoneNamed( ___tracy_scoped_zone, true )
|
|
#define ZoneScopedN( name ) ZoneNamedN( ___tracy_scoped_zone, name, true )
|
|
#define ZoneScopedC( color ) ZoneNamedC( ___tracy_scoped_zone, color, true )
|
|
#define ZoneScopedNC( name, color ) ZoneNamedNC( ___tracy_scoped_zone, name, color, true )
|
|
|
|
#define ZoneText( txt, size ) ___tracy_scoped_zone.Text( txt, size );
|
|
#define ZoneTextV( varname, txt, size ) varname.Text( txt, size );
|
|
#define ZoneName( txt, size ) ___tracy_scoped_zone.Name( txt, size );
|
|
#define ZoneNameV( varname, txt, size ) varname.Name( txt, size );
|
|
#define ZoneColor( color ) __trace_scoped_zone.Color( color );
|
|
#define ZoneColorV( varname, color ) varname.Color( color );
|
|
#define ZoneValue( value ) ___tracy_scoped_zone.Value( value );
|
|
#define ZoneValueV( varname, value ) varname.Value( value );
|
|
|
|
#define FrameMark tracy::Profiler::SendFrameMark( nullptr );
|
|
#define FrameMarkNamed( name ) tracy::Profiler::SendFrameMark( name );
|
|
#define FrameMarkStart( name ) tracy::Profiler::SendFrameMark( name, tracy::QueueType::FrameMarkMsgStart );
|
|
#define FrameMarkEnd( name ) tracy::Profiler::SendFrameMark( name, tracy::QueueType::FrameMarkMsgEnd );
|
|
|
|
#define FrameImage( image, width, height, offset, flip ) tracy::Profiler::SendFrameImage( image, width, height, offset, flip );
|
|
|
|
#define TracyLockable( type, varname ) tracy::Lockable<type> varname { [] () -> const tracy::SourceLocationData* { static constexpr tracy::SourceLocationData srcloc { nullptr, #type " " #varname, __FILE__, __LINE__, 0 }; return &srcloc; }() };
|
|
#define TracyLockableN( type, varname, desc ) tracy::Lockable<type> varname { [] () -> const tracy::SourceLocationData* { static constexpr tracy::SourceLocationData srcloc { nullptr, desc, __FILE__, __LINE__, 0 }; return &srcloc; }() };
|
|
#define TracySharedLockable( type, varname ) tracy::SharedLockable<type> varname { [] () -> const tracy::SourceLocationData* { static constexpr tracy::SourceLocationData srcloc { nullptr, #type " " #varname, __FILE__, __LINE__, 0 }; return &srcloc; }() };
|
|
#define TracySharedLockableN( type, varname, desc ) tracy::SharedLockable<type> varname { [] () -> const tracy::SourceLocationData* { static constexpr tracy::SourceLocationData srcloc { nullptr, desc, __FILE__, __LINE__, 0 }; return &srcloc; }() };
|
|
#define LockableBase( type ) tracy::Lockable<type>
|
|
#define SharedLockableBase( type ) tracy::SharedLockable<type>
|
|
#define LockMark( varname ) static constexpr tracy::SourceLocationData __tracy_lock_location_##varname { nullptr, __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 }; varname.Mark( &__tracy_lock_location_##varname );
|
|
#define LockableName( varname, txt, size ) varname.CustomName( txt, size );
|
|
|
|
#define TracyPlot( name, val ) tracy::Profiler::PlotData( name, val );
|
|
#define TracyPlotConfig( name, type ) tracy::Profiler::ConfigurePlot( name, type );
|
|
|
|
#define TracyAppInfo( txt, size ) tracy::Profiler::MessageAppInfo( txt, size );
|
|
|
|
#if defined TRACY_HAS_CALLSTACK && defined TRACY_CALLSTACK
|
|
# define TracyMessage( txt, size ) tracy::Profiler::Message( txt, size, TRACY_CALLSTACK );
|
|
# define TracyMessageL( txt ) tracy::Profiler::Message( txt, TRACY_CALLSTACK );
|
|
# define TracyMessageC( txt, size, color ) tracy::Profiler::MessageColor( txt, size, color, TRACY_CALLSTACK );
|
|
# define TracyMessageLC( txt, color ) tracy::Profiler::MessageColor( txt, color, TRACY_CALLSTACK );
|
|
|
|
# define TracyAlloc( ptr, size ) tracy::Profiler::MemAllocCallstack( ptr, size, TRACY_CALLSTACK, false );
|
|
# define TracyFree( ptr ) tracy::Profiler::MemFreeCallstack( ptr, TRACY_CALLSTACK, false );
|
|
# define TracySecureAlloc( ptr, size ) tracy::Profiler::MemAllocCallstack( ptr, size, TRACY_CALLSTACK, true );
|
|
# define TracySecureFree( ptr ) tracy::Profiler::MemFreeCallstack( ptr, TRACY_CALLSTACK, true );
|
|
|
|
# define TracyAllocN( ptr, size, name ) tracy::Profiler::MemAllocCallstackNamed( ptr, size, TRACY_CALLSTACK, false, name );
|
|
# define TracyFreeN( ptr, name ) tracy::Profiler::MemFreeCallstackNamed( ptr, TRACY_CALLSTACK, false, name );
|
|
# define TracySecureAllocN( ptr, size, name ) tracy::Profiler::MemAllocCallstackNamed( ptr, size, TRACY_CALLSTACK, true, name );
|
|
# define TracySecureFreeN( ptr, name ) tracy::Profiler::MemFreeCallstackNamed( ptr, TRACY_CALLSTACK, true, name );
|
|
#else
|
|
# define TracyMessage( txt, size ) tracy::Profiler::Message( txt, size, 0 );
|
|
# define TracyMessageL( txt ) tracy::Profiler::Message( txt, 0 );
|
|
# define TracyMessageC( txt, size, color ) tracy::Profiler::MessageColor( txt, size, color, 0 );
|
|
# define TracyMessageLC( txt, color ) tracy::Profiler::MessageColor( txt, color, 0 );
|
|
|
|
# define TracyAlloc( ptr, size ) tracy::Profiler::MemAlloc( ptr, size, false );
|
|
# define TracyFree( ptr ) tracy::Profiler::MemFree( ptr, false );
|
|
# define TracySecureAlloc( ptr, size ) tracy::Profiler::MemAlloc( ptr, size, true );
|
|
# define TracySecureFree( ptr ) tracy::Profiler::MemFree( ptr, true );
|
|
|
|
# define TracyAllocN( ptr, size, name ) tracy::Profiler::MemAllocNamed( ptr, size, false, name );
|
|
# define TracyFreeN( ptr, name ) tracy::Profiler::MemFreeNamed( ptr, false, name );
|
|
# define TracySecureAllocN( ptr, size, name ) tracy::Profiler::MemAllocNamed( ptr, size, true, name );
|
|
# define TracySecureFreeN( ptr, name ) tracy::Profiler::MemFreeNamed( ptr, true, name );
|
|
#endif
|
|
|
|
#ifdef TRACY_HAS_CALLSTACK
|
|
# define ZoneNamedS( varname, depth, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { nullptr, __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), depth, active );
|
|
# define ZoneNamedNS( varname, name, depth, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { name, __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), depth, active );
|
|
# define ZoneNamedCS( varname, color, depth, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { nullptr, __FUNCTION__, __FILE__, (uint32_t)__LINE__, color }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), depth, active );
|
|
# define ZoneNamedNCS( varname, name, color, depth, active ) static constexpr tracy::SourceLocationData TracyConcat(__tracy_source_location,__LINE__) { name, __FUNCTION__, __FILE__, (uint32_t)__LINE__, color }; tracy::ScopedZone varname( &TracyConcat(__tracy_source_location,__LINE__), depth, active );
|
|
|
|
# define ZoneTransientS( varname, depth, active ) tracy::ScopedZone varname( __LINE__, __FILE__, strlen( __FILE__ ), __FUNCTION__, strlen( __FUNCTION__ ), nullptr, 0, depth, active );
|
|
# define ZoneTransientNS( varname, name, depth, active ) tracy::ScopedZone varname( __LINE__, __FILE__, strlen( __FILE__ ), __FUNCTION__, strlen( __FUNCTION__ ), name, strlen( name ), depth, active );
|
|
|
|
# define ZoneScopedS( depth ) ZoneNamedS( ___tracy_scoped_zone, depth, true )
|
|
# define ZoneScopedNS( name, depth ) ZoneNamedNS( ___tracy_scoped_zone, name, depth, true )
|
|
# define ZoneScopedCS( color, depth ) ZoneNamedCS( ___tracy_scoped_zone, color, depth, true )
|
|
# define ZoneScopedNCS( name, color, depth ) ZoneNamedNCS( ___tracy_scoped_zone, name, color, depth, true )
|
|
|
|
# define TracyAllocS( ptr, size, depth ) tracy::Profiler::MemAllocCallstack( ptr, size, depth, false );
|
|
# define TracyFreeS( ptr, depth ) tracy::Profiler::MemFreeCallstack( ptr, depth, false );
|
|
# define TracySecureAllocS( ptr, size, depth ) tracy::Profiler::MemAllocCallstack( ptr, size, depth, true );
|
|
# define TracySecureFreeS( ptr, depth ) tracy::Profiler::MemFreeCallstack( ptr, depth, true );
|
|
|
|
# define TracyAllocNS( ptr, size, depth, name ) tracy::Profiler::MemAllocCallstackNamed( ptr, size, depth, false, name );
|
|
# define TracyFreeNS( ptr, depth, name ) tracy::Profiler::MemFreeCallstackNamed( ptr, depth, false, name );
|
|
# define TracySecureAllocNS( ptr, size, depth, name ) tracy::Profiler::MemAllocCallstackNamed( ptr, size, depth, true, name );
|
|
# define TracySecureFreeNS( ptr, depth, name ) tracy::Profiler::MemFreeCallstackNamed( ptr, depth, true, name );
|
|
|
|
# define TracyMessageS( txt, size, depth ) tracy::Profiler::Message( txt, size, depth );
|
|
# define TracyMessageLS( txt, depth ) tracy::Profiler::Message( txt, depth );
|
|
# define TracyMessageCS( txt, size, color, depth ) tracy::Profiler::MessageColor( txt, size, color, depth );
|
|
# define TracyMessageLCS( txt, color, depth ) tracy::Profiler::MessageColor( txt, color, depth );
|
|
#else
|
|
# define ZoneNamedS( varname, depth, active ) ZoneNamed( varname, active )
|
|
# define ZoneNamedNS( varname, name, depth, active ) ZoneNamedN( varname, name, active )
|
|
# define ZoneNamedCS( varname, color, depth, active ) ZoneNamedC( varname, color, active )
|
|
# define ZoneNamedNCS( varname, name, color, depth, active ) ZoneNamedNC( varname, name, color, active )
|
|
|
|
# define ZoneTransientS( varname, depth, active ) ZoneTransient( varname, active )
|
|
# define ZoneTransientNS( varname, name, depth, active ) ZoneTransientN( varname, name, active )
|
|
|
|
# define ZoneScopedS( depth ) ZoneScoped
|
|
# define ZoneScopedNS( name, depth ) ZoneScopedN( name )
|
|
# define ZoneScopedCS( color, depth ) ZoneScopedC( color )
|
|
# define ZoneScopedNCS( name, color, depth ) ZoneScopedNC( name, color )
|
|
|
|
# define TracyAllocS( ptr, size, depth ) TracyAlloc( ptr, size )
|
|
# define TracyFreeS( ptr, depth ) TracyFree( ptr )
|
|
# define TracySecureAllocS( ptr, size, depth ) TracySecureAlloc( ptr, size )
|
|
# define TracySecureFreeS( ptr, depth ) TracySecureFree( ptr )
|
|
|
|
# define TracyAllocNS( ptr, size, depth, name ) TracyAlloc( ptr, size, name )
|
|
# define TracyFreeNS( ptr, depth, name ) TracyFree( ptr, name )
|
|
# define TracySecureAllocNS( ptr, size, depth, name ) TracySecureAlloc( ptr, size, name )
|
|
# define TracySecureFreeNS( ptr, depth, name ) TracySecureFree( ptr, name )
|
|
|
|
# define TracyMessageS( txt, size, depth ) TracyMessage( txt, size )
|
|
# define TracyMessageLS( txt, depth ) TracyMessageL( txt )
|
|
# define TracyMessageCS( txt, size, color, depth ) TracyMessageC( txt, size, color )
|
|
# define TracyMessageLCS( txt, color, depth ) TracyMessageLC( txt, color )
|
|
#endif
|
|
|
|
#define TracyParameterRegister( cb ) tracy::Profiler::ParameterRegister( cb );
|
|
#define TracyParameterSetup( idx, name, isBool, val ) tracy::Profiler::ParameterSetup( idx, name, isBool, val );
|
|
#define TracyIsConnected tracy::GetProfiler().IsConnected()
|
|
|
|
#endif
|
|
|
|
#endif
|