diff options
Diffstat (limited to 'nhrpd')
-rw-r--r-- | nhrpd/nhrp_nhs.c | 1 | ||||
-rw-r--r-- | nhrpd/nhrp_peer.c | 77 | ||||
-rw-r--r-- | nhrpd/nhrp_shortcut.c | 29 | ||||
-rw-r--r-- | nhrpd/nhrp_vty.c | 14 |
4 files changed, 69 insertions, 52 deletions
diff --git a/nhrpd/nhrp_nhs.c b/nhrpd/nhrp_nhs.c index 1e53c1659..5f8bbd702 100644 --- a/nhrpd/nhrp_nhs.c +++ b/nhrpd/nhrp_nhs.c @@ -476,6 +476,7 @@ int nhrp_nhs_match_ip(union sockunion *in_ip, struct nhrp_interface *nifp) int i; struct nhrp_nhs *nhs; struct nhrp_registration *reg; + for (i = 0; i < AFI_MAX; i++) { list_for_each_entry(nhs, &nifp->afi[i].nhslist_head, nhslist_entry) diff --git a/nhrpd/nhrp_peer.c b/nhrpd/nhrp_peer.c index a4c93bd2a..d89e82b52 100644 --- a/nhrpd/nhrp_peer.c +++ b/nhrpd/nhrp_peer.c @@ -290,6 +290,7 @@ static int nhrp_peer_defer_vici_request(struct thread *t) struct interface *ifp = p->ifp; struct nhrp_interface *nifp = ifp->info; char buf[SU_ADDRSTRLEN]; + THREAD_OFF(p->t_timer); if (p->online) { @@ -341,7 +342,9 @@ int nhrp_peer_check(struct nhrp_peer *p, int establish) (nifp->ipsec_fallback_profile && !p->prio) ? 15 : 30, &p->t_fallback); } else { - int r_time_ms = rand() % 1000; // Maximum timeout is 1 seconds + /* Maximum timeout is 1 second */ + int r_time_ms = rand() % 1000; + debugf(NHRP_DEBUG_COMMON, "Initiating IPsec connection request to %s after %d ms:\n", sockunion2str(&vc->remote.nbma, buf, sizeof(buf)) @@ -414,7 +417,8 @@ static void nhrp_process_nat_extension(struct nhrp_packet_parser *pp, * extension and update the cache without which * the neighbor table in the kernel contains the * source NBMA address which is not reachable - * since it is behind a NAT device */ + * since it is behind a NAT device + */ if (!sockunion2str(proto, buf1, sizeof(buf1))) strlcpy(buf1, "NULL", sizeof(buf1)); debugf(NHRP_DEBUG_COMMON, @@ -506,19 +510,18 @@ static void nhrp_handle_resolution_req(struct nhrp_packet_parser *pp) continue; } - proto_addr = (sockunion_family(&cie_proto) == AF_UNSPEC) ? &pp->src_proto : &cie_proto; - /* Check if there is an entry for this proto_addr in - * NHRP_NAT_EXTENSION */ + /* Check for this proto_addr in NHRP_NAT_EXTENSION */ nhrp_process_nat_extension(pp, proto_addr, &cie_nbma_nat); if (sockunion_family(&cie_nbma_nat) == AF_UNSPEC) { /* It may be possible that this resolution reply is * coming directly from NATTED Spoke and there is not - * NAT Extension present */ + * NAT Extension present + */ debugf(NHRP_DEBUG_COMMON, "No NAT Extension for %s", sockunion2str(proto_addr, buf, sizeof(buf)) ? buf @@ -569,7 +572,6 @@ static void nhrp_handle_resolution_req(struct nhrp_packet_parser *pp) if (nbma_addr) sockunion2str(nbma_addr, buf, sizeof(buf)); - debugf(NHRP_DEBUG_COMMON, "shortcut res_rep: updating binding for nmba addr %s", nbma_addr ? buf : "(NULL)"); @@ -961,7 +963,7 @@ static void nhrp_peer_forward(struct nhrp_peer *p, union sockunion cie_nbma, cie_protocol, cie_protocol_mandatory, *proto = NULL; uint16_t type, len; - struct nhrp_cache *c; + struct nhrp_cache *c = NULL; char buf[SU_ADDRSTRLEN]; if (pp->hdr->hop_count == 0) @@ -1037,7 +1039,8 @@ static void nhrp_peer_forward(struct nhrp_peer *p, "Processing NHRP_EXTENSION_NAT_ADDRESS while forwarding the reply packet"); /* For reply packet use protocol * specified in CIE of mandatory part - * for cache lookup */ + * for cache lookup + */ if (sockunion_family( &cie_protocol_mandatory) != AF_UNSPEC) @@ -1049,34 +1052,32 @@ static void nhrp_peer_forward(struct nhrp_peer *p, sockunion2str(proto, buf, sizeof(buf))); c = nhrp_cache_get(nifp->ifp, proto, 0); - if (c) { - debugf(NHRP_DEBUG_COMMON, - "c->cur.remote_nbma_natoa is %s", - sockunion2str( - &c->cur.remote_nbma_natoa, - buf, sizeof(buf)) - ? buf - : "NULL"); - if (sockunion_family( - &c->cur.remote_nbma_natoa) - != AF_UNSPEC) { - cie = nhrp_cie_push( - zb, - NHRP_CODE_SUCCESS, - &c->cur.remote_nbma_natoa, - proto); - if (!cie) - goto err; - } - } else { - debugf(NHRP_DEBUG_COMMON, - "No cache entry for Proto is %s", - sockunion2str( - proto, buf, - sizeof(buf))); - zbuf_put(zb, extpl.head, len); + } + + if (c) { + debugf(NHRP_DEBUG_COMMON, + "c->cur.remote_nbma_natoa is %s", + sockunion2str( + &c->cur.remote_nbma_natoa, + buf, sizeof(buf)) + ? buf + : "NULL"); + if (sockunion_family( + &c->cur.remote_nbma_natoa) + != AF_UNSPEC) { + cie = nhrp_cie_push( + zb, + NHRP_CODE_SUCCESS, + &c->cur.remote_nbma_natoa, + proto); + if (!cie) + goto err; } } else { + if (proto) + debugf(NHRP_DEBUG_COMMON, + "No cache entry for proto %s", + buf); zbuf_put(zb, extpl.head, len); } } @@ -1084,13 +1085,15 @@ static void nhrp_peer_forward(struct nhrp_peer *p, default: if (htons(ext->type) & NHRP_EXTENSION_FLAG_COMPULSORY) /* FIXME: RFC says to just copy, but not - * append our selves to the transit NHS list */ + * append our selves to the transit NHS list + */ goto err; /* fallthru */ case NHRP_EXTENSION_RESPONDER_ADDRESS: /* Supported compulsory extensions, and any * non-compulsory that is not explicitly handled, - * should be just copied. */ + * should be just copied. + */ zbuf_copy(zb, &extpl, len); break; } diff --git a/nhrpd/nhrp_shortcut.c b/nhrpd/nhrp_shortcut.c index cf4b5972c..dd6392237 100644 --- a/nhrpd/nhrp_shortcut.c +++ b/nhrpd/nhrp_shortcut.c @@ -211,7 +211,7 @@ static void nhrp_shortcut_recv_resolution_rep(struct nhrp_reqid *reqid, struct nhrp_extension_header *ext; struct nhrp_cie_header *cie; struct nhrp_cache *c = NULL; - struct nhrp_cache *c_dst_proto = NULL; + struct nhrp_cache *c_dst = NULL; union sockunion *proto, cie_proto, *nbma, cie_nbma, nat_nbma; struct prefix prefix, route_prefix; struct zbuf extpl; @@ -278,8 +278,10 @@ static void nhrp_shortcut_recv_resolution_rep(struct nhrp_reqid *reqid, switch (htons(ext->type) & ~NHRP_EXTENSION_FLAG_COMPULSORY) { case NHRP_EXTENSION_NAT_ADDRESS: { struct nhrp_cie_header *cie_nat; + do { union sockunion cie_nat_proto, cie_nat_nbma; + sockunion_family(&cie_nat_proto) = AF_UNSPEC; sockunion_family(&cie_nat_nbma) = AF_UNSPEC; cie_nat = nhrp_cie_pull(&extpl, pp->hdr, @@ -307,7 +309,8 @@ static void nhrp_shortcut_recv_resolution_rep(struct nhrp_reqid *reqid, nbma = &nat_nbma; } /* For NHRP resolution reply the cie_nbma in mandatory part is the - * address of the actual address of the sender */ + * address of the actual address of the sender + */ else if (!sockunion_same(&cie_nbma, &pp->peer->vc->remote.nbma) && !nhrp_nhs_match_ip(&pp->peer->vc->remote.nbma, nifp)) { debugf(NHRP_DEBUG_COMMON, @@ -316,7 +319,7 @@ static void nhrp_shortcut_recv_resolution_rep(struct nhrp_reqid *reqid, debugf(NHRP_DEBUG_COMMON, "cie_nbma %s", sockunion2str(&cie_nbma, buf[1], sizeof(buf[1]))); debugf(NHRP_DEBUG_COMMON, "remote.nbma %s", - sockunion2str(&pp->peer->vc->remote.nbma, buf[1], + sockunion2str(&pp->peer->vc->remote.nbma, buf[1], sizeof(buf[1]))); nbma = &pp->peer->vc->remote.nbma; nat_nbma = *nbma; @@ -338,7 +341,9 @@ static void nhrp_shortcut_recv_resolution_rep(struct nhrp_reqid *reqid, nhrp_cache_update_binding(c, NHRP_CACHE_DYNAMIC, holding_time, nhrp_peer_get(pp->ifp, nbma), - htons(cie->mtu), nbma, &cie_nbma); + htons(cie->mtu), + nbma, + &cie_nbma); } else { debugf(NHRP_DEBUG_COMMON, "Shortcut: no cache for nbma %s", buf[2]); @@ -346,17 +351,21 @@ static void nhrp_shortcut_recv_resolution_rep(struct nhrp_reqid *reqid, /* Update cache binding for dst_proto as well */ if (sockunion_cmp(proto, &pp->dst_proto)) { - c_dst_proto = nhrp_cache_get(pp->ifp, &pp->dst_proto, 1); - if (c_dst_proto) { + c_dst = nhrp_cache_get(pp->ifp, &pp->dst_proto, 1); + if (c_dst) { debugf(NHRP_DEBUG_COMMON, - "Shortcut: cache found, update binding"); - nhrp_cache_update_binding(c_dst_proto, NHRP_CACHE_DYNAMIC, + "Shortcut: cache found, update binding"); + nhrp_cache_update_binding(c_dst, + NHRP_CACHE_DYNAMIC, holding_time, nhrp_peer_get(pp->ifp, nbma), - htons(cie->mtu), nbma, &cie_nbma); + htons(cie->mtu), + nbma, + &cie_nbma); } else { debugf(NHRP_DEBUG_COMMON, - "Shortcut: no cache for nbma %s", buf[2]); + "Shortcut: no cache for nbma %s", + buf[2]); } } } diff --git a/nhrpd/nhrp_vty.c b/nhrpd/nhrp_vty.c index a55903707..08900cfc6 100644 --- a/nhrpd/nhrp_vty.c +++ b/nhrpd/nhrp_vty.c @@ -565,7 +565,8 @@ DEFUN(if_no_nhrp_map, if_no_nhrp_map_cmd, return CMD_SUCCESS; nhrp_cache_update_binding(c, c->cur.type, -1, - nhrp_peer_get(ifp, &nbma_addr), 0, NULL, NULL); + nhrp_peer_get(ifp, &nbma_addr), 0, NULL, + NULL); return CMD_SUCCESS; } @@ -637,8 +638,9 @@ static void show_ip_nhrp_cache(struct nhrp_cache *c, void *pctx) if (!ctx->count && !ctx->json) { - vty_out(vty, "%-8s %-8s %-24s %-24s %-24s %-6s %s\n", "Iface", "Type", - "Protocol", "NBMA", "Claimed NBMA", "Flags", "Identity"); + vty_out(vty, "%-8s %-8s %-24s %-24s %-24s %-6s %s\n", "Iface", + "Type", "Protocol", "NBMA", "Claimed NBMA", "Flags", + "Identity"); } ctx->count++; @@ -649,7 +651,8 @@ static void show_ip_nhrp_cache(struct nhrp_cache *c, void *pctx) else snprintf(buf[1], sizeof(buf[1]), "-"); - if (c->cur.peer && sockunion_family(&c->cur.remote_nbma_claimed) != AF_UNSPEC) + if (c->cur.peer + && sockunion_family(&c->cur.remote_nbma_claimed) != AF_UNSPEC) sockunion2str(&c->cur.remote_nbma_claimed, buf[2], sizeof(buf[2])); @@ -979,7 +982,8 @@ static void clear_nhrp_cache(struct nhrp_cache *c, void *data) { struct info_ctx *ctx = data; if (c->cur.type <= NHRP_CACHE_DYNAMIC) { - nhrp_cache_update_binding(c, c->cur.type, -1, NULL, 0, NULL, NULL); + nhrp_cache_update_binding(c, c->cur.type, -1, NULL, 0, NULL, + NULL); ctx->count++; } } |