1
0
mirror of https://github.com/wolfpld/tracy synced 2025-04-30 20:53:52 +00:00

Accept zero-depth callstack

This commit is contained in:
Igor S. Gerasimov 2024-12-27 10:53:49 +01:00
parent 117ab107c1
commit 39137d809e

View File

@ -4291,9 +4291,16 @@ TRACY_API TracyCZoneCtx ___tracy_emit_zone_begin_callstack( const struct ___trac
TracyQueueCommitC( zoneValidationThread ); TracyQueueCommitC( zoneValidationThread );
} }
#endif #endif
tracy::GetProfiler().SendCallstack( depth ); if (depth > 0 && tracy::has_stacktrace()) {
{ tracy::GetProfiler().SendCallstack( depth );
TracyQueuePrepareC( tracy::QueueType::ZoneBeginCallstack ); {
TracyQueuePrepareC( tracy::QueueType::ZoneBeginCallstack );
tracy::MemWrite( &item->zoneBegin.time, tracy::Profiler::GetTime() );
tracy::MemWrite( &item->zoneBegin.srcloc, (uint64_t)srcloc );
TracyQueueCommitC( zoneBeginThread );
}
} else {
TracyQueuePrepareC( tracy::QueueType::ZoneBegin );
tracy::MemWrite( &item->zoneBegin.time, tracy::Profiler::GetTime() ); tracy::MemWrite( &item->zoneBegin.time, tracy::Profiler::GetTime() );
tracy::MemWrite( &item->zoneBegin.srcloc, (uint64_t)srcloc ); tracy::MemWrite( &item->zoneBegin.srcloc, (uint64_t)srcloc );
TracyQueueCommitC( zoneBeginThread ); TracyQueueCommitC( zoneBeginThread );
@ -4356,9 +4363,16 @@ TRACY_API TracyCZoneCtx ___tracy_emit_zone_begin_alloc_callstack( uint64_t srclo
TracyQueueCommitC( zoneValidationThread ); TracyQueueCommitC( zoneValidationThread );
} }
#endif #endif
tracy::GetProfiler().SendCallstack( depth ); if (depth > 0 && tracy::has_stacktrace()) {
{ tracy::GetProfiler().SendCallstack( depth );
TracyQueuePrepareC( tracy::QueueType::ZoneBeginAllocSrcLocCallstack ); {
TracyQueuePrepareC( tracy::QueueType::ZoneBeginAllocSrcLocCallstack );
tracy::MemWrite( &item->zoneBegin.time, tracy::Profiler::GetTime() );
tracy::MemWrite( &item->zoneBegin.srcloc, srcloc );
TracyQueueCommitC( zoneBeginThread );
}
} else {
TracyQueuePrepareC( tracy::QueueType::ZoneBeginAllocSrcLoc );
tracy::MemWrite( &item->zoneBegin.time, tracy::Profiler::GetTime() ); tracy::MemWrite( &item->zoneBegin.time, tracy::Profiler::GetTime() );
tracy::MemWrite( &item->zoneBegin.srcloc, srcloc ); tracy::MemWrite( &item->zoneBegin.srcloc, srcloc );
TracyQueueCommitC( zoneBeginThread ); TracyQueueCommitC( zoneBeginThread );