diff options
| author | Donatas Abraitis <donatas@opensourcerouting.org> | 2023-10-20 17:49:18 +0300 | 
|---|---|---|
| committer | Mergify <37929162+mergify[bot]@users.noreply.github.com> | 2023-10-25 11:22:32 +0000 | 
| commit | 8ec1d39b2767b7f90b888645df75ab41e9923f7a (patch) | |
| tree | 6eead9e1cfe66c08e3be009f579ee505e8634198 /bgpd/bgp_attr.c | |
| parent | 42cae6e9bd5e779c4a62526cb744184e5fba8bb2 (diff) | |
bgpd: Handle MP_REACH_NLRI malformed packets with session reset
Avoid crashing bgpd.
```
(gdb)
bgp_mp_reach_parse (args=<optimized out>, mp_update=0x7fffffffe140) at bgpd/bgp_attr.c:2341
2341			stream_get(&attr->mp_nexthop_global, s, IPV6_MAX_BYTELEN);
(gdb)
stream_get (dst=0x7fffffffe1ac, s=0x7ffff0006e80, size=16) at lib/stream.c:320
320	{
(gdb)
321		STREAM_VERIFY_SANE(s);
(gdb)
323		if (STREAM_READABLE(s) < size) {
(gdb)
34	  return __builtin___memcpy_chk (__dest, __src, __len, __bos0 (__dest));
(gdb)
Thread 1 "bgpd" received signal SIGSEGV, Segmentation fault.
0x00005555556e37be in route_set_aspath_prepend (rule=0x555555aac0d0, prefix=0x7fffffffe050,
    object=0x7fffffffdb00) at bgpd/bgp_routemap.c:2282
2282		if (path->attr->aspath->refcnt)
(gdb)
```
With the configuration:
```
 neighbor 127.0.0.1 remote-as external
 neighbor 127.0.0.1 passive
 neighbor 127.0.0.1 ebgp-multihop
 neighbor 127.0.0.1 disable-connected-check
 neighbor 127.0.0.1 update-source 127.0.0.2
 neighbor 127.0.0.1 timers 3 90
 neighbor 127.0.0.1 timers connect 1
 address-family ipv4 unicast
  redistribute connected
  neighbor 127.0.0.1 default-originate
  neighbor 127.0.0.1 route-map RM_IN in
 exit-address-family
!
route-map RM_IN permit 10
 set as-path prepend 200
exit
```
Reported-by: Iggy Frankovic <iggyfran@amazon.com>
Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
(cherry picked from commit b08afc81c60607a4f736f418f2e3eb06087f1a35)
Diffstat (limited to 'bgpd/bgp_attr.c')
| -rw-r--r-- | bgpd/bgp_attr.c | 6 | 
1 files changed, 1 insertions, 5 deletions
diff --git a/bgpd/bgp_attr.c b/bgpd/bgp_attr.c index 7916233444..d92e4c55ed 100644 --- a/bgpd/bgp_attr.c +++ b/bgpd/bgp_attr.c @@ -2422,7 +2422,7 @@ int bgp_mp_reach_parse(struct bgp_attr_parser_args *args,  		mp_update->afi = afi;  		mp_update->safi = safi; -		return BGP_ATTR_PARSE_EOR; +		return bgp_attr_malformed(args, BGP_NOTIFY_UPDATE_MAL_ATTR, 0);  	}  	mp_update->afi = afi; @@ -3759,10 +3759,6 @@ enum bgp_attr_parse_ret bgp_attr_parse(struct peer *peer, struct attr *attr,  			goto done;  		} -		if (ret == BGP_ATTR_PARSE_EOR) { -			goto done; -		} -  		if (ret == BGP_ATTR_PARSE_ERROR) {  			flog_warn(EC_BGP_ATTRIBUTE_PARSE_ERROR,  				  "%s: Attribute %s, parse error", peer->host,  | 
