40 lines
1.2 KiB
C

/* SPDX-License-Identifier: GPL-2.0 */
/* Copyright (c) 2020 Rockchip Electronics Co., Ltd. */
#ifndef __RK_CRYPTO_BIGNUM_H__
#define __RK_CRYPTO_BIGNUM_H__
enum bignum_endian {
RK_BG_BIG_ENDIAN,
RK_BG_LITTILE_ENDIAN
};
/**
* struct rk_bignum - crypto bignum struct.
*/
struct rk_bignum {
u32 n_words;
u32 *data;
};
struct rk_ecp_point {
struct rk_bignum *x; /*!< the point's X coordinate */
struct rk_bignum *y; /*!< the point's Y coordinate */
};
struct rk_bignum *rk_bn_alloc(u32 max_size);
void rk_bn_free(struct rk_bignum *bn);
int rk_bn_set_data(struct rk_bignum *bn, const u8 *data, u32 size, enum bignum_endian endian);
int rk_bn_get_data(const struct rk_bignum *bn, u8 *data, u32 size, enum bignum_endian endian);
u32 rk_bn_get_size(const struct rk_bignum *bn);
int rk_bn_highest_bit(const struct rk_bignum *src);
struct rk_ecp_point *rk_ecc_alloc_point_zero(u32 max_size);
struct rk_ecp_point *rk_ecc_alloc_point(const uint8_t *x, uint32_t x_len,
const uint8_t *y, uint32_t y_len,
enum bignum_endian endian, u32 max_size);
void rk_ecc_free_point(struct rk_ecp_point *point);
bool rk_ecp_point_is_zero(struct rk_ecp_point *point);
#endif