blob: d1a74ab47a9821a7a98d8ac5a548866f0cb0dec7 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0+
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -07002/*
3 * Freescale Layerscape MC I/O wrapper
4 *
Yogesh Gaura6f2a6e2018-05-09 10:52:17 +05305 * Copyright 2013-2016 Freescale Semiconductor, Inc.
Ioana Ciornei95f309a2023-05-31 19:04:32 +03006 * Copyright 2017, 2023 NXP
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -07007 */
8
9#include <fsl-mc/fsl_mc_sys.h>
10#include <fsl-mc/fsl_mc_cmd.h>
11#include <fsl-mc/fsl_dprc.h>
12
Ioana Ciornei95f309a2023-05-31 19:04:32 +030013/**
14 * dprc_get_container_id - Get container ID associated with a given portal.
15 * @mc_io: Pointer to Mc portal's I/O object
16 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
17 * @container_id: Requested container id
18 *
19 * Return: '0' on Success; Error code otherwise.
20 */
21int dprc_get_container_id(struct fsl_mc_io *mc_io, u32 cmd_flags, int *container_id)
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070022{
23 struct mc_command cmd = { 0 };
24 int err;
25
26 /* prepare command */
27 cmd.header = mc_encode_cmd_header(DPRC_CMDID_GET_CONT_ID,
Prabhakar Kushwaha87457d12015-07-07 15:40:06 +053028 cmd_flags,
29 0);
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070030
31 /* send command to mc*/
32 err = mc_send_command(mc_io, &cmd);
33 if (err)
34 return err;
35
36 /* retrieve response parameters */
Ioana Ciornei95f309a2023-05-31 19:04:32 +030037 *container_id = (int)mc_cmd_read_object_id(&cmd);
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070038
39 return 0;
40}
41
Ioana Ciornei95f309a2023-05-31 19:04:32 +030042/**
43 * dprc_open() - Open DPRC object for use
44 * @mc_io: Pointer to MC portal's I/O object
45 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
46 * @container_id: Container ID to open
47 * @token: Returned token of DPRC object
48 *
49 * Return: '0' on Success; Error code otherwise.
50 *
51 * @warning Required before any operation on the object.
52 */
53int dprc_open(struct fsl_mc_io *mc_io, u32 cmd_flags, int container_id, u16 *token)
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070054{
Ioana Ciornei95f309a2023-05-31 19:04:32 +030055 struct dprc_cmd_open *cmd_params;
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070056 struct mc_command cmd = { 0 };
57 int err;
58
59 /* prepare command */
Prabhakar Kushwaha87457d12015-07-07 15:40:06 +053060 cmd.header = mc_encode_cmd_header(DPRC_CMDID_OPEN, cmd_flags,
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070061 0);
Ioana Ciornei95f309a2023-05-31 19:04:32 +030062 cmd_params = (struct dprc_cmd_open *)cmd.params;
63 cmd_params->container_id = cpu_to_le32(container_id);
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070064
65 /* send command to mc*/
66 err = mc_send_command(mc_io, &cmd);
67 if (err)
68 return err;
69
70 /* retrieve response parameters */
Ioana Ciornei95f309a2023-05-31 19:04:32 +030071 *token = mc_cmd_hdr_read_token(&cmd);
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070072
73 return 0;
74}
75
Ioana Ciornei95f309a2023-05-31 19:04:32 +030076/**
77 * dprc_close() - Close the control session of the object
78 * @mc_io: Pointer to MC portal's I/O object
79 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
80 * @token: Token of DPRC object
81 *
82 * After this function is called, no further operations are
83 * allowed on the object without opening a new control session.
84 *
85 * Return: '0' on Success; Error code otherwise.
86 */
87int dprc_close(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token)
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070088{
89 struct mc_command cmd = { 0 };
90
91 /* prepare command */
Prabhakar Kushwaha87457d12015-07-07 15:40:06 +053092 cmd.header = mc_encode_cmd_header(DPRC_CMDID_CLOSE, cmd_flags,
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -070093 token);
94
95 /* send command to mc*/
96 return mc_send_command(mc_io, &cmd);
97}
98
Ioana Ciornei95f309a2023-05-31 19:04:32 +030099/**
100 * dprc_create_container() - Create child container
101 * @mc_io: Pointer to MC portal's I/O object
102 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
103 * @token: Token of DPRC object
104 * @cfg: Child container configuration
105 * @child_container_id: Returned child container ID
106 * @child_portal_offset:Returned child portal offset from MC portal base
107 *
108 * Return: '0' on Success; Error code otherwise.
109 */
110int dprc_create_container(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
111 struct dprc_cfg *cfg, int *child_container_id,
112 uint64_t *child_portal_offset)
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530113{
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300114 struct dprc_cmd_create_container *cmd_params;
115 struct dprc_rsp_create_container *rsp_params;
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530116 struct mc_command cmd = { 0 };
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300117 int err, i;
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530118
119 /* prepare command */
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530120 cmd.header = mc_encode_cmd_header(DPRC_CMDID_CREATE_CONT,
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300121 cmd_flags, token);
122 cmd_params = (struct dprc_cmd_create_container *)cmd.params;
123 cmd_params->options = cpu_to_le32(cfg->options);
124 cmd_params->icid = cpu_to_le32(cfg->icid);
125 cmd_params->portal_id = cpu_to_le32(cfg->portal_id);
126 for (i = 0; i < 16; i++)
127 cmd_params->label[i] = cfg->label[i];
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530128
129 /* send command to mc*/
130 err = mc_send_command(mc_io, &cmd);
131 if (err)
132 return err;
133
134 /* retrieve response parameters */
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300135 rsp_params = (struct dprc_rsp_create_container *)cmd.params;
136 *child_container_id = le32_to_cpu(rsp_params->child_container_id);
137 *child_portal_offset = le64_to_cpu(rsp_params->child_portal_addr);
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530138
139 return 0;
140}
141
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300142/**
143 * dprc_destroy_container() - Destroy child container.
144 * @mc_io: Pointer to MC portal's I/O object
145 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
146 * @token: Token of DPRC object
147 * @child_container_id: ID of the container to destroy
148 *
149 * This function terminates the child container, so following this call the
150 * child container ID becomes invalid.
151 *
152 * Notes:
153 * - All resources and objects of the destroyed container are returned to the
154 * parent container or destroyed if were created be the destroyed container.
155 * - This function destroy all the child containers of the specified
156 * container prior to destroying the container itself.
157 *
158 * warning: Only the parent container is allowed to destroy a child policy
159 * Container 0 can't be destroyed
160 *
161 * Return: '0' on Success; Error code otherwise.
162 *
163 */
164int dprc_destroy_container(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530165 int child_container_id)
166{
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300167 struct dprc_cmd_destroy_container *cmd_params;
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530168 struct mc_command cmd = { 0 };
169
170 /* prepare command */
171 cmd.header = mc_encode_cmd_header(DPRC_CMDID_DESTROY_CONT,
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300172 cmd_flags, token);
173 cmd_params = (struct dprc_cmd_destroy_container *)cmd.params;
174 cmd_params->child_container_id = cpu_to_le32(child_container_id);
Prabhakar Kushwaha1ebbe4f2015-11-04 12:25:53 +0530175
176 /* send command to mc*/
177 return mc_send_command(mc_io, &cmd);
178}
179
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300180/**
181 * dprc_connect() - Connect two endpoints to create a network link between them
182 * @mc_io: Pointer to MC portal's I/O object
183 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
184 * @token: Token of DPRC object
185 * @endpoint1: Endpoint 1 configuration parameters
186 * @endpoint2: Endpoint 2 configuration parameters
187 * @cfg: Connection configuration. The connection configuration
188 * is ignored for connections made to DPMAC objects, where
189 * rate is retrieved from the MAC configuration.
190 *
191 * Return: '0' on Success; Error code otherwise.
192 */
193int dprc_connect(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700194 const struct dprc_endpoint *endpoint1,
Prabhakar Kushwaha87457d12015-07-07 15:40:06 +0530195 const struct dprc_endpoint *endpoint2,
196 const struct dprc_connection_cfg *cfg)
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700197{
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300198 struct dprc_cmd_connect *cmd_params;
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700199 struct mc_command cmd = { 0 };
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300200 int i;
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700201
202 /* prepare command */
203 cmd.header = mc_encode_cmd_header(DPRC_CMDID_CONNECT,
Prabhakar Kushwaha87457d12015-07-07 15:40:06 +0530204 cmd_flags,
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700205 token);
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300206 cmd_params = (struct dprc_cmd_connect *)cmd.params;
207 cmd_params->ep1_id = cpu_to_le32(endpoint1->id);
208 cmd_params->ep1_interface_id = cpu_to_le16(endpoint1->if_id);
209 cmd_params->ep2_id = cpu_to_le32(endpoint2->id);
210 cmd_params->ep2_interface_id = cpu_to_le16(endpoint2->if_id);
211 cmd_params->max_rate = cpu_to_le32(cfg->max_rate);
212 cmd_params->committed_rate = cpu_to_le32(cfg->committed_rate);
213 for (i = 0; i < 16; i++) {
214 cmd_params->ep1_type[i] = endpoint1->type[i];
215 cmd_params->ep2_type[i] = endpoint2->type[i];
216 }
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700217
218 /* send command to mc*/
219 return mc_send_command(mc_io, &cmd);
220}
221
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300222/**
223 * dprc_disconnect() - Disconnect one endpoint to remove its network connection
224 * @mc_io: Pointer to MC portal's I/O object
225 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
226 * @token: Token of DPRC object
227 * @endpoint: Endpoint configuration parameters
228 *
229 * Return: '0' on Success; Error code otherwise.
230 */
231int dprc_disconnect(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700232 const struct dprc_endpoint *endpoint)
233{
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300234 struct dprc_cmd_disconnect *cmd_params;
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700235 struct mc_command cmd = { 0 };
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300236 int i;
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700237
238 /* prepare command */
239 cmd.header = mc_encode_cmd_header(DPRC_CMDID_DISCONNECT,
Prabhakar Kushwaha87457d12015-07-07 15:40:06 +0530240 cmd_flags,
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700241 token);
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300242 cmd_params = (struct dprc_cmd_disconnect *)cmd.params;
243 cmd_params->id = cpu_to_le32(endpoint->id);
244 cmd_params->interface_id = cpu_to_le32(endpoint->if_id);
245 for (i = 0; i < 16; i++)
246 cmd_params->type[i] = endpoint->type[i];
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700247
248 /* send command to mc*/
249 return mc_send_command(mc_io, &cmd);
250}
251
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300252/**
253 * dprc_get_connection() - Get connected endpoint and link status if connection
254 * exists.
255 * @mc_io: Pointer to MC portal's I/O object
256 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
257 * @token: Token of DPRC object
258 * @endpoint1: Endpoint 1 configuration parameters
259 * @endpoint2: Returned endpoint 2 configuration parameters
260 * @state: Returned link state:
261 * 1 - link is up;
262 * 0 - link is down;
263 * -1 - no connection (endpoint2 information is irrelevant)
264 *
265 * Return: '0' on Success; -ENAVAIL if connection does not exist.
266 */
267int dprc_get_connection(struct fsl_mc_io *mc_io, u32 cmd_flags, u16 token,
Prabhakar Kushwaha87457d12015-07-07 15:40:06 +0530268 const struct dprc_endpoint *endpoint1,
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300269 struct dprc_endpoint *endpoint2, int *state)
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700270{
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300271 struct dprc_cmd_get_connection *cmd_params;
272 struct dprc_rsp_get_connection *rsp_params;
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700273 struct mc_command cmd = { 0 };
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300274 int err, i;
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700275
276 /* prepare command */
277 cmd.header = mc_encode_cmd_header(DPRC_CMDID_GET_CONNECTION,
Prabhakar Kushwaha87457d12015-07-07 15:40:06 +0530278 cmd_flags,
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700279 token);
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300280 cmd_params = (struct dprc_cmd_get_connection *)cmd.params;
281 cmd_params->ep1_id = cpu_to_le32(endpoint1->id);
282 cmd_params->ep1_interface_id = cpu_to_le16(endpoint1->if_id);
283 for (i = 0; i < 16; i++)
284 cmd_params->ep1_type[i] = endpoint1->type[i];
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700285
286 /* send command to mc*/
287 err = mc_send_command(mc_io, &cmd);
288 if (err)
289 return err;
290
291 /* retrieve response parameters */
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300292 rsp_params = (struct dprc_rsp_get_connection *)cmd.params;
293 endpoint2->id = le32_to_cpu(rsp_params->ep2_id);
294 endpoint2->if_id = le16_to_cpu(rsp_params->ep2_interface_id);
295 *state = le32_to_cpu(rsp_params->state);
296 for (i = 0; i < 16; i++)
297 endpoint2->type[i] = rsp_params->ep2_type[i];
Prabhakar Kushwahaa2a55e52015-03-19 09:20:45 -0700298
299 return 0;
300}
Yogesh Gaur2557c5a2017-11-15 11:59:31 +0530301
Ioana Ciornei95f309a2023-05-31 19:04:32 +0300302/**
303 * dprc_get_api_version - Get Data Path Resource Container API version
304 * @mc_io: Pointer to Mc portal's I/O object
305 * @cmd_flags: Command flags; one or more of 'MC_CMD_FLAG_'
306 * @major_ver: Major version of Data Path Resource Container API
307 * @minor_ver: Minor version of Data Path Resource Container API
308 *
309 * Return: '0' on Success; Error code otherwise.
310 */
311int dprc_get_api_version(struct fsl_mc_io *mc_io, u32 cmd_flags,
312 u16 *major_ver, u16 *minor_ver)
Yogesh Gaur2557c5a2017-11-15 11:59:31 +0530313{
314 struct mc_command cmd = { 0 };
315 int err;
316
317 /* prepare command */
318 cmd.header = mc_encode_cmd_header(DPRC_CMDID_GET_API_VERSION,
319 cmd_flags, 0);
320
321 /* send command to mc */
322 err = mc_send_command(mc_io, &cmd);
323 if (err)
324 return err;
325
326 /* retrieve response parameters */
327 mc_cmd_read_api_version(&cmd, major_ver, minor_ver);
328
329 return 0;
330}