diff options
| author | Naman Trivedi <[email protected]> | 2025-08-28 15:42:22 +0200 |
|---|---|---|
| committer | Michal Simek <[email protected]> | 2025-10-09 09:07:03 +0200 |
| commit | 4146a31dcec709058a8e793b86712b0ffa1ba15a (patch) | |
| tree | fde641edd88939431fff5a3e1000ebfcf38c4963 /arch | |
| parent | e7fe2c7bc60d9963f8309d0094fec753b767fd36 (diff) | |
drivers: firmware: update xilinx_pm_request to support max payload
Currently xilinx_pm_request API supports four u32 payloads. However the
legacy SMC format supports five u32 request payloads and extended SMC
format supports six u32 request payloads. Add support for the same in
xilinx_pm_request API. Also add two dummy arguments to all the callers
of xilinx_pm_request.
The TF-A always fills seven u32 return payload so add support
for the same in xilinx_pm_request API.
Signed-off-by: Naman Trivedi <[email protected]>
Signed-off-by: Venkatesh Yadav Abbarapu <[email protected]>
Acked-by: Senthil Nathan Thangaraj <[email protected]>
Signed-off-by: Michal Simek <[email protected]>
Link: https://lore.kernel.org/r/5ae6b560741f3ca8b89059c4ebb87acf75b4718e.1756388537.git.michal.simek@amd.com
Diffstat (limited to 'arch')
| -rw-r--r-- | arch/arm/mach-zynqmp/aes.c | 3 | ||||
| -rw-r--r-- | arch/arm/mach-zynqmp/cpu.c | 4 | ||||
| -rw-r--r-- | arch/arm/mach-zynqmp/zynqmp.c | 10 |
3 files changed, 9 insertions, 8 deletions
diff --git a/arch/arm/mach-zynqmp/aes.c b/arch/arm/mach-zynqmp/aes.c index 9a05fbf9c11..dec428c159e 100644 --- a/arch/arm/mach-zynqmp/aes.c +++ b/arch/arm/mach-zynqmp/aes.c @@ -47,7 +47,8 @@ int zynqmp_aes_operation(struct zynqmp_aes *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); + lower_32_bits((ulong)aes), 0, 0, 0, 0, + ret_payload); if (ret || ret_payload[1]) { printf("Failed: AES op status:0x%x, errcode:0x%x\n", ret, ret_payload[1]); diff --git a/arch/arm/mach-zynqmp/cpu.c b/arch/arm/mach-zynqmp/cpu.c index b7a4142fd54..5f194aaff9a 100644 --- a/arch/arm/mach-zynqmp/cpu.c +++ b/arch/arm/mach-zynqmp/cpu.c @@ -205,7 +205,7 @@ int zynqmp_mmio_write(const u32 address, #if defined(CONFIG_ZYNQMP_FIRMWARE) else return xilinx_pm_request(PM_MMIO_WRITE, address, mask, - value, 0, NULL); + value, 0, 0, 0, NULL); #endif return -EINVAL; @@ -226,7 +226,7 @@ int zynqmp_mmio_read(const u32 address, u32 *value) u32 ret_payload[PAYLOAD_ARG_CNT]; ret = xilinx_pm_request(PM_MMIO_READ, address, 0, 0, - 0, ret_payload); + 0, 0, 0, ret_payload); *value = ret_payload[1]; } #endif diff --git a/arch/arm/mach-zynqmp/zynqmp.c b/arch/arm/mach-zynqmp/zynqmp.c index 279006b4d13..c0398a466ff 100644 --- a/arch/arm/mach-zynqmp/zynqmp.c +++ b/arch/arm/mach-zynqmp/zynqmp.c @@ -57,7 +57,7 @@ static int do_zynqmp_verify_secure(struct cmd_tbl *cmdtp, int flag, int argc, } ret = xilinx_pm_request(PM_SECURE_IMAGE, src_lo, src_hi, - key_lo, key_hi, ret_payload); + key_lo, key_hi, 0, 0, ret_payload); if (ret) { printf("Failed: secure op status:0x%x\n", ret); } else { @@ -260,7 +260,7 @@ static int do_zynqmp_rsa(struct cmd_tbl *cmdtp, int flag, int argc, ret = xilinx_pm_request(PM_SECURE_RSA, upper_32_bits((ulong)srcaddr), lower_32_bits((ulong)srcaddr), srclen, rsaop, - ret_payload); + 0, 0, ret_payload); if (ret || ret_payload[1]) { printf("Failed: RSA status:0x%x, errcode:0x%x\n", ret, ret_payload[1]); @@ -309,7 +309,7 @@ static int do_zynqmp_sha3(struct cmd_tbl *cmdtp, int flag, srcaddr + roundup(srclen, ARCH_DMA_MINALIGN)); ret = xilinx_pm_request(PM_SECURE_SHA, 0, 0, 0, - ZYNQMP_SHA3_INIT, ret_payload); + ZYNQMP_SHA3_INIT, 0, 0, ret_payload); if (ret || ret_payload[1]) { printf("Failed: SHA INIT status:0x%x, errcode:0x%x\n", ret, ret_payload[1]); @@ -318,7 +318,7 @@ static int do_zynqmp_sha3(struct cmd_tbl *cmdtp, int flag, ret = xilinx_pm_request(PM_SECURE_SHA, upper_32_bits((ulong)srcaddr), lower_32_bits((ulong)srcaddr), - srclen, ZYNQMP_SHA3_UPDATE, ret_payload); + srclen, ZYNQMP_SHA3_UPDATE, 0, 0, ret_payload); if (ret || ret_payload[1]) { printf("Failed: SHA UPDATE status:0x%x, errcode:0x%x\n", ret, ret_payload[1]); @@ -328,7 +328,7 @@ static int do_zynqmp_sha3(struct cmd_tbl *cmdtp, int flag, ret = xilinx_pm_request(PM_SECURE_SHA, upper_32_bits((ulong)hashaddr), lower_32_bits((ulong)hashaddr), ZYNQMP_SHA3_SIZE, ZYNQMP_SHA3_FINAL, - ret_payload); + 0, 0, ret_payload); if (ret || ret_payload[1]) { printf("Failed: SHA FINAL status:0x%x, errcode:0x%x\n", ret, ret_payload[1]); |
