mirror of
https://github.com/ossrs/srs.git
synced 2025-03-09 15:49:59 +00:00
RTC: Store the actual size of buffer for RTP packet.
This commit is contained in:
parent
f6589aa370
commit
8c94faf693
3 changed files with 43 additions and 33 deletions
|
@ -290,7 +290,7 @@ public:
|
|||
// video/audio packet use raw bytes, no video/audio packet.
|
||||
char* payload;
|
||||
|
||||
public:
|
||||
private:
|
||||
class SrsSharedPtrPayload
|
||||
{
|
||||
public:
|
||||
|
|
|
@ -766,7 +766,8 @@ SrsRtpPacket2::SrsRtpPacket2()
|
|||
{
|
||||
payload_ = NULL;
|
||||
payload_type_ = SrsRtpPacketPayloadTypeUnknown;
|
||||
shared_msg = NULL;
|
||||
shared_buffer = NULL;
|
||||
actual_buffer_size_ = 0;
|
||||
|
||||
nalu_type = SrsAvcNaluTypeReserved;
|
||||
frame_type = SrsFrameTypeReserved;
|
||||
|
@ -779,7 +780,7 @@ SrsRtpPacket2::SrsRtpPacket2()
|
|||
SrsRtpPacket2::~SrsRtpPacket2()
|
||||
{
|
||||
recycle_payload();
|
||||
recycle_shared_msg();
|
||||
recycle_shared_buffer();
|
||||
}
|
||||
|
||||
void SrsRtpPacket2::reset()
|
||||
|
@ -794,7 +795,7 @@ void SrsRtpPacket2::reset()
|
|||
|
||||
// Recyle the payload again, to ensure the packet is new one.
|
||||
recycle_payload();
|
||||
recycle_shared_msg();
|
||||
recycle_shared_buffer();
|
||||
}
|
||||
|
||||
void SrsRtpPacket2::recycle_payload()
|
||||
|
@ -805,48 +806,47 @@ void SrsRtpPacket2::recycle_payload()
|
|||
|
||||
if (payload_type_ == SrsRtpPacketPayloadTypeRaw && _srs_rtp_raw_cache->enabled()) {
|
||||
_srs_rtp_raw_cache->recycle((SrsRtpRawPayload*)payload_);
|
||||
payload_ = NULL;
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
if (payload_type_ == SrsRtpPacketPayloadTypeFUA2 && _srs_rtp_fua_cache->enabled()) {
|
||||
_srs_rtp_fua_cache->recycle((SrsRtpFUAPayload2*)payload_);
|
||||
payload_ = NULL;
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
srs_freep(payload_);
|
||||
|
||||
cleanup:
|
||||
payload_ = NULL;
|
||||
payload_type_ = SrsRtpPacketPayloadTypeUnknown;
|
||||
}
|
||||
|
||||
void SrsRtpPacket2::recycle_shared_msg()
|
||||
void SrsRtpPacket2::recycle_shared_buffer()
|
||||
{
|
||||
if (!shared_msg) {
|
||||
if (!shared_buffer) {
|
||||
return;
|
||||
}
|
||||
|
||||
// Only recycle the message for UDP packets.
|
||||
if (shared_msg->payload && shared_msg->size == kRtpPacketSize) {
|
||||
if (_srs_rtp_msg_cache_objs->enabled() && shared_msg->count() > 0) {
|
||||
if (shared_buffer->payload && shared_buffer->size == kRtpPacketSize) {
|
||||
if (_srs_rtp_msg_cache_objs->enabled() && shared_buffer->count() > 0) {
|
||||
// Recycle the small shared message objects.
|
||||
_srs_rtp_msg_cache_objs->recycle(shared_msg);
|
||||
_srs_rtp_msg_cache_objs->recycle(shared_buffer);
|
||||
goto cleanup;
|
||||
}
|
||||
|
||||
if (_srs_rtp_msg_cache_buffers->enabled() && shared_msg->count() == 0) {
|
||||
if (_srs_rtp_msg_cache_buffers->enabled() && shared_buffer->count() == 0) {
|
||||
// Recycle the UDP large buffer.
|
||||
_srs_rtp_msg_cache_buffers->recycle(shared_msg);
|
||||
_srs_rtp_msg_cache_buffers->recycle(shared_buffer);
|
||||
goto cleanup;
|
||||
}
|
||||
}
|
||||
|
||||
srs_freep(shared_msg);
|
||||
return;
|
||||
srs_freep(shared_buffer);
|
||||
|
||||
cleanup:
|
||||
shared_msg = NULL;
|
||||
shared_buffer = NULL;
|
||||
actual_buffer_size_ = 0;
|
||||
}
|
||||
|
||||
bool SrsRtpPacket2::recycle()
|
||||
|
@ -859,7 +859,7 @@ bool SrsRtpPacket2::recycle()
|
|||
// We only recycle the payload and shared messages,
|
||||
// for header and fields, user will reset or copy it.
|
||||
recycle_payload();
|
||||
recycle_shared_msg();
|
||||
recycle_shared_buffer();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
@ -867,28 +867,30 @@ bool SrsRtpPacket2::recycle()
|
|||
char* SrsRtpPacket2::wrap(int size)
|
||||
{
|
||||
// If the buffer is large enough, reuse it.
|
||||
if (shared_msg && shared_msg->size >= size) {
|
||||
return shared_msg->payload;
|
||||
if (shared_buffer && shared_buffer->size >= size) {
|
||||
return shared_buffer->payload;
|
||||
}
|
||||
|
||||
// Create a large enough message, with under-layer buffer.
|
||||
while (true) {
|
||||
srs_freep(shared_msg);
|
||||
shared_msg = _srs_rtp_msg_cache_buffers->allocate();
|
||||
srs_freep(shared_buffer);
|
||||
shared_buffer = _srs_rtp_msg_cache_buffers->allocate();
|
||||
// The buffer size is larger or equals to the size of packet.
|
||||
actual_buffer_size_ = size;
|
||||
|
||||
// If got a cached message(which has payload), but it's too small,
|
||||
// we free it and allocate a larger one.
|
||||
if (shared_msg->payload && shared_msg->size < size) {
|
||||
if (shared_buffer->payload && shared_buffer->size < size) {
|
||||
++_srs_pps_objs_rothers->sugar;
|
||||
continue;
|
||||
}
|
||||
|
||||
// Create under-layer buffer for new message
|
||||
if (!shared_msg->payload) {
|
||||
if (!shared_buffer->payload) {
|
||||
// For RTC, we use larger under-layer buffer for each packet.
|
||||
int nb_buffer = srs_max(size, kRtpPacketSize);
|
||||
char* buf = new char[nb_buffer];
|
||||
shared_msg->wrap(buf, nb_buffer);
|
||||
shared_buffer->wrap(buf, nb_buffer);
|
||||
|
||||
++_srs_pps_objs_rbuf->sugar;
|
||||
}
|
||||
|
@ -896,7 +898,7 @@ char* SrsRtpPacket2::wrap(int size)
|
|||
break;
|
||||
}
|
||||
|
||||
return shared_msg->payload;
|
||||
return shared_buffer->payload;
|
||||
}
|
||||
|
||||
char* SrsRtpPacket2::wrap(char* data, int size)
|
||||
|
@ -908,11 +910,15 @@ char* SrsRtpPacket2::wrap(char* data, int size)
|
|||
|
||||
char* SrsRtpPacket2::wrap(SrsSharedPtrMessage* msg)
|
||||
{
|
||||
// Recycle the shared message.
|
||||
recycle_shared_msg();
|
||||
// Generally, the wrap(msg) is used for RTMP to RTC, which is not generated by RTC,
|
||||
// so we do not recycle the msg. It's ok to directly free the msg, event the msg is
|
||||
// allocated by object cache manager.
|
||||
srs_freep(shared_buffer);
|
||||
|
||||
// Copy from the new message.
|
||||
shared_msg = msg->copy();
|
||||
shared_buffer = msg->copy();
|
||||
// If we wrap a message, the size of packet equals to the message size.
|
||||
actual_buffer_size_ = shared_buffer->size;
|
||||
|
||||
return msg->payload;
|
||||
}
|
||||
|
@ -924,19 +930,20 @@ SrsRtpPacket2* SrsRtpPacket2::copy()
|
|||
// We got packet from cache, the payload and message MUST be NULL,
|
||||
// because we had clear it in recycle.
|
||||
//srs_assert(!cp->payload_);
|
||||
//srs_assert(!cp->shared_msg);
|
||||
//srs_assert(!cp->shared_buffer);
|
||||
|
||||
cp->header = header;
|
||||
cp->payload_ = payload_? payload_->copy():NULL;
|
||||
cp->payload_type_ = payload_type_;
|
||||
|
||||
cp->nalu_type = nalu_type;
|
||||
cp->shared_msg = shared_msg->copy2();
|
||||
cp->shared_buffer = shared_buffer->copy2();
|
||||
cp->actual_buffer_size_ = actual_buffer_size_;
|
||||
cp->frame_type = frame_type;
|
||||
|
||||
cp->cached_payload_size = cached_payload_size;
|
||||
// For performance issue, do not copy the unused field.
|
||||
//cp->decode_handler = decode_handler;
|
||||
cp->decode_handler = decode_handler;
|
||||
|
||||
return cp;
|
||||
}
|
||||
|
|
|
@ -289,7 +289,10 @@ private:
|
|||
SrsRtpPacketPayloadType payload_type_;
|
||||
private:
|
||||
// The original shared message, all RTP packets can refer to its data.
|
||||
SrsSharedPtrMessage* shared_msg;
|
||||
// Note that the size of shared msg, is not the packet size, it's a larger aligned buffer.
|
||||
SrsSharedPtrMessage* shared_buffer;
|
||||
// The size of original packet.
|
||||
int actual_buffer_size_;
|
||||
// Helper fields.
|
||||
public:
|
||||
// The first byte as nalu type, for video decoder only.
|
||||
|
@ -311,7 +314,7 @@ public:
|
|||
void reset();
|
||||
private:
|
||||
void recycle_payload();
|
||||
void recycle_shared_msg();
|
||||
void recycle_shared_buffer();
|
||||
public:
|
||||
// Recycle the object to reuse it.
|
||||
virtual bool recycle();
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue