guo ecf2d82159
sync branch rt-smart. (#6641)
* 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>
2022-12-03 12:07:44 +08:00

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