• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

randombit / botan / 5079590438

25 May 2023 12:28PM UTC coverage: 92.228% (+0.5%) from 91.723%
5079590438

Pull #3502

github

Pull Request #3502: Apply clang-format to the codebase

75589 of 81959 relevant lines covered (92.23%)

12139530.51 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

97.09
/src/tests/test_simd.cpp
1
/*
2
* (C) 2017 Jack Lloyd
3
*
4
* Botan is released under the Simplified BSD License (see license.txt)
5
*/
6

7
#include "tests.h"
8

9
#if defined(BOTAN_HAS_SIMD_32)
10
   #include <botan/internal/bswap.h>
11
   #include <botan/internal/cpuid.h>
12
   #include <botan/internal/loadstor.h>
13
   #include <botan/internal/rotate.h>
14
   #include <botan/internal/simd_32.h>
15
#endif
16

17
namespace Botan_Tests {
18

19
#if defined(BOTAN_HAS_SIMD_32)
20

21
class SIMD_32_Tests final : public Test {
×
22
   public:
23
      std::vector<Test::Result> run() override {
1✔
24
         Test::Result result("SIMD_4x32");
1✔
25

26
         if(Botan::CPUID::has_simd_32() == false) {
1✔
27
            result.test_note("Skipping SIMD_4x32 tests due to missing CPU support at runtime");
×
28
            return {result};
×
29
         }
30

31
         const uint32_t pat1 = 0xAABBCCDD;
1✔
32
         const uint32_t pat2 = 0x87654321;
1✔
33
         const uint32_t pat3 = 0x01234567;
1✔
34
         const uint32_t pat4 = 0xC0D0E0F0;
1✔
35

36
         // pat1 + pat{1,2,3,4}
37
         // precomputed to avoid integer overflow warnings
38
         const uint32_t pat1_1 = 0x557799BA;
1✔
39
         const uint32_t pat1_2 = 0x32210FFE;
1✔
40
         const uint32_t pat1_3 = 0xABDF1244;
1✔
41
         const uint32_t pat1_4 = 0x6B8CADCD;
1✔
42

43
         test_eq(result, "default init", Botan::SIMD_4x32(), 0, 0, 0, 0);
1✔
44
         test_eq(result, "SIMD scalar constructor", Botan::SIMD_4x32(1, 2, 3, 4), 1, 2, 3, 4);
1✔
45

46
         const Botan::SIMD_4x32 splat = Botan::SIMD_4x32::splat(pat1);
1✔
47

48
         test_eq(result, "splat", splat, pat1, pat1, pat1, pat1);
1✔
49

50
         const Botan::SIMD_4x32 input(pat1, pat2, pat3, pat4);
1✔
51

52
         Botan::SIMD_4x32 rol = input.rotl<3>();
1✔
53

54
         test_eq(result,
1✔
55
                 "rotl",
56
                 rol,
57
                 Botan::rotl<3>(pat1),
58
                 Botan::rotl<3>(pat2),
59
                 Botan::rotl<3>(pat3),
60
                 Botan::rotl<3>(pat4));
61

62
         Botan::SIMD_4x32 ror = input.rotr<9>();
1✔
63

64
         test_eq(result,
1✔
65
                 "rotr",
66
                 ror,
67
                 Botan::rotr<9>(pat1),
68
                 Botan::rotr<9>(pat2),
69
                 Botan::rotr<9>(pat3),
70
                 Botan::rotr<9>(pat4));
71

72
         Botan::SIMD_4x32 add = input + splat;
1✔
73
         test_eq(result, "add +", add, pat1_1, pat1_2, pat1_3, pat1_4);
1✔
74

75
         add -= splat;
1✔
76
         test_eq(result, "sub -=", add, pat1, pat2, pat3, pat4);
1✔
77

78
         add += splat;
1✔
79
         test_eq(result, "add +=", add, pat1_1, pat1_2, pat1_3, pat1_4);
1✔
80

81
         test_eq(result, "xor", input ^ splat, 0, pat2 ^ pat1, pat3 ^ pat1, pat4 ^ pat1);
1✔
82
         test_eq(result, "or", input | splat, pat1, pat2 | pat1, pat3 | pat1, pat4 | pat1);
1✔
83
         test_eq(result, "and", input & splat, pat1, pat2 & pat1, pat3 & pat1, pat4 & pat1);
1✔
84

85
         Botan::SIMD_4x32 blender = input;
1✔
86
         blender |= splat;
1✔
87
         test_eq(result, "|=", blender, pat1, pat2 | pat1, pat3 | pat1, pat4 | pat1);
1✔
88
         blender &= splat;
1✔
89
         test_eq(result, "&=", blender, pat1, pat1, pat1, pat1);
1✔
90
         blender ^= splat;
1✔
91
         test_eq(result, "^=", blender, 0, 0, 0, 0);
1✔
92

93
         blender = ~blender;
1✔
94
         test_eq(result, "~", blender, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF, 0xFFFFFFFF);
1✔
95

96
         blender = blender.shr<23>();
1✔
97
         test_eq(result, ">>", blender, 0x1FF, 0x1FF, 0x1FF, 0x1FF);
1✔
98

99
         blender = blender.shl<27>();
1✔
100
         test_eq(result, "<<", blender, 0xF8000000, 0xF8000000, 0xF8000000, 0xF8000000);
1✔
101

102
         blender = ~blender;
1✔
103
         test_eq(result, "~", blender, 0x7FFFFFF, 0x7FFFFFF, 0x7FFFFFF, 0x7FFFFFF);
1✔
104

105
         blender = input.andc(~blender);
1✔
106
         test_eq(
1✔
107
            result, "andc", blender, ~pat1 & 0xF8000000, ~pat2 & 0xF8000000, ~pat3 & 0xF8000000, ~pat4 & 0xF8000000);
108

109
         test_eq(result,
1✔
110
                 "bswap",
111
                 input.bswap(),
1✔
112
                 Botan::reverse_bytes(pat1),
113
                 Botan::reverse_bytes(pat2),
114
                 Botan::reverse_bytes(pat3),
115
                 Botan::reverse_bytes(pat4));
116

117
         Botan::SIMD_4x32 t1(pat1, pat2, pat3, pat4);
1✔
118
         Botan::SIMD_4x32 t2(pat1 + 1, pat2 + 1, pat3 + 1, pat4 + 1);
1✔
119
         Botan::SIMD_4x32 t3(pat1 + 2, pat2 + 2, pat3 + 2, pat4 + 2);
1✔
120
         Botan::SIMD_4x32 t4(pat1 + 3, pat2 + 3, pat3 + 3, pat4 + 3);
1✔
121

122
         Botan::SIMD_4x32::transpose(t1, t2, t3, t4);
1✔
123

124
         test_eq(result, "transpose t1", t1, pat1, pat1 + 1, pat1 + 2, pat1 + 3);
1✔
125
         test_eq(result, "transpose t2", t2, pat2, pat2 + 1, pat2 + 2, pat2 + 3);
1✔
126
         test_eq(result, "transpose t3", t3, pat3, pat3 + 1, pat3 + 2, pat3 + 3);
1✔
127
         test_eq(result, "transpose t4", t4, pat4, pat4 + 1, pat4 + 2, pat4 + 3);
1✔
128

129
         test_eq(result, "shift left 1", input.shift_elems_left<1>(), 0, pat1, pat2, pat3);
1✔
130
         test_eq(result, "shift left 2", input.shift_elems_left<2>(), 0, 0, pat1, pat2);
1✔
131
         test_eq(result, "shift left 3", input.shift_elems_left<3>(), 0, 0, 0, pat1);
1✔
132

133
         test_eq(result, "shift right 1", input.shift_elems_right<1>(), pat2, pat3, pat4, 0);
1✔
134
         test_eq(result, "shift right 2", input.shift_elems_right<2>(), pat3, pat4, 0, 0);
1✔
135
         test_eq(result, "shift right 3", input.shift_elems_right<3>(), pat4, 0, 0, 0);
1✔
136

137
         return {result};
2✔
138
      }
1✔
139

140
   private:
141
      static void test_eq(Test::Result& result,
30✔
142
                          const std::string& op,
143
                          const Botan::SIMD_4x32& simd,
144
                          uint32_t exp0,
145
                          uint32_t exp1,
146
                          uint32_t exp2,
147
                          uint32_t exp3) {
148
         uint8_t arr_be[16 + 15];
30✔
149
         uint8_t arr_be2[16 + 15];
30✔
150
         uint8_t arr_le[16 + 15];
30✔
151
         uint8_t arr_le2[16 + 15];
30✔
152

153
         for(size_t misalignment = 0; misalignment != 16; ++misalignment) {
510✔
154
            uint8_t* mem_be = arr_be + misalignment;
480✔
155
            uint8_t* mem_be2 = arr_be2 + misalignment;
480✔
156
            uint8_t* mem_le = arr_le + misalignment;
480✔
157
            uint8_t* mem_le2 = arr_le2 + misalignment;
480✔
158

159
            simd.store_be(mem_be);
480✔
160

161
            result.test_int_eq(
960✔
162
               "SIMD_4x32 " + op + " elem0 BE", Botan::make_uint32(mem_be[0], mem_be[1], mem_be[2], mem_be[3]), exp0);
960✔
163
            result.test_int_eq(
480✔
164
               "SIMD_4x32 " + op + " elem1 BE", Botan::make_uint32(mem_be[4], mem_be[5], mem_be[6], mem_be[7]), exp1);
960✔
165
            result.test_int_eq(
480✔
166
               "SIMD_4x32 " + op + " elem2 BE", Botan::make_uint32(mem_be[8], mem_be[9], mem_be[10], mem_be[11]), exp2);
960✔
167
            result.test_int_eq("SIMD_4x32 " + op + " elem3 BE",
960✔
168
                               Botan::make_uint32(mem_be[12], mem_be[13], mem_be[14], mem_be[15]),
480✔
169
                               exp3);
170

171
            // Check load_be+store_be results in same value
172
            const Botan::SIMD_4x32 reloaded_be = Botan::SIMD_4x32::load_be(mem_be);
480✔
173
            reloaded_be.store_be(mem_be2);
480✔
174
            result.test_eq(nullptr, "SIMD_4x32 load_be", mem_be, 16, mem_be2, 16);
480✔
175

176
            simd.store_le(mem_le);
480✔
177

178
            result.test_int_eq(
960✔
179
               "SIMD_4x32 " + op + " elem0 LE", Botan::make_uint32(mem_le[3], mem_le[2], mem_le[1], mem_le[0]), exp0);
960✔
180
            result.test_int_eq(
480✔
181
               "SIMD_4x32 " + op + " elem1 LE", Botan::make_uint32(mem_le[7], mem_le[6], mem_le[5], mem_le[4]), exp1);
960✔
182
            result.test_int_eq(
480✔
183
               "SIMD_4x32 " + op + " elem2 LE", Botan::make_uint32(mem_le[11], mem_le[10], mem_le[9], mem_le[8]), exp2);
960✔
184
            result.test_int_eq("SIMD_4x32 " + op + " elem3 LE",
960✔
185
                               Botan::make_uint32(mem_le[15], mem_le[14], mem_le[13], mem_le[12]),
480✔
186
                               exp3);
187

188
            // Check load_le+store_le results in same value
189
            const Botan::SIMD_4x32 reloaded_le = Botan::SIMD_4x32::load_le(mem_le);
480✔
190
            reloaded_le.store_le(mem_le2);
480✔
191
            result.test_eq(nullptr, "SIMD_4x32 load_le", mem_le, 16, mem_le2, 16);
960✔
192
         }
193
      }
30✔
194
};
195

196
BOTAN_REGISTER_TEST("utils", "simd_32", SIMD_32_Tests);
197
#endif
198

199
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc