blob: 6c2a7bd5659a853970c3e0c664208cc7a6f12f38 [file] [log] [blame]
/*
* Copyright (c) 2022, Arm Limited. All rights reserved.
*
* SPDX-License-Identifier: BSD-3-Clause
*
*/
#ifndef __RSS_COMMS_PROTOCOL_EMBED_H__
#define __RSS_COMMS_PROTOCOL_EMBED_H__
#include <cdefs.h>
#include <initial_attestation.h>
#include <psa/client.h>
#include <platform_def.h>
/*
* In the current implementation the RoT Service request that requires the
* biggest message buffer is the RSS_ATTEST_GET_TOKEN. The maximum required
* buffer size is calculated based on the platform-specific needs of
* this request.
*/
#ifndef RSS_COMMS_PAYLOAD_MAX_SIZE
#define RSS_COMMS_PAYLOAD_MAX_SIZE (PSA_INITIAL_ATTEST_CHALLENGE_SIZE_64 \
+ PLAT_ATTEST_TOKEN_MAX_SIZE)
#endif
struct __packed rss_embed_msg_t {
psa_handle_t handle;
uint32_t ctrl_param; /* type, in_len, out_len */
uint16_t io_size[PSA_MAX_IOVEC];
uint8_t trailer[RSS_COMMS_PAYLOAD_MAX_SIZE];
};
struct __packed rss_embed_reply_t {
int32_t return_val;
uint16_t out_size[PSA_MAX_IOVEC];
uint8_t trailer[RSS_COMMS_PAYLOAD_MAX_SIZE];
};
psa_status_t rss_protocol_embed_serialize_msg(psa_handle_t handle,
int16_t type,
const psa_invec *in_vec,
uint8_t in_len,
const psa_outvec *out_vec,
uint8_t out_len,
struct rss_embed_msg_t *msg,
size_t *msg_len);
psa_status_t rss_protocol_embed_deserialize_reply(psa_outvec *out_vec,
uint8_t out_len,
psa_status_t *return_val,
const struct rss_embed_reply_t *reply,
size_t reply_size);
#endif /* __RSS_COMMS_PROTOCOL_EMBED_H__ */