[gst-cvs] gst-plugins-ugly: x264enc: adaptive NALU type checking

Mark Nauwelaerts mnauw at kemper.freedesktop.org
Mon Apr 19 01:44:33 PDT 2010


Module: gst-plugins-ugly
Branch: master
Commit: 6ebb4e0fedf0ee8c75eba9269600f61caf6b83d7
URL:    http://cgit.freedesktop.org/gstreamer/gst-plugins-ugly/commit/?id=6ebb4e0fedf0ee8c75eba9269600f61caf6b83d7

Author: Mark Nauwelaerts <mark.nauwelaerts at collabora.co.uk>
Date:   Tue Apr 13 16:59:03 2010 +0200

x264enc: adaptive NALU type checking

In particular, be less picky about SEI NALU order, which makes test more
robust with respect to changes in libx264.

See also #615410.

---

 tests/check/elements/x264enc.c |   27 +++++++++++----------------
 1 files changed, 11 insertions(+), 16 deletions(-)

diff --git a/tests/check/elements/x264enc.c b/tests/check/elements/x264enc.c
index c256f4e..ecfa4d4 100644
--- a/tests/check/elements/x264enc.c
+++ b/tests/check/elements/x264enc.c
@@ -154,7 +154,7 @@ GST_START_TEST (test_video_pad)
     switch (i) {
       case 0:
       {
-        gint nsize, npos, j, type;
+        gint nsize, npos, j, type, next_type;
         guint8 *data = GST_BUFFER_DATA (outbuffer);
         gint size = GST_BUFFER_SIZE (outbuffer);
 
@@ -162,6 +162,8 @@ GST_START_TEST (test_video_pad)
 
         npos = 0;
         j = 0;
+        /* need SPS first */
+        next_type = 7;
         /* loop through NALs */
         while (npos < size) {
           fail_unless (size - npos >= 4);
@@ -169,24 +171,17 @@ GST_START_TEST (test_video_pad)
           fail_unless (nsize > 0);
           fail_unless (npos + 4 + nsize <= size);
           type = data[npos + 4] & 0x1F;
-          /* check the first NALs, disregard AU (9) */
-          if (type != 9) {
-            switch (j) {
-              case 0:
-                /* SEI */
-                fail_unless (type == 6);
-                break;
-              case 1:
+          /* check the first NALs, disregard AU (9), SEI (6) */
+          if (type != 9 && type != 6) {
+            fail_unless (type == next_type);
+            switch (type) {
+              case 7:
                 /* SPS */
-                fail_unless (type == 7);
+                next_type = 8;
                 break;
-              case 2:
+              case 8:
                 /* PPS */
-                fail_unless (type == 8);
-                break;
-              case 3:
-                /* IDR */
-                fail_unless (type == 5);
+                next_type = 5;
                 break;
               default:
                 break;





More information about the Gstreamer-commits mailing list