Embedded SDK
Embedded SDK
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 
29 extern const cx_hash_info_t cx_blake2b_info;
30 
31 WARN_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
33 cx_err_t cx_blake2b_final(cx_blake2b_t *ctx, uint8_t *digest);
34 size_t cx_blake2b_get_output_size(const cx_blake2b_t *ctx);
35 
36 struct 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 };
43 typedef 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