mirror of
https://github.com/wolfpld/tracy.git
synced 2024-11-23 06:44:35 +00:00
Send sampled call stacks.
This commit is contained in:
parent
f186540c4f
commit
9e9c7db5b1
@ -77,6 +77,14 @@ struct ThreadTrace
|
|||||||
uint32_t subProcessTag;
|
uint32_t subProcessTag;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct StackWalkEvent
|
||||||
|
{
|
||||||
|
uint64_t eventTimeStamp;
|
||||||
|
uint32_t stackProcess;
|
||||||
|
uint32_t stackThread;
|
||||||
|
uint64_t stack[192];
|
||||||
|
};
|
||||||
|
|
||||||
void WINAPI EventRecordCallback( PEVENT_RECORD record )
|
void WINAPI EventRecordCallback( PEVENT_RECORD record )
|
||||||
{
|
{
|
||||||
#ifdef TRACY_ON_DEMAND
|
#ifdef TRACY_ON_DEMAND
|
||||||
@ -125,6 +133,24 @@ void WINAPI EventRecordCallback( PEVENT_RECORD record )
|
|||||||
TracyLfqCommit;
|
TracyLfqCommit;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 0xdef2fe46: // StackWalk Guid
|
||||||
|
if( hdr.EventDescriptor.Opcode == 32 )
|
||||||
|
{
|
||||||
|
const auto sw = (const StackWalkEvent*)record->UserData;
|
||||||
|
if( sw->stackProcess == s_pid )
|
||||||
|
{
|
||||||
|
const uint64_t sz = ( record->UserDataLength - 16 ) / 8;
|
||||||
|
auto trace = (uint64_t*)tracy_malloc( ( 1 + sz ) * sizeof( uint64_t ) );
|
||||||
|
memcpy( trace, &sz, sizeof( uint64_t ) );
|
||||||
|
memcpy( trace+1, sw->stack, sizeof( uint64_t ) * sz );
|
||||||
|
TracyLfqPrepare( QueueType::CallstackSample );
|
||||||
|
MemWrite( &item->callstackSample.time, sw->eventTimeStamp );
|
||||||
|
MemWrite( &item->callstackSample.thread, (uint64_t)sw->stackThread );
|
||||||
|
MemWrite( &item->callstackSample.ptr, (uint64_t)trace );
|
||||||
|
TracyLfqCommit;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -9,7 +9,7 @@ namespace tracy
|
|||||||
|
|
||||||
constexpr unsigned Lz4CompressBound( unsigned isize ) { return isize + ( isize / 255 ) + 16; }
|
constexpr unsigned Lz4CompressBound( unsigned isize ) { return isize + ( isize / 255 ) + 16; }
|
||||||
|
|
||||||
enum : uint32_t { ProtocolVersion = 25 };
|
enum : uint32_t { ProtocolVersion = 26 };
|
||||||
enum : uint32_t { BroadcastVersion = 0 };
|
enum : uint32_t { BroadcastVersion = 0 };
|
||||||
|
|
||||||
using lz4sz_t = uint32_t;
|
using lz4sz_t = uint32_t;
|
||||||
|
@ -20,6 +20,7 @@ enum class QueueType : uint8_t
|
|||||||
CallstackMemory,
|
CallstackMemory,
|
||||||
Callstack,
|
Callstack,
|
||||||
CallstackAlloc,
|
CallstackAlloc,
|
||||||
|
CallstackSample,
|
||||||
FrameImage,
|
FrameImage,
|
||||||
ZoneBegin,
|
ZoneBegin,
|
||||||
ZoneBeginCallstack,
|
ZoneBeginCallstack,
|
||||||
@ -290,6 +291,13 @@ struct QueueCallstackAlloc
|
|||||||
uint64_t nativePtr;
|
uint64_t nativePtr;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct QueueCallstackSample
|
||||||
|
{
|
||||||
|
int64_t time;
|
||||||
|
uint64_t thread;
|
||||||
|
uint64_t ptr;
|
||||||
|
};
|
||||||
|
|
||||||
struct QueueCallstackFrameSize
|
struct QueueCallstackFrameSize
|
||||||
{
|
{
|
||||||
uint64_t ptr;
|
uint64_t ptr;
|
||||||
@ -406,6 +414,7 @@ struct QueueItem
|
|||||||
QueueCallstackMemory callstackMemory;
|
QueueCallstackMemory callstackMemory;
|
||||||
QueueCallstack callstack;
|
QueueCallstack callstack;
|
||||||
QueueCallstackAlloc callstackAlloc;
|
QueueCallstackAlloc callstackAlloc;
|
||||||
|
QueueCallstackSample callstackSample;
|
||||||
QueueCallstackFrameSize callstackFrameSize;
|
QueueCallstackFrameSize callstackFrameSize;
|
||||||
QueueCallstackFrame callstackFrame;
|
QueueCallstackFrame callstackFrame;
|
||||||
QueueCrashReport crashReport;
|
QueueCrashReport crashReport;
|
||||||
@ -436,6 +445,7 @@ static constexpr size_t QueueDataSize[] = {
|
|||||||
sizeof( QueueHeader ) + sizeof( QueueCallstackMemory ),
|
sizeof( QueueHeader ) + sizeof( QueueCallstackMemory ),
|
||||||
sizeof( QueueHeader ) + sizeof( QueueCallstack ),
|
sizeof( QueueHeader ) + sizeof( QueueCallstack ),
|
||||||
sizeof( QueueHeader ) + sizeof( QueueCallstackAlloc ),
|
sizeof( QueueHeader ) + sizeof( QueueCallstackAlloc ),
|
||||||
|
sizeof( QueueHeader ) + sizeof( QueueCallstackSample ),
|
||||||
sizeof( QueueHeader ) + sizeof( QueueFrameImage ),
|
sizeof( QueueHeader ) + sizeof( QueueFrameImage ),
|
||||||
sizeof( QueueHeader ) + sizeof( QueueZoneBegin ),
|
sizeof( QueueHeader ) + sizeof( QueueZoneBegin ),
|
||||||
sizeof( QueueHeader ) + sizeof( QueueZoneBegin ), // callstack
|
sizeof( QueueHeader ) + sizeof( QueueZoneBegin ), // callstack
|
||||||
|
Loading…
Reference in New Issue
Block a user