Embedded SDK
Embedded SDK
Loading...
Searching...
No Matches
lcx_poly1305.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
34#ifndef LCX_POLY1305_H
35#define LCX_POLY1305_H
36
37#if defined(HAVE_POLY1305)
38
39#include "ox.h"
40#include <stddef.h>
41
45typedef struct {
46 uint32_t r[4];
47 uint32_t s[4];
48 uint32_t acc[5];
49 uint8_t block[16];
50 size_t block_len;
51} cx_poly1305_context_t;
52
67void cx_poly1305_init(cx_poly1305_context_t *ctx);
68
81void cx_poly1305_set_key(cx_poly1305_context_t *ctx, const uint8_t *key);
82
100WARN_UNUSED_RESULT cx_err_t cx_poly1305_update(cx_poly1305_context_t *ctx,
101 const uint8_t *input,
102 size_t in_len);
103
116WARN_UNUSED_RESULT cx_err_t cx_poly1305_finish(cx_poly1305_context_t *ctx, uint8_t *tag);
117
137WARN_UNUSED_RESULT cx_err_t cx_poly1305_mac(const uint8_t *key,
138 const uint8_t *input,
139 size_t in_len,
140 uint8_t *tag);
141
142#endif // HAVE_POLY1305
143
144#endif // LCX_POLY1305_H