Mercurial > vec
comparison test/test_arith.h @ 25:92156fe32755
impl/ppc/altivec: update to new implementation
the signed average function is wrong; it needs to round up the number
when only one of them is odd, but that doesn't necessarily seem to be
true because altivec is weird, and that's what we need to emulate the
quirks for. ugh.
also the altivec backend uses the generic functions instead of fallbacks
because it does indeed use the exact same memory structure as the generic
implementation...
author | Paper <paper@tflc.us> |
---|---|
date | Sun, 24 Nov 2024 11:15:59 +0000 |
parents | e26874655738 |
children |
comparison
equal
deleted
inserted
replaced
24:e49e70f7012f | 25:92156fe32755 |
---|---|
1 #include <math.h> | |
2 | |
1 #define CREATE_TEST(sign, psign, csign, bits, size, op, equiv) \ | 3 #define CREATE_TEST(sign, psign, csign, bits, size, op, equiv) \ |
2 static int test_arith_v##sign##int##bits##x##size##_##op(v##sign##int##bits##x##size a, v##sign##int##bits##x##size b) \ | 4 static int test_arith_v##sign##int##bits##x##size##_##op(v##sign##int##bits##x##size a, v##sign##int##bits##x##size b) \ |
3 { \ | 5 { \ |
4 V##csign##INT##bits##x##size##_ALIGNED_ARRAY(orig_a); \ | 6 V##csign##INT##bits##x##size##_ALIGNED_ARRAY(orig_a); \ |
5 V##csign##INT##bits##x##size##_ALIGNED_ARRAY(orig_b); \ | 7 V##csign##INT##bits##x##size##_ALIGNED_ARRAY(orig_b); \ |
11 v##sign##int##bits##x##size##_store_aligned(b, orig_b); \ | 13 v##sign##int##bits##x##size##_store_aligned(b, orig_b); \ |
12 v##sign##int##bits##x##size##_store_aligned(c, orig_c); \ | 14 v##sign##int##bits##x##size##_store_aligned(c, orig_c); \ |
13 \ | 15 \ |
14 for (int i = 0; i < size; i++) { \ | 16 for (int i = 0; i < size; i++) { \ |
15 if ((sign##int##bits##_t)(equiv) != orig_c[i]) { \ | 17 if ((sign##int##bits##_t)(equiv) != orig_c[i]) { \ |
16 fprintf(stderr, "v" #sign "int" #bits "x" #size "_" #op " test FAILED at index %d: (" #equiv ") [%" PRI ## psign ## bits "] does not equal result [%" PRI ## psign ## bits "]!\n", i, equiv, orig_c[i]); \ | 18 fprintf(stderr, "v" #sign "int" #bits "x" #size "_" #op " test FAILED at index %d: (" #equiv ") [%" PRI ## psign ## bits "] does not equal result [%" PRI ## psign ## bits "]!\n", i, (sign##int##bits##_t)(equiv), orig_c[i]); \ |
17 print_v##sign##int##bits##x##size(stderr,a); \ | 19 print_v##sign##int##bits##x##size(stderr,a); \ |
18 print_v##sign##int##bits##x##size(stderr,b); \ | 20 print_v##sign##int##bits##x##size(stderr,b); \ |
19 print_v##sign##int##bits##x##size(stderr,c); \ | 21 print_v##sign##int##bits##x##size(stderr,c); \ |
20 fprintf(stderr, "\n"); \ | 22 fprintf(stderr, "\n"); \ |
21 return 1; \ | 23 return 1; \ |
58 CREATE_TEST(sign, psign, csign, bits, size, mul, orig_a[i] * orig_b[i]) \ | 60 CREATE_TEST(sign, psign, csign, bits, size, mul, orig_a[i] * orig_b[i]) \ |
59 CREATE_TEST(sign, psign, csign, bits, size, div, (orig_b[i]) ? (orig_a[i] / orig_b[i]) : 0) \ | 61 CREATE_TEST(sign, psign, csign, bits, size, div, (orig_b[i]) ? (orig_a[i] / orig_b[i]) : 0) \ |
60 CREATE_TEST(sign, psign, csign, bits, size, and, orig_a[i] & orig_b[i]) \ | 62 CREATE_TEST(sign, psign, csign, bits, size, and, orig_a[i] & orig_b[i]) \ |
61 CREATE_TEST(sign, psign, csign, bits, size, or, orig_a[i] | orig_b[i]) \ | 63 CREATE_TEST(sign, psign, csign, bits, size, or, orig_a[i] | orig_b[i]) \ |
62 CREATE_TEST(sign, psign, csign, bits, size, xor, orig_a[i] ^ orig_b[i]) \ | 64 CREATE_TEST(sign, psign, csign, bits, size, xor, orig_a[i] ^ orig_b[i]) \ |
63 CREATE_TEST(sign, psign, csign, bits, size, avg, (orig_a[i] + orig_b[i] + 1) / 2) \ | 65 CREATE_TEST(sign, psign, csign, bits, size, avg, vec_##sign##avg(orig_a[i], orig_b[i])) \ |
64 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, rshift, vec_##sign##rshift(orig_a[i], orig_b[i])) \ | 66 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, rshift, vec_##sign##rshift(orig_a[i], orig_b[i])) \ |
65 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, lshift, vec_##sign##lshift(orig_a[i], orig_b[i])) \ | 67 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, lshift, vec_##sign##lshift(orig_a[i], orig_b[i])) \ |
66 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, lrshift, vec_lrshift((vec_uint##bits)orig_a[i], orig_b[i])) | 68 CREATE_TEST_SHIFT(sign, psign, csign, bits, size, lrshift, vec_lrshift((vec_uint##bits)orig_a[i], orig_b[i])) |
67 | 69 |
68 #define CREATE_TESTS(bits, size) \ | 70 #define CREATE_TESTS(bits, size) \ |