aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorRamiro Polla <ramiro.polla@gmail.com>2024-12-01 17:09:40 +0100
committerRamiro Polla <ramiro.polla@gmail.com>2024-12-05 21:10:29 +0100
commit536a44e8dcffde5ccb3bcaef9e1d5d343c39059d (patch)
tree34d2718a5235a93227cee8a271d10893d333f6f8
parent6a108d475988bd9602f1245c9a560b9b20d2389c (diff)
downloadffmpeg-536a44e8dcffde5ccb3bcaef9e1d5d343c39059d.tar.gz
checkasm/sw_range_convert: test negative input values
-rw-r--r--tests/checkasm/sw_range_convert.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/tests/checkasm/sw_range_convert.c b/tests/checkasm/sw_range_convert.c
index bf14209987..ba576ff08c 100644
--- a/tests/checkasm/sw_range_convert.c
+++ b/tests/checkasm/sw_range_convert.c
@@ -65,6 +65,8 @@ static void check_lumConvertRange(int from)
LOCAL_ALIGNED_32(int16_t, dst0, [LARGEST_INPUT_SIZE * 2]);
LOCAL_ALIGNED_32(int16_t, dst1, [LARGEST_INPUT_SIZE * 2]);
+ int32_t *dst0_32 = (int32_t *) dst0;
+ int32_t *dst1_32 = (int32_t *) dst1;
declare_func(void, int16_t *dst, int width);
@@ -89,6 +91,11 @@ static void check_lumConvertRange(int from)
int width = input_sizes[dstWi];
if (check_func(c->lumConvertRange, "%s%d_%d", func_str, bit_depth, width)) {
randomize_buffers(dst0, dst1, bit_depth, width);
+ if (bit_depth == 16) {
+ dst1_32[2] = dst0_32[2] = -1;
+ } else {
+ dst1[2] = dst0[2] = -1;
+ }
call_ref(dst0, width);
call_new(dst1, width);
if (memcmp(dst0, dst1, width * sample_size))
@@ -115,6 +122,8 @@ static void check_chrConvertRange(int from)
LOCAL_ALIGNED_32(int16_t, dstV0, [LARGEST_INPUT_SIZE * 2]);
LOCAL_ALIGNED_32(int16_t, dstU1, [LARGEST_INPUT_SIZE * 2]);
LOCAL_ALIGNED_32(int16_t, dstV1, [LARGEST_INPUT_SIZE * 2]);
+ int32_t *dstU0_32 = (int32_t *) dstU0;
+ int32_t *dstU1_32 = (int32_t *) dstU1;
declare_func(void, int16_t *dstU, int16_t *dstV, int width);
@@ -140,6 +149,11 @@ static void check_chrConvertRange(int from)
if (check_func(c->chrConvertRange, "%s%d_%d", func_str, bit_depth, width)) {
randomize_buffers(dstU0, dstU1, bit_depth, width);
randomize_buffers(dstV0, dstV1, bit_depth, width);
+ if (bit_depth == 16) {
+ dstU1_32[2] = dstU0_32[2] = -1;
+ } else {
+ dstU1[2] = dstU0[2] = -1;
+ }
call_ref(dstU0, dstV0, width);
call_new(dstU1, dstV1, width);
if (memcmp(dstU0, dstU1, width * sample_size) ||