| // SPDX-License-Identifier: GPL-2.0+ |
| /* |
| * Copyright (c) 2019, softathome |
| */ |
| |
| #ifndef USE_HOSTCC |
| #include <common.h> |
| #include <malloc.h> |
| #endif |
| #include <image.h> |
| #include <uboot_aes.h> |
| |
| int image_aes_decrypt(struct image_cipher_info *info, |
| const void *cipher, size_t cipher_len, |
| void **data, size_t *size) |
| { |
| #ifndef USE_HOSTCC |
| unsigned char key_exp[AES256_EXPAND_KEY_LENGTH]; |
| unsigned int aes_blocks, key_len = info->cipher->key_len; |
| |
| *data = malloc(cipher_len); |
| if (!*data) { |
| printf("Can't allocate memory to decrypt\n"); |
| return -ENOMEM; |
| } |
| *size = info->size_unciphered; |
| |
| memcpy(&key_exp[0], info->key, key_len); |
| |
| /* First we expand the key. */ |
| aes_expand_key((u8 *)info->key, key_len, key_exp); |
| |
| /* Calculate the number of AES blocks to encrypt. */ |
| aes_blocks = DIV_ROUND_UP(cipher_len, AES_BLOCK_LENGTH); |
| |
| aes_cbc_decrypt_blocks(key_len, key_exp, (u8 *)info->iv, |
| (u8 *)cipher, *data, aes_blocks); |
| #endif |
| |
| return 0; |
| } |