// SPDX-License-Identifier: GPL-2.0 /* * (C) Copyright 2018 Xilinx, Inc. * Siva Durga Prasad Paladugu * * Copyright (C) 2023 Weidmueller Interface GmbH & Co. KG * Christian Taedcke */ #include #include #include #include #include #include int zynqmp_aes_operation(struct zynqmp_aes *aes) { u32 ret_payload[PAYLOAD_ARG_CNT]; int ret; if (zynqmp_firmware_version() <= PMUFW_V1_0) return -ENOENT; if (aes->srcaddr && aes->ivaddr && aes->dstaddr) { flush_dcache_range(aes->srcaddr, aes->srcaddr + roundup(aes->len, ARCH_DMA_MINALIGN)); flush_dcache_range(aes->ivaddr, aes->ivaddr + roundup(IV_SIZE, ARCH_DMA_MINALIGN)); flush_dcache_range(aes->dstaddr, aes->dstaddr + roundup(aes->len, ARCH_DMA_MINALIGN)); } if (aes->keysrc == 0) { if (aes->keyaddr == 0) return -EINVAL; flush_dcache_range(aes->keyaddr, aes->keyaddr + roundup(KEY_PTR_LEN, ARCH_DMA_MINALIGN)); } flush_dcache_range((ulong)aes, (ulong)(aes) + roundup(sizeof(struct zynqmp_aes), ARCH_DMA_MINALIGN)); ret = xilinx_pm_request(PM_SECURE_AES, upper_32_bits((ulong)aes), lower_32_bits((ulong)aes), 0, 0, ret_payload); if (ret || ret_payload[1]) { printf("Failed: AES op status:0x%x, errcode:0x%x\n", ret, ret_payload[1]); return -EIO; } return 0; }