blob: 24f39657235ad0b4ae9860b9ad592c02a8362d44 [file] [log] [blame]
Raef Coles734aaac2022-06-15 14:37:22 +01001/*
2 * Copyright (c) 2022, Arm Limited. All rights reserved.
3 *
4 * SPDX-License-Identifier: BSD-3-Clause
5 *
6 */
7
Tamas Band0973182024-02-21 12:42:00 +01008#ifndef __RSE_COMMS_PROTOCOL_H__
9#define __RSE_COMMS_PROTOCOL_H__
Raef Coles734aaac2022-06-15 14:37:22 +010010
11#include <cdefs.h>
12#include <stdint.h>
13
14#include <psa/client.h>
Tamas Band0973182024-02-21 12:42:00 +010015#include "rse_comms_protocol_embed.h"
16#include "rse_comms_protocol_pointer_access.h"
Raef Coles734aaac2022-06-15 14:37:22 +010017
Tamas Band0973182024-02-21 12:42:00 +010018enum rse_comms_protocol_version_t {
19 RSE_COMMS_PROTOCOL_EMBED = 0,
20 RSE_COMMS_PROTOCOL_POINTER_ACCESS = 1,
Raef Coles734aaac2022-06-15 14:37:22 +010021};
22
Tamas Band0973182024-02-21 12:42:00 +010023struct __packed serialized_rse_comms_header_t {
Raef Coles734aaac2022-06-15 14:37:22 +010024 uint8_t protocol_ver;
25 uint8_t seq_num;
26 uint16_t client_id;
27};
28
Tamas Band0973182024-02-21 12:42:00 +010029/* MHU message passed from Host to RSE to deliver a PSA client call */
30struct __packed serialized_rse_comms_msg_t {
31 struct serialized_rse_comms_header_t header;
Raef Coles734aaac2022-06-15 14:37:22 +010032 union __packed {
Tamas Band0973182024-02-21 12:42:00 +010033 struct rse_embed_msg_t embed;
34 struct rse_pointer_access_msg_t pointer_access;
Raef Coles734aaac2022-06-15 14:37:22 +010035 } msg;
36};
37
Tamas Band0973182024-02-21 12:42:00 +010038/* MHU reply message to hold the PSA client reply result returned by RSE */
39struct __packed serialized_rse_comms_reply_t {
40 struct serialized_rse_comms_header_t header;
Raef Coles734aaac2022-06-15 14:37:22 +010041 union __packed {
Tamas Band0973182024-02-21 12:42:00 +010042 struct rse_embed_reply_t embed;
43 struct rse_pointer_access_reply_t pointer_access;
Raef Coles734aaac2022-06-15 14:37:22 +010044 } reply;
45};
46
47/* in_len and out_len are uint8_ts, therefore if there are more than 255 iovecs
48 * an error may occur.
49 */
Tamas Band0973182024-02-21 12:42:00 +010050CASSERT(PSA_MAX_IOVEC <= UINT8_MAX, assert_rse_comms_max_iovec_too_large);
Raef Coles734aaac2022-06-15 14:37:22 +010051
Tamas Band0973182024-02-21 12:42:00 +010052psa_status_t rse_protocol_serialize_msg(psa_handle_t handle,
Raef Coles734aaac2022-06-15 14:37:22 +010053 int16_t type,
54 const psa_invec *in_vec,
55 uint8_t in_len,
56 const psa_outvec *out_vec,
57 uint8_t out_len,
Tamas Band0973182024-02-21 12:42:00 +010058 struct serialized_rse_comms_msg_t *msg,
Raef Coles734aaac2022-06-15 14:37:22 +010059 size_t *msg_len);
60
Tamas Band0973182024-02-21 12:42:00 +010061psa_status_t rse_protocol_deserialize_reply(psa_outvec *out_vec,
Raef Coles734aaac2022-06-15 14:37:22 +010062 uint8_t out_len,
63 psa_status_t *return_val,
Tamas Band0973182024-02-21 12:42:00 +010064 const struct serialized_rse_comms_reply_t *reply,
Raef Coles734aaac2022-06-15 14:37:22 +010065 size_t reply_size);
66
Tamas Band0973182024-02-21 12:42:00 +010067#endif /* __RSE_COMMS_PROTOCOL_H__ */