API参考
载入中...
搜索中...
未找到
ecp_nistp256.h
1/*
2 * This file is part of the openHiTLS project.
3 *
4 * openHiTLS is licensed under the Mulan PSL v2.
5 * You can use this software according to the terms and conditions of the Mulan PSL v2.
6 * You may obtain a copy of Mulan PSL v2 at:
7 *
8 * http://license.coscl.org.cn/MulanPSL2
9 *
10 * THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
11 * EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
12 * MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
13 * See the Mulan PSL v2 for more details.
14 */
15
16#ifndef ECP_NISTP256_H
17#define ECP_NISTP256_H
18
19#include "hitls_build.h"
20#if defined(HITLS_CRYPTO_CURVE_NISTP256) && defined(HITLS_CRYPTO_NIST_ECC_ACCELERATE)
21
22#include "ecc_local.h"
23
24#ifdef __cplusplus
25extern "C" {
26#endif
27
38int32_t ECP256_Point2Affine(const ECC_Para *para, ECC_Point *r, const ECC_Point *pt);
39
52int32_t ECP256_PointMulAdd(ECC_Para *para, ECC_Point *r,
53 const BN_BigNum *k1, const BN_BigNum *k2, const ECC_Point *pt);
54
66int32_t ECP256_PointMul(ECC_Para *para, ECC_Point *r, const BN_BigNum *k, const ECC_Point *pt);
67
78int32_t ECP256_ModOrderInv(const ECC_Para *para, BN_BigNum *r, const BN_BigNum *a);
79
80#ifdef __cplusplus
81}
82#endif
83
84#endif /* defined(HITLS_CRYPTO_CURVE_NISTP256) */
85
86#endif