xref: /linux/drivers/net/ethernet/intel/ice/devlink/port.c (revision 7f81907b7e3f93dfed2e903af52659baa4944341)
1 // SPDX-License-Identifier: GPL-2.0
2 /* Copyright (c) 2024, Intel Corporation. */
3 
4 #include <linux/vmalloc.h>
5 
6 #include "ice.h"
7 #include "devlink.h"
8 #include "port.h"
9 #include "ice_lib.h"
10 #include "ice_fltr.h"
11 
12 static int ice_active_port_option = -1;
13 
14 /**
15  * ice_devlink_port_opt_speed_str - convert speed to a string
16  * @speed: speed value
17  */
18 static const char *ice_devlink_port_opt_speed_str(u8 speed)
19 {
20 	switch (speed & ICE_AQC_PORT_OPT_MAX_LANE_M) {
21 	case ICE_AQC_PORT_OPT_MAX_LANE_100M:
22 		return "0.1";
23 	case ICE_AQC_PORT_OPT_MAX_LANE_1G:
24 		return "1";
25 	case ICE_AQC_PORT_OPT_MAX_LANE_2500M:
26 		return "2.5";
27 	case ICE_AQC_PORT_OPT_MAX_LANE_5G:
28 		return "5";
29 	case ICE_AQC_PORT_OPT_MAX_LANE_10G:
30 		return "10";
31 	case ICE_AQC_PORT_OPT_MAX_LANE_25G:
32 		return "25";
33 	case ICE_AQC_PORT_OPT_MAX_LANE_50G:
34 		return "50";
35 	case ICE_AQC_PORT_OPT_MAX_LANE_100G:
36 		return "100";
37 	}
38 
39 	return "-";
40 }
41 
42 #define ICE_PORT_OPT_DESC_LEN	50
43 /**
44  * ice_devlink_port_options_print - Print available port split options
45  * @pf: the PF to print split port options
46  *
47  * Prints a table with available port split options and max port speeds
48  */
49 static void ice_devlink_port_options_print(struct ice_pf *pf)
50 {
51 	u8 i, j, options_count, cnt, speed, pending_idx, active_idx;
52 	struct ice_aqc_get_port_options_elem *options, *opt;
53 	struct device *dev = ice_pf_to_dev(pf);
54 	bool active_valid, pending_valid;
55 	char desc[ICE_PORT_OPT_DESC_LEN];
56 	const char *str;
57 	int status;
58 
59 	options = kcalloc(ICE_AQC_PORT_OPT_MAX * ICE_MAX_PORT_PER_PCI_DEV,
60 			  sizeof(*options), GFP_KERNEL);
61 	if (!options)
62 		return;
63 
64 	for (i = 0; i < ICE_MAX_PORT_PER_PCI_DEV; i++) {
65 		opt = options + i * ICE_AQC_PORT_OPT_MAX;
66 		options_count = ICE_AQC_PORT_OPT_MAX;
67 		active_valid = 0;
68 
69 		status = ice_aq_get_port_options(&pf->hw, opt, &options_count,
70 						 i, true, &active_idx,
71 						 &active_valid, &pending_idx,
72 						 &pending_valid);
73 		if (status) {
74 			dev_dbg(dev, "Couldn't read port option for port %d, err %d\n",
75 				i, status);
76 			goto err;
77 		}
78 	}
79 
80 	dev_dbg(dev, "Available port split options and max port speeds (Gbps):\n");
81 	dev_dbg(dev, "Status  Split      Quad 0          Quad 1\n");
82 	dev_dbg(dev, "        count  L0  L1  L2  L3  L4  L5  L6  L7\n");
83 
84 	for (i = 0; i < options_count; i++) {
85 		cnt = 0;
86 
87 		if (i == ice_active_port_option)
88 			str = "Active";
89 		else if ((i == pending_idx) && pending_valid)
90 			str = "Pending";
91 		else
92 			str = "";
93 
94 		cnt += snprintf(&desc[cnt], ICE_PORT_OPT_DESC_LEN - cnt,
95 				"%-8s", str);
96 
97 		cnt += snprintf(&desc[cnt], ICE_PORT_OPT_DESC_LEN - cnt,
98 				"%-6u", options[i].pmd);
99 
100 		for (j = 0; j < ICE_MAX_PORT_PER_PCI_DEV; ++j) {
101 			speed = options[i + j * ICE_AQC_PORT_OPT_MAX].max_lane_speed;
102 			str = ice_devlink_port_opt_speed_str(speed);
103 			cnt += snprintf(&desc[cnt], ICE_PORT_OPT_DESC_LEN - cnt,
104 					"%3s ", str);
105 		}
106 
107 		dev_dbg(dev, "%s\n", desc);
108 	}
109 
110 err:
111 	kfree(options);
112 }
113 
114 /**
115  * ice_devlink_aq_set_port_option - Send set port option admin queue command
116  * @pf: the PF to print split port options
117  * @option_idx: selected port option
118  * @extack: extended netdev ack structure
119  *
120  * Sends set port option admin queue command with selected port option and
121  * calls NVM write activate.
122  */
123 static int
124 ice_devlink_aq_set_port_option(struct ice_pf *pf, u8 option_idx,
125 			       struct netlink_ext_ack *extack)
126 {
127 	struct device *dev = ice_pf_to_dev(pf);
128 	int status;
129 
130 	status = ice_aq_set_port_option(&pf->hw, 0, true, option_idx);
131 	if (status) {
132 		dev_dbg(dev, "ice_aq_set_port_option, err %d aq_err %d\n",
133 			status, pf->hw.adminq.sq_last_status);
134 		NL_SET_ERR_MSG_MOD(extack, "Port split request failed");
135 		return -EIO;
136 	}
137 
138 	status = ice_acquire_nvm(&pf->hw, ICE_RES_WRITE);
139 	if (status) {
140 		dev_dbg(dev, "ice_acquire_nvm failed, err %d aq_err %d\n",
141 			status, pf->hw.adminq.sq_last_status);
142 		NL_SET_ERR_MSG_MOD(extack, "Failed to acquire NVM semaphore");
143 		return -EIO;
144 	}
145 
146 	status = ice_nvm_write_activate(&pf->hw, ICE_AQC_NVM_ACTIV_REQ_EMPR, NULL);
147 	if (status) {
148 		dev_dbg(dev, "ice_nvm_write_activate failed, err %d aq_err %d\n",
149 			status, pf->hw.adminq.sq_last_status);
150 		NL_SET_ERR_MSG_MOD(extack, "Port split request failed to save data");
151 		ice_release_nvm(&pf->hw);
152 		return -EIO;
153 	}
154 
155 	ice_release_nvm(&pf->hw);
156 
157 	NL_SET_ERR_MSG_MOD(extack, "Reboot required to finish port split");
158 	return 0;
159 }
160 
161 /**
162  * ice_devlink_port_split - .port_split devlink handler
163  * @devlink: devlink instance structure
164  * @port: devlink port structure
165  * @count: number of ports to split to
166  * @extack: extended netdev ack structure
167  *
168  * Callback for the devlink .port_split operation.
169  *
170  * Unfortunately, the devlink expression of available options is limited
171  * to just a number, so search for an FW port option which supports
172  * the specified number. As there could be multiple FW port options with
173  * the same port split count, allow switching between them. When the same
174  * port split count request is issued again, switch to the next FW port
175  * option with the same port split count.
176  *
177  * Return: zero on success or an error code on failure.
178  */
179 static int
180 ice_devlink_port_split(struct devlink *devlink, struct devlink_port *port,
181 		       unsigned int count, struct netlink_ext_ack *extack)
182 {
183 	struct ice_aqc_get_port_options_elem options[ICE_AQC_PORT_OPT_MAX];
184 	u8 i, j, active_idx, pending_idx, new_option;
185 	struct ice_pf *pf = devlink_priv(devlink);
186 	u8 option_count = ICE_AQC_PORT_OPT_MAX;
187 	struct device *dev = ice_pf_to_dev(pf);
188 	bool active_valid, pending_valid;
189 	int status;
190 
191 	status = ice_aq_get_port_options(&pf->hw, options, &option_count,
192 					 0, true, &active_idx, &active_valid,
193 					 &pending_idx, &pending_valid);
194 	if (status) {
195 		dev_dbg(dev, "Couldn't read port split options, err = %d\n",
196 			status);
197 		NL_SET_ERR_MSG_MOD(extack, "Failed to get available port split options");
198 		return -EIO;
199 	}
200 
201 	new_option = ICE_AQC_PORT_OPT_MAX;
202 	active_idx = pending_valid ? pending_idx : active_idx;
203 	for (i = 1; i <= option_count; i++) {
204 		/* In order to allow switching between FW port options with
205 		 * the same port split count, search for a new option starting
206 		 * from the active/pending option (with array wrap around).
207 		 */
208 		j = (active_idx + i) % option_count;
209 
210 		if (count == options[j].pmd) {
211 			new_option = j;
212 			break;
213 		}
214 	}
215 
216 	if (new_option == active_idx) {
217 		dev_dbg(dev, "request to split: count: %u is already set and there are no other options\n",
218 			count);
219 		NL_SET_ERR_MSG_MOD(extack, "Requested split count is already set");
220 		ice_devlink_port_options_print(pf);
221 		return -EINVAL;
222 	}
223 
224 	if (new_option == ICE_AQC_PORT_OPT_MAX) {
225 		dev_dbg(dev, "request to split: count: %u not found\n", count);
226 		NL_SET_ERR_MSG_MOD(extack, "Port split requested unsupported port config");
227 		ice_devlink_port_options_print(pf);
228 		return -EINVAL;
229 	}
230 
231 	status = ice_devlink_aq_set_port_option(pf, new_option, extack);
232 	if (status)
233 		return status;
234 
235 	ice_devlink_port_options_print(pf);
236 
237 	return 0;
238 }
239 
240 /**
241  * ice_devlink_port_unsplit - .port_unsplit devlink handler
242  * @devlink: devlink instance structure
243  * @port: devlink port structure
244  * @extack: extended netdev ack structure
245  *
246  * Callback for the devlink .port_unsplit operation.
247  * Calls ice_devlink_port_split with split count set to 1.
248  * There could be no FW option available with split count 1.
249  *
250  * Return: zero on success or an error code on failure.
251  */
252 static int
253 ice_devlink_port_unsplit(struct devlink *devlink, struct devlink_port *port,
254 			 struct netlink_ext_ack *extack)
255 {
256 	return ice_devlink_port_split(devlink, port, 1, extack);
257 }
258 
259 /**
260  * ice_devlink_set_port_split_options - Set port split options
261  * @pf: the PF to set port split options
262  * @attrs: devlink attributes
263  *
264  * Sets devlink port split options based on available FW port options
265  */
266 static void
267 ice_devlink_set_port_split_options(struct ice_pf *pf,
268 				   struct devlink_port_attrs *attrs)
269 {
270 	struct ice_aqc_get_port_options_elem options[ICE_AQC_PORT_OPT_MAX];
271 	u8 i, active_idx, pending_idx, option_count = ICE_AQC_PORT_OPT_MAX;
272 	bool active_valid, pending_valid;
273 	int status;
274 
275 	status = ice_aq_get_port_options(&pf->hw, options, &option_count,
276 					 0, true, &active_idx, &active_valid,
277 					 &pending_idx, &pending_valid);
278 	if (status) {
279 		dev_dbg(ice_pf_to_dev(pf), "Couldn't read port split options, err = %d\n",
280 			status);
281 		return;
282 	}
283 
284 	/* find the biggest available port split count */
285 	for (i = 0; i < option_count; i++)
286 		attrs->lanes = max_t(int, attrs->lanes, options[i].pmd);
287 
288 	attrs->splittable = attrs->lanes ? 1 : 0;
289 	ice_active_port_option = active_idx;
290 }
291 
292 static const struct devlink_port_ops ice_devlink_port_ops = {
293 	.port_split = ice_devlink_port_split,
294 	.port_unsplit = ice_devlink_port_unsplit,
295 };
296 
297 /**
298  * ice_devlink_set_switch_id - Set unique switch id based on pci dsn
299  * @pf: the PF to create a devlink port for
300  * @ppid: struct with switch id information
301  */
302 static void
303 ice_devlink_set_switch_id(struct ice_pf *pf, struct netdev_phys_item_id *ppid)
304 {
305 	struct pci_dev *pdev = pf->pdev;
306 	u64 id;
307 
308 	id = pci_get_dsn(pdev);
309 
310 	ppid->id_len = sizeof(id);
311 	put_unaligned_be64(id, &ppid->id);
312 }
313 
314 /**
315  * ice_devlink_create_pf_port - Create a devlink port for this PF
316  * @pf: the PF to create a devlink port for
317  *
318  * Create and register a devlink_port for this PF.
319  * This function has to be called under devl_lock.
320  *
321  * Return: zero on success or an error code on failure.
322  */
323 int ice_devlink_create_pf_port(struct ice_pf *pf)
324 {
325 	struct devlink_port_attrs attrs = {};
326 	struct devlink_port *devlink_port;
327 	struct devlink *devlink;
328 	struct ice_vsi *vsi;
329 	struct device *dev;
330 	int err;
331 
332 	devlink = priv_to_devlink(pf);
333 
334 	dev = ice_pf_to_dev(pf);
335 
336 	devlink_port = &pf->devlink_port;
337 
338 	vsi = ice_get_main_vsi(pf);
339 	if (!vsi)
340 		return -EIO;
341 
342 	attrs.flavour = DEVLINK_PORT_FLAVOUR_PHYSICAL;
343 	attrs.phys.port_number = pf->hw.pf_id;
344 
345 	/* As FW supports only port split options for whole device,
346 	 * set port split options only for first PF.
347 	 */
348 	if (pf->hw.pf_id == 0)
349 		ice_devlink_set_port_split_options(pf, &attrs);
350 
351 	ice_devlink_set_switch_id(pf, &attrs.switch_id);
352 
353 	devlink_port_attrs_set(devlink_port, &attrs);
354 
355 	err = devl_port_register_with_ops(devlink, devlink_port, vsi->idx,
356 					  &ice_devlink_port_ops);
357 	if (err) {
358 		dev_err(dev, "Failed to create devlink port for PF %d, error %d\n",
359 			pf->hw.pf_id, err);
360 		return err;
361 	}
362 
363 	return 0;
364 }
365 
366 /**
367  * ice_devlink_destroy_pf_port - Destroy the devlink_port for this PF
368  * @pf: the PF to cleanup
369  *
370  * Unregisters the devlink_port structure associated with this PF.
371  * This function has to be called under devl_lock.
372  */
373 void ice_devlink_destroy_pf_port(struct ice_pf *pf)
374 {
375 	devl_port_unregister(&pf->devlink_port);
376 }
377 
378 /**
379  * ice_devlink_port_get_vf_fn_mac - .port_fn_hw_addr_get devlink handler
380  * @port: devlink port structure
381  * @hw_addr: MAC address of the port
382  * @hw_addr_len: length of MAC address
383  * @extack: extended netdev ack structure
384  *
385  * Callback for the devlink .port_fn_hw_addr_get operation
386  * Return: zero on success or an error code on failure.
387  */
388 static int ice_devlink_port_get_vf_fn_mac(struct devlink_port *port,
389 					  u8 *hw_addr, int *hw_addr_len,
390 					  struct netlink_ext_ack *extack)
391 {
392 	struct ice_vf *vf = container_of(port, struct ice_vf, devlink_port);
393 
394 	ether_addr_copy(hw_addr, vf->dev_lan_addr);
395 	*hw_addr_len = ETH_ALEN;
396 
397 	return 0;
398 }
399 
400 /**
401  * ice_devlink_port_set_vf_fn_mac - .port_fn_hw_addr_set devlink handler
402  * @port: devlink port structure
403  * @hw_addr: MAC address of the port
404  * @hw_addr_len: length of MAC address
405  * @extack: extended netdev ack structure
406  *
407  * Callback for the devlink .port_fn_hw_addr_set operation
408  * Return: zero on success or an error code on failure.
409  */
410 static int ice_devlink_port_set_vf_fn_mac(struct devlink_port *port,
411 					  const u8 *hw_addr,
412 					  int hw_addr_len,
413 					  struct netlink_ext_ack *extack)
414 
415 {
416 	struct devlink_port_attrs *attrs = &port->attrs;
417 	struct devlink_port_pci_vf_attrs *pci_vf;
418 	struct devlink *devlink = port->devlink;
419 	struct ice_pf *pf;
420 	u16 vf_id;
421 
422 	pf = devlink_priv(devlink);
423 	pci_vf = &attrs->pci_vf;
424 	vf_id = pci_vf->vf;
425 
426 	return __ice_set_vf_mac(pf, vf_id, hw_addr);
427 }
428 
429 static const struct devlink_port_ops ice_devlink_vf_port_ops = {
430 	.port_fn_hw_addr_get = ice_devlink_port_get_vf_fn_mac,
431 	.port_fn_hw_addr_set = ice_devlink_port_set_vf_fn_mac,
432 };
433 
434 /**
435  * ice_devlink_create_vf_port - Create a devlink port for this VF
436  * @vf: the VF to create a port for
437  *
438  * Create and register a devlink_port for this VF.
439  *
440  * Return: zero on success or an error code on failure.
441  */
442 int ice_devlink_create_vf_port(struct ice_vf *vf)
443 {
444 	struct devlink_port_attrs attrs = {};
445 	struct devlink_port *devlink_port;
446 	struct devlink *devlink;
447 	struct ice_vsi *vsi;
448 	struct device *dev;
449 	struct ice_pf *pf;
450 	int err;
451 
452 	pf = vf->pf;
453 	dev = ice_pf_to_dev(pf);
454 	devlink_port = &vf->devlink_port;
455 
456 	vsi = ice_get_vf_vsi(vf);
457 	if (!vsi)
458 		return -EINVAL;
459 
460 	attrs.flavour = DEVLINK_PORT_FLAVOUR_PCI_VF;
461 	attrs.pci_vf.pf = pf->hw.pf_id;
462 	attrs.pci_vf.vf = vf->vf_id;
463 
464 	ice_devlink_set_switch_id(pf, &attrs.switch_id);
465 
466 	devlink_port_attrs_set(devlink_port, &attrs);
467 	devlink = priv_to_devlink(pf);
468 
469 	err = devl_port_register_with_ops(devlink, devlink_port, vsi->idx,
470 					  &ice_devlink_vf_port_ops);
471 	if (err) {
472 		dev_err(dev, "Failed to create devlink port for VF %d, error %d\n",
473 			vf->vf_id, err);
474 		return err;
475 	}
476 
477 	return 0;
478 }
479 
480 /**
481  * ice_devlink_destroy_vf_port - Destroy the devlink_port for this VF
482  * @vf: the VF to cleanup
483  *
484  * Unregisters the devlink_port structure associated with this VF.
485  */
486 void ice_devlink_destroy_vf_port(struct ice_vf *vf)
487 {
488 	devl_rate_leaf_destroy(&vf->devlink_port);
489 	devl_port_unregister(&vf->devlink_port);
490 }
491 
492 /**
493  * ice_devlink_create_sf_dev_port - Register virtual port for a subfunction
494  * @sf_dev: the subfunction device to create a devlink port for
495  *
496  * Register virtual flavour devlink port for the subfunction auxiliary device
497  * created after activating a dynamically added devlink port.
498  *
499  * Return: zero on success or an error code on failure.
500  */
501 int ice_devlink_create_sf_dev_port(struct ice_sf_dev *sf_dev)
502 {
503 	struct devlink_port_attrs attrs = {};
504 	struct ice_dynamic_port *dyn_port;
505 	struct devlink_port *devlink_port;
506 	struct devlink *devlink;
507 	struct ice_vsi *vsi;
508 
509 	dyn_port = sf_dev->dyn_port;
510 	vsi = dyn_port->vsi;
511 
512 	devlink_port = &sf_dev->priv->devlink_port;
513 
514 	attrs.flavour = DEVLINK_PORT_FLAVOUR_VIRTUAL;
515 
516 	devlink_port_attrs_set(devlink_port, &attrs);
517 	devlink = priv_to_devlink(sf_dev->priv);
518 
519 	return devl_port_register(devlink, devlink_port, vsi->idx);
520 }
521 
522 /**
523  * ice_devlink_destroy_sf_dev_port - Destroy virtual port for a subfunction
524  * @sf_dev: the subfunction device to create a devlink port for
525  *
526  * Unregisters the virtual port associated with this subfunction.
527  */
528 void ice_devlink_destroy_sf_dev_port(struct ice_sf_dev *sf_dev)
529 {
530 	devl_port_unregister(&sf_dev->priv->devlink_port);
531 }
532 
533 /**
534  * ice_activate_dynamic_port - Activate a dynamic port
535  * @dyn_port: dynamic port instance to activate
536  * @extack: extack for reporting error messages
537  *
538  * Activate the dynamic port based on its flavour.
539  *
540  * Return: zero on success or an error code on failure.
541  */
542 static int
543 ice_activate_dynamic_port(struct ice_dynamic_port *dyn_port,
544 			  struct netlink_ext_ack *extack)
545 {
546 	int err;
547 
548 	if (dyn_port->active)
549 		return 0;
550 
551 	err = ice_sf_eth_activate(dyn_port, extack);
552 	if (err)
553 		return err;
554 
555 	dyn_port->active = true;
556 
557 	return 0;
558 }
559 
560 /**
561  * ice_deactivate_dynamic_port - Deactivate a dynamic port
562  * @dyn_port: dynamic port instance to deactivate
563  *
564  * Undo activation of a dynamic port.
565  */
566 static void ice_deactivate_dynamic_port(struct ice_dynamic_port *dyn_port)
567 {
568 	if (!dyn_port->active)
569 		return;
570 
571 	ice_sf_eth_deactivate(dyn_port);
572 	dyn_port->active = false;
573 }
574 
575 /**
576  * ice_dealloc_dynamic_port - Deallocate and remove a dynamic port
577  * @dyn_port: dynamic port instance to deallocate
578  *
579  * Free resources associated with a dynamically added devlink port. Will
580  * deactivate the port if its currently active.
581  */
582 static void ice_dealloc_dynamic_port(struct ice_dynamic_port *dyn_port)
583 {
584 	struct devlink_port *devlink_port = &dyn_port->devlink_port;
585 	struct ice_pf *pf = dyn_port->pf;
586 
587 	ice_deactivate_dynamic_port(dyn_port);
588 
589 	xa_erase(&pf->sf_nums, devlink_port->attrs.pci_sf.sf);
590 	ice_eswitch_detach_sf(pf, dyn_port);
591 	ice_vsi_free(dyn_port->vsi);
592 	xa_erase(&pf->dyn_ports, dyn_port->vsi->idx);
593 	kfree(dyn_port);
594 }
595 
596 /**
597  * ice_dealloc_all_dynamic_ports - Deallocate all dynamic devlink ports
598  * @pf: pointer to the pf structure
599  */
600 void ice_dealloc_all_dynamic_ports(struct ice_pf *pf)
601 {
602 	struct ice_dynamic_port *dyn_port;
603 	unsigned long index;
604 
605 	xa_for_each(&pf->dyn_ports, index, dyn_port)
606 		ice_dealloc_dynamic_port(dyn_port);
607 }
608 
609 /**
610  * ice_devlink_port_new_check_attr - Check that new port attributes are valid
611  * @pf: pointer to the PF structure
612  * @new_attr: the attributes for the new port
613  * @extack: extack for reporting error messages
614  *
615  * Check that the attributes for the new port are valid before continuing to
616  * allocate the devlink port.
617  *
618  * Return: zero on success or an error code on failure.
619  */
620 static int
621 ice_devlink_port_new_check_attr(struct ice_pf *pf,
622 				const struct devlink_port_new_attrs *new_attr,
623 				struct netlink_ext_ack *extack)
624 {
625 	if (new_attr->flavour != DEVLINK_PORT_FLAVOUR_PCI_SF) {
626 		NL_SET_ERR_MSG_MOD(extack, "Flavour other than pcisf is not supported");
627 		return -EOPNOTSUPP;
628 	}
629 
630 	if (new_attr->controller_valid) {
631 		NL_SET_ERR_MSG_MOD(extack, "Setting controller is not supported");
632 		return -EOPNOTSUPP;
633 	}
634 
635 	if (new_attr->port_index_valid) {
636 		NL_SET_ERR_MSG_MOD(extack, "Driver does not support user defined port index assignment");
637 		return -EOPNOTSUPP;
638 	}
639 
640 	if (new_attr->pfnum != pf->hw.pf_id) {
641 		NL_SET_ERR_MSG_MOD(extack, "Incorrect pfnum supplied");
642 		return -EINVAL;
643 	}
644 
645 	if (!pci_msix_can_alloc_dyn(pf->pdev)) {
646 		NL_SET_ERR_MSG_MOD(extack, "Dynamic MSIX-X interrupt allocation is not supported");
647 		return -EOPNOTSUPP;
648 	}
649 
650 	return 0;
651 }
652 
653 /**
654  * ice_devlink_port_del - devlink handler for port delete
655  * @devlink: pointer to devlink
656  * @port: devlink port to be deleted
657  * @extack: pointer to extack
658  *
659  * Deletes devlink port and deallocates all resources associated with
660  * created subfunction.
661  *
662  * Return: zero on success or an error code on failure.
663  */
664 static int
665 ice_devlink_port_del(struct devlink *devlink, struct devlink_port *port,
666 		     struct netlink_ext_ack *extack)
667 {
668 	struct ice_dynamic_port *dyn_port;
669 
670 	dyn_port = ice_devlink_port_to_dyn(port);
671 	ice_dealloc_dynamic_port(dyn_port);
672 
673 	return 0;
674 }
675 
676 /**
677  * ice_devlink_port_fn_hw_addr_set - devlink handler for mac address set
678  * @port: pointer to devlink port
679  * @hw_addr: hw address to set
680  * @hw_addr_len: hw address length
681  * @extack: extack for reporting error messages
682  *
683  * Sets mac address for the port, verifies arguments and copies address
684  * to the subfunction structure.
685  *
686  * Return: zero on success or an error code on failure.
687  */
688 static int
689 ice_devlink_port_fn_hw_addr_set(struct devlink_port *port, const u8 *hw_addr,
690 				int hw_addr_len,
691 				struct netlink_ext_ack *extack)
692 {
693 	struct ice_dynamic_port *dyn_port;
694 
695 	dyn_port = ice_devlink_port_to_dyn(port);
696 
697 	if (dyn_port->attached) {
698 		NL_SET_ERR_MSG_MOD(extack,
699 				   "Ethernet address can be change only in detached state");
700 		return -EBUSY;
701 	}
702 
703 	if (hw_addr_len != ETH_ALEN || !is_valid_ether_addr(hw_addr)) {
704 		NL_SET_ERR_MSG_MOD(extack, "Invalid ethernet address");
705 		return -EADDRNOTAVAIL;
706 	}
707 
708 	ether_addr_copy(dyn_port->hw_addr, hw_addr);
709 
710 	return 0;
711 }
712 
713 /**
714  * ice_devlink_port_fn_hw_addr_get - devlink handler for mac address get
715  * @port: pointer to devlink port
716  * @hw_addr: hw address to set
717  * @hw_addr_len: hw address length
718  * @extack: extack for reporting error messages
719  *
720  * Returns mac address for the port.
721  *
722  * Return: zero on success or an error code on failure.
723  */
724 static int
725 ice_devlink_port_fn_hw_addr_get(struct devlink_port *port, u8 *hw_addr,
726 				int *hw_addr_len,
727 				struct netlink_ext_ack *extack)
728 {
729 	struct ice_dynamic_port *dyn_port;
730 
731 	dyn_port = ice_devlink_port_to_dyn(port);
732 
733 	ether_addr_copy(hw_addr, dyn_port->hw_addr);
734 	*hw_addr_len = ETH_ALEN;
735 
736 	return 0;
737 }
738 
739 /**
740  * ice_devlink_port_fn_state_set - devlink handler for port state set
741  * @port: pointer to devlink port
742  * @state: state to set
743  * @extack: extack for reporting error messages
744  *
745  * Activates or deactivates the port.
746  *
747  * Return: zero on success or an error code on failure.
748  */
749 static int
750 ice_devlink_port_fn_state_set(struct devlink_port *port,
751 			      enum devlink_port_fn_state state,
752 			      struct netlink_ext_ack *extack)
753 {
754 	struct ice_dynamic_port *dyn_port;
755 
756 	dyn_port = ice_devlink_port_to_dyn(port);
757 
758 	switch (state) {
759 	case DEVLINK_PORT_FN_STATE_ACTIVE:
760 		return ice_activate_dynamic_port(dyn_port, extack);
761 
762 	case DEVLINK_PORT_FN_STATE_INACTIVE:
763 		ice_deactivate_dynamic_port(dyn_port);
764 		break;
765 	}
766 
767 	return 0;
768 }
769 
770 /**
771  * ice_devlink_port_fn_state_get - devlink handler for port state get
772  * @port: pointer to devlink port
773  * @state: admin configured state of the port
774  * @opstate: current port operational state
775  * @extack: extack for reporting error messages
776  *
777  * Gets port state.
778  *
779  * Return: zero on success or an error code on failure.
780  */
781 static int
782 ice_devlink_port_fn_state_get(struct devlink_port *port,
783 			      enum devlink_port_fn_state *state,
784 			      enum devlink_port_fn_opstate *opstate,
785 			      struct netlink_ext_ack *extack)
786 {
787 	struct ice_dynamic_port *dyn_port;
788 
789 	dyn_port = ice_devlink_port_to_dyn(port);
790 
791 	if (dyn_port->active)
792 		*state = DEVLINK_PORT_FN_STATE_ACTIVE;
793 	else
794 		*state = DEVLINK_PORT_FN_STATE_INACTIVE;
795 
796 	if (dyn_port->attached)
797 		*opstate = DEVLINK_PORT_FN_OPSTATE_ATTACHED;
798 	else
799 		*opstate = DEVLINK_PORT_FN_OPSTATE_DETACHED;
800 
801 	return 0;
802 }
803 
804 static const struct devlink_port_ops ice_devlink_port_sf_ops = {
805 	.port_del = ice_devlink_port_del,
806 	.port_fn_hw_addr_get = ice_devlink_port_fn_hw_addr_get,
807 	.port_fn_hw_addr_set = ice_devlink_port_fn_hw_addr_set,
808 	.port_fn_state_get = ice_devlink_port_fn_state_get,
809 	.port_fn_state_set = ice_devlink_port_fn_state_set,
810 };
811 
812 /**
813  * ice_reserve_sf_num - Reserve a subfunction number for this port
814  * @pf: pointer to the pf structure
815  * @new_attr: devlink port attributes requested
816  * @extack: extack for reporting error messages
817  * @sfnum: on success, the sf number reserved
818  *
819  * Reserve a subfunction number for this port. Only called for
820  * DEVLINK_PORT_FLAVOUR_PCI_SF ports.
821  *
822  * Return: zero on success or an error code on failure.
823  */
824 static int
825 ice_reserve_sf_num(struct ice_pf *pf,
826 		   const struct devlink_port_new_attrs *new_attr,
827 		   struct netlink_ext_ack *extack, u32 *sfnum)
828 {
829 	int err;
830 
831 	/* If user didn't request an explicit number, pick one */
832 	if (!new_attr->sfnum_valid)
833 		return xa_alloc(&pf->sf_nums, sfnum, NULL, xa_limit_32b,
834 				GFP_KERNEL);
835 
836 	/* Otherwise, check and use the number provided */
837 	err = xa_insert(&pf->sf_nums, new_attr->sfnum, NULL, GFP_KERNEL);
838 	if (err) {
839 		if (err == -EBUSY)
840 			NL_SET_ERR_MSG_MOD(extack, "Subfunction with given sfnum already exists");
841 		return err;
842 	}
843 
844 	*sfnum = new_attr->sfnum;
845 
846 	return 0;
847 }
848 
849 /**
850  * ice_devlink_create_sf_port - Register PCI subfunction devlink port
851  * @dyn_port: the dynamic port instance structure for this subfunction
852  *
853  * Register PCI subfunction flavour devlink port for a dynamically added
854  * subfunction port.
855  *
856  * Return: zero on success or an error code on failure.
857  */
858 int ice_devlink_create_sf_port(struct ice_dynamic_port *dyn_port)
859 {
860 	struct devlink_port_attrs attrs = {};
861 	struct devlink_port *devlink_port;
862 	struct devlink *devlink;
863 	struct ice_vsi *vsi;
864 	struct ice_pf *pf;
865 
866 	vsi = dyn_port->vsi;
867 	pf = dyn_port->pf;
868 
869 	devlink_port = &dyn_port->devlink_port;
870 
871 	attrs.flavour = DEVLINK_PORT_FLAVOUR_PCI_SF;
872 	attrs.pci_sf.pf = pf->hw.pf_id;
873 	attrs.pci_sf.sf = dyn_port->sfnum;
874 
875 	devlink_port_attrs_set(devlink_port, &attrs);
876 	devlink = priv_to_devlink(pf);
877 
878 	return devl_port_register_with_ops(devlink, devlink_port, vsi->idx,
879 					   &ice_devlink_port_sf_ops);
880 }
881 
882 /**
883  * ice_devlink_destroy_sf_port - Destroy the devlink_port for this SF
884  * @dyn_port: the dynamic port instance structure for this subfunction
885  *
886  * Unregisters the devlink_port structure associated with this SF.
887  */
888 void ice_devlink_destroy_sf_port(struct ice_dynamic_port *dyn_port)
889 {
890 	devl_rate_leaf_destroy(&dyn_port->devlink_port);
891 	devl_port_unregister(&dyn_port->devlink_port);
892 }
893 
894 /**
895  * ice_alloc_dynamic_port - Allocate new dynamic port
896  * @pf: pointer to the pf structure
897  * @new_attr: devlink port attributes requested
898  * @extack: extack for reporting error messages
899  * @devlink_port: index of newly created devlink port
900  *
901  * Allocate a new dynamic port instance and prepare it for configuration
902  * with devlink.
903  *
904  * Return: zero on success or an error code on failure.
905  */
906 static int
907 ice_alloc_dynamic_port(struct ice_pf *pf,
908 		       const struct devlink_port_new_attrs *new_attr,
909 		       struct netlink_ext_ack *extack,
910 		       struct devlink_port **devlink_port)
911 {
912 	struct ice_dynamic_port *dyn_port;
913 	struct ice_vsi *vsi;
914 	u32 sfnum;
915 	int err;
916 
917 	err = ice_reserve_sf_num(pf, new_attr, extack, &sfnum);
918 	if (err)
919 		return err;
920 
921 	dyn_port = kzalloc(sizeof(*dyn_port), GFP_KERNEL);
922 	if (!dyn_port) {
923 		err = -ENOMEM;
924 		goto unroll_reserve_sf_num;
925 	}
926 
927 	vsi = ice_vsi_alloc(pf);
928 	if (!vsi) {
929 		NL_SET_ERR_MSG_MOD(extack, "Unable to allocate VSI");
930 		err = -ENOMEM;
931 		goto unroll_dyn_port_alloc;
932 	}
933 
934 	dyn_port->vsi = vsi;
935 	dyn_port->pf = pf;
936 	dyn_port->sfnum = sfnum;
937 	eth_random_addr(dyn_port->hw_addr);
938 
939 	err = xa_insert(&pf->dyn_ports, vsi->idx, dyn_port, GFP_KERNEL);
940 	if (err) {
941 		NL_SET_ERR_MSG_MOD(extack, "Port index reservation failed");
942 		goto unroll_vsi_alloc;
943 	}
944 
945 	err = ice_eswitch_attach_sf(pf, dyn_port);
946 	if (err) {
947 		NL_SET_ERR_MSG_MOD(extack, "Failed to attach SF to eswitch");
948 		goto unroll_xa_insert;
949 	}
950 
951 	*devlink_port = &dyn_port->devlink_port;
952 
953 	return 0;
954 
955 unroll_xa_insert:
956 	xa_erase(&pf->dyn_ports, vsi->idx);
957 unroll_vsi_alloc:
958 	ice_vsi_free(vsi);
959 unroll_dyn_port_alloc:
960 	kfree(dyn_port);
961 unroll_reserve_sf_num:
962 	xa_erase(&pf->sf_nums, sfnum);
963 
964 	return err;
965 }
966 
967 /**
968  * ice_devlink_port_new - devlink handler for the new port
969  * @devlink: pointer to devlink
970  * @new_attr: pointer to the port new attributes
971  * @extack: extack for reporting error messages
972  * @devlink_port: pointer to a new port
973  *
974  * Creates new devlink port, checks new port attributes and reject
975  * any unsupported parameters, allocates new subfunction for that port.
976  *
977  * Return: zero on success or an error code on failure.
978  */
979 int
980 ice_devlink_port_new(struct devlink *devlink,
981 		     const struct devlink_port_new_attrs *new_attr,
982 		     struct netlink_ext_ack *extack,
983 		     struct devlink_port **devlink_port)
984 {
985 	struct ice_pf *pf = devlink_priv(devlink);
986 	int err;
987 
988 	err = ice_devlink_port_new_check_attr(pf, new_attr, extack);
989 	if (err)
990 		return err;
991 
992 	if (!ice_is_eswitch_mode_switchdev(pf)) {
993 		NL_SET_ERR_MSG_MOD(extack,
994 				   "SF ports are only supported in eswitch switchdev mode");
995 		return -EOPNOTSUPP;
996 	}
997 
998 	return ice_alloc_dynamic_port(pf, new_attr, extack, devlink_port);
999 }
1000