LCOV - code coverage report
Current view: top level - src - hash.cpp (source / functions) Coverage Total Hit
Test: total_coverage.info Lines: 100.0 % 51 51
Test Date: 2024-11-04 05:10:19 Functions: 100.0 % 4 4
Branches: 100.0 % 6 6

             Branch data     Line data    Source code
       1                 :             : // Copyright (c) 2013-2022 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                 :             : #include <hash.h>
       6                 :             : #include <span.h>
       7                 :             : #include <crypto/common.h>
       8                 :             : #include <crypto/hmac_sha512.h>
       9                 :             : 
      10                 :             : #include <bit>
      11                 :             : #include <string>
      12                 :             : 
      13                 :     7781091 : unsigned int MurmurHash3(unsigned int nHashSeed, Span<const unsigned char> vDataToHash)
      14                 :             : {
      15                 :             :     // The following is MurmurHash3 (x86_32), see https://github.com/aappleby/smhasher/blob/master/src/MurmurHash3.cpp
      16                 :     7781091 :     uint32_t h1 = nHashSeed;
      17                 :     7781091 :     const uint32_t c1 = 0xcc9e2d51;
      18                 :     7781091 :     const uint32_t c2 = 0x1b873593;
      19                 :             : 
      20                 :     7781091 :     const int nblocks = vDataToHash.size() / 4;
      21                 :             : 
      22                 :             :     //----------
      23                 :             :     // body
      24                 :     7781091 :     const uint8_t* blocks = vDataToHash.data();
      25                 :             : 
      26         [ +  + ]:    68926732 :     for (int i = 0; i < nblocks; ++i) {
      27                 :    61145641 :         uint32_t k1 = ReadLE32(blocks + i*4);
      28                 :             : 
      29                 :    61145641 :         k1 *= c1;
      30                 :    61145641 :         k1 = std::rotl(k1, 15);
      31                 :    61145641 :         k1 *= c2;
      32                 :             : 
      33                 :    61145641 :         h1 ^= k1;
      34                 :    61145641 :         h1 = std::rotl(h1, 13);
      35                 :    61145641 :         h1 = h1 * 5 + 0xe6546b64;
      36                 :             :     }
      37                 :             : 
      38                 :             :     //----------
      39                 :             :     // tail
      40                 :     7781091 :     const uint8_t* tail = vDataToHash.data() + nblocks * 4;
      41                 :             : 
      42                 :     7781091 :     uint32_t k1 = 0;
      43                 :             : 
      44   [ +  +  +  + ]:     7781091 :     switch (vDataToHash.size() & 3) {
      45                 :          16 :         case 3:
      46                 :          16 :             k1 ^= tail[2] << 16;
      47                 :      241251 :             [[fallthrough]];
      48                 :      241251 :         case 2:
      49                 :      241251 :             k1 ^= tail[1] << 8;
      50                 :      241606 :             [[fallthrough]];
      51                 :      241606 :         case 1:
      52                 :      241606 :             k1 ^= tail[0];
      53                 :      241606 :             k1 *= c1;
      54                 :      241606 :             k1 = std::rotl(k1, 15);
      55                 :      241606 :             k1 *= c2;
      56                 :      241606 :             h1 ^= k1;
      57                 :             :     }
      58                 :             : 
      59                 :             :     //----------
      60                 :             :     // finalization
      61                 :     7781091 :     h1 ^= vDataToHash.size();
      62                 :     7781091 :     h1 ^= h1 >> 16;
      63                 :     7781091 :     h1 *= 0x85ebca6b;
      64                 :     7781091 :     h1 ^= h1 >> 13;
      65                 :     7781091 :     h1 *= 0xc2b2ae35;
      66                 :     7781091 :     h1 ^= h1 >> 16;
      67                 :             : 
      68                 :     7781091 :     return h1;
      69                 :             : }
      70                 :             : 
      71                 :      778391 : void BIP32Hash(const ChainCode &chainCode, unsigned int nChild, unsigned char header, const unsigned char data[32], unsigned char output[64])
      72                 :             : {
      73                 :      778391 :     unsigned char num[4];
      74                 :      778391 :     WriteBE32(num, nChild);
      75                 :      778391 :     CHMAC_SHA512(chainCode.begin(), chainCode.size()).Write(&header, 1).Write(data, 32).Write(num, 4).Finalize(output);
      76                 :      778391 : }
      77                 :             : 
      78                 :       96378 : uint256 SHA256Uint256(const uint256& input)
      79                 :             : {
      80                 :       96378 :     uint256 result;
      81                 :       96378 :     CSHA256().Write(input.begin(), 32).Finalize(result.begin());
      82                 :       96378 :     return result;
      83                 :             : }
      84                 :             : 
      85                 :        6380 : HashWriter TaggedHash(const std::string& tag)
      86                 :             : {
      87                 :        6380 :     HashWriter writer{};
      88                 :        6380 :     uint256 taghash;
      89                 :        6380 :     CSHA256().Write((const unsigned char*)tag.data(), tag.size()).Finalize(taghash.begin());
      90                 :        6380 :     writer << taghash << taghash;
      91                 :        6380 :     return writer;
      92                 :             : }
        

Generated by: LCOV version 2.0-1