blob: 235ea92f9dcd29b681aa51b01ba7d9bfb6551ef4 [file] [log] [blame]
/*
* 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 */