Skip to content

Commit

Permalink
bgpd:support tcp-mss for neighbor group
Browse files Browse the repository at this point in the history
Signed-off-by: hanyu.zly <[email protected]>
  • Loading branch information
zice312963205 committed Nov 6, 2024
1 parent 960462a commit b4dd73f
Show file tree
Hide file tree
Showing 7 changed files with 93 additions and 9 deletions.
2 changes: 1 addition & 1 deletion bgpd/bgp_vty.c
Original file line number Diff line number Diff line change
Expand Up @@ -18732,7 +18732,7 @@ static void bgp_config_write_peer_global(struct vty *vty, struct bgp *bgp,
}

/* TCP max segment size */
if (CHECK_FLAG(peer->flags, PEER_FLAG_TCP_MSS))
if (peergroup_flag_check(peer, PEER_FLAG_TCP_MSS))
vty_out(vty, " neighbor %s tcp-mss %d\n", addr, peer->tcp_mss);

/* passive */
Expand Down
56 changes: 53 additions & 3 deletions bgpd/bgpd.c
Original file line number Diff line number Diff line change
Expand Up @@ -3031,6 +3031,10 @@ static void peer_group2peer_config_copy(struct peer_group *group,
bgp_peer_configure_bfd(peer, false);
bgp_peer_config_apply(peer, group);
}
/* peer tcp-mss */
if (!CHECK_FLAG(peer->flags_override, PEER_FLAG_TCP_MSS)) {
PEER_ATTR_INHERIT(peer, group, tcp_mss);
}
}

/* Peer group's remote AS configuration. */
Expand Down Expand Up @@ -4796,6 +4800,7 @@ static const struct peer_flag_action peer_flag_action_list[] = {
{PEER_FLAG_AS_LOOP_DETECTION, 0, peer_change_none},
{PEER_FLAG_EXTENDED_LINK_BANDWIDTH, 0, peer_change_none},
{PEER_FLAG_LONESOUL, 0, peer_change_reset_out},
{PEER_FLAG_TCP_MSS, 0, peer_change_none},
{0, 0, 0}};

static const struct peer_flag_action peer_af_flag_action_list[] = {
Expand Down Expand Up @@ -6097,8 +6102,24 @@ void peer_port_unset(struct peer *peer)
*/
void peer_tcp_mss_set(struct peer *peer, uint32_t tcp_mss)
{
struct peer *member;
struct listnode *node, *nnode;

peer_flag_set(peer, PEER_FLAG_TCP_MSS);
peer->tcp_mss = tcp_mss;
SET_FLAG(peer->flags, PEER_FLAG_TCP_MSS);

if (!CHECK_FLAG(peer->sflags, PEER_STATUS_GROUP))
return;

for (ALL_LIST_ELEMENTS(peer->group->peer, node, nnode, member)) {
/* Skip peers with overridden configuration. */
if (CHECK_FLAG(member->flags_override, PEER_FLAG_TCP_MSS))
continue;

/* Set flag and configuration on peer-group member. */
SET_FLAG(member->flags, PEER_FLAG_TCP_MSS);
PEER_ATTR_INHERIT(member, peer->group, tcp_mss);
}
bgp_tcp_mss_set(peer);
}

Expand All @@ -6108,8 +6129,37 @@ void peer_tcp_mss_set(struct peer *peer, uint32_t tcp_mss)
*/
void peer_tcp_mss_unset(struct peer *peer)
{
UNSET_FLAG(peer->flags, PEER_FLAG_TCP_MSS);
peer->tcp_mss = 0;
struct peer *member;
struct listnode *node, *nnode;

/* Inherit configuration from peer-group if peer is member. */
if (peer_group_active(peer)) {
peer_flag_inherit(peer, PEER_FLAG_TCP_MSS);
PEER_ATTR_INHERIT(peer, peer->group, tcp_mss);
} else {
/* Otherwise remove flag and configuration from peer. */
peer_flag_unset(peer, PEER_FLAG_TCP_MSS);
peer->tcp_mss = 0;
}

/* Skip peer-group mechanics for regular peers. */
if (!CHECK_FLAG(peer->sflags, PEER_STATUS_GROUP)) {
return;
}

/*
* Remove flag and configuration from all peer-group members, unless
* they are explicitely overriding peer-group configuration.
*/
for (ALL_LIST_ELEMENTS(peer->group->peer, node, nnode, member)) {
/* Skip peers with overridden configuration. */
if (CHECK_FLAG(member->flags_override, PEER_FLAG_TCP_MSS))
continue;

/* Remove flag and configuration on peer-group member. */
UNSET_FLAG(member->flags, PEER_FLAG_TCP_MSS);
member->tcp_mss = 0;
}
bgp_tcp_mss_set(peer);
}

Expand Down
3 changes: 3 additions & 0 deletions tests/topotests/bgp_tcp_mss/r1/bgpd.conf
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
router bgp 65000
no bgp ebgp-requires-policy
neighbor aaa peer-group
neighbor aaa remote-as 65001
neighbor 192.168.254.2 peer-group aaa
neighbor 192.168.255.2 remote-as 65001
neighbor 192.168.255.2 timers 3 10
exit-address-family
Expand Down
3 changes: 3 additions & 0 deletions tests/topotests/bgp_tcp_mss/r1/zebra.conf
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,8 @@
interface r1-eth0
ip address 192.168.255.1/24
!
interface r1-eth1
ip address 192.168.254.1/24
!
ip forwarding
!
3 changes: 3 additions & 0 deletions tests/topotests/bgp_tcp_mss/r2/bgpd.conf
Original file line number Diff line number Diff line change
@@ -1,5 +1,8 @@
router bgp 65001
no bgp ebgp-requires-policy
neighbor aaa peer-group
neighbor aaa remote-as 65000
neighbor 192.168.254.1 peer-group aaa
neighbor 192.168.255.1 remote-as 65000
neighbor 192.168.255.1 timers 3 10
exit-address-family
Expand Down
3 changes: 3 additions & 0 deletions tests/topotests/bgp_tcp_mss/r2/zebra.conf
Original file line number Diff line number Diff line change
Expand Up @@ -2,5 +2,8 @@
interface r2-eth0
ip address 192.168.255.2/24
!
interface r2-eth1
ip address 192.168.254.2/24
!
ip forwarding
!
32 changes: 27 additions & 5 deletions tests/topotests/bgp_tcp_mss/test_bgp_tcp_mss.py
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,10 @@ def build_topo(tgen):
switch.add_link(tgen.gears["r1"])
switch.add_link(tgen.gears["r2"])

switch = tgen.add_switch("s2")
switch.add_link(tgen.gears["r1"])
switch.add_link(tgen.gears["r2"])


def setup_module(mod):
tgen = Topogen(build_topo, mod.__name__)
Expand Down Expand Up @@ -78,11 +82,15 @@ def test_bgp_tcp_mss():
router2 = tgen.gears["r2"]

def _bgp_converge(router):
output = json.loads(router.vtysh_cmd("show ip bgp neighbor 192.168.255.2 json"))
output = json.loads(router.vtysh_cmd("show ip bgp neighbor json"))
expected = {
"192.168.255.2": {
"bgpState": "Established",
"addressFamilyInfo": {"ipv4Unicast": {"acceptedPrefixCounter": 0}},
},
"192.168.254.2": {
"bgpState": "Established",
"addressFamilyInfo": {"ipv4Unicast": {"acceptedPrefixCounter": 0}},
}
}
return topotest.json_cmp(output, expected)
Expand All @@ -108,7 +116,7 @@ def _bgp_check_neighbor_tcp_mss(router, neigh):

logger.info("Check if neighbor sessions are up in {}".format(router1.name))
test_func = functools.partial(_bgp_converge, router1)
_, result = topotest.run_and_expect(test_func, None, count=15, wait=0.5)
_, result = topotest.run_and_expect(test_func, None, count=15, wait=1)
assert result is None, 'Failed to see BGP convergence in "{}"'.format(router1.name)

logger.info("BGP neighbor session is up in {}".format(router1.name))
Expand All @@ -117,19 +125,21 @@ def _bgp_check_neighbor_tcp_mss(router, neigh):
"Configure tcp-mss 500 on {} and reset the session".format(router1.name)
)
_bgp_conf_tcp_mss(router1, "65000", "192.168.255.2")
_bgp_conf_tcp_mss(router1, "65000", "aaa")
_bgp_clear_session(router1)

logger.info(
"Configure tcp-mss 500 on {} and reset the session".format(router2.name)
)
_bgp_conf_tcp_mss(router2, "65001", "192.168.255.1")
_bgp_conf_tcp_mss(router2, "65001", "aaa")
_bgp_clear_session(router2)

logger.info(
"Check if neighbor session is up after reset in {}".format(router1.name)
)
test_func = functools.partial(_bgp_converge, router1)
_, result = topotest.run_and_expect(test_func, None, count=15, wait=0.5)
_, result = topotest.run_and_expect(test_func, None, count=15, wait=1)
assert result is None, 'Failed to see BGP convergence after reset in "{}"'.format(
router1.name
)
Expand All @@ -138,7 +148,13 @@ def _bgp_check_neighbor_tcp_mss(router, neigh):
"Verify if TCP MSS value is synced with neighbor in {}".format(router1.name)
)
test_func = functools.partial(_bgp_check_neighbor_tcp_mss, router1, "192.168.255.2")
_, result = topotest.run_and_expect(test_func, None, count=10, wait=0.5)
_, result = topotest.run_and_expect(test_func, None, count=15, wait=1)
assert (
result is None
), 'Failed to sync TCP MSS value over BGP session in "{}"'.format(router1.name)

test_func = functools.partial(_bgp_check_neighbor_tcp_mss, router1, "192.168.254.2")
success, result = topotest.run_and_expect(test_func, None, count=15, wait=1)
assert (
result is None
), 'Failed to sync TCP MSS value over BGP session in "{}"'.format(router1.name)
Expand All @@ -148,7 +164,13 @@ def _bgp_check_neighbor_tcp_mss(router, neigh):
"Verify if TCP MSS value is synced with neighbor in {}".format(router2.name)
)
test_func = functools.partial(_bgp_check_neighbor_tcp_mss, router2, "192.168.255.1")
_, result = topotest.run_and_expect(test_func, None, count=10, wait=0.5)
_, result = topotest.run_and_expect(test_func, None, count=15, wait=1)
assert (
result is None
), 'Failed to sync TCP MSS value over BGP session in "{}"'.format(router2.name)

test_func = functools.partial(_bgp_check_neighbor_tcp_mss, router2, "192.168.254.1")
success, result = topotest.run_and_expect(test_func, None, count=15, wait=1)
assert (
result is None
), 'Failed to sync TCP MSS value over BGP session in "{}"'.format(router2.name)
Expand Down

0 comments on commit b4dd73f

Please sign in to comment.