1 /*===-- llvm-c/blake3.h - BLAKE3 C Interface ----------------------*- C -*-===*\
3 |* Released into the public domain with CC0 1.0 *|
4 |* See 'llvm/lib/Support/BLAKE3/LICENSE' for info. *|
5 |* SPDX-License-Identifier: CC0-1.0 *|
7 |*===----------------------------------------------------------------------===*|
9 |* This header declares the C interface to LLVM's BLAKE3 implementation. *|
10 |* Original BLAKE3 C API: https://github.com/BLAKE3-team/BLAKE3/tree/1.3.1/c *|
12 |* Symbols are prefixed with 'llvm' to avoid a potential conflict with *|
13 |* another BLAKE3 version within the same program. *|
15 \*===----------------------------------------------------------------------===*/
17 #ifndef LLVM_C_BLAKE3_H
18 #define LLVM_C_BLAKE3_H
27 #define LLVM_BLAKE3_VERSION_STRING "1.3.1"
28 #define LLVM_BLAKE3_KEY_LEN 32
29 #define LLVM_BLAKE3_OUT_LEN 32
30 #define LLVM_BLAKE3_BLOCK_LEN 64
31 #define LLVM_BLAKE3_CHUNK_LEN 1024
32 #define LLVM_BLAKE3_MAX_DEPTH 54
34 // This struct is a private implementation detail. It has to be here because
35 // it's part of llvm_blake3_hasher below.
38 uint64_t chunk_counter
;
39 uint8_t buf
[LLVM_BLAKE3_BLOCK_LEN
];
41 uint8_t blocks_compressed
;
43 } llvm_blake3_chunk_state
;
47 llvm_blake3_chunk_state chunk
;
49 // The stack size is MAX_DEPTH + 1 because we do lazy merging. For example,
50 // with 7 chunks, we have 3 entries in the stack. Adding an 8th chunk
51 // requires a 4th entry, rather than merging everything down to 1, because we
52 // don't know whether more input is coming. This is different from how the
53 // reference implementation does things.
54 uint8_t cv_stack
[(LLVM_BLAKE3_MAX_DEPTH
+ 1) * LLVM_BLAKE3_OUT_LEN
];
57 const char *llvm_blake3_version(void);
58 void llvm_blake3_hasher_init(llvm_blake3_hasher
*self
);
59 void llvm_blake3_hasher_init_keyed(llvm_blake3_hasher
*self
,
60 const uint8_t key
[LLVM_BLAKE3_KEY_LEN
]);
61 void llvm_blake3_hasher_init_derive_key(llvm_blake3_hasher
*self
,
63 void llvm_blake3_hasher_init_derive_key_raw(llvm_blake3_hasher
*self
,
66 void llvm_blake3_hasher_update(llvm_blake3_hasher
*self
, const void *input
,
68 void llvm_blake3_hasher_finalize(const llvm_blake3_hasher
*self
, uint8_t *out
,
70 void llvm_blake3_hasher_finalize_seek(const llvm_blake3_hasher
*self
,
71 uint64_t seek
, uint8_t *out
,
73 void llvm_blake3_hasher_reset(llvm_blake3_hasher
*self
);
79 #endif /* LLVM_C_BLAKE3_H */