mirror of
https://github.com/wolfpld/tracy.git
synced 2025-03-20 07:40:02 +08:00
Manual allocation of socket memory.
This commit is contained in:
parent
fc94378e0c
commit
51013dc0e6
@ -101,6 +101,7 @@ Profiler::Profiler()
|
|||||||
, m_mainThread( GetThreadHandle() )
|
, m_mainThread( GetThreadHandle() )
|
||||||
, m_epoch( std::chrono::duration_cast<std::chrono::seconds>( std::chrono::system_clock::now().time_since_epoch() ).count() )
|
, m_epoch( std::chrono::duration_cast<std::chrono::seconds>( std::chrono::system_clock::now().time_since_epoch() ).count() )
|
||||||
, m_shutdown( false )
|
, m_shutdown( false )
|
||||||
|
, m_sock( nullptr )
|
||||||
, m_stream( LZ4_createStream() )
|
, m_stream( LZ4_createStream() )
|
||||||
, m_buffer( (char*)tracy_malloc( TargetFrameSize*3 ) )
|
, m_buffer( (char*)tracy_malloc( TargetFrameSize*3 ) )
|
||||||
, m_bufferOffset( 0 )
|
, m_bufferOffset( 0 )
|
||||||
@ -134,6 +135,12 @@ Profiler::~Profiler()
|
|||||||
tracy_free( m_buffer );
|
tracy_free( m_buffer );
|
||||||
LZ4_freeStream( m_stream );
|
LZ4_freeStream( m_stream );
|
||||||
|
|
||||||
|
if( m_sock )
|
||||||
|
{
|
||||||
|
m_sock->~Socket();
|
||||||
|
tracy_free( m_sock );
|
||||||
|
}
|
||||||
|
|
||||||
assert( s_instance );
|
assert( s_instance );
|
||||||
s_instance = nullptr;
|
s_instance = nullptr;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -185,7 +185,7 @@ private:
|
|||||||
uint64_t m_mainThread;
|
uint64_t m_mainThread;
|
||||||
uint64_t m_epoch;
|
uint64_t m_epoch;
|
||||||
std::atomic<bool> m_shutdown;
|
std::atomic<bool> m_shutdown;
|
||||||
std::unique_ptr<Socket> m_sock;
|
Socket* m_sock;
|
||||||
|
|
||||||
LZ4_stream_t* m_stream;
|
LZ4_stream_t* m_stream;
|
||||||
char* m_buffer;
|
char* m_buffer;
|
||||||
|
|||||||
@ -1,9 +1,11 @@
|
|||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
#include <new>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <sys/types.h>
|
#include <sys/types.h>
|
||||||
|
|
||||||
|
#include "TracyAlloc.hpp"
|
||||||
#include "TracySocket.hpp"
|
#include "TracySocket.hpp"
|
||||||
|
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
@ -226,7 +228,7 @@ bool ListenSocket::Listen( const char* port, int backlog )
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
std::unique_ptr<Socket> ListenSocket::Accept()
|
Socket* ListenSocket::Accept()
|
||||||
{
|
{
|
||||||
struct sockaddr_storage remote;
|
struct sockaddr_storage remote;
|
||||||
socklen_t sz = sizeof( remote );
|
socklen_t sz = sizeof( remote );
|
||||||
@ -249,7 +251,9 @@ std::unique_ptr<Socket> ListenSocket::Accept()
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
return std::make_unique<Socket>( sock );
|
auto ptr = (Socket*)tracy_malloc( sizeof( Socket ) );
|
||||||
|
new(ptr) Socket( sock );
|
||||||
|
return ptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|||||||
@ -1,8 +1,6 @@
|
|||||||
#ifndef __TRACYSOCKET_HPP__
|
#ifndef __TRACYSOCKET_HPP__
|
||||||
#define __TRACYSOCKET_HPP__
|
#define __TRACYSOCKET_HPP__
|
||||||
|
|
||||||
#include <memory>
|
|
||||||
|
|
||||||
struct timeval;
|
struct timeval;
|
||||||
|
|
||||||
namespace tracy
|
namespace tracy
|
||||||
@ -40,7 +38,7 @@ public:
|
|||||||
~ListenSocket();
|
~ListenSocket();
|
||||||
|
|
||||||
bool Listen( const char* port, int backlog );
|
bool Listen( const char* port, int backlog );
|
||||||
std::unique_ptr<Socket> Accept();
|
Socket* Accept();
|
||||||
void Close();
|
void Close();
|
||||||
|
|
||||||
ListenSocket( const ListenSocket& ) = delete;
|
ListenSocket( const ListenSocket& ) = delete;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user