pimd: Receive incoming v6 addresses and place in pim_ifp list

Add code to properly receive v6 addresses up from zebra and to
properly place them into our interface secondary address list.

Additionally cleanup some code in pim_cmd.c that was broken
by these changes.

Signed-off-by: Donald Sharp <sharpd@cumulusnetworks.com>
This commit is contained in:
Donald Sharp 2017-03-30 09:10:05 -04:00
parent eeff6d3f99
commit 294b6d7243
4 changed files with 48 additions and 53 deletions

View File

@ -816,6 +816,7 @@ static void pim_show_interfaces_single(struct vty *vty, const char *ifname, u_ch
mloop = pim_socket_mcastloop_get(pim_ifp->pim_sock_fd); mloop = pim_socket_mcastloop_get(pim_ifp->pim_sock_fd);
if (uj) { if (uj) {
char pbuf[PREFIX2STR_BUFFER];
json_row = json_object_new_object(); json_row = json_object_new_object();
json_object_pim_ifp_add(json_row, ifp); json_object_pim_ifp_add(json_row, ifp);
@ -827,7 +828,8 @@ static void pim_show_interfaces_single(struct vty *vty, const char *ifname, u_ch
sec_list = json_object_new_array(); sec_list = json_object_new_array();
for (ALL_LIST_ELEMENTS_RO(pim_ifp->sec_addr_list, sec_node, sec_addr)) { for (ALL_LIST_ELEMENTS_RO(pim_ifp->sec_addr_list, sec_node, sec_addr)) {
json_object_array_add(sec_list, json_object_new_string(inet_ntoa(sec_addr->addr))); json_object_array_add(sec_list,
json_object_new_string(prefix2str(&sec_addr->addr, pbuf, PREFIX2STR_BUFFER)));
} }
json_object_object_add(json_row, "secondaryAddressList", sec_list); json_object_object_add(json_row, "secondaryAddressList", sec_list);
} }
@ -918,11 +920,12 @@ static void pim_show_interfaces_single(struct vty *vty, const char *ifname, u_ch
vty_out(vty, "Use Source : %s%s", inet_ntoa(pim_ifp->update_source), VTY_NEWLINE); vty_out(vty, "Use Source : %s%s", inet_ntoa(pim_ifp->update_source), VTY_NEWLINE);
} }
if (pim_ifp->sec_addr_list) { if (pim_ifp->sec_addr_list) {
char pbuf[PREFIX2STR_BUFFER];
vty_out(vty, "Address : %s (primary)%s", vty_out(vty, "Address : %s (primary)%s",
inet_ntoa(ifaddr), VTY_NEWLINE); inet_ntoa(ifaddr), VTY_NEWLINE);
for (ALL_LIST_ELEMENTS_RO(pim_ifp->sec_addr_list, sec_node, sec_addr)) { for (ALL_LIST_ELEMENTS_RO(pim_ifp->sec_addr_list, sec_node, sec_addr)) {
vty_out(vty, " %s%s", vty_out(vty, " %s%s",
inet_ntoa(sec_addr->addr), VTY_NEWLINE); prefix2str(&sec_addr->addr, pbuf, PREFIX2STR_BUFFER), VTY_NEWLINE);
} }
} else { } else {
vty_out(vty, "Address : %s%s", inet_ntoa(ifaddr), VTY_NEWLINE); vty_out(vty, "Address : %s%s", inet_ntoa(ifaddr), VTY_NEWLINE);
@ -1607,13 +1610,9 @@ static void pim_show_neighbors_secondary(struct vty *vty)
neigh_src_str, sizeof(neigh_src_str)); neigh_src_str, sizeof(neigh_src_str));
for (ALL_LIST_ELEMENTS_RO(neigh->prefix_list, prefix_node, p)) { for (ALL_LIST_ELEMENTS_RO(neigh->prefix_list, prefix_node, p)) {
char neigh_sec_str[INET_ADDRSTRLEN]; char neigh_sec_str[100];
if (p->family != AF_INET) prefix2str(p, neigh_sec_str, 100);
continue;
pim_inet4_dump("<src?>", p->u.prefix4,
neigh_sec_str, sizeof(neigh_sec_str));
vty_out(vty, "%-9s %-15s %-15s %-15s%s", vty_out(vty, "%-9s %-15s %-15s %-15s%s",
ifp->name, ifp->name,

View File

@ -324,12 +324,29 @@ static int pim_sec_addr_comp(const void *p1, const void *p2)
const struct pim_secondary_addr *sec1 = p1; const struct pim_secondary_addr *sec1 = p1;
const struct pim_secondary_addr *sec2 = p2; const struct pim_secondary_addr *sec2 = p2;
if (ntohl(sec1->addr.s_addr) < ntohl(sec2->addr.s_addr)) if (sec1->addr.family == AF_INET &&
sec2->addr.family == AF_INET6)
return -1; return -1;
if (ntohl(sec1->addr.s_addr) > ntohl(sec2->addr.s_addr)) if (sec1->addr.family == AF_INET6 &&
sec2->addr.family == AF_INET)
return 1; return 1;
if (sec1->addr.family == AF_INET)
{
if (ntohl(sec1->addr.u.prefix4.s_addr) < ntohl(sec2->addr.u.prefix4.s_addr))
return -1;
if (ntohl(sec1->addr.u.prefix4.s_addr) > ntohl(sec2->addr.u.prefix4.s_addr))
return 1;
}
else
{
return memcmp (&sec1->addr.u.prefix6,
&sec2->addr.u.prefix6,
sizeof (struct in6_addr));
}
return 0; return 0;
} }
@ -339,7 +356,7 @@ static void pim_sec_addr_free(struct pim_secondary_addr *sec_addr)
} }
static struct pim_secondary_addr * static struct pim_secondary_addr *
pim_sec_addr_find(struct pim_interface *pim_ifp, struct in_addr addr) pim_sec_addr_find(struct pim_interface *pim_ifp, struct prefix *addr)
{ {
struct pim_secondary_addr *sec_addr; struct pim_secondary_addr *sec_addr;
struct listnode *node; struct listnode *node;
@ -349,7 +366,7 @@ pim_sec_addr_find(struct pim_interface *pim_ifp, struct in_addr addr)
} }
for (ALL_LIST_ELEMENTS_RO(pim_ifp->sec_addr_list, node, sec_addr)) { for (ALL_LIST_ELEMENTS_RO(pim_ifp->sec_addr_list, node, sec_addr)) {
if (sec_addr->addr.s_addr == addr.s_addr) { if (prefix_cmp(&sec_addr->addr, addr)) {
return sec_addr; return sec_addr;
} }
} }
@ -364,7 +381,7 @@ static void pim_sec_addr_del(struct pim_interface *pim_ifp,
pim_sec_addr_free(sec_addr); pim_sec_addr_free(sec_addr);
} }
static int pim_sec_addr_add(struct pim_interface *pim_ifp, struct in_addr addr) static int pim_sec_addr_add(struct pim_interface *pim_ifp, struct prefix *addr)
{ {
int changed = 0; int changed = 0;
struct pim_secondary_addr *sec_addr; struct pim_secondary_addr *sec_addr;
@ -391,7 +408,7 @@ static int pim_sec_addr_add(struct pim_interface *pim_ifp, struct in_addr addr)
} }
changed = 1; changed = 1;
sec_addr->addr = addr; sec_addr->addr = *addr;
listnode_add_sort(pim_ifp->sec_addr_list, sec_addr); listnode_add_sort(pim_ifp->sec_addr_list, sec_addr);
return changed; return changed;
@ -433,10 +450,6 @@ static int pim_sec_addr_update(struct interface *ifp)
for (ALL_LIST_ELEMENTS_RO(ifp->connected, node, ifc)) { for (ALL_LIST_ELEMENTS_RO(ifp->connected, node, ifc)) {
struct prefix *p = ifc->address; struct prefix *p = ifc->address;
if (p->family != AF_INET) {
continue;
}
if (PIM_INADDR_IS_ANY(p->u.prefix4)) { if (PIM_INADDR_IS_ANY(p->u.prefix4)) {
continue; continue;
} }
@ -446,7 +459,7 @@ static int pim_sec_addr_update(struct interface *ifp)
continue; continue;
} }
if (pim_sec_addr_add(pim_ifp, p->u.prefix4)) { if (pim_sec_addr_add(pim_ifp, p)) {
changed = 1; changed = 1;
} }
} }
@ -571,6 +584,9 @@ void pim_if_addr_add(struct connected *ifc)
detect_address_change(ifp, 0, __PRETTY_FUNCTION__); detect_address_change(ifp, 0, __PRETTY_FUNCTION__);
if (ifc->address->family != AF_INET)
return;
if (PIM_IF_TEST_IGMP(pim_ifp->options)) { if (PIM_IF_TEST_IGMP(pim_ifp->options)) {
struct igmp_sock *igmp; struct igmp_sock *igmp;
@ -675,6 +691,9 @@ void pim_if_addr_del(struct connected *ifc, int force_prim_as_any)
ifp = ifc->ifp; ifp = ifc->ifp;
zassert(ifp); zassert(ifp);
if (ifc->address->family != AF_INET)
return;
if (PIM_DEBUG_ZEBRA) { if (PIM_DEBUG_ZEBRA) {
char buf[BUFSIZ]; char buf[BUFSIZ];
prefix2str(ifc->address, buf, BUFSIZ); prefix2str(ifc->address, buf, BUFSIZ);
@ -709,11 +728,8 @@ void pim_if_addr_add_all(struct interface *ifp)
struct prefix *p = ifc->address; struct prefix *p = ifc->address;
if (p->family != AF_INET) if (p->family != AF_INET)
{
v6_addrs++; v6_addrs++;
continue; else
}
v4_addrs++; v4_addrs++;
pim_if_addr_add(ifc); pim_if_addr_add(ifc);
} }

View File

@ -69,7 +69,7 @@ enum pim_secondary_addr_flags {
}; };
struct pim_secondary_addr { struct pim_secondary_addr {
struct in_addr addr; struct prefix addr;
enum pim_secondary_addr_flags flags; enum pim_secondary_addr_flags flags;
}; };

View File

@ -257,31 +257,11 @@ static int pim_zebra_if_address_add(int command, struct zclient *zclient,
#endif #endif
} }
if (p->family != AF_INET)
{
struct listnode *cnode;
struct connected *conn;
int v4addrs = 0;
for (ALL_LIST_ELEMENTS_RO (c->ifp->connected, cnode, conn))
{
if (conn->address->family == AF_INET)
v4addrs++;
}
if (!v4addrs && pim_ifp)
{
pim_ifp->primary_address = pim_find_primary_addr (c->ifp);
pim_if_addr_add_all (c->ifp);
pim_if_add_vif (c->ifp);
}
return 0;
}
if (!CHECK_FLAG(c->flags, ZEBRA_IFA_SECONDARY)) { if (!CHECK_FLAG(c->flags, ZEBRA_IFA_SECONDARY)) {
/* trying to add primary address */ /* trying to add primary address */
struct in_addr primary_addr = pim_find_primary_addr(c->ifp); struct in_addr primary_addr = pim_find_primary_addr(c->ifp);
if (primary_addr.s_addr != p->u.prefix4.s_addr) { if (p->family != AF_INET || primary_addr.s_addr != p->u.prefix4.s_addr) {
if (PIM_DEBUG_ZEBRA) { if (PIM_DEBUG_ZEBRA) {
/* but we had a primary address already */ /* but we had a primary address already */