OLD | NEW |
1 //===- subzero/crosstest/test_bitmanip_main.cpp - Driver for tests. -------===// | 1 //===- subzero/crosstest/test_bitmanip_main.cpp - Driver for tests. -------===// |
2 // | 2 // |
3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
4 // | 4 // |
5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
7 // | 7 // |
8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
9 // | 9 // |
10 // Driver for cross testing bit manipulation intrinsics. | 10 // Driver for cross testing bit manipulation intrinsics. |
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
95 << "): sz=" << static_cast<uint64_t>(ResultSz) | 95 << "): sz=" << static_cast<uint64_t>(ResultSz) |
96 << " llc=" << static_cast<uint64_t>(ResultLlc) | 96 << " llc=" << static_cast<uint64_t>(ResultLlc) |
97 << "\n"; | 97 << "\n"; |
98 } | 98 } |
99 } | 99 } |
100 } | 100 } |
101 } | 101 } |
102 | 102 |
103 template <typename Type> | 103 template <typename Type> |
104 void testByteSwap(size_t &TotalTests, size_t &Passes, size_t &Failures) { | 104 void testByteSwap(size_t &TotalTests, size_t &Passes, size_t &Failures) { |
105 for (size_t i = 0; i < NumValues; ++i) { | 105 typedef Type (*FuncType)(Type); |
106 Type Value = static_cast<Type>(Values[i]); | 106 static struct { |
107 ++TotalTests; | 107 const char *Name; |
108 Type ResultSz = test_bswap(Value); | 108 FuncType FuncLlc; |
109 Type ResultLlc = Subzero_::test_bswap(Value); | 109 FuncType FuncSz; |
110 if (ResultSz == ResultLlc) { | 110 } Funcs[] = { |
111 ++Passes; | 111 {"bswap", test_bswap, Subzero_::test_bswap}, |
112 } else { | 112 {"bswap_alloca", test_bswap_alloca, Subzero_::test_bswap_alloca}}; |
113 ++Failures; | 113 const static size_t NumFuncs = sizeof(Funcs) / sizeof(*Funcs); |
114 std::cout << "test_bswap" << (CHAR_BIT * sizeof(Type)) << "(" | 114 for (size_t f = 0; f < NumFuncs; ++f) { |
115 << static_cast<uint64_t>(Value) | 115 for (size_t i = 0; i < NumValues; ++i) { |
116 << "): sz=" << static_cast<uint64_t>(ResultSz) | 116 Type Value = static_cast<Type>(Values[i]); |
117 << " llc=" << static_cast<uint64_t>(ResultLlc) << "\n"; | 117 ++TotalTests; |
| 118 Type ResultSz = Funcs[f].FuncSz(Value); |
| 119 Type ResultLlc = Funcs[f].FuncLlc(Value); |
| 120 if (ResultSz == ResultLlc) { |
| 121 ++Passes; |
| 122 } else { |
| 123 ++Failures; |
| 124 std::cout << "test_" << Funcs[f].Name << (CHAR_BIT * sizeof(Type)) |
| 125 << "(" << static_cast<uint64_t>(Value) |
| 126 << "): sz=" << static_cast<uint64_t>(ResultSz) |
| 127 << " llc=" << static_cast<uint64_t>(ResultLlc) << "\n"; |
| 128 } |
118 } | 129 } |
119 } | 130 } |
120 } | 131 } |
121 | 132 |
122 int main(int argc, char **argv) { | 133 int main(int argc, char **argv) { |
123 size_t TotalTests = 0; | 134 size_t TotalTests = 0; |
124 size_t Passes = 0; | 135 size_t Passes = 0; |
125 size_t Failures = 0; | 136 size_t Failures = 0; |
126 | 137 |
127 testBitManip<uint32_t>(TotalTests, Passes, Failures); | 138 testBitManip<uint32_t>(TotalTests, Passes, Failures); |
128 testBitManip<uint64_t>(TotalTests, Passes, Failures); | 139 testBitManip<uint64_t>(TotalTests, Passes, Failures); |
129 testByteSwap<uint16_t>(TotalTests, Passes, Failures); | 140 testByteSwap<uint16_t>(TotalTests, Passes, Failures); |
130 testByteSwap<uint32_t>(TotalTests, Passes, Failures); | 141 testByteSwap<uint32_t>(TotalTests, Passes, Failures); |
131 testByteSwap<uint64_t>(TotalTests, Passes, Failures); | 142 testByteSwap<uint64_t>(TotalTests, Passes, Failures); |
132 | 143 |
133 std::cout << "TotalTests=" << TotalTests << " Passes=" << Passes | 144 std::cout << "TotalTests=" << TotalTests << " Passes=" << Passes |
134 << " Failures=" << Failures << "\n"; | 145 << " Failures=" << Failures << "\n"; |
135 return Failures; | 146 return Failures; |
136 } | 147 } |
OLD | NEW |