Embedded SDK
Embedded SDK
Loading...
Searching...
No Matches
cx_blake2b.h
Go to the documentation of this file.
1
2/*******************************************************************************
3 * Ledger Nano S - Secure firmware
4 * (c) 2022 Ledger
5 *
6 * Licensed under the Apache License, Version 2.0 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
9 *
10 * http://www.apache.org/licenses/LICENSE-2.0
11 *
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
17 ********************************************************************************/
18
19#ifndef CX_BLAKE2B_H
20#define CX_BLAKE2B_H
21
22#ifdef HAVE_BLAKE2
23
24#include "lcx_wrappers.h"
25#include "lcx_blake2.h"
26#include <stdbool.h>
27#include <stddef.h>
28
29extern const cx_hash_info_t cx_blake2b_info;
30
31WARN_UNUSED_RESULT cx_err_t cx_blake2b_update(cx_blake2b_t *ctx, const uint8_t *data, size_t len);
32// No need to add WARN_UNUSED_RESULT to cx_blake2b_final(), it always returns CX_OK
33cx_err_t cx_blake2b_final(cx_blake2b_t *ctx, uint8_t *digest);
34size_t cx_blake2b_get_output_size(const cx_blake2b_t *ctx);
35
36struct cx_xblake_s {
37 cx_blake2b_t blake2b;
38 uint64_t m[16];
39 uint64_t v[16];
40 uint8_t buffer[BLAKE2B_OUTBYTES];
41 uint8_t block1[BLAKE2B_BLOCKBYTES];
42};
43typedef struct cx_xblake_s cx_xblake_t;
44
45#endif // HAVE_BLAKE2
46
47#endif // CX_BLAKE2B_H
BLAKE2 crypographic hash function.
unsigned char uint8_t
Definition usbd_conf.h:53