diff mbox series

[FFmpeg-devel,1/3] checkasm/h264dsp: add h264_add_pixels_clear test

Message ID CAEa-L+vst=H1BhGFiL49d6jVkn4ykqXAoqa-XFznwJsDyOuCYw@mail.gmail.com
State New
Headers show
Series [FFmpeg-devel,1/3] checkasm/h264dsp: add h264_add_pixels_clear test | expand

Checks

Context Check Description
yinshiyou/make_loongarch64 success Make finished
yinshiyou/make_fate_loongarch64 success Make fate finished
andriy/make_x86 success Make finished
andriy/make_fate_x86 success Make fate finished

Commit Message

flow gg Dec. 25, 2023, 4 a.m. UTC

diff mbox series

Patch

From 39a9d1728cd867f5a4bfc39232167e9769247bf6 Mon Sep 17 00:00:00 2001
From: sunyuechi <sunyuechi@iscas.ac.cn>
Date: Thu, 21 Dec 2023 20:02:11 +0800
Subject: [PATCH 1/3] checkasm/h264dsp: add h264_add_pixels_clear test

---
 tests/checkasm/h264dsp.c | 55 ++++++++++++++++++++++++++++++++++++++++
 1 file changed, 55 insertions(+)

diff --git a/tests/checkasm/h264dsp.c b/tests/checkasm/h264dsp.c
index 3c95f9d74d..2a33d3da66 100644
--- a/tests/checkasm/h264dsp.c
+++ b/tests/checkasm/h264dsp.c
@@ -440,6 +440,58 @@  static void check_loop_filter_intra(void)
     }
 }
 
+#define randomize(buf, len) \
+    do { \
+        for (int i = 0; i < len; i++) \
+            buf[i] = rnd(); \
+    } while (0)
+
+static void check_h264_add_pixels_clear(void)
+{
+#define BUF_SIZE 1024
+    LOCAL_ALIGNED_32(int16_t, src, [BUF_SIZE]);
+    LOCAL_ALIGNED_32(int16_t, src2, [BUF_SIZE]);
+    LOCAL_ALIGNED_32(uint8_t, dst, [BUF_SIZE]);
+    LOCAL_ALIGNED_32(uint8_t, dst2, [BUF_SIZE]);
+    H264DSPContext h;
+    ff_h264dsp_init(&h, 8, 1);
+    declare_func(void, uint8_t *, int16_t *, int);
+    int func, stride;
+
+    for (func = 0; func < 2; func++) {
+            void (*add_pixels_clear)(uint8_t *, int16_t *, int) = NULL;
+            const char *name;
+            switch (func) {
+            case 0:
+                add_pixels_clear = h.h264_add_pixels4_clear;
+                name = "h264_add_pixels4_clear";
+                stride = 4;
+                break;
+            case 1:
+                add_pixels_clear = h.h264_add_pixels8_clear;
+                name = "h264_add_pixels8_clear";
+                stride = 8;
+                break;
+            }
+
+            if (check_func(add_pixels_clear, "%s", name)) {
+                randomize(src, BUF_SIZE);
+                memcpy(src2, src, BUF_SIZE * sizeof(*src));
+                randomize(dst, BUF_SIZE);
+                memcpy(dst2, dst, BUF_SIZE * sizeof(*dst));
+
+                call_ref(dst, src, stride);
+                call_new(dst2, src2, stride);
+
+                if (memcmp(dst, dst2, BUF_SIZE * sizeof(*dst)) != 0 || memcmp(src, src2, BUF_SIZE * (*src)) != 0){
+                    fail();
+                }
+
+                bench_new(dst, src, stride);
+            }
+    }
+}
+
 void checkasm_check_h264dsp(void)
 {
     check_idct();
@@ -451,4 +503,7 @@  void checkasm_check_h264dsp(void)
 
     check_loop_filter_intra();
     report("loop_filter_intra");
+
+    check_h264_add_pixels_clear();
+    report("add_pixels_clear");
 }
-- 
2.43.0