diff options
author | Martin Mares <mj@ucw.cz> | 2003-02-22 23:47:45 +0100 |
---|---|---|
committer | Martin Mares <mj@ucw.cz> | 2003-02-22 23:47:45 +0100 |
commit | 11d4474c17e76e9811dcb32f555fa1c6f3684fab (patch) | |
tree | 68ed6fd715e7b72eba4bcfec7d3ef2990373915f /proto/bgp/packets.c | |
parent | 7b7a7b43a6915efbe9180f07cd1284a39efacf02 (diff) | |
download | bird-11d4474c17e76e9811dcb32f555fa1c6f3684fab.tar bird-11d4474c17e76e9811dcb32f555fa1c6f3684fab.zip |
Better selection of link-local NLRI addresses, at least for our own
address. Need to do it better for the other neighbors -- the current
solution works only if they use the standard 64+64 global addresses
and the interface identifier in lower 64 bits is the same as for the
link-scope addresses.
Diffstat (limited to 'proto/bgp/packets.c')
-rw-r--r-- | proto/bgp/packets.c | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/proto/bgp/packets.c b/proto/bgp/packets.c index bf89343..03b2211 100644 --- a/proto/bgp/packets.c +++ b/proto/bgp/packets.c @@ -193,20 +193,27 @@ bgp_create_update(struct bgp_conn *conn, byte *buf) nh = ea_find(buck->eattrs, EA_CODE(EAP_BGP, BA_NEXT_HOP)); ASSERT(nh); ip = *(ip_addr *) nh->u.ptr->data; + is_ll = 0; if (ipa_equal(ip, p->local_addr)) - is_ll = 1; + { + is_ll = 1; + ip_ll = p->local_link; + } else { n = neigh_find(&p->p, &ip, 0); if (n && n->iface == p->neigh->iface) - is_ll = 1; - else - is_ll = 0; + { + /* FIXME: We are assuming the global scope addresses use the lower 64 bits + * as an interface identifier which hasn't necessarily to be true. + */ + is_ll = 1; + ip_ll = ipa_or(ipa_build(0xfe800000,0,0,0), ipa_and(ip, ipa_build(0,0,~0,~0))); + } } if (is_ll) { *tmp++ = 32; - ip_ll = ipa_or(ipa_build(0xfe80,0,0,0), ipa_and(ip, ipa_build(0,0,~0,~0))); ipa_hton(ip); memcpy(tmp, &ip, 16); ipa_hton(ip_ll); |