diff options
Diffstat (limited to 'src/lib/libcrypto/ec/ec_internal.h')
-rw-r--r-- | src/lib/libcrypto/ec/ec_internal.h | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/src/lib/libcrypto/ec/ec_internal.h b/src/lib/libcrypto/ec/ec_internal.h new file mode 100644 index 0000000000..327d9ea94d --- /dev/null +++ b/src/lib/libcrypto/ec/ec_internal.h | |||
@@ -0,0 +1,65 @@ | |||
1 | /* $OpenBSD: ec_internal.h,v 1.2 2025/08/02 15:44:09 jsing Exp $ */ | ||
2 | /* | ||
3 | * Copyright (c) 2024 Joel Sing <jsing@openbsd.org> | ||
4 | * | ||
5 | * Permission to use, copy, modify, and distribute this software for any | ||
6 | * purpose with or without fee is hereby granted, provided that the above | ||
7 | * copyright notice and this permission notice appear in all copies. | ||
8 | * | ||
9 | * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES | ||
10 | * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF | ||
11 | * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR | ||
12 | * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES | ||
13 | * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN | ||
14 | * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||
15 | * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||
16 | */ | ||
17 | |||
18 | #include <openssl/bn.h> | ||
19 | |||
20 | #ifndef HEADER_EC_INTERNAL_H | ||
21 | #define HEADER_EC_INTERNAL_H | ||
22 | |||
23 | #define EC_FIELD_ELEMENT_MAX_BITS 521 | ||
24 | #define EC_FIELD_ELEMENT_MAX_BYTES \ | ||
25 | (EC_FIELD_ELEMENT_MAX_BITS + 7) / 8 | ||
26 | #define EC_FIELD_ELEMENT_MAX_WORDS \ | ||
27 | ((EC_FIELD_ELEMENT_MAX_BYTES + BN_BYTES - 1) / BN_BYTES) | ||
28 | |||
29 | typedef struct { | ||
30 | BN_ULONG w[EC_FIELD_ELEMENT_MAX_WORDS]; | ||
31 | } EC_FIELD_ELEMENT; | ||
32 | |||
33 | typedef struct { | ||
34 | size_t n; | ||
35 | EC_FIELD_ELEMENT m; | ||
36 | EC_FIELD_ELEMENT rr; | ||
37 | BN_ULONG minv0; | ||
38 | } EC_FIELD_MODULUS; | ||
39 | |||
40 | int ec_field_modulus_from_bn(EC_FIELD_MODULUS *fm, const BIGNUM *bn, | ||
41 | BN_CTX *ctx); | ||
42 | |||
43 | int ec_field_element_from_bn(const EC_FIELD_MODULUS *fm, const EC_GROUP *group, | ||
44 | EC_FIELD_ELEMENT *fe, const BIGNUM *bn, BN_CTX *ctx); | ||
45 | int ec_field_element_to_bn(const EC_FIELD_MODULUS *fm, const EC_FIELD_ELEMENT *fe, | ||
46 | BIGNUM *bn, BN_CTX *ctx); | ||
47 | |||
48 | void ec_field_element_copy(EC_FIELD_ELEMENT *dst, const EC_FIELD_ELEMENT *src); | ||
49 | void ec_field_element_select(const EC_FIELD_MODULUS *fm, EC_FIELD_ELEMENT *r, | ||
50 | const EC_FIELD_ELEMENT *a, const EC_FIELD_ELEMENT *b, int conditional); | ||
51 | |||
52 | int ec_field_element_equal(const EC_FIELD_MODULUS *fm, const EC_FIELD_ELEMENT *a, | ||
53 | const EC_FIELD_ELEMENT *b); | ||
54 | int ec_field_element_is_zero(const EC_FIELD_MODULUS *fm, const EC_FIELD_ELEMENT *fe); | ||
55 | |||
56 | void ec_field_element_add(const EC_FIELD_MODULUS *m, EC_FIELD_ELEMENT *r, | ||
57 | const EC_FIELD_ELEMENT *a, const EC_FIELD_ELEMENT *b); | ||
58 | void ec_field_element_sub(const EC_FIELD_MODULUS *m, EC_FIELD_ELEMENT *r, | ||
59 | const EC_FIELD_ELEMENT *a, const EC_FIELD_ELEMENT *b); | ||
60 | void ec_field_element_mul(const EC_FIELD_MODULUS *m, EC_FIELD_ELEMENT *r, | ||
61 | const EC_FIELD_ELEMENT *a, const EC_FIELD_ELEMENT *b); | ||
62 | void ec_field_element_sqr(const EC_FIELD_MODULUS *m, EC_FIELD_ELEMENT *r, | ||
63 | const EC_FIELD_ELEMENT *a); | ||
64 | |||
65 | #endif | ||