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:
Seungha Yang 2023-02-19 03:39:21 +09:00
parent 070a80943d
commit b88b323e04
2 changed files with 43 additions and 22 deletions

View file

@ -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) {

View file

@ -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) {