mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-25 18:30:04 +00:00
Merge commit '9ff5257357d9975654279db17bbc8525583ba1cc' into integrated
Conflicts: proto/ospf/config.Y
This commit is contained in:
commit
c02ed79eb4
@ -2212,7 +2212,10 @@ protocol ospf <name> {
|
|||||||
<tag>neighbors { <m/set/ } </tag>
|
<tag>neighbors { <m/set/ } </tag>
|
||||||
A set of neighbors to which Hello messages on NBMA or PtMP
|
A set of neighbors to which Hello messages on NBMA or PtMP
|
||||||
networks are to be sent. For NBMA networks, some of them
|
networks are to be sent. For NBMA networks, some of them
|
||||||
could be marked as eligible.
|
could be marked as eligible. In OSPFv3, link-local addresses
|
||||||
|
should be used, using global ones is possible, but it is
|
||||||
|
nonstandard and might be problematic. And definitely,
|
||||||
|
link-local and global addresses should not be mixed.
|
||||||
|
|
||||||
</descrip>
|
</descrip>
|
||||||
|
|
||||||
|
@ -120,7 +120,7 @@ CF_KEYWORDS(GLOBAL, LSID, ROUTER, SELF, INSTANCE, REAL)
|
|||||||
|
|
||||||
%type <t> opttext
|
%type <t> opttext
|
||||||
%type <ld> lsadb_args
|
%type <ld> lsadb_args
|
||||||
%type <i> ospf_proto_key
|
%type <i> ospf_proto_key nbma_eligible
|
||||||
|
|
||||||
CF_GRAMMAR
|
CF_GRAMMAR
|
||||||
|
|
||||||
@ -286,7 +286,7 @@ ospf_iface_item:
|
|||||||
| STUB bool { OSPF_PATT->stub = $2 ; }
|
| STUB bool { OSPF_PATT->stub = $2 ; }
|
||||||
| CHECK LINK bool { OSPF_PATT->check_link = $3; }
|
| CHECK LINK bool { OSPF_PATT->check_link = $3; }
|
||||||
| ECMP WEIGHT expr { OSPF_PATT->ecmp_weight = $3 - 1; if (($3<1) || ($3>256)) cf_error("ECMP weight must be in range 1-256"); }
|
| ECMP WEIGHT expr { OSPF_PATT->ecmp_weight = $3 - 1; if (($3<1) || ($3>256)) cf_error("ECMP weight must be in range 1-256"); }
|
||||||
| NEIGHBORS '{' ipa_list '}'
|
| NEIGHBORS '{' nbma_list '}'
|
||||||
| AUTHENTICATION NONE { OSPF_PATT->autype = OSPF_AUTH_NONE; }
|
| AUTHENTICATION NONE { OSPF_PATT->autype = OSPF_AUTH_NONE; }
|
||||||
| AUTHENTICATION SIMPLE { OSPF_PATT->autype = OSPF_AUTH_SIMPLE; ospf_check_auth(); }
|
| AUTHENTICATION SIMPLE { OSPF_PATT->autype = OSPF_AUTH_SIMPLE; ospf_check_auth(); }
|
||||||
| AUTHENTICATION CRYPTOGRAPHIC { OSPF_PATT->autype = OSPF_AUTH_CRYPT; ospf_check_auth(); }
|
| AUTHENTICATION CRYPTOGRAPHIC { OSPF_PATT->autype = OSPF_AUTH_CRYPT; ospf_check_auth(); }
|
||||||
@ -318,34 +318,25 @@ pref_opt:
|
|||||||
| TAG expr { this_pref->tag = $2; }
|
| TAG expr { this_pref->tag = $2; }
|
||||||
;
|
;
|
||||||
|
|
||||||
ipa_list:
|
nbma_list:
|
||||||
/* empty */
|
/* empty */
|
||||||
| ipa_list ipa_item
|
| nbma_list nbma_item
|
||||||
;
|
;
|
||||||
|
|
||||||
ipa_item:
|
nbma_eligible:
|
||||||
ipa_el
|
/* empty */ { $$ = 0; }
|
||||||
| ipa_ne;
|
| ELIGIBLE { $$ = 1; }
|
||||||
|
;
|
||||||
|
|
||||||
ipa_el: ipa ';'
|
nbma_item: ipa nbma_eligible ';'
|
||||||
{
|
{
|
||||||
this_nbma = cfg_allocz(sizeof(struct nbma_node));
|
this_nbma = cfg_allocz(sizeof(struct nbma_node));
|
||||||
add_tail(&OSPF_PATT->nbma_list, NODE this_nbma);
|
add_tail(&OSPF_PATT->nbma_list, NODE this_nbma);
|
||||||
this_nbma->ip=$1;
|
this_nbma->ip=$1;
|
||||||
this_nbma->eligible=0;
|
this_nbma->eligible=$2;
|
||||||
}
|
}
|
||||||
;
|
;
|
||||||
|
|
||||||
ipa_ne: ipa ELIGIBLE ';'
|
|
||||||
{
|
|
||||||
this_nbma = cfg_allocz(sizeof(struct nbma_node));
|
|
||||||
add_tail(&OSPF_PATT->nbma_list, NODE this_nbma);
|
|
||||||
this_nbma->ip=$1;
|
|
||||||
this_nbma->eligible=1;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
|
|
||||||
|
|
||||||
ospf_iface_start:
|
ospf_iface_start:
|
||||||
{
|
{
|
||||||
this_ipatt = cfg_allocz(sizeof(struct ospf_iface_patt));
|
this_ipatt = cfg_allocz(sizeof(struct ospf_iface_patt));
|
||||||
|
@ -567,8 +567,20 @@ ospf_iface_new(struct ospf_area *oa, struct ifa *addr, struct ospf_iface_patt *i
|
|||||||
init_list(&ifa->nbma_list);
|
init_list(&ifa->nbma_list);
|
||||||
|
|
||||||
WALK_LIST(nb, ip->nbma_list)
|
WALK_LIST(nb, ip->nbma_list)
|
||||||
if (ipa_in_net(nb->ip, addr->prefix, addr->pxlen))
|
{
|
||||||
|
/* In OSPFv3, addr is link-local while configured neighbors could
|
||||||
|
have global IP (although RFC 5340 C.5 says link-local addresses
|
||||||
|
should be used). Because OSPFv3 iface is not subnet-specific,
|
||||||
|
there is no need for ipa_in_net() check */
|
||||||
|
|
||||||
|
if (ospf_is_v2(po) && !ipa_in_net(nb->ip, addr->prefix, addr->pxlen))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (ospf_is_v3(po) && !ipa_has_link_scope(nb->ip))
|
||||||
|
log(L_WARN "In OSPFv3, configured neighbor address (%I) should be link-local", nb->ip);
|
||||||
|
|
||||||
add_nbma_node(ifa, nb, 0);
|
add_nbma_node(ifa, nb, 0);
|
||||||
|
}
|
||||||
|
|
||||||
ifa->state = OSPF_IS_DOWN;
|
ifa->state = OSPF_IS_DOWN;
|
||||||
add_tail(&oa->po->iface_list, NODE ifa);
|
add_tail(&oa->po->iface_list, NODE ifa);
|
||||||
@ -758,9 +770,13 @@ ospf_iface_reconfigure(struct ospf_iface *ifa, struct ospf_iface_patt *new)
|
|||||||
/* NBMA LIST - add new */
|
/* NBMA LIST - add new */
|
||||||
WALK_LIST(nb, new->nbma_list)
|
WALK_LIST(nb, new->nbma_list)
|
||||||
{
|
{
|
||||||
if (!ipa_in_net(nb->ip, ifa->addr->prefix, ifa->addr->pxlen))
|
/* See related note in ospf_iface_new() */
|
||||||
|
if (ospf_is_v2(po) && !ipa_in_net(nb->ip, ifa->addr->prefix, ifa->addr->pxlen))
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
|
if (ospf_is_v3(po) && !ipa_has_link_scope(nb->ip))
|
||||||
|
log(L_WARN "In OSPFv3, configured neighbor address (%I) should be link-local", nb->ip);
|
||||||
|
|
||||||
if (! find_nbma_node(ifa, nb->ip))
|
if (! find_nbma_node(ifa, nb->ip))
|
||||||
{
|
{
|
||||||
OSPF_TRACE(D_EVENTS, "Adding NBMA neighbor %I on interface %s",
|
OSPF_TRACE(D_EVENTS, "Adding NBMA neighbor %I on interface %s",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user