J-Alves | 0e1e7ca | 2021-01-25 14:11:06 +0000 | [diff] [blame] | 1 | /* |
Shruti Gupta | 38133fa | 2023-04-19 17:00:38 +0100 | [diff] [blame] | 2 | * Copyright (c) 2023, Arm Limited. All rights reserved. |
J-Alves | 0e1e7ca | 2021-01-25 14:11:06 +0000 | [diff] [blame] | 3 | * |
| 4 | * SPDX-License-Identifier: BSD-3-Clause |
| 5 | */ |
| 6 | |
J-Alves | eeb2547 | 2021-03-11 09:54:21 +0000 | [diff] [blame] | 7 | #include "cactus_message_loop.h" |
J-Alves | 0e1e7ca | 2021-01-25 14:11:06 +0000 | [diff] [blame] | 8 | #include "cactus_test_cmds.h" |
Shruti Gupta | 38133fa | 2023-04-19 17:00:38 +0100 | [diff] [blame] | 9 | #include <fpu.h> |
J-Alves | 0e1e7ca | 2021-01-25 14:11:06 +0000 | [diff] [blame] | 10 | #include "spm_common.h" |
| 11 | |
| 12 | /* |
Shruti Gupta | 38133fa | 2023-04-19 17:00:38 +0100 | [diff] [blame] | 13 | * Note Test must exercise FILL and COMPARE command in |
| 14 | * sequence and on same CPU. |
| 15 | */ |
Arunachalam Ganapathy | 7e514f6 | 2023-08-30 13:27:36 +0100 | [diff] [blame] | 16 | static fpu_state_t sp_fpu_state_write; |
| 17 | static fpu_state_t sp_fpu_state_read; |
Shruti Gupta | 38133fa | 2023-04-19 17:00:38 +0100 | [diff] [blame] | 18 | static unsigned int core_pos; |
| 19 | /* |
J-Alves | 0e1e7ca | 2021-01-25 14:11:06 +0000 | [diff] [blame] | 20 | * Fill SIMD vectors from secure world side with a unique value. |
J-Alves | 0e1e7ca | 2021-01-25 14:11:06 +0000 | [diff] [blame] | 21 | */ |
| 22 | CACTUS_CMD_HANDLER(req_simd_fill, CACTUS_REQ_SIMD_FILL_CMD) |
| 23 | { |
Shruti Gupta | 38133fa | 2023-04-19 17:00:38 +0100 | [diff] [blame] | 24 | core_pos = platform_get_core_pos(read_mpidr_el1()); |
Arunachalam Ganapathy | 7e514f6 | 2023-08-30 13:27:36 +0100 | [diff] [blame] | 25 | fpu_state_write_rand(&sp_fpu_state_write); |
J-Alves | 0e1e7ca | 2021-01-25 14:11:06 +0000 | [diff] [blame] | 26 | return cactus_response(ffa_dir_msg_dest(*args), |
| 27 | ffa_dir_msg_source(*args), |
| 28 | CACTUS_SUCCESS); |
| 29 | } |
Shruti Gupta | 38133fa | 2023-04-19 17:00:38 +0100 | [diff] [blame] | 30 | |
| 31 | /* |
| 32 | * compare FPU state(SIMD vectors, FPCR, FPSR) from secure world side with the previous |
| 33 | * SIMD_SECURE_VALUE unique value. |
| 34 | */ |
| 35 | CACTUS_CMD_HANDLER(req_simd_compare, CACTUS_CMP_SIMD_VALUE_CMD) |
| 36 | { |
| 37 | bool test_succeed = false; |
| 38 | |
| 39 | unsigned int core_pos1 = platform_get_core_pos(read_mpidr_el1()); |
| 40 | if (core_pos1 == core_pos) { |
Arunachalam Ganapathy | 7e514f6 | 2023-08-30 13:27:36 +0100 | [diff] [blame] | 41 | fpu_state_read(&sp_fpu_state_read); |
| 42 | if (fpu_state_compare(&sp_fpu_state_write, |
| 43 | &sp_fpu_state_read) == 0) { |
| 44 | test_succeed = true; |
| 45 | } |
Shruti Gupta | 38133fa | 2023-04-19 17:00:38 +0100 | [diff] [blame] | 46 | } |
| 47 | return cactus_response(ffa_dir_msg_dest(*args), |
| 48 | ffa_dir_msg_source(*args), |
| 49 | test_succeed ? CACTUS_SUCCESS : CACTUS_ERROR); |
| 50 | } |