/*
 * Copyright (c) 2024, Arm Limited. All rights reserved.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 *
 */

/*
 * Packing scheme of the control parameter
 *
 *  31           30-28   27    26-24  23-20   19     18-16   15-0
 * +------------+-----+------+-------+-----+-------+-------+------+
 * |            |     |      | invec |     |       | outvec| type |
 * | Res        | Res | Res  | number| Res | Res   | number|      |
 * +------------+-----+------+-------+-----+-------+-------+------+
 *
 * Res: Reserved.
 */

#ifndef RSE_COMMS_PROTOCOL_COMMON
#define RSE_COMMS_PROTOCOL_COMMON

#define TYPE_OFFSET	(0U)
#define TYPE_MASK	(0xFFFFUL << TYPE_OFFSET)
#define IN_LEN_OFFSET	(24U)
#define IN_LEN_MASK	(0x7UL << IN_LEN_OFFSET)
#define OUT_LEN_OFFSET	(16U)
#define OUT_LEN_MASK	(0x7UL << OUT_LEN_OFFSET)

#define PARAM_PACK(type, in_len, out_len)			   \
	(((((uint32_t)(type)) << TYPE_OFFSET) & TYPE_MASK)	 | \
	 ((((uint32_t)(in_len)) << IN_LEN_OFFSET) & IN_LEN_MASK) | \
	 ((((uint32_t)(out_len)) << OUT_LEN_OFFSET) & OUT_LEN_MASK))

#endif /* RSE_COMMS_PROTOCOL_COMMON */