mirror of
https://github.com/wolfpld/tracy
synced 2025-04-29 12:23:53 +00:00
Remove one stack address load.
This commit is contained in:
parent
af3773dc9a
commit
77dfefb5d0
@ -20,11 +20,12 @@ public:
|
|||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::LockAnnounce;
|
item->hdr.type = QueueType::LockAnnounce;
|
||||||
item->lockAnnounce.id = m_id;
|
item->lockAnnounce.id = m_id;
|
||||||
item->lockAnnounce.srcloc = (uint64_t)srcloc;
|
item->lockAnnounce.srcloc = (uint64_t)srcloc;
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
Lockable( const Lockable& ) = delete;
|
Lockable( const Lockable& ) = delete;
|
||||||
@ -37,12 +38,13 @@ public:
|
|||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::LockWait;
|
item->hdr.type = QueueType::LockWait;
|
||||||
item->lockWait.id = m_id;
|
item->lockWait.id = m_id;
|
||||||
item->lockWait.thread = thread;
|
item->lockWait.thread = thread;
|
||||||
item->lockWait.time = Profiler::GetTime( cpu );
|
item->lockWait.time = Profiler::GetTime( cpu );
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
m_lockable.lock();
|
m_lockable.lock();
|
||||||
@ -50,12 +52,13 @@ public:
|
|||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::LockObtain;
|
item->hdr.type = QueueType::LockObtain;
|
||||||
item->lockObtain.id = m_id;
|
item->lockObtain.id = m_id;
|
||||||
item->lockObtain.thread = thread;
|
item->lockObtain.thread = thread;
|
||||||
item->lockObtain.time = Profiler::GetTime( cpu );
|
item->lockObtain.time = Profiler::GetTime( cpu );
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -66,12 +69,13 @@ public:
|
|||||||
uint32_t cpu;
|
uint32_t cpu;
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::LockRelease;
|
item->hdr.type = QueueType::LockRelease;
|
||||||
item->lockRelease.id = m_id;
|
item->lockRelease.id = m_id;
|
||||||
item->lockRelease.thread = GetThreadHandle();
|
item->lockRelease.thread = GetThreadHandle();
|
||||||
item->lockRelease.time = Profiler::GetTime( cpu );
|
item->lockRelease.time = Profiler::GetTime( cpu );
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
tracy_force_inline bool try_lock()
|
tracy_force_inline bool try_lock()
|
||||||
@ -82,12 +86,13 @@ public:
|
|||||||
uint32_t cpu;
|
uint32_t cpu;
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::LockObtain;
|
item->hdr.type = QueueType::LockObtain;
|
||||||
item->lockObtain.id = (uint64_t)&m_lockable;
|
item->lockObtain.id = (uint64_t)&m_lockable;
|
||||||
item->lockObtain.thread = GetThreadHandle();
|
item->lockObtain.thread = GetThreadHandle();
|
||||||
item->lockObtain.time = Profiler::GetTime( cpu );
|
item->lockObtain.time = Profiler::GetTime( cpu );
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
@ -96,12 +101,13 @@ public:
|
|||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::LockMark;
|
item->hdr.type = QueueType::LockMark;
|
||||||
item->lockMark.id = m_id;
|
item->lockMark.id = m_id;
|
||||||
item->lockMark.thread = GetThreadHandle();
|
item->lockMark.thread = GetThreadHandle();
|
||||||
item->lockMark.srcloc = (uint64_t)srcloc;
|
item->lockMark.srcloc = (uint64_t)srcloc;
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -319,20 +319,22 @@ void Profiler::CalibrateDelay()
|
|||||||
static const tracy::SourceLocation __tracy_source_location { __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 };
|
static const tracy::SourceLocation __tracy_source_location { __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 };
|
||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
|
auto& tail = ptoken->get_tail_index();
|
||||||
auto item = ptoken->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = ptoken->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::ZoneBegin;
|
item->hdr.type = QueueType::ZoneBegin;
|
||||||
item->zoneBegin.thread = GetThreadHandle();
|
item->zoneBegin.thread = GetThreadHandle();
|
||||||
item->zoneBegin.time = GetTime( item->zoneBegin.cpu );
|
item->zoneBegin.time = GetTime( item->zoneBegin.cpu );
|
||||||
item->zoneBegin.srcloc = (uint64_t)&__tracy_source_location;
|
item->zoneBegin.srcloc = (uint64_t)&__tracy_source_location;
|
||||||
ptoken->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
|
auto& tail = ptoken->get_tail_index();
|
||||||
auto item = ptoken->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = ptoken->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::ZoneEnd;
|
item->hdr.type = QueueType::ZoneEnd;
|
||||||
item->zoneEnd.thread = 0;
|
item->zoneEnd.thread = 0;
|
||||||
item->zoneEnd.time = GetTime( item->zoneEnd.cpu );
|
item->zoneEnd.time = GetTime( item->zoneEnd.cpu );
|
||||||
ptoken->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const auto f0 = GetTime( cpu );
|
const auto f0 = GetTime( cpu );
|
||||||
@ -347,20 +349,22 @@ void Profiler::CalibrateDelay()
|
|||||||
static const tracy::SourceLocation __tracy_source_location { __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 };
|
static const tracy::SourceLocation __tracy_source_location { __FUNCTION__, __FILE__, (uint32_t)__LINE__, 0 };
|
||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
|
auto& tail = ptoken->get_tail_index();
|
||||||
auto item = ptoken->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = ptoken->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::ZoneBegin;
|
item->hdr.type = QueueType::ZoneBegin;
|
||||||
item->zoneBegin.thread = GetThreadHandle();
|
item->zoneBegin.thread = GetThreadHandle();
|
||||||
item->zoneBegin.time = GetTime( item->zoneBegin.cpu );
|
item->zoneBegin.time = GetTime( item->zoneBegin.cpu );
|
||||||
item->zoneBegin.srcloc = (uint64_t)&__tracy_source_location;
|
item->zoneBegin.srcloc = (uint64_t)&__tracy_source_location;
|
||||||
ptoken->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
|
auto& tail = ptoken->get_tail_index();
|
||||||
auto item = ptoken->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = ptoken->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::ZoneEnd;
|
item->hdr.type = QueueType::ZoneEnd;
|
||||||
item->zoneEnd.thread = 0;
|
item->zoneEnd.thread = 0;
|
||||||
item->zoneEnd.time = GetTime( item->zoneEnd.cpu );
|
item->zoneEnd.time = GetTime( item->zoneEnd.cpu );
|
||||||
ptoken->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
const auto t1 = GetTime( cpu );
|
const auto t1 = GetTime( cpu );
|
||||||
|
@ -70,10 +70,11 @@ public:
|
|||||||
uint32_t cpu;
|
uint32_t cpu;
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::FrameMarkMsg;
|
item->hdr.type = QueueType::FrameMarkMsg;
|
||||||
item->frameMark.time = GetTime( cpu );
|
item->frameMark.time = GetTime( cpu );
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
static bool ShouldExit();
|
static bool ShouldExit();
|
||||||
|
@ -19,23 +19,25 @@ public:
|
|||||||
m_thread = thread;
|
m_thread = thread;
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::ZoneBegin;
|
item->hdr.type = QueueType::ZoneBegin;
|
||||||
item->zoneBegin.time = Profiler::GetTime( item->zoneBegin.cpu );
|
item->zoneBegin.time = Profiler::GetTime( item->zoneBegin.cpu );
|
||||||
item->zoneBegin.thread = thread;
|
item->zoneBegin.thread = thread;
|
||||||
item->zoneBegin.srcloc = (uint64_t)srcloc;
|
item->zoneBegin.srcloc = (uint64_t)srcloc;
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
tracy_force_inline ~ScopedZone()
|
tracy_force_inline ~ScopedZone()
|
||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::ZoneEnd;
|
item->hdr.type = QueueType::ZoneEnd;
|
||||||
item->zoneEnd.time = Profiler::GetTime( item->zoneEnd.cpu );
|
item->zoneEnd.time = Profiler::GetTime( item->zoneEnd.cpu );
|
||||||
item->zoneEnd.thread = m_thread;
|
item->zoneEnd.thread = m_thread;
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
tracy_force_inline void Text( const char* txt, size_t size )
|
tracy_force_inline void Text( const char* txt, size_t size )
|
||||||
@ -45,22 +47,24 @@ public:
|
|||||||
memcpy( ptr, txt, size );
|
memcpy( ptr, txt, size );
|
||||||
ptr[size] = '\0';
|
ptr[size] = '\0';
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::ZoneText;
|
item->hdr.type = QueueType::ZoneText;
|
||||||
item->zoneText.thread = m_thread;
|
item->zoneText.thread = m_thread;
|
||||||
item->zoneText.text = (uint64_t)ptr;
|
item->zoneText.text = (uint64_t)ptr;
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
tracy_force_inline void Name( const char* name )
|
tracy_force_inline void Name( const char* name )
|
||||||
{
|
{
|
||||||
Magic magic;
|
Magic magic;
|
||||||
auto& token = s_token;
|
auto& token = s_token;
|
||||||
|
auto& tail = token->get_tail_index();
|
||||||
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
auto item = token->enqueue_begin<moodycamel::CanAlloc>( magic );
|
||||||
item->hdr.type = QueueType::ZoneName;
|
item->hdr.type = QueueType::ZoneName;
|
||||||
item->zoneName.thread = m_thread;
|
item->zoneName.thread = m_thread;
|
||||||
item->zoneName.name = (uint64_t)name;
|
item->zoneName.name = (uint64_t)name;
|
||||||
token->enqueue_finish( magic );
|
tail.store( magic + 1, std::memory_order_release );
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -958,11 +958,6 @@ public:
|
|||||||
return inner_enqueue_begin<CanAlloc>(token, currentTailIndex);
|
return inner_enqueue_begin<CanAlloc>(token, currentTailIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
tracy_force_inline void enqueue_finish(producer_token_t const& token, index_t currentTailIndex)
|
|
||||||
{
|
|
||||||
inner_enqueue_finish(token, currentTailIndex);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Enqueues several items.
|
// Enqueues several items.
|
||||||
// Allocates memory if required. Only fails if memory allocation fails (or
|
// Allocates memory if required. Only fails if memory allocation fails (or
|
||||||
// implicit production is disabled because Traits::INITIAL_IMPLICIT_PRODUCER_HASH_SIZE
|
// implicit production is disabled because Traits::INITIAL_IMPLICIT_PRODUCER_HASH_SIZE
|
||||||
@ -1307,11 +1302,6 @@ private:
|
|||||||
return static_cast<ExplicitProducer*>(token.producer)->ConcurrentQueue::ExplicitProducer::template enqueue_begin<canAlloc>(currentTailIndex);
|
return static_cast<ExplicitProducer*>(token.producer)->ConcurrentQueue::ExplicitProducer::template enqueue_begin<canAlloc>(currentTailIndex);
|
||||||
}
|
}
|
||||||
|
|
||||||
tracy_force_inline void inner_enqueue_finish(producer_token_t const& token, index_t currentTailIndex)
|
|
||||||
{
|
|
||||||
return static_cast<ExplicitProducer*>(token.producer)->ConcurrentQueue::ExplicitProducer::template enqueue_finish(currentTailIndex);
|
|
||||||
}
|
|
||||||
|
|
||||||
template<AllocationMode canAlloc, typename U>
|
template<AllocationMode canAlloc, typename U>
|
||||||
inline bool inner_enqueue(U&& element)
|
inline bool inner_enqueue(U&& element)
|
||||||
{
|
{
|
||||||
@ -1989,9 +1979,9 @@ private:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
tracy_force_inline void enqueue_finish(index_t currentTailIndex)
|
tracy_force_inline std::atomic<index_t>& get_tail_index()
|
||||||
{
|
{
|
||||||
this->tailIndex.store(currentTailIndex + 1, std::memory_order_release);
|
return this->tailIndex;
|
||||||
}
|
}
|
||||||
|
|
||||||
template<typename U>
|
template<typename U>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user