diff options
| author | Tom Gundersen <teg@jklm.no> | 2015-06-25 13:02:53 +0200 | 
|---|---|---|
| committer | Tom Gundersen <teg@jklm.no> | 2015-06-25 13:02:53 +0200 | 
| commit | 3dfc034b4d46f67d6eda8801f1d4be26c37ab0b7 (patch) | |
| tree | 38b1d3d8071d40d704428a549040f044cf1b7595 /src | |
| parent | 9124468a5e5664e9fb7ca448021a6d8ea8ec4aeb (diff) | |
| parent | dd906398dd0aa8582bdba519a2026278359c2888 (diff) | |
Merge pull request #355 from dvdhrm/netlink
sd-netlink cleanups
Diffstat (limited to 'src')
| -rw-r--r-- | src/libsystemd/sd-netlink/netlink-message.c | 109 | ||||
| -rw-r--r-- | src/libsystemd/sd-netlink/netlink-socket.c | 4 | ||||
| -rw-r--r-- | src/libsystemd/sd-netlink/netlink-types.c | 515 | ||||
| -rw-r--r-- | src/libsystemd/sd-netlink/netlink-types.h | 61 | ||||
| -rw-r--r-- | src/network/networkd-netdev-bond.c | 7 | ||||
| -rw-r--r-- | src/network/networkd-netdev-bond.h | 6 | 
6 files changed, 377 insertions, 325 deletions
| diff --git a/src/libsystemd/sd-netlink/netlink-message.c b/src/libsystemd/sd-netlink/netlink-message.c index 87324fc2f7..a935b821f6 100644 --- a/src/libsystemd/sd-netlink/netlink-message.c +++ b/src/libsystemd/sd-netlink/netlink-message.c @@ -68,15 +68,18 @@ int message_new(sd_netlink *rtnl, sd_netlink_message **ret, uint16_t type) {          size_t size;          int r; -        r = type_system_get_type(NULL, &nl_type, type); +        r = type_system_get_type(&type_system_root, &nl_type, type);          if (r < 0)                  return r; +        if (type_get_type(nl_type) != NETLINK_TYPE_NESTED) +                return -EINVAL; +          r = message_new_empty(rtnl, &m);          if (r < 0)                  return r; -        size = NLMSG_SPACE(nl_type->size); +        size = NLMSG_SPACE(type_get_size(nl_type));          assert(size >= sizeof(struct nlmsghdr));          m->hdr = malloc0(size); @@ -85,7 +88,7 @@ int message_new(sd_netlink *rtnl, sd_netlink_message **ret, uint16_t type) {          m->hdr->nlmsg_flags = NLM_F_REQUEST | NLM_F_ACK; -        m->container_type_system[0] = nl_type->type_system; +        type_get_type_system(nl_type, &m->container_type_system[0]);          m->hdr->nlmsg_len = size;          m->hdr->nlmsg_type = type; @@ -214,18 +217,22 @@ static int add_rtattr(sd_netlink_message *m, unsigned short type, const void *da          return offset;  } -static int message_attribute_has_type(sd_netlink_message *m, uint16_t attribute_type, uint16_t data_type) { +static int message_attribute_has_type(sd_netlink_message *m, size_t *out_size, uint16_t attribute_type, uint16_t data_type) {          const NLType *type;          int r; +        assert(m); +          r = type_system_get_type(m->container_type_system[m->n_containers], &type, attribute_type);          if (r < 0)                  return r; -        if (type->type != data_type) +        if (type_get_type(type) != data_type)                  return -EINVAL; -        return type->size; +        if (out_size) +                *out_size = type_get_size(type); +        return 0;  }  int sd_netlink_message_append_string(sd_netlink_message *m, unsigned short type, const char *data) { @@ -236,11 +243,9 @@ int sd_netlink_message_append_string(sd_netlink_message *m, unsigned short type,          assert_return(!m->sealed, -EPERM);          assert_return(data, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_STRING); +        r = message_attribute_has_type(m, &size, type, NETLINK_TYPE_STRING);          if (r < 0)                  return r; -        else -                size = (size_t)r;          if (size) {                  length = strnlen(data, size+1); @@ -262,7 +267,7 @@ int sd_netlink_message_append_u8(sd_netlink_message *m, unsigned short type, uin          assert_return(m, -EINVAL);          assert_return(!m->sealed, -EPERM); -        r = message_attribute_has_type(m, type, NLA_U8); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_U8);          if (r < 0)                  return r; @@ -280,7 +285,7 @@ int sd_netlink_message_append_u16(sd_netlink_message *m, unsigned short type, ui          assert_return(m, -EINVAL);          assert_return(!m->sealed, -EPERM); -        r = message_attribute_has_type(m, type, NLA_U16); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_U16);          if (r < 0)                  return r; @@ -297,7 +302,7 @@ int sd_netlink_message_append_u32(sd_netlink_message *m, unsigned short type, ui          assert_return(m, -EINVAL);          assert_return(!m->sealed, -EPERM); -        r = message_attribute_has_type(m, type, NLA_U32); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_U32);          if (r < 0)                  return r; @@ -315,7 +320,7 @@ int sd_netlink_message_append_in_addr(sd_netlink_message *m, unsigned short type          assert_return(!m->sealed, -EPERM);          assert_return(data, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_IN_ADDR); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_IN_ADDR);          if (r < 0)                  return r; @@ -333,7 +338,7 @@ int sd_netlink_message_append_in6_addr(sd_netlink_message *m, unsigned short typ          assert_return(!m->sealed, -EPERM);          assert_return(data, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_IN_ADDR); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_IN_ADDR);          if (r < 0)                  return r; @@ -351,7 +356,7 @@ int sd_netlink_message_append_ether_addr(sd_netlink_message *m, unsigned short t          assert_return(!m->sealed, -EPERM);          assert_return(data, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_ETHER_ADDR); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_ETHER_ADDR);          if (r < 0)                  return r; @@ -369,7 +374,7 @@ int sd_netlink_message_append_cache_info(sd_netlink_message *m, unsigned short t          assert_return(!m->sealed, -EPERM);          assert_return(info, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_CACHE_INFO); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_CACHE_INFO);          if (r < 0)                  return r; @@ -388,15 +393,14 @@ int sd_netlink_message_open_container(sd_netlink_message *m, unsigned short type          assert_return(!m->sealed, -EPERM);          assert_return(m->n_containers < RTNL_CONTAINER_DEPTH, -ERANGE); -        r = message_attribute_has_type(m, type, NLA_NESTED); +        r = message_attribute_has_type(m, &size, type, NETLINK_TYPE_NESTED);          if (r < 0) {                  const NLTypeSystemUnion *type_system_union;                  int family; -                r = message_attribute_has_type(m, type, NLA_UNION); +                r = message_attribute_has_type(m, &size, type, NETLINK_TYPE_UNION);                  if (r < 0)                          return r; -                size = (size_t) r;                  r = sd_rtnl_message_get_family(m, &family);                  if (r < 0) @@ -412,8 +416,6 @@ int sd_netlink_message_open_container(sd_netlink_message *m, unsigned short type                  if (r < 0)                          return r;          } else { -                size = (size_t)r; -                  r = type_system_get_type_system(m->container_type_system[m->n_containers],                                                  &m->container_type_system[m->n_containers + 1],                                                  type); @@ -499,7 +501,7 @@ int sd_netlink_message_read_string(sd_netlink_message *m, unsigned short type, c          assert_return(m, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_STRING); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_STRING);          if (r < 0)                  return r; @@ -521,7 +523,7 @@ int sd_netlink_message_read_u8(sd_netlink_message *m, unsigned short type, uint8          assert_return(m, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_U8); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_U8);          if (r < 0)                  return r; @@ -543,7 +545,7 @@ int sd_netlink_message_read_u16(sd_netlink_message *m, unsigned short type, uint          assert_return(m, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_U16); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_U16);          if (r < 0)                  return r; @@ -565,7 +567,7 @@ int sd_netlink_message_read_u32(sd_netlink_message *m, unsigned short type, uint          assert_return(m, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_U32); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_U32);          if (r < 0)                  return r; @@ -587,7 +589,7 @@ int sd_netlink_message_read_ether_addr(sd_netlink_message *m, unsigned short typ          assert_return(m, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_ETHER_ADDR); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_ETHER_ADDR);          if (r < 0)                  return r; @@ -609,7 +611,7 @@ int sd_netlink_message_read_cache_info(sd_netlink_message *m, unsigned short typ          assert_return(m, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_CACHE_INFO); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_CACHE_INFO);          if (r < 0)                  return r; @@ -631,7 +633,7 @@ int sd_netlink_message_read_in_addr(sd_netlink_message *m, unsigned short type,          assert_return(m, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_IN_ADDR); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_IN_ADDR);          if (r < 0)                  return r; @@ -653,7 +655,7 @@ int sd_netlink_message_read_in6_addr(sd_netlink_message *m, unsigned short type,          assert_return(m, -EINVAL); -        r = message_attribute_has_type(m, type, NLA_IN_ADDR); +        r = message_attribute_has_type(m, NULL, type, NETLINK_TYPE_IN_ADDR);          if (r < 0)                  return r; @@ -669,10 +671,11 @@ int sd_netlink_message_read_in6_addr(sd_netlink_message *m, unsigned short type,          return 0;  } -int sd_netlink_message_enter_container(sd_netlink_message *m, unsigned short type) { +int sd_netlink_message_enter_container(sd_netlink_message *m, unsigned short type_id) {          const NLType *nl_type;          const NLTypeSystem *type_system;          void *container; +        uint16_t type;          size_t size;          int r; @@ -681,22 +684,24 @@ int sd_netlink_message_enter_container(sd_netlink_message *m, unsigned short typ          r = type_system_get_type(m->container_type_system[m->n_containers],                                   &nl_type, -                                 type); +                                 type_id);          if (r < 0)                  return r; -        if (nl_type->type == NLA_NESTED) { +        type = type_get_type(nl_type); + +        if (type == NETLINK_TYPE_NESTED) {                  r = type_system_get_type_system(m->container_type_system[m->n_containers],                                                  &type_system, -                                                type); +                                                type_id);                  if (r < 0)                          return r; -        } else if (nl_type->type == NLA_UNION) { +        } else if (type == NETLINK_TYPE_UNION) {                  const NLTypeSystemUnion *type_system_union;                  r = type_system_get_type_system_union(m->container_type_system[m->n_containers],                                                        &type_system_union, -                                                      type); +                                                      type_id);                  if (r < 0)                          return r; @@ -739,7 +744,7 @@ int sd_netlink_message_enter_container(sd_netlink_message *m, unsigned short typ          } else                  return -EINVAL; -        r = rtnl_message_read_internal(m, type, &container); +        r = rtnl_message_read_internal(m, type_id, &container);          if (r < 0)                  return r;          else @@ -750,7 +755,7 @@ int sd_netlink_message_enter_container(sd_netlink_message *m, unsigned short typ          r = rtnl_message_parse(m,                                 &m->rta_offset_tb[m->n_containers],                                 &m->rta_tb_size[m->n_containers], -                               type_system->max, +                               type_system_get_count(type_system),                                 container,                                 size);          if (r < 0) { @@ -808,17 +813,17 @@ int sd_netlink_message_get_errno(sd_netlink_message *m) {  int rtnl_message_parse(sd_netlink_message *m,                         size_t **rta_offset_tb,                         unsigned short *rta_tb_size, -                       int max, +                       int count,                         struct rtattr *rta,                         unsigned int rt_len) {          unsigned short type;          size_t *tb; -        tb = new0(size_t, max + 1); +        tb = new0(size_t, count);          if(!tb)                  return -ENOMEM; -        *rta_tb_size = max + 1; +        *rta_tb_size = count;          for (; RTA_OK(rta, rt_len); rta = RTA_NEXT(rta, rt_len)) {                  type = RTA_TYPE(rta); @@ -826,7 +831,7 @@ int rtnl_message_parse(sd_netlink_message *m,                  /* if the kernel is newer than the headers we used                     when building, we ignore out-of-range attributes                   */ -                if (type > max) +                if (type >= count)                          continue;                  if (tb[type]) @@ -841,7 +846,9 @@ int rtnl_message_parse(sd_netlink_message *m,  }  int sd_netlink_message_rewind(sd_netlink_message *m) { -        const NLType *type; +        const NLType *nl_type; +        uint16_t type; +        size_t size;          unsigned i;          int r; @@ -867,24 +874,26 @@ int sd_netlink_message_rewind(sd_netlink_message *m) {          assert(m->hdr); -        r = type_system_get_type(NULL, &type, m->hdr->nlmsg_type); +        r = type_system_get_type(&type_system_root, &nl_type, m->hdr->nlmsg_type);          if (r < 0)                  return r; -        if (type->type == NLA_NESTED) { -                const NLTypeSystem *type_system = type->type_system; +        type = type_get_type(nl_type); +        size = type_get_size(nl_type); + +        if (type == NETLINK_TYPE_NESTED) { +                const NLTypeSystem *type_system; -                assert(type_system); +                type_get_type_system(nl_type, &type_system);                  m->container_type_system[0] = type_system;                  r = rtnl_message_parse(m,                                         &m->rta_offset_tb[m->n_containers],                                         &m->rta_tb_size[m->n_containers], -                                       type_system->max, -                                       (struct rtattr*)((uint8_t*)NLMSG_DATA(m->hdr) + -                                                        NLMSG_ALIGN(type->size)), -                                       NLMSG_PAYLOAD(m->hdr, type->size)); +                                       type_system_get_count(type_system), +                                       (struct rtattr*)((uint8_t*)NLMSG_DATA(m->hdr) + NLMSG_ALIGN(size)), +                                       NLMSG_PAYLOAD(m->hdr, size));                  if (r < 0)                          return r;          } diff --git a/src/libsystemd/sd-netlink/netlink-socket.c b/src/libsystemd/sd-netlink/netlink-socket.c index 8136cf36ae..84ff7c38c9 100644 --- a/src/libsystemd/sd-netlink/netlink-socket.c +++ b/src/libsystemd/sd-netlink/netlink-socket.c @@ -243,7 +243,7 @@ int socket_read_message(sd_netlink *rtnl) {                  }                  /* check that we support this message type */ -                r = type_system_get_type(NULL, &nl_type, new_msg->nlmsg_type); +                r = type_system_get_type(&type_system_root, &nl_type, new_msg->nlmsg_type);                  if (r < 0) {                          if (r == -EOPNOTSUPP)                                  log_debug("sd-netlink: ignored message with unknown type: %i", @@ -253,7 +253,7 @@ int socket_read_message(sd_netlink *rtnl) {                  }                  /* check that the size matches the message type */ -                if (new_msg->nlmsg_len < NLMSG_LENGTH(nl_type->size)) { +                if (new_msg->nlmsg_len < NLMSG_LENGTH(type_get_size(nl_type))) {                          log_debug("sd-netlink: message larger than expected, dropping");                          continue;                  } diff --git a/src/libsystemd/sd-netlink/netlink-types.c b/src/libsystemd/sd-netlink/netlink-types.c index 273033770f..74ac2ab344 100644 --- a/src/libsystemd/sd-netlink/netlink-types.c +++ b/src/libsystemd/sd-netlink/netlink-types.c @@ -39,152 +39,195 @@  #include "netlink-types.h"  #include "missing.h" +/* Maximum ARP IP target defined in kernel */ +#define BOND_MAX_ARP_TARGETS    16 + +typedef enum { +        BOND_ARP_TARGETS_0, +        BOND_ARP_TARGETS_1, +        BOND_ARP_TARGETS_2, +        BOND_ARP_TARGETS_3, +        BOND_ARP_TARGETS_4, +        BOND_ARP_TARGETS_5, +        BOND_ARP_TARGETS_6, +        BOND_ARP_TARGETS_7, +        BOND_ARP_TARGETS_8, +        BOND_ARP_TARGETS_9, +        BOND_ARP_TARGETS_10, +        BOND_ARP_TARGETS_11, +        BOND_ARP_TARGETS_12, +        BOND_ARP_TARGETS_13, +        BOND_ARP_TARGETS_14, +        BOND_ARP_TARGETS_MAX = BOND_MAX_ARP_TARGETS, +} BondArpTargets; + +struct NLType { +        uint16_t type; +        size_t size; +        const NLTypeSystem *type_system; +        const NLTypeSystemUnion *type_system_union; +}; + +struct NLTypeSystem { +        uint16_t count; +        const NLType *types; +}; +  static const NLTypeSystem rtnl_link_type_system; +static const NLType empty_types[1] = { +        /* fake array to avoid .types==NULL, which denotes invalid type-systems */ +}; + +static const NLTypeSystem empty_type_system = { +        .count = 0, +        .types = empty_types, +}; +  static const NLType rtnl_link_info_data_veth_types[VETH_INFO_MAX + 1] = { -        [VETH_INFO_PEER]  = { .type = NLA_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, +        [VETH_INFO_PEER]  = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) },  };  static const NLType rtnl_link_info_data_ipvlan_types[IFLA_IPVLAN_MAX + 1] = { -        [IFLA_IPVLAN_MODE]  = { .type = NLA_U16 }, +        [IFLA_IPVLAN_MODE]  = { .type = NETLINK_TYPE_U16 },  };  static const NLType rtnl_link_info_data_macvlan_types[IFLA_MACVLAN_MAX + 1] = { -        [IFLA_MACVLAN_MODE]  = { .type = NLA_U32 }, -        [IFLA_MACVLAN_FLAGS] = { .type = NLA_U16 }, +        [IFLA_MACVLAN_MODE]  = { .type = NETLINK_TYPE_U32 }, +        [IFLA_MACVLAN_FLAGS] = { .type = NETLINK_TYPE_U16 },  };  static const NLType rtnl_link_info_data_bridge_types[IFLA_BRIDGE_MAX + 1] = { -        [IFLA_BRIDGE_FLAGS]     = { .type = NLA_U16 }, -        [IFLA_BRIDGE_MODE]      = { .type = NLA_U16 }, +        [IFLA_BRIDGE_FLAGS]     = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BRIDGE_MODE]      = { .type = NETLINK_TYPE_U16 },  /* -        [IFLA_BRIDGE_VLAN_INFO] = { .type = NLA_BINARY, +        [IFLA_BRIDGE_VLAN_INFO] = { .type = NETLINK_TYPE_BINARY,                                      .len = sizeof(struct bridge_vlan_info), },  */  };  static const NLType rtnl_link_info_data_vlan_types[IFLA_VLAN_MAX + 1] = { -        [IFLA_VLAN_ID]          = { .type = NLA_U16 }, +        [IFLA_VLAN_ID]          = { .type = NETLINK_TYPE_U16 },  /*          [IFLA_VLAN_FLAGS]       = { .len = sizeof(struct ifla_vlan_flags) }, -        [IFLA_VLAN_EGRESS_QOS]  = { .type = NLA_NESTED }, -        [IFLA_VLAN_INGRESS_QOS] = { .type = NLA_NESTED }, +        [IFLA_VLAN_EGRESS_QOS]  = { .type = NETLINK_TYPE_NESTED }, +        [IFLA_VLAN_INGRESS_QOS] = { .type = NETLINK_TYPE_NESTED },  */ -        [IFLA_VLAN_PROTOCOL]    = { .type = NLA_U16 }, +        [IFLA_VLAN_PROTOCOL]    = { .type = NETLINK_TYPE_U16 },  };  static const NLType rtnl_link_info_data_vxlan_types[IFLA_VXLAN_MAX+1] = { -        [IFLA_VXLAN_ID] = { .type = NLA_U32 }, -        [IFLA_VXLAN_GROUP] = {.type = NLA_IN_ADDR }, -        [IFLA_VXLAN_LINK] = { .type = NLA_U32 }, -        [IFLA_VXLAN_LOCAL] = { .type = NLA_U32}, -        [IFLA_VXLAN_TTL] = { .type = NLA_U8 }, -        [IFLA_VXLAN_TOS] = { .type = NLA_U8 }, -        [IFLA_VXLAN_LEARNING] = { .type = NLA_U8 }, -        [IFLA_VXLAN_AGEING] = { .type = NLA_U32 }, -        [IFLA_VXLAN_LIMIT] = { .type = NLA_U32 }, -        [IFLA_VXLAN_PORT_RANGE] = { .type = NLA_U32}, -        [IFLA_VXLAN_PROXY] = { .type = NLA_U8 }, -        [IFLA_VXLAN_RSC] = { .type = NLA_U8 }, -        [IFLA_VXLAN_L2MISS] = { .type = NLA_U8 }, -        [IFLA_VXLAN_L3MISS] = { .type = NLA_U8 }, +        [IFLA_VXLAN_ID]         = { .type = NETLINK_TYPE_U32 }, +        [IFLA_VXLAN_GROUP]      = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_VXLAN_LINK]       = { .type = NETLINK_TYPE_U32 }, +        [IFLA_VXLAN_LOCAL]      = { .type = NETLINK_TYPE_U32}, +        [IFLA_VXLAN_TTL]        = { .type = NETLINK_TYPE_U8 }, +        [IFLA_VXLAN_TOS]        = { .type = NETLINK_TYPE_U8 }, +        [IFLA_VXLAN_LEARNING]   = { .type = NETLINK_TYPE_U8 }, +        [IFLA_VXLAN_AGEING]     = { .type = NETLINK_TYPE_U32 }, +        [IFLA_VXLAN_LIMIT]      = { .type = NETLINK_TYPE_U32 }, +        [IFLA_VXLAN_PORT_RANGE] = { .type = NETLINK_TYPE_U32}, +        [IFLA_VXLAN_PROXY]      = { .type = NETLINK_TYPE_U8 }, +        [IFLA_VXLAN_RSC]        = { .type = NETLINK_TYPE_U8 }, +        [IFLA_VXLAN_L2MISS]     = { .type = NETLINK_TYPE_U8 }, +        [IFLA_VXLAN_L3MISS]     = { .type = NETLINK_TYPE_U8 },  };  static const NLType rtnl_bond_arp_target_types[BOND_ARP_TARGETS_MAX + 1] = { -        [BOND_ARP_TARGETS_0]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_1]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_2]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_3]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_4]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_5]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_6]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_7]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_8]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_9]        = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_10]       = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_11]       = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_12]       = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_13]       = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_14]       = { .type = NLA_U32 }, -        [BOND_ARP_TARGETS_MAX]      = { .type = NLA_U32 }, +        [BOND_ARP_TARGETS_0]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_1]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_2]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_3]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_4]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_5]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_6]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_7]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_8]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_9]        = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_10]       = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_11]       = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_12]       = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_13]       = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_14]       = { .type = NETLINK_TYPE_U32 }, +        [BOND_ARP_TARGETS_MAX]      = { .type = NETLINK_TYPE_U32 },  };  static const NLTypeSystem rtnl_bond_arp_type_system = { -        .max = ELEMENTSOF(rtnl_bond_arp_target_types) - 1, +        .count = ELEMENTSOF(rtnl_bond_arp_target_types),          .types = rtnl_bond_arp_target_types,  };  static const NLType rtnl_link_info_data_bond_types[IFLA_BOND_MAX + 1] = { -        [IFLA_BOND_MODE]                = { .type = NLA_U8 }, -        [IFLA_BOND_ACTIVE_SLAVE]        = { .type = NLA_U32 }, -        [IFLA_BOND_MIIMON]              = { .type = NLA_U32 }, -        [IFLA_BOND_UPDELAY]             = { .type = NLA_U32 }, -        [IFLA_BOND_DOWNDELAY]           = { .type = NLA_U32 }, -        [IFLA_BOND_USE_CARRIER]         = { .type = NLA_U8 }, -        [IFLA_BOND_ARP_INTERVAL]        = { .type = NLA_U32 }, -        [IFLA_BOND_ARP_IP_TARGET]       = { .type = NLA_NESTED, .type_system = &rtnl_bond_arp_type_system }, -        [IFLA_BOND_ARP_VALIDATE]        = { .type = NLA_U32 }, -        [IFLA_BOND_ARP_ALL_TARGETS]     = { .type = NLA_U32 }, -        [IFLA_BOND_PRIMARY]             = { .type = NLA_U32 }, -        [IFLA_BOND_PRIMARY_RESELECT]    = { .type = NLA_U8 }, -        [IFLA_BOND_FAIL_OVER_MAC]       = { .type = NLA_U8 }, -        [IFLA_BOND_XMIT_HASH_POLICY]    = { .type = NLA_U8 }, -        [IFLA_BOND_RESEND_IGMP]         = { .type = NLA_U32 }, -        [IFLA_BOND_NUM_PEER_NOTIF]      = { .type = NLA_U8 }, -        [IFLA_BOND_ALL_SLAVES_ACTIVE]   = { .type = NLA_U8 }, -        [IFLA_BOND_MIN_LINKS]           = { .type = NLA_U32 }, -        [IFLA_BOND_LP_INTERVAL]         = { .type = NLA_U32 }, -        [IFLA_BOND_PACKETS_PER_SLAVE]   = { .type = NLA_U32 }, -        [IFLA_BOND_AD_LACP_RATE]        = { .type = NLA_U8 }, -        [IFLA_BOND_AD_SELECT]           = { .type = NLA_U8 }, -        [IFLA_BOND_AD_INFO]             = { .type = NLA_NESTED }, +        [IFLA_BOND_MODE]                = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_ACTIVE_SLAVE]        = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_MIIMON]              = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_UPDELAY]             = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_DOWNDELAY]           = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_USE_CARRIER]         = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_ARP_INTERVAL]        = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_ARP_IP_TARGET]       = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_bond_arp_type_system }, +        [IFLA_BOND_ARP_VALIDATE]        = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_ARP_ALL_TARGETS]     = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_PRIMARY]             = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_PRIMARY_RESELECT]    = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_FAIL_OVER_MAC]       = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_XMIT_HASH_POLICY]    = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_RESEND_IGMP]         = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_NUM_PEER_NOTIF]      = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_ALL_SLAVES_ACTIVE]   = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_MIN_LINKS]           = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_LP_INTERVAL]         = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_PACKETS_PER_SLAVE]   = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BOND_AD_LACP_RATE]        = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_AD_SELECT]           = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BOND_AD_INFO]             = { .type = NETLINK_TYPE_NESTED },  };  static const NLType rtnl_link_info_data_iptun_types[IFLA_IPTUN_MAX + 1] = { -        [IFLA_IPTUN_LINK]                = { .type = NLA_U32 }, -        [IFLA_IPTUN_LOCAL]               = { .type = NLA_IN_ADDR }, -        [IFLA_IPTUN_REMOTE]              = { .type = NLA_IN_ADDR }, -        [IFLA_IPTUN_TTL]                 = { .type = NLA_U8 }, -        [IFLA_IPTUN_TOS]                 = { .type = NLA_U8 }, -        [IFLA_IPTUN_PMTUDISC]            = { .type = NLA_U8 }, -        [IFLA_IPTUN_FLAGS]               = { .type = NLA_U16 }, -        [IFLA_IPTUN_PROTO]               = { .type = NLA_U8 }, -        [IFLA_IPTUN_6RD_PREFIX]          = { .type = NLA_IN_ADDR }, -        [IFLA_IPTUN_6RD_RELAY_PREFIX]    = { .type = NLA_U32 }, -        [IFLA_IPTUN_6RD_PREFIXLEN]       = { .type = NLA_U16 }, -        [IFLA_IPTUN_6RD_RELAY_PREFIXLEN] = { .type = NLA_U16 }, +        [IFLA_IPTUN_LINK]                = { .type = NETLINK_TYPE_U32 }, +        [IFLA_IPTUN_LOCAL]               = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_IPTUN_REMOTE]              = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_IPTUN_TTL]                 = { .type = NETLINK_TYPE_U8 }, +        [IFLA_IPTUN_TOS]                 = { .type = NETLINK_TYPE_U8 }, +        [IFLA_IPTUN_PMTUDISC]            = { .type = NETLINK_TYPE_U8 }, +        [IFLA_IPTUN_FLAGS]               = { .type = NETLINK_TYPE_U16 }, +        [IFLA_IPTUN_PROTO]               = { .type = NETLINK_TYPE_U8 }, +        [IFLA_IPTUN_6RD_PREFIX]          = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_IPTUN_6RD_RELAY_PREFIX]    = { .type = NETLINK_TYPE_U32 }, +        [IFLA_IPTUN_6RD_PREFIXLEN]       = { .type = NETLINK_TYPE_U16 }, +        [IFLA_IPTUN_6RD_RELAY_PREFIXLEN] = { .type = NETLINK_TYPE_U16 },  };  static  const NLType rtnl_link_info_data_ipgre_types[IFLA_GRE_MAX + 1] = { -        [IFLA_GRE_LINK]     = { .type = NLA_U32 }, -        [IFLA_GRE_IFLAGS]   = { .type = NLA_U16 }, -        [IFLA_GRE_OFLAGS]   = { .type = NLA_U16 }, -        [IFLA_GRE_IKEY]     = { .type = NLA_U32 }, -        [IFLA_GRE_OKEY]     = { .type = NLA_U32 }, -        [IFLA_GRE_LOCAL]    = { .type = NLA_IN_ADDR }, -        [IFLA_GRE_REMOTE]   = { .type = NLA_IN_ADDR }, -        [IFLA_GRE_TTL]      = { .type = NLA_U8 }, -        [IFLA_GRE_TOS]      = { .type = NLA_U8 }, -        [IFLA_GRE_PMTUDISC] = { .type = NLA_U8 }, +        [IFLA_GRE_LINK]     = { .type = NETLINK_TYPE_U32 }, +        [IFLA_GRE_IFLAGS]   = { .type = NETLINK_TYPE_U16 }, +        [IFLA_GRE_OFLAGS]   = { .type = NETLINK_TYPE_U16 }, +        [IFLA_GRE_IKEY]     = { .type = NETLINK_TYPE_U32 }, +        [IFLA_GRE_OKEY]     = { .type = NETLINK_TYPE_U32 }, +        [IFLA_GRE_LOCAL]    = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_GRE_REMOTE]   = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_GRE_TTL]      = { .type = NETLINK_TYPE_U8 }, +        [IFLA_GRE_TOS]      = { .type = NETLINK_TYPE_U8 }, +        [IFLA_GRE_PMTUDISC] = { .type = NETLINK_TYPE_U8 },  };  static const NLType rtnl_link_info_data_ipvti_types[IFLA_VTI_MAX + 1] = { -        [IFLA_VTI_LINK]         = { .type = NLA_U32 }, -        [IFLA_VTI_IKEY]         = { .type = NLA_U32 }, -        [IFLA_VTI_OKEY]         = { .type = NLA_U32 }, -        [IFLA_VTI_LOCAL]        = { .type = NLA_IN_ADDR  }, -        [IFLA_VTI_REMOTE]       = { .type = NLA_IN_ADDR  }, +        [IFLA_VTI_LINK]         = { .type = NETLINK_TYPE_U32 }, +        [IFLA_VTI_IKEY]         = { .type = NETLINK_TYPE_U32 }, +        [IFLA_VTI_OKEY]         = { .type = NETLINK_TYPE_U32 }, +        [IFLA_VTI_LOCAL]        = { .type = NETLINK_TYPE_IN_ADDR  }, +        [IFLA_VTI_REMOTE]       = { .type = NETLINK_TYPE_IN_ADDR  },  };  static const NLType rtnl_link_info_data_ip6tnl_types[IFLA_IPTUN_MAX + 1] = { -        [IFLA_IPTUN_LINK]                = { .type = NLA_U32 }, -        [IFLA_IPTUN_LOCAL]               = { .type = NLA_IN_ADDR }, -        [IFLA_IPTUN_REMOTE]              = { .type = NLA_IN_ADDR }, -        [IFLA_IPTUN_TTL]                 = { .type = NLA_U8 }, -        [IFLA_IPTUN_FLAGS]               = { .type = NLA_U32 }, -        [IFLA_IPTUN_PROTO]               = { .type = NLA_U8 }, -        [IFLA_IPTUN_ENCAP_LIMIT]         = { .type = NLA_U8 }, -        [IFLA_IPTUN_FLOWINFO]            = { .type = NLA_U32}, +        [IFLA_IPTUN_LINK]                = { .type = NETLINK_TYPE_U32 }, +        [IFLA_IPTUN_LOCAL]               = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_IPTUN_REMOTE]              = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_IPTUN_TTL]                 = { .type = NETLINK_TYPE_U8 }, +        [IFLA_IPTUN_FLAGS]               = { .type = NETLINK_TYPE_U32 }, +        [IFLA_IPTUN_PROTO]               = { .type = NETLINK_TYPE_U8 }, +        [IFLA_IPTUN_ENCAP_LIMIT]         = { .type = NETLINK_TYPE_U8 }, +        [IFLA_IPTUN_FLOWINFO]            = { .type = NETLINK_TYPE_U32},  };  /* these strings must match the .kind entries in the kernel */ @@ -211,37 +254,37 @@ static const char* const nl_union_link_info_data_table[_NL_UNION_LINK_INFO_DATA_  DEFINE_STRING_TABLE_LOOKUP(nl_union_link_info_data, NLUnionLinkInfoData);  static const NLTypeSystem rtnl_link_info_data_type_systems[_NL_UNION_LINK_INFO_DATA_MAX] = { -        [NL_UNION_LINK_INFO_DATA_BOND] =        { .max = ELEMENTSOF(rtnl_link_info_data_bond_types) - 1, +        [NL_UNION_LINK_INFO_DATA_BOND] =        { .count = ELEMENTSOF(rtnl_link_info_data_bond_types),                                                    .types = rtnl_link_info_data_bond_types }, -        [NL_UNION_LINK_INFO_DATA_BRIDGE] =      { .max = ELEMENTSOF(rtnl_link_info_data_bridge_types) - 1, +        [NL_UNION_LINK_INFO_DATA_BRIDGE] =      { .count = ELEMENTSOF(rtnl_link_info_data_bridge_types),                                                    .types = rtnl_link_info_data_bridge_types }, -        [NL_UNION_LINK_INFO_DATA_VLAN] =        { .max = ELEMENTSOF(rtnl_link_info_data_vlan_types) - 1, +        [NL_UNION_LINK_INFO_DATA_VLAN] =        { .count = ELEMENTSOF(rtnl_link_info_data_vlan_types),                                                    .types = rtnl_link_info_data_vlan_types }, -        [NL_UNION_LINK_INFO_DATA_VETH] =        { .max = ELEMENTSOF(rtnl_link_info_data_veth_types) - 1, +        [NL_UNION_LINK_INFO_DATA_VETH] =        { .count = ELEMENTSOF(rtnl_link_info_data_veth_types),                                                    .types = rtnl_link_info_data_veth_types }, -        [NL_UNION_LINK_INFO_DATA_MACVLAN] =     { .max = ELEMENTSOF(rtnl_link_info_data_macvlan_types) - 1, +        [NL_UNION_LINK_INFO_DATA_MACVLAN] =     { .count = ELEMENTSOF(rtnl_link_info_data_macvlan_types),                                                    .types = rtnl_link_info_data_macvlan_types }, -        [NL_UNION_LINK_INFO_DATA_IPVLAN] =      { .max = ELEMENTSOF(rtnl_link_info_data_ipvlan_types) - 1, +        [NL_UNION_LINK_INFO_DATA_IPVLAN] =      { .count = ELEMENTSOF(rtnl_link_info_data_ipvlan_types),                                                    .types = rtnl_link_info_data_ipvlan_types }, -        [NL_UNION_LINK_INFO_DATA_VXLAN] =       { .max = ELEMENTSOF(rtnl_link_info_data_vxlan_types) - 1, +        [NL_UNION_LINK_INFO_DATA_VXLAN] =       { .count = ELEMENTSOF(rtnl_link_info_data_vxlan_types),                                                    .types = rtnl_link_info_data_vxlan_types }, -        [NL_UNION_LINK_INFO_DATA_IPIP_TUNNEL] = { .max = ELEMENTSOF(rtnl_link_info_data_iptun_types) - 1, +        [NL_UNION_LINK_INFO_DATA_IPIP_TUNNEL] = { .count = ELEMENTSOF(rtnl_link_info_data_iptun_types),                                                    .types = rtnl_link_info_data_iptun_types }, -        [NL_UNION_LINK_INFO_DATA_IPGRE_TUNNEL] =  { .max = ELEMENTSOF(rtnl_link_info_data_ipgre_types) - 1, +        [NL_UNION_LINK_INFO_DATA_IPGRE_TUNNEL] =  { .count = ELEMENTSOF(rtnl_link_info_data_ipgre_types),                                                      .types = rtnl_link_info_data_ipgre_types }, -        [NL_UNION_LINK_INFO_DATA_IPGRETAP_TUNNEL] =  { .max = ELEMENTSOF(rtnl_link_info_data_ipgre_types) - 1, +        [NL_UNION_LINK_INFO_DATA_IPGRETAP_TUNNEL] =  { .count = ELEMENTSOF(rtnl_link_info_data_ipgre_types),                                                      .types = rtnl_link_info_data_ipgre_types }, -        [NL_UNION_LINK_INFO_DATA_IP6GRE_TUNNEL] =  { .max = ELEMENTSOF(rtnl_link_info_data_ipgre_types) - 1, +        [NL_UNION_LINK_INFO_DATA_IP6GRE_TUNNEL] =  { .count = ELEMENTSOF(rtnl_link_info_data_ipgre_types),                                                      .types = rtnl_link_info_data_ipgre_types }, -        [NL_UNION_LINK_INFO_DATA_IP6GRETAP_TUNNEL] =  { .max = ELEMENTSOF(rtnl_link_info_data_ipgre_types) - 1, +        [NL_UNION_LINK_INFO_DATA_IP6GRETAP_TUNNEL] =  { .count = ELEMENTSOF(rtnl_link_info_data_ipgre_types),                                                      .types = rtnl_link_info_data_ipgre_types }, -        [NL_UNION_LINK_INFO_DATA_SIT_TUNNEL] =  { .max = ELEMENTSOF(rtnl_link_info_data_iptun_types) - 1, +        [NL_UNION_LINK_INFO_DATA_SIT_TUNNEL] =  { .count = ELEMENTSOF(rtnl_link_info_data_iptun_types),                                                    .types = rtnl_link_info_data_iptun_types }, -        [NL_UNION_LINK_INFO_DATA_VTI_TUNNEL] =  { .max = ELEMENTSOF(rtnl_link_info_data_ipvti_types) - 1, +        [NL_UNION_LINK_INFO_DATA_VTI_TUNNEL] =  { .count = ELEMENTSOF(rtnl_link_info_data_ipvti_types),                                                    .types = rtnl_link_info_data_ipvti_types }, -        [NL_UNION_LINK_INFO_DATA_VTI6_TUNNEL] =  { .max = ELEMENTSOF(rtnl_link_info_data_ipvti_types) - 1, +        [NL_UNION_LINK_INFO_DATA_VTI6_TUNNEL] =  { .count = ELEMENTSOF(rtnl_link_info_data_ipvti_types),                                                    .types = rtnl_link_info_data_ipvti_types }, -        [NL_UNION_LINK_INFO_DATA_IP6TNL_TUNNEL] =  { .max = ELEMENTSOF(rtnl_link_info_data_ip6tnl_types) - 1, +        [NL_UNION_LINK_INFO_DATA_IP6TNL_TUNNEL] =  { .count = ELEMENTSOF(rtnl_link_info_data_ip6tnl_types),                                                       .types = rtnl_link_info_data_ip6tnl_types },  }; @@ -255,33 +298,33 @@ static const NLTypeSystemUnion rtnl_link_info_data_type_system_union = {  };  static const NLType rtnl_link_info_types[IFLA_INFO_MAX + 1] = { -        [IFLA_INFO_KIND]        = { .type = NLA_STRING }, -        [IFLA_INFO_DATA]        = { .type = NLA_UNION, .type_system_union = &rtnl_link_info_data_type_system_union}, +        [IFLA_INFO_KIND]        = { .type = NETLINK_TYPE_STRING }, +        [IFLA_INFO_DATA]        = { .type = NETLINK_TYPE_UNION, .type_system_union = &rtnl_link_info_data_type_system_union},  /*          [IFLA_INFO_XSTATS], -        [IFLA_INFO_SLAVE_KIND]  = { .type = NLA_STRING }, -        [IFLA_INFO_SLAVE_DATA]  = { .type = NLA_NESTED }, +        [IFLA_INFO_SLAVE_KIND]  = { .type = NETLINK_TYPE_STRING }, +        [IFLA_INFO_SLAVE_DATA]  = { .type = NETLINK_TYPE_NESTED },  */  };  static const NLTypeSystem rtnl_link_info_type_system = { -        .max = ELEMENTSOF(rtnl_link_info_types) - 1, +        .count = ELEMENTSOF(rtnl_link_info_types),          .types = rtnl_link_info_types,  };  static const struct NLType rtnl_prot_info_bridge_port_types[IFLA_BRPORT_MAX + 1] = { -        [IFLA_BRPORT_STATE]     = { .type = NLA_U8 }, -        [IFLA_BRPORT_COST]      = { .type = NLA_U32 }, -        [IFLA_BRPORT_PRIORITY]  = { .type = NLA_U16 }, -        [IFLA_BRPORT_MODE]      = { .type = NLA_U8 }, -        [IFLA_BRPORT_GUARD]     = { .type = NLA_U8 }, -        [IFLA_BRPORT_PROTECT]   = { .type = NLA_U8 }, -        [IFLA_BRPORT_LEARNING]  = { .type = NLA_U8 }, -        [IFLA_BRPORT_UNICAST_FLOOD] = { .type = NLA_U8 }, +        [IFLA_BRPORT_STATE]             = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BRPORT_COST]              = { .type = NETLINK_TYPE_U32 }, +        [IFLA_BRPORT_PRIORITY]          = { .type = NETLINK_TYPE_U16 }, +        [IFLA_BRPORT_MODE]              = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BRPORT_GUARD]             = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BRPORT_PROTECT]           = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BRPORT_LEARNING]          = { .type = NETLINK_TYPE_U8 }, +        [IFLA_BRPORT_UNICAST_FLOOD]     = { .type = NETLINK_TYPE_U8 },  };  static const NLTypeSystem rtnl_prot_info_type_systems[AF_MAX] = { -        [AF_BRIDGE] =   { .max = ELEMENTSOF(rtnl_prot_info_bridge_port_types) - 1, +        [AF_BRIDGE] =   { .count = ELEMENTSOF(rtnl_prot_info_bridge_port_types),                            .types = rtnl_prot_info_bridge_port_types },  }; @@ -292,7 +335,7 @@ static const NLTypeSystemUnion rtnl_prot_info_type_system_union = {  };  static const struct NLType rtnl_af_spec_inet6_types[IFLA_INET6_MAX + 1] = { -        [IFLA_INET6_FLAGS]              = { .type = NLA_U32 }, +        [IFLA_INET6_FLAGS]              = { .type = NETLINK_TYPE_U32 },  /*          IFLA_INET6_CONF,          IFLA_INET6_STATS, @@ -300,114 +343,114 @@ static const struct NLType rtnl_af_spec_inet6_types[IFLA_INET6_MAX + 1] = {          IFLA_INET6_CACHEINFO,          IFLA_INET6_ICMP6STATS,  */ -        [IFLA_INET6_TOKEN]              = { .type = NLA_IN_ADDR }, -        [IFLA_INET6_ADDR_GEN_MODE]      = { .type = NLA_U8 }, +        [IFLA_INET6_TOKEN]              = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFLA_INET6_ADDR_GEN_MODE]      = { .type = NETLINK_TYPE_U8 },  };  static const NLTypeSystem rtnl_af_spec_inet6_type_system = { -        .max = ELEMENTSOF(rtnl_af_spec_inet6_types) - 1, +        .count = ELEMENTSOF(rtnl_af_spec_inet6_types),          .types = rtnl_af_spec_inet6_types,  };  static const NLType rtnl_af_spec_types[AF_MAX + 1] = { -        [AF_INET6] =    { .type = NLA_NESTED, .type_system = &rtnl_af_spec_inet6_type_system }, +        [AF_INET6] =    { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_af_spec_inet6_type_system },  };  static const NLTypeSystem rtnl_af_spec_type_system = { -        .max = ELEMENTSOF(rtnl_af_spec_types) - 1, +        .count = ELEMENTSOF(rtnl_af_spec_types),          .types = rtnl_af_spec_types,  };  static const NLType rtnl_link_types[IFLA_MAX + 1 ] = { -        [IFLA_ADDRESS]          = { .type = NLA_ETHER_ADDR, }, -        [IFLA_BROADCAST]        = { .type = NLA_ETHER_ADDR, }, -        [IFLA_IFNAME]           = { .type = NLA_STRING, .size = IFNAMSIZ - 1, }, -        [IFLA_MTU]              = { .type = NLA_U32 }, -        [IFLA_LINK]             = { .type = NLA_U32 }, +        [IFLA_ADDRESS]          = { .type = NETLINK_TYPE_ETHER_ADDR, }, +        [IFLA_BROADCAST]        = { .type = NETLINK_TYPE_ETHER_ADDR, }, +        [IFLA_IFNAME]           = { .type = NETLINK_TYPE_STRING, .size = IFNAMSIZ - 1, }, +        [IFLA_MTU]              = { .type = NETLINK_TYPE_U32 }, +        [IFLA_LINK]             = { .type = NETLINK_TYPE_U32 },  /*          [IFLA_QDISC],          [IFLA_STATS],          [IFLA_COST],          [IFLA_PRIORITY],  */ -        [IFLA_MASTER]           = { .type = NLA_U32 }, +        [IFLA_MASTER]           = { .type = NETLINK_TYPE_U32 },  /*          [IFLA_WIRELESS],  */ -        [IFLA_PROTINFO]         = { .type = NLA_UNION, .type_system_union = &rtnl_prot_info_type_system_union }, -        [IFLA_TXQLEN]           = { .type = NLA_U32 }, +        [IFLA_PROTINFO]         = { .type = NETLINK_TYPE_UNION, .type_system_union = &rtnl_prot_info_type_system_union }, +        [IFLA_TXQLEN]           = { .type = NETLINK_TYPE_U32 },  /*          [IFLA_MAP]              = { .len = sizeof(struct rtnl_link_ifmap) },  */ -        [IFLA_WEIGHT]           = { .type = NLA_U32 }, -        [IFLA_OPERSTATE]        = { .type = NLA_U8 }, -        [IFLA_LINKMODE]         = { .type = NLA_U8 }, -        [IFLA_LINKINFO]         = { .type = NLA_NESTED, .type_system = &rtnl_link_info_type_system }, -        [IFLA_NET_NS_PID]       = { .type = NLA_U32 }, -        [IFLA_IFALIAS]          = { .type = NLA_STRING, .size = IFALIASZ - 1 }, +        [IFLA_WEIGHT]           = { .type = NETLINK_TYPE_U32 }, +        [IFLA_OPERSTATE]        = { .type = NETLINK_TYPE_U8 }, +        [IFLA_LINKMODE]         = { .type = NETLINK_TYPE_U8 }, +        [IFLA_LINKINFO]         = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_link_info_type_system }, +        [IFLA_NET_NS_PID]       = { .type = NETLINK_TYPE_U32 }, +        [IFLA_IFALIAS]          = { .type = NETLINK_TYPE_STRING, .size = IFALIASZ - 1 },  /*          [IFLA_NUM_VF], -        [IFLA_VFINFO_LIST]      = {. type = NLA_NESTED, }, +        [IFLA_VFINFO_LIST]      = {. type = NETLINK_TYPE_NESTED, },          [IFLA_STATS64], -        [IFLA_VF_PORTS]         = { .type = NLA_NESTED }, -        [IFLA_PORT_SELF]        = { .type = NLA_NESTED }, +        [IFLA_VF_PORTS]         = { .type = NETLINK_TYPE_NESTED }, +        [IFLA_PORT_SELF]        = { .type = NETLINK_TYPE_NESTED },  */ -        [IFLA_AF_SPEC]          = { .type = NLA_NESTED, .type_system = &rtnl_af_spec_type_system }, +        [IFLA_AF_SPEC]          = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_af_spec_type_system },  /*          [IFLA_VF_PORTS],          [IFLA_PORT_SELF],          [IFLA_AF_SPEC],  */ -        [IFLA_GROUP]            = { .type = NLA_U32 }, -        [IFLA_NET_NS_FD]        = { .type = NLA_U32 }, -        [IFLA_EXT_MASK]         = { .type = NLA_U32 }, -        [IFLA_PROMISCUITY]      = { .type = NLA_U32 }, -        [IFLA_NUM_TX_QUEUES]    = { .type = NLA_U32 }, -        [IFLA_NUM_RX_QUEUES]    = { .type = NLA_U32 }, -        [IFLA_CARRIER]          = { .type = NLA_U8 }, +        [IFLA_GROUP]            = { .type = NETLINK_TYPE_U32 }, +        [IFLA_NET_NS_FD]        = { .type = NETLINK_TYPE_U32 }, +        [IFLA_EXT_MASK]         = { .type = NETLINK_TYPE_U32 }, +        [IFLA_PROMISCUITY]      = { .type = NETLINK_TYPE_U32 }, +        [IFLA_NUM_TX_QUEUES]    = { .type = NETLINK_TYPE_U32 }, +        [IFLA_NUM_RX_QUEUES]    = { .type = NETLINK_TYPE_U32 }, +        [IFLA_CARRIER]          = { .type = NETLINK_TYPE_U8 },  /* -        [IFLA_PHYS_PORT_ID]     = { .type = NLA_BINARY, .len = MAX_PHYS_PORT_ID_LEN }, +        [IFLA_PHYS_PORT_ID]     = { .type = NETLINK_TYPE_BINARY, .len = MAX_PHYS_PORT_ID_LEN },  */  };  static const NLTypeSystem rtnl_link_type_system = { -        .max = ELEMENTSOF(rtnl_link_types) - 1, +        .count = ELEMENTSOF(rtnl_link_types),          .types = rtnl_link_types,  };  /* IFA_FLAGS was defined in kernel 3.14, but we still support older   * kernels where IFA_MAX is lower. */  static const NLType rtnl_address_types[CONST_MAX(IFA_MAX, IFA_FLAGS) + 1] = { -        [IFA_ADDRESS]           = { .type = NLA_IN_ADDR }, -        [IFA_LOCAL]             = { .type = NLA_IN_ADDR }, -        [IFA_LABEL]             = { .type = NLA_STRING, .size = IFNAMSIZ - 1 }, -        [IFA_BROADCAST]         = { .type = NLA_IN_ADDR }, /* 6? */ -        [IFA_CACHEINFO]         = { .type = NLA_CACHE_INFO, .size = sizeof(struct ifa_cacheinfo) }, +        [IFA_ADDRESS]           = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFA_LOCAL]             = { .type = NETLINK_TYPE_IN_ADDR }, +        [IFA_LABEL]             = { .type = NETLINK_TYPE_STRING, .size = IFNAMSIZ - 1 }, +        [IFA_BROADCAST]         = { .type = NETLINK_TYPE_IN_ADDR }, /* 6? */ +        [IFA_CACHEINFO]         = { .type = NETLINK_TYPE_CACHE_INFO, .size = sizeof(struct ifa_cacheinfo) },  /*          [IFA_ANYCAST],          [IFA_MULTICAST],  */ -        [IFA_FLAGS]             = { .type = NLA_U32 }, +        [IFA_FLAGS]             = { .type = NETLINK_TYPE_U32 },  };  static const NLTypeSystem rtnl_address_type_system = { -        .max = ELEMENTSOF(rtnl_address_types) - 1, +        .count = ELEMENTSOF(rtnl_address_types),          .types = rtnl_address_types,  };  static const NLType rtnl_route_types[RTA_MAX + 1] = { -        [RTA_DST]               = { .type = NLA_IN_ADDR }, /* 6? */ -        [RTA_SRC]               = { .type = NLA_IN_ADDR }, /* 6? */ -        [RTA_IIF]               = { .type = NLA_U32 }, -        [RTA_OIF]               = { .type = NLA_U32 }, -        [RTA_GATEWAY]           = { .type = NLA_IN_ADDR }, -        [RTA_PRIORITY]          = { .type = NLA_U32 }, -        [RTA_PREFSRC]           = { .type = NLA_IN_ADDR }, /* 6? */ +        [RTA_DST]               = { .type = NETLINK_TYPE_IN_ADDR }, /* 6? */ +        [RTA_SRC]               = { .type = NETLINK_TYPE_IN_ADDR }, /* 6? */ +        [RTA_IIF]               = { .type = NETLINK_TYPE_U32 }, +        [RTA_OIF]               = { .type = NETLINK_TYPE_U32 }, +        [RTA_GATEWAY]           = { .type = NETLINK_TYPE_IN_ADDR }, +        [RTA_PRIORITY]          = { .type = NETLINK_TYPE_U32 }, +        [RTA_PREFSRC]           = { .type = NETLINK_TYPE_IN_ADDR }, /* 6? */  /* -        [RTA_METRICS]           = { .type = NLA_NESTED }, +        [RTA_METRICS]           = { .type = NETLINK_TYPE_NESTED },          [RTA_MULTIPATH]         = { .len = sizeof(struct rtnexthop) },  */ -        [RTA_FLOW]              = { .type = NLA_U32 }, /* 6? */ +        [RTA_FLOW]              = { .type = NETLINK_TYPE_U32 }, /* 6? */  /*          RTA_CACHEINFO,          RTA_TABLE, @@ -417,65 +460,95 @@ static const NLType rtnl_route_types[RTA_MAX + 1] = {  };  static const NLTypeSystem rtnl_route_type_system = { -        .max = ELEMENTSOF(rtnl_route_types) - 1, +        .count = ELEMENTSOF(rtnl_route_types),          .types = rtnl_route_types,  };  static const NLType rtnl_neigh_types[NDA_MAX + 1] = { -        [NDA_DST]               = { .type = NLA_IN_ADDR }, -        [NDA_LLADDR]            = { .type = NLA_ETHER_ADDR }, -        [NDA_CACHEINFO]         = { .type = NLA_CACHE_INFO, .size = sizeof(struct nda_cacheinfo) }, -        [NDA_PROBES]            = { .type = NLA_U32 }, -        [NDA_VLAN]              = { .type = NLA_U16 }, -        [NDA_PORT]              = { .type = NLA_U16 }, -        [NDA_VNI]               = { .type = NLA_U32 }, -        [NDA_IFINDEX]           = { .type = NLA_U32 }, +        [NDA_DST]               = { .type = NETLINK_TYPE_IN_ADDR }, +        [NDA_LLADDR]            = { .type = NETLINK_TYPE_ETHER_ADDR }, +        [NDA_CACHEINFO]         = { .type = NETLINK_TYPE_CACHE_INFO, .size = sizeof(struct nda_cacheinfo) }, +        [NDA_PROBES]            = { .type = NETLINK_TYPE_U32 }, +        [NDA_VLAN]              = { .type = NETLINK_TYPE_U16 }, +        [NDA_PORT]              = { .type = NETLINK_TYPE_U16 }, +        [NDA_VNI]               = { .type = NETLINK_TYPE_U32 }, +        [NDA_IFINDEX]           = { .type = NETLINK_TYPE_U32 },  };  static const NLTypeSystem rtnl_neigh_type_system = { -        .max = ELEMENTSOF(rtnl_neigh_types) - 1, +        .count = ELEMENTSOF(rtnl_neigh_types),          .types = rtnl_neigh_types,  };  static const NLType rtnl_types[RTM_MAX + 1] = { -        [NLMSG_DONE]   = { .type = NLA_META, .size = 0 }, -        [NLMSG_ERROR]  = { .type = NLA_META, .size = sizeof(struct nlmsgerr) }, -        [RTM_NEWLINK]  = { .type = NLA_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, -        [RTM_DELLINK]  = { .type = NLA_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, -        [RTM_GETLINK]  = { .type = NLA_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, -        [RTM_SETLINK]  = { .type = NLA_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, -        [RTM_NEWADDR]  = { .type = NLA_NESTED, .type_system = &rtnl_address_type_system, .size = sizeof(struct ifaddrmsg) }, -        [RTM_DELADDR]  = { .type = NLA_NESTED, .type_system = &rtnl_address_type_system, .size = sizeof(struct ifaddrmsg) }, -        [RTM_GETADDR]  = { .type = NLA_NESTED, .type_system = &rtnl_address_type_system, .size = sizeof(struct ifaddrmsg) }, -        [RTM_NEWROUTE] = { .type = NLA_NESTED, .type_system = &rtnl_route_type_system, .size = sizeof(struct rtmsg) }, -        [RTM_DELROUTE] = { .type = NLA_NESTED, .type_system = &rtnl_route_type_system, .size = sizeof(struct rtmsg) }, -        [RTM_GETROUTE] = { .type = NLA_NESTED, .type_system = &rtnl_route_type_system, .size = sizeof(struct rtmsg) }, -        [RTM_NEWNEIGH] = { .type = NLA_NESTED, .type_system = &rtnl_neigh_type_system, .size = sizeof(struct ndmsg) }, -        [RTM_DELNEIGH] = { .type = NLA_NESTED, .type_system = &rtnl_neigh_type_system, .size = sizeof(struct ndmsg) }, -        [RTM_GETNEIGH] = { .type = NLA_NESTED, .type_system = &rtnl_neigh_type_system, .size = sizeof(struct ndmsg) }, -}; - -const NLTypeSystem rtnl_type_system = { -        .max = ELEMENTSOF(rtnl_types) - 1, +        [NLMSG_DONE]   = { .type = NETLINK_TYPE_NESTED, .type_system = &empty_type_system, .size = 0 }, +        [NLMSG_ERROR]  = { .type = NETLINK_TYPE_NESTED, .type_system = &empty_type_system, .size = sizeof(struct nlmsgerr) }, +        [RTM_NEWLINK]  = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, +        [RTM_DELLINK]  = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, +        [RTM_GETLINK]  = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, +        [RTM_SETLINK]  = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_link_type_system, .size = sizeof(struct ifinfomsg) }, +        [RTM_NEWADDR]  = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_address_type_system, .size = sizeof(struct ifaddrmsg) }, +        [RTM_DELADDR]  = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_address_type_system, .size = sizeof(struct ifaddrmsg) }, +        [RTM_GETADDR]  = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_address_type_system, .size = sizeof(struct ifaddrmsg) }, +        [RTM_NEWROUTE] = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_route_type_system, .size = sizeof(struct rtmsg) }, +        [RTM_DELROUTE] = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_route_type_system, .size = sizeof(struct rtmsg) }, +        [RTM_GETROUTE] = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_route_type_system, .size = sizeof(struct rtmsg) }, +        [RTM_NEWNEIGH] = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_neigh_type_system, .size = sizeof(struct ndmsg) }, +        [RTM_DELNEIGH] = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_neigh_type_system, .size = sizeof(struct ndmsg) }, +        [RTM_GETNEIGH] = { .type = NETLINK_TYPE_NESTED, .type_system = &rtnl_neigh_type_system, .size = sizeof(struct ndmsg) }, +}; + +const NLTypeSystem type_system_root = { +        .count = ELEMENTSOF(rtnl_types),          .types = rtnl_types,  }; -int type_system_get_type(const NLTypeSystem *type_system, const NLType **ret, uint16_t type) { -        const NLType *nl_type; +uint16_t type_get_type(const NLType *type) { +        assert(type); +        return type->type; +} +size_t type_get_size(const NLType *type) { +        assert(type); +        return type->size; +} + +void type_get_type_system(const NLType *nl_type, const NLTypeSystem **ret) { +        assert(nl_type);          assert(ret); +        assert(nl_type->type == NETLINK_TYPE_NESTED); +        assert(nl_type->type_system); -        if (!type_system) -                type_system = &rtnl_type_system; +        *ret = nl_type->type_system; +} +void type_get_type_system_union(const NLType *nl_type, const NLTypeSystemUnion **ret) { +        assert(nl_type); +        assert(ret); +        assert(nl_type->type == NETLINK_TYPE_UNION); +        assert(nl_type->type_system_union); + +        *ret = nl_type->type_system_union; +} + +uint16_t type_system_get_count(const NLTypeSystem *type_system) { +        assert(type_system); +        return type_system->count; +} + +int type_system_get_type(const NLTypeSystem *type_system, const NLType **ret, uint16_t type) { +        const NLType *nl_type; + +        assert(ret); +        assert(type_system);          assert(type_system->types); -        if (type > type_system->max) +        if (type >= type_system->count)                  return -EOPNOTSUPP;          nl_type = &type_system->types[type]; -        if (nl_type->type == NLA_UNSPEC) +        if (nl_type->type == NETLINK_TYPE_UNSPEC)                  return -EOPNOTSUPP;          *ret = nl_type; @@ -493,11 +566,7 @@ int type_system_get_type_system(const NLTypeSystem *type_system, const NLTypeSys          if (r < 0)                  return r; -        assert(nl_type->type == NLA_NESTED); -        assert(nl_type->type_system); - -        *ret = nl_type->type_system; - +        type_get_type_system(nl_type, ret);          return 0;  } @@ -511,11 +580,7 @@ int type_system_get_type_system_union(const NLTypeSystem *type_system, const NLT          if (r < 0)                  return r; -        assert(nl_type->type == NLA_UNION); -        assert(nl_type->type_system_union); - -        *ret = nl_type->type_system_union; - +        type_get_type_system_union(nl_type, ret);          return 0;  } @@ -552,7 +617,7 @@ int type_system_union_protocol_get_type_system(const NLTypeSystemUnion *type_sys                  return -EOPNOTSUPP;          type_system = &type_system_union->type_systems[protocol]; -        if (type_system->max == 0) +        if (!type_system->types)                  return -EOPNOTSUPP;          *ret = type_system; diff --git a/src/libsystemd/sd-netlink/netlink-types.h b/src/libsystemd/sd-netlink/netlink-types.h index de1544bf36..a210163241 100644 --- a/src/libsystemd/sd-netlink/netlink-types.h +++ b/src/libsystemd/sd-netlink/netlink-types.h @@ -22,18 +22,17 @@  ***/  enum { -        NLA_UNSPEC, -        NLA_META, -        NLA_U8, -        NLA_U16, -        NLA_U32, -        NLA_U64, -        NLA_STRING, -        NLA_IN_ADDR, -        NLA_ETHER_ADDR, -        NLA_CACHE_INFO, -        NLA_NESTED, -        NLA_UNION, +        NETLINK_TYPE_UNSPEC, +        NETLINK_TYPE_U8,                        /* NLA_U8 */ +        NETLINK_TYPE_U16,                       /* NLA_U16 */ +        NETLINK_TYPE_U32,                       /* NLA_U32 */ +        NETLINK_TYPE_U64,                       /* NLA_U64 */ +        NETLINK_TYPE_STRING,                    /* NLA_STRING */ +        NETLINK_TYPE_IN_ADDR, +        NETLINK_TYPE_ETHER_ADDR, +        NETLINK_TYPE_CACHE_INFO, +        NETLINK_TYPE_NESTED,                    /* NLA_NESTED */ +        NETLINK_TYPE_UNION,  };  typedef enum NLMatchType { @@ -53,18 +52,14 @@ struct NLTypeSystemUnion {          const NLTypeSystem *type_systems;  }; -struct NLTypeSystem { -        uint16_t max; -        const NLType *types; -}; +extern const NLTypeSystem type_system_root; -struct NLType { -        uint16_t type; -        size_t size; -        const NLTypeSystem *type_system; -        const NLTypeSystemUnion *type_system_union; -}; +uint16_t type_get_type(const NLType *type); +size_t type_get_size(const NLType *type); +void type_get_type_system(const NLType *type, const NLTypeSystem **ret); +void type_get_type_system_union(const NLType *type, const NLTypeSystemUnion **ret); +uint16_t type_system_get_count(const NLTypeSystem *type_system);  int type_system_get_type(const NLTypeSystem *type_system, const NLType **ret, uint16_t type);  int type_system_get_type_system(const NLTypeSystem *type_system, const NLTypeSystem **ret, uint16_t type);  int type_system_get_type_system_union(const NLTypeSystem *type_system, const NLTypeSystemUnion **ret, uint16_t type); @@ -95,25 +90,3 @@ typedef enum NLUnionLinkInfoData {  const char *nl_union_link_info_data_to_string(NLUnionLinkInfoData p) _const_;  NLUnionLinkInfoData nl_union_link_info_data_from_string(const char *p) _pure_; - -/* Maximum ARP IP target defined in kernel */ -#define BOND_MAX_ARP_TARGETS    16 - -typedef enum BondArpTargets { -        BOND_ARP_TARGETS_0, -        BOND_ARP_TARGETS_1, -        BOND_ARP_TARGETS_2, -        BOND_ARP_TARGETS_3, -        BOND_ARP_TARGETS_4, -        BOND_ARP_TARGETS_5, -        BOND_ARP_TARGETS_6, -        BOND_ARP_TARGETS_7, -        BOND_ARP_TARGETS_8, -        BOND_ARP_TARGETS_9, -        BOND_ARP_TARGETS_10, -        BOND_ARP_TARGETS_11, -        BOND_ARP_TARGETS_12, -        BOND_ARP_TARGETS_13, -        BOND_ARP_TARGETS_14, -        BOND_ARP_TARGETS_MAX = BOND_MAX_ARP_TARGETS, -} BondArpTargets; diff --git a/src/network/networkd-netdev-bond.c b/src/network/networkd-netdev-bond.c index 6336ff58a7..a60034dbe6 100644 --- a/src/network/networkd-netdev-bond.c +++ b/src/network/networkd-netdev-bond.c @@ -25,7 +25,6 @@  #include "conf-parser.h"  #include "sd-netlink.h" -#include "netlink-types.h"  #include "networkd-netdev-bond.h"  #include "missing.h" @@ -372,11 +371,11 @@ int config_parse_arp_ip_target_address(const char *unit,                  b->n_arp_ip_targets ++;                  buffer = NULL; - -                if (b->n_arp_ip_targets > BOND_ARP_TARGETS_MAX) -                        break;          } +        if (b->n_arp_ip_targets > NETDEV_BOND_ARP_TARGETS_MAX) +                log_syntax(unit, LOG_WARNING, filename, line, EINVAL, "More than the maximum number of kernel-supported ARP ip targets specified: %d > %d", b->n_arp_ip_targets, NETDEV_BOND_ARP_TARGETS_MAX); +          return 0;  } diff --git a/src/network/networkd-netdev-bond.h b/src/network/networkd-netdev-bond.h index 32d1702d58..9991fa731f 100644 --- a/src/network/networkd-netdev-bond.h +++ b/src/network/networkd-netdev-bond.h @@ -25,6 +25,12 @@ typedef struct Bond Bond;  #include "networkd-netdev.h" +/* + * Maximum number of targets supported by the kernel for a single + * bond netdev. + */ +#define NETDEV_BOND_ARP_TARGETS_MAX 16 +  typedef enum BondMode {          NETDEV_BOND_MODE_BALANCE_RR,          NETDEV_BOND_MODE_ACTIVE_BACKUP, | 
