ecf2d82159
* Synchronize the code of the rt mart branch to the master branch. * TTY device * Add lwP code from rt-smart * Add vnode in DFS, but DFS will be re-write for rt-smart * There are three libcpu for rt-smart: * arm/cortex-a, arm/aarch64 * riscv64 Co-authored-by: Rbb666 <zhangbingru@rt-thread.com> Co-authored-by: zhkag <zhkag@foxmail.com>
108 lines
2.5 KiB
C
108 lines
2.5 KiB
C
#ifndef SUNXI_HAL_TWI_H
|
|
#define SUNXI_HAL_TWI_H
|
|
|
|
#include "hal_sem.h"
|
|
#include "hal_clk.h"
|
|
#include "sunxi_hal_common.h"
|
|
#include "hal_gpio.h"
|
|
#include "sunxi_hal_regulator.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#define CE_ALIGN_SIZE (0x4)
|
|
#define CE_ROUND_UP(x,y) ((((x) + ((y) - 1)) / (y)) * (y))
|
|
|
|
#define AES_KEYSIZE_128 128
|
|
#define AES_KEYSIZE_192 192
|
|
#define AES_KEYSIZE_256 256
|
|
|
|
#define AES_BLOCK_SIZE (16)
|
|
|
|
/*define the ctx for aes requtest*/
|
|
typedef struct {
|
|
uint8_t *src_buffer;
|
|
uint32_t src_length;
|
|
uint8_t *dst_buffer;
|
|
uint32_t dst_length;
|
|
uint8_t *iv;
|
|
uint8_t *iv_next;
|
|
uint8_t *key;
|
|
uint32_t key_length;
|
|
uint8_t padding[AES_BLOCK_SIZE];
|
|
uint32_t padding_len;
|
|
uint32_t dir;
|
|
uint32_t mode;
|
|
uint32_t bitwidth;
|
|
} crypto_aes_req_ctx_t;
|
|
|
|
/*define the ctx for hash requtest*/
|
|
#define SHA_MAX_DIGEST_SIZE (64)
|
|
#define MD5_DIGEST_SIZE (16)
|
|
#define SHA1_DIGEST_SIZE (20)
|
|
#define SHA224_DIGEST_SIZE (28)
|
|
#define SHA256_DIGEST_SIZE (32)
|
|
#define SHA384_DIGEST_SIZE (48)
|
|
#define SHA512_DIGEST_SIZE (64)
|
|
|
|
#define MD5_BLOCK_SIZE (64)
|
|
#define SHA1_BLOCK_SIZE (64)
|
|
#define SHA224_BLOCK_SIZE (64)
|
|
#define SHA256_BLOCK_SIZE (64)
|
|
#define SHA384_BLOCK_SIZE (128)
|
|
#define SHA512_BLOCK_SIZE (128)
|
|
|
|
typedef struct {
|
|
uint8_t *src_buffer;
|
|
uint32_t src_length;
|
|
uint8_t *dst_buffer;
|
|
uint32_t dst_length;
|
|
uint8_t md[SHA_MAX_DIGEST_SIZE];
|
|
uint32_t md_size;
|
|
uint8_t padding[SHA512_BLOCK_SIZE * 2];
|
|
uint32_t padding_len;
|
|
uint32_t type;
|
|
uint32_t dir;
|
|
uint32_t padding_mode;
|
|
} crypto_hash_req_ctx_t;
|
|
|
|
typedef struct {
|
|
uint8_t *rng_buf;
|
|
uint32_t rng_len;
|
|
uint32_t mode;
|
|
uint8_t *key;
|
|
uint32_t key_len;
|
|
} crypto_rng_req_ctx_t;
|
|
|
|
/*define the ctx for rsa requtest*/
|
|
typedef struct {
|
|
uint8_t *key_n;
|
|
uint32_t n_len;
|
|
uint8_t *key_e;
|
|
uint32_t e_len;
|
|
uint8_t *key_d;
|
|
uint32_t d_len;
|
|
uint8_t *src_buffer;
|
|
uint32_t src_length;
|
|
uint8_t *dst_buffer;
|
|
uint32_t dst_length;
|
|
uint32_t dir;
|
|
uint32_t type;
|
|
uint32_t bitwidth;
|
|
} crypto_rsa_req_ctx_t;
|
|
|
|
int do_aes_crypto(crypto_aes_req_ctx_t *req_ctx);
|
|
int sunxi_ce_init(void);
|
|
int sunxi_ce_uninit(void);
|
|
int do_hash_crypto(crypto_hash_req_ctx_t *req_ctx);
|
|
int do_rsa_crypto(crypto_rsa_req_ctx_t *req_ctx);
|
|
int do_rsa_crypto_new(crypto_rsa_req_ctx_t *req_ctx);
|
|
int do_rng_gen(crypto_rng_req_ctx_t *req_ctx);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif
|