diff options
author | Mark Nauwelaerts <mark.nauwelaerts@collabora.co.uk> | 2008-08-11 17:24:58 +0000 |
---|---|---|
committer | Mark Nauwelaerts <mark.nauwelaerts@collabora.co.uk> | 2008-08-11 17:24:58 +0000 |
commit | be6a492ed50086a11caa0238aab3a237dc6ee715 (patch) | |
tree | 44b6bb7720d75e324750c3db7c23a5a7d3d6de07 | |
parent | dbfc737cd24f6d03e6488e4d2db2ec8114821138 (diff) | |
download | gst-plugins-bad-be6a492ed50086a11caa0238aab3a237dc6ee715.tar.gz gst-plugins-bad-be6a492ed50086a11caa0238aab3a237dc6ee715.tar.bz2 gst-plugins-bad-be6a492ed50086a11caa0238aab3a237dc6ee715.zip |
ext/x264/gstx264enc.c: Allocate some buffers in more adaptive and economical fashion.
Original commit message from CVS:
* ext/x264/gstx264enc.c: (gst_x264_enc_init),
(gst_x264_enc_header_buf), (gst_x264_enc_encode_frame):
Allocate some buffers in more adaptive and economical fashion.
-rw-r--r-- | ChangeLog | 6 | ||||
-rw-r--r-- | ext/x264/gstx264enc.c | 28 |
2 files changed, 20 insertions, 14 deletions
@@ -1,5 +1,11 @@ 2008-08-11 Mark Nauwelaerts <mark.nauwelaerts@collabora.co.uk> + * ext/x264/gstx264enc.c: (gst_x264_enc_init), + (gst_x264_enc_header_buf), (gst_x264_enc_encode_frame): + Allocate some buffers in more adaptive and economical fashion. + +2008-08-11 Mark Nauwelaerts <mark.nauwelaerts@collabora.co.uk> + * configure.ac: Check for sufficiently up-to-date x264 API. * ext/x264/gstx264enc.c: (gst_x264_enc_pass_get_type), diff --git a/ext/x264/gstx264enc.c b/ext/x264/gstx264enc.c index 3eae9129..5182e84e 100644 --- a/ext/x264/gstx264enc.c +++ b/ext/x264/gstx264enc.c @@ -424,7 +424,7 @@ gst_x264_enc_init (GstX264Enc * encoder, GstX264EncClass * klass) /* resources */ encoder->delay = g_queue_new (); - encoder->buffer_size = 1040000; + encoder->buffer_size = 100000; encoder->buffer = g_malloc (encoder->buffer_size); x264_param_default (&encoder->x264param); @@ -637,16 +637,18 @@ gst_x264_enc_header_buf (GstX264Enc * encoder) return NULL; } - /* This should be enough for a header buffer. */ - buffer_size = 100000; - buffer = g_malloc (buffer_size); - - if (nal[1].i_type != 7 || nal[2].i_type != 8) { - GST_ELEMENT_ERROR (encoder, STREAM, ENCODE, ("Unexpected x264 header."), - ("TODO avcC header construction for high profiles needs some work")); + /* x264 is expected to return an SEI (some identification info), + * followed by an SPS and PPS */ + if (i_nal != 3 || nal[1].i_type != 7 || nal[2].i_type != 8) { + GST_ELEMENT_ERROR (encoder, STREAM, ENCODE, NULL, + ("Unexpected x264 header.")); return NULL; } + /* nal payloads with emulation_prevention_three_byte, and some header data */ + buffer_size = (nal[1].i_payload + nal[2].i_payload) * 4 + 100; + buffer = g_malloc (buffer_size); + sps = nal[1].p_payload; buffer[0] = 1; /* AVC Decoder Configuration Record ver. 1 */ @@ -672,9 +674,7 @@ gst_x264_enc_header_buf (GstX264Enc * encoder) i_size += nal_size + 2; buf = gst_buffer_new_and_alloc (i_size); - memcpy (GST_BUFFER_DATA (buf), buffer, i_size); - g_free (buffer); return buf; @@ -906,12 +906,12 @@ gst_x264_enc_encode_frame (GstX264Enc * encoder, x264_picture_t * pic_in, i_size = 0; for (i = 0; i < *i_nal; i++) { - int i_data = encoder->buffer_size - i_size - 4; + gint i_data = encoder->buffer_size - i_size - 4; - if (i_data < encoder->buffer_size / 2) { - encoder->buffer_size *= 2; + if (i_data < nal[i].i_payload * 2) { + encoder->buffer_size += 2 * nal[i].i_payload; encoder->buffer = g_realloc (encoder->buffer, encoder->buffer_size); - i_data = encoder->buffer_size - i_size; + i_data = encoder->buffer_size - i_size - 4; } nal_size = |