We would advertise IPv6 routes to non-multiprotocol aware peers. Fix that.
Also, fix the way we parse options, to handle multiple optional parameters with
one capability in it (or many; it's just the way quagga send them).
Signed-off-by: Benjamin Cama <benoar@dolka.fr>
/* flag established peers for update */
for (i = 0; i < BGP_NUM_PEERS; i++)
/* flag established peers for update */
for (i = 0; i < BGP_NUM_PEERS; i++)
- if (bgp_peers[i].state == Established)
+ if (bgp_peers[i].state == Established
+ && bgp_peers[i].mp_handling == HandleIPv6Routes)
bgp_peers[i].update_routes6 = 1;
LOG(4, 0, 0, "Registered BGP route %s/%d\n",
bgp_peers[i].update_routes6 = 1;
LOG(4, 0, 0, "Registered BGP route %s/%d\n",
/* flag established peers for update */
for (i = 0; i < BGP_NUM_PEERS; i++)
/* flag established peers for update */
for (i = 0; i < BGP_NUM_PEERS; i++)
- if (bgp_peers[i].state == Established)
+ if (bgp_peers[i].state == Established
+ && bgp_peers[i].mp_handling == HandleIPv6Routes)
bgp_peers[i].update_routes6 = 1;
LOG(4, 0, 0, "Removed BGP route %s/%d\n",
bgp_peers[i].update_routes6 = 1;
LOG(4, 0, 0, "Removed BGP route %s/%d\n",
param_offset < data.opt_len;
param_offset += 2 + param->len)
{
param_offset < data.opt_len;
param_offset += 2 + param->len)
{
- param = (struct bgp_opt_param *)(&data.opt_params + param_offset);
+ param = (struct bgp_opt_param *)((char *)&data.opt_params + param_offset);
/* sensible check */
if (data.opt_len - param_offset < 2
/* sensible check */
if (data.opt_len - param_offset < 2
capabilities_len = param->len;
capabilities = (char *)¶m->value;
capabilities_len = param->len;
capabilities = (char *)¶m->value;
- /* look for BGP multiprotocol capability */
- if (capabilities)
- {
+ /* look for BGP multiprotocol capability */
for (capability_offset = 0;
capability_offset < capabilities_len;
capability_offset += 2 + capability->len)
for (capability_offset = 0;
capability_offset < capabilities_len;
capability_offset += 2 + capability->len)
peer->mp_handling = HandleIPv6Routes;
}
}
peer->mp_handling = HandleIPv6Routes;
}
}
+ if (peer->mp_handling != HandleIPv6Routes)
+ {
+ peer->mp_handling = DoesntHandleIPv6Routes;
+ if (config->ipv6_prefix.s6_addr[0])
+ LOG(1, 0, 0, "Warning: BGP peer %s doesn't handle IPv6 prefixes updates\n",
+ peer->name);
+ }
+
/* next transition requires an exchange of keepalives */
bgp_send_keepalive(peer);
}
/* next transition requires an exchange of keepalives */
bgp_send_keepalive(peer);
}
/* if we know peer doesn't support MP (mp_handling == DoesntHandleIPv6Routes)
then don't add this parameter */
/* if we know peer doesn't support MP (mp_handling == DoesntHandleIPv6Routes)
then don't add this parameter */
- if (peer->mp_handling == HandlingUnknown
- || peer->mp_handling == HandleIPv6Routes)
+ if (config->ipv6_prefix.s6_addr[0]
+ && (peer->mp_handling == HandlingUnknown
+ || peer->mp_handling == HandleIPv6Routes))
{
/* construct the param and capability */
cap_mp_ipv6.code = BGP_CAP_CODE_MP;
{
/* construct the param and capability */
cap_mp_ipv6.code = BGP_CAP_CODE_MP;