mirror of
https://gitlab.nic.cz/labs/bird.git
synced 2025-01-05 08:31:53 +00:00
Babel: Update RFC references
This commit is contained in:
parent
eefb296799
commit
501256cfc8
@ -1885,7 +1885,7 @@ protocol sections.
|
|||||||
<label id="babel-intro">
|
<label id="babel-intro">
|
||||||
|
|
||||||
<p>The Babel protocol
|
<p>The Babel protocol
|
||||||
(<rfc id="6126">) is a loop-avoiding distance-vector routing protocol that is
|
(<rfc id="8966">) is a loop-avoiding distance-vector routing protocol that is
|
||||||
robust and efficient both in ordinary wired networks and in wireless mesh
|
robust and efficient both in ordinary wired networks and in wireless mesh
|
||||||
networks. Babel is conceptually very simple in its operation and "just works"
|
networks. Babel is conceptually very simple in its operation and "just works"
|
||||||
in its default configuration, though some configuration is possible and in some
|
in its default configuration, though some configuration is possible and in some
|
||||||
|
@ -14,9 +14,8 @@
|
|||||||
/**
|
/**
|
||||||
* DOC: The Babel protocol
|
* DOC: The Babel protocol
|
||||||
*
|
*
|
||||||
* Babel (RFC6126) is a loop-avoiding distance-vector routing protocol that is
|
* The Babel is a loop-avoiding distance-vector routing protocol that is robust
|
||||||
* robust and efficient both in ordinary wired networks and in wireless mesh
|
* and efficient both in ordinary wired networks and in wireless mesh networks.
|
||||||
* networks.
|
|
||||||
*
|
*
|
||||||
* The Babel protocol keeps state for each neighbour in a &babel_neighbor
|
* The Babel protocol keeps state for each neighbour in a &babel_neighbor
|
||||||
* struct, tracking received Hello and I Heard You (IHU) messages. A
|
* struct, tracking received Hello and I Heard You (IHU) messages. A
|
||||||
@ -33,6 +32,12 @@
|
|||||||
* an entry is updated by receiving updates from the network or when modified by
|
* an entry is updated by receiving updates from the network or when modified by
|
||||||
* internal timers. The function selects from feasible and reachable routes the
|
* internal timers. The function selects from feasible and reachable routes the
|
||||||
* one with the lowest metric to be announced to the core.
|
* one with the lowest metric to be announced to the core.
|
||||||
|
*
|
||||||
|
* Supported standards:
|
||||||
|
* RFC 8966 - The Babel Routing Protocol
|
||||||
|
* RFC 8967 - MAC Authentication for Babel
|
||||||
|
* RFC 9079 - Source Specific Routing for Babel
|
||||||
|
* RFC 9229 - IPv4 Routes with IPv6 Next Hop for Babel
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
@ -294,7 +299,7 @@ babel_expire_routes(struct babel_proto *p)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Add seqno request to the table of pending requests (RFC 6216 3.2.6) and send
|
* Add seqno request to the table of pending requests (RFC 8966 3.2.6) and send
|
||||||
* it to network. Do nothing if it is already in the table.
|
* it to network. Do nothing if it is already in the table.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
@ -1022,7 +1027,7 @@ babel_send_update_(struct babel_iface *ifa, btime changed, struct fib *rtable)
|
|||||||
|
|
||||||
babel_enqueue(&msg, ifa);
|
babel_enqueue(&msg, ifa);
|
||||||
|
|
||||||
/* RFC 6126 3.7.3 - update feasibility distance for redistributed routes */
|
/* RFC 8966 3.7.3 - update feasibility distance for redistributed routes */
|
||||||
if (e->router_id != p->router_id)
|
if (e->router_id != p->router_id)
|
||||||
{
|
{
|
||||||
struct babel_source *s = babel_get_source(p, e, e->router_id, msg.update.seqno);
|
struct babel_source *s = babel_get_source(p, e, e->router_id, msg.update.seqno);
|
||||||
@ -1325,7 +1330,7 @@ babel_handle_update(union babel_msg *m, struct babel_iface *ifa)
|
|||||||
best = e->selected;
|
best = e->selected;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* RFC section 3.8.2.2 - Dealing with unfeasible updates. Generate a one-off
|
* RFC 8966 3.8.2.2 - dealing with unfeasible updates. Generate a one-off
|
||||||
* (not retransmitted) unicast seqno request to the originator of this update.
|
* (not retransmitted) unicast seqno request to the originator of this update.
|
||||||
* Note: !feasible -> s exists, check for 's' is just for clarity / safety.
|
* Note: !feasible -> s exists, check for 's' is just for clarity / safety.
|
||||||
*/
|
*/
|
||||||
@ -1370,7 +1375,7 @@ babel_handle_route_request(union babel_msg *m, struct babel_iface *ifa)
|
|||||||
struct babel_proto *p = ifa->proto;
|
struct babel_proto *p = ifa->proto;
|
||||||
struct babel_msg_route_request *msg = &m->route_request;
|
struct babel_msg_route_request *msg = &m->route_request;
|
||||||
|
|
||||||
/* RFC 6126 3.8.1.1 */
|
/* RFC 8966 3.8.1.1 */
|
||||||
|
|
||||||
/* Wildcard request - full update on the interface */
|
/* Wildcard request - full update on the interface */
|
||||||
if (msg->full)
|
if (msg->full)
|
||||||
@ -1428,7 +1433,7 @@ babel_handle_seqno_request(union babel_msg *m, struct babel_iface *ifa)
|
|||||||
struct babel_proto *p = ifa->proto;
|
struct babel_proto *p = ifa->proto;
|
||||||
struct babel_msg_seqno_request *msg = &m->seqno_request;
|
struct babel_msg_seqno_request *msg = &m->seqno_request;
|
||||||
|
|
||||||
/* RFC 6126 3.8.1.2 */
|
/* RFC 8966 3.8.1.2 */
|
||||||
|
|
||||||
TRACE(D_PACKETS, "Handling seqno request for %N router-id %lR seqno %d hop count %d",
|
TRACE(D_PACKETS, "Handling seqno request for %N router-id %lR seqno %d hop count %d",
|
||||||
&msg->net, msg->router_id, msg->seqno, msg->hop_count);
|
&msg->net, msg->router_id, msg->seqno, msg->hop_count);
|
||||||
|
Loading…
Reference in New Issue
Block a user