| /* |
| * Copyright (C) 2017 Amlogic, Inc. All rights reserved. |
| * * |
| This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License as published by |
| * the Free Software Foundation; either version 2 of the License, or |
| * (at your option) any later version. |
| * * |
| This program is distributed in the hope that 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, write to the Free Software Foundation, Inc., |
| * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
| * * |
| Description: |
| */ |
| |
| #ifndef __HW_AES_H |
| #define __HW_AES_H |
| |
| #ifndef __AP_DMA_H__ |
| #define __AP_DMA_H__ |
| |
| typedef struct dma_dsc { |
| union { |
| uint32_t d32; |
| struct { |
| unsigned length:17; |
| unsigned irq:1; |
| unsigned eoc:1; |
| unsigned loop:1; |
| unsigned mode:4; |
| unsigned begin:1; |
| unsigned end:1; |
| unsigned op_mode:2; |
| unsigned enc_sha_only:1; |
| unsigned block:1; |
| unsigned error:1; |
| unsigned owner:1; |
| } b; |
| } dsc_cfg; |
| uint32_t src_addr; |
| uint32_t tgt_addr; |
| } dma_dsc_t; |
| |
| #endif /* __AP_DMA_H__ */ |
| |
| enum aes_ret_t { |
| AES_RET_SUCCESS=0, |
| AES_RET_ADDR=1, |
| AES_RET_SIZE=2, |
| AES_RET_TYPE=3, |
| AES_RET_MODE = 4, |
| }; |
| |
| /** |
| * |
| * @param key A pointer to the key buffer |
| * @param iv Byte length of iv buffer |
| * @param ct A pointer to the source buffer |
| * @param pt A pointer to the target buffer |
| * @param size Byte length of source buffer |
| * @param AEStype 128: aes128 192: aes192 256: aes256 |
| * @param CryptMode 1: encrypt 0: decrypt |
| */ |
| int aes_cbc_crypt(uint8_t *key, uint8_t *iv, |
| uint8_t *ct, uint8_t *pt, uint32_t size, uint16_t AEStype,uint8_t CryptMode); |
| |
| #endif |