LCOV - code coverage report
Current view: top level - src/crypto - hkdf_sha256_32.cpp (source / functions) Coverage Total Hit
Test: fuzz_coverage.info Lines: 100.0 % 8 8
Test Date: 2024-12-04 04:00:22 Functions: 100.0 % 2 2
Branches: 50.0 % 2 1

             Branch data     Line data    Source code
       1                 :             : // Copyright (c) 2018-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                 :             : #include <crypto/hkdf_sha256_32.h>
       6                 :             : 
       7                 :             : #include <assert.h>
       8                 :             : #include <string.h>
       9                 :             : 
      10                 :        2498 : CHKDF_HMAC_SHA256_L32::CHKDF_HMAC_SHA256_L32(const unsigned char* ikm, size_t ikmlen, const std::string& salt)
      11                 :             : {
      12                 :        2498 :     CHMAC_SHA256((const unsigned char*)salt.data(), salt.size()).Write(ikm, ikmlen).Finalize(m_prk);
      13                 :        2498 : }
      14                 :             : 
      15                 :       82877 : void CHKDF_HMAC_SHA256_L32::Expand32(const std::string& info, unsigned char hash[OUTPUT_SIZE])
      16                 :             : {
      17                 :             :     // expand a 32byte key (single round)
      18         [ -  + ]:       82877 :     assert(info.size() <= 128);
      19                 :       82877 :     static const unsigned char one[1] = {1};
      20                 :       82877 :     CHMAC_SHA256(m_prk, 32).Write((const unsigned char*)info.data(), info.size()).Write(one, 1).Finalize(hash);
      21                 :       82877 : }
        

Generated by: LCOV version 2.0-1