From: Donatas Abraitis Date: Fri, 24 Mar 2023 07:55:23 +0000 (+0200) Subject: bgpd: Check 7 bytes for Long-lived Graceful-Restart capability X-Git-Tag: frr-8.4.4~37^2 X-Git-Url: https://git.puffer.fish/?a=commitdiff_plain;h=0d5069143974e5a8935a6e6889aef452c46dccd2;p=matthieu%2Ffrr.git bgpd: Check 7 bytes for Long-lived Graceful-Restart capability It's not 4 bytes, it was assuming the same as Graceful-Restart tuples. LLGR has more 3 bytes (Long-lived Stale Time). Signed-off-by: Donatas Abraitis (cherry picked from commit b1d33ec293e8e36fbb8766252f3b016d268e31ce) --- diff --git a/bgpd/bgp_open.c b/bgpd/bgp_open.c index d1667fac26..907e75e76b 100644 --- a/bgpd/bgp_open.c +++ b/bgpd/bgp_open.c @@ -599,12 +599,24 @@ static int bgp_capability_restart(struct peer *peer, static int bgp_capability_llgr(struct peer *peer, struct capability_header *caphdr) { +/* + * +--------------------------------------------------+ + * | Address Family Identifier (16 bits) | + * +--------------------------------------------------+ + * | Subsequent Address Family Identifier (8 bits) | + * +--------------------------------------------------+ + * | Flags for Address Family (8 bits) | + * +--------------------------------------------------+ + * | Long-lived Stale Time (24 bits) | + * +--------------------------------------------------+ + */ +#define BGP_CAP_LLGR_MIN_PACKET_LEN 7 struct stream *s = BGP_INPUT(peer); size_t end = stream_get_getp(s) + caphdr->length; SET_FLAG(peer->cap, PEER_CAP_LLGR_RCV); - while (stream_get_getp(s) + 4 <= end) { + while (stream_get_getp(s) + BGP_CAP_LLGR_MIN_PACKET_LEN <= end) { afi_t afi; safi_t safi; iana_afi_t pkt_afi = stream_getw(s);