Project Alice
Loading...
Searching...
No Matches
blake3.h
Go to the documentation of this file.
1/*===-- llvm-c/blake3.h - BLAKE3 C Interface ----------------------*- C -*-===*\
2|* *|
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 *|
6|* *|
7|*===----------------------------------------------------------------------===*|
8|* *|
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 *|
11|* *|
12|* Symbols are prefixed with 'llvm' to avoid a potential conflict with *|
13|* another BLAKE3 version within the same program. *|
14|* *|
15\*===----------------------------------------------------------------------===*/
16
17#ifndef LLVM_C_BLAKE3_H
18#define LLVM_C_BLAKE3_H
19
20#include <stddef.h>
21#include <stdint.h>
22
23#ifdef __cplusplus
24extern "C" {
25#endif
26
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
33
34// This struct is a private implementation detail. It has to be here because
35// it's part of llvm_blake3_hasher below.
36typedef struct {
37 uint32_t cv[8];
44
45typedef struct {
46 uint32_t key[8];
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.
56
57const char *llvm_blake3_version(void);
60 const uint8_t key[LLVM_BLAKE3_KEY_LEN]);
62 const char *context);
64 const void *context,
65 size_t context_len);
66void llvm_blake3_hasher_update(llvm_blake3_hasher *self, const void *input,
67 size_t input_len);
69 size_t out_len);
71 uint64_t seek, uint8_t *out,
72 size_t out_len);
74
75#ifdef __cplusplus
76}
77#endif
78
79#endif /* LLVM_C_BLAKE3_H */
void llvm_blake3_hasher_finalize(const llvm_blake3_hasher *self, uint8_t *out, size_t out_len)
void llvm_blake3_hasher_reset(llvm_blake3_hasher *self)
#define LLVM_BLAKE3_BLOCK_LEN
Definition: blake3.h:30
void llvm_blake3_hasher_update(llvm_blake3_hasher *self, const void *input, size_t input_len)
void llvm_blake3_hasher_init(llvm_blake3_hasher *self)
#define LLVM_BLAKE3_OUT_LEN
Definition: blake3.h:29
void llvm_blake3_hasher_init_keyed(llvm_blake3_hasher *self, const uint8_t key[LLVM_BLAKE3_KEY_LEN])
#define LLVM_BLAKE3_MAX_DEPTH
Definition: blake3.h:32
const char * llvm_blake3_version(void)
#define LLVM_BLAKE3_KEY_LEN
Definition: blake3.h:28
void llvm_blake3_hasher_init_derive_key(llvm_blake3_hasher *self, const char *context)
void llvm_blake3_hasher_finalize_seek(const llvm_blake3_hasher *self, uint64_t seek, uint8_t *out, size_t out_len)
void llvm_blake3_hasher_init_derive_key_raw(llvm_blake3_hasher *self, const void *context, size_t context_len)
uint uint32_t
ulong uint64_t
uchar uint8_t
uint64_t chunk_counter
Definition: blake3.h:38
uint8_t blocks_compressed
Definition: blake3.h:41
uint8_t cv_stack_len
Definition: blake3.h:48
llvm_blake3_chunk_state chunk
Definition: blake3.h:47