xref: /linux/net/devlink/port.c (revision 7cc9196675234d4de0e1e19b9da1a8b86ecfeedd)
1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3  * Copyright (c) 2016 Mellanox Technologies. All rights reserved.
4  * Copyright (c) 2016 Jiri Pirko <jiri@mellanox.com>
5  */
6 
7 #include "devl_internal.h"
8 
9 #define DEVLINK_PORT_FN_CAPS_VALID_MASK \
10 	(_BITUL(__DEVLINK_PORT_FN_ATTR_CAPS_MAX) - 1)
11 
12 static const struct nla_policy devlink_function_nl_policy[DEVLINK_PORT_FUNCTION_ATTR_MAX + 1] = {
13 	[DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR] = { .type = NLA_BINARY },
14 	[DEVLINK_PORT_FN_ATTR_STATE] =
15 		NLA_POLICY_RANGE(NLA_U8, DEVLINK_PORT_FN_STATE_INACTIVE,
16 				 DEVLINK_PORT_FN_STATE_ACTIVE),
17 	[DEVLINK_PORT_FN_ATTR_CAPS] =
18 		NLA_POLICY_BITFIELD32(DEVLINK_PORT_FN_CAPS_VALID_MASK),
19 };
20 
21 #define ASSERT_DEVLINK_PORT_REGISTERED(devlink_port)				\
22 	WARN_ON_ONCE(!(devlink_port)->registered)
23 #define ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port)			\
24 	WARN_ON_ONCE((devlink_port)->registered)
25 
26 struct devlink_port *devlink_port_get_by_index(struct devlink *devlink,
27 					       unsigned int port_index)
28 {
29 	return xa_load(&devlink->ports, port_index);
30 }
31 
32 struct devlink_port *devlink_port_get_from_attrs(struct devlink *devlink,
33 						 struct nlattr **attrs)
34 {
35 	if (attrs[DEVLINK_ATTR_PORT_INDEX]) {
36 		u32 port_index = nla_get_u32(attrs[DEVLINK_ATTR_PORT_INDEX]);
37 		struct devlink_port *devlink_port;
38 
39 		devlink_port = devlink_port_get_by_index(devlink, port_index);
40 		if (!devlink_port)
41 			return ERR_PTR(-ENODEV);
42 		return devlink_port;
43 	}
44 	return ERR_PTR(-EINVAL);
45 }
46 
47 struct devlink_port *devlink_port_get_from_info(struct devlink *devlink,
48 						struct genl_info *info)
49 {
50 	return devlink_port_get_from_attrs(devlink, info->attrs);
51 }
52 
53 static void devlink_port_fn_cap_fill(struct nla_bitfield32 *caps,
54 				     u32 cap, bool is_enable)
55 {
56 	caps->selector |= cap;
57 	if (is_enable)
58 		caps->value |= cap;
59 }
60 
61 static int devlink_port_fn_roce_fill(struct devlink_port *devlink_port,
62 				     struct nla_bitfield32 *caps,
63 				     struct netlink_ext_ack *extack)
64 {
65 	bool is_enable;
66 	int err;
67 
68 	if (!devlink_port->ops->port_fn_roce_get)
69 		return 0;
70 
71 	err = devlink_port->ops->port_fn_roce_get(devlink_port, &is_enable,
72 						  extack);
73 	if (err) {
74 		if (err == -EOPNOTSUPP)
75 			return 0;
76 		return err;
77 	}
78 
79 	devlink_port_fn_cap_fill(caps, DEVLINK_PORT_FN_CAP_ROCE, is_enable);
80 	return 0;
81 }
82 
83 static int devlink_port_fn_migratable_fill(struct devlink_port *devlink_port,
84 					   struct nla_bitfield32 *caps,
85 					   struct netlink_ext_ack *extack)
86 {
87 	bool is_enable;
88 	int err;
89 
90 	if (!devlink_port->ops->port_fn_migratable_get ||
91 	    devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF)
92 		return 0;
93 
94 	err = devlink_port->ops->port_fn_migratable_get(devlink_port,
95 							&is_enable, extack);
96 	if (err) {
97 		if (err == -EOPNOTSUPP)
98 			return 0;
99 		return err;
100 	}
101 
102 	devlink_port_fn_cap_fill(caps, DEVLINK_PORT_FN_CAP_MIGRATABLE, is_enable);
103 	return 0;
104 }
105 
106 static int devlink_port_fn_ipsec_crypto_fill(struct devlink_port *devlink_port,
107 					     struct nla_bitfield32 *caps,
108 					     struct netlink_ext_ack *extack)
109 {
110 	bool is_enable;
111 	int err;
112 
113 	if (!devlink_port->ops->port_fn_ipsec_crypto_get ||
114 	    devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF)
115 		return 0;
116 
117 	err = devlink_port->ops->port_fn_ipsec_crypto_get(devlink_port, &is_enable, extack);
118 	if (err) {
119 		if (err == -EOPNOTSUPP)
120 			return 0;
121 		return err;
122 	}
123 
124 	devlink_port_fn_cap_fill(caps, DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO, is_enable);
125 	return 0;
126 }
127 
128 static int devlink_port_fn_ipsec_packet_fill(struct devlink_port *devlink_port,
129 					     struct nla_bitfield32 *caps,
130 					     struct netlink_ext_ack *extack)
131 {
132 	bool is_enable;
133 	int err;
134 
135 	if (!devlink_port->ops->port_fn_ipsec_packet_get ||
136 	    devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF)
137 		return 0;
138 
139 	err = devlink_port->ops->port_fn_ipsec_packet_get(devlink_port, &is_enable, extack);
140 	if (err) {
141 		if (err == -EOPNOTSUPP)
142 			return 0;
143 		return err;
144 	}
145 
146 	devlink_port_fn_cap_fill(caps, DEVLINK_PORT_FN_CAP_IPSEC_PACKET, is_enable);
147 	return 0;
148 }
149 
150 static int devlink_port_fn_caps_fill(struct devlink_port *devlink_port,
151 				     struct sk_buff *msg,
152 				     struct netlink_ext_ack *extack,
153 				     bool *msg_updated)
154 {
155 	struct nla_bitfield32 caps = {};
156 	int err;
157 
158 	err = devlink_port_fn_roce_fill(devlink_port, &caps, extack);
159 	if (err)
160 		return err;
161 
162 	err = devlink_port_fn_migratable_fill(devlink_port, &caps, extack);
163 	if (err)
164 		return err;
165 
166 	err = devlink_port_fn_ipsec_crypto_fill(devlink_port, &caps, extack);
167 	if (err)
168 		return err;
169 
170 	err = devlink_port_fn_ipsec_packet_fill(devlink_port, &caps, extack);
171 	if (err)
172 		return err;
173 
174 	if (!caps.selector)
175 		return 0;
176 	err = nla_put_bitfield32(msg, DEVLINK_PORT_FN_ATTR_CAPS, caps.value,
177 				 caps.selector);
178 	if (err)
179 		return err;
180 
181 	*msg_updated = true;
182 	return 0;
183 }
184 
185 int devlink_nl_port_handle_fill(struct sk_buff *msg, struct devlink_port *devlink_port)
186 {
187 	if (devlink_nl_put_handle(msg, devlink_port->devlink))
188 		return -EMSGSIZE;
189 	if (nla_put_u32(msg, DEVLINK_ATTR_PORT_INDEX, devlink_port->index))
190 		return -EMSGSIZE;
191 	return 0;
192 }
193 
194 size_t devlink_nl_port_handle_size(struct devlink_port *devlink_port)
195 {
196 	struct devlink *devlink = devlink_port->devlink;
197 
198 	return nla_total_size(strlen(devlink->dev->bus->name) + 1) /* DEVLINK_ATTR_BUS_NAME */
199 	     + nla_total_size(strlen(dev_name(devlink->dev)) + 1) /* DEVLINK_ATTR_DEV_NAME */
200 	     + nla_total_size(4); /* DEVLINK_ATTR_PORT_INDEX */
201 }
202 
203 static int devlink_nl_port_attrs_put(struct sk_buff *msg,
204 				     struct devlink_port *devlink_port)
205 {
206 	struct devlink_port_attrs *attrs = &devlink_port->attrs;
207 
208 	if (!devlink_port->attrs_set)
209 		return 0;
210 	if (attrs->lanes) {
211 		if (nla_put_u32(msg, DEVLINK_ATTR_PORT_LANES, attrs->lanes))
212 			return -EMSGSIZE;
213 	}
214 	if (nla_put_u8(msg, DEVLINK_ATTR_PORT_SPLITTABLE, attrs->splittable))
215 		return -EMSGSIZE;
216 	if (nla_put_u16(msg, DEVLINK_ATTR_PORT_FLAVOUR, attrs->flavour))
217 		return -EMSGSIZE;
218 	switch (devlink_port->attrs.flavour) {
219 	case DEVLINK_PORT_FLAVOUR_PCI_PF:
220 		if (nla_put_u32(msg, DEVLINK_ATTR_PORT_CONTROLLER_NUMBER,
221 				attrs->pci_pf.controller) ||
222 		    nla_put_u16(msg, DEVLINK_ATTR_PORT_PCI_PF_NUMBER, attrs->pci_pf.pf))
223 			return -EMSGSIZE;
224 		if (nla_put_u8(msg, DEVLINK_ATTR_PORT_EXTERNAL, attrs->pci_pf.external))
225 			return -EMSGSIZE;
226 		break;
227 	case DEVLINK_PORT_FLAVOUR_PCI_VF:
228 		if (nla_put_u32(msg, DEVLINK_ATTR_PORT_CONTROLLER_NUMBER,
229 				attrs->pci_vf.controller) ||
230 		    nla_put_u16(msg, DEVLINK_ATTR_PORT_PCI_PF_NUMBER, attrs->pci_vf.pf) ||
231 		    nla_put_u16(msg, DEVLINK_ATTR_PORT_PCI_VF_NUMBER, attrs->pci_vf.vf))
232 			return -EMSGSIZE;
233 		if (nla_put_u8(msg, DEVLINK_ATTR_PORT_EXTERNAL, attrs->pci_vf.external))
234 			return -EMSGSIZE;
235 		break;
236 	case DEVLINK_PORT_FLAVOUR_PCI_SF:
237 		if (nla_put_u32(msg, DEVLINK_ATTR_PORT_CONTROLLER_NUMBER,
238 				attrs->pci_sf.controller) ||
239 		    nla_put_u16(msg, DEVLINK_ATTR_PORT_PCI_PF_NUMBER,
240 				attrs->pci_sf.pf) ||
241 		    nla_put_u32(msg, DEVLINK_ATTR_PORT_PCI_SF_NUMBER,
242 				attrs->pci_sf.sf))
243 			return -EMSGSIZE;
244 		break;
245 	case DEVLINK_PORT_FLAVOUR_PHYSICAL:
246 	case DEVLINK_PORT_FLAVOUR_CPU:
247 	case DEVLINK_PORT_FLAVOUR_DSA:
248 		if (nla_put_u32(msg, DEVLINK_ATTR_PORT_NUMBER,
249 				attrs->phys.port_number))
250 			return -EMSGSIZE;
251 		if (!attrs->split)
252 			return 0;
253 		if (nla_put_u32(msg, DEVLINK_ATTR_PORT_SPLIT_GROUP,
254 				attrs->phys.port_number))
255 			return -EMSGSIZE;
256 		if (nla_put_u32(msg, DEVLINK_ATTR_PORT_SPLIT_SUBPORT_NUMBER,
257 				attrs->phys.split_subport_number))
258 			return -EMSGSIZE;
259 		break;
260 	default:
261 		break;
262 	}
263 	return 0;
264 }
265 
266 static int devlink_port_fn_hw_addr_fill(struct devlink_port *port,
267 					struct sk_buff *msg,
268 					struct netlink_ext_ack *extack,
269 					bool *msg_updated)
270 {
271 	u8 hw_addr[MAX_ADDR_LEN];
272 	int hw_addr_len;
273 	int err;
274 
275 	if (!port->ops->port_fn_hw_addr_get)
276 		return 0;
277 
278 	err = port->ops->port_fn_hw_addr_get(port, hw_addr, &hw_addr_len,
279 					     extack);
280 	if (err) {
281 		if (err == -EOPNOTSUPP)
282 			return 0;
283 		return err;
284 	}
285 	err = nla_put(msg, DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR, hw_addr_len, hw_addr);
286 	if (err)
287 		return err;
288 	*msg_updated = true;
289 	return 0;
290 }
291 
292 static bool
293 devlink_port_fn_state_valid(enum devlink_port_fn_state state)
294 {
295 	return state == DEVLINK_PORT_FN_STATE_INACTIVE ||
296 	       state == DEVLINK_PORT_FN_STATE_ACTIVE;
297 }
298 
299 static bool
300 devlink_port_fn_opstate_valid(enum devlink_port_fn_opstate opstate)
301 {
302 	return opstate == DEVLINK_PORT_FN_OPSTATE_DETACHED ||
303 	       opstate == DEVLINK_PORT_FN_OPSTATE_ATTACHED;
304 }
305 
306 static int devlink_port_fn_state_fill(struct devlink_port *port,
307 				      struct sk_buff *msg,
308 				      struct netlink_ext_ack *extack,
309 				      bool *msg_updated)
310 {
311 	enum devlink_port_fn_opstate opstate;
312 	enum devlink_port_fn_state state;
313 	int err;
314 
315 	if (!port->ops->port_fn_state_get)
316 		return 0;
317 
318 	err = port->ops->port_fn_state_get(port, &state, &opstate, extack);
319 	if (err) {
320 		if (err == -EOPNOTSUPP)
321 			return 0;
322 		return err;
323 	}
324 	if (!devlink_port_fn_state_valid(state)) {
325 		WARN_ON_ONCE(1);
326 		NL_SET_ERR_MSG(extack, "Invalid state read from driver");
327 		return -EINVAL;
328 	}
329 	if (!devlink_port_fn_opstate_valid(opstate)) {
330 		WARN_ON_ONCE(1);
331 		NL_SET_ERR_MSG(extack, "Invalid operational state read from driver");
332 		return -EINVAL;
333 	}
334 	if (nla_put_u8(msg, DEVLINK_PORT_FN_ATTR_STATE, state) ||
335 	    nla_put_u8(msg, DEVLINK_PORT_FN_ATTR_OPSTATE, opstate))
336 		return -EMSGSIZE;
337 	*msg_updated = true;
338 	return 0;
339 }
340 
341 static int
342 devlink_port_fn_mig_set(struct devlink_port *devlink_port, bool enable,
343 			struct netlink_ext_ack *extack)
344 {
345 	return devlink_port->ops->port_fn_migratable_set(devlink_port, enable,
346 							 extack);
347 }
348 
349 static int
350 devlink_port_fn_roce_set(struct devlink_port *devlink_port, bool enable,
351 			 struct netlink_ext_ack *extack)
352 {
353 	return devlink_port->ops->port_fn_roce_set(devlink_port, enable,
354 						   extack);
355 }
356 
357 static int
358 devlink_port_fn_ipsec_crypto_set(struct devlink_port *devlink_port, bool enable,
359 				 struct netlink_ext_ack *extack)
360 {
361 	return devlink_port->ops->port_fn_ipsec_crypto_set(devlink_port, enable, extack);
362 }
363 
364 static int
365 devlink_port_fn_ipsec_packet_set(struct devlink_port *devlink_port, bool enable,
366 				 struct netlink_ext_ack *extack)
367 {
368 	return devlink_port->ops->port_fn_ipsec_packet_set(devlink_port, enable, extack);
369 }
370 
371 static int devlink_port_fn_caps_set(struct devlink_port *devlink_port,
372 				    const struct nlattr *attr,
373 				    struct netlink_ext_ack *extack)
374 {
375 	struct nla_bitfield32 caps;
376 	u32 caps_value;
377 	int err;
378 
379 	caps = nla_get_bitfield32(attr);
380 	caps_value = caps.value & caps.selector;
381 	if (caps.selector & DEVLINK_PORT_FN_CAP_ROCE) {
382 		err = devlink_port_fn_roce_set(devlink_port,
383 					       caps_value & DEVLINK_PORT_FN_CAP_ROCE,
384 					       extack);
385 		if (err)
386 			return err;
387 	}
388 	if (caps.selector & DEVLINK_PORT_FN_CAP_MIGRATABLE) {
389 		err = devlink_port_fn_mig_set(devlink_port, caps_value &
390 					      DEVLINK_PORT_FN_CAP_MIGRATABLE,
391 					      extack);
392 		if (err)
393 			return err;
394 	}
395 	if (caps.selector & DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO) {
396 		err = devlink_port_fn_ipsec_crypto_set(devlink_port, caps_value &
397 						       DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO,
398 						       extack);
399 		if (err)
400 			return err;
401 	}
402 	if (caps.selector & DEVLINK_PORT_FN_CAP_IPSEC_PACKET) {
403 		err = devlink_port_fn_ipsec_packet_set(devlink_port, caps_value &
404 						       DEVLINK_PORT_FN_CAP_IPSEC_PACKET,
405 						       extack);
406 		if (err)
407 			return err;
408 	}
409 	return 0;
410 }
411 
412 static int
413 devlink_nl_port_function_attrs_put(struct sk_buff *msg, struct devlink_port *port,
414 				   struct netlink_ext_ack *extack)
415 {
416 	struct nlattr *function_attr;
417 	bool msg_updated = false;
418 	int err;
419 
420 	function_attr = nla_nest_start_noflag(msg, DEVLINK_ATTR_PORT_FUNCTION);
421 	if (!function_attr)
422 		return -EMSGSIZE;
423 
424 	err = devlink_port_fn_hw_addr_fill(port, msg, extack, &msg_updated);
425 	if (err)
426 		goto out;
427 	err = devlink_port_fn_caps_fill(port, msg, extack, &msg_updated);
428 	if (err)
429 		goto out;
430 	err = devlink_port_fn_state_fill(port, msg, extack, &msg_updated);
431 	if (err)
432 		goto out;
433 	err = devlink_rel_devlink_handle_put(msg, port->devlink,
434 					     port->rel_index,
435 					     DEVLINK_PORT_FN_ATTR_DEVLINK,
436 					     &msg_updated);
437 
438 out:
439 	if (err || !msg_updated)
440 		nla_nest_cancel(msg, function_attr);
441 	else
442 		nla_nest_end(msg, function_attr);
443 	return err;
444 }
445 
446 static int devlink_nl_port_fill(struct sk_buff *msg,
447 				struct devlink_port *devlink_port,
448 				enum devlink_command cmd, u32 portid, u32 seq,
449 				int flags, struct netlink_ext_ack *extack)
450 {
451 	struct devlink *devlink = devlink_port->devlink;
452 	void *hdr;
453 
454 	hdr = genlmsg_put(msg, portid, seq, &devlink_nl_family, flags, cmd);
455 	if (!hdr)
456 		return -EMSGSIZE;
457 
458 	if (devlink_nl_put_handle(msg, devlink))
459 		goto nla_put_failure;
460 	if (nla_put_u32(msg, DEVLINK_ATTR_PORT_INDEX, devlink_port->index))
461 		goto nla_put_failure;
462 
463 	spin_lock_bh(&devlink_port->type_lock);
464 	if (nla_put_u16(msg, DEVLINK_ATTR_PORT_TYPE, devlink_port->type))
465 		goto nla_put_failure_type_locked;
466 	if (devlink_port->desired_type != DEVLINK_PORT_TYPE_NOTSET &&
467 	    nla_put_u16(msg, DEVLINK_ATTR_PORT_DESIRED_TYPE,
468 			devlink_port->desired_type))
469 		goto nla_put_failure_type_locked;
470 	if (devlink_port->type == DEVLINK_PORT_TYPE_ETH) {
471 		if (devlink_port->type_eth.netdev &&
472 		    (nla_put_u32(msg, DEVLINK_ATTR_PORT_NETDEV_IFINDEX,
473 				 devlink_port->type_eth.ifindex) ||
474 		     nla_put_string(msg, DEVLINK_ATTR_PORT_NETDEV_NAME,
475 				    devlink_port->type_eth.ifname)))
476 			goto nla_put_failure_type_locked;
477 	}
478 	if (devlink_port->type == DEVLINK_PORT_TYPE_IB) {
479 		struct ib_device *ibdev = devlink_port->type_ib.ibdev;
480 
481 		if (ibdev &&
482 		    nla_put_string(msg, DEVLINK_ATTR_PORT_IBDEV_NAME,
483 				   ibdev->name))
484 			goto nla_put_failure_type_locked;
485 	}
486 	spin_unlock_bh(&devlink_port->type_lock);
487 	if (devlink_nl_port_attrs_put(msg, devlink_port))
488 		goto nla_put_failure;
489 	if (devlink_nl_port_function_attrs_put(msg, devlink_port, extack))
490 		goto nla_put_failure;
491 	if (devlink_port->linecard &&
492 	    nla_put_u32(msg, DEVLINK_ATTR_LINECARD_INDEX,
493 			devlink_linecard_index(devlink_port->linecard)))
494 		goto nla_put_failure;
495 
496 	genlmsg_end(msg, hdr);
497 	return 0;
498 
499 nla_put_failure_type_locked:
500 	spin_unlock_bh(&devlink_port->type_lock);
501 nla_put_failure:
502 	genlmsg_cancel(msg, hdr);
503 	return -EMSGSIZE;
504 }
505 
506 static void devlink_port_notify(struct devlink_port *devlink_port,
507 				enum devlink_command cmd)
508 {
509 	struct devlink *devlink = devlink_port->devlink;
510 	struct devlink_obj_desc desc;
511 	struct sk_buff *msg;
512 	int err;
513 
514 	WARN_ON(cmd != DEVLINK_CMD_PORT_NEW && cmd != DEVLINK_CMD_PORT_DEL);
515 
516 	if (!__devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
517 		return;
518 
519 	msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
520 	if (!msg)
521 		return;
522 
523 	err = devlink_nl_port_fill(msg, devlink_port, cmd, 0, 0, 0, NULL);
524 	if (err) {
525 		nlmsg_free(msg);
526 		return;
527 	}
528 
529 	devlink_nl_obj_desc_init(&desc, devlink);
530 	devlink_nl_obj_desc_port_set(&desc, devlink_port);
531 	devlink_nl_notify_send_desc(devlink, msg, &desc);
532 }
533 
534 static void devlink_ports_notify(struct devlink *devlink,
535 				 enum devlink_command cmd)
536 {
537 	struct devlink_port *devlink_port;
538 	unsigned long port_index;
539 
540 	xa_for_each(&devlink->ports, port_index, devlink_port)
541 		devlink_port_notify(devlink_port, cmd);
542 }
543 
544 void devlink_ports_notify_register(struct devlink *devlink)
545 {
546 	devlink_ports_notify(devlink, DEVLINK_CMD_PORT_NEW);
547 }
548 
549 void devlink_ports_notify_unregister(struct devlink *devlink)
550 {
551 	devlink_ports_notify(devlink, DEVLINK_CMD_PORT_DEL);
552 }
553 
554 int devlink_nl_port_get_doit(struct sk_buff *skb, struct genl_info *info)
555 {
556 	struct devlink_port *devlink_port = info->user_ptr[1];
557 	struct sk_buff *msg;
558 	int err;
559 
560 	msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
561 	if (!msg)
562 		return -ENOMEM;
563 
564 	err = devlink_nl_port_fill(msg, devlink_port, DEVLINK_CMD_PORT_NEW,
565 				   info->snd_portid, info->snd_seq, 0,
566 				   info->extack);
567 	if (err) {
568 		nlmsg_free(msg);
569 		return err;
570 	}
571 
572 	return genlmsg_reply(msg, info);
573 }
574 
575 static int
576 devlink_nl_port_get_dump_one(struct sk_buff *msg, struct devlink *devlink,
577 			     struct netlink_callback *cb, int flags)
578 {
579 	struct devlink_nl_dump_state *state = devlink_dump_state(cb);
580 	struct devlink_port *devlink_port;
581 	unsigned long port_index;
582 	int err = 0;
583 
584 	xa_for_each_start(&devlink->ports, port_index, devlink_port, state->idx) {
585 		err = devlink_nl_port_fill(msg, devlink_port,
586 					   DEVLINK_CMD_PORT_NEW,
587 					   NETLINK_CB(cb->skb).portid,
588 					   cb->nlh->nlmsg_seq, flags,
589 					   cb->extack);
590 		if (err) {
591 			state->idx = port_index;
592 			break;
593 		}
594 	}
595 
596 	return err;
597 }
598 
599 int devlink_nl_port_get_dumpit(struct sk_buff *skb, struct netlink_callback *cb)
600 {
601 	return devlink_nl_dumpit(skb, cb, devlink_nl_port_get_dump_one);
602 }
603 
604 static int devlink_port_type_set(struct devlink_port *devlink_port,
605 				 enum devlink_port_type port_type)
606 
607 {
608 	int err;
609 
610 	if (!devlink_port->ops->port_type_set)
611 		return -EOPNOTSUPP;
612 
613 	if (port_type == devlink_port->type)
614 		return 0;
615 
616 	err = devlink_port->ops->port_type_set(devlink_port, port_type);
617 	if (err)
618 		return err;
619 
620 	devlink_port->desired_type = port_type;
621 	devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
622 	return 0;
623 }
624 
625 static int devlink_port_function_hw_addr_set(struct devlink_port *port,
626 					     const struct nlattr *attr,
627 					     struct netlink_ext_ack *extack)
628 {
629 	const u8 *hw_addr;
630 	int hw_addr_len;
631 
632 	hw_addr = nla_data(attr);
633 	hw_addr_len = nla_len(attr);
634 	if (hw_addr_len > MAX_ADDR_LEN) {
635 		NL_SET_ERR_MSG(extack, "Port function hardware address too long");
636 		return -EINVAL;
637 	}
638 	if (port->type == DEVLINK_PORT_TYPE_ETH) {
639 		if (hw_addr_len != ETH_ALEN) {
640 			NL_SET_ERR_MSG(extack, "Address must be 6 bytes for Ethernet device");
641 			return -EINVAL;
642 		}
643 		if (!is_unicast_ether_addr(hw_addr)) {
644 			NL_SET_ERR_MSG(extack, "Non-unicast hardware address unsupported");
645 			return -EINVAL;
646 		}
647 	}
648 
649 	return port->ops->port_fn_hw_addr_set(port, hw_addr, hw_addr_len,
650 					      extack);
651 }
652 
653 static int devlink_port_fn_state_set(struct devlink_port *port,
654 				     const struct nlattr *attr,
655 				     struct netlink_ext_ack *extack)
656 {
657 	enum devlink_port_fn_state state;
658 
659 	state = nla_get_u8(attr);
660 	return port->ops->port_fn_state_set(port, state, extack);
661 }
662 
663 static int devlink_port_function_validate(struct devlink_port *devlink_port,
664 					  struct nlattr **tb,
665 					  struct netlink_ext_ack *extack)
666 {
667 	const struct devlink_port_ops *ops = devlink_port->ops;
668 	struct nlattr *attr;
669 
670 	if (tb[DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR] &&
671 	    !ops->port_fn_hw_addr_set) {
672 		NL_SET_ERR_MSG_ATTR(extack, tb[DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR],
673 				    "Port doesn't support function attributes");
674 		return -EOPNOTSUPP;
675 	}
676 	if (tb[DEVLINK_PORT_FN_ATTR_STATE] && !ops->port_fn_state_set) {
677 		NL_SET_ERR_MSG_ATTR(extack, tb[DEVLINK_PORT_FN_ATTR_STATE],
678 				    "Function does not support state setting");
679 		return -EOPNOTSUPP;
680 	}
681 	attr = tb[DEVLINK_PORT_FN_ATTR_CAPS];
682 	if (attr) {
683 		struct nla_bitfield32 caps;
684 
685 		caps = nla_get_bitfield32(attr);
686 		if (caps.selector & DEVLINK_PORT_FN_CAP_ROCE &&
687 		    !ops->port_fn_roce_set) {
688 			NL_SET_ERR_MSG_ATTR(extack, attr,
689 					    "Port doesn't support RoCE function attribute");
690 			return -EOPNOTSUPP;
691 		}
692 		if (caps.selector & DEVLINK_PORT_FN_CAP_MIGRATABLE) {
693 			if (!ops->port_fn_migratable_set) {
694 				NL_SET_ERR_MSG_ATTR(extack, attr,
695 						    "Port doesn't support migratable function attribute");
696 				return -EOPNOTSUPP;
697 			}
698 			if (devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF) {
699 				NL_SET_ERR_MSG_ATTR(extack, attr,
700 						    "migratable function attribute supported for VFs only");
701 				return -EOPNOTSUPP;
702 			}
703 		}
704 		if (caps.selector & DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO) {
705 			if (!ops->port_fn_ipsec_crypto_set) {
706 				NL_SET_ERR_MSG_ATTR(extack, attr,
707 						    "Port doesn't support ipsec_crypto function attribute");
708 				return -EOPNOTSUPP;
709 			}
710 			if (devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF) {
711 				NL_SET_ERR_MSG_ATTR(extack, attr,
712 						    "ipsec_crypto function attribute supported for VFs only");
713 				return -EOPNOTSUPP;
714 			}
715 		}
716 		if (caps.selector & DEVLINK_PORT_FN_CAP_IPSEC_PACKET) {
717 			if (!ops->port_fn_ipsec_packet_set) {
718 				NL_SET_ERR_MSG_ATTR(extack, attr,
719 						    "Port doesn't support ipsec_packet function attribute");
720 				return -EOPNOTSUPP;
721 			}
722 			if (devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF) {
723 				NL_SET_ERR_MSG_ATTR(extack, attr,
724 						    "ipsec_packet function attribute supported for VFs only");
725 				return -EOPNOTSUPP;
726 			}
727 		}
728 	}
729 	return 0;
730 }
731 
732 static int devlink_port_function_set(struct devlink_port *port,
733 				     const struct nlattr *attr,
734 				     struct netlink_ext_ack *extack)
735 {
736 	struct nlattr *tb[DEVLINK_PORT_FUNCTION_ATTR_MAX + 1];
737 	int err;
738 
739 	err = nla_parse_nested(tb, DEVLINK_PORT_FUNCTION_ATTR_MAX, attr,
740 			       devlink_function_nl_policy, extack);
741 	if (err < 0) {
742 		NL_SET_ERR_MSG(extack, "Fail to parse port function attributes");
743 		return err;
744 	}
745 
746 	err = devlink_port_function_validate(port, tb, extack);
747 	if (err)
748 		return err;
749 
750 	attr = tb[DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR];
751 	if (attr) {
752 		err = devlink_port_function_hw_addr_set(port, attr, extack);
753 		if (err)
754 			return err;
755 	}
756 
757 	attr = tb[DEVLINK_PORT_FN_ATTR_CAPS];
758 	if (attr) {
759 		err = devlink_port_fn_caps_set(port, attr, extack);
760 		if (err)
761 			return err;
762 	}
763 
764 	/* Keep this as the last function attribute set, so that when
765 	 * multiple port function attributes are set along with state,
766 	 * Those can be applied first before activating the state.
767 	 */
768 	attr = tb[DEVLINK_PORT_FN_ATTR_STATE];
769 	if (attr)
770 		err = devlink_port_fn_state_set(port, attr, extack);
771 
772 	if (!err)
773 		devlink_port_notify(port, DEVLINK_CMD_PORT_NEW);
774 	return err;
775 }
776 
777 int devlink_nl_port_set_doit(struct sk_buff *skb, struct genl_info *info)
778 {
779 	struct devlink_port *devlink_port = info->user_ptr[1];
780 	int err;
781 
782 	if (info->attrs[DEVLINK_ATTR_PORT_TYPE]) {
783 		enum devlink_port_type port_type;
784 
785 		port_type = nla_get_u16(info->attrs[DEVLINK_ATTR_PORT_TYPE]);
786 		err = devlink_port_type_set(devlink_port, port_type);
787 		if (err)
788 			return err;
789 	}
790 
791 	if (info->attrs[DEVLINK_ATTR_PORT_FUNCTION]) {
792 		struct nlattr *attr = info->attrs[DEVLINK_ATTR_PORT_FUNCTION];
793 		struct netlink_ext_ack *extack = info->extack;
794 
795 		err = devlink_port_function_set(devlink_port, attr, extack);
796 		if (err)
797 			return err;
798 	}
799 
800 	return 0;
801 }
802 
803 int devlink_nl_port_split_doit(struct sk_buff *skb, struct genl_info *info)
804 {
805 	struct devlink_port *devlink_port = info->user_ptr[1];
806 	struct devlink *devlink = info->user_ptr[0];
807 	u32 count;
808 
809 	if (GENL_REQ_ATTR_CHECK(info, DEVLINK_ATTR_PORT_SPLIT_COUNT))
810 		return -EINVAL;
811 	if (!devlink_port->ops->port_split)
812 		return -EOPNOTSUPP;
813 
814 	count = nla_get_u32(info->attrs[DEVLINK_ATTR_PORT_SPLIT_COUNT]);
815 
816 	if (!devlink_port->attrs.splittable) {
817 		/* Split ports cannot be split. */
818 		if (devlink_port->attrs.split)
819 			NL_SET_ERR_MSG(info->extack, "Port cannot be split further");
820 		else
821 			NL_SET_ERR_MSG(info->extack, "Port cannot be split");
822 		return -EINVAL;
823 	}
824 
825 	if (count < 2 || !is_power_of_2(count) || count > devlink_port->attrs.lanes) {
826 		NL_SET_ERR_MSG(info->extack, "Invalid split count");
827 		return -EINVAL;
828 	}
829 
830 	return devlink_port->ops->port_split(devlink, devlink_port, count,
831 					     info->extack);
832 }
833 
834 int devlink_nl_port_unsplit_doit(struct sk_buff *skb, struct genl_info *info)
835 {
836 	struct devlink_port *devlink_port = info->user_ptr[1];
837 	struct devlink *devlink = info->user_ptr[0];
838 
839 	if (!devlink_port->ops->port_unsplit)
840 		return -EOPNOTSUPP;
841 	return devlink_port->ops->port_unsplit(devlink, devlink_port, info->extack);
842 }
843 
844 int devlink_nl_port_new_doit(struct sk_buff *skb, struct genl_info *info)
845 {
846 	struct netlink_ext_ack *extack = info->extack;
847 	struct devlink_port_new_attrs new_attrs = {};
848 	struct devlink *devlink = info->user_ptr[0];
849 	struct devlink_port *devlink_port;
850 	struct sk_buff *msg;
851 	int err;
852 
853 	if (!devlink->ops->port_new)
854 		return -EOPNOTSUPP;
855 
856 	if (!info->attrs[DEVLINK_ATTR_PORT_FLAVOUR] ||
857 	    !info->attrs[DEVLINK_ATTR_PORT_PCI_PF_NUMBER]) {
858 		NL_SET_ERR_MSG(extack, "Port flavour or PCI PF are not specified");
859 		return -EINVAL;
860 	}
861 	new_attrs.flavour = nla_get_u16(info->attrs[DEVLINK_ATTR_PORT_FLAVOUR]);
862 	new_attrs.pfnum =
863 		nla_get_u16(info->attrs[DEVLINK_ATTR_PORT_PCI_PF_NUMBER]);
864 
865 	if (info->attrs[DEVLINK_ATTR_PORT_INDEX]) {
866 		/* Port index of the new port being created by driver. */
867 		new_attrs.port_index =
868 			nla_get_u32(info->attrs[DEVLINK_ATTR_PORT_INDEX]);
869 		new_attrs.port_index_valid = true;
870 	}
871 	if (info->attrs[DEVLINK_ATTR_PORT_CONTROLLER_NUMBER]) {
872 		new_attrs.controller =
873 			nla_get_u16(info->attrs[DEVLINK_ATTR_PORT_CONTROLLER_NUMBER]);
874 		new_attrs.controller_valid = true;
875 	}
876 	if (new_attrs.flavour == DEVLINK_PORT_FLAVOUR_PCI_SF &&
877 	    info->attrs[DEVLINK_ATTR_PORT_PCI_SF_NUMBER]) {
878 		new_attrs.sfnum = nla_get_u32(info->attrs[DEVLINK_ATTR_PORT_PCI_SF_NUMBER]);
879 		new_attrs.sfnum_valid = true;
880 	}
881 
882 	err = devlink->ops->port_new(devlink, &new_attrs,
883 				     extack, &devlink_port);
884 	if (err)
885 		return err;
886 
887 	msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
888 	if (!msg) {
889 		err = -ENOMEM;
890 		goto err_out_port_del;
891 	}
892 	err = devlink_nl_port_fill(msg, devlink_port, DEVLINK_CMD_NEW,
893 				   info->snd_portid, info->snd_seq, 0, NULL);
894 	if (WARN_ON_ONCE(err))
895 		goto err_out_msg_free;
896 	err = genlmsg_reply(msg, info);
897 	if (err)
898 		goto err_out_port_del;
899 	return 0;
900 
901 err_out_msg_free:
902 	nlmsg_free(msg);
903 err_out_port_del:
904 	devlink_port->ops->port_del(devlink, devlink_port, NULL);
905 	return err;
906 }
907 
908 int devlink_nl_port_del_doit(struct sk_buff *skb, struct genl_info *info)
909 {
910 	struct devlink_port *devlink_port = info->user_ptr[1];
911 	struct netlink_ext_ack *extack = info->extack;
912 	struct devlink *devlink = info->user_ptr[0];
913 
914 	if (!devlink_port->ops->port_del)
915 		return -EOPNOTSUPP;
916 
917 	return devlink_port->ops->port_del(devlink, devlink_port, extack);
918 }
919 
920 static void devlink_port_type_warn(struct work_struct *work)
921 {
922 	struct devlink_port *port = container_of(to_delayed_work(work),
923 						 struct devlink_port,
924 						 type_warn_dw);
925 	dev_warn(port->devlink->dev, "Type was not set for devlink port.");
926 }
927 
928 static bool devlink_port_type_should_warn(struct devlink_port *devlink_port)
929 {
930 	/* Ignore CPU and DSA flavours. */
931 	return devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_CPU &&
932 	       devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_DSA &&
933 	       devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_UNUSED;
934 }
935 
936 #define DEVLINK_PORT_TYPE_WARN_TIMEOUT (HZ * 3600)
937 
938 static void devlink_port_type_warn_schedule(struct devlink_port *devlink_port)
939 {
940 	if (!devlink_port_type_should_warn(devlink_port))
941 		return;
942 	/* Schedule a work to WARN in case driver does not set port
943 	 * type within timeout.
944 	 */
945 	schedule_delayed_work(&devlink_port->type_warn_dw,
946 			      DEVLINK_PORT_TYPE_WARN_TIMEOUT);
947 }
948 
949 static void devlink_port_type_warn_cancel(struct devlink_port *devlink_port)
950 {
951 	if (!devlink_port_type_should_warn(devlink_port))
952 		return;
953 	cancel_delayed_work_sync(&devlink_port->type_warn_dw);
954 }
955 
956 /**
957  * devlink_port_init() - Init devlink port
958  *
959  * @devlink: devlink
960  * @devlink_port: devlink port
961  *
962  * Initialize essential stuff that is needed for functions
963  * that may be called before devlink port registration.
964  * Call to this function is optional and not needed
965  * in case the driver does not use such functions.
966  */
967 void devlink_port_init(struct devlink *devlink,
968 		       struct devlink_port *devlink_port)
969 {
970 	if (devlink_port->initialized)
971 		return;
972 	devlink_port->devlink = devlink;
973 	INIT_LIST_HEAD(&devlink_port->region_list);
974 	devlink_port->initialized = true;
975 }
976 EXPORT_SYMBOL_GPL(devlink_port_init);
977 
978 /**
979  * devlink_port_fini() - Deinitialize devlink port
980  *
981  * @devlink_port: devlink port
982  *
983  * Deinitialize essential stuff that is in use for functions
984  * that may be called after devlink port unregistration.
985  * Call to this function is optional and not needed
986  * in case the driver does not use such functions.
987  */
988 void devlink_port_fini(struct devlink_port *devlink_port)
989 {
990 	WARN_ON(!list_empty(&devlink_port->region_list));
991 }
992 EXPORT_SYMBOL_GPL(devlink_port_fini);
993 
994 static const struct devlink_port_ops devlink_port_dummy_ops = {};
995 
996 /**
997  * devl_port_register_with_ops() - Register devlink port
998  *
999  * @devlink: devlink
1000  * @devlink_port: devlink port
1001  * @port_index: driver-specific numerical identifier of the port
1002  * @ops: port ops
1003  *
1004  * Register devlink port with provided port index. User can use
1005  * any indexing, even hw-related one. devlink_port structure
1006  * is convenient to be embedded inside user driver private structure.
1007  * Note that the caller should take care of zeroing the devlink_port
1008  * structure.
1009  */
1010 int devl_port_register_with_ops(struct devlink *devlink,
1011 				struct devlink_port *devlink_port,
1012 				unsigned int port_index,
1013 				const struct devlink_port_ops *ops)
1014 {
1015 	int err;
1016 
1017 	devl_assert_locked(devlink);
1018 
1019 	ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1020 
1021 	devlink_port_init(devlink, devlink_port);
1022 	devlink_port->registered = true;
1023 	devlink_port->index = port_index;
1024 	devlink_port->ops = ops ? ops : &devlink_port_dummy_ops;
1025 	spin_lock_init(&devlink_port->type_lock);
1026 	INIT_LIST_HEAD(&devlink_port->reporter_list);
1027 	err = xa_insert(&devlink->ports, port_index, devlink_port, GFP_KERNEL);
1028 	if (err) {
1029 		devlink_port->registered = false;
1030 		return err;
1031 	}
1032 
1033 	INIT_DELAYED_WORK(&devlink_port->type_warn_dw, &devlink_port_type_warn);
1034 	devlink_port_type_warn_schedule(devlink_port);
1035 	devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
1036 	return 0;
1037 }
1038 EXPORT_SYMBOL_GPL(devl_port_register_with_ops);
1039 
1040 /**
1041  *	devlink_port_register_with_ops - Register devlink port
1042  *
1043  *	@devlink: devlink
1044  *	@devlink_port: devlink port
1045  *	@port_index: driver-specific numerical identifier of the port
1046  *	@ops: port ops
1047  *
1048  *	Register devlink port with provided port index. User can use
1049  *	any indexing, even hw-related one. devlink_port structure
1050  *	is convenient to be embedded inside user driver private structure.
1051  *	Note that the caller should take care of zeroing the devlink_port
1052  *	structure.
1053  *
1054  *	Context: Takes and release devlink->lock <mutex>.
1055  */
1056 int devlink_port_register_with_ops(struct devlink *devlink,
1057 				   struct devlink_port *devlink_port,
1058 				   unsigned int port_index,
1059 				   const struct devlink_port_ops *ops)
1060 {
1061 	int err;
1062 
1063 	devl_lock(devlink);
1064 	err = devl_port_register_with_ops(devlink, devlink_port,
1065 					  port_index, ops);
1066 	devl_unlock(devlink);
1067 	return err;
1068 }
1069 EXPORT_SYMBOL_GPL(devlink_port_register_with_ops);
1070 
1071 /**
1072  * devl_port_unregister() - Unregister devlink port
1073  *
1074  * @devlink_port: devlink port
1075  */
1076 void devl_port_unregister(struct devlink_port *devlink_port)
1077 {
1078 	lockdep_assert_held(&devlink_port->devlink->lock);
1079 	WARN_ON(devlink_port->type != DEVLINK_PORT_TYPE_NOTSET);
1080 
1081 	devlink_port_type_warn_cancel(devlink_port);
1082 	devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_DEL);
1083 	xa_erase(&devlink_port->devlink->ports, devlink_port->index);
1084 	WARN_ON(!list_empty(&devlink_port->reporter_list));
1085 	devlink_port->registered = false;
1086 }
1087 EXPORT_SYMBOL_GPL(devl_port_unregister);
1088 
1089 /**
1090  *	devlink_port_unregister - Unregister devlink port
1091  *
1092  *	@devlink_port: devlink port
1093  *
1094  *	Context: Takes and release devlink->lock <mutex>.
1095  */
1096 void devlink_port_unregister(struct devlink_port *devlink_port)
1097 {
1098 	struct devlink *devlink = devlink_port->devlink;
1099 
1100 	devl_lock(devlink);
1101 	devl_port_unregister(devlink_port);
1102 	devl_unlock(devlink);
1103 }
1104 EXPORT_SYMBOL_GPL(devlink_port_unregister);
1105 
1106 static void devlink_port_type_netdev_checks(struct devlink_port *devlink_port,
1107 					    struct net_device *netdev)
1108 {
1109 	const struct net_device_ops *ops = netdev->netdev_ops;
1110 
1111 	/* If driver registers devlink port, it should set devlink port
1112 	 * attributes accordingly so the compat functions are called
1113 	 * and the original ops are not used.
1114 	 */
1115 	if (ops->ndo_get_phys_port_name) {
1116 		/* Some drivers use the same set of ndos for netdevs
1117 		 * that have devlink_port registered and also for
1118 		 * those who don't. Make sure that ndo_get_phys_port_name
1119 		 * returns -EOPNOTSUPP here in case it is defined.
1120 		 * Warn if not.
1121 		 */
1122 		char name[IFNAMSIZ];
1123 		int err;
1124 
1125 		err = ops->ndo_get_phys_port_name(netdev, name, sizeof(name));
1126 		WARN_ON(err != -EOPNOTSUPP);
1127 	}
1128 	if (ops->ndo_get_port_parent_id) {
1129 		/* Some drivers use the same set of ndos for netdevs
1130 		 * that have devlink_port registered and also for
1131 		 * those who don't. Make sure that ndo_get_port_parent_id
1132 		 * returns -EOPNOTSUPP here in case it is defined.
1133 		 * Warn if not.
1134 		 */
1135 		struct netdev_phys_item_id ppid;
1136 		int err;
1137 
1138 		err = ops->ndo_get_port_parent_id(netdev, &ppid);
1139 		WARN_ON(err != -EOPNOTSUPP);
1140 	}
1141 }
1142 
1143 static void __devlink_port_type_set(struct devlink_port *devlink_port,
1144 				    enum devlink_port_type type,
1145 				    void *type_dev)
1146 {
1147 	struct net_device *netdev = type_dev;
1148 
1149 	ASSERT_DEVLINK_PORT_REGISTERED(devlink_port);
1150 
1151 	if (type == DEVLINK_PORT_TYPE_NOTSET) {
1152 		devlink_port_type_warn_schedule(devlink_port);
1153 	} else {
1154 		devlink_port_type_warn_cancel(devlink_port);
1155 		if (type == DEVLINK_PORT_TYPE_ETH && netdev)
1156 			devlink_port_type_netdev_checks(devlink_port, netdev);
1157 	}
1158 
1159 	spin_lock_bh(&devlink_port->type_lock);
1160 	devlink_port->type = type;
1161 	switch (type) {
1162 	case DEVLINK_PORT_TYPE_ETH:
1163 		devlink_port->type_eth.netdev = netdev;
1164 		if (netdev) {
1165 			ASSERT_RTNL();
1166 			devlink_port->type_eth.ifindex = netdev->ifindex;
1167 			BUILD_BUG_ON(sizeof(devlink_port->type_eth.ifname) !=
1168 				     sizeof(netdev->name));
1169 			strcpy(devlink_port->type_eth.ifname, netdev->name);
1170 		}
1171 		break;
1172 	case DEVLINK_PORT_TYPE_IB:
1173 		devlink_port->type_ib.ibdev = type_dev;
1174 		break;
1175 	default:
1176 		break;
1177 	}
1178 	spin_unlock_bh(&devlink_port->type_lock);
1179 	devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
1180 }
1181 
1182 /**
1183  *	devlink_port_type_eth_set - Set port type to Ethernet
1184  *
1185  *	@devlink_port: devlink port
1186  *
1187  *	If driver is calling this, most likely it is doing something wrong.
1188  */
1189 void devlink_port_type_eth_set(struct devlink_port *devlink_port)
1190 {
1191 	dev_warn(devlink_port->devlink->dev,
1192 		 "devlink port type for port %d set to Ethernet without a software interface reference, device type not supported by the kernel?\n",
1193 		 devlink_port->index);
1194 	__devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_ETH, NULL);
1195 }
1196 EXPORT_SYMBOL_GPL(devlink_port_type_eth_set);
1197 
1198 /**
1199  *	devlink_port_type_ib_set - Set port type to InfiniBand
1200  *
1201  *	@devlink_port: devlink port
1202  *	@ibdev: related IB device
1203  */
1204 void devlink_port_type_ib_set(struct devlink_port *devlink_port,
1205 			      struct ib_device *ibdev)
1206 {
1207 	__devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_IB, ibdev);
1208 }
1209 EXPORT_SYMBOL_GPL(devlink_port_type_ib_set);
1210 
1211 /**
1212  *	devlink_port_type_clear - Clear port type
1213  *
1214  *	@devlink_port: devlink port
1215  *
1216  *	If driver is calling this for clearing Ethernet type, most likely
1217  *	it is doing something wrong.
1218  */
1219 void devlink_port_type_clear(struct devlink_port *devlink_port)
1220 {
1221 	if (devlink_port->type == DEVLINK_PORT_TYPE_ETH)
1222 		dev_warn(devlink_port->devlink->dev,
1223 			 "devlink port type for port %d cleared without a software interface reference, device type not supported by the kernel?\n",
1224 			 devlink_port->index);
1225 	__devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_NOTSET, NULL);
1226 }
1227 EXPORT_SYMBOL_GPL(devlink_port_type_clear);
1228 
1229 int devlink_port_netdevice_event(struct notifier_block *nb,
1230 				 unsigned long event, void *ptr)
1231 {
1232 	struct net_device *netdev = netdev_notifier_info_to_dev(ptr);
1233 	struct devlink_port *devlink_port = netdev->devlink_port;
1234 	struct devlink *devlink;
1235 
1236 	if (!devlink_port)
1237 		return NOTIFY_OK;
1238 	devlink = devlink_port->devlink;
1239 
1240 	switch (event) {
1241 	case NETDEV_POST_INIT:
1242 		/* Set the type but not netdev pointer. It is going to be set
1243 		 * later on by NETDEV_REGISTER event. Happens once during
1244 		 * netdevice register
1245 		 */
1246 		__devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_ETH,
1247 					NULL);
1248 		break;
1249 	case NETDEV_REGISTER:
1250 	case NETDEV_CHANGENAME:
1251 		if (devlink_net(devlink) != dev_net(netdev))
1252 			return NOTIFY_OK;
1253 		/* Set the netdev on top of previously set type. Note this
1254 		 * event happens also during net namespace change so here
1255 		 * we take into account netdev pointer appearing in this
1256 		 * namespace.
1257 		 */
1258 		__devlink_port_type_set(devlink_port, devlink_port->type,
1259 					netdev);
1260 		break;
1261 	case NETDEV_UNREGISTER:
1262 		if (devlink_net(devlink) != dev_net(netdev))
1263 			return NOTIFY_OK;
1264 		/* Clear netdev pointer, but not the type. This event happens
1265 		 * also during net namespace change so we need to clear
1266 		 * pointer to netdev that is going to another net namespace.
1267 		 */
1268 		__devlink_port_type_set(devlink_port, devlink_port->type,
1269 					NULL);
1270 		break;
1271 	case NETDEV_PRE_UNINIT:
1272 		/* Clear the type and the netdev pointer. Happens one during
1273 		 * netdevice unregister.
1274 		 */
1275 		__devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_NOTSET,
1276 					NULL);
1277 		break;
1278 	}
1279 
1280 	return NOTIFY_OK;
1281 }
1282 
1283 static int __devlink_port_attrs_set(struct devlink_port *devlink_port,
1284 				    enum devlink_port_flavour flavour)
1285 {
1286 	struct devlink_port_attrs *attrs = &devlink_port->attrs;
1287 
1288 	devlink_port->attrs_set = true;
1289 	attrs->flavour = flavour;
1290 	if (attrs->switch_id.id_len) {
1291 		devlink_port->switch_port = true;
1292 		if (WARN_ON(attrs->switch_id.id_len > MAX_PHYS_ITEM_ID_LEN))
1293 			attrs->switch_id.id_len = MAX_PHYS_ITEM_ID_LEN;
1294 	} else {
1295 		devlink_port->switch_port = false;
1296 	}
1297 	return 0;
1298 }
1299 
1300 /**
1301  *	devlink_port_attrs_set - Set port attributes
1302  *
1303  *	@devlink_port: devlink port
1304  *	@attrs: devlink port attrs
1305  */
1306 void devlink_port_attrs_set(struct devlink_port *devlink_port,
1307 			    struct devlink_port_attrs *attrs)
1308 {
1309 	int ret;
1310 
1311 	ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1312 
1313 	devlink_port->attrs = *attrs;
1314 	ret = __devlink_port_attrs_set(devlink_port, attrs->flavour);
1315 	if (ret)
1316 		return;
1317 	WARN_ON(attrs->splittable && attrs->split);
1318 }
1319 EXPORT_SYMBOL_GPL(devlink_port_attrs_set);
1320 
1321 /**
1322  *	devlink_port_attrs_pci_pf_set - Set PCI PF port attributes
1323  *
1324  *	@devlink_port: devlink port
1325  *	@controller: associated controller number for the devlink port instance
1326  *	@pf: associated PF for the devlink port instance
1327  *	@external: indicates if the port is for an external controller
1328  */
1329 void devlink_port_attrs_pci_pf_set(struct devlink_port *devlink_port, u32 controller,
1330 				   u16 pf, bool external)
1331 {
1332 	struct devlink_port_attrs *attrs = &devlink_port->attrs;
1333 	int ret;
1334 
1335 	ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1336 
1337 	ret = __devlink_port_attrs_set(devlink_port,
1338 				       DEVLINK_PORT_FLAVOUR_PCI_PF);
1339 	if (ret)
1340 		return;
1341 	attrs->pci_pf.controller = controller;
1342 	attrs->pci_pf.pf = pf;
1343 	attrs->pci_pf.external = external;
1344 }
1345 EXPORT_SYMBOL_GPL(devlink_port_attrs_pci_pf_set);
1346 
1347 /**
1348  *	devlink_port_attrs_pci_vf_set - Set PCI VF port attributes
1349  *
1350  *	@devlink_port: devlink port
1351  *	@controller: associated controller number for the devlink port instance
1352  *	@pf: associated PF for the devlink port instance
1353  *	@vf: associated VF of a PF for the devlink port instance
1354  *	@external: indicates if the port is for an external controller
1355  */
1356 void devlink_port_attrs_pci_vf_set(struct devlink_port *devlink_port, u32 controller,
1357 				   u16 pf, u16 vf, bool external)
1358 {
1359 	struct devlink_port_attrs *attrs = &devlink_port->attrs;
1360 	int ret;
1361 
1362 	ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1363 
1364 	ret = __devlink_port_attrs_set(devlink_port,
1365 				       DEVLINK_PORT_FLAVOUR_PCI_VF);
1366 	if (ret)
1367 		return;
1368 	attrs->pci_vf.controller = controller;
1369 	attrs->pci_vf.pf = pf;
1370 	attrs->pci_vf.vf = vf;
1371 	attrs->pci_vf.external = external;
1372 }
1373 EXPORT_SYMBOL_GPL(devlink_port_attrs_pci_vf_set);
1374 
1375 /**
1376  *	devlink_port_attrs_pci_sf_set - Set PCI SF port attributes
1377  *
1378  *	@devlink_port: devlink port
1379  *	@controller: associated controller number for the devlink port instance
1380  *	@pf: associated PF for the devlink port instance
1381  *	@sf: associated SF of a PF for the devlink port instance
1382  *	@external: indicates if the port is for an external controller
1383  */
1384 void devlink_port_attrs_pci_sf_set(struct devlink_port *devlink_port, u32 controller,
1385 				   u16 pf, u32 sf, bool external)
1386 {
1387 	struct devlink_port_attrs *attrs = &devlink_port->attrs;
1388 	int ret;
1389 
1390 	ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1391 
1392 	ret = __devlink_port_attrs_set(devlink_port,
1393 				       DEVLINK_PORT_FLAVOUR_PCI_SF);
1394 	if (ret)
1395 		return;
1396 	attrs->pci_sf.controller = controller;
1397 	attrs->pci_sf.pf = pf;
1398 	attrs->pci_sf.sf = sf;
1399 	attrs->pci_sf.external = external;
1400 }
1401 EXPORT_SYMBOL_GPL(devlink_port_attrs_pci_sf_set);
1402 
1403 static void devlink_port_rel_notify_cb(struct devlink *devlink, u32 port_index)
1404 {
1405 	struct devlink_port *devlink_port;
1406 
1407 	devlink_port = devlink_port_get_by_index(devlink, port_index);
1408 	if (!devlink_port)
1409 		return;
1410 	devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
1411 }
1412 
1413 static void devlink_port_rel_cleanup_cb(struct devlink *devlink, u32 port_index,
1414 					u32 rel_index)
1415 {
1416 	struct devlink_port *devlink_port;
1417 
1418 	devlink_port = devlink_port_get_by_index(devlink, port_index);
1419 	if (devlink_port && devlink_port->rel_index == rel_index)
1420 		devlink_port->rel_index = 0;
1421 }
1422 
1423 /**
1424  * devl_port_fn_devlink_set - Attach peer devlink
1425  *			      instance to port function.
1426  * @devlink_port: devlink port
1427  * @fn_devlink: devlink instance to attach
1428  */
1429 int devl_port_fn_devlink_set(struct devlink_port *devlink_port,
1430 			     struct devlink *fn_devlink)
1431 {
1432 	ASSERT_DEVLINK_PORT_REGISTERED(devlink_port);
1433 
1434 	if (WARN_ON(devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_SF ||
1435 		    devlink_port->attrs.pci_sf.external))
1436 		return -EINVAL;
1437 
1438 	return devlink_rel_nested_in_add(&devlink_port->rel_index,
1439 					 devlink_port->devlink->index,
1440 					 devlink_port->index,
1441 					 devlink_port_rel_notify_cb,
1442 					 devlink_port_rel_cleanup_cb,
1443 					 fn_devlink);
1444 }
1445 EXPORT_SYMBOL_GPL(devl_port_fn_devlink_set);
1446 
1447 /**
1448  *	devlink_port_linecard_set - Link port with a linecard
1449  *
1450  *	@devlink_port: devlink port
1451  *	@linecard: devlink linecard
1452  */
1453 void devlink_port_linecard_set(struct devlink_port *devlink_port,
1454 			       struct devlink_linecard *linecard)
1455 {
1456 	ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1457 
1458 	devlink_port->linecard = linecard;
1459 }
1460 EXPORT_SYMBOL_GPL(devlink_port_linecard_set);
1461 
1462 static int __devlink_port_phys_port_name_get(struct devlink_port *devlink_port,
1463 					     char *name, size_t len)
1464 {
1465 	struct devlink_port_attrs *attrs = &devlink_port->attrs;
1466 	int n = 0;
1467 
1468 	if (!devlink_port->attrs_set)
1469 		return -EOPNOTSUPP;
1470 
1471 	switch (attrs->flavour) {
1472 	case DEVLINK_PORT_FLAVOUR_PHYSICAL:
1473 		if (devlink_port->linecard)
1474 			n = snprintf(name, len, "l%u",
1475 				     devlink_linecard_index(devlink_port->linecard));
1476 		if (n < len)
1477 			n += snprintf(name + n, len - n, "p%u",
1478 				      attrs->phys.port_number);
1479 		if (n < len && attrs->split)
1480 			n += snprintf(name + n, len - n, "s%u",
1481 				      attrs->phys.split_subport_number);
1482 		break;
1483 	case DEVLINK_PORT_FLAVOUR_CPU:
1484 	case DEVLINK_PORT_FLAVOUR_DSA:
1485 	case DEVLINK_PORT_FLAVOUR_UNUSED:
1486 		/* As CPU and DSA ports do not have a netdevice associated
1487 		 * case should not ever happen.
1488 		 */
1489 		WARN_ON(1);
1490 		return -EINVAL;
1491 	case DEVLINK_PORT_FLAVOUR_PCI_PF:
1492 		if (attrs->pci_pf.external) {
1493 			n = snprintf(name, len, "c%u", attrs->pci_pf.controller);
1494 			if (n >= len)
1495 				return -EINVAL;
1496 			len -= n;
1497 			name += n;
1498 		}
1499 		n = snprintf(name, len, "pf%u", attrs->pci_pf.pf);
1500 		break;
1501 	case DEVLINK_PORT_FLAVOUR_PCI_VF:
1502 		if (attrs->pci_vf.external) {
1503 			n = snprintf(name, len, "c%u", attrs->pci_vf.controller);
1504 			if (n >= len)
1505 				return -EINVAL;
1506 			len -= n;
1507 			name += n;
1508 		}
1509 		n = snprintf(name, len, "pf%uvf%u",
1510 			     attrs->pci_vf.pf, attrs->pci_vf.vf);
1511 		break;
1512 	case DEVLINK_PORT_FLAVOUR_PCI_SF:
1513 		if (attrs->pci_sf.external) {
1514 			n = snprintf(name, len, "c%u", attrs->pci_sf.controller);
1515 			if (n >= len)
1516 				return -EINVAL;
1517 			len -= n;
1518 			name += n;
1519 		}
1520 		n = snprintf(name, len, "pf%usf%u", attrs->pci_sf.pf,
1521 			     attrs->pci_sf.sf);
1522 		break;
1523 	case DEVLINK_PORT_FLAVOUR_VIRTUAL:
1524 		return -EOPNOTSUPP;
1525 	}
1526 
1527 	if (n >= len)
1528 		return -EINVAL;
1529 
1530 	return 0;
1531 }
1532 
1533 int devlink_compat_phys_port_name_get(struct net_device *dev,
1534 				      char *name, size_t len)
1535 {
1536 	struct devlink_port *devlink_port;
1537 
1538 	/* RTNL mutex is held here which ensures that devlink_port
1539 	 * instance cannot disappear in the middle. No need to take
1540 	 * any devlink lock as only permanent values are accessed.
1541 	 */
1542 	ASSERT_RTNL();
1543 
1544 	devlink_port = dev->devlink_port;
1545 	if (!devlink_port)
1546 		return -EOPNOTSUPP;
1547 
1548 	return __devlink_port_phys_port_name_get(devlink_port, name, len);
1549 }
1550 
1551 int devlink_compat_switch_id_get(struct net_device *dev,
1552 				 struct netdev_phys_item_id *ppid)
1553 {
1554 	struct devlink_port *devlink_port;
1555 
1556 	/* Caller must hold RTNL mutex or reference to dev, which ensures that
1557 	 * devlink_port instance cannot disappear in the middle. No need to take
1558 	 * any devlink lock as only permanent values are accessed.
1559 	 */
1560 	devlink_port = dev->devlink_port;
1561 	if (!devlink_port || !devlink_port->switch_port)
1562 		return -EOPNOTSUPP;
1563 
1564 	memcpy(ppid, &devlink_port->attrs.switch_id, sizeof(*ppid));
1565 
1566 	return 0;
1567 }
1568