]> git.proxmox.com Git - mirror_frr.git/blobdiff - bgpd/bgp_updgrp_packet.c
Merge pull request #12513 from Pdoijode/master
[mirror_frr.git] / bgpd / bgp_updgrp_packet.c
index 9de97cf06003221d899aa7e8acd324adf7fd0055..346a3e7806ca21068a5cba85218c929f2ff5480a 100644 (file)
@@ -379,10 +379,11 @@ struct stream *bpacket_reformat_for_peer(struct bpacket *pkt,
 
                route_map_sets_nh =
                        (CHECK_FLAG(vec->flags,
-                                   BPKT_ATTRVEC_FLAGS_RMAP_IPV4_NH_CHANGED)
-                        || CHECK_FLAG(
-                                vec->flags,
-                                BPKT_ATTRVEC_FLAGS_RMAP_NH_PEER_ADDRESS));
+                                   BPKT_ATTRVEC_FLAGS_RMAP_IPV4_NH_CHANGED) ||
+                        CHECK_FLAG(vec->flags,
+                                   BPKT_ATTRVEC_FLAGS_RMAP_VPNV4_NH_CHANGED) ||
+                        CHECK_FLAG(vec->flags,
+                                   BPKT_ATTRVEC_FLAGS_RMAP_NH_PEER_ADDRESS));
 
                switch (nhlen) {
                case BGP_ATTR_NHLEN_IPV4:
@@ -468,10 +469,12 @@ struct stream *bpacket_reformat_for_peer(struct bpacket *pkt,
 
                route_map_sets_nh =
                        (CHECK_FLAG(vec->flags,
-                                   BPKT_ATTRVEC_FLAGS_RMAP_IPV6_GNH_CHANGED)
-                        || CHECK_FLAG(
+                                   BPKT_ATTRVEC_FLAGS_RMAP_IPV6_GNH_CHANGED) ||
+                        CHECK_FLAG(
                                 vec->flags,
-                                BPKT_ATTRVEC_FLAGS_RMAP_NH_PEER_ADDRESS));
+                                BPKT_ATTRVEC_FLAGS_RMAP_VPNV6_GNH_CHANGED) ||
+                        CHECK_FLAG(vec->flags,
+                                   BPKT_ATTRVEC_FLAGS_RMAP_NH_PEER_ADDRESS));
 
                /*
                 * The logic here is rather similar to that for IPv4, the
@@ -1069,6 +1072,9 @@ void subgroup_default_update_packet(struct update_subgroup *subgrp,
        safi_t safi;
        struct bpacket_attr_vec_arr vecarr;
        bool addpath_capable = false;
+       uint8_t default_originate_label[4] = {0x80, 0x00, 0x00};
+       mpls_label_t *label = NULL;
+       uint32_t num_labels = 0;
 
        if (DISABLE_BGP_ANNOUNCE)
                return;
@@ -1082,6 +1088,11 @@ void subgroup_default_update_packet(struct update_subgroup *subgrp,
        bpacket_attr_vec_arr_reset(&vecarr);
        addpath_capable = bgp_addpath_encode_tx(peer, afi, safi);
 
+       if (safi == SAFI_LABELED_UNICAST) {
+               label = (mpls_label_t *)default_originate_label;
+               num_labels = 1;
+       }
+
        memset(&p, 0, sizeof(p));
        p.family = afi2family(afi);
        p.prefixlen = 0;
@@ -1124,9 +1135,9 @@ void subgroup_default_update_packet(struct update_subgroup *subgrp,
        pos = stream_get_endp(s);
        stream_putw(s, 0);
        total_attr_len = bgp_packet_attribute(
-               NULL, peer, s, attr, &vecarr, &p, afi, safi, from, NULL, NULL,
-               0, addpath_capable, BGP_ADDPATH_TX_ID_FOR_DEFAULT_ORIGINATE,
-               NULL);
+               NULL, peer, s, attr, &vecarr, &p, afi, safi, from, NULL, label,
+               num_labels, addpath_capable,
+               BGP_ADDPATH_TX_ID_FOR_DEFAULT_ORIGINATE, NULL);
 
        /* Set Total Path Attribute Length. */
        stream_putw_at(s, pos, total_attr_len);
@@ -1276,6 +1287,15 @@ bpacket_vec_arr_inherit_attr_flags(struct bpacket_attr_vec_arr *vecarr,
                SET_FLAG(vecarr->entries[BGP_ATTR_VEC_NH].flags,
                         BPKT_ATTRVEC_FLAGS_RMAP_IPV6_GNH_CHANGED);
 
+       if (CHECK_FLAG(attr->rmap_change_flags, BATTR_RMAP_VPNV4_NHOP_CHANGED))
+               SET_FLAG(vecarr->entries[BGP_ATTR_VEC_NH].flags,
+                        BPKT_ATTRVEC_FLAGS_RMAP_VPNV4_NH_CHANGED);
+
+       if (CHECK_FLAG(attr->rmap_change_flags,
+                      BATTR_RMAP_VPNV6_GLOBAL_NHOP_CHANGED))
+               SET_FLAG(vecarr->entries[BGP_ATTR_VEC_NH].flags,
+                        BPKT_ATTRVEC_FLAGS_RMAP_VPNV6_GNH_CHANGED);
+
        if (CHECK_FLAG(attr->rmap_change_flags,
                       BATTR_RMAP_IPV6_LL_NHOP_CHANGED))
                SET_FLAG(vecarr->entries[BGP_ATTR_VEC_NH].flags,