h264parser: Stop considering 5 bytes NAL complete
authorNicolas Dufresne <nicolas.dufresne@collabora.com>
Fri, 2 Nov 2018 18:18:54 +0000 (14:18 -0400)
committerSebastian Dröge <slomo@coaxion.net>
Tue, 6 Nov 2018 07:26:03 +0000 (07:26 +0000)
This is only TRUE for SEQ_END / STREAM_END. Before this patch, passing
any valid 5 bytes of a NAL would make the parser pretend this NAL is
complete.

gst-libs/gst/codecparsers/gsth264parser.c

index 73968db..30d6aea 100644 (file)
@@ -1343,7 +1343,13 @@ gst_h264_parser_identify_nalu (GstH264NalParser * nalparser,
       gst_h264_parser_identify_nalu_unchecked (nalparser, data, offset, size,
       nalu);
 
-  if (res != GST_H264_PARSER_OK || nalu->size == 1)
+  if (res != GST_H264_PARSER_OK)
+    goto beach;
+
+  /* The two NALs are exactly 1 byte size and are placed at the end of an AU,
+   * there is no need to wait for the following */
+  if (nalu->type == GST_H264_NAL_SEQ_END ||
+      nalu->type == GST_H264_NAL_STREAM_END)
     goto beach;
 
   off2 = scan_for_start_codes (data + nalu->offset, size - nalu->offset);