19#include "hitls_build.h"
20#ifdef HITLS_CRYPTO_SM4
25#include "crypt_types.h"
26#include "crypt_local_types.h"
32#define CRYPT_SM4_BLOCKSIZE 16
33#define CRYPT_SM4_BLOCKSIZE_16 256
34#define CRYPT_SM4_ROUNDS 32
37 uint8_t iv[CRYPT_SM4_BLOCKSIZE];
38 uint32_t rk[CRYPT_SM4_ROUNDS];
50int32_t CRYPT_SM4_SetKey(CRYPT_SM4_Ctx *ctx,
const uint8_t *key, uint32_t keyLen);
62int32_t CRYPT_SM4_Encrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t length);
74int32_t CRYPT_SM4_Decrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t length);
81void CRYPT_SM4_Clean(CRYPT_SM4_Ctx *ctx);
83#ifdef HITLS_CRYPTO_XTS
95int32_t CRYPT_SM4_XTS_SetEncryptKey(CRYPT_SM4_Ctx *ctx,
const uint8_t *key, uint32_t len);
106int32_t CRYPT_SM4_XTS_SetDecryptKey(CRYPT_SM4_Ctx *ctx,
const uint8_t *key, uint32_t len);
113void CRYPT_SM4_XTS_Clean(CRYPT_SM4_Ctx *ctx);
127int32_t CRYPT_SM4_XTS_Decrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv);
141int32_t CRYPT_SM4_XTS_Encrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv);
153int32_t CRYPT_SM4_SetEncryptKey(CRYPT_SM4_Ctx *ctx,
const uint8_t *key, uint32_t len);
164int32_t CRYPT_SM4_SetDecryptKey(CRYPT_SM4_Ctx *ctx,
const uint8_t *key, uint32_t len);
166#ifdef HITLS_CRYPTO_ECB
177int32_t CRYPT_SM4_ECB_Encrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len);
189int32_t CRYPT_SM4_ECB_Decrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len);
192#ifdef HITLS_CRYPTO_CBC
204int32_t CRYPT_SM4_CBC_Encrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv);
217int32_t CRYPT_SM4_CBC_Decrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv);
220#if defined(HITLS_CRYPTO_CTR) || defined(HITLS_CRYPTO_GCM)
232int32_t CRYPT_SM4_CTR_Encrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv);
245int32_t CRYPT_SM4_CTR_Decrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv);
248#ifdef HITLS_CRYPTO_OFB
261int32_t CRYPT_SM4_OFB_Encrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv, uint8_t *offset);
275int32_t CRYPT_SM4_OFB_Decrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv, uint8_t *offset);
278#ifdef HITLS_CRYPTO_CFB
291int32_t CRYPT_SM4_CFB_Encrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv, uint8_t *offset);
305int32_t CRYPT_SM4_CFB_Decrypt(CRYPT_SM4_Ctx *ctx,
const uint8_t *in, uint8_t *out, uint32_t len, uint8_t *iv, uint8_t *offset);