tracy/client/TracyScoped.hpp

142 lines
4.3 KiB
C++
Raw Normal View History

2017-09-10 18:09:57 +00:00
#ifndef __TRACYSCOPED_HPP__
#define __TRACYSCOPED_HPP__
#include <stdint.h>
2017-09-28 19:10:02 +00:00
#include <string.h>
2017-09-10 18:09:57 +00:00
#include "../common/TracySystem.hpp"
#include "../common/TracyAlign.hpp"
#include "../common/TracyAlloc.hpp"
2017-09-10 18:09:57 +00:00
#include "TracyProfiler.hpp"
namespace tracy
{
class ScopedZone
{
public:
2017-10-03 13:10:25 +00:00
tracy_force_inline ScopedZone( const SourceLocation* srcloc )
#ifdef TRACY_ON_DEMAND
: m_active( s_profiler.IsConnected() )
#endif
2017-09-10 18:09:57 +00:00
{
2018-07-10 19:55:52 +00:00
#ifdef TRACY_ON_DEMAND
if( !m_active ) return;
#endif
2017-10-03 14:41:32 +00:00
const auto thread = GetThreadHandle();
m_thread = thread;
2017-10-03 12:50:55 +00:00
Magic magic;
2017-10-10 23:44:35 +00:00
auto& token = s_token.ptr;
2017-10-10 23:27:22 +00:00
auto& tail = token->get_tail_index();
auto item = token->enqueue_begin<tracy::moodycamel::CanAlloc>( magic );
MemWrite( &item->hdr.type, QueueType::ZoneBegin );
#ifdef TRACY_RDTSCP_OPT
MemWrite( &item->zoneBegin.time, Profiler::GetTime( item->zoneBegin.cpu ) );
#else
uint32_t cpu;
MemWrite( &item->zoneBegin.time, Profiler::GetTime( cpu ) );
MemWrite( &item->zoneBegin.cpu, cpu );
#endif
MemWrite( &item->zoneBegin.thread, thread );
MemWrite( &item->zoneBegin.srcloc, (uint64_t)srcloc );
2017-10-10 23:27:22 +00:00
tail.store( magic + 1, std::memory_order_release );
2017-09-10 18:09:57 +00:00
}
2018-06-21 22:56:01 +00:00
tracy_force_inline ScopedZone( const SourceLocation* srcloc, int depth )
#ifdef TRACY_ON_DEMAND
: m_active( s_profiler.IsConnected() )
#endif
2018-06-21 22:56:01 +00:00
{
2018-07-10 19:55:52 +00:00
#ifdef TRACY_ON_DEMAND
if( !m_active ) return;
#endif
2018-06-21 22:56:01 +00:00
const auto thread = GetThreadHandle();
m_thread = thread;
Magic magic;
auto& token = s_token.ptr;
auto& tail = token->get_tail_index();
auto item = token->enqueue_begin<tracy::moodycamel::CanAlloc>( magic );
2018-06-21 22:56:01 +00:00
MemWrite( &item->hdr.type, QueueType::ZoneBeginCallstack );
#ifdef TRACY_RDTSCP_OPT
MemWrite( &item->zoneBegin.time, Profiler::GetTime( item->zoneBegin.cpu ) );
#else
uint32_t cpu;
MemWrite( &item->zoneBegin.time, Profiler::GetTime( cpu ) );
MemWrite( &item->zoneBegin.cpu, cpu );
#endif
MemWrite( &item->zoneBegin.thread, thread );
MemWrite( &item->zoneBegin.srcloc, (uint64_t)srcloc );
tail.store( magic + 1, std::memory_order_release );
s_profiler.SendCallstack( depth, thread );
}
2017-10-03 13:10:25 +00:00
tracy_force_inline ~ScopedZone()
2017-09-10 18:09:57 +00:00
{
2018-07-10 19:55:52 +00:00
#ifdef TRACY_ON_DEMAND
if( !m_active ) return;
#endif
2017-10-03 12:50:55 +00:00
Magic magic;
2017-10-10 23:44:35 +00:00
auto& token = s_token.ptr;
2017-10-10 23:27:22 +00:00
auto& tail = token->get_tail_index();
auto item = token->enqueue_begin<tracy::moodycamel::CanAlloc>( magic );
MemWrite( &item->hdr.type, QueueType::ZoneEnd );
#ifdef TRACY_RDTSCP_OPT
MemWrite( &item->zoneEnd.time, Profiler::GetTime( item->zoneEnd.cpu ) );
#else
uint32_t cpu;
MemWrite( &item->zoneEnd.time, Profiler::GetTime( cpu ) );
2018-06-20 20:27:46 +00:00
MemWrite( &item->zoneEnd.cpu, cpu );
#endif
MemWrite( &item->zoneEnd.thread, m_thread );
2017-10-10 23:27:22 +00:00
tail.store( magic + 1, std::memory_order_release );
2017-09-10 18:09:57 +00:00
}
2017-10-03 13:10:25 +00:00
tracy_force_inline void Text( const char* txt, size_t size )
2017-09-27 00:18:17 +00:00
{
2018-07-10 19:55:52 +00:00
#ifdef TRACY_ON_DEMAND
if( !m_active ) return;
#endif
2017-10-03 12:50:55 +00:00
Magic magic;
auto& token = s_token.ptr;
auto ptr = (char*)tracy_malloc( size+1 );
2017-09-27 00:18:17 +00:00
memcpy( ptr, txt, size );
ptr[size] = '\0';
2017-10-10 23:27:22 +00:00
auto& tail = token->get_tail_index();
auto item = token->enqueue_begin<tracy::moodycamel::CanAlloc>( magic );
MemWrite( &item->hdr.type, QueueType::ZoneText );
MemWrite( &item->zoneText.thread, m_thread );
MemWrite( &item->zoneText.text, (uint64_t)ptr );
2017-10-10 23:27:22 +00:00
tail.store( magic + 1, std::memory_order_release );
2017-09-27 00:18:17 +00:00
}
2018-06-29 14:01:31 +00:00
tracy_force_inline void Name( const char* txt, size_t size )
{
2018-07-10 19:55:52 +00:00
#ifdef TRACY_ON_DEMAND
if( !m_active ) return;
#endif
2018-06-29 14:01:31 +00:00
Magic magic;
auto& token = s_token.ptr;
auto ptr = (char*)tracy_malloc( size+1 );
memcpy( ptr, txt, size );
ptr[size] = '\0';
auto& tail = token->get_tail_index();
auto item = token->enqueue_begin<tracy::moodycamel::CanAlloc>( magic );
2018-06-29 14:01:31 +00:00
MemWrite( &item->hdr.type, QueueType::ZoneName );
MemWrite( &item->zoneText.thread, m_thread );
MemWrite( &item->zoneText.text, (uint64_t)ptr );
tail.store( magic + 1, std::memory_order_release );
}
2017-09-10 18:09:57 +00:00
private:
2017-10-03 14:41:32 +00:00
uint64_t m_thread;
2018-07-10 19:55:52 +00:00
#ifdef TRACY_ON_DEMAND
const bool m_active;
2018-07-10 19:55:52 +00:00
#endif
2017-09-10 18:09:57 +00:00
};
}
#endif