mirror of
https://github.com/wolfpld/tracy.git
synced 2024-11-30 01:04:36 +00:00
Reduce custom vector size 16 -> 13 bytes.
This commit is contained in:
parent
1a117b330f
commit
34123de977
17
server/TracyPopcnt.hpp
Normal file
17
server/TracyPopcnt.hpp
Normal file
@ -0,0 +1,17 @@
|
||||
#ifndef __TRACYPOPCNT_HPP__
|
||||
#define __TRACYPOPCNT_HPP__
|
||||
|
||||
#ifdef _MSC_VER
|
||||
# include <intrin.h>
|
||||
# define TracyCountBits __popcnt64
|
||||
#else
|
||||
static int TracyCountBits( uint64_t i )
|
||||
{
|
||||
i = i - ( (i >> 1) & 0x5555555555555555 );
|
||||
i = ( i & 0x3333333333333333 ) + ( (i >> 2) & 0x3333333333333333 );
|
||||
i = ( (i + (i >> 4) ) & 0x0F0F0F0F0F0F0F0F );
|
||||
return ( i * (0x0101010101010101) ) >> 56;
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif
|
@ -5,6 +5,7 @@
|
||||
#include <stdint.h>
|
||||
|
||||
#include "TracyMemory.hpp"
|
||||
#include "TracyPopcnt.hpp"
|
||||
|
||||
namespace tracy
|
||||
{
|
||||
@ -13,6 +14,7 @@ namespace tracy
|
||||
template<typename T>
|
||||
using Vector = std::vector<T>;
|
||||
#else
|
||||
#pragma pack( 1 )
|
||||
template<typename T>
|
||||
class Vector
|
||||
{
|
||||
@ -20,10 +22,11 @@ public:
|
||||
using iterator = T*;
|
||||
|
||||
Vector()
|
||||
: m_ptr( nullptr )
|
||||
: m_ptr( new T[1] )
|
||||
, m_size( 0 )
|
||||
, m_capacity( 0 )
|
||||
{
|
||||
memUsage.fetch_add( sizeof( T ), std::memory_order_relaxed );
|
||||
}
|
||||
|
||||
Vector( const Vector& ) = delete;
|
||||
@ -37,7 +40,7 @@ public:
|
||||
|
||||
~Vector()
|
||||
{
|
||||
memUsage.fetch_sub( m_capacity * sizeof( T ), std::memory_order_relaxed );
|
||||
memUsage.fetch_sub( Capacity() * sizeof( T ), std::memory_order_relaxed );
|
||||
delete[] m_ptr;
|
||||
}
|
||||
|
||||
@ -73,13 +76,13 @@ public:
|
||||
|
||||
void push_back( const T& v )
|
||||
{
|
||||
if( m_size == m_capacity ) AllocMore();
|
||||
if( m_size == Capacity() ) AllocMore();
|
||||
m_ptr[m_size++] = v;
|
||||
}
|
||||
|
||||
void push_back( T&& v )
|
||||
{
|
||||
if( m_size == m_capacity ) AllocMore();
|
||||
if( m_size == Capacity() ) AllocMore();
|
||||
m_ptr[m_size++] = std::move( v );
|
||||
}
|
||||
|
||||
@ -87,7 +90,7 @@ public:
|
||||
{
|
||||
assert( it >= m_ptr && it <= m_ptr + m_size );
|
||||
const auto dist = it - m_ptr;
|
||||
if( m_size == m_capacity ) AllocMore();
|
||||
if( m_size == Capacity() ) AllocMore();
|
||||
if( dist != m_size ) memmove( m_ptr + dist + 1, m_ptr + dist, ( m_size - dist ) * sizeof( T ) );
|
||||
m_size++;
|
||||
m_ptr[dist] = v;
|
||||
@ -98,7 +101,7 @@ public:
|
||||
{
|
||||
assert( it >= m_ptr && it <= m_ptr + m_size );
|
||||
const auto dist = it - m_ptr;
|
||||
if( m_size == m_capacity ) AllocMore();
|
||||
if( m_size == Capacity() ) AllocMore();
|
||||
if( dist != m_size ) memmove( m_ptr + dist + 1, m_ptr + dist, ( m_size - dist ) * sizeof( T ) );
|
||||
m_size++;
|
||||
m_ptr[dist] = std::move( v );
|
||||
@ -110,7 +113,7 @@ public:
|
||||
assert( it >= m_ptr && it <= m_ptr + m_size );
|
||||
const auto sz = end - begin;
|
||||
const auto dist = it - m_ptr;
|
||||
while( m_size + sz > m_capacity ) AllocMore();
|
||||
while( m_size + sz > Capacity() ) AllocMore();
|
||||
if( dist != m_size ) memmove( m_ptr + dist + sz, m_ptr + dist, ( m_size - dist ) * sizeof( T ) );
|
||||
m_size += sz;
|
||||
memcpy( m_ptr + dist, begin, sz * sizeof( T ) );
|
||||
@ -133,8 +136,15 @@ public:
|
||||
|
||||
void reserve( size_t cap )
|
||||
{
|
||||
if( cap <= m_capacity ) return;
|
||||
memUsage.fetch_add( ( cap - m_capacity ) * sizeof( T ), std::memory_order_relaxed );
|
||||
if( cap <= Capacity() ) return;
|
||||
cap--;
|
||||
cap |= cap >> 1;
|
||||
cap |= cap >> 2;
|
||||
cap |= cap >> 4;
|
||||
cap |= cap >> 8;
|
||||
cap |= cap >> 16;
|
||||
cap = TracyCountBits( cap );
|
||||
memUsage.fetch_add( ( ( 1 << cap ) - Capacity() ) * sizeof( T ), std::memory_order_relaxed );
|
||||
m_capacity = cap;
|
||||
Realloc();
|
||||
}
|
||||
@ -147,22 +157,14 @@ public:
|
||||
private:
|
||||
void AllocMore()
|
||||
{
|
||||
if( m_capacity == 0 )
|
||||
{
|
||||
m_capacity = 1;
|
||||
memUsage.fetch_add( m_capacity * sizeof( T ), std::memory_order_relaxed );
|
||||
}
|
||||
else
|
||||
{
|
||||
memUsage.fetch_add( m_capacity * sizeof( T ), std::memory_order_relaxed );
|
||||
m_capacity *= 2;
|
||||
}
|
||||
memUsage.fetch_add( Capacity() * sizeof( T ), std::memory_order_relaxed );
|
||||
m_capacity++;
|
||||
Realloc();
|
||||
}
|
||||
|
||||
void Realloc()
|
||||
{
|
||||
T* ptr = new T[m_capacity];
|
||||
T* ptr = new T[Capacity()];
|
||||
if( m_size != 0 )
|
||||
{
|
||||
memcpy( ptr, m_ptr, m_size * sizeof( T ) );
|
||||
@ -171,10 +173,16 @@ private:
|
||||
m_ptr = ptr;
|
||||
}
|
||||
|
||||
uint32_t Capacity() const
|
||||
{
|
||||
return 1 << m_capacity;
|
||||
}
|
||||
|
||||
T* m_ptr;
|
||||
uint32_t m_size;
|
||||
uint32_t m_capacity;
|
||||
uint8_t m_capacity;
|
||||
};
|
||||
#pragma pack()
|
||||
#endif
|
||||
|
||||
}
|
||||
|
@ -19,25 +19,13 @@
|
||||
#include "TracyFileRead.hpp"
|
||||
#include "TracyFileWrite.hpp"
|
||||
#include "TracyImGui.hpp"
|
||||
#include "TracyPopcnt.hpp"
|
||||
#include "TracyView.hpp"
|
||||
|
||||
#ifdef TRACY_FILESELECTOR
|
||||
# include "../nfd/nfd.h"
|
||||
#endif
|
||||
|
||||
#ifdef _MSC_VER
|
||||
# include <intrin.h>
|
||||
# define CountBits __popcnt64
|
||||
#else
|
||||
static int CountBits( uint64_t i )
|
||||
{
|
||||
i = i - ( (i >> 1) & 0x5555555555555555 );
|
||||
i = ( i & 0x3333333333333333 ) + ( (i >> 2) & 0x3333333333333333 );
|
||||
i = ( (i + (i >> 4) ) & 0x0F0F0F0F0F0F0F0F );
|
||||
return ( i * (0x0101010101010101) ) >> 56;
|
||||
}
|
||||
#endif
|
||||
|
||||
namespace tracy
|
||||
{
|
||||
|
||||
@ -2505,11 +2493,11 @@ int View::DrawLocks( uint64_t tid, bool hover, double pxns, const ImVec2& wpos,
|
||||
{
|
||||
if( (*vbegin)->lockCount == 1 )
|
||||
{
|
||||
ImGui::Text( "Thread \"%s\" has lock. Blocked threads (%i):", GetThreadString( tid ), CountBits( (*vbegin)->waitList ) );
|
||||
ImGui::Text( "Thread \"%s\" has lock. Blocked threads (%i):", GetThreadString( tid ), TracyCountBits( (*vbegin)->waitList ) );
|
||||
}
|
||||
else
|
||||
{
|
||||
ImGui::Text( "Thread \"%s\" has %i locks. Blocked threads (%i):", GetThreadString( tid ), (*vbegin)->lockCount, CountBits( (*vbegin)->waitList ) );
|
||||
ImGui::Text( "Thread \"%s\" has %i locks. Blocked threads (%i):", GetThreadString( tid ), (*vbegin)->lockCount, TracyCountBits( (*vbegin)->waitList ) );
|
||||
}
|
||||
auto waitList = (*vbegin)->waitList;
|
||||
int t = 0;
|
||||
|
@ -112,6 +112,7 @@
|
||||
<ClInclude Include="..\..\..\server\TracyFileWrite.hpp" />
|
||||
<ClInclude Include="..\..\..\server\TracyImGui.hpp" />
|
||||
<ClInclude Include="..\..\..\server\TracyMemory.hpp" />
|
||||
<ClInclude Include="..\..\..\server\TracyPopcnt.hpp" />
|
||||
<ClInclude Include="..\..\..\server\TracySlab.hpp" />
|
||||
<ClInclude Include="..\..\..\server\TracyVector.hpp" />
|
||||
<ClInclude Include="..\..\..\server\TracyView.hpp" />
|
||||
|
@ -140,5 +140,8 @@
|
||||
<ClInclude Include="..\..\..\server\TracyCharUtil.hpp">
|
||||
<Filter>server</Filter>
|
||||
</ClInclude>
|
||||
<ClInclude Include="..\..\..\server\TracyPopcnt.hpp">
|
||||
<Filter>server</Filter>
|
||||
</ClInclude>
|
||||
</ItemGroup>
|
||||
</Project>
|
Loading…
Reference in New Issue
Block a user