/* must have nrli_len, what is left of the attribute */
nlri_len = LEN_LEFT;
- if ((!nlri_len) || (nlri_len > STREAM_READABLE(s))) {
+ if (nlri_len > STREAM_READABLE(s)) {
zlog_info("%s: (%s) Failed to read NLRI", __func__, peer->host);
return BGP_ATTR_PARSE_ERROR_NOTIFYPLS;
}
+ if (!nlri_len) {
+ zlog_info("%s: (%s) No Reachability, Treating as a EOR marker",
+ __func__, peer->host);
+
+ mp_update->afi = afi;
+ mp_update->safi = safi;
+ return BGP_ATTR_PARSE_EOR;
+ }
+
mp_update->afi = afi;
mp_update->safi = safi;
mp_update->nlri = stream_pnt(s);
ret = BGP_ATTR_PARSE_ERROR;
}
+ if (ret == BGP_ATTR_PARSE_EOR) {
+ if (as4_path)
+ aspath_unintern(&as4_path);
+ return ret;
+ }
+
/* If hard error occured immediately return to the caller. */
if (ret == BGP_ATTR_PARSE_ERROR) {
zlog_warn("%s: Attribute %s, parse error", peer->host,
/* only used internally, send notify + convert to BGP_ATTR_PARSE_ERROR
*/
BGP_ATTR_PARSE_ERROR_NOTIFYPLS = -3,
+ BGP_ATTR_PARSE_EOR = -4,
} bgp_attr_parse_ret_t;
struct bpacket_attr_vec_arr;
* Non-MP IPv4/Unicast EoR is a completely empty UPDATE
* and MP EoR should have only an empty MP_UNREACH
*/
- if (!update_len && !withdraw_len && nlris[NLRI_MP_UPDATE].length == 0) {
+ if ((!update_len && !withdraw_len &&
+ nlris[NLRI_MP_UPDATE].length == 0) ||
+ (attr_parse_ret == BGP_ATTR_PARSE_EOR)) {
afi_t afi = 0;
safi_t safi;
&& nlris[NLRI_MP_WITHDRAW].length == 0) {
afi = nlris[NLRI_MP_WITHDRAW].afi;
safi = nlris[NLRI_MP_WITHDRAW].safi;
+ } else if (attr_parse_ret == BGP_ATTR_PARSE_EOR) {
+ afi = nlris[NLRI_MP_UPDATE].afi;
+ safi = nlris[NLRI_MP_UPDATE].safi;
}
if (afi && peer->afc[afi][safi]) {