mirror of
https://github.com/wolfpld/tracy.git
synced 2024-11-22 14:44:34 +00:00
linux: respect TRACY_NO_SAMPLING
for sys-tracing
This compile-time flag was being ignored on Linux. This change adds gating for software-sampled stack trace sampling following the same pattern as other `TRACY_NO_SAMPLE_*` options. If `TRACY_NO_SAMPLING=1` is provided as an environment variable, software stack sampling is also disabled.
This commit is contained in:
parent
2b7b79352b
commit
6249999153
@ -770,6 +770,13 @@ bool SysTraceStart( int64_t& samplingPeriod )
|
|||||||
TracyDebug( "sched_wakeup id: %i\n", wakeupId );
|
TracyDebug( "sched_wakeup id: %i\n", wakeupId );
|
||||||
TracyDebug( "drm_vblank_event id: %i\n", vsyncId );
|
TracyDebug( "drm_vblank_event id: %i\n", vsyncId );
|
||||||
|
|
||||||
|
#ifdef TRACY_NO_SAMPLING
|
||||||
|
const bool noSoftwareSampling = true;
|
||||||
|
#else
|
||||||
|
const char* noSoftwareSamplingEnv = GetEnvVar( "TRACY_NO_SAMPLING" );
|
||||||
|
const bool noSoftwareSampling = noSoftwareSamplingEnv && noSoftwareSamplingEnv[0] == '1';
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef TRACY_NO_SAMPLE_RETIREMENT
|
#ifdef TRACY_NO_SAMPLE_RETIREMENT
|
||||||
const bool noRetirement = true;
|
const bool noRetirement = true;
|
||||||
#else
|
#else
|
||||||
@ -839,28 +846,31 @@ bool SysTraceStart( int64_t& samplingPeriod )
|
|||||||
pe.clockid = CLOCK_MONOTONIC_RAW;
|
pe.clockid = CLOCK_MONOTONIC_RAW;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
TracyDebug( "Setup software sampling\n" );
|
if( !noSoftwareSampling )
|
||||||
ProbePreciseIp( pe, currentPid );
|
|
||||||
for( int i=0; i<s_numCpus; i++ )
|
|
||||||
{
|
{
|
||||||
int fd = perf_event_open( &pe, currentPid, i, -1, PERF_FLAG_FD_CLOEXEC );
|
TracyDebug( "Setup software sampling\n" );
|
||||||
if( fd == -1 )
|
ProbePreciseIp( pe, currentPid );
|
||||||
|
for( int i=0; i<s_numCpus; i++ )
|
||||||
{
|
{
|
||||||
pe.exclude_kernel = 1;
|
int fd = perf_event_open( &pe, currentPid, i, -1, PERF_FLAG_FD_CLOEXEC );
|
||||||
ProbePreciseIp( pe, currentPid );
|
|
||||||
fd = perf_event_open( &pe, currentPid, i, -1, PERF_FLAG_FD_CLOEXEC );
|
|
||||||
if( fd == -1 )
|
if( fd == -1 )
|
||||||
{
|
{
|
||||||
TracyDebug( " Failed to setup!\n");
|
pe.exclude_kernel = 1;
|
||||||
break;
|
ProbePreciseIp( pe, currentPid );
|
||||||
|
fd = perf_event_open( &pe, currentPid, i, -1, PERF_FLAG_FD_CLOEXEC );
|
||||||
|
if( fd == -1 )
|
||||||
|
{
|
||||||
|
TracyDebug( " Failed to setup!\n");
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
TracyDebug( " No access to kernel samples\n" );
|
||||||
|
}
|
||||||
|
new( s_ring+s_numBuffers ) RingBuffer( 64*1024, fd, EventCallstack );
|
||||||
|
if( s_ring[s_numBuffers].IsValid() )
|
||||||
|
{
|
||||||
|
s_numBuffers++;
|
||||||
|
TracyDebug( " Core %i ok\n", i );
|
||||||
}
|
}
|
||||||
TracyDebug( " No access to kernel samples\n" );
|
|
||||||
}
|
|
||||||
new( s_ring+s_numBuffers ) RingBuffer( 64*1024, fd, EventCallstack );
|
|
||||||
if( s_ring[s_numBuffers].IsValid() )
|
|
||||||
{
|
|
||||||
s_numBuffers++;
|
|
||||||
TracyDebug( " Core %i ok\n", i );
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user