]> git.sesse.net Git - ffmpeg/commitdiff
checkasm/vf_threshold : add test for threshold16
authorMartin Vignali <martin.vignali@gmail.com>
Thu, 7 Dec 2017 21:03:44 +0000 (22:03 +0100)
committerMartin Vignali <martin.vignali@gmail.com>
Sat, 9 Dec 2017 13:47:13 +0000 (14:47 +0100)
tests/checkasm/vf_threshold.c

index 3709f2671e04940999c194ac876d9c8d9ff5d30c..5a2fc0e4ee4f8802f3e070f713971671b06c7180 100644 (file)
@@ -32,7 +32,7 @@
            tmp_buf[j] = rnd() & 0xFF;    \
     } while (0)
 
-static void check_threshold_8(void){
+static void check_threshold(int depth){
     LOCAL_ALIGNED_32(uint8_t, in       , [WIDTH_PADDED]);
     LOCAL_ALIGNED_32(uint8_t, threshold, [WIDTH_PADDED]);
     LOCAL_ALIGNED_32(uint8_t, min      , [WIDTH_PADDED]);
@@ -49,7 +49,7 @@ static void check_threshold_8(void){
                  ptrdiff_t olinesize, int w, int h);
 
     ThresholdContext s;
-    s.depth = 8;
+    s.depth = depth;
     ff_threshold_init(&s);
 
     memset(in,     0, WIDTH_PADDED);
@@ -63,10 +63,13 @@ static void check_threshold_8(void){
     randomize_buffers(min, WIDTH);
     randomize_buffers(max, WIDTH);
 
-    if (check_func(s.threshold, "threshold8")) {
+    if (depth == 16)
+        w /= 2;
+
+    if (check_func(s.threshold, "threshold%d", depth)) {
         call_ref(in, threshold, min, max, out_ref, line_size, line_size, line_size, line_size, line_size, w, 1);
         call_new(in, threshold, min, max, out_new, line_size, line_size, line_size, line_size, line_size, w, 1);
-        if (memcmp(out_ref, out_new, w))
+        if (memcmp(out_ref, out_new, WIDTH))
             fail();
         bench_new(in, threshold, min, max, out_new, line_size, line_size, line_size, line_size, line_size, w, 1);
     }
@@ -74,6 +77,9 @@ static void check_threshold_8(void){
 
 void checkasm_check_vf_threshold(void)
 {
-    check_threshold_8();
+    check_threshold(8);
     report("threshold8");
+
+    check_threshold(16);
+    report("threshold16");
 }