1 // SPDX-License-Identifier: GPL-2.0-or-later
3 * Copyright (c) 2016 Mellanox Technologies. All rights reserved.
7 #include "devl_internal.h"
9 #define DEVLINK_PORT_FN_CAPS_VALID_MASK \
10 (_BITUL(__DEVLINK_PORT_FN_ATTR_CAPS_MAX) - 1)
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 [DEVLINK_PORT_FN_ATTR_MAX_IO_EQS] = { .type = NLA_U32 },
22 #define ASSERT_DEVLINK_PORT_REGISTERED(devlink_port) \
23 WARN_ON_ONCE(!(devlink_port)->registered)
24 #define ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port) \
25 WARN_ON_ONCE((devlink_port)->registered)
27 struct devlink_port *devlink_port_get_by_index(struct devlink *devlink,
28 unsigned int port_index)
30 return xa_load(&devlink->ports, port_index);
33 struct devlink_port *devlink_port_get_from_attrs(struct devlink *devlink,
34 struct nlattr **attrs)
36 if (attrs[DEVLINK_ATTR_PORT_INDEX]) {
37 u32 port_index = nla_get_u32(attrs[DEVLINK_ATTR_PORT_INDEX]);
38 struct devlink_port *devlink_port;
40 devlink_port = devlink_port_get_by_index(devlink, port_index);
42 return ERR_PTR(-ENODEV);
45 return ERR_PTR(-EINVAL);
48 struct devlink_port *devlink_port_get_from_info(struct devlink *devlink,
49 struct genl_info *info)
51 return devlink_port_get_from_attrs(devlink, info->attrs);
54 static void devlink_port_fn_cap_fill(struct nla_bitfield32 *caps,
55 u32 cap, bool is_enable)
57 caps->selector |= cap;
62 static int devlink_port_fn_roce_fill(struct devlink_port *devlink_port,
63 struct nla_bitfield32 *caps,
64 struct netlink_ext_ack *extack)
69 if (!devlink_port->ops->port_fn_roce_get)
72 err = devlink_port->ops->port_fn_roce_get(devlink_port, &is_enable,
75 if (err == -EOPNOTSUPP)
80 devlink_port_fn_cap_fill(caps, DEVLINK_PORT_FN_CAP_ROCE, is_enable);
84 static int devlink_port_fn_migratable_fill(struct devlink_port *devlink_port,
85 struct nla_bitfield32 *caps,
86 struct netlink_ext_ack *extack)
91 if (!devlink_port->ops->port_fn_migratable_get ||
92 devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF)
95 err = devlink_port->ops->port_fn_migratable_get(devlink_port,
98 if (err == -EOPNOTSUPP)
103 devlink_port_fn_cap_fill(caps, DEVLINK_PORT_FN_CAP_MIGRATABLE, is_enable);
107 static int devlink_port_fn_ipsec_crypto_fill(struct devlink_port *devlink_port,
108 struct nla_bitfield32 *caps,
109 struct netlink_ext_ack *extack)
114 if (!devlink_port->ops->port_fn_ipsec_crypto_get ||
115 devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF)
118 err = devlink_port->ops->port_fn_ipsec_crypto_get(devlink_port, &is_enable, extack);
120 if (err == -EOPNOTSUPP)
125 devlink_port_fn_cap_fill(caps, DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO, is_enable);
129 static int devlink_port_fn_ipsec_packet_fill(struct devlink_port *devlink_port,
130 struct nla_bitfield32 *caps,
131 struct netlink_ext_ack *extack)
136 if (!devlink_port->ops->port_fn_ipsec_packet_get ||
137 devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF)
140 err = devlink_port->ops->port_fn_ipsec_packet_get(devlink_port, &is_enable, extack);
142 if (err == -EOPNOTSUPP)
147 devlink_port_fn_cap_fill(caps, DEVLINK_PORT_FN_CAP_IPSEC_PACKET, is_enable);
151 static int devlink_port_fn_caps_fill(struct devlink_port *devlink_port,
153 struct netlink_ext_ack *extack,
156 struct nla_bitfield32 caps = {};
159 err = devlink_port_fn_roce_fill(devlink_port, &caps, extack);
163 err = devlink_port_fn_migratable_fill(devlink_port, &caps, extack);
167 err = devlink_port_fn_ipsec_crypto_fill(devlink_port, &caps, extack);
171 err = devlink_port_fn_ipsec_packet_fill(devlink_port, &caps, extack);
177 err = nla_put_bitfield32(msg, DEVLINK_PORT_FN_ATTR_CAPS, caps.value,
186 static int devlink_port_fn_max_io_eqs_fill(struct devlink_port *port,
188 struct netlink_ext_ack *extack,
194 if (!port->ops->port_fn_max_io_eqs_get)
197 err = port->ops->port_fn_max_io_eqs_get(port, &max_io_eqs, extack);
199 if (err == -EOPNOTSUPP)
203 err = nla_put_u32(msg, DEVLINK_PORT_FN_ATTR_MAX_IO_EQS, max_io_eqs);
210 int devlink_nl_port_handle_fill(struct sk_buff *msg, struct devlink_port *devlink_port)
212 if (devlink_nl_put_handle(msg, devlink_port->devlink))
214 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_INDEX, devlink_port->index))
219 size_t devlink_nl_port_handle_size(struct devlink_port *devlink_port)
221 struct devlink *devlink = devlink_port->devlink;
223 return nla_total_size(strlen(devlink->dev->bus->name) + 1) /* DEVLINK_ATTR_BUS_NAME */
224 + nla_total_size(strlen(dev_name(devlink->dev)) + 1) /* DEVLINK_ATTR_DEV_NAME */
225 + nla_total_size(4); /* DEVLINK_ATTR_PORT_INDEX */
228 static int devlink_nl_port_attrs_put(struct sk_buff *msg,
229 struct devlink_port *devlink_port)
231 struct devlink_port_attrs *attrs = &devlink_port->attrs;
233 if (!devlink_port->attrs_set)
236 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_LANES, attrs->lanes))
239 if (nla_put_u8(msg, DEVLINK_ATTR_PORT_SPLITTABLE, attrs->splittable))
241 if (nla_put_u16(msg, DEVLINK_ATTR_PORT_FLAVOUR, attrs->flavour))
243 switch (devlink_port->attrs.flavour) {
244 case DEVLINK_PORT_FLAVOUR_PCI_PF:
245 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_CONTROLLER_NUMBER,
246 attrs->pci_pf.controller) ||
247 nla_put_u16(msg, DEVLINK_ATTR_PORT_PCI_PF_NUMBER, attrs->pci_pf.pf))
249 if (nla_put_u8(msg, DEVLINK_ATTR_PORT_EXTERNAL, attrs->pci_pf.external))
252 case DEVLINK_PORT_FLAVOUR_PCI_VF:
253 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_CONTROLLER_NUMBER,
254 attrs->pci_vf.controller) ||
255 nla_put_u16(msg, DEVLINK_ATTR_PORT_PCI_PF_NUMBER, attrs->pci_vf.pf) ||
256 nla_put_u16(msg, DEVLINK_ATTR_PORT_PCI_VF_NUMBER, attrs->pci_vf.vf))
258 if (nla_put_u8(msg, DEVLINK_ATTR_PORT_EXTERNAL, attrs->pci_vf.external))
261 case DEVLINK_PORT_FLAVOUR_PCI_SF:
262 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_CONTROLLER_NUMBER,
263 attrs->pci_sf.controller) ||
264 nla_put_u16(msg, DEVLINK_ATTR_PORT_PCI_PF_NUMBER,
266 nla_put_u32(msg, DEVLINK_ATTR_PORT_PCI_SF_NUMBER,
270 case DEVLINK_PORT_FLAVOUR_PHYSICAL:
271 case DEVLINK_PORT_FLAVOUR_CPU:
272 case DEVLINK_PORT_FLAVOUR_DSA:
273 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_NUMBER,
274 attrs->phys.port_number))
278 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_SPLIT_GROUP,
279 attrs->phys.port_number))
281 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_SPLIT_SUBPORT_NUMBER,
282 attrs->phys.split_subport_number))
291 static int devlink_port_fn_hw_addr_fill(struct devlink_port *port,
293 struct netlink_ext_ack *extack,
296 u8 hw_addr[MAX_ADDR_LEN];
300 if (!port->ops->port_fn_hw_addr_get)
303 err = port->ops->port_fn_hw_addr_get(port, hw_addr, &hw_addr_len,
306 if (err == -EOPNOTSUPP)
310 err = nla_put(msg, DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR, hw_addr_len, hw_addr);
318 devlink_port_fn_state_valid(enum devlink_port_fn_state state)
320 return state == DEVLINK_PORT_FN_STATE_INACTIVE ||
321 state == DEVLINK_PORT_FN_STATE_ACTIVE;
325 devlink_port_fn_opstate_valid(enum devlink_port_fn_opstate opstate)
327 return opstate == DEVLINK_PORT_FN_OPSTATE_DETACHED ||
328 opstate == DEVLINK_PORT_FN_OPSTATE_ATTACHED;
331 static int devlink_port_fn_state_fill(struct devlink_port *port,
333 struct netlink_ext_ack *extack,
336 enum devlink_port_fn_opstate opstate;
337 enum devlink_port_fn_state state;
340 if (!port->ops->port_fn_state_get)
343 err = port->ops->port_fn_state_get(port, &state, &opstate, extack);
345 if (err == -EOPNOTSUPP)
349 if (!devlink_port_fn_state_valid(state)) {
351 NL_SET_ERR_MSG(extack, "Invalid state read from driver");
354 if (!devlink_port_fn_opstate_valid(opstate)) {
356 NL_SET_ERR_MSG(extack, "Invalid operational state read from driver");
359 if (nla_put_u8(msg, DEVLINK_PORT_FN_ATTR_STATE, state) ||
360 nla_put_u8(msg, DEVLINK_PORT_FN_ATTR_OPSTATE, opstate))
367 devlink_port_fn_mig_set(struct devlink_port *devlink_port, bool enable,
368 struct netlink_ext_ack *extack)
370 return devlink_port->ops->port_fn_migratable_set(devlink_port, enable,
375 devlink_port_fn_roce_set(struct devlink_port *devlink_port, bool enable,
376 struct netlink_ext_ack *extack)
378 return devlink_port->ops->port_fn_roce_set(devlink_port, enable,
383 devlink_port_fn_ipsec_crypto_set(struct devlink_port *devlink_port, bool enable,
384 struct netlink_ext_ack *extack)
386 return devlink_port->ops->port_fn_ipsec_crypto_set(devlink_port, enable, extack);
390 devlink_port_fn_ipsec_packet_set(struct devlink_port *devlink_port, bool enable,
391 struct netlink_ext_ack *extack)
393 return devlink_port->ops->port_fn_ipsec_packet_set(devlink_port, enable, extack);
396 static int devlink_port_fn_caps_set(struct devlink_port *devlink_port,
397 const struct nlattr *attr,
398 struct netlink_ext_ack *extack)
400 struct nla_bitfield32 caps;
404 caps = nla_get_bitfield32(attr);
405 caps_value = caps.value & caps.selector;
406 if (caps.selector & DEVLINK_PORT_FN_CAP_ROCE) {
407 err = devlink_port_fn_roce_set(devlink_port,
408 caps_value & DEVLINK_PORT_FN_CAP_ROCE,
413 if (caps.selector & DEVLINK_PORT_FN_CAP_MIGRATABLE) {
414 err = devlink_port_fn_mig_set(devlink_port, caps_value &
415 DEVLINK_PORT_FN_CAP_MIGRATABLE,
420 if (caps.selector & DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO) {
421 err = devlink_port_fn_ipsec_crypto_set(devlink_port, caps_value &
422 DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO,
427 if (caps.selector & DEVLINK_PORT_FN_CAP_IPSEC_PACKET) {
428 err = devlink_port_fn_ipsec_packet_set(devlink_port, caps_value &
429 DEVLINK_PORT_FN_CAP_IPSEC_PACKET,
438 devlink_port_fn_max_io_eqs_set(struct devlink_port *devlink_port,
439 const struct nlattr *attr,
440 struct netlink_ext_ack *extack)
444 max_io_eqs = nla_get_u32(attr);
445 return devlink_port->ops->port_fn_max_io_eqs_set(devlink_port,
450 devlink_nl_port_function_attrs_put(struct sk_buff *msg, struct devlink_port *port,
451 struct netlink_ext_ack *extack)
453 struct nlattr *function_attr;
454 bool msg_updated = false;
457 function_attr = nla_nest_start_noflag(msg, DEVLINK_ATTR_PORT_FUNCTION);
461 err = devlink_port_fn_hw_addr_fill(port, msg, extack, &msg_updated);
464 err = devlink_port_fn_caps_fill(port, msg, extack, &msg_updated);
467 err = devlink_port_fn_state_fill(port, msg, extack, &msg_updated);
470 err = devlink_port_fn_max_io_eqs_fill(port, msg, extack, &msg_updated);
473 err = devlink_rel_devlink_handle_put(msg, port->devlink,
475 DEVLINK_PORT_FN_ATTR_DEVLINK,
479 if (err || !msg_updated)
480 nla_nest_cancel(msg, function_attr);
482 nla_nest_end(msg, function_attr);
486 static int devlink_nl_port_fill(struct sk_buff *msg,
487 struct devlink_port *devlink_port,
488 enum devlink_command cmd, u32 portid, u32 seq,
489 int flags, struct netlink_ext_ack *extack)
491 struct devlink *devlink = devlink_port->devlink;
494 hdr = genlmsg_put(msg, portid, seq, &devlink_nl_family, flags, cmd);
498 if (devlink_nl_put_handle(msg, devlink))
499 goto nla_put_failure;
500 if (nla_put_u32(msg, DEVLINK_ATTR_PORT_INDEX, devlink_port->index))
501 goto nla_put_failure;
503 spin_lock_bh(&devlink_port->type_lock);
504 if (nla_put_u16(msg, DEVLINK_ATTR_PORT_TYPE, devlink_port->type))
505 goto nla_put_failure_type_locked;
506 if (devlink_port->desired_type != DEVLINK_PORT_TYPE_NOTSET &&
507 nla_put_u16(msg, DEVLINK_ATTR_PORT_DESIRED_TYPE,
508 devlink_port->desired_type))
509 goto nla_put_failure_type_locked;
510 if (devlink_port->type == DEVLINK_PORT_TYPE_ETH) {
511 if (devlink_port->type_eth.netdev &&
512 (nla_put_u32(msg, DEVLINK_ATTR_PORT_NETDEV_IFINDEX,
513 devlink_port->type_eth.ifindex) ||
514 nla_put_string(msg, DEVLINK_ATTR_PORT_NETDEV_NAME,
515 devlink_port->type_eth.ifname)))
516 goto nla_put_failure_type_locked;
518 if (devlink_port->type == DEVLINK_PORT_TYPE_IB) {
519 struct ib_device *ibdev = devlink_port->type_ib.ibdev;
522 nla_put_string(msg, DEVLINK_ATTR_PORT_IBDEV_NAME,
524 goto nla_put_failure_type_locked;
526 spin_unlock_bh(&devlink_port->type_lock);
527 if (devlink_nl_port_attrs_put(msg, devlink_port))
528 goto nla_put_failure;
529 if (devlink_nl_port_function_attrs_put(msg, devlink_port, extack))
530 goto nla_put_failure;
531 if (devlink_port->linecard &&
532 nla_put_u32(msg, DEVLINK_ATTR_LINECARD_INDEX,
533 devlink_linecard_index(devlink_port->linecard)))
534 goto nla_put_failure;
536 genlmsg_end(msg, hdr);
539 nla_put_failure_type_locked:
540 spin_unlock_bh(&devlink_port->type_lock);
542 genlmsg_cancel(msg, hdr);
546 static void devlink_port_notify(struct devlink_port *devlink_port,
547 enum devlink_command cmd)
549 struct devlink *devlink = devlink_port->devlink;
550 struct devlink_obj_desc desc;
554 WARN_ON(cmd != DEVLINK_CMD_PORT_NEW && cmd != DEVLINK_CMD_PORT_DEL);
556 if (!__devl_is_registered(devlink) || !devlink_nl_notify_need(devlink))
559 msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
563 err = devlink_nl_port_fill(msg, devlink_port, cmd, 0, 0, 0, NULL);
569 devlink_nl_obj_desc_init(&desc, devlink);
570 devlink_nl_obj_desc_port_set(&desc, devlink_port);
571 devlink_nl_notify_send_desc(devlink, msg, &desc);
574 static void devlink_ports_notify(struct devlink *devlink,
575 enum devlink_command cmd)
577 struct devlink_port *devlink_port;
578 unsigned long port_index;
580 xa_for_each(&devlink->ports, port_index, devlink_port)
581 devlink_port_notify(devlink_port, cmd);
584 void devlink_ports_notify_register(struct devlink *devlink)
586 devlink_ports_notify(devlink, DEVLINK_CMD_PORT_NEW);
589 void devlink_ports_notify_unregister(struct devlink *devlink)
591 devlink_ports_notify(devlink, DEVLINK_CMD_PORT_DEL);
594 int devlink_nl_port_get_doit(struct sk_buff *skb, struct genl_info *info)
596 struct devlink_port *devlink_port = info->user_ptr[1];
600 msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
604 err = devlink_nl_port_fill(msg, devlink_port, DEVLINK_CMD_PORT_NEW,
605 info->snd_portid, info->snd_seq, 0,
612 return genlmsg_reply(msg, info);
616 devlink_nl_port_get_dump_one(struct sk_buff *msg, struct devlink *devlink,
617 struct netlink_callback *cb, int flags)
619 struct devlink_nl_dump_state *state = devlink_dump_state(cb);
620 struct devlink_port *devlink_port;
621 unsigned long port_index;
624 xa_for_each_start(&devlink->ports, port_index, devlink_port, state->idx) {
625 err = devlink_nl_port_fill(msg, devlink_port,
626 DEVLINK_CMD_PORT_NEW,
627 NETLINK_CB(cb->skb).portid,
628 cb->nlh->nlmsg_seq, flags,
631 state->idx = port_index;
639 int devlink_nl_port_get_dumpit(struct sk_buff *skb, struct netlink_callback *cb)
641 return devlink_nl_dumpit(skb, cb, devlink_nl_port_get_dump_one);
644 static int devlink_port_type_set(struct devlink_port *devlink_port,
645 enum devlink_port_type port_type)
650 if (!devlink_port->ops->port_type_set)
653 if (port_type == devlink_port->type)
656 err = devlink_port->ops->port_type_set(devlink_port, port_type);
660 devlink_port->desired_type = port_type;
661 devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
665 static int devlink_port_function_hw_addr_set(struct devlink_port *port,
666 const struct nlattr *attr,
667 struct netlink_ext_ack *extack)
672 hw_addr = nla_data(attr);
673 hw_addr_len = nla_len(attr);
674 if (hw_addr_len > MAX_ADDR_LEN) {
675 NL_SET_ERR_MSG(extack, "Port function hardware address too long");
678 if (port->type == DEVLINK_PORT_TYPE_ETH) {
679 if (hw_addr_len != ETH_ALEN) {
680 NL_SET_ERR_MSG(extack, "Address must be 6 bytes for Ethernet device");
683 if (!is_unicast_ether_addr(hw_addr)) {
684 NL_SET_ERR_MSG(extack, "Non-unicast hardware address unsupported");
689 return port->ops->port_fn_hw_addr_set(port, hw_addr, hw_addr_len,
693 static int devlink_port_fn_state_set(struct devlink_port *port,
694 const struct nlattr *attr,
695 struct netlink_ext_ack *extack)
697 enum devlink_port_fn_state state;
699 state = nla_get_u8(attr);
700 return port->ops->port_fn_state_set(port, state, extack);
703 static int devlink_port_function_validate(struct devlink_port *devlink_port,
705 struct netlink_ext_ack *extack)
707 const struct devlink_port_ops *ops = devlink_port->ops;
710 if (tb[DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR] &&
711 !ops->port_fn_hw_addr_set) {
712 NL_SET_ERR_MSG_ATTR(extack, tb[DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR],
713 "Port doesn't support function attributes");
716 if (tb[DEVLINK_PORT_FN_ATTR_STATE] && !ops->port_fn_state_set) {
717 NL_SET_ERR_MSG_ATTR(extack, tb[DEVLINK_PORT_FN_ATTR_STATE],
718 "Function does not support state setting");
721 attr = tb[DEVLINK_PORT_FN_ATTR_CAPS];
723 struct nla_bitfield32 caps;
725 caps = nla_get_bitfield32(attr);
726 if (caps.selector & DEVLINK_PORT_FN_CAP_ROCE &&
727 !ops->port_fn_roce_set) {
728 NL_SET_ERR_MSG_ATTR(extack, attr,
729 "Port doesn't support RoCE function attribute");
732 if (caps.selector & DEVLINK_PORT_FN_CAP_MIGRATABLE) {
733 if (!ops->port_fn_migratable_set) {
734 NL_SET_ERR_MSG_ATTR(extack, attr,
735 "Port doesn't support migratable function attribute");
738 if (devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF) {
739 NL_SET_ERR_MSG_ATTR(extack, attr,
740 "migratable function attribute supported for VFs only");
744 if (caps.selector & DEVLINK_PORT_FN_CAP_IPSEC_CRYPTO) {
745 if (!ops->port_fn_ipsec_crypto_set) {
746 NL_SET_ERR_MSG_ATTR(extack, attr,
747 "Port doesn't support ipsec_crypto function attribute");
750 if (devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF) {
751 NL_SET_ERR_MSG_ATTR(extack, attr,
752 "ipsec_crypto function attribute supported for VFs only");
756 if (caps.selector & DEVLINK_PORT_FN_CAP_IPSEC_PACKET) {
757 if (!ops->port_fn_ipsec_packet_set) {
758 NL_SET_ERR_MSG_ATTR(extack, attr,
759 "Port doesn't support ipsec_packet function attribute");
762 if (devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_VF) {
763 NL_SET_ERR_MSG_ATTR(extack, attr,
764 "ipsec_packet function attribute supported for VFs only");
769 if (tb[DEVLINK_PORT_FN_ATTR_MAX_IO_EQS] &&
770 !ops->port_fn_max_io_eqs_set) {
771 NL_SET_ERR_MSG_ATTR(extack, tb[DEVLINK_PORT_FN_ATTR_MAX_IO_EQS],
772 "Function does not support max_io_eqs setting");
778 static int devlink_port_function_set(struct devlink_port *port,
779 const struct nlattr *attr,
780 struct netlink_ext_ack *extack)
782 struct nlattr *tb[DEVLINK_PORT_FUNCTION_ATTR_MAX + 1];
785 err = nla_parse_nested(tb, DEVLINK_PORT_FUNCTION_ATTR_MAX, attr,
786 devlink_function_nl_policy, extack);
788 NL_SET_ERR_MSG(extack, "Fail to parse port function attributes");
792 err = devlink_port_function_validate(port, tb, extack);
796 attr = tb[DEVLINK_PORT_FUNCTION_ATTR_HW_ADDR];
798 err = devlink_port_function_hw_addr_set(port, attr, extack);
803 attr = tb[DEVLINK_PORT_FN_ATTR_CAPS];
805 err = devlink_port_fn_caps_set(port, attr, extack);
810 attr = tb[DEVLINK_PORT_FN_ATTR_MAX_IO_EQS];
812 err = devlink_port_fn_max_io_eqs_set(port, attr, extack);
817 /* Keep this as the last function attribute set, so that when
818 * multiple port function attributes are set along with state,
819 * Those can be applied first before activating the state.
821 attr = tb[DEVLINK_PORT_FN_ATTR_STATE];
823 err = devlink_port_fn_state_set(port, attr, extack);
826 devlink_port_notify(port, DEVLINK_CMD_PORT_NEW);
830 int devlink_nl_port_set_doit(struct sk_buff *skb, struct genl_info *info)
832 struct devlink_port *devlink_port = info->user_ptr[1];
835 if (info->attrs[DEVLINK_ATTR_PORT_TYPE]) {
836 enum devlink_port_type port_type;
838 port_type = nla_get_u16(info->attrs[DEVLINK_ATTR_PORT_TYPE]);
839 err = devlink_port_type_set(devlink_port, port_type);
844 if (info->attrs[DEVLINK_ATTR_PORT_FUNCTION]) {
845 struct nlattr *attr = info->attrs[DEVLINK_ATTR_PORT_FUNCTION];
846 struct netlink_ext_ack *extack = info->extack;
848 err = devlink_port_function_set(devlink_port, attr, extack);
856 int devlink_nl_port_split_doit(struct sk_buff *skb, struct genl_info *info)
858 struct devlink_port *devlink_port = info->user_ptr[1];
859 struct devlink *devlink = info->user_ptr[0];
862 if (GENL_REQ_ATTR_CHECK(info, DEVLINK_ATTR_PORT_SPLIT_COUNT))
864 if (!devlink_port->ops->port_split)
867 count = nla_get_u32(info->attrs[DEVLINK_ATTR_PORT_SPLIT_COUNT]);
869 if (!devlink_port->attrs.splittable) {
870 /* Split ports cannot be split. */
871 if (devlink_port->attrs.split)
872 NL_SET_ERR_MSG(info->extack, "Port cannot be split further");
874 NL_SET_ERR_MSG(info->extack, "Port cannot be split");
878 if (count < 2 || !is_power_of_2(count) || count > devlink_port->attrs.lanes) {
879 NL_SET_ERR_MSG(info->extack, "Invalid split count");
883 return devlink_port->ops->port_split(devlink, devlink_port, count,
887 int devlink_nl_port_unsplit_doit(struct sk_buff *skb, struct genl_info *info)
889 struct devlink_port *devlink_port = info->user_ptr[1];
890 struct devlink *devlink = info->user_ptr[0];
892 if (!devlink_port->ops->port_unsplit)
894 return devlink_port->ops->port_unsplit(devlink, devlink_port, info->extack);
897 int devlink_nl_port_new_doit(struct sk_buff *skb, struct genl_info *info)
899 struct netlink_ext_ack *extack = info->extack;
900 struct devlink_port_new_attrs new_attrs = {};
901 struct devlink *devlink = info->user_ptr[0];
902 struct devlink_port *devlink_port;
906 if (!devlink->ops->port_new)
909 if (!info->attrs[DEVLINK_ATTR_PORT_FLAVOUR] ||
910 !info->attrs[DEVLINK_ATTR_PORT_PCI_PF_NUMBER]) {
911 NL_SET_ERR_MSG(extack, "Port flavour or PCI PF are not specified");
914 new_attrs.flavour = nla_get_u16(info->attrs[DEVLINK_ATTR_PORT_FLAVOUR]);
916 nla_get_u16(info->attrs[DEVLINK_ATTR_PORT_PCI_PF_NUMBER]);
918 if (info->attrs[DEVLINK_ATTR_PORT_INDEX]) {
919 /* Port index of the new port being created by driver. */
920 new_attrs.port_index =
921 nla_get_u32(info->attrs[DEVLINK_ATTR_PORT_INDEX]);
922 new_attrs.port_index_valid = true;
924 if (info->attrs[DEVLINK_ATTR_PORT_CONTROLLER_NUMBER]) {
925 new_attrs.controller =
926 nla_get_u16(info->attrs[DEVLINK_ATTR_PORT_CONTROLLER_NUMBER]);
927 new_attrs.controller_valid = true;
929 if (new_attrs.flavour == DEVLINK_PORT_FLAVOUR_PCI_SF &&
930 info->attrs[DEVLINK_ATTR_PORT_PCI_SF_NUMBER]) {
931 new_attrs.sfnum = nla_get_u32(info->attrs[DEVLINK_ATTR_PORT_PCI_SF_NUMBER]);
932 new_attrs.sfnum_valid = true;
935 err = devlink->ops->port_new(devlink, &new_attrs,
936 extack, &devlink_port);
940 msg = nlmsg_new(NLMSG_DEFAULT_SIZE, GFP_KERNEL);
943 goto err_out_port_del;
945 err = devlink_nl_port_fill(msg, devlink_port, DEVLINK_CMD_PORT_NEW,
946 info->snd_portid, info->snd_seq, 0, NULL);
947 if (WARN_ON_ONCE(err))
948 goto err_out_msg_free;
949 err = genlmsg_reply(msg, info);
951 goto err_out_port_del;
957 devlink_port->ops->port_del(devlink, devlink_port, NULL);
961 int devlink_nl_port_del_doit(struct sk_buff *skb, struct genl_info *info)
963 struct devlink_port *devlink_port = info->user_ptr[1];
964 struct netlink_ext_ack *extack = info->extack;
965 struct devlink *devlink = info->user_ptr[0];
967 if (!devlink_port->ops->port_del)
970 return devlink_port->ops->port_del(devlink, devlink_port, extack);
973 static void devlink_port_type_warn(struct work_struct *work)
975 struct devlink_port *port = container_of(to_delayed_work(work),
978 dev_warn(port->devlink->dev, "Type was not set for devlink port.");
981 static bool devlink_port_type_should_warn(struct devlink_port *devlink_port)
983 /* Ignore CPU and DSA flavours. */
984 return devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_CPU &&
985 devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_DSA &&
986 devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_UNUSED;
989 #define DEVLINK_PORT_TYPE_WARN_TIMEOUT (HZ * 3600)
991 static void devlink_port_type_warn_schedule(struct devlink_port *devlink_port)
993 if (!devlink_port_type_should_warn(devlink_port))
995 /* Schedule a work to WARN in case driver does not set port
996 * type within timeout.
998 schedule_delayed_work(&devlink_port->type_warn_dw,
999 DEVLINK_PORT_TYPE_WARN_TIMEOUT);
1002 static void devlink_port_type_warn_cancel(struct devlink_port *devlink_port)
1004 if (!devlink_port_type_should_warn(devlink_port))
1006 cancel_delayed_work_sync(&devlink_port->type_warn_dw);
1010 * devlink_port_init() - Init devlink port
1013 * @devlink_port: devlink port
1015 * Initialize essential stuff that is needed for functions
1016 * that may be called before devlink port registration.
1017 * Call to this function is optional and not needed
1018 * in case the driver does not use such functions.
1020 void devlink_port_init(struct devlink *devlink,
1021 struct devlink_port *devlink_port)
1023 if (devlink_port->initialized)
1025 devlink_port->devlink = devlink;
1026 INIT_LIST_HEAD(&devlink_port->region_list);
1027 devlink_port->initialized = true;
1029 EXPORT_SYMBOL_GPL(devlink_port_init);
1032 * devlink_port_fini() - Deinitialize devlink port
1034 * @devlink_port: devlink port
1036 * Deinitialize essential stuff that is in use for functions
1037 * that may be called after devlink port unregistration.
1038 * Call to this function is optional and not needed
1039 * in case the driver does not use such functions.
1041 void devlink_port_fini(struct devlink_port *devlink_port)
1043 WARN_ON(!list_empty(&devlink_port->region_list));
1045 EXPORT_SYMBOL_GPL(devlink_port_fini);
1047 static const struct devlink_port_ops devlink_port_dummy_ops = {};
1050 * devl_port_register_with_ops() - Register devlink port
1053 * @devlink_port: devlink port
1054 * @port_index: driver-specific numerical identifier of the port
1057 * Register devlink port with provided port index. User can use
1058 * any indexing, even hw-related one. devlink_port structure
1059 * is convenient to be embedded inside user driver private structure.
1060 * Note that the caller should take care of zeroing the devlink_port
1063 int devl_port_register_with_ops(struct devlink *devlink,
1064 struct devlink_port *devlink_port,
1065 unsigned int port_index,
1066 const struct devlink_port_ops *ops)
1070 devl_assert_locked(devlink);
1072 ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1074 devlink_port_init(devlink, devlink_port);
1075 devlink_port->registered = true;
1076 devlink_port->index = port_index;
1077 devlink_port->ops = ops ? ops : &devlink_port_dummy_ops;
1078 spin_lock_init(&devlink_port->type_lock);
1079 INIT_LIST_HEAD(&devlink_port->reporter_list);
1080 err = xa_insert(&devlink->ports, port_index, devlink_port, GFP_KERNEL);
1082 devlink_port->registered = false;
1086 INIT_DELAYED_WORK(&devlink_port->type_warn_dw, &devlink_port_type_warn);
1087 devlink_port_type_warn_schedule(devlink_port);
1088 devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
1091 EXPORT_SYMBOL_GPL(devl_port_register_with_ops);
1094 * devlink_port_register_with_ops - Register devlink port
1097 * @devlink_port: devlink port
1098 * @port_index: driver-specific numerical identifier of the port
1101 * Register devlink port with provided port index. User can use
1102 * any indexing, even hw-related one. devlink_port structure
1103 * is convenient to be embedded inside user driver private structure.
1104 * Note that the caller should take care of zeroing the devlink_port
1107 * Context: Takes and release devlink->lock <mutex>.
1109 int devlink_port_register_with_ops(struct devlink *devlink,
1110 struct devlink_port *devlink_port,
1111 unsigned int port_index,
1112 const struct devlink_port_ops *ops)
1117 err = devl_port_register_with_ops(devlink, devlink_port,
1119 devl_unlock(devlink);
1122 EXPORT_SYMBOL_GPL(devlink_port_register_with_ops);
1125 * devl_port_unregister() - Unregister devlink port
1127 * @devlink_port: devlink port
1129 void devl_port_unregister(struct devlink_port *devlink_port)
1131 lockdep_assert_held(&devlink_port->devlink->lock);
1132 WARN_ON(devlink_port->type != DEVLINK_PORT_TYPE_NOTSET);
1134 devlink_port_type_warn_cancel(devlink_port);
1135 devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_DEL);
1136 xa_erase(&devlink_port->devlink->ports, devlink_port->index);
1137 WARN_ON(!list_empty(&devlink_port->reporter_list));
1138 devlink_port->registered = false;
1140 EXPORT_SYMBOL_GPL(devl_port_unregister);
1143 * devlink_port_unregister - Unregister devlink port
1145 * @devlink_port: devlink port
1147 * Context: Takes and release devlink->lock <mutex>.
1149 void devlink_port_unregister(struct devlink_port *devlink_port)
1151 struct devlink *devlink = devlink_port->devlink;
1154 devl_port_unregister(devlink_port);
1155 devl_unlock(devlink);
1157 EXPORT_SYMBOL_GPL(devlink_port_unregister);
1159 static void devlink_port_type_netdev_checks(struct devlink_port *devlink_port,
1160 struct net_device *netdev)
1162 const struct net_device_ops *ops = netdev->netdev_ops;
1164 /* If driver registers devlink port, it should set devlink port
1165 * attributes accordingly so the compat functions are called
1166 * and the original ops are not used.
1168 if (ops->ndo_get_phys_port_name) {
1169 /* Some drivers use the same set of ndos for netdevs
1170 * that have devlink_port registered and also for
1171 * those who don't. Make sure that ndo_get_phys_port_name
1172 * returns -EOPNOTSUPP here in case it is defined.
1175 char name[IFNAMSIZ];
1178 err = ops->ndo_get_phys_port_name(netdev, name, sizeof(name));
1179 WARN_ON(err != -EOPNOTSUPP);
1181 if (ops->ndo_get_port_parent_id) {
1182 /* Some drivers use the same set of ndos for netdevs
1183 * that have devlink_port registered and also for
1184 * those who don't. Make sure that ndo_get_port_parent_id
1185 * returns -EOPNOTSUPP here in case it is defined.
1188 struct netdev_phys_item_id ppid;
1191 err = ops->ndo_get_port_parent_id(netdev, &ppid);
1192 WARN_ON(err != -EOPNOTSUPP);
1196 static void __devlink_port_type_set(struct devlink_port *devlink_port,
1197 enum devlink_port_type type,
1200 struct net_device *netdev = type_dev;
1202 ASSERT_DEVLINK_PORT_REGISTERED(devlink_port);
1204 if (type == DEVLINK_PORT_TYPE_NOTSET) {
1205 devlink_port_type_warn_schedule(devlink_port);
1207 devlink_port_type_warn_cancel(devlink_port);
1208 if (type == DEVLINK_PORT_TYPE_ETH && netdev)
1209 devlink_port_type_netdev_checks(devlink_port, netdev);
1212 spin_lock_bh(&devlink_port->type_lock);
1213 devlink_port->type = type;
1215 case DEVLINK_PORT_TYPE_ETH:
1216 devlink_port->type_eth.netdev = netdev;
1219 devlink_port->type_eth.ifindex = netdev->ifindex;
1220 BUILD_BUG_ON(sizeof(devlink_port->type_eth.ifname) !=
1221 sizeof(netdev->name));
1222 strcpy(devlink_port->type_eth.ifname, netdev->name);
1225 case DEVLINK_PORT_TYPE_IB:
1226 devlink_port->type_ib.ibdev = type_dev;
1231 spin_unlock_bh(&devlink_port->type_lock);
1232 devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
1236 * devlink_port_type_eth_set - Set port type to Ethernet
1238 * @devlink_port: devlink port
1240 * If driver is calling this, most likely it is doing something wrong.
1242 void devlink_port_type_eth_set(struct devlink_port *devlink_port)
1244 dev_warn(devlink_port->devlink->dev,
1245 "devlink port type for port %d set to Ethernet without a software interface reference, device type not supported by the kernel?\n",
1246 devlink_port->index);
1247 __devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_ETH, NULL);
1249 EXPORT_SYMBOL_GPL(devlink_port_type_eth_set);
1252 * devlink_port_type_ib_set - Set port type to InfiniBand
1254 * @devlink_port: devlink port
1255 * @ibdev: related IB device
1257 void devlink_port_type_ib_set(struct devlink_port *devlink_port,
1258 struct ib_device *ibdev)
1260 __devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_IB, ibdev);
1262 EXPORT_SYMBOL_GPL(devlink_port_type_ib_set);
1265 * devlink_port_type_clear - Clear port type
1267 * @devlink_port: devlink port
1269 * If driver is calling this for clearing Ethernet type, most likely
1270 * it is doing something wrong.
1272 void devlink_port_type_clear(struct devlink_port *devlink_port)
1274 if (devlink_port->type == DEVLINK_PORT_TYPE_ETH)
1275 dev_warn(devlink_port->devlink->dev,
1276 "devlink port type for port %d cleared without a software interface reference, device type not supported by the kernel?\n",
1277 devlink_port->index);
1278 __devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_NOTSET, NULL);
1280 EXPORT_SYMBOL_GPL(devlink_port_type_clear);
1282 int devlink_port_netdevice_event(struct notifier_block *nb,
1283 unsigned long event, void *ptr)
1285 struct net_device *netdev = netdev_notifier_info_to_dev(ptr);
1286 struct devlink_port *devlink_port = netdev->devlink_port;
1287 struct devlink *devlink;
1291 devlink = devlink_port->devlink;
1294 case NETDEV_POST_INIT:
1295 /* Set the type but not netdev pointer. It is going to be set
1296 * later on by NETDEV_REGISTER event. Happens once during
1297 * netdevice register
1299 __devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_ETH,
1302 case NETDEV_REGISTER:
1303 case NETDEV_CHANGENAME:
1304 if (devlink_net(devlink) != dev_net(netdev))
1306 /* Set the netdev on top of previously set type. Note this
1307 * event happens also during net namespace change so here
1308 * we take into account netdev pointer appearing in this
1311 __devlink_port_type_set(devlink_port, devlink_port->type,
1314 case NETDEV_UNREGISTER:
1315 if (devlink_net(devlink) != dev_net(netdev))
1317 /* Clear netdev pointer, but not the type. This event happens
1318 * also during net namespace change so we need to clear
1319 * pointer to netdev that is going to another net namespace.
1321 __devlink_port_type_set(devlink_port, devlink_port->type,
1324 case NETDEV_PRE_UNINIT:
1325 /* Clear the type and the netdev pointer. Happens one during
1326 * netdevice unregister.
1328 __devlink_port_type_set(devlink_port, DEVLINK_PORT_TYPE_NOTSET,
1336 static int __devlink_port_attrs_set(struct devlink_port *devlink_port,
1337 enum devlink_port_flavour flavour)
1339 struct devlink_port_attrs *attrs = &devlink_port->attrs;
1341 devlink_port->attrs_set = true;
1342 attrs->flavour = flavour;
1343 if (attrs->switch_id.id_len) {
1344 devlink_port->switch_port = true;
1345 if (WARN_ON(attrs->switch_id.id_len > MAX_PHYS_ITEM_ID_LEN))
1346 attrs->switch_id.id_len = MAX_PHYS_ITEM_ID_LEN;
1348 devlink_port->switch_port = false;
1354 * devlink_port_attrs_set - Set port attributes
1356 * @devlink_port: devlink port
1357 * @attrs: devlink port attrs
1359 void devlink_port_attrs_set(struct devlink_port *devlink_port,
1360 struct devlink_port_attrs *attrs)
1364 ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1366 devlink_port->attrs = *attrs;
1367 ret = __devlink_port_attrs_set(devlink_port, attrs->flavour);
1370 WARN_ON(attrs->splittable && attrs->split);
1372 EXPORT_SYMBOL_GPL(devlink_port_attrs_set);
1375 * devlink_port_attrs_pci_pf_set - Set PCI PF port attributes
1377 * @devlink_port: devlink port
1378 * @controller: associated controller number for the devlink port instance
1379 * @pf: associated PCI function number for the devlink port instance
1380 * @external: indicates if the port is for an external controller
1382 void devlink_port_attrs_pci_pf_set(struct devlink_port *devlink_port, u32 controller,
1383 u16 pf, bool external)
1385 struct devlink_port_attrs *attrs = &devlink_port->attrs;
1388 ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1390 ret = __devlink_port_attrs_set(devlink_port,
1391 DEVLINK_PORT_FLAVOUR_PCI_PF);
1394 attrs->pci_pf.controller = controller;
1395 attrs->pci_pf.pf = pf;
1396 attrs->pci_pf.external = external;
1398 EXPORT_SYMBOL_GPL(devlink_port_attrs_pci_pf_set);
1401 * devlink_port_attrs_pci_vf_set - Set PCI VF port attributes
1403 * @devlink_port: devlink port
1404 * @controller: associated controller number for the devlink port instance
1405 * @pf: associated PCI function number for the devlink port instance
1406 * @vf: associated PCI VF number of a PF for the devlink port instance;
1407 * VF number starts from 0 for the first PCI virtual function
1408 * @external: indicates if the port is for an external controller
1410 void devlink_port_attrs_pci_vf_set(struct devlink_port *devlink_port, u32 controller,
1411 u16 pf, u16 vf, bool external)
1413 struct devlink_port_attrs *attrs = &devlink_port->attrs;
1416 ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1418 ret = __devlink_port_attrs_set(devlink_port,
1419 DEVLINK_PORT_FLAVOUR_PCI_VF);
1422 attrs->pci_vf.controller = controller;
1423 attrs->pci_vf.pf = pf;
1424 attrs->pci_vf.vf = vf;
1425 attrs->pci_vf.external = external;
1427 EXPORT_SYMBOL_GPL(devlink_port_attrs_pci_vf_set);
1430 * devlink_port_attrs_pci_sf_set - Set PCI SF port attributes
1432 * @devlink_port: devlink port
1433 * @controller: associated controller number for the devlink port instance
1434 * @pf: associated PCI function number for the devlink port instance
1435 * @sf: associated SF number of a PF for the devlink port instance
1436 * @external: indicates if the port is for an external controller
1438 void devlink_port_attrs_pci_sf_set(struct devlink_port *devlink_port, u32 controller,
1439 u16 pf, u32 sf, bool external)
1441 struct devlink_port_attrs *attrs = &devlink_port->attrs;
1444 ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1446 ret = __devlink_port_attrs_set(devlink_port,
1447 DEVLINK_PORT_FLAVOUR_PCI_SF);
1450 attrs->pci_sf.controller = controller;
1451 attrs->pci_sf.pf = pf;
1452 attrs->pci_sf.sf = sf;
1453 attrs->pci_sf.external = external;
1455 EXPORT_SYMBOL_GPL(devlink_port_attrs_pci_sf_set);
1457 static void devlink_port_rel_notify_cb(struct devlink *devlink, u32 port_index)
1459 struct devlink_port *devlink_port;
1461 devlink_port = devlink_port_get_by_index(devlink, port_index);
1464 devlink_port_notify(devlink_port, DEVLINK_CMD_PORT_NEW);
1467 static void devlink_port_rel_cleanup_cb(struct devlink *devlink, u32 port_index,
1470 struct devlink_port *devlink_port;
1472 devlink_port = devlink_port_get_by_index(devlink, port_index);
1473 if (devlink_port && devlink_port->rel_index == rel_index)
1474 devlink_port->rel_index = 0;
1478 * devl_port_fn_devlink_set - Attach peer devlink
1479 * instance to port function.
1480 * @devlink_port: devlink port
1481 * @fn_devlink: devlink instance to attach
1483 int devl_port_fn_devlink_set(struct devlink_port *devlink_port,
1484 struct devlink *fn_devlink)
1486 ASSERT_DEVLINK_PORT_REGISTERED(devlink_port);
1488 if (WARN_ON(devlink_port->attrs.flavour != DEVLINK_PORT_FLAVOUR_PCI_SF ||
1489 devlink_port->attrs.pci_sf.external))
1492 return devlink_rel_nested_in_add(&devlink_port->rel_index,
1493 devlink_port->devlink->index,
1494 devlink_port->index,
1495 devlink_port_rel_notify_cb,
1496 devlink_port_rel_cleanup_cb,
1499 EXPORT_SYMBOL_GPL(devl_port_fn_devlink_set);
1502 * devlink_port_linecard_set - Link port with a linecard
1504 * @devlink_port: devlink port
1505 * @linecard: devlink linecard
1507 void devlink_port_linecard_set(struct devlink_port *devlink_port,
1508 struct devlink_linecard *linecard)
1510 ASSERT_DEVLINK_PORT_NOT_REGISTERED(devlink_port);
1512 devlink_port->linecard = linecard;
1514 EXPORT_SYMBOL_GPL(devlink_port_linecard_set);
1516 static int __devlink_port_phys_port_name_get(struct devlink_port *devlink_port,
1517 char *name, size_t len)
1519 struct devlink_port_attrs *attrs = &devlink_port->attrs;
1522 if (!devlink_port->attrs_set)
1525 switch (attrs->flavour) {
1526 case DEVLINK_PORT_FLAVOUR_PHYSICAL:
1527 if (devlink_port->linecard)
1528 n = snprintf(name, len, "l%u",
1529 devlink_linecard_index(devlink_port->linecard));
1531 n += snprintf(name + n, len - n, "p%u",
1532 attrs->phys.port_number);
1533 if (n < len && attrs->split)
1534 n += snprintf(name + n, len - n, "s%u",
1535 attrs->phys.split_subport_number);
1537 case DEVLINK_PORT_FLAVOUR_CPU:
1538 case DEVLINK_PORT_FLAVOUR_DSA:
1539 case DEVLINK_PORT_FLAVOUR_UNUSED:
1540 /* As CPU and DSA ports do not have a netdevice associated
1541 * case should not ever happen.
1545 case DEVLINK_PORT_FLAVOUR_PCI_PF:
1546 if (attrs->pci_pf.external) {
1547 n = snprintf(name, len, "c%u", attrs->pci_pf.controller);
1553 n = snprintf(name, len, "pf%u", attrs->pci_pf.pf);
1555 case DEVLINK_PORT_FLAVOUR_PCI_VF:
1556 if (attrs->pci_vf.external) {
1557 n = snprintf(name, len, "c%u", attrs->pci_vf.controller);
1563 n = snprintf(name, len, "pf%uvf%u",
1564 attrs->pci_vf.pf, attrs->pci_vf.vf);
1566 case DEVLINK_PORT_FLAVOUR_PCI_SF:
1567 if (attrs->pci_sf.external) {
1568 n = snprintf(name, len, "c%u", attrs->pci_sf.controller);
1574 n = snprintf(name, len, "pf%usf%u", attrs->pci_sf.pf,
1577 case DEVLINK_PORT_FLAVOUR_VIRTUAL:
1587 int devlink_compat_phys_port_name_get(struct net_device *dev,
1588 char *name, size_t len)
1590 struct devlink_port *devlink_port;
1592 /* RTNL mutex is held here which ensures that devlink_port
1593 * instance cannot disappear in the middle. No need to take
1594 * any devlink lock as only permanent values are accessed.
1598 devlink_port = dev->devlink_port;
1602 return __devlink_port_phys_port_name_get(devlink_port, name, len);
1605 int devlink_compat_switch_id_get(struct net_device *dev,
1606 struct netdev_phys_item_id *ppid)
1608 struct devlink_port *devlink_port;
1610 /* Caller must hold RTNL mutex or reference to dev, which ensures that
1611 * devlink_port instance cannot disappear in the middle. No need to take
1612 * any devlink lock as only permanent values are accessed.
1614 devlink_port = dev->devlink_port;
1615 if (!devlink_port || !devlink_port->switch_port)
1618 memcpy(ppid, &devlink_port->attrs.switch_id, sizeof(*ppid));