mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-24 08:08:22 +00:00
nvencoder: Optimization for byte-stream to packetized format conversion
Allocate single memory instead of per NAL Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/3992>
This commit is contained in:
parent
070a80943d
commit
b88b323e04
2 changed files with 43 additions and 22 deletions
|
@ -51,6 +51,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_STATIC (gst_nv_h264_encoder_debug);
|
GST_DEBUG_CATEGORY_STATIC (gst_nv_h264_encoder_debug);
|
||||||
#define GST_CAT_DEFAULT gst_nv_h264_encoder_debug
|
#define GST_CAT_DEFAULT gst_nv_h264_encoder_debug
|
||||||
|
@ -1650,7 +1651,11 @@ gst_nv_h264_encoder_create_output_buffer (GstNvEncoder * encoder,
|
||||||
buffer = gst_buffer_new_memdup (bitstream->bitstreamBufferPtr,
|
buffer = gst_buffer_new_memdup (bitstream->bitstreamBufferPtr,
|
||||||
bitstream->bitstreamSizeInBytes);
|
bitstream->bitstreamSizeInBytes);
|
||||||
} else {
|
} else {
|
||||||
buffer = gst_buffer_new ();
|
std::vector < GstH264NalUnit > nalu_list;
|
||||||
|
gsize total_size = 0;
|
||||||
|
GstMapInfo info;
|
||||||
|
guint8 *data;
|
||||||
|
|
||||||
rst = gst_h264_parser_identify_nalu (self->parser,
|
rst = gst_h264_parser_identify_nalu (self->parser,
|
||||||
(guint8 *) bitstream->bitstreamBufferPtr, 0,
|
(guint8 *) bitstream->bitstreamBufferPtr, 0,
|
||||||
bitstream->bitstreamSizeInBytes, &nalu);
|
bitstream->bitstreamSizeInBytes, &nalu);
|
||||||
|
@ -1659,16 +1664,8 @@ gst_nv_h264_encoder_create_output_buffer (GstNvEncoder * encoder,
|
||||||
rst = GST_H264_PARSER_OK;
|
rst = GST_H264_PARSER_OK;
|
||||||
|
|
||||||
while (rst == GST_H264_PARSER_OK) {
|
while (rst == GST_H264_PARSER_OK) {
|
||||||
GstMemory *mem;
|
nalu_list.push_back (nalu);
|
||||||
guint8 *data;
|
total_size += nalu.size + 4;
|
||||||
|
|
||||||
data = (guint8 *) g_malloc0 (nalu.size + 4);
|
|
||||||
GST_WRITE_UINT32_BE (data, nalu.size);
|
|
||||||
memcpy (data + 4, nalu.data + nalu.offset, nalu.size);
|
|
||||||
|
|
||||||
mem = gst_memory_new_wrapped ((GstMemoryFlags) 0, data, nalu.size + 4,
|
|
||||||
0, nalu.size + 4, data, (GDestroyNotify) g_free);
|
|
||||||
gst_buffer_append_memory (buffer, mem);
|
|
||||||
|
|
||||||
rst = gst_h264_parser_identify_nalu (self->parser,
|
rst = gst_h264_parser_identify_nalu (self->parser,
|
||||||
(guint8 *) bitstream->bitstreamBufferPtr, nalu.offset + nalu.size,
|
(guint8 *) bitstream->bitstreamBufferPtr, nalu.offset + nalu.size,
|
||||||
|
@ -1677,6 +1674,20 @@ gst_nv_h264_encoder_create_output_buffer (GstNvEncoder * encoder,
|
||||||
if (rst == GST_H264_PARSER_NO_NAL_END)
|
if (rst == GST_H264_PARSER_NO_NAL_END)
|
||||||
rst = GST_H264_PARSER_OK;
|
rst = GST_H264_PARSER_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
buffer = gst_buffer_new_and_alloc (total_size);
|
||||||
|
gst_buffer_map (buffer, &info, GST_MAP_WRITE);
|
||||||
|
data = (guint8 *) info.data;
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
for (const auto & it : nalu_list) {
|
||||||
|
GST_WRITE_UINT32_BE (data, it.size);
|
||||||
|
data += 4;
|
||||||
|
memcpy (data, it.data + it.offset, it.size);
|
||||||
|
data += it.size;
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
|
||||||
|
gst_buffer_unmap (buffer, &info);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bitstream->pictureType == NV_ENC_PIC_TYPE_IDR && self->sei) {
|
if (bitstream->pictureType == NV_ENC_PIC_TYPE_IDR && self->sei) {
|
||||||
|
|
|
@ -51,6 +51,7 @@
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <set>
|
#include <set>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <vector>
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_STATIC (gst_nv_h265_encoder_debug);
|
GST_DEBUG_CATEGORY_STATIC (gst_nv_h265_encoder_debug);
|
||||||
#define GST_CAT_DEFAULT gst_nv_h265_encoder_debug
|
#define GST_CAT_DEFAULT gst_nv_h265_encoder_debug
|
||||||
|
@ -1669,7 +1670,11 @@ gst_nv_h265_encoder_create_output_buffer (GstNvEncoder * encoder,
|
||||||
buffer = gst_buffer_new_memdup (bitstream->bitstreamBufferPtr,
|
buffer = gst_buffer_new_memdup (bitstream->bitstreamBufferPtr,
|
||||||
bitstream->bitstreamSizeInBytes);
|
bitstream->bitstreamSizeInBytes);
|
||||||
} else {
|
} else {
|
||||||
buffer = gst_buffer_new ();
|
std::vector < GstH265NalUnit > nalu_list;
|
||||||
|
gsize total_size = 0;
|
||||||
|
GstMapInfo info;
|
||||||
|
guint8 *data;
|
||||||
|
|
||||||
rst = gst_h265_parser_identify_nalu (self->parser,
|
rst = gst_h265_parser_identify_nalu (self->parser,
|
||||||
(guint8 *) bitstream->bitstreamBufferPtr, 0,
|
(guint8 *) bitstream->bitstreamBufferPtr, 0,
|
||||||
bitstream->bitstreamSizeInBytes, &nalu);
|
bitstream->bitstreamSizeInBytes, &nalu);
|
||||||
|
@ -1678,16 +1683,8 @@ gst_nv_h265_encoder_create_output_buffer (GstNvEncoder * encoder,
|
||||||
rst = GST_H265_PARSER_OK;
|
rst = GST_H265_PARSER_OK;
|
||||||
|
|
||||||
while (rst == GST_H265_PARSER_OK) {
|
while (rst == GST_H265_PARSER_OK) {
|
||||||
GstMemory *mem;
|
nalu_list.push_back (nalu);
|
||||||
guint8 *data;
|
total_size += nalu.size + 4;
|
||||||
|
|
||||||
data = (guint8 *) g_malloc0 (nalu.size + 4);
|
|
||||||
GST_WRITE_UINT32_BE (data, nalu.size);
|
|
||||||
memcpy (data + 4, nalu.data + nalu.offset, nalu.size);
|
|
||||||
|
|
||||||
mem = gst_memory_new_wrapped ((GstMemoryFlags) 0, data, nalu.size + 4,
|
|
||||||
0, nalu.size + 4, data, (GDestroyNotify) g_free);
|
|
||||||
gst_buffer_append_memory (buffer, mem);
|
|
||||||
|
|
||||||
rst = gst_h265_parser_identify_nalu (self->parser,
|
rst = gst_h265_parser_identify_nalu (self->parser,
|
||||||
(guint8 *) bitstream->bitstreamBufferPtr, nalu.offset + nalu.size,
|
(guint8 *) bitstream->bitstreamBufferPtr, nalu.offset + nalu.size,
|
||||||
|
@ -1696,6 +1693,19 @@ gst_nv_h265_encoder_create_output_buffer (GstNvEncoder * encoder,
|
||||||
if (rst == GST_H265_PARSER_NO_NAL_END)
|
if (rst == GST_H265_PARSER_NO_NAL_END)
|
||||||
rst = GST_H265_PARSER_OK;
|
rst = GST_H265_PARSER_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
buffer = gst_buffer_new_and_alloc (total_size);
|
||||||
|
gst_buffer_map (buffer, &info, GST_MAP_WRITE);
|
||||||
|
data = (guint8 *) info.data;
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
for (const auto & it : nalu_list) {
|
||||||
|
GST_WRITE_UINT32_BE (data, it.size);
|
||||||
|
data += 4;
|
||||||
|
memcpy (data, it.data + it.offset, it.size);
|
||||||
|
data += it.size;
|
||||||
|
}
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
gst_buffer_unmap (buffer, &info);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (bitstream->pictureType == NV_ENC_PIC_TYPE_IDR && self->sei) {
|
if (bitstream->pictureType == NV_ENC_PIC_TYPE_IDR && self->sei) {
|
||||||
|
|
Loading…
Reference in a new issue