Abdellatif El Khlifi | 2f403d1 | 2023-08-04 14:33:40 +0100 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0+ */ |
| 2 | /* |
| 3 | * Copyright 2022-2023 Arm Limited and/or its affiliates <open-source-office@arm.com> |
| 4 | * |
| 5 | * Authors: |
| 6 | * Abdellatif El Khlifi <abdellatif.elkhlifi@arm.com> |
| 7 | */ |
| 8 | |
| 9 | #ifndef __ARM_FFA_PRV_H |
| 10 | #define __ARM_FFA_PRV_H |
| 11 | |
| 12 | #include <mapmem.h> |
| 13 | #include <linux/bitfield.h> |
| 14 | #include <linux/bitops.h> |
| 15 | |
| 16 | /* This header is exclusively used by the FF-A Uclass and FF-A driver(s) */ |
| 17 | |
| 18 | /* Arm FF-A driver name */ |
| 19 | #define FFA_DRV_NAME "arm_ffa" |
| 20 | |
| 21 | /* The FF-A SMC function definitions */ |
| 22 | |
| 23 | #if CONFIG_IS_ENABLED(SANDBOX) |
| 24 | |
| 25 | /* Providing Arm SMCCC declarations to sandbox */ |
| 26 | |
| 27 | /** |
| 28 | * struct sandbox_smccc_1_2_regs - emulated SMC call arguments or results |
| 29 | * @a0-a17 argument values from registers 0 to 17 |
| 30 | */ |
| 31 | struct sandbox_smccc_1_2_regs { |
| 32 | ulong a0; |
| 33 | ulong a1; |
| 34 | ulong a2; |
| 35 | ulong a3; |
| 36 | ulong a4; |
| 37 | ulong a5; |
| 38 | ulong a6; |
| 39 | ulong a7; |
| 40 | ulong a8; |
| 41 | ulong a9; |
| 42 | ulong a10; |
| 43 | ulong a11; |
| 44 | ulong a12; |
| 45 | ulong a13; |
| 46 | ulong a14; |
| 47 | ulong a15; |
| 48 | ulong a16; |
| 49 | ulong a17; |
| 50 | }; |
| 51 | |
| 52 | typedef struct sandbox_smccc_1_2_regs ffa_value_t; |
| 53 | |
| 54 | #define ARM_SMCCC_FAST_CALL 1UL |
| 55 | #define ARM_SMCCC_OWNER_STANDARD 4 |
| 56 | #define ARM_SMCCC_SMC_32 0 |
| 57 | #define ARM_SMCCC_SMC_64 1 |
| 58 | #define ARM_SMCCC_TYPE_SHIFT 31 |
| 59 | #define ARM_SMCCC_CALL_CONV_SHIFT 30 |
| 60 | #define ARM_SMCCC_OWNER_MASK 0x3f |
| 61 | #define ARM_SMCCC_OWNER_SHIFT 24 |
| 62 | #define ARM_SMCCC_FUNC_MASK 0xffff |
| 63 | |
| 64 | #define ARM_SMCCC_CALL_VAL(type, calling_convention, owner, func_num) \ |
| 65 | (((type) << ARM_SMCCC_TYPE_SHIFT) | \ |
| 66 | ((calling_convention) << ARM_SMCCC_CALL_CONV_SHIFT) | \ |
| 67 | (((owner) & ARM_SMCCC_OWNER_MASK) << ARM_SMCCC_OWNER_SHIFT) | \ |
| 68 | ((func_num) & ARM_SMCCC_FUNC_MASK)) |
| 69 | |
| 70 | #else |
| 71 | /* CONFIG_ARM64 */ |
| 72 | #include <linux/arm-smccc.h> |
| 73 | typedef struct arm_smccc_1_2_regs ffa_value_t; |
| 74 | #endif |
| 75 | |
| 76 | /* Defining the function pointer type for the function executing the FF-A ABIs */ |
| 77 | typedef void (*invoke_ffa_fn_t)(ffa_value_t args, ffa_value_t *res); |
| 78 | |
| 79 | /* FF-A driver version definitions */ |
| 80 | |
| 81 | #define MAJOR_VERSION_MASK GENMASK(30, 16) |
| 82 | #define MINOR_VERSION_MASK GENMASK(15, 0) |
| 83 | #define GET_FFA_MAJOR_VERSION(x) \ |
| 84 | ((u16)(FIELD_GET(MAJOR_VERSION_MASK, (x)))) |
| 85 | #define GET_FFA_MINOR_VERSION(x) \ |
| 86 | ((u16)(FIELD_GET(MINOR_VERSION_MASK, (x)))) |
| 87 | #define PACK_VERSION_INFO(major, minor) \ |
| 88 | (FIELD_PREP(MAJOR_VERSION_MASK, (major)) | \ |
| 89 | FIELD_PREP(MINOR_VERSION_MASK, (minor))) |
| 90 | |
| 91 | #define FFA_MAJOR_VERSION (1) |
| 92 | #define FFA_MINOR_VERSION (0) |
| 93 | #define FFA_VERSION_1_0 \ |
| 94 | PACK_VERSION_INFO(FFA_MAJOR_VERSION, FFA_MINOR_VERSION) |
| 95 | |
| 96 | /* Endpoint ID mask (u-boot endpoint ID) */ |
| 97 | |
| 98 | #define GET_SELF_ENDPOINT_ID_MASK GENMASK(15, 0) |
| 99 | #define GET_SELF_ENDPOINT_ID(x) \ |
| 100 | ((u16)(FIELD_GET(GET_SELF_ENDPOINT_ID_MASK, (x)))) |
| 101 | |
| 102 | #define PREP_SELF_ENDPOINT_ID_MASK GENMASK(31, 16) |
| 103 | #define PREP_SELF_ENDPOINT_ID(x) \ |
| 104 | (FIELD_PREP(PREP_SELF_ENDPOINT_ID_MASK, (x))) |
| 105 | |
| 106 | /* Partition endpoint ID mask (partition with which u-boot communicates with) */ |
| 107 | |
| 108 | #define PREP_PART_ENDPOINT_ID_MASK GENMASK(15, 0) |
| 109 | #define PREP_PART_ENDPOINT_ID(x) \ |
| 110 | (FIELD_PREP(PREP_PART_ENDPOINT_ID_MASK, (x))) |
| 111 | |
| 112 | /* Definitions of the Arm FF-A interfaces supported by the Arm FF-A driver */ |
| 113 | |
| 114 | #define FFA_SMC(calling_convention, func_num) \ |
| 115 | ARM_SMCCC_CALL_VAL(ARM_SMCCC_FAST_CALL, (calling_convention), \ |
| 116 | ARM_SMCCC_OWNER_STANDARD, (func_num)) |
| 117 | |
| 118 | #define FFA_SMC_32(func_num) FFA_SMC(ARM_SMCCC_SMC_32, (func_num)) |
| 119 | #define FFA_SMC_64(func_num) FFA_SMC(ARM_SMCCC_SMC_64, (func_num)) |
| 120 | |
| 121 | enum ffa_abis { |
| 122 | FFA_ERROR = 0x60, |
| 123 | FFA_SUCCESS = 0x61, |
| 124 | FFA_INTERRUPT = 0x62, |
| 125 | FFA_VERSION = 0x63, |
| 126 | FFA_FEATURES = 0x64, |
| 127 | FFA_RX_RELEASE = 0x65, |
| 128 | FFA_RXTX_MAP = 0x66, |
| 129 | FFA_RXTX_UNMAP = 0x67, |
| 130 | FFA_PARTITION_INFO_GET = 0x68, |
| 131 | FFA_ID_GET = 0x69, |
| 132 | FFA_RUN = 0x6d, |
| 133 | FFA_MSG_SEND_DIRECT_REQ = 0x6f, |
| 134 | FFA_MSG_SEND_DIRECT_RESP = 0x70, |
| 135 | |
| 136 | /* To be updated when adding new FFA IDs */ |
| 137 | FFA_FIRST_ID = FFA_ERROR, /* Lowest number ID */ |
| 138 | FFA_LAST_ID = FFA_MSG_SEND_DIRECT_RESP, /* Highest number ID */ |
| 139 | }; |
| 140 | |
| 141 | enum ffa_abi_errcode { |
| 142 | NOT_SUPPORTED = 1, |
| 143 | INVALID_PARAMETERS, |
| 144 | NO_MEMORY, |
| 145 | BUSY, |
| 146 | INTERRUPTED, |
| 147 | DENIED, |
| 148 | RETRY, |
| 149 | ABORTED, |
| 150 | MAX_NUMBER_FFA_ERR |
| 151 | }; |
| 152 | |
| 153 | extern int ffa_to_std_errmap[MAX_NUMBER_FFA_ERR]; |
| 154 | |
| 155 | /* Container structure and helper macros to map between an FF-A error and relevant error log */ |
| 156 | struct ffa_abi_errmap { |
| 157 | char *err_str[MAX_NUMBER_FFA_ERR]; |
| 158 | }; |
| 159 | |
| 160 | #define FFA_ERRMAP_COUNT (FFA_LAST_ID - FFA_FIRST_ID + 1) |
| 161 | #define FFA_ID_TO_ERRMAP_ID(ffa_id) ((ffa_id) - FFA_FIRST_ID) |
| 162 | |
| 163 | /** |
| 164 | * enum ffa_rxtx_buf_sizes - minimum sizes supported |
| 165 | * for the RX/TX buffers |
| 166 | */ |
| 167 | enum ffa_rxtx_buf_sizes { |
| 168 | RXTX_4K, |
| 169 | RXTX_64K, |
| 170 | RXTX_16K |
| 171 | }; |
| 172 | |
| 173 | /** |
| 174 | * struct ffa_rxtxpair - Hosts the RX/TX buffers virtual addresses |
| 175 | * @rxbuf: virtual address of the RX buffer |
| 176 | * @txbuf: virtual address of the TX buffer |
| 177 | * @rxtx_min_pages: RX/TX buffers minimum size in pages |
| 178 | * |
| 179 | * Hosts the virtual addresses of the mapped RX/TX buffers |
| 180 | * These addresses are used by the FF-A functions that use the RX/TX buffers |
| 181 | */ |
| 182 | struct ffa_rxtxpair { |
| 183 | void *rxbuf; /* Virtual address returned by memalign */ |
| 184 | void *txbuf; /* Virtual address returned by memalign */ |
| 185 | size_t rxtx_min_pages; /* Minimum number of pages in each of the RX/TX buffers */ |
| 186 | }; |
| 187 | |
| 188 | struct ffa_partition_desc; |
| 189 | |
| 190 | /** |
| 191 | * struct ffa_partitions - descriptors for all secure partitions |
| 192 | * @count: The number of partitions descriptors |
| 193 | * @descs The partitions descriptors table |
| 194 | * |
| 195 | * Contains the partitions descriptors table |
| 196 | */ |
| 197 | struct ffa_partitions { |
| 198 | u32 count; |
| 199 | struct ffa_partition_desc *descs; /* Virtual address */ |
| 200 | }; |
| 201 | |
| 202 | /** |
| 203 | * struct ffa_priv - the driver private data structure |
| 204 | * |
| 205 | * @fwk_version: FF-A framework version |
| 206 | * @emul: FF-A sandbox emulator |
| 207 | * @id: u-boot endpoint ID |
| 208 | * @partitions: The partitions descriptors structure |
| 209 | * @pair: The RX/TX buffers pair |
| 210 | * |
| 211 | * The device private data structure containing all the |
| 212 | * data read from secure world. |
| 213 | */ |
| 214 | struct ffa_priv { |
| 215 | u32 fwk_version; |
| 216 | struct udevice *emul; |
| 217 | u16 id; |
| 218 | struct ffa_partitions partitions; |
| 219 | struct ffa_rxtxpair pair; |
| 220 | }; |
| 221 | |
| 222 | /** |
| 223 | * ffa_get_version_hdlr() - FFA_VERSION handler function |
| 224 | * @dev: The FF-A bus device |
| 225 | * |
| 226 | * Implement FFA_VERSION FF-A function |
| 227 | * to get from the secure world the FF-A framework version |
| 228 | * FFA_VERSION is used to discover the FF-A framework. |
| 229 | * |
| 230 | * Return: |
| 231 | * |
| 232 | * 0 on success. Otherwise, failure |
| 233 | */ |
| 234 | int ffa_get_version_hdlr(struct udevice *dev); |
| 235 | |
| 236 | /** |
| 237 | * invoke_ffa_fn() - SMC wrapper |
| 238 | * @args: FF-A ABI arguments to be copied to Xn registers |
| 239 | * @res: FF-A ABI return data to be copied from Xn registers |
| 240 | * |
| 241 | * Calls low level SMC implementation. |
| 242 | * This function should be implemented by the user driver. |
| 243 | */ |
| 244 | void invoke_ffa_fn(ffa_value_t args, ffa_value_t *res); |
| 245 | |
| 246 | #endif |