Bitcoin ABC 0.26.3
P2P Digital Currency
Loading...
Searching...
No Matches
Macros | Functions
hash_impl.h File Reference
#include "hash.h"
#include "util.h"
#include <stdlib.h>
#include <stdint.h>
#include <string.h>
Include dependency graph for hash_impl.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Macros

#define Ch(x, y, z)   ((z) ^ ((x) & ((y) ^ (z))))
 
#define Maj(x, y, z)   (((x) & (y)) | ((z) & ((x) | (y))))
 
#define Sigma0(x)   (((x) >> 2 | (x) << 30) ^ ((x) >> 13 | (x) << 19) ^ ((x) >> 22 | (x) << 10))
 
#define Sigma1(x)   (((x) >> 6 | (x) << 26) ^ ((x) >> 11 | (x) << 21) ^ ((x) >> 25 | (x) << 7))
 
#define sigma0(x)   (((x) >> 7 | (x) << 25) ^ ((x) >> 18 | (x) << 14) ^ ((x) >> 3))
 
#define sigma1(x)   (((x) >> 17 | (x) << 15) ^ ((x) >> 19 | (x) << 13) ^ ((x) >> 10))
 
#define Round(a, b, c, d, e, f, g, h, k, w)
 

Functions

static void secp256k1_sha256_initialize (secp256k1_sha256 *hash)
 
static void secp256k1_sha256_transform (uint32_t *s, const uint32_t *chunk)
 Perform one SHA-256 transformation, processing 16 big endian 32-bit words.
 
static void secp256k1_sha256_write (secp256k1_sha256 *hash, const unsigned char *data, size_t len)
 
static void secp256k1_sha256_finalize (secp256k1_sha256 *hash, unsigned char *out32)
 
static void secp256k1_sha256_initialize_tagged (secp256k1_sha256 *hash, const unsigned char *tag, size_t taglen)
 
static void secp256k1_hmac_sha256_initialize (secp256k1_hmac_sha256 *hash, const unsigned char *key, size_t keylen)
 
static void secp256k1_hmac_sha256_write (secp256k1_hmac_sha256 *hash, const unsigned char *data, size_t size)
 
static void secp256k1_hmac_sha256_finalize (secp256k1_hmac_sha256 *hash, unsigned char *out32)
 
static void secp256k1_rfc6979_hmac_sha256_initialize (secp256k1_rfc6979_hmac_sha256 *rng, const unsigned char *key, size_t keylen)
 
static void secp256k1_rfc6979_hmac_sha256_generate (secp256k1_rfc6979_hmac_sha256 *rng, unsigned char *out, size_t outlen)
 
static void secp256k1_rfc6979_hmac_sha256_finalize (secp256k1_rfc6979_hmac_sha256 *rng)
 

Macro Definition Documentation

◆ Ch

#define Ch (   x,
  y,
 
)    ((z) ^ ((x) & ((y) ^ (z))))

Definition at line 17 of file hash_impl.h.

◆ Maj

#define Maj (   x,
  y,
 
)    (((x) & (y)) | ((z) & ((x) | (y))))

Definition at line 18 of file hash_impl.h.

◆ Round

#define Round (   a,
  b,
  c,
  d,
  e,
  f,
  g,
  h,
  k,
 
)
Value:
do { \
uint32_t t1 = (h) + Sigma1(e) + Ch((e), (f), (g)) + (k) + (w); \
uint32_t t2 = Sigma0(a) + Maj((a), (b), (c)); \
(d) += t1; \
(h) = t1 + t2; \
} while(0)
#define Maj(x, y, z)
Definition hash_impl.h:18
#define Sigma0(x)
Definition hash_impl.h:19
#define Sigma1(x)
Definition hash_impl.h:20
#define Ch(x, y, z)
Definition hash_impl.h:17
T GetRand(T nMax=std::numeric_limits< T >::max()) noexcept
Generate a uniform random integer of type T in the range [0..nMax) nMax defaults to std::numeric_limi...
Definition random.h:85

Definition at line 24 of file hash_impl.h.

◆ Sigma0

#define Sigma0 (   x)    (((x) >> 2 | (x) << 30) ^ ((x) >> 13 | (x) << 19) ^ ((x) >> 22 | (x) << 10))

Definition at line 19 of file hash_impl.h.

◆ sigma0

#define sigma0 (   x)    (((x) >> 7 | (x) << 25) ^ ((x) >> 18 | (x) << 14) ^ ((x) >> 3))

Definition at line 21 of file hash_impl.h.

◆ Sigma1

#define Sigma1 (   x)    (((x) >> 6 | (x) << 26) ^ ((x) >> 11 | (x) << 21) ^ ((x) >> 25 | (x) << 7))

Definition at line 20 of file hash_impl.h.

◆ sigma1

#define sigma1 (   x)    (((x) >> 17 | (x) << 15) ^ ((x) >> 19 | (x) << 13) ^ ((x) >> 10))

Definition at line 22 of file hash_impl.h.

Function Documentation

◆ secp256k1_hmac_sha256_finalize()

static void secp256k1_hmac_sha256_finalize ( secp256k1_hmac_sha256 hash,
unsigned char out32 
)
static

Definition at line 212 of file hash_impl.h.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ secp256k1_hmac_sha256_initialize()

static void secp256k1_hmac_sha256_initialize ( secp256k1_hmac_sha256 hash,
const unsigned char key,
size_t  keylen 
)
static

Definition at line 180 of file hash_impl.h.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ secp256k1_hmac_sha256_write()

static void secp256k1_hmac_sha256_write ( secp256k1_hmac_sha256 hash,
const unsigned char data,
size_t  size 
)
static

Definition at line 208 of file hash_impl.h.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ secp256k1_rfc6979_hmac_sha256_finalize()

static void secp256k1_rfc6979_hmac_sha256_finalize ( secp256k1_rfc6979_hmac_sha256 rng)
static

Definition at line 282 of file hash_impl.h.

Here is the call graph for this function:

◆ secp256k1_rfc6979_hmac_sha256_generate()

static void secp256k1_rfc6979_hmac_sha256_generate ( secp256k1_rfc6979_hmac_sha256 rng,
unsigned char out,
size_t  outlen 
)
static

Definition at line 251 of file hash_impl.h.

Here is the call graph for this function:

◆ secp256k1_rfc6979_hmac_sha256_initialize()

static void secp256k1_rfc6979_hmac_sha256_initialize ( secp256k1_rfc6979_hmac_sha256 rng,
const unsigned char key,
size_t  keylen 
)
static

Definition at line 221 of file hash_impl.h.

Here is the call graph for this function:

◆ secp256k1_sha256_finalize()

static void secp256k1_sha256_finalize ( secp256k1_sha256 hash,
unsigned char out32 
)
static

Definition at line 151 of file hash_impl.h.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ secp256k1_sha256_initialize()

static void secp256k1_sha256_initialize ( secp256k1_sha256 hash)
static

Definition at line 37 of file hash_impl.h.

Here is the caller graph for this function:

◆ secp256k1_sha256_initialize_tagged()

static void secp256k1_sha256_initialize_tagged ( secp256k1_sha256 hash,
const unsigned char tag,
size_t  taglen 
)
static

Definition at line 169 of file hash_impl.h.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ secp256k1_sha256_transform()

static void secp256k1_sha256_transform ( uint32_t s,
const uint32_t chunk 
)
static

Perform one SHA-256 transformation, processing 16 big endian 32-bit words.

Definition at line 50 of file hash_impl.h.

Here is the call graph for this function:
Here is the caller graph for this function:

◆ secp256k1_sha256_write()

static void secp256k1_sha256_write ( secp256k1_sha256 hash,
const unsigned char data,
size_t  len 
)
static

Definition at line 132 of file hash_impl.h.

Here is the call graph for this function:
Here is the caller graph for this function: