1 // SPDX-License-Identifier: GPL-2.0-or-later 2 /* 3 * drivers/net/bond/bond_netlink.c - Netlink interface for bonding 4 * Copyright (c) 2013 Jiri Pirko <jiri@resnulli.us> 5 * Copyright (c) 2013 Scott Feldman <sfeldma@cumulusnetworks.com> 6 */ 7 8 #include <linux/module.h> 9 #include <linux/errno.h> 10 #include <linux/netdevice.h> 11 #include <linux/etherdevice.h> 12 #include <linux/if_link.h> 13 #include <linux/if_ether.h> 14 #include <net/netlink.h> 15 #include <net/rtnetlink.h> 16 #include <net/bonding.h> 17 #include <net/ipv6.h> 18 19 static size_t bond_get_slave_size(const struct net_device *bond_dev, 20 const struct net_device *slave_dev) 21 { 22 return nla_total_size(sizeof(u8)) + /* IFLA_BOND_SLAVE_STATE */ 23 nla_total_size(sizeof(u8)) + /* IFLA_BOND_SLAVE_MII_STATUS */ 24 nla_total_size(sizeof(u32)) + /* IFLA_BOND_SLAVE_LINK_FAILURE_COUNT */ 25 nla_total_size(MAX_ADDR_LEN) + /* IFLA_BOND_SLAVE_PERM_HWADDR */ 26 nla_total_size(sizeof(u16)) + /* IFLA_BOND_SLAVE_QUEUE_ID */ 27 nla_total_size(sizeof(u16)) + /* IFLA_BOND_SLAVE_AD_AGGREGATOR_ID */ 28 nla_total_size(sizeof(u8)) + /* IFLA_BOND_SLAVE_AD_ACTOR_OPER_PORT_STATE */ 29 nla_total_size(sizeof(u16)) + /* IFLA_BOND_SLAVE_AD_PARTNER_OPER_PORT_STATE */ 30 nla_total_size(sizeof(s32)) + /* IFLA_BOND_SLAVE_PRIO */ 31 nla_total_size(sizeof(u16)) + /* IFLA_BOND_SLAVE_ACTOR_PORT_PRIO */ 32 nla_total_size(sizeof(u8)) + /* IFLA_BOND_SLAVE_AD_CHURN_ACTOR_STATE */ 33 nla_total_size(sizeof(u8)) + /* IFLA_BOND_SLAVE_AD_CHURN_PARTNER_STATE */ 34 0; 35 } 36 37 static int bond_fill_slave_info(struct sk_buff *skb, 38 const struct net_device *bond_dev, 39 const struct net_device *slave_dev) 40 { 41 struct slave *slave = bond_slave_get_rtnl(slave_dev); 42 43 if (nla_put_u8(skb, IFLA_BOND_SLAVE_STATE, bond_slave_state(slave))) 44 goto nla_put_failure; 45 46 if (nla_put_u8(skb, IFLA_BOND_SLAVE_MII_STATUS, slave->link)) 47 goto nla_put_failure; 48 49 if (nla_put_u32(skb, IFLA_BOND_SLAVE_LINK_FAILURE_COUNT, 50 slave->link_failure_count)) 51 goto nla_put_failure; 52 53 if (nla_put(skb, IFLA_BOND_SLAVE_PERM_HWADDR, 54 slave_dev->addr_len, slave->perm_hwaddr)) 55 goto nla_put_failure; 56 57 if (nla_put_u16(skb, IFLA_BOND_SLAVE_QUEUE_ID, 58 READ_ONCE(slave->queue_id))) 59 goto nla_put_failure; 60 61 if (nla_put_s32(skb, IFLA_BOND_SLAVE_PRIO, slave->prio)) 62 goto nla_put_failure; 63 64 if (BOND_MODE(slave->bond) == BOND_MODE_8023AD) { 65 const struct aggregator *agg; 66 const struct port *ad_port; 67 68 ad_port = &SLAVE_AD_INFO(slave)->port; 69 rcu_read_lock(); 70 agg = rcu_dereference(SLAVE_AD_INFO(slave)->port.aggregator); 71 if (agg) { 72 if (nla_put_u16(skb, IFLA_BOND_SLAVE_AD_AGGREGATOR_ID, 73 agg->aggregator_identifier)) 74 goto nla_put_failure_rcu; 75 if (nla_put_u8(skb, 76 IFLA_BOND_SLAVE_AD_ACTOR_OPER_PORT_STATE, 77 ad_port->actor_oper_port_state)) 78 goto nla_put_failure_rcu; 79 if (nla_put_u16(skb, 80 IFLA_BOND_SLAVE_AD_PARTNER_OPER_PORT_STATE, 81 ad_port->partner_oper.port_state)) 82 goto nla_put_failure_rcu; 83 84 if (nla_put_u8(skb, IFLA_BOND_SLAVE_AD_CHURN_ACTOR_STATE, 85 READ_ONCE(ad_port->sm_churn_actor_state))) 86 goto nla_put_failure_rcu; 87 if (nla_put_u8(skb, IFLA_BOND_SLAVE_AD_CHURN_PARTNER_STATE, 88 READ_ONCE(ad_port->sm_churn_partner_state))) 89 goto nla_put_failure_rcu; 90 } 91 rcu_read_unlock(); 92 93 if (nla_put_u16(skb, IFLA_BOND_SLAVE_ACTOR_PORT_PRIO, 94 SLAVE_AD_INFO(slave)->port_priority)) 95 goto nla_put_failure; 96 } 97 98 return 0; 99 100 nla_put_failure_rcu: 101 rcu_read_unlock(); 102 nla_put_failure: 103 return -EMSGSIZE; 104 } 105 106 /* Limit the max delay range to 300s */ 107 static const struct netlink_range_validation delay_range = { 108 .max = 300000, 109 }; 110 111 static const struct nla_policy bond_policy[IFLA_BOND_MAX + 1] = { 112 [IFLA_BOND_MODE] = { .type = NLA_U8 }, 113 [IFLA_BOND_ACTIVE_SLAVE] = { .type = NLA_U32 }, 114 [IFLA_BOND_MIIMON] = { .type = NLA_U32 }, 115 [IFLA_BOND_UPDELAY] = { .type = NLA_U32 }, 116 [IFLA_BOND_DOWNDELAY] = { .type = NLA_U32 }, 117 [IFLA_BOND_USE_CARRIER] = { .type = NLA_U8 }, 118 [IFLA_BOND_ARP_INTERVAL] = { .type = NLA_U32 }, 119 [IFLA_BOND_ARP_IP_TARGET] = { .type = NLA_NESTED }, 120 [IFLA_BOND_ARP_VALIDATE] = { .type = NLA_U32 }, 121 [IFLA_BOND_ARP_ALL_TARGETS] = { .type = NLA_U32 }, 122 [IFLA_BOND_PRIMARY] = { .type = NLA_U32 }, 123 [IFLA_BOND_PRIMARY_RESELECT] = { .type = NLA_U8 }, 124 [IFLA_BOND_FAIL_OVER_MAC] = { .type = NLA_U8 }, 125 [IFLA_BOND_XMIT_HASH_POLICY] = { .type = NLA_U8 }, 126 [IFLA_BOND_RESEND_IGMP] = { .type = NLA_U32 }, 127 [IFLA_BOND_NUM_PEER_NOTIF] = { .type = NLA_U8 }, 128 [IFLA_BOND_ALL_SLAVES_ACTIVE] = { .type = NLA_U8 }, 129 [IFLA_BOND_MIN_LINKS] = { .type = NLA_U32 }, 130 [IFLA_BOND_LP_INTERVAL] = { .type = NLA_U32 }, 131 [IFLA_BOND_PACKETS_PER_SLAVE] = { .type = NLA_U32 }, 132 [IFLA_BOND_AD_LACP_ACTIVE] = { .type = NLA_U8 }, 133 [IFLA_BOND_AD_LACP_RATE] = { .type = NLA_U8 }, 134 [IFLA_BOND_AD_SELECT] = { .type = NLA_U8 }, 135 [IFLA_BOND_AD_INFO] = { .type = NLA_NESTED }, 136 [IFLA_BOND_AD_ACTOR_SYS_PRIO] = { .type = NLA_U16 }, 137 [IFLA_BOND_AD_USER_PORT_KEY] = { .type = NLA_U16 }, 138 [IFLA_BOND_AD_ACTOR_SYSTEM] = { .type = NLA_BINARY, 139 .len = ETH_ALEN }, 140 [IFLA_BOND_TLB_DYNAMIC_LB] = { .type = NLA_U8 }, 141 [IFLA_BOND_PEER_NOTIF_DELAY] = NLA_POLICY_FULL_RANGE(NLA_U32, &delay_range), 142 [IFLA_BOND_MISSED_MAX] = { .type = NLA_U8 }, 143 [IFLA_BOND_NS_IP6_TARGET] = { .type = NLA_NESTED }, 144 [IFLA_BOND_COUPLED_CONTROL] = { .type = NLA_U8 }, 145 [IFLA_BOND_BROADCAST_NEIGH] = { .type = NLA_U8 }, 146 [IFLA_BOND_LACP_STRICT] = { .type = NLA_U8 }, 147 }; 148 149 static const struct nla_policy bond_slave_policy[IFLA_BOND_SLAVE_MAX + 1] = { 150 [IFLA_BOND_SLAVE_QUEUE_ID] = { .type = NLA_U16 }, 151 [IFLA_BOND_SLAVE_PRIO] = { .type = NLA_S32 }, 152 [IFLA_BOND_SLAVE_ACTOR_PORT_PRIO] = { .type = NLA_U16 }, 153 }; 154 155 static int bond_validate(struct nlattr *tb[], struct nlattr *data[], 156 struct netlink_ext_ack *extack) 157 { 158 if (tb[IFLA_ADDRESS]) { 159 if (nla_len(tb[IFLA_ADDRESS]) != ETH_ALEN) 160 return -EINVAL; 161 if (!is_valid_ether_addr(nla_data(tb[IFLA_ADDRESS]))) 162 return -EADDRNOTAVAIL; 163 } 164 return 0; 165 } 166 167 static int bond_slave_changelink(struct net_device *bond_dev, 168 struct net_device *slave_dev, 169 struct nlattr *tb[], struct nlattr *data[], 170 struct netlink_ext_ack *extack) 171 { 172 struct bonding *bond = netdev_priv(bond_dev); 173 struct bond_opt_value newval; 174 int err; 175 176 if (!data) 177 return 0; 178 179 if (data[IFLA_BOND_SLAVE_QUEUE_ID]) { 180 u16 queue_id = nla_get_u16(data[IFLA_BOND_SLAVE_QUEUE_ID]); 181 char queue_id_str[IFNAMSIZ + 7]; 182 183 /* queue_id option setting expects slave_name:queue_id */ 184 snprintf(queue_id_str, sizeof(queue_id_str), "%s:%u\n", 185 slave_dev->name, queue_id); 186 bond_opt_initstr(&newval, queue_id_str); 187 err = __bond_opt_set(bond, BOND_OPT_QUEUE_ID, &newval, 188 data[IFLA_BOND_SLAVE_QUEUE_ID], extack); 189 if (err) 190 return err; 191 } 192 193 if (data[IFLA_BOND_SLAVE_PRIO]) { 194 int prio = nla_get_s32(data[IFLA_BOND_SLAVE_PRIO]); 195 196 bond_opt_slave_initval(&newval, &slave_dev, prio); 197 err = __bond_opt_set(bond, BOND_OPT_PRIO, &newval, 198 data[IFLA_BOND_SLAVE_PRIO], extack); 199 if (err) 200 return err; 201 } 202 203 if (data[IFLA_BOND_SLAVE_ACTOR_PORT_PRIO]) { 204 u16 ad_prio = nla_get_u16(data[IFLA_BOND_SLAVE_ACTOR_PORT_PRIO]); 205 206 bond_opt_slave_initval(&newval, &slave_dev, ad_prio); 207 err = __bond_opt_set(bond, BOND_OPT_ACTOR_PORT_PRIO, &newval, 208 data[IFLA_BOND_SLAVE_ACTOR_PORT_PRIO], extack); 209 if (err) 210 return err; 211 } 212 213 return 0; 214 } 215 216 static int bond_changelink(struct net_device *bond_dev, struct nlattr *tb[], 217 struct nlattr *data[], 218 struct netlink_ext_ack *extack) 219 { 220 struct bonding *bond = netdev_priv(bond_dev); 221 struct bond_opt_value newval; 222 int miimon = 0; 223 int err; 224 225 if (!data) 226 return 0; 227 228 if (data[IFLA_BOND_MODE]) { 229 int mode = nla_get_u8(data[IFLA_BOND_MODE]); 230 231 bond_opt_initval(&newval, mode); 232 err = __bond_opt_set(bond, BOND_OPT_MODE, &newval, 233 data[IFLA_BOND_MODE], extack); 234 if (err) 235 return err; 236 } 237 if (data[IFLA_BOND_ACTIVE_SLAVE]) { 238 int ifindex = nla_get_u32(data[IFLA_BOND_ACTIVE_SLAVE]); 239 struct net_device *slave_dev; 240 char *active_slave = ""; 241 242 if (ifindex != 0) { 243 slave_dev = __dev_get_by_index(dev_net(bond_dev), 244 ifindex); 245 if (!slave_dev) 246 return -ENODEV; 247 active_slave = slave_dev->name; 248 } 249 bond_opt_initstr(&newval, active_slave); 250 err = __bond_opt_set(bond, BOND_OPT_ACTIVE_SLAVE, &newval, 251 data[IFLA_BOND_ACTIVE_SLAVE], extack); 252 if (err) 253 return err; 254 } 255 if (data[IFLA_BOND_MIIMON]) { 256 miimon = nla_get_u32(data[IFLA_BOND_MIIMON]); 257 258 bond_opt_initval(&newval, miimon); 259 err = __bond_opt_set(bond, BOND_OPT_MIIMON, &newval, 260 data[IFLA_BOND_MIIMON], extack); 261 if (err) 262 return err; 263 } 264 if (data[IFLA_BOND_UPDELAY]) { 265 int updelay = nla_get_u32(data[IFLA_BOND_UPDELAY]); 266 267 bond_opt_initval(&newval, updelay); 268 err = __bond_opt_set(bond, BOND_OPT_UPDELAY, &newval, 269 data[IFLA_BOND_UPDELAY], extack); 270 if (err) 271 return err; 272 } 273 if (data[IFLA_BOND_DOWNDELAY]) { 274 int downdelay = nla_get_u32(data[IFLA_BOND_DOWNDELAY]); 275 276 bond_opt_initval(&newval, downdelay); 277 err = __bond_opt_set(bond, BOND_OPT_DOWNDELAY, &newval, 278 data[IFLA_BOND_DOWNDELAY], extack); 279 if (err) 280 return err; 281 } 282 if (data[IFLA_BOND_PEER_NOTIF_DELAY]) { 283 int delay = nla_get_u32(data[IFLA_BOND_PEER_NOTIF_DELAY]); 284 285 bond_opt_initval(&newval, delay); 286 err = __bond_opt_set(bond, BOND_OPT_PEER_NOTIF_DELAY, &newval, 287 data[IFLA_BOND_PEER_NOTIF_DELAY], extack); 288 if (err) 289 return err; 290 } 291 if (data[IFLA_BOND_USE_CARRIER]) { 292 if (nla_get_u8(data[IFLA_BOND_USE_CARRIER]) != 1) { 293 NL_SET_ERR_MSG_ATTR(extack, data[IFLA_BOND_USE_CARRIER], 294 "option obsolete, use_carrier cannot be disabled"); 295 return -EINVAL; 296 } 297 } 298 if (data[IFLA_BOND_ARP_INTERVAL]) { 299 int arp_interval = nla_get_u32(data[IFLA_BOND_ARP_INTERVAL]); 300 301 if (arp_interval && miimon) { 302 NL_SET_ERR_MSG_ATTR(extack, data[IFLA_BOND_ARP_INTERVAL], 303 "ARP monitoring cannot be used with MII monitoring"); 304 return -EINVAL; 305 } 306 307 bond_opt_initval(&newval, arp_interval); 308 err = __bond_opt_set(bond, BOND_OPT_ARP_INTERVAL, &newval, 309 data[IFLA_BOND_ARP_INTERVAL], extack); 310 if (err) 311 return err; 312 } 313 if (data[IFLA_BOND_ARP_IP_TARGET]) { 314 struct nlattr *attr; 315 int i = 0, rem; 316 317 bond_option_arp_ip_targets_clear(bond); 318 nla_for_each_nested(attr, data[IFLA_BOND_ARP_IP_TARGET], rem) { 319 __be32 target; 320 321 if (nla_len(attr) < sizeof(target)) 322 return -EINVAL; 323 324 target = nla_get_be32(attr); 325 326 bond_opt_initval(&newval, (__force u64)target); 327 err = __bond_opt_set(bond, BOND_OPT_ARP_TARGETS, 328 &newval, 329 data[IFLA_BOND_ARP_IP_TARGET], 330 extack); 331 if (err) 332 break; 333 i++; 334 } 335 if (i == 0 && bond->params.arp_interval) 336 netdev_warn(bond->dev, "Removing last arp target with arp_interval on\n"); 337 if (err) 338 return err; 339 } 340 #if IS_ENABLED(CONFIG_IPV6) 341 if (data[IFLA_BOND_NS_IP6_TARGET]) { 342 struct nlattr *attr; 343 int i = 0, rem; 344 345 bond_option_ns_ip6_targets_clear(bond); 346 nla_for_each_nested(attr, data[IFLA_BOND_NS_IP6_TARGET], rem) { 347 struct in6_addr addr6; 348 349 if (nla_len(attr) < sizeof(addr6)) { 350 NL_SET_ERR_MSG(extack, "Invalid IPv6 address"); 351 return -EINVAL; 352 } 353 354 addr6 = nla_get_in6_addr(attr); 355 356 bond_opt_initextra(&newval, &addr6, sizeof(addr6)); 357 err = __bond_opt_set(bond, BOND_OPT_NS_TARGETS, 358 &newval, 359 data[IFLA_BOND_NS_IP6_TARGET], 360 extack); 361 if (err) 362 break; 363 i++; 364 } 365 if (i == 0 && bond->params.arp_interval) 366 netdev_warn(bond->dev, "Removing last ns target with arp_interval on\n"); 367 if (err) 368 return err; 369 } 370 #endif 371 if (data[IFLA_BOND_ARP_VALIDATE]) { 372 int arp_validate = nla_get_u32(data[IFLA_BOND_ARP_VALIDATE]); 373 374 if (arp_validate && miimon) { 375 NL_SET_ERR_MSG_ATTR(extack, data[IFLA_BOND_ARP_INTERVAL], 376 "ARP validating cannot be used with MII monitoring"); 377 return -EINVAL; 378 } 379 380 bond_opt_initval(&newval, arp_validate); 381 err = __bond_opt_set(bond, BOND_OPT_ARP_VALIDATE, &newval, 382 data[IFLA_BOND_ARP_VALIDATE], extack); 383 if (err) 384 return err; 385 } 386 if (data[IFLA_BOND_ARP_ALL_TARGETS]) { 387 int arp_all_targets = 388 nla_get_u32(data[IFLA_BOND_ARP_ALL_TARGETS]); 389 390 bond_opt_initval(&newval, arp_all_targets); 391 err = __bond_opt_set(bond, BOND_OPT_ARP_ALL_TARGETS, &newval, 392 data[IFLA_BOND_ARP_ALL_TARGETS], extack); 393 if (err) 394 return err; 395 } 396 if (data[IFLA_BOND_PRIMARY]) { 397 int ifindex = nla_get_u32(data[IFLA_BOND_PRIMARY]); 398 struct net_device *dev; 399 char *primary = ""; 400 401 dev = __dev_get_by_index(dev_net(bond_dev), ifindex); 402 if (dev) 403 primary = dev->name; 404 405 bond_opt_initstr(&newval, primary); 406 err = __bond_opt_set(bond, BOND_OPT_PRIMARY, &newval, 407 data[IFLA_BOND_PRIMARY], extack); 408 if (err) 409 return err; 410 } 411 if (data[IFLA_BOND_PRIMARY_RESELECT]) { 412 int primary_reselect = 413 nla_get_u8(data[IFLA_BOND_PRIMARY_RESELECT]); 414 415 bond_opt_initval(&newval, primary_reselect); 416 err = __bond_opt_set(bond, BOND_OPT_PRIMARY_RESELECT, &newval, 417 data[IFLA_BOND_PRIMARY_RESELECT], extack); 418 if (err) 419 return err; 420 } 421 if (data[IFLA_BOND_FAIL_OVER_MAC]) { 422 int fail_over_mac = 423 nla_get_u8(data[IFLA_BOND_FAIL_OVER_MAC]); 424 425 bond_opt_initval(&newval, fail_over_mac); 426 err = __bond_opt_set(bond, BOND_OPT_FAIL_OVER_MAC, &newval, 427 data[IFLA_BOND_FAIL_OVER_MAC], extack); 428 if (err) 429 return err; 430 } 431 if (data[IFLA_BOND_XMIT_HASH_POLICY]) { 432 int xmit_hash_policy = 433 nla_get_u8(data[IFLA_BOND_XMIT_HASH_POLICY]); 434 435 bond_opt_initval(&newval, xmit_hash_policy); 436 err = __bond_opt_set(bond, BOND_OPT_XMIT_HASH, &newval, 437 data[IFLA_BOND_XMIT_HASH_POLICY], extack); 438 if (err) 439 return err; 440 } 441 if (data[IFLA_BOND_RESEND_IGMP]) { 442 int resend_igmp = 443 nla_get_u32(data[IFLA_BOND_RESEND_IGMP]); 444 445 bond_opt_initval(&newval, resend_igmp); 446 err = __bond_opt_set(bond, BOND_OPT_RESEND_IGMP, &newval, 447 data[IFLA_BOND_RESEND_IGMP], extack); 448 if (err) 449 return err; 450 } 451 if (data[IFLA_BOND_NUM_PEER_NOTIF]) { 452 int num_peer_notif = 453 nla_get_u8(data[IFLA_BOND_NUM_PEER_NOTIF]); 454 455 bond_opt_initval(&newval, num_peer_notif); 456 err = __bond_opt_set(bond, BOND_OPT_NUM_PEER_NOTIF, &newval, 457 data[IFLA_BOND_NUM_PEER_NOTIF], extack); 458 if (err) 459 return err; 460 } 461 if (data[IFLA_BOND_ALL_SLAVES_ACTIVE]) { 462 int all_slaves_active = 463 nla_get_u8(data[IFLA_BOND_ALL_SLAVES_ACTIVE]); 464 465 bond_opt_initval(&newval, all_slaves_active); 466 err = __bond_opt_set(bond, BOND_OPT_ALL_SLAVES_ACTIVE, &newval, 467 data[IFLA_BOND_ALL_SLAVES_ACTIVE], extack); 468 if (err) 469 return err; 470 } 471 if (data[IFLA_BOND_MIN_LINKS]) { 472 int min_links = 473 nla_get_u32(data[IFLA_BOND_MIN_LINKS]); 474 475 bond_opt_initval(&newval, min_links); 476 err = __bond_opt_set(bond, BOND_OPT_MINLINKS, &newval, 477 data[IFLA_BOND_MIN_LINKS], extack); 478 if (err) 479 return err; 480 } 481 if (data[IFLA_BOND_LP_INTERVAL]) { 482 int lp_interval = 483 nla_get_u32(data[IFLA_BOND_LP_INTERVAL]); 484 485 bond_opt_initval(&newval, lp_interval); 486 err = __bond_opt_set(bond, BOND_OPT_LP_INTERVAL, &newval, 487 data[IFLA_BOND_LP_INTERVAL], extack); 488 if (err) 489 return err; 490 } 491 if (data[IFLA_BOND_PACKETS_PER_SLAVE]) { 492 int packets_per_slave = 493 nla_get_u32(data[IFLA_BOND_PACKETS_PER_SLAVE]); 494 495 bond_opt_initval(&newval, packets_per_slave); 496 err = __bond_opt_set(bond, BOND_OPT_PACKETS_PER_SLAVE, &newval, 497 data[IFLA_BOND_PACKETS_PER_SLAVE], extack); 498 if (err) 499 return err; 500 } 501 502 if (data[IFLA_BOND_AD_LACP_ACTIVE]) { 503 int lacp_active = nla_get_u8(data[IFLA_BOND_AD_LACP_ACTIVE]); 504 505 bond_opt_initval(&newval, lacp_active); 506 err = __bond_opt_set(bond, BOND_OPT_LACP_ACTIVE, &newval, 507 data[IFLA_BOND_AD_LACP_ACTIVE], extack); 508 if (err) 509 return err; 510 } 511 512 if (data[IFLA_BOND_AD_LACP_RATE]) { 513 int lacp_rate = 514 nla_get_u8(data[IFLA_BOND_AD_LACP_RATE]); 515 516 bond_opt_initval(&newval, lacp_rate); 517 err = __bond_opt_set(bond, BOND_OPT_LACP_RATE, &newval, 518 data[IFLA_BOND_AD_LACP_RATE], extack); 519 if (err) 520 return err; 521 } 522 if (data[IFLA_BOND_AD_SELECT]) { 523 int ad_select = 524 nla_get_u8(data[IFLA_BOND_AD_SELECT]); 525 526 bond_opt_initval(&newval, ad_select); 527 err = __bond_opt_set(bond, BOND_OPT_AD_SELECT, &newval, 528 data[IFLA_BOND_AD_SELECT], extack); 529 if (err) 530 return err; 531 } 532 if (data[IFLA_BOND_AD_ACTOR_SYS_PRIO]) { 533 int actor_sys_prio = 534 nla_get_u16(data[IFLA_BOND_AD_ACTOR_SYS_PRIO]); 535 536 bond_opt_initval(&newval, actor_sys_prio); 537 err = __bond_opt_set(bond, BOND_OPT_AD_ACTOR_SYS_PRIO, &newval, 538 data[IFLA_BOND_AD_ACTOR_SYS_PRIO], extack); 539 if (err) 540 return err; 541 } 542 if (data[IFLA_BOND_AD_USER_PORT_KEY]) { 543 int port_key = 544 nla_get_u16(data[IFLA_BOND_AD_USER_PORT_KEY]); 545 546 bond_opt_initval(&newval, port_key); 547 err = __bond_opt_set(bond, BOND_OPT_AD_USER_PORT_KEY, &newval, 548 data[IFLA_BOND_AD_USER_PORT_KEY], extack); 549 if (err) 550 return err; 551 } 552 if (data[IFLA_BOND_AD_ACTOR_SYSTEM]) { 553 if (nla_len(data[IFLA_BOND_AD_ACTOR_SYSTEM]) != ETH_ALEN) 554 return -EINVAL; 555 556 bond_opt_initval(&newval, 557 nla_get_u64(data[IFLA_BOND_AD_ACTOR_SYSTEM])); 558 err = __bond_opt_set(bond, BOND_OPT_AD_ACTOR_SYSTEM, &newval, 559 data[IFLA_BOND_AD_ACTOR_SYSTEM], extack); 560 if (err) 561 return err; 562 } 563 if (data[IFLA_BOND_TLB_DYNAMIC_LB]) { 564 int dynamic_lb = nla_get_u8(data[IFLA_BOND_TLB_DYNAMIC_LB]); 565 566 bond_opt_initval(&newval, dynamic_lb); 567 err = __bond_opt_set(bond, BOND_OPT_TLB_DYNAMIC_LB, &newval, 568 data[IFLA_BOND_TLB_DYNAMIC_LB], extack); 569 if (err) 570 return err; 571 } 572 573 if (data[IFLA_BOND_MISSED_MAX]) { 574 int missed_max = nla_get_u8(data[IFLA_BOND_MISSED_MAX]); 575 576 bond_opt_initval(&newval, missed_max); 577 err = __bond_opt_set(bond, BOND_OPT_MISSED_MAX, &newval, 578 data[IFLA_BOND_MISSED_MAX], extack); 579 if (err) 580 return err; 581 } 582 583 if (data[IFLA_BOND_COUPLED_CONTROL]) { 584 int coupled_control = nla_get_u8(data[IFLA_BOND_COUPLED_CONTROL]); 585 586 bond_opt_initval(&newval, coupled_control); 587 err = __bond_opt_set(bond, BOND_OPT_COUPLED_CONTROL, &newval, 588 data[IFLA_BOND_COUPLED_CONTROL], extack); 589 if (err) 590 return err; 591 } 592 593 if (data[IFLA_BOND_BROADCAST_NEIGH]) { 594 int broadcast_neigh = nla_get_u8(data[IFLA_BOND_BROADCAST_NEIGH]); 595 596 bond_opt_initval(&newval, broadcast_neigh); 597 err = __bond_opt_set(bond, BOND_OPT_BROADCAST_NEIGH, &newval, 598 data[IFLA_BOND_BROADCAST_NEIGH], extack); 599 if (err) 600 return err; 601 } 602 603 if (data[IFLA_BOND_LACP_STRICT]) { 604 int fallback_mode = nla_get_u8(data[IFLA_BOND_LACP_STRICT]); 605 606 bond_opt_initval(&newval, fallback_mode); 607 err = __bond_opt_set(bond, BOND_OPT_LACP_STRICT, &newval, 608 data[IFLA_BOND_LACP_STRICT], extack); 609 if (err) 610 return err; 611 } 612 613 return 0; 614 } 615 616 static int bond_newlink(struct net_device *bond_dev, 617 struct rtnl_newlink_params *params, 618 struct netlink_ext_ack *extack) 619 { 620 struct bonding *bond = netdev_priv(bond_dev); 621 struct nlattr **data = params->data; 622 struct nlattr **tb = params->tb; 623 int err; 624 625 err = register_netdevice(bond_dev); 626 if (err) 627 return err; 628 629 netif_carrier_off(bond_dev); 630 bond_work_init_all(bond); 631 632 err = bond_changelink(bond_dev, tb, data, extack); 633 if (err) { 634 bond_work_cancel_all(bond); 635 unregister_netdevice(bond_dev); 636 } 637 638 return err; 639 } 640 641 static size_t bond_get_size(const struct net_device *bond_dev) 642 { 643 return nla_total_size(sizeof(u8)) + /* IFLA_BOND_MODE */ 644 nla_total_size(sizeof(u32)) + /* IFLA_BOND_ACTIVE_SLAVE */ 645 nla_total_size(sizeof(u32)) + /* IFLA_BOND_MIIMON */ 646 nla_total_size(sizeof(u32)) + /* IFLA_BOND_UPDELAY */ 647 nla_total_size(sizeof(u32)) + /* IFLA_BOND_DOWNDELAY */ 648 nla_total_size(sizeof(u8)) + /* IFLA_BOND_USE_CARRIER */ 649 nla_total_size(sizeof(u32)) + /* IFLA_BOND_ARP_INTERVAL */ 650 /* IFLA_BOND_ARP_IP_TARGET */ 651 nla_total_size(sizeof(struct nlattr)) + 652 nla_total_size(sizeof(u32)) * BOND_MAX_ARP_TARGETS + 653 nla_total_size(sizeof(u32)) + /* IFLA_BOND_ARP_VALIDATE */ 654 nla_total_size(sizeof(u32)) + /* IFLA_BOND_ARP_ALL_TARGETS */ 655 nla_total_size(sizeof(u32)) + /* IFLA_BOND_PRIMARY */ 656 nla_total_size(sizeof(u8)) + /* IFLA_BOND_PRIMARY_RESELECT */ 657 nla_total_size(sizeof(u8)) + /* IFLA_BOND_FAIL_OVER_MAC */ 658 nla_total_size(sizeof(u8)) + /* IFLA_BOND_XMIT_HASH_POLICY */ 659 nla_total_size(sizeof(u32)) + /* IFLA_BOND_RESEND_IGMP */ 660 nla_total_size(sizeof(u8)) + /* IFLA_BOND_NUM_PEER_NOTIF */ 661 nla_total_size(sizeof(u8)) + /* IFLA_BOND_ALL_SLAVES_ACTIVE */ 662 nla_total_size(sizeof(u32)) + /* IFLA_BOND_MIN_LINKS */ 663 nla_total_size(sizeof(u32)) + /* IFLA_BOND_LP_INTERVAL */ 664 nla_total_size(sizeof(u32)) + /* IFLA_BOND_PACKETS_PER_SLAVE */ 665 nla_total_size(sizeof(u8)) + /* IFLA_BOND_AD_LACP_ACTIVE */ 666 nla_total_size(sizeof(u8)) + /* IFLA_BOND_AD_LACP_RATE */ 667 nla_total_size(sizeof(u8)) + /* IFLA_BOND_AD_SELECT */ 668 nla_total_size(sizeof(struct nlattr)) + /* IFLA_BOND_AD_INFO */ 669 nla_total_size(sizeof(u16)) + /* IFLA_BOND_AD_INFO_AGGREGATOR */ 670 nla_total_size(sizeof(u16)) + /* IFLA_BOND_AD_INFO_NUM_PORTS */ 671 nla_total_size(sizeof(u16)) + /* IFLA_BOND_AD_INFO_ACTOR_KEY */ 672 nla_total_size(sizeof(u16)) + /* IFLA_BOND_AD_INFO_PARTNER_KEY*/ 673 nla_total_size(ETH_ALEN) + /* IFLA_BOND_AD_INFO_PARTNER_MAC*/ 674 nla_total_size(sizeof(u16)) + /* IFLA_BOND_AD_ACTOR_SYS_PRIO */ 675 nla_total_size(sizeof(u16)) + /* IFLA_BOND_AD_USER_PORT_KEY */ 676 nla_total_size(ETH_ALEN) + /* IFLA_BOND_AD_ACTOR_SYSTEM */ 677 nla_total_size(sizeof(u8)) + /* IFLA_BOND_TLB_DYNAMIC_LB */ 678 nla_total_size(sizeof(u32)) + /* IFLA_BOND_PEER_NOTIF_DELAY */ 679 nla_total_size(sizeof(u8)) + /* IFLA_BOND_MISSED_MAX */ 680 /* IFLA_BOND_NS_IP6_TARGET */ 681 nla_total_size(sizeof(struct nlattr)) + 682 nla_total_size(sizeof(struct in6_addr)) * BOND_MAX_NS_TARGETS + 683 nla_total_size(sizeof(u8)) + /* IFLA_BOND_COUPLED_CONTROL */ 684 nla_total_size(sizeof(u8)) + /* IFLA_BOND_BROADCAST_NEIGH */ 685 nla_total_size(sizeof(u8)) + /* IFLA_BOND_LACP_STRICT */ 686 0; 687 } 688 689 static int bond_option_active_slave_get_ifindex(struct bonding *bond) 690 { 691 const struct net_device *slave; 692 int ifindex; 693 694 rcu_read_lock(); 695 slave = bond_option_active_slave_get_rcu(bond); 696 ifindex = slave ? slave->ifindex : 0; 697 rcu_read_unlock(); 698 return ifindex; 699 } 700 701 static int bond_fill_info(struct sk_buff *skb, 702 const struct net_device *bond_dev) 703 { 704 struct bonding *bond = netdev_priv(bond_dev); 705 unsigned int packets_per_slave; 706 int ifindex, i, targets_added; 707 struct nlattr *targets; 708 struct slave *primary; 709 710 if (nla_put_u8(skb, IFLA_BOND_MODE, BOND_MODE(bond))) 711 goto nla_put_failure; 712 713 ifindex = bond_option_active_slave_get_ifindex(bond); 714 if (ifindex && nla_put_u32(skb, IFLA_BOND_ACTIVE_SLAVE, ifindex)) 715 goto nla_put_failure; 716 717 if (nla_put_u32(skb, IFLA_BOND_MIIMON, bond->params.miimon)) 718 goto nla_put_failure; 719 720 if (nla_put_u32(skb, IFLA_BOND_UPDELAY, 721 bond->params.updelay * bond->params.miimon)) 722 goto nla_put_failure; 723 724 if (nla_put_u32(skb, IFLA_BOND_DOWNDELAY, 725 bond->params.downdelay * bond->params.miimon)) 726 goto nla_put_failure; 727 728 if (nla_put_u32(skb, IFLA_BOND_PEER_NOTIF_DELAY, 729 bond->params.peer_notif_delay * bond->params.miimon)) 730 goto nla_put_failure; 731 732 if (nla_put_u8(skb, IFLA_BOND_USE_CARRIER, 1)) 733 goto nla_put_failure; 734 735 if (nla_put_u32(skb, IFLA_BOND_ARP_INTERVAL, bond->params.arp_interval)) 736 goto nla_put_failure; 737 738 targets = nla_nest_start_noflag(skb, IFLA_BOND_ARP_IP_TARGET); 739 if (!targets) 740 goto nla_put_failure; 741 742 targets_added = 0; 743 for (i = 0; i < BOND_MAX_ARP_TARGETS; i++) { 744 if (bond->params.arp_targets[i]) { 745 if (nla_put_be32(skb, i, bond->params.arp_targets[i])) 746 goto nla_put_failure; 747 targets_added = 1; 748 } 749 } 750 751 if (targets_added) 752 nla_nest_end(skb, targets); 753 else 754 nla_nest_cancel(skb, targets); 755 756 if (nla_put_u32(skb, IFLA_BOND_ARP_VALIDATE, bond->params.arp_validate)) 757 goto nla_put_failure; 758 759 if (nla_put_u32(skb, IFLA_BOND_ARP_ALL_TARGETS, 760 bond->params.arp_all_targets)) 761 goto nla_put_failure; 762 763 #if IS_ENABLED(CONFIG_IPV6) 764 targets = nla_nest_start(skb, IFLA_BOND_NS_IP6_TARGET); 765 if (!targets) 766 goto nla_put_failure; 767 768 targets_added = 0; 769 for (i = 0; i < BOND_MAX_NS_TARGETS; i++) { 770 if (!ipv6_addr_any(&bond->params.ns_targets[i])) { 771 if (nla_put_in6_addr(skb, i, &bond->params.ns_targets[i])) 772 goto nla_put_failure; 773 targets_added = 1; 774 } 775 } 776 777 if (targets_added) 778 nla_nest_end(skb, targets); 779 else 780 nla_nest_cancel(skb, targets); 781 #endif 782 783 primary = rtnl_dereference(bond->primary_slave); 784 if (primary && 785 nla_put_u32(skb, IFLA_BOND_PRIMARY, primary->dev->ifindex)) 786 goto nla_put_failure; 787 788 if (nla_put_u8(skb, IFLA_BOND_PRIMARY_RESELECT, 789 bond->params.primary_reselect)) 790 goto nla_put_failure; 791 792 if (nla_put_u8(skb, IFLA_BOND_FAIL_OVER_MAC, 793 bond->params.fail_over_mac)) 794 goto nla_put_failure; 795 796 if (nla_put_u8(skb, IFLA_BOND_XMIT_HASH_POLICY, 797 bond->params.xmit_policy)) 798 goto nla_put_failure; 799 800 if (nla_put_u32(skb, IFLA_BOND_RESEND_IGMP, 801 bond->params.resend_igmp)) 802 goto nla_put_failure; 803 804 if (nla_put_u8(skb, IFLA_BOND_NUM_PEER_NOTIF, 805 bond->params.num_peer_notif)) 806 goto nla_put_failure; 807 808 if (nla_put_u8(skb, IFLA_BOND_ALL_SLAVES_ACTIVE, 809 bond->params.all_slaves_active)) 810 goto nla_put_failure; 811 812 if (nla_put_u32(skb, IFLA_BOND_MIN_LINKS, 813 bond->params.min_links)) 814 goto nla_put_failure; 815 816 if (nla_put_u32(skb, IFLA_BOND_LP_INTERVAL, 817 bond->params.lp_interval)) 818 goto nla_put_failure; 819 820 packets_per_slave = bond->params.packets_per_slave; 821 if (nla_put_u32(skb, IFLA_BOND_PACKETS_PER_SLAVE, 822 packets_per_slave)) 823 goto nla_put_failure; 824 825 if (nla_put_u8(skb, IFLA_BOND_AD_LACP_ACTIVE, 826 bond->params.lacp_active)) 827 goto nla_put_failure; 828 829 if (nla_put_u8(skb, IFLA_BOND_AD_LACP_RATE, 830 bond->params.lacp_fast)) 831 goto nla_put_failure; 832 833 if (nla_put_u8(skb, IFLA_BOND_AD_SELECT, 834 bond->params.ad_select)) 835 goto nla_put_failure; 836 837 if (nla_put_u8(skb, IFLA_BOND_TLB_DYNAMIC_LB, 838 bond->params.tlb_dynamic_lb)) 839 goto nla_put_failure; 840 841 if (nla_put_u8(skb, IFLA_BOND_MISSED_MAX, 842 bond->params.missed_max)) 843 goto nla_put_failure; 844 845 if (nla_put_u8(skb, IFLA_BOND_COUPLED_CONTROL, 846 bond->params.coupled_control)) 847 goto nla_put_failure; 848 849 if (nla_put_u8(skb, IFLA_BOND_BROADCAST_NEIGH, 850 bond->params.broadcast_neighbor)) 851 goto nla_put_failure; 852 853 if (nla_put_u8(skb, IFLA_BOND_LACP_STRICT, 854 bond->params.lacp_strict)) 855 goto nla_put_failure; 856 857 if (BOND_MODE(bond) == BOND_MODE_8023AD) { 858 struct ad_info info; 859 860 if (capable(CAP_NET_ADMIN)) { 861 if (nla_put_u16(skb, IFLA_BOND_AD_ACTOR_SYS_PRIO, 862 bond->params.ad_actor_sys_prio)) 863 goto nla_put_failure; 864 865 if (nla_put_u16(skb, IFLA_BOND_AD_USER_PORT_KEY, 866 bond->params.ad_user_port_key)) 867 goto nla_put_failure; 868 869 if (nla_put(skb, IFLA_BOND_AD_ACTOR_SYSTEM, 870 ETH_ALEN, &bond->params.ad_actor_system)) 871 goto nla_put_failure; 872 } 873 if (!bond_3ad_get_active_agg_info(bond, &info)) { 874 struct nlattr *nest; 875 876 nest = nla_nest_start_noflag(skb, IFLA_BOND_AD_INFO); 877 if (!nest) 878 goto nla_put_failure; 879 880 if (nla_put_u16(skb, IFLA_BOND_AD_INFO_AGGREGATOR, 881 info.aggregator_id)) 882 goto nla_put_failure; 883 if (nla_put_u16(skb, IFLA_BOND_AD_INFO_NUM_PORTS, 884 info.ports)) 885 goto nla_put_failure; 886 if (nla_put_u16(skb, IFLA_BOND_AD_INFO_ACTOR_KEY, 887 info.actor_key)) 888 goto nla_put_failure; 889 if (nla_put_u16(skb, IFLA_BOND_AD_INFO_PARTNER_KEY, 890 info.partner_key)) 891 goto nla_put_failure; 892 if (nla_put(skb, IFLA_BOND_AD_INFO_PARTNER_MAC, 893 sizeof(info.partner_system), 894 &info.partner_system)) 895 goto nla_put_failure; 896 897 nla_nest_end(skb, nest); 898 } 899 } 900 901 return 0; 902 903 nla_put_failure: 904 return -EMSGSIZE; 905 } 906 907 static size_t bond_get_linkxstats_size(const struct net_device *dev, int attr) 908 { 909 switch (attr) { 910 case IFLA_STATS_LINK_XSTATS: 911 case IFLA_STATS_LINK_XSTATS_SLAVE: 912 break; 913 default: 914 return 0; 915 } 916 917 return bond_3ad_stats_size() + nla_total_size(0); 918 } 919 920 static int bond_fill_linkxstats(struct sk_buff *skb, 921 const struct net_device *dev, 922 int *prividx, int attr) 923 { 924 struct nlattr *nla __maybe_unused; 925 struct slave *slave = NULL; 926 struct nlattr *nest, *nest2; 927 struct bonding *bond; 928 929 switch (attr) { 930 case IFLA_STATS_LINK_XSTATS: 931 bond = netdev_priv(dev); 932 break; 933 case IFLA_STATS_LINK_XSTATS_SLAVE: 934 slave = bond_slave_get_rtnl(dev); 935 if (!slave) 936 return 0; 937 bond = slave->bond; 938 break; 939 default: 940 return -EINVAL; 941 } 942 943 nest = nla_nest_start_noflag(skb, LINK_XSTATS_TYPE_BOND); 944 if (!nest) 945 return -EMSGSIZE; 946 if (BOND_MODE(bond) == BOND_MODE_8023AD) { 947 struct bond_3ad_stats *stats; 948 949 if (slave) 950 stats = &SLAVE_AD_INFO(slave)->stats; 951 else 952 stats = &BOND_AD_INFO(bond).stats; 953 954 nest2 = nla_nest_start_noflag(skb, BOND_XSTATS_3AD); 955 if (!nest2) { 956 nla_nest_end(skb, nest); 957 return -EMSGSIZE; 958 } 959 960 if (bond_3ad_stats_fill(skb, stats)) { 961 nla_nest_cancel(skb, nest2); 962 nla_nest_end(skb, nest); 963 return -EMSGSIZE; 964 } 965 nla_nest_end(skb, nest2); 966 } 967 nla_nest_end(skb, nest); 968 969 return 0; 970 } 971 972 struct rtnl_link_ops bond_link_ops __read_mostly = { 973 .kind = "bond", 974 .priv_size = sizeof(struct bonding), 975 .setup = bond_setup, 976 .maxtype = IFLA_BOND_MAX, 977 .policy = bond_policy, 978 .validate = bond_validate, 979 .newlink = bond_newlink, 980 .changelink = bond_changelink, 981 .get_size = bond_get_size, 982 .fill_info = bond_fill_info, 983 .get_num_tx_queues = bond_get_num_tx_queues, 984 .get_num_rx_queues = bond_get_num_tx_queues, /* Use the same number 985 as for TX queues */ 986 .fill_linkxstats = bond_fill_linkxstats, 987 .get_linkxstats_size = bond_get_linkxstats_size, 988 .slave_maxtype = IFLA_BOND_SLAVE_MAX, 989 .slave_policy = bond_slave_policy, 990 .slave_changelink = bond_slave_changelink, 991 .get_slave_size = bond_get_slave_size, 992 .fill_slave_info = bond_fill_slave_info, 993 }; 994 995 int __init bond_netlink_init(void) 996 { 997 return rtnl_link_register(&bond_link_ops); 998 } 999 1000 void bond_netlink_fini(void) 1001 { 1002 rtnl_link_unregister(&bond_link_ops); 1003 } 1004 1005 MODULE_ALIAS_RTNL_LINK("bond"); 1006