Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(15)

Side by Side Diff: crosstest/mem_intrin_main.cpp

Issue 877003003: Subzero: Use a "known" version of clang-format. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Fix wildcards Created 5 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* crosstest.py --test=mem_intrin.cpp --driver=mem_intrin_main.cpp \ 1 /* crosstest.py --test=mem_intrin.cpp --driver=mem_intrin_main.cpp \
2 --prefix=Subzero_ --output=mem_intrin */ 2 --prefix=Subzero_ --output=mem_intrin */
3 3
4 #include <stdint.h> /* cstdint requires -std=c++0x or higher */ 4 #include <stdint.h> /* cstdint requires -std=c++0x or higher */
5 #include <cstdio> 5 #include <cstdio>
6 6
7 #include "mem_intrin.h" 7 #include "mem_intrin.h"
8 namespace Subzero_ { 8 namespace Subzero_ {
9 #include "mem_intrin.h" 9 #include "mem_intrin.h"
10 } 10 }
11 11
12 #define XSTR(s) STR(s) 12 #define XSTR(s) STR(s)
13 #define STR(s) #s 13 #define STR(s) #s
14 14
15 void testFixedLen(size_t &TotalTests, size_t &Passes, size_t &Failures) { 15 void testFixedLen(size_t &TotalTests, size_t &Passes, size_t &Failures) {
16 #define do_test_fixed(test_func) \ 16 #define do_test_fixed(test_func) \
17 for (uint8_t init_val = 0; init_val < 100; ++init_val) { \ 17 for (uint8_t init_val = 0; init_val < 100; ++init_val) { \
18 ++TotalTests; \ 18 ++TotalTests; \
19 int llc_result = test_func(init_val); \ 19 int llc_result = test_func(init_val); \
20 int sz_result = Subzero_::test_func(init_val); \ 20 int sz_result = Subzero_::test_func(init_val); \
21 if (llc_result == sz_result) { \ 21 if (llc_result == sz_result) { \
22 ++Passes; \ 22 ++Passes; \
23 } else { \ 23 } else { \
24 ++Failures; \ 24 ++Failures; \
25 printf("Failure (%s): init_val=%d, llc=%d, sz=%d\n", \ 25 printf("Failure (%s): init_val=%d, llc=%d, sz=%d\n", STR(test_func), \
26 STR(test_func), init_val, llc_result, sz_result); \ 26 init_val, llc_result, sz_result); \
27 } \ 27 } \
28 } 28 }
29 29
30 do_test_fixed(memcpy_test_fixed_len) 30 do_test_fixed(memcpy_test_fixed_len) do_test_fixed(memmove_test_fixed_len)
jvoung (off chromium) 2015/01/27 18:08:11 This is a bit odd. I wonder if having semi-colons
Jim Stichnoth 2015/01/27 19:24:11 Right - adding semicolons fixed it.
31 do_test_fixed(memmove_test_fixed_len) 31 do_test_fixed(memset_test_fixed_len)
32 do_test_fixed(memset_test_fixed_len)
33 #undef do_test_fixed 32 #undef do_test_fixed
34 } 33 }
35 34
36 void testVariableLen(size_t &TotalTests, size_t &Passes, size_t &Failures) { 35 void testVariableLen(size_t &TotalTests, size_t &Passes, size_t &Failures) {
37 uint8_t buf[256]; 36 uint8_t buf[256];
38 uint8_t buf2[256]; 37 uint8_t buf2[256];
39 #define do_test_variable(test_func) \ 38 #define do_test_variable(test_func) \
40 for (size_t len = 4; len < 128; ++len) { \ 39 for (size_t len = 4; len < 128; ++len) { \
41 for (uint8_t init_val = 0; init_val < 100; ++init_val) { \ 40 for (uint8_t init_val = 0; init_val < 100; ++init_val) { \
42 ++TotalTests; \ 41 ++TotalTests; \
43 int llc_result = test_func(buf, buf2, init_val, len); \ 42 int llc_result = test_func(buf, buf2, init_val, len); \
44 int sz_result = Subzero_::test_func(buf, buf2, init_val, len); \ 43 int sz_result = Subzero_::test_func(buf, buf2, init_val, len); \
45 if (llc_result == sz_result) { \ 44 if (llc_result == sz_result) { \
46 ++Passes; \ 45 ++Passes; \
47 } else { \ 46 } else { \
48 ++Failures; \ 47 ++Failures; \
49 printf("Failure (%s): init_val=%d, len=%d, llc=%d, sz=%d\n", \ 48 printf("Failure (%s): init_val=%d, len=%d, llc=%d, sz=%d\n", \
50 STR(test_func), init_val, len, llc_result, sz_result); \ 49 STR(test_func), init_val, len, llc_result, sz_result); \
51 } \ 50 } \
52 } \ 51 } \
53 } 52 }
54 53
55 do_test_variable(memcpy_test) 54 do_test_variable(memcpy_test) do_test_variable(memmove_test)
jvoung (off chromium) 2015/01/27 18:08:11 similar
Jim Stichnoth 2015/01/27 19:24:11 Done.
56 do_test_variable(memmove_test) 55 do_test_variable(memset_test)
57 do_test_variable(memset_test)
58 #undef do_test_variable 56 #undef do_test_variable
59 } 57 }
60 58
61 int main(int argc, char **argv) { 59 int main(int argc, char **argv) {
62 unsigned TotalTests = 0; 60 unsigned TotalTests = 0;
63 unsigned Passes = 0; 61 unsigned Passes = 0;
64 unsigned Failures = 0; 62 unsigned Failures = 0;
65 testFixedLen(TotalTests, Passes, Failures); 63 testFixedLen(TotalTests, Passes, Failures);
66 testVariableLen(TotalTests, Passes, Failures); 64 testVariableLen(TotalTests, Passes, Failures);
67 printf("TotalTests=%u Passes=%u Failures=%u\n", TotalTests, Passes, Failures); 65 printf("TotalTests=%u Passes=%u Failures=%u\n", TotalTests, Passes, Failures);
68 return Failures; 66 return Failures;
69 } 67 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698