LCOV - code coverage report
Current view: top level - src/crypto - sha256_avx2.cpp (source / functions) Hit Total Coverage
Test: total_coverage.info Lines: 284 284 100.0 %
Date: 2020-09-26 01:30:44 Functions: 24 24 100.0 %

          Line data    Source code
       1             : // Copyright (c) 2017-2019 The Bitcoin Core developers
       2             : // Distributed under the MIT software license, see the accompanying
       3             : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
       4             : 
       5             : #ifdef ENABLE_AVX2
       6             : 
       7             : #include <stdint.h>
       8             : #include <immintrin.h>
       9             : 
      10             : #include <crypto/common.h>
      11             : 
      12             : namespace sha256d64_avx2 {
      13             : namespace {
      14             : 
      15    12363650 : __m256i inline K(uint32_t x) { return _mm256_set1_epi32(x); }
      16             : 
      17    84126575 : __m256i inline Add(__m256i x, __m256i y) { return _mm256_add_epi32(x, y); }
      18      483795 : __m256i inline Add(__m256i x, __m256i y, __m256i z) { return Add(Add(x, y), z); }
      19    14675115 : __m256i inline Add(__m256i x, __m256i y, __m256i z, __m256i w) { return Add(Add(x, y), Add(z, w)); }
      20      107510 : __m256i inline Add(__m256i x, __m256i y, __m256i z, __m256i w, __m256i v) { return Add(Add(x, y, z), Add(w, v)); }
      21       53755 : __m256i inline Inc(__m256i& x, __m256i y) { x = Add(x, y); return x; }
      22      268775 : __m256i inline Inc(__m256i& x, __m256i y, __m256i z) { x = Add(x, y, z); return x; }
      23     4300400 : __m256i inline Inc(__m256i& x, __m256i y, __m256i z, __m256i w) { x = Add(x, y, z, w); return x; }
      24    81492580 : __m256i inline Xor(__m256i x, __m256i y) { return _mm256_xor_si256(x, y); }
      25    30425330 : __m256i inline Xor(__m256i x, __m256i y, __m256i z) { return Xor(Xor(x, y), z); }
      26   102134500 : __m256i inline Or(__m256i x, __m256i y) { return _mm256_or_si256(x, y); }
      27    30962880 : __m256i inline And(__m256i x, __m256i y) { return _mm256_and_si256(x, y); }
      28    91275990 : __m256i inline ShR(__m256i x, int n) { return _mm256_srli_epi32(x, n); }
      29    81492580 : __m256i inline ShL(__m256i x, int n) { return _mm256_slli_epi32(x, n); }
      30             : 
      31    10320960 : __m256i inline Ch(__m256i x, __m256i y, __m256i z) { return Xor(z, And(x, Xor(y, z))); }
      32    10320960 : __m256i inline Maj(__m256i x, __m256i y, __m256i z) { return Or(And(x, y), And(z, Or(x, y))); }
      33    10320960 : __m256i inline Sigma0(__m256i x) { return Xor(Or(ShR(x, 2), ShL(x, 30)), Or(ShR(x, 13), ShL(x, 19)), Or(ShR(x, 22), ShL(x, 10))); }
      34    10320960 : __m256i inline Sigma1(__m256i x) { return Xor(Or(ShR(x, 6), ShL(x, 26)), Or(ShR(x, 11), ShL(x, 21)), Or(ShR(x, 25), ShL(x, 7))); }
      35     4730440 : __m256i inline sigma0(__m256i x) { return Xor(Or(ShR(x, 7), ShL(x, 25)), Or(ShR(x, 18), ShL(x, 14)), ShR(x, 3)); }
      36     5052970 : __m256i inline sigma1(__m256i x) { return Xor(Or(ShR(x, 17), ShL(x, 15)), Or(ShR(x, 19), ShL(x, 13)), ShR(x, 10)); }
      37             : 
      38             : /** One round of SHA-256. */
      39    10320960 : void inline __attribute__((always_inline)) Round(__m256i a, __m256i b, __m256i c, __m256i& d, __m256i e, __m256i f, __m256i g, __m256i& h, __m256i k)
      40             : {
      41    10320960 :     __m256i t1 = Add(h, Sigma1(e), Ch(e, f, g), k);
      42    10320960 :     __m256i t2 = Add(Sigma0(a), Maj(a, b, c));
      43    10320960 :     d = Add(d, t1);
      44    10320960 :     h = Add(t1, t2);
      45    10320960 : }
      46             : 
      47      860080 : __m256i inline Read8(const unsigned char* chunk, int offset) {
      48      860080 :     __m256i ret = _mm256_set_epi32(
      49      860080 :         ReadLE32(chunk + 0 + offset),
      50      860080 :         ReadLE32(chunk + 64 + offset),
      51      860080 :         ReadLE32(chunk + 128 + offset),
      52      860080 :         ReadLE32(chunk + 192 + offset),
      53      860080 :         ReadLE32(chunk + 256 + offset),
      54      860080 :         ReadLE32(chunk + 320 + offset),
      55      860080 :         ReadLE32(chunk + 384 + offset),
      56      860080 :         ReadLE32(chunk + 448 + offset)
      57             :     );
      58      860080 :     return _mm256_shuffle_epi8(ret, _mm256_set_epi32(0x0C0D0E0FUL, 0x08090A0BUL, 0x04050607UL, 0x00010203UL, 0x0C0D0E0FUL, 0x08090A0BUL, 0x04050607UL, 0x00010203UL));
      59             : }
      60             : 
      61      430040 : void inline Write8(unsigned char* out, int offset, __m256i v) {
      62      430040 :     v = _mm256_shuffle_epi8(v, _mm256_set_epi32(0x0C0D0E0FUL, 0x08090A0BUL, 0x04050607UL, 0x00010203UL, 0x0C0D0E0FUL, 0x08090A0BUL, 0x04050607UL, 0x00010203UL));
      63      430040 :     WriteLE32(out + 0 + offset, _mm256_extract_epi32(v, 7));
      64      430040 :     WriteLE32(out + 32 + offset, _mm256_extract_epi32(v, 6));
      65      430040 :     WriteLE32(out + 64 + offset, _mm256_extract_epi32(v, 5));
      66      430040 :     WriteLE32(out + 96 + offset, _mm256_extract_epi32(v, 4));
      67      430040 :     WriteLE32(out + 128 + offset, _mm256_extract_epi32(v, 3));
      68      430040 :     WriteLE32(out + 160 + offset, _mm256_extract_epi32(v, 2));
      69      430040 :     WriteLE32(out + 192 + offset, _mm256_extract_epi32(v, 1));
      70      430040 :     WriteLE32(out + 224 + offset, _mm256_extract_epi32(v, 0));
      71      430040 : }
      72             : 
      73             : }
      74             : 
      75       53755 : void Transform_8way(unsigned char* out, const unsigned char* in)
      76             : {
      77             :     // Transform 1
      78       53755 :     __m256i a = K(0x6a09e667ul);
      79       53755 :     __m256i b = K(0xbb67ae85ul);
      80       53755 :     __m256i c = K(0x3c6ef372ul);
      81       53755 :     __m256i d = K(0xa54ff53aul);
      82       53755 :     __m256i e = K(0x510e527ful);
      83       53755 :     __m256i f = K(0x9b05688cul);
      84       53755 :     __m256i g = K(0x1f83d9abul);
      85       53755 :     __m256i h = K(0x5be0cd19ul);
      86             : 
      87       53755 :     __m256i w0, w1, w2, w3, w4, w5, w6, w7, w8, w9, w10, w11, w12, w13, w14, w15;
      88             : 
      89       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x428a2f98ul), w0 = Read8(in, 0)));
      90       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x71374491ul), w1 = Read8(in, 4)));
      91       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0xb5c0fbcful), w2 = Read8(in, 8)));
      92       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0xe9b5dba5ul), w3 = Read8(in, 12)));
      93       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x3956c25bul), w4 = Read8(in, 16)));
      94       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x59f111f1ul), w5 = Read8(in, 20)));
      95       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x923f82a4ul), w6 = Read8(in, 24)));
      96       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0xab1c5ed5ul), w7 = Read8(in, 28)));
      97       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0xd807aa98ul), w8 = Read8(in, 32)));
      98       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x12835b01ul), w9 = Read8(in, 36)));
      99       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x243185beul), w10 = Read8(in, 40)));
     100       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x550c7dc3ul), w11 = Read8(in, 44)));
     101       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x72be5d74ul), w12 = Read8(in, 48)));
     102       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x80deb1feul), w13 = Read8(in, 52)));
     103       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x9bdc06a7ul), w14 = Read8(in, 56)));
     104       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0xc19bf174ul), w15 = Read8(in, 60)));
     105       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0xe49b69c1ul), Inc(w0, sigma1(w14), w9, sigma0(w1))));
     106       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0xefbe4786ul), Inc(w1, sigma1(w15), w10, sigma0(w2))));
     107       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x0fc19dc6ul), Inc(w2, sigma1(w0), w11, sigma0(w3))));
     108       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x240ca1ccul), Inc(w3, sigma1(w1), w12, sigma0(w4))));
     109       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x2de92c6ful), Inc(w4, sigma1(w2), w13, sigma0(w5))));
     110       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x4a7484aaul), Inc(w5, sigma1(w3), w14, sigma0(w6))));
     111       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x5cb0a9dcul), Inc(w6, sigma1(w4), w15, sigma0(w7))));
     112       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x76f988daul), Inc(w7, sigma1(w5), w0, sigma0(w8))));
     113       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x983e5152ul), Inc(w8, sigma1(w6), w1, sigma0(w9))));
     114       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0xa831c66dul), Inc(w9, sigma1(w7), w2, sigma0(w10))));
     115       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0xb00327c8ul), Inc(w10, sigma1(w8), w3, sigma0(w11))));
     116       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0xbf597fc7ul), Inc(w11, sigma1(w9), w4, sigma0(w12))));
     117       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0xc6e00bf3ul), Inc(w12, sigma1(w10), w5, sigma0(w13))));
     118       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0xd5a79147ul), Inc(w13, sigma1(w11), w6, sigma0(w14))));
     119       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x06ca6351ul), Inc(w14, sigma1(w12), w7, sigma0(w15))));
     120       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x14292967ul), Inc(w15, sigma1(w13), w8, sigma0(w0))));
     121       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x27b70a85ul), Inc(w0, sigma1(w14), w9, sigma0(w1))));
     122       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x2e1b2138ul), Inc(w1, sigma1(w15), w10, sigma0(w2))));
     123       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x4d2c6dfcul), Inc(w2, sigma1(w0), w11, sigma0(w3))));
     124       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x53380d13ul), Inc(w3, sigma1(w1), w12, sigma0(w4))));
     125       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x650a7354ul), Inc(w4, sigma1(w2), w13, sigma0(w5))));
     126       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x766a0abbul), Inc(w5, sigma1(w3), w14, sigma0(w6))));
     127       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x81c2c92eul), Inc(w6, sigma1(w4), w15, sigma0(w7))));
     128       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x92722c85ul), Inc(w7, sigma1(w5), w0, sigma0(w8))));
     129       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0xa2bfe8a1ul), Inc(w8, sigma1(w6), w1, sigma0(w9))));
     130       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0xa81a664bul), Inc(w9, sigma1(w7), w2, sigma0(w10))));
     131       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0xc24b8b70ul), Inc(w10, sigma1(w8), w3, sigma0(w11))));
     132       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0xc76c51a3ul), Inc(w11, sigma1(w9), w4, sigma0(w12))));
     133       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0xd192e819ul), Inc(w12, sigma1(w10), w5, sigma0(w13))));
     134       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0xd6990624ul), Inc(w13, sigma1(w11), w6, sigma0(w14))));
     135       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0xf40e3585ul), Inc(w14, sigma1(w12), w7, sigma0(w15))));
     136       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x106aa070ul), Inc(w15, sigma1(w13), w8, sigma0(w0))));
     137       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x19a4c116ul), Inc(w0, sigma1(w14), w9, sigma0(w1))));
     138       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x1e376c08ul), Inc(w1, sigma1(w15), w10, sigma0(w2))));
     139       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x2748774cul), Inc(w2, sigma1(w0), w11, sigma0(w3))));
     140       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x34b0bcb5ul), Inc(w3, sigma1(w1), w12, sigma0(w4))));
     141       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x391c0cb3ul), Inc(w4, sigma1(w2), w13, sigma0(w5))));
     142       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x4ed8aa4aul), Inc(w5, sigma1(w3), w14, sigma0(w6))));
     143       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x5b9cca4ful), Inc(w6, sigma1(w4), w15, sigma0(w7))));
     144       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x682e6ff3ul), Inc(w7, sigma1(w5), w0, sigma0(w8))));
     145       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x748f82eeul), Inc(w8, sigma1(w6), w1, sigma0(w9))));
     146       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x78a5636ful), Inc(w9, sigma1(w7), w2, sigma0(w10))));
     147       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x84c87814ul), Inc(w10, sigma1(w8), w3, sigma0(w11))));
     148       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x8cc70208ul), Inc(w11, sigma1(w9), w4, sigma0(w12))));
     149       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x90befffaul), Inc(w12, sigma1(w10), w5, sigma0(w13))));
     150       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0xa4506cebul), Inc(w13, sigma1(w11), w6, sigma0(w14))));
     151       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0xbef9a3f7ul), Inc(w14, sigma1(w12), w7, sigma0(w15))));
     152       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0xc67178f2ul), Inc(w15, sigma1(w13), w8, sigma0(w0))));
     153             : 
     154       53755 :     a = Add(a, K(0x6a09e667ul));
     155       53755 :     b = Add(b, K(0xbb67ae85ul));
     156       53755 :     c = Add(c, K(0x3c6ef372ul));
     157       53755 :     d = Add(d, K(0xa54ff53aul));
     158       53755 :     e = Add(e, K(0x510e527ful));
     159       53755 :     f = Add(f, K(0x9b05688cul));
     160       53755 :     g = Add(g, K(0x1f83d9abul));
     161       53755 :     h = Add(h, K(0x5be0cd19ul));
     162             : 
     163       53755 :     __m256i t0 = a, t1 = b, t2 = c, t3 = d, t4 = e, t5 = f, t6 = g, t7 = h;
     164             : 
     165             :     // Transform 2
     166       53755 :     Round(a, b, c, d, e, f, g, h, K(0xc28a2f98ul));
     167       53755 :     Round(h, a, b, c, d, e, f, g, K(0x71374491ul));
     168       53755 :     Round(g, h, a, b, c, d, e, f, K(0xb5c0fbcful));
     169       53755 :     Round(f, g, h, a, b, c, d, e, K(0xe9b5dba5ul));
     170       53755 :     Round(e, f, g, h, a, b, c, d, K(0x3956c25bul));
     171       53755 :     Round(d, e, f, g, h, a, b, c, K(0x59f111f1ul));
     172       53755 :     Round(c, d, e, f, g, h, a, b, K(0x923f82a4ul));
     173       53755 :     Round(b, c, d, e, f, g, h, a, K(0xab1c5ed5ul));
     174       53755 :     Round(a, b, c, d, e, f, g, h, K(0xd807aa98ul));
     175       53755 :     Round(h, a, b, c, d, e, f, g, K(0x12835b01ul));
     176       53755 :     Round(g, h, a, b, c, d, e, f, K(0x243185beul));
     177       53755 :     Round(f, g, h, a, b, c, d, e, K(0x550c7dc3ul));
     178       53755 :     Round(e, f, g, h, a, b, c, d, K(0x72be5d74ul));
     179       53755 :     Round(d, e, f, g, h, a, b, c, K(0x80deb1feul));
     180       53755 :     Round(c, d, e, f, g, h, a, b, K(0x9bdc06a7ul));
     181       53755 :     Round(b, c, d, e, f, g, h, a, K(0xc19bf374ul));
     182       53755 :     Round(a, b, c, d, e, f, g, h, K(0x649b69c1ul));
     183       53755 :     Round(h, a, b, c, d, e, f, g, K(0xf0fe4786ul));
     184       53755 :     Round(g, h, a, b, c, d, e, f, K(0x0fe1edc6ul));
     185       53755 :     Round(f, g, h, a, b, c, d, e, K(0x240cf254ul));
     186       53755 :     Round(e, f, g, h, a, b, c, d, K(0x4fe9346ful));
     187       53755 :     Round(d, e, f, g, h, a, b, c, K(0x6cc984beul));
     188       53755 :     Round(c, d, e, f, g, h, a, b, K(0x61b9411eul));
     189       53755 :     Round(b, c, d, e, f, g, h, a, K(0x16f988faul));
     190       53755 :     Round(a, b, c, d, e, f, g, h, K(0xf2c65152ul));
     191       53755 :     Round(h, a, b, c, d, e, f, g, K(0xa88e5a6dul));
     192       53755 :     Round(g, h, a, b, c, d, e, f, K(0xb019fc65ul));
     193       53755 :     Round(f, g, h, a, b, c, d, e, K(0xb9d99ec7ul));
     194       53755 :     Round(e, f, g, h, a, b, c, d, K(0x9a1231c3ul));
     195       53755 :     Round(d, e, f, g, h, a, b, c, K(0xe70eeaa0ul));
     196       53755 :     Round(c, d, e, f, g, h, a, b, K(0xfdb1232bul));
     197       53755 :     Round(b, c, d, e, f, g, h, a, K(0xc7353eb0ul));
     198       53755 :     Round(a, b, c, d, e, f, g, h, K(0x3069bad5ul));
     199       53755 :     Round(h, a, b, c, d, e, f, g, K(0xcb976d5ful));
     200       53755 :     Round(g, h, a, b, c, d, e, f, K(0x5a0f118ful));
     201       53755 :     Round(f, g, h, a, b, c, d, e, K(0xdc1eeefdul));
     202       53755 :     Round(e, f, g, h, a, b, c, d, K(0x0a35b689ul));
     203       53755 :     Round(d, e, f, g, h, a, b, c, K(0xde0b7a04ul));
     204       53755 :     Round(c, d, e, f, g, h, a, b, K(0x58f4ca9dul));
     205       53755 :     Round(b, c, d, e, f, g, h, a, K(0xe15d5b16ul));
     206       53755 :     Round(a, b, c, d, e, f, g, h, K(0x007f3e86ul));
     207       53755 :     Round(h, a, b, c, d, e, f, g, K(0x37088980ul));
     208       53755 :     Round(g, h, a, b, c, d, e, f, K(0xa507ea32ul));
     209       53755 :     Round(f, g, h, a, b, c, d, e, K(0x6fab9537ul));
     210       53755 :     Round(e, f, g, h, a, b, c, d, K(0x17406110ul));
     211       53755 :     Round(d, e, f, g, h, a, b, c, K(0x0d8cd6f1ul));
     212       53755 :     Round(c, d, e, f, g, h, a, b, K(0xcdaa3b6dul));
     213       53755 :     Round(b, c, d, e, f, g, h, a, K(0xc0bbbe37ul));
     214       53755 :     Round(a, b, c, d, e, f, g, h, K(0x83613bdaul));
     215       53755 :     Round(h, a, b, c, d, e, f, g, K(0xdb48a363ul));
     216       53755 :     Round(g, h, a, b, c, d, e, f, K(0x0b02e931ul));
     217       53755 :     Round(f, g, h, a, b, c, d, e, K(0x6fd15ca7ul));
     218       53755 :     Round(e, f, g, h, a, b, c, d, K(0x521afacaul));
     219       53755 :     Round(d, e, f, g, h, a, b, c, K(0x31338431ul));
     220       53755 :     Round(c, d, e, f, g, h, a, b, K(0x6ed41a95ul));
     221       53755 :     Round(b, c, d, e, f, g, h, a, K(0x6d437890ul));
     222       53755 :     Round(a, b, c, d, e, f, g, h, K(0xc39c91f2ul));
     223       53755 :     Round(h, a, b, c, d, e, f, g, K(0x9eccabbdul));
     224       53755 :     Round(g, h, a, b, c, d, e, f, K(0xb5c9a0e6ul));
     225       53755 :     Round(f, g, h, a, b, c, d, e, K(0x532fb63cul));
     226       53755 :     Round(e, f, g, h, a, b, c, d, K(0xd2c741c6ul));
     227       53755 :     Round(d, e, f, g, h, a, b, c, K(0x07237ea3ul));
     228       53755 :     Round(c, d, e, f, g, h, a, b, K(0xa4954b68ul));
     229       53755 :     Round(b, c, d, e, f, g, h, a, K(0x4c191d76ul));
     230             : 
     231       53755 :     w0 = Add(t0, a);
     232       53755 :     w1 = Add(t1, b);
     233       53755 :     w2 = Add(t2, c);
     234       53755 :     w3 = Add(t3, d);
     235       53755 :     w4 = Add(t4, e);
     236       53755 :     w5 = Add(t5, f);
     237       53755 :     w6 = Add(t6, g);
     238       53755 :     w7 = Add(t7, h);
     239             : 
     240             :     // Transform 3
     241       53755 :     a = K(0x6a09e667ul);
     242       53755 :     b = K(0xbb67ae85ul);
     243       53755 :     c = K(0x3c6ef372ul);
     244       53755 :     d = K(0xa54ff53aul);
     245       53755 :     e = K(0x510e527ful);
     246       53755 :     f = K(0x9b05688cul);
     247       53755 :     g = K(0x1f83d9abul);
     248       53755 :     h = K(0x5be0cd19ul);
     249             : 
     250       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x428a2f98ul), w0));
     251       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x71374491ul), w1));
     252       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0xb5c0fbcful), w2));
     253       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0xe9b5dba5ul), w3));
     254       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x3956c25bul), w4));
     255       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x59f111f1ul), w5));
     256       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x923f82a4ul), w6));
     257       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0xab1c5ed5ul), w7));
     258       53755 :     Round(a, b, c, d, e, f, g, h, K(0x5807aa98ul));
     259       53755 :     Round(h, a, b, c, d, e, f, g, K(0x12835b01ul));
     260       53755 :     Round(g, h, a, b, c, d, e, f, K(0x243185beul));
     261       53755 :     Round(f, g, h, a, b, c, d, e, K(0x550c7dc3ul));
     262       53755 :     Round(e, f, g, h, a, b, c, d, K(0x72be5d74ul));
     263       53755 :     Round(d, e, f, g, h, a, b, c, K(0x80deb1feul));
     264       53755 :     Round(c, d, e, f, g, h, a, b, K(0x9bdc06a7ul));
     265       53755 :     Round(b, c, d, e, f, g, h, a, K(0xc19bf274ul));
     266       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0xe49b69c1ul), Inc(w0, sigma0(w1))));
     267       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0xefbe4786ul), Inc(w1, K(0xa00000ul), sigma0(w2))));
     268       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x0fc19dc6ul), Inc(w2, sigma1(w0), sigma0(w3))));
     269       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x240ca1ccul), Inc(w3, sigma1(w1), sigma0(w4))));
     270       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x2de92c6ful), Inc(w4, sigma1(w2), sigma0(w5))));
     271       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x4a7484aaul), Inc(w5, sigma1(w3), sigma0(w6))));
     272       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x5cb0a9dcul), Inc(w6, sigma1(w4), K(0x100ul), sigma0(w7))));
     273       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x76f988daul), Inc(w7, sigma1(w5), w0, K(0x11002000ul))));
     274       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x983e5152ul), w8 = Add(K(0x80000000ul), sigma1(w6), w1)));
     275       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0xa831c66dul), w9 = Add(sigma1(w7), w2)));
     276       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0xb00327c8ul), w10 = Add(sigma1(w8), w3)));
     277       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0xbf597fc7ul), w11 = Add(sigma1(w9), w4)));
     278       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0xc6e00bf3ul), w12 = Add(sigma1(w10), w5)));
     279       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0xd5a79147ul), w13 = Add(sigma1(w11), w6)));
     280       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x06ca6351ul), w14 = Add(sigma1(w12), w7, K(0x400022ul))));
     281       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x14292967ul), w15 = Add(K(0x100ul), sigma1(w13), w8, sigma0(w0))));
     282       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x27b70a85ul), Inc(w0, sigma1(w14), w9, sigma0(w1))));
     283       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x2e1b2138ul), Inc(w1, sigma1(w15), w10, sigma0(w2))));
     284       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x4d2c6dfcul), Inc(w2, sigma1(w0), w11, sigma0(w3))));
     285       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x53380d13ul), Inc(w3, sigma1(w1), w12, sigma0(w4))));
     286       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x650a7354ul), Inc(w4, sigma1(w2), w13, sigma0(w5))));
     287       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x766a0abbul), Inc(w5, sigma1(w3), w14, sigma0(w6))));
     288       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x81c2c92eul), Inc(w6, sigma1(w4), w15, sigma0(w7))));
     289       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x92722c85ul), Inc(w7, sigma1(w5), w0, sigma0(w8))));
     290       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0xa2bfe8a1ul), Inc(w8, sigma1(w6), w1, sigma0(w9))));
     291       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0xa81a664bul), Inc(w9, sigma1(w7), w2, sigma0(w10))));
     292       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0xc24b8b70ul), Inc(w10, sigma1(w8), w3, sigma0(w11))));
     293       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0xc76c51a3ul), Inc(w11, sigma1(w9), w4, sigma0(w12))));
     294       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0xd192e819ul), Inc(w12, sigma1(w10), w5, sigma0(w13))));
     295       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0xd6990624ul), Inc(w13, sigma1(w11), w6, sigma0(w14))));
     296       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0xf40e3585ul), Inc(w14, sigma1(w12), w7, sigma0(w15))));
     297       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x106aa070ul), Inc(w15, sigma1(w13), w8, sigma0(w0))));
     298       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x19a4c116ul), Inc(w0, sigma1(w14), w9, sigma0(w1))));
     299       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x1e376c08ul), Inc(w1, sigma1(w15), w10, sigma0(w2))));
     300       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x2748774cul), Inc(w2, sigma1(w0), w11, sigma0(w3))));
     301       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x34b0bcb5ul), Inc(w3, sigma1(w1), w12, sigma0(w4))));
     302       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x391c0cb3ul), Inc(w4, sigma1(w2), w13, sigma0(w5))));
     303       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0x4ed8aa4aul), Inc(w5, sigma1(w3), w14, sigma0(w6))));
     304       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0x5b9cca4ful), Inc(w6, sigma1(w4), w15, sigma0(w7))));
     305       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0x682e6ff3ul), Inc(w7, sigma1(w5), w0, sigma0(w8))));
     306       53755 :     Round(a, b, c, d, e, f, g, h, Add(K(0x748f82eeul), Inc(w8, sigma1(w6), w1, sigma0(w9))));
     307       53755 :     Round(h, a, b, c, d, e, f, g, Add(K(0x78a5636ful), Inc(w9, sigma1(w7), w2, sigma0(w10))));
     308       53755 :     Round(g, h, a, b, c, d, e, f, Add(K(0x84c87814ul), Inc(w10, sigma1(w8), w3, sigma0(w11))));
     309       53755 :     Round(f, g, h, a, b, c, d, e, Add(K(0x8cc70208ul), Inc(w11, sigma1(w9), w4, sigma0(w12))));
     310       53755 :     Round(e, f, g, h, a, b, c, d, Add(K(0x90befffaul), Inc(w12, sigma1(w10), w5, sigma0(w13))));
     311       53755 :     Round(d, e, f, g, h, a, b, c, Add(K(0xa4506cebul), Inc(w13, sigma1(w11), w6, sigma0(w14))));
     312       53755 :     Round(c, d, e, f, g, h, a, b, Add(K(0xbef9a3f7ul), w14, sigma1(w12), w7, sigma0(w15)));
     313       53755 :     Round(b, c, d, e, f, g, h, a, Add(K(0xc67178f2ul), w15, sigma1(w13), w8, sigma0(w0)));
     314             : 
     315             :     // Output
     316       53755 :     Write8(out, 0, Add(a, K(0x6a09e667ul)));
     317       53755 :     Write8(out, 4, Add(b, K(0xbb67ae85ul)));
     318       53755 :     Write8(out, 8, Add(c, K(0x3c6ef372ul)));
     319       53755 :     Write8(out, 12, Add(d, K(0xa54ff53aul)));
     320       53755 :     Write8(out, 16, Add(e, K(0x510e527ful)));
     321       53755 :     Write8(out, 20, Add(f, K(0x9b05688cul)));
     322       53755 :     Write8(out, 24, Add(g, K(0x1f83d9abul)));
     323       53755 :     Write8(out, 28, Add(h, K(0x5be0cd19ul)));
     324       53755 : }
     325             : 
     326             : }
     327             : 
     328             : #endif

Generated by: LCOV version 1.15