1
0
mirror of https://github.com/wolfpld/tracy.git synced 2025-03-20 07:40:02 +08:00

memset on non-POD data is UB.

This commit is contained in:
Bartosz Taudul 2017-11-16 02:19:52 +01:00
parent e579374504
commit 515443605d
3 changed files with 5 additions and 17 deletions

View File

@ -66,8 +66,6 @@ enum { SourceLocationSize = sizeof( SourceLocation ) };
struct ZoneEvent
{
void Init() { memset( &child, 0, 12 ); }
int64_t start;
int64_t end;
int32_t srcloc;
@ -79,7 +77,6 @@ struct ZoneEvent
};
enum { ZoneEventSize = sizeof( ZoneEvent ) };
static_assert( sizeof( ZoneEvent::child ) == 13, "Adjust vector clear size!" );
struct LockEvent
@ -108,8 +105,6 @@ static_assert( std::numeric_limits<decltype(LockEvent::lockCount)>::max() >= Max
struct GpuEvent
{
void Init() { memset( &child, 0, 12 ); }
int64_t cpuStart;
int64_t cpuEnd;
int64_t gpuStart;
@ -120,7 +115,6 @@ struct GpuEvent
};
enum { GpuEventSize = sizeof( GpuEvent ) };
static_assert( sizeof( GpuEvent::child ) == 13, "Adjust vector clear size!" );
#pragma pack()

View File

@ -24,7 +24,6 @@ public:
Vector()
: m_ptr( nullptr )
, m_size( 0 )
, m_capacity( 0 )
{
}

View File

@ -619,8 +619,7 @@ void View::Process( const QueueItem& ev )
void View::ProcessZoneBegin( const QueueZoneBegin& ev )
{
auto zone = m_slab.Alloc<ZoneEvent>();
zone->Init();
auto zone = m_slab.AllocInit<ZoneEvent>();
CheckSourceLocation( ev.srcloc );
@ -639,8 +638,7 @@ void View::ProcessZoneBeginAllocSrcLoc( const QueueZoneBegin& ev )
auto it = m_pendingSourceLocationPayload.find( ev.srcloc );
assert( it != m_pendingSourceLocationPayload.end() );
auto zone = m_slab.Alloc<ZoneEvent>();
zone->Init();
auto zone = m_slab.AllocInit<ZoneEvent>();
zone->start = ev.time * m_timerMul;
zone->end = -1;
@ -844,8 +842,7 @@ void View::ProcessGpuZoneBegin( const QueueGpuZoneBegin& ev )
CheckSourceLocation( ev.srcloc );
auto zone = m_slab.Alloc<GpuEvent>();
zone->Init();
auto zone = m_slab.AllocInit<GpuEvent>();
zone->cpuStart = ev.cpuTime * m_timerMul;
zone->cpuEnd = -1;
@ -3822,8 +3819,7 @@ void View::ReadTimeline( FileRead& f, Vector<ZoneEvent*>& vec )
for( uint64_t i=0; i<sz; i++ )
{
auto zone = m_slab.Alloc<ZoneEvent>();
zone->Init();
auto zone = m_slab.AllocInit<ZoneEvent>();
m_zonesCnt++;
vec.push_back( zone );
@ -3846,8 +3842,7 @@ void View::ReadTimeline( FileRead& f, Vector<GpuEvent*>& vec )
for( uint64_t i=0; i<sz; i++ )
{
auto zone = m_slab.Alloc<GpuEvent>();
zone->Init();
auto zone = m_slab.AllocInit<GpuEvent>();
vec.push_back( zone );