/*
 * Copyright (c) 2018 naehrwert
 * Copyright (c) 2018-2021 CTCaer
 *
 * This program is free software; you can redistribute it and/or modify it
 * under the terms and conditions of the GNU General Public License,
 * version 2, as published by the Free Software Foundation.
 *
 * This program is distributed in the hope it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
 * more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 */

#ifndef _SE_T210_H
#define _SE_T210_H

#include <utils/types.h>

#define SE_CRYPTO_QUEUE_LENGTH 50
#define SE_MAX_SRC_SG_COUNT    50
#define SE_MAX_DST_SG_COUNT    50

#define SE_AES_KEYSLOT_COUNT   16
#define SE_RSA_KEYSLOT_COUNT   2
#define SE_MAX_LAST_BLOCK_SIZE 0xFFFFF

#define SE_AES_BLOCK_SIZE   16
#define SE_AES_IV_SIZE      16
#define SE_AES_MIN_KEY_SIZE 16
#define SE_AES_MAX_KEY_SIZE 32
#define SE_KEY_128_SIZE     16
#define SE_KEY_192_SIZE     24
#define SE_KEY_256_SIZE     32
#define SE_SHA_192_SIZE     24
#define SE_SHA_256_SIZE     32
#define SE_SHA_384_SIZE     48
#define SE_SHA_512_SIZE     64
#define SE_RNG_IV_SIZE		16
#define SE_RNG_DT_SIZE		16
#define SE_RNG_KEY_SIZE		16
#define SE_RNG_SEED_SIZE (SE_RNG_IV_SIZE + SE_RNG_KEY_SIZE + SE_RNG_DT_SIZE)

#define SE_AES_CMAC_DIGEST_SIZE 16
#define SE_RSA512_DIGEST_SIZE   64
#define SE_RSA1024_DIGEST_SIZE  128
#define SE_RSA1536_DIGEST_SIZE  192
#define SE_RSA2048_DIGEST_SIZE  256

#define  DECRYPT   0
#define  ENCRYPT   1

/* SE register definitions */
#define SE_SE_SECURITY_REG 0x000
#define  SE_HARD_SETTING   BIT(0)
#define  SE_ENG_DIS        BIT(1)
#define  SE_PERKEY_SETTING BIT(2)
#define  SE_SOFT_SETTING   BIT(16)

#define SE_TZRAM_SECURITY_REG 0x004
#define  SE_TZRAM_HARD_SETTING BIT(0)
#define  SE_TZRAM_ENG_DIS      BIT(1)

#define SE_OPERATION_REG 0x008
#define  SE_OP_ABORT       0
#define  SE_OP_START       1
#define  SE_OP_RESTART_OUT 2
#define  SE_OP_CTX_SAVE    3
#define  SE_OP_RESTART_IN  4

#define SE_INT_ENABLE_REG	0x00C
#define SE_INT_STATUS_REG	0x010
#define  SE_INT_IN_LL_BUF_RD  BIT(0)
#define  SE_INT_IN_DONE       BIT(1)
#define  SE_INT_OUT_LL_BUF_WR BIT(2)
#define  SE_INT_OUT_DONE      BIT(3)
#define  SE_INT_OP_DONE       BIT(4)
#define  SE_INT_RESEED_NEEDED BIT(5)
#define  SE_INT_ERR_STAT      BIT(16)

#define SE_CONFIG_REG 0x014
#define  DST_MEMORY      0
#define  DST_HASHREG     1
#define  DST_KEYTABLE    2
#define  DST_SRK         3
#define  DST_RSAREG      4
#define  SE_CONFIG_DST(x)      ((x) << 2)
#define  ALG_NOP         0
#define  ALG_AES_DEC     1
#define  SE_CONFIG_DEC_ALG(x)  ((x) << 8)
#define  ALG_NOP         0
#define  ALG_AES_ENC     1
#define  ALG_RNG         2
#define  ALG_SHA         3
#define  ALG_RSA         4
#define  SE_CONFIG_ENC_ALG(x)  ((x) << 12)
#define  MODE_KEY128     0
#define  MODE_KEY192     1
#define  MODE_KEY256     2
#define  MODE_SHA1       0
#define  MODE_SHA224     4
#define  MODE_SHA256     5
#define  MODE_SHA384     6
#define  MODE_SHA512     7
#define  SE_CONFIG_DEC_MODE(x) ((x) << 16)
#define  SE_CONFIG_ENC_MODE(x) ((x) << 24)

#define SE_IN_LL_ADDR_REG        0x018
#define SE_IN_CUR_BYTE_ADDR_REG  0x01C
#define SE_IN_CUR_LL_ID_REG      0x020
#define SE_OUT_LL_ADDR_REG       0x024
#define SE_OUT_CUR_BYTE_ADDR_REG 0x028
#define SE_OUT_CUR_LL_ID_REG     0x02C

#define SE_HASH_RESULT_REG 0x030
#define  SE_HASH_RESULT_REG_COUNT 16

#define SE_CONTEXT_SAVE_CONFIG_REG 0x070
#define  KEYS_0_3        0
#define  KEYS_4_7        1
#define  ORIGINAL_IV     2
#define  UPDATED_IV      3
#define  SE_CONTEXT_AES_WORD_QUAD(x)    ((x) << 0)
#define  SE_CONTEXT_AES_KEY_INDEX(x)    ((x) << 8)
#define  KEYS_0_3        0
#define  KEYS_4_7        1
#define  KEYS_8_11       2
#define  KEYS_12_15      3
#define  SE_CONTEXT_RSA_WORD_QUAD(x)    ((x) << 12)
#define  SLOT0_EXPONENT  0
#define  SLOT0_MODULUS   1
#define  SLOT1_EXPONENT  2
#define  SLOT1_MODULUS   3
#define  SE_CONTEXT_RSA_KEY_INDEX(x)    ((x) << 16)
#define  STICKY_0_3      0
#define  STICKY_4_7      1
#define  SE_CONTEXT_STICKY_WORD_QUAD(x) ((x) << 24)
#define  STICKY_BITS     0
#define  RSA_KEYTABLE    1
#define  AES_KEYTABLE    2
#define  MEM             4
#define  SRK             6
#define SE_CONTEXT_SRC(x)               ((x) << 29)

#define SE_CTX_SAVE_AUTO_T210B01_REG 0x074
#define  SE_CTX_SAVE_AUTO_ENABLE		BIT(0)
#define  SE_CTX_SAVE_AUTO_LOCK          BIT(8)
#define  SE_CTX_SAVE_AUTO_CURR_CNT_MASK (0x3FF << 16)

#define SE_CRYPTO_LAST_BLOCK 0x080

#define SE_SHA_CONFIG_REG 0x200
#define  SHA_CONTINUE  0
#define  SHA_INIT_HASH 1

#define SE_SHA_MSG_LENGTH_0_REG 0x204
#define SE_SHA_MSG_LENGTH_1_REG 0x208
#define SE_SHA_MSG_LENGTH_2_REG 0x20C
#define SE_SHA_MSG_LENGTH_3_REG 0x210
#define SE_SHA_MSG_LEFT_0_REG   0x214
#define SE_SHA_MSG_LEFT_1_REG   0x218
#define SE_SHA_MSG_LEFT_2_REG   0x21C
#define SE_SHA_MSG_LEFT_3_REG   0x220

#define SE_CRYPTO_SECURITY_PERKEY_REG 0x280
#define  SE_KEY_LOCK_FLAG   0x80
#define SE_CRYPTO_KEYTABLE_ACCESS_REG 0x284
#define  SE_CRYPTO_KEYTABLE_ACCESS_REG_COUNT 16
#define  SE_KEY_TBL_DIS_KEYREAD_FLAG    BIT(0)
#define  SE_KEY_TBL_DIS_KEYUPDATE_FLAG  BIT(1)
#define  SE_KEY_TBL_DIS_OIVREAD_FLAG    BIT(2)
#define  SE_KEY_TBL_DIS_OIVUPDATE_FLAG  BIT(3)
#define  SE_KEY_TBL_DIS_UIVREAD_FLAG    BIT(4)
#define  SE_KEY_TBL_DIS_UIVUPDATE_FLAG  BIT(5)
#define  SE_KEY_TBL_DIS_KEYUSE_FLAG     BIT(6)
#define  SE_KEY_TBL_DIS_KEY_ACCESS_FLAG 0x7F

#define SE_CRYPTO_CONFIG_REG 0x304
#define  HASH_DISABLE   0
#define  HASH_ENABLE    1
#define  SE_CRYPTO_HASH(x)          ((x) << 0)
#define  XOR_BYPASS     0
#define  XOR_TOP        2
#define  XOR_BOTTOM     3
#define  SE_CRYPTO_XOR_POS(x)       ((x) << 1)
#define  INPUT_MEMORY   0
#define  INPUT_RANDOM   1
#define  INPUT_AESOUT   2
#define  INPUT_LNR_CTR  3
#define  SE_CRYPTO_INPUT_SEL(x)     ((x) << 3)
#define  VCTRAM_MEM     0
#define  VCTRAM_AESOUT  2
#define  VCTRAM_PREVMEM 3
#define  SE_CRYPTO_VCTRAM_SEL(x)    ((x) << 5)
#define  IV_ORIGINAL    0
#define  IV_UPDATED     1
#define  SE_CRYPTO_IV_SEL(x)        ((x) << 7)
#define  CORE_DECRYPT   0
#define  CORE_ENCRYPT   1
#define  SE_CRYPTO_CORE_SEL(x)      ((x) << 8)
#define  SE_CRYPTO_KEYSCH_BYPASS BIT(10)
#define  SE_CRYPTO_CTR_CNTN(x)      ((x) << 11)
#define  SE_CRYPTO_KEY_INDEX(x)     ((x) << 24)
#define  MEMIF_AHB      0
#define  MEMIF_MCCIF    1
#define  SE_CRYPTO_MEMIF(x)         ((x) << 31)

#define SE_CRYPTO_LINEAR_CTR_REG 0x308
#define  SE_CRYPTO_LINEAR_CTR_REG_COUNT 4

#define SE_CRYPTO_BLOCK_COUNT_REG 0x318

#define SE_CRYPTO_KEYTABLE_ADDR_REG 0x31C
#define  SE_KEYTABLE_PKT(x)         ((x) << 0)
#define  KEYS_0_3        0
#define  KEYS_4_7        1
#define  ORIGINAL_IV     2
#define  UPDATED_IV      3
#define  SE_KEYTABLE_QUAD(x)        ((x) << 2)
#define  SE_KEYTABLE_SLOT(x)        ((x) << 4)

#define SE_CRYPTO_KEYTABLE_DATA_REG 0x320

#define SE_CRYPTO_KEYTABLE_DST_REG 0x330
#define  KEYS_0_3        0
#define  KEYS_4_7        1
#define  ORIGINAL_IV     2
#define  UPDATED_IV      3
#define  SE_KEYTABLE_DST_WORD_QUAD(x) ((x) << 0)
#define  SE_KEYTABLE_DST_KEY_INDEX(x) ((x) << 8)

#define SE_RNG_CONFIG_REG 0x340
#define  MODE_NORMAL 0
#define  MODE_FORCE_INSTANTION 1
#define  MODE_FORCE_RESEED     2
#define  SE_RNG_CONFIG_MODE(x)        ((x) << 0)
#define  SRC_NONE        0
#define  SRC_ENTROPY     1
#define  SRC_LFSR        2
#define  SE_RNG_CONFIG_SRC(x)         ((x) << 2)

#define SE_RNG_SRC_CONFIG_REG	0x344
#define  RO_ENTR_LOCK_DISABLE  0
#define  RO_ENTR_LOCK_ENABLE   1
#define  SE_RNG_SRC_CONFIG_ENTR_SRC_LOCK(x) ((x) << 0)
#define  RO_ENTR_DISABLE       0
#define  RO_ENTR_ENABLE        1
#define  SE_RNG_SRC_CONFIG_ENTR_SRC(x)      ((x) << 1)
#define  RO_HW_DIS_CYA_DISABLE 0
#define  RO_HW_DIS_CYA_ENABLE  1
#define  SE_RNG_SRC_CONFIG_HW_DIS_CYA(x)    ((x) << 2)
#define  SE_RNG_SRC_CONFIG_ENTR_SUBSMPL(x)  ((x) << 4)
#define  SE_RNG_SRC_CONFIG_ENTR_DATA_FLUSH  BIT(8)

#define SE_RNG_RESEED_INTERVAL_REG 0x348

#define SE_RSA_CONFIG 0x400
#define  RSA_KEY_SLOT_ONE 0
#define  RSA_KEY_SLOT_TW0 1
#define  RSA_KEY_SLOT(x)            ((x) << 24)

#define SE_RSA_KEY_SIZE_REG 0x404
#define  RSA_KEY_WIDTH_512  0
#define  RSA_KEY_WIDTH_1024 1
#define  RSA_KEY_WIDTH_1536 2
#define  RSA_KEY_WIDTH_2048 3

#define SE_RSA_EXP_SIZE_REG 0x408

#define SE_RSA_SECURITY_PERKEY_REG 0x40C
#define  SE_RSA_KEY_LOCK_FLAG               0x80
#define SE_RSA_KEYTABLE_ACCESS_REG 0x410
#define  SE_RSA_KEY_TBL_DIS_KEYREAD_FLAG    BIT(0)
#define  SE_RSA_KEY_TBL_DIS_KEYUPDATE_FLAG  BIT(1)
#define  SE_RSA_KEY_TBL_DIS_KEYUSE_FLAG     BIT(2)
#define  SE_RSA_KEY_TBL_DIS_KEY_ACCESS_FLAG 0x7F
#define  SE_RSA_KEY_TBL_DIS_KEY_READ_UPDATE_FLAG      (SE_RSA_KEY_TBL_DIS_KEYREAD_FLAG | SE_RSA_KEY_TBL_DIS_KEYUPDATE_FLAG)
#define  SE_RSA_KEY_TBL_DIS_KEY_READ_UPDATE_USE_FLAG  (SE_RSA_KEY_TBL_DIS_KEYREAD_FLAG | SE_RSA_KEY_TBL_DIS_KEYUPDATE_FLAG | SE_RSA_KEY_TBL_DIS_KEYUSE_FLAG)

#define SE_RSA_KEYTABLE_ADDR_REG 0x420
#define  SE_RSA_KEYTABLE_PKT(x)        ((x) << 0)
#define  RSA_KEY_TYPE_EXP       0
#define  RSA_KEY_TYPE_MOD       1
#define  SE_RSA_KEYTABLE_TYPE(x)       ((x) << 6)
#define  RSA_KEY_NUM(x)                ((x) << 7)
#define  RSA_KEY_INPUT_MODE_REG 0
#define  RSA_KEY_INPUT_MODE_DMA 1
#define  SE_RSA_KEYTABLE_INPUT_MODE(x) ((x) << 8)
#define  RSA_KEY_READ           0
#define  RSA_KEY_WRITE          1
#define  SE_RSA_KEY_OP(x)              ((x) << 10)

#define SE_RSA_KEYTABLE_DATA_REG 0x424

#define SE_RSA_OUTPUT_REG 0x428
#define  SE_RSA_OUTPUT_REG_COUNT 64

#define SE_STATUS_REG 0x800
#define  SE_STATUS_STATE_IDLE     0
#define  SE_STATUS_STATE_BUSY     1
#define  SE_STATUS_STATE_WAIT_OUT 2
#define  SE_STATUS_STATE_WAIT_IN  3
#define  SE_STATUS_STATE_MASK     3

#define SE_ERR_STATUS_REG 0x804
#define  SE_ERR_STATUS_SE_NS_ACCESS    BIT(0)
#define  SE_ERR_STATUS_BUSY_REG_WR     BIT(1)
#define  SE_ERR_STATUS_DST             BIT(2)
#define  SE_ERR_STATUS_SRK_USAGE_LIMIT BIT(3)
#define  SE_ERR_STATUS_TZRAM_NS_ACCESS BIT(24)
#define  SE_ERR_STATUS_TZRAM_ADDRESS   BIT(25)

#define SE_MISC_REG 0x808
#define  SE_ENTROPY_NEXT_192BIT BIT(0)
#define  SE_ENTROPY_VN_BYPASS   BIT(1)
#define  SE_CLK_OVR_ON          BIT(2)

#define SE_SPARE_REG 0x80C
#define  SE_ERRATA_FIX_DISABLE 0
#define  SE_ERRATA_FIX_ENABLE  1
#define  SE_ECO(x) ((x) << 0)

#endif