xref: /rk3399_ARM-atf/drivers/arm/rse/rse_comms_protocol.c (revision a1901c7d0d05ac02b254bf215fb889b9c0a9bc7d)
195511698STamas Ban /*
295511698STamas Ban  * Copyright (c) 2022, Arm Limited. All rights reserved.
395511698STamas Ban  *
495511698STamas Ban  * SPDX-License-Identifier: BSD-3-Clause
595511698STamas Ban  *
695511698STamas Ban  */
795511698STamas Ban #include <assert.h>
895511698STamas Ban 
995511698STamas Ban #include <common/debug.h>
10*e249e569STamas Ban #include "rse_comms_protocol.h"
1195511698STamas Ban 
rse_protocol_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 serialized_rse_comms_msg_t * msg,size_t * msg_len)12*e249e569STamas Ban psa_status_t rse_protocol_serialize_msg(psa_handle_t handle,
1395511698STamas Ban 					int16_t type,
1495511698STamas Ban 					const psa_invec *in_vec,
1595511698STamas Ban 					uint8_t in_len,
1695511698STamas Ban 					const psa_outvec *out_vec,
1795511698STamas Ban 					uint8_t out_len,
18*e249e569STamas Ban 					struct serialized_rse_comms_msg_t *msg,
1995511698STamas Ban 					size_t *msg_len)
2095511698STamas Ban {
2195511698STamas Ban 	psa_status_t status;
2295511698STamas Ban 
2395511698STamas Ban 	assert(msg != NULL);
2495511698STamas Ban 	assert(msg_len != NULL);
2595511698STamas Ban 	assert(in_vec != NULL);
2695511698STamas Ban 
2795511698STamas Ban 	switch (msg->header.protocol_ver) {
28*e249e569STamas Ban 	case RSE_COMMS_PROTOCOL_EMBED:
29*e249e569STamas Ban 		status = rse_protocol_embed_serialize_msg(handle, type, in_vec, in_len, out_vec,
3095511698STamas Ban 							  out_len, &msg->msg.embed, msg_len);
3195511698STamas Ban 		if (status != PSA_SUCCESS) {
3295511698STamas Ban 			return status;
3395511698STamas Ban 		}
3495511698STamas Ban 		break;
35*e249e569STamas Ban 	case RSE_COMMS_PROTOCOL_POINTER_ACCESS:
36*e249e569STamas Ban 		status = rse_protocol_pointer_access_serialize_msg(handle, type, in_vec, in_len,
3795511698STamas Ban 								   out_vec, out_len,
3895511698STamas Ban 								   &msg->msg.pointer_access,
3995511698STamas Ban 								   msg_len);
4095511698STamas Ban 		if (status != PSA_SUCCESS) {
4195511698STamas Ban 			return status;
4295511698STamas Ban 		}
4395511698STamas Ban 		break;
4495511698STamas Ban 	default:
4595511698STamas Ban 		return PSA_ERROR_NOT_SUPPORTED;
4695511698STamas Ban 	}
4795511698STamas Ban 
48*e249e569STamas Ban 	*msg_len += sizeof(struct serialized_rse_comms_header_t);
4995511698STamas Ban 
5095511698STamas Ban 	return PSA_SUCCESS;
5195511698STamas Ban }
5295511698STamas Ban 
rse_protocol_deserialize_reply(psa_outvec * out_vec,uint8_t out_len,psa_status_t * return_val,const struct serialized_rse_comms_reply_t * reply,size_t reply_size)53*e249e569STamas Ban psa_status_t rse_protocol_deserialize_reply(psa_outvec *out_vec,
5495511698STamas Ban 					    uint8_t out_len,
5595511698STamas Ban 					    psa_status_t *return_val,
56*e249e569STamas Ban 					    const struct serialized_rse_comms_reply_t *reply,
5795511698STamas Ban 					    size_t reply_size)
5895511698STamas Ban {
5995511698STamas Ban 	assert(reply != NULL);
6095511698STamas Ban 	assert(return_val != NULL);
6195511698STamas Ban 
6295511698STamas Ban 	switch (reply->header.protocol_ver) {
63*e249e569STamas Ban 	case RSE_COMMS_PROTOCOL_EMBED:
64*e249e569STamas Ban 		return rse_protocol_embed_deserialize_reply(out_vec, out_len, return_val,
6595511698STamas Ban 							    &reply->reply.embed, reply_size);
66*e249e569STamas Ban 	case RSE_COMMS_PROTOCOL_POINTER_ACCESS:
67*e249e569STamas Ban 		return rse_protocol_pointer_access_deserialize_reply(out_vec, out_len, return_val,
6895511698STamas Ban 								     &reply->reply.pointer_access,
6995511698STamas Ban 								     reply_size);
7095511698STamas Ban 	default:
7195511698STamas Ban 		return PSA_ERROR_NOT_SUPPORTED;
7295511698STamas Ban 	}
7395511698STamas Ban 
7495511698STamas Ban 	return PSA_SUCCESS;
7595511698STamas Ban }
76