]> git.puffer.fish Git - mirror/frr.git/log
mirror/frr.git
8 months agobgpd: add json support for BGP L3NHG values 16631/head
Philippe Guibert [Thu, 22 Aug 2024 14:53:55 +0000 (16:53 +0200)]
bgpd: add json support for BGP L3NHG values

Some json attributes are missing for L3NHG values.

> PE1# show bgp vrf all detail
> [..]
> Instance vrf-purple:
> BGP table version is 1, local router ID is 27.3.0.85, vrf id 7
> Default local pref 100, local AS 65000
> BGP routing table entry for fe80::4620:ff:feff:ff01/128, version 1
> Paths: (1 available, best #1, vrf vrf-purple)
>   Not advertised to any peer
>   Imported from 10.30.30.30:5:[2]:[0]:[48]:[44:20:00:ff:ff:01]:[128]:[fe80::4620:ff:feff:ff01], VNI 4000  Local
>     ::ffff:a1e:1e1e (metric 20) from 10.30.30.30 (10.30.30.30) announce-nh-self
>       Origin IGP, localpref 100, valid, internal, best (First path received)
>       Extended Community: RT:65000:4000 ET:8
>       Last update: Thu Aug 22 18:23:38 2024
>
> Displayed 1 routes and 1 total paths

> PE1# show bgp vrf all json detail
> {
> "vrf-purple":{
>  "vrfId": 7,
>  "vrfName": "vrf-purple",
>  "tableVersion": 1,
>  "routerId": "27.3.0.85",
>  "defaultLocPrf": 100,
>  "localAS": 65000,
>  "routes": { "fe80::4620:ff:feff:ff01/128": [{"importedFrom":"10.30.30.30:5","l3nhg":false,"l3nhgActive":false, "vni": "4000",
> "aspath":{"string":"Local","segments":[],"length":0},"announceNexthopSelf":true,"origin":"IGP","locPrf":100,
> "valid":true,"version":1,"bestpath":{"overall":true,"selectionReason":"First path received"},
> "extendedCommunity":{"string":"RT:65000:4000 ET:8"},"lastUpdate":{"epoch":1724343817,
> "string":"Thu Aug 22 18:23:37 2024\n"},
> "nexthops":[{"ip":"::ffff:a1e:1e1e","hostname":"PE2","afi":"ipv6",
> "scope":"global","metric":20,"accessible":true,"used":true}],
> "peer":{"peerId":"10.30.30.30","routerId":"10.30.30.30","hostname":"PE2","type":"internal"}}]
>  }  }
> }

Signed-off-by: Philippe Guibert <philippe.guibert@6wind.com>
8 months agoMerge pull request #16546 from dmytroshytyi-6WIND/fix_bgp_open_notification_snmp
Donatas Abraitis [Thu, 22 Aug 2024 05:18:23 +0000 (07:18 +0200)]
Merge pull request #16546 from dmytroshytyi-6WIND/fix_bgp_open_notification_snmp

bgpd: fix, do not access peer->notify.data when it is null

8 months agoMerge pull request #16619 from qlyoung/fix-rtd-build-sphinx-environment-injection
Jafar Al-Gharaibeh [Thu, 22 Aug 2024 04:05:24 +0000 (00:05 -0400)]
Merge pull request #16619 from qlyoung/fix-rtd-build-sphinx-environment-injection

doc: update sphinx configs for RTD changes

8 months agodoc: update sphinx configs for RTD changes 16619/head
Quentin Young [Wed, 21 Aug 2024 23:38:09 +0000 (19:38 -0400)]
doc: update sphinx configs for RTD changes

Read The Docs made some changes that require us to add some
configuration in our build config files.

Signed-off-by: Quentin Young <qlyoung@qlyoung.net>
8 months agoMerge pull request #16608 from louis-6wind/fix-no-rpki
Donatas Abraitis [Wed, 21 Aug 2024 20:12:05 +0000 (22:12 +0200)]
Merge pull request #16608 from louis-6wind/fix-no-rpki

bgpd: fix crash at no rpki

8 months agotopotest: test_bgp_snmp_bgpv4v2_notification 16546/head
Dmytro Shytyi [Thu, 8 Aug 2024 13:42:40 +0000 (15:42 +0200)]
topotest: test_bgp_snmp_bgpv4v2_notification

This test checks the bgp crash on rt2 when 2 commands
launched consequently:
T0: rr, config -> router bgp 65004 -> neighbor 192.168.12.2 password 8888
T1: rt2, snmpwalk -v 2c -c public 127.0.0.1 .1.3.6.1.4.1.7336.4.2.1
T2: test if rt2 bgp is crashed.

Signed-off-by: Dmytro Shytyi <dmytro.shytyi@6wind.com>
8 months agobgpd: fix, do not access peer->notify.data when it is null
Dmytro Shytyi [Thu, 8 Aug 2024 13:53:11 +0000 (15:53 +0200)]
bgpd: fix, do not access peer->notify.data when it is null

bgp crash on rt2 spotted when 2 commands
launched consequently:
T0: rr, config -> router bgp 65004 -> neighbor 192.168.12.2 password
8888
T1: rt2, snmpwalk -v 2c -c public 127.0.0.1 .1.3.6.1.4.1.7336.4.2.1
T2: rt2 bgp is crashed.

config rt2-bgp:
---------------

!
debug bgp updates
!
router bgp 65002
 no bgp ebgp-requires-policy
 no bgp network import-check
 no bgp default ipv4-unicast
 neighbor 192.168.12.4 remote-as external
 neighbor 192.168.12.4 timers 1 3
 neighbor 192.168.12.4 timers connect 1
 neighbor 2001:db8::12:4 remote-as external
 neighbor 2001:db8::12:4 timers 1 3
 neighbor 2001:db8::12:4 timers connect 1
 !
 address-family ipv4 unicast
  neighbor 192.168.12.4 activate
  neighbor 192.168.12.4 addpath-tx-all-paths

 exit-address-family
 address-family ipv6 unicast
  neighbor 2001:db8::12:4 activate
 exit-address-family
!
agentx
!

config rt2-snmpd:
agentAddress 127.0.0.1,[::1]

group public_group v1 public
group public_group v2c public
access public_group "" any noauth prefix all all none

rocommunity public default

view all included .1

iquerySecName frr
rouser frr

master agentx

agentXSocket /etc/frr/agentx
agentXPerms 777 755 root frr

config rt2-zebra:
-----------------

!
interface r2-eth0
 ip address 192.168.12.2/24
 ipv6 address 2001:db8::12:2/64
!

config rr-bgpd:
---------------

!
debug bgp updates
!
router bgp 65004
 no bgp ebgp-requires-policy
 no bgp network import-check
 no bgp default ipv4-unicast
 neighbor 192.168.12.1 remote-as external
 neighbor 192.168.12.1 timers 1 3
 neighbor 192.168.12.1 timers connect 1
 neighbor 192.168.12.2 remote-as external
 neighbor 192.168.12.2 timers 1 3
 neighbor 192.168.12.2 timers connect 1
 neighbor 192.168.12.3 remote-as external
 neighbor 192.168.12.3 timers 1 3
 neighbor 192.168.12.3 timers connect 1
 neighbor 2001:db8::12:1 remote-as external
 neighbor 2001:db8::12:1 timers 1 3
 neighbor 2001:db8::12:1 timers connect 1
 neighbor 2001:db8::12:2 remote-as external
 neighbor 2001:db8::12:2 timers 1 3
 neighbor 2001:db8::12:2 timers connect 1
 neighbor 2001:db8::12:3 remote-as external
 neighbor 2001:db8::12:3 timers 1 3
 neighbor 2001:db8::12:3 timers connect 1
 !
 address-family ipv4 unicast
  neighbor 192.168.12.1 activate
  neighbor 192.168.12.1 addpath-tx-all-paths
  neighbor 192.168.12.1 route-server-client
  neighbor 192.168.12.2 activate
  neighbor 192.168.12.2 addpath-tx-all-paths
  neighbor 192.168.12.2 route-server-client
  neighbor 192.168.12.3 activate
  neighbor 192.168.12.3 addpath-tx-all-paths
  neighbor 192.168.12.3 route-server-client
 exit-address-family
 address-family ipv6 unicast
  neighbor 2001:db8::12:1 activate
  neighbor 2001:db8::12:1 route-server-client
  neighbor 2001:db8::12:2 activate
  neighbor 2001:db8::12:2 route-server-client
  neighbor 2001:db8::12:3 activate
  neighbor 2001:db8::12:3 route-server-client
 exit-address-family
!
agentx
!

config rr-zebra:
----------------
!
interface rr-eth0
 ip address 192.168.12.4/24
 ipv6 address 2001:db8::12:4/64
!

Fixes: 2d8fff6b81bb ("bgpd: Implement BGP4V2-MIB(bgp4V2PeerErrorsTable)")
Signed-off-by: Dmytro Shytyi <dmytro.shytyi@6wind.com>
8 months agobgpd: fix crash at no rpki 16608/head
Louis Scalbert [Tue, 20 Aug 2024 08:33:30 +0000 (10:33 +0200)]
bgpd: fix crash at no rpki

When 'no rpki' is requested and the rtrlib RPKI object was freed, bgpd
is crashing.

RPKI is configured in VRF red.

> ip l set red down
> ip l del red
> printf 'conf\n vrf red\n no rpki' | vtysh

> Core was generated by `/usr/bin/bgpd -A 127.0.0.1 -M snmp -M rpki -M bmp'.
> Program terminated with signal SIGSEGV, Segmentation fault.
> #0  __pthread_kill_implementation (no_tid=0, signo=11, threadid=140411103615424) at ./nptl/pthread_kill.c:44
> 44 ./nptl/pthread_kill.c: No such file or directory.
> [Current thread is 1 (Thread 0x7fb401f419c0 (LWP 190226))]
> (gdb) bt
> #0  __pthread_kill_implementation (no_tid=0, signo=11, threadid=140411103615424) at ./nptl/pthread_kill.c:44
> #1  __pthread_kill_internal (signo=11, threadid=140411103615424) at ./nptl/pthread_kill.c:78
> #2  __GI___pthread_kill (threadid=140411103615424, signo=signo@entry=11) at ./nptl/pthread_kill.c:89
> #3  0x00007fb4021ad476 in __GI_raise (sig=11) at ../sysdeps/posix/raise.c:26
> #4  0x00007fb4025ce22b in core_handler (signo=11, siginfo=0x7fff831b2d70, context=0x7fff831b2c40) at lib/sigevent.c:248
> #5  <signal handler called>
> #6  rtr_mgr_remove_group (config=0x55fe8789f750, preference=11) at /build/make-pkg/output/source/DIST_RTRLIB/rtrlib/rtrlib/rtr_mgr.c:607
> #7  0x00007fb40145f518 in rpki_delete_all_cache_nodes (rpki_vrf=0x55fe8789f4f0) at bgpd/bgp_rpki.c:442
> #8  0x00007fb401463098 in no_rpki_magic (self=0x7fb40146bba0 <no_rpki_cmd>, vty=0x55fe877f5130, argc=2, argv=0x55fe877fccd0) at bgpd/bgp_rpki.c:1732
> #9  0x00007fb40145c09a in no_rpki (self=0x7fb40146bba0 <no_rpki_cmd>, vty=0x55fe877f5130, argc=2, argv=0x55fe877fccd0) at ./bgpd/bgp_rpki_clippy.c:37
> #10 0x00007fb402527abc in cmd_execute_command_real (vline=0x55fe877fd150, vty=0x55fe877f5130, cmd=0x0, up_level=0) at lib/command.c:984
> #11 0x00007fb402527c35 in cmd_execute_command (vline=0x55fe877fd150, vty=0x55fe877f5130, cmd=0x0, vtysh=0) at lib/command.c:1043
> #12 0x00007fb4025281e5 in cmd_execute (vty=0x55fe877f5130, cmd=0x55fe877fb8c0 "no rpki\n", matched=0x0, vtysh=0) at lib/command.c:1209
> #13 0x00007fb4025f0aed in vty_command (vty=0x55fe877f5130, buf=0x55fe877fb8c0 "no rpki\n") at lib/vty.c:615
> #14 0x00007fb4025f2a11 in vty_execute (vty=0x55fe877f5130) at lib/vty.c:1378
> #15 0x00007fb4025f513d in vtysh_read (thread=0x7fff831b5fa0) at lib/vty.c:2373
> #16 0x00007fb4025e9611 in event_call (thread=0x7fff831b5fa0) at lib/event.c:2011
> #17 0x00007fb402566976 in frr_run (master=0x55fe871a14a0) at lib/libfrr.c:1212
> #18 0x000055fe857829fa in main (argc=9, argv=0x7fff831b6218) at bgpd/bgp_main.c:549

Fixes: 8156765abe ("bgpd: Add `no rpki` command")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
8 months agoMerge pull request #16597 from kprovost/master
Jafar Al-Gharaibeh [Mon, 19 Aug 2024 17:02:36 +0000 (13:02 -0400)]
Merge pull request #16597 from kprovost/master

zebra: fix loading kernel routes without netlink

8 months agoMerge pull request #16605 from donaldsharp/spelling_in_master_2
Mark Stapp [Mon, 19 Aug 2024 13:20:36 +0000 (09:20 -0400)]
Merge pull request #16605 from donaldsharp/spelling_in_master_2

Spelling in master 2

8 months agobgpd: Actually ensure the hash works 16605/head
Donald Sharp [Sun, 18 Aug 2024 20:26:45 +0000 (16:26 -0400)]
bgpd: Actually ensure the hash works

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agozebra: Do not assign time and then never use it
Donald Sharp [Sun, 18 Aug 2024 20:18:54 +0000 (16:18 -0400)]
zebra: Do not assign time and then never use it

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months ago*: Spelling issues
Donald Sharp [Sun, 18 Aug 2024 17:29:26 +0000 (13:29 -0400)]
*: Spelling issues

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16602 from LabNConsulting/chopps/fix-warnings
Donald Sharp [Sun, 18 Aug 2024 19:22:33 +0000 (15:22 -0400)]
Merge pull request #16602 from LabNConsulting/chopps/fix-warnings

mgmtd: fix a couple compilation warnings.

8 months agoMerge pull request #16603 from cscarpitta/fix/fix-compilation-warnings
Donald Sharp [Sun, 18 Aug 2024 17:34:12 +0000 (13:34 -0400)]
Merge pull request #16603 from cscarpitta/fix/fix-compilation-warnings

lib, zebra: Fix a couple compilation warnings

8 months agoMerge pull request #16601 from LabNConsulting/aceelindem/ospf-sa-warning-fix
Donald Sharp [Sun, 18 Aug 2024 16:49:12 +0000 (12:49 -0400)]
Merge pull request #16601 from LabNConsulting/aceelindem/ospf-sa-warning-fix

 ospfd: Fix SA warnings in ospf_packet.c and ospf_vty.c

8 months agoMerge pull request #16599 from anlancs/fix/pimd-limit-join
Donald Sharp [Sun, 18 Aug 2024 16:48:51 +0000 (12:48 -0400)]
Merge pull request #16599 from anlancs/fix/pimd-limit-join

pimd: fix missing checking the return value for igmp command

8 months agozebra: Fix compilation warning 16603/head
Carmine Scarpitta [Sun, 18 Aug 2024 11:02:06 +0000 (13:02 +0200)]
zebra: Fix compilation warning

Make sure the variable `srv6` is not NULL before dereferencing it.

Fixes the following compilation warnings:

```
error 15-Aug-2024 14:20:01 zebra/zebra_srv6_vty.c:974:8: warning: Access to field 'locators' results in a dereference of a null pointer (loaded from variable 'srv6') [core.NullDereference]
error 15-Aug-2024 14:20:01                 for (ALL_LIST_ELEMENTS_RO(srv6->locators, node, locator)) {
error 15-Aug-2024 14:20:01                      ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
error 15-Aug-2024 14:20:01 ./lib/linklist.h:345:11: note: expanded from macro 'ALL_LIST_ELEMENTS_RO'
error 15-Aug-2024 14:20:01         (node) = listhead(list), ((data) = NULL);                              \
error 15-Aug-2024 14:20:01                  ^~~~~~~~~~~~~~
error 15-Aug-2024 14:20:01 ./lib/linklist.h:63:22: note: expanded from macro 'listhead'
error 15-Aug-2024 14:20:01 #define listhead(X) ((X) ? ((X)->head) : NULL)
error 15-Aug-2024 14:20:01                      ^
```

Signed-off-by: Carmine Scarpitta <cscarpit@cisco.com>
8 months agolib: Fix compilation warning
Carmine Scarpitta [Sun, 18 Aug 2024 10:57:34 +0000 (12:57 +0200)]
lib: Fix compilation warning

Don't store unnecessary `len` returned by snprintf and snprintfrr function.

Fixes the following compilation warnings:

```
error 15-Aug-2024 13:54:10 In file included from lib/bfd.c:16:
error 15-Aug-2024 13:54:10 In file included from ./lib/zclient.h:22:
error 15-Aug-2024 13:54:10 In file included from ./lib/nexthop.h:14:
error 15-Aug-2024 13:54:10 ./lib/srv6.h:338:3: warning: Value stored to 'len' is never read [deadcode.DeadStores]
error 15-Aug-2024 13:54:10                 len += snprintf(str + len, size - len, " USP");
error 15-Aug-2024 13:54:10                 ^      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
error 15-Aug-2024 13:54:10 ./lib/srv6.h:343:3: warning: Value stored to 'len' is never read [deadcode.DeadStores]
error 15-Aug-2024 13:54:10                 len += snprintfrr(str + len, size - len, " nh6 %pI6", &ctx->nh6);
error 15-Aug-2024 13:54:10                 ^      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
error 15-Aug-2024 13:54:10 ./lib/srv6.h:347:3: warning: Value stored to 'len' is never read [deadcode.DeadStores]
error 15-Aug-2024 13:54:10                 len += snprintfrr(str + len, size - len, " nh4 %pI4", &ctx->nh4);
error 15-Aug-2024 13:54:10                 ^      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
error 15-Aug-2024 13:54:10 ./lib/srv6.h:354:3: warning: Value stored to 'len' is never read [deadcode.DeadStores]
error 15-Aug-2024 13:54:10                 len += snprintf(str + len, size - len, " vrf_id %u",
error 15-Aug-2024 13:54:10                 ^      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
error 15-Aug-2024 13:54:10 ./lib/srv6.h:367:3: warning: Value stored to 'len' is never read [deadcode.DeadStores]
error 15-Aug-2024 13:54:10                 len += snprintf(str + len, size - len, " unknown(%s)", __func__);
error 15-Aug-2024 13:54:10                 ^      ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
```

Signed-off-by: Carmine Scarpitta <cscarpit@cisco.com>
8 months agomgmtd: fix a couple compilation warnings. 16602/head
Christian Hopps [Sun, 18 Aug 2024 10:33:29 +0000 (05:33 -0500)]
mgmtd: fix a couple compilation warnings.

Also an empty (thus non-replace) notify selectors message shouldn't
clear the selectors, it should just do nothing.

Signed-off-by: Christian Hopps <chopps@labn.net>
8 months ago ospfd: Fix SA warnings in ospf_packet.c and ospf_vty.c 16601/head
Acee [Fri, 16 Aug 2024 17:49:41 +0000 (13:49 -0400)]
 ospfd: Fix SA warnings in ospf_packet.c and ospf_vty.c

    Fix SA warnings in ospf_packet.c and ospf_vty.c. The former was
    introduced by commit ed480148844259b7e9e30ed92489cdf44085457e.

Signed-off-by: Acee <aceelindem@gmail.com>
8 months agopimd: fix missing checking the return value for igmp command 16599/head
anlan_cs [Thu, 15 Aug 2024 12:49:24 +0000 (20:49 +0800)]
pimd: fix missing checking the return value for igmp command

`gm_join_new()` will return NULL in the case of running out of
socket/file resources.  Just add the check for it.

Signed-off-by: anlan_cs <anlan_cs@tom.com>
8 months agozebra: fix loading kernel routs without netlink 16597/head
Kristof Provost [Thu, 15 Aug 2024 16:34:35 +0000 (18:34 +0200)]
zebra: fix loading kernel routs without netlink

Commit 605df8d44 zebra: Use zebra dplane for RTM link and addr broke loading of
kernel routes at startup for configurations without netlink.

It rearranged the startup sequence in zebra_ns_enable() to pass via
zebra_ns_startup_continue(), triggered through zebra_dplane_startup_stage()
calls. However, it neglected to make these calls in the non-netlink code path.
As a result zebra failed to load kernel routes at startup on platforms such
as FreeBSD.

Insert these calls so we run through all of the expected startup stages.

Signed-off-by: Kristof Provost <kprovost@netgate.com>
8 months agoMerge pull request #16590 from donaldsharp/spelling_in_master
Mark Stapp [Thu, 15 Aug 2024 18:42:11 +0000 (14:42 -0400)]
Merge pull request #16590 from donaldsharp/spelling_in_master

*: Fix spelling errors found

8 months agoMerge pull request #16589 from opensourcerouting/fix/remove_deprecated_confdate
Mark Stapp [Thu, 15 Aug 2024 17:45:38 +0000 (13:45 -0400)]
Merge pull request #16589 from opensourcerouting/fix/remove_deprecated_confdate

ospfd: Remove deprecated router_info_area_id_cmd

8 months agoMerge pull request #16586 from donaldsharp/fix_route_scale_startup
Mark Stapp [Thu, 15 Aug 2024 13:21:12 +0000 (09:21 -0400)]
Merge pull request #16586 from donaldsharp/fix_route_scale_startup

tests: Fix route_scale startup issues

8 months agoMerge pull request #16549 from opensourcerouting/fix/some_memory_optimizations_for_st...
Donald Sharp [Thu, 15 Aug 2024 13:20:41 +0000 (09:20 -0400)]
Merge pull request #16549 from opensourcerouting/fix/some_memory_optimizations_for_struct_attr

bgpd: Move evpn_overlay to a pointer

8 months ago*: Fix spelling errors found 16590/head
Donald Sharp [Wed, 14 Aug 2024 20:53:09 +0000 (16:53 -0400)]
*: Fix spelling errors found

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16585 from pguibert6WIND/prd_pretty_mt_fix
Donatas Abraitis [Thu, 15 Aug 2024 06:59:47 +0000 (08:59 +0200)]
Merge pull request #16585 from pguibert6WIND/prd_pretty_mt_fix

bgpd: fix memory type for static->prd_pretty

8 months agoospfd: Remove deprecated router_info_area_id_cmd 16589/head
Donatas Abraitis [Wed, 14 Aug 2024 20:16:39 +0000 (23:16 +0300)]
ospfd: Remove deprecated router_info_area_id_cmd

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agoMerge pull request #16578 from donaldsharp/more_memory_leaks_on_shutdown
Donatas Abraitis [Wed, 14 Aug 2024 20:09:39 +0000 (22:09 +0200)]
Merge pull request #16578 from donaldsharp/more_memory_leaks_on_shutdown

More memory leaks on shutdown

8 months agoMerge pull request #16583 from mjstapp/fix_all_proto_nhg
Donald Sharp [Wed, 14 Aug 2024 18:54:27 +0000 (14:54 -0400)]
Merge pull request #16583 from mjstapp/fix_all_proto_nhg

tests: add retries to nhg tests in all_proto_startup

8 months agoMerge pull request #16574 from donaldsharp/non_json_free_ptr
Donatas Abraitis [Wed, 14 Aug 2024 16:44:54 +0000 (18:44 +0200)]
Merge pull request #16574 from donaldsharp/non_json_free_ptr

bgpd: Free up non-freed json memory on function return

8 months agotests: Fix route_scale startup issues 16586/head
Donald Sharp [Wed, 14 Aug 2024 14:18:41 +0000 (10:18 -0400)]
tests: Fix route_scale startup issues

Upstream CI is frequently running into a situation where
the routes are not being installed.  These routes
start at the beginning and suddenly in the middle
they start working properly.

D   1.0.15.183/32 [150/0] via 192.168.0.1, r1-eth0 inactive, weight 1, 00:10:17
                          via 192.168.1.1, r1-eth1 inactive, weight 1, 00:10:17
D   1.0.15.184/32 [150/0] via 192.168.0.1, r1-eth0 inactive, weight 1, 00:10:17
                          via 192.168.1.1, r1-eth1 inactive, weight 1, 00:10:17
D   1.0.15.185/32 [150/0] via 192.168.0.1, r1-eth0 inactive, weight 1, 00:10:17
                          via 192.168.1.1, r1-eth1 inactive, weight 1, 00:10:17
D>* 1.0.15.186/32 [150/0] via 192.168.0.1, r1-eth0, weight 1, 00:10:17
  *                       via 192.168.1.1, r1-eth1, weight 1, 00:10:17
D>* 1.0.15.187/32 [150/0] via 192.168.0.1, r1-eth0, weight 1, 00:10:17
  *                       via 192.168.1.1, r1-eth1, weight 1, 00:10:17
D>* 1.0.15.188/32 [150/0] via 192.168.0.1, r1-eth0, weight 1, 00:10:17

Turning on some debugs showed that the failed installed routes are
trying to be matched against the default route.  Thus implying
all the connected routes for the test are not yet successfully
installed.  Let's modify the test(s) on startup to just ensure
that the connected routes are installed correctly.  I am no
longer seeing the problem after this change.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agobgpd: fix memory type for static->prd_pretty 16585/head
Philippe Guibert [Wed, 14 Aug 2024 13:36:36 +0000 (15:36 +0200)]
bgpd: fix memory type for static->prd_pretty

A crash happens when executing the following command:

> ubuntu2204hwe# conf
> ubuntu2204hwe(config)# router bgp 65500
> ubuntu2204hwe(config-router)#  !
> ubuntu2204hwe(config-router)#  address-family ipv4 unicast
> ubuntu2204hwe(config-router-af)#   sid vpn export auto
> ubuntu2204hwe(config-router-af)#  exit-address-family
> ubuntu2204hwe(config-router)#  !
> ubuntu2204hwe(config-router)#  address-family ipv4 vpn
> ubuntu2204hwe(config-router-af)#   network 4.4.4.4/32 rd 55:55 label 556
> ubuntu2204hwe(config-router-af)#   network 5.5.5.5/32 rd 662:33 label 232
> ubuntu2204hwe(config-router-af)#  exit-address-family
> ubuntu2204hwe(config-router)# exit
> ubuntu2204hwe(config)# !
> ubuntu2204hwe(config)# no router bgp

The crash analysis indicates a memory item has been freed.

> #6  0x000076066a629c15 in mt_count_free (mt=0x56b57be85e00 <MTYPE_BGP_NAME>, ptr=0x60200038b4f0)
>     at lib/memory.c:73
> #7  mt_count_free (ptr=0x60200038b4f0, mt=0x56b57be85e00 <MTYPE_BGP_NAME>) at lib/memory.c:69
> #8  qfree (mt=mt@entry=0x56b57be85e00 <MTYPE_BGP_NAME>, ptr=0x60200038b4f0) at lib/memory.c:129
> #9  0x000056b57bb09ce9 in bgp_free (bgp=<optimized out>) at bgpd/bgpd.c:4120
> #10 0x000056b57bb0aa73 in bgp_unlock (bgp=<optimized out>) at ./bgpd/bgpd.h:2513
> #11 peer_free (peer=0x62a000000200) at bgpd/bgpd.c:1313
> #12 0x000056b57bb0aca8 in peer_unlock_with_caller (name=<optimized out>, peer=<optimized out>)
>     at bgpd/bgpd.c:1344
> #13 0x000076066a6dbb2c in event_call (thread=thread@entry=0x7ffc8cae1d60) at lib/event.c:2011
> #14 0x000076066a60aa88 in frr_run (master=0x613000000040) at lib/libfrr.c:1214
> #15 0x000056b57b8b2c44 in main (argc=<optimized out>, argv=<optimized out>) at bgpd/bgp_main.c:543

Actually, the BGP_NAME item has not been used at allocation for
static->prd_pretty, and this results in reaching 0 quicker at bgp
deletion.

Fix this by reassigning MTYPE_BGP_NAME to prd_pretty.

Fixes: 16600df2c4f4 ("bgpd: fix show run of network route-distinguisher")
Signed-off-by: Philippe Guibert <philippe.guibert@6wind.com>
8 months agoMerge pull request #16579 from opensourcerouting/fix/bgpd_use_after_free_no_router_bgp
Donald Sharp [Wed, 14 Aug 2024 12:39:25 +0000 (08:39 -0400)]
Merge pull request #16579 from opensourcerouting/fix/bgpd_use_after_free_no_router_bgp

bgpd: Avoid use-after-free when doing `no router bgp` with auto created instances

8 months agotests: add retries to nhg tests in all_proto_startup 16583/head
Mark Stapp [Wed, 14 Aug 2024 12:37:00 +0000 (08:37 -0400)]
tests: add retries to nhg tests in all_proto_startup

The all_protocol_startup topotest needs to allow for some delay
between configuring nexthop-groups and their installation. Add
some wait periods in a couple of nhg test cases.

Signed-off-by: Mark Stapp <mjs@cisco.com>
8 months agobgpd: Avoid use-after-free when doing `no router bgp` with auto created instances 16579/head
Donatas Abraitis [Wed, 14 Aug 2024 07:16:01 +0000 (10:16 +0300)]
bgpd: Avoid use-after-free when doing `no router bgp` with auto created instances

```
==1145965==ERROR: AddressSanitizer: heap-use-after-free on address 0x6030007159c0 at pc 0x55ade8d962d1 bp 0x7ffec4ce74c0 sp 0x7ffec4ce74b0
READ of size 8 at 0x6030007159c0 thread T0
    0 0x55ade8d962d0 in no_router_bgp bgpd/bgp_vty.c:1701
    1 0x7efe5aed19ed in cmd_execute_command_real lib/command.c:1002
    2 0x7efe5aed1da3 in cmd_execute_command lib/command.c:1061
    3 0x7efe5aed2303 in cmd_execute lib/command.c:1227
    4 0x7efe5af6c023 in vty_command lib/vty.c:616
    5 0x7efe5af6d2d2 in vty_execute lib/vty.c:1379
    6 0x7efe5af77df2 in vtysh_read lib/vty.c:2374
    7 0x7efe5af64c9b in event_call lib/event.c:1996
    8 0x7efe5af03887 in frr_run lib/libfrr.c:1232
    9 0x55ade8cd9850 in main bgpd/bgp_main.c:555
    10 0x7efe5aa29d8f in __libc_start_call_main ../sysdeps/nptl/libc_start_call_main.h:58
    11 0x7efe5aa29e3f in __libc_start_main_impl ../csu/libc-start.c:392
    12 0x55ade8cdc314 in _start (/usr/lib/frr/bgpd+0x16f314)
```

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agoMerge pull request #16575 from donaldsharp/doc_address_sanitizer_stuff
Mark Stapp [Tue, 13 Aug 2024 18:18:40 +0000 (14:18 -0400)]
Merge pull request #16575 from donaldsharp/doc_address_sanitizer_stuff

doc: Add doc to show sysctl setting for Sanitizers

8 months agoMerge pull request #16576 from opensourcerouting/fix/free_opaque_data_of_route_entry
Donald Sharp [Tue, 13 Aug 2024 18:14:36 +0000 (14:14 -0400)]
Merge pull request #16576 from opensourcerouting/fix/free_opaque_data_of_route_entry

zebra: Do not forget to free opaque data for route entry

8 months agobabeld: Free up memory on shutdown 16578/head
Donald Sharp [Tue, 13 Aug 2024 18:12:05 +0000 (14:12 -0400)]
babeld: Free up memory on shutdown

a) call vector_delete on created vector on shutdown.
b) Call babel_clean_routing_process on shutdown

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agopbrd: Call vrf_terminate on shutdown
Donald Sharp [Tue, 13 Aug 2024 18:11:07 +0000 (14:11 -0400)]
pbrd: Call vrf_terminate on shutdown

Free up vrf memory on shutdown.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agozebra: Do not forget to free opaque data for route entry 16576/head
Donatas Abraitis [Tue, 13 Aug 2024 15:00:30 +0000 (18:00 +0300)]
zebra: Do not forget to free opaque data for route entry

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agoMerge pull request #16559 from donaldsharp/fix_python_warning
Donatas Abraitis [Tue, 13 Aug 2024 14:20:27 +0000 (16:20 +0200)]
Merge pull request #16559 from donaldsharp/fix_python_warning

tests: Fix bgp_duplicate_nexthop python warning

8 months agodoc: Add doc to show sysctl setting for Sanitizers 16575/head
Donald Sharp [Tue, 13 Aug 2024 12:58:29 +0000 (08:58 -0400)]
doc: Add doc to show sysctl setting for Sanitizers

In order to run the XXXX Sanitizers over the code as a developer
modern linux distro's require a specific sysctl.  Let's document
that so that people are aware of it.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agobgpd: Free up non-freed json memory on function return 16574/head
Donald Sharp [Tue, 13 Aug 2024 12:49:01 +0000 (08:49 -0400)]
bgpd: Free up non-freed json memory on function return

json_peers is allocated in the above if statement block
for json but is not freed in this code path.  Noticed
by running Address Sanitizer.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16558 from nabahr/pim_doc
Donald Sharp [Tue, 13 Aug 2024 12:47:27 +0000 (08:47 -0400)]
Merge pull request #16558 from nabahr/pim_doc

doc: Fix up pim user docs.

8 months agoMerge pull request #16557 from donaldsharp/pathd_shutdown_memory_leaks
Donatas Abraitis [Mon, 12 Aug 2024 20:45:32 +0000 (23:45 +0300)]
Merge pull request #16557 from donaldsharp/pathd_shutdown_memory_leaks

pathd: Cleanup shutdown memory leaks

8 months agoMerge pull request #16555 from donaldsharp/agentx_event_leak
Donatas Abraitis [Mon, 12 Aug 2024 20:45:14 +0000 (23:45 +0300)]
Merge pull request #16555 from donaldsharp/agentx_event_leak

lib: Fix memory leak in snmp on shutdown

8 months agodoc: Fix up pim user docs. 16558/head
Nathan Bahr [Mon, 12 Aug 2024 16:00:06 +0000 (16:00 +0000)]
doc: Fix up pim user docs.

Signed-off-by: Nathan Bahr <nbahr@atcorp.com>
8 months agotests: Fix bgp_duplicate_nexthop python warning 16559/head
Donald Sharp [Mon, 12 Aug 2024 17:55:26 +0000 (13:55 -0400)]
tests: Fix bgp_duplicate_nexthop python warning

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16534 from opensourcerouting/fix/start_ldpd_if_unified
Donald Sharp [Mon, 12 Aug 2024 14:25:54 +0000 (10:25 -0400)]
Merge pull request #16534 from opensourcerouting/fix/start_ldpd_if_unified

doc: Document on how to start specific daemons with unified config in topotests

8 months agopathd: Cleanup shutdown memory leaks 16557/head
Donald Sharp [Mon, 12 Aug 2024 14:14:31 +0000 (10:14 -0400)]
pathd: Cleanup shutdown memory leaks

Just some code to cleanup the shutdown memory leaks
that are in pathd.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agolib: Fix memory leak in snmp on shutdown 16555/head
Donald Sharp [Fri, 9 Aug 2024 18:50:59 +0000 (14:50 -0400)]
lib: Fix memory leak in snmp on shutdown

The events list is storing a `struct event *` allocated
as a MTYPE_TMP pointer, on shutdown ensure that it is
properly free'd up.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16439 from louis-6wind/fix-ipv4-mapped-ipv6
Donatas Abraitis [Mon, 12 Aug 2024 12:37:36 +0000 (15:37 +0300)]
Merge pull request #16439 from louis-6wind/fix-ipv4-mapped-ipv6

bgpd: fixes for ipv4 mapped ipv6 address

8 months agoMerge pull request #16545 from mjstapp/fix_isis_threeway
Donatas Abraitis [Mon, 12 Aug 2024 06:39:45 +0000 (09:39 +0300)]
Merge pull request #16545 from mjstapp/fix_isis_threeway

isisd: fix memory handling in isis_adj_process_threeway()

8 months agoMerge pull request #16556 from donaldsharp/mgmt_ignore
Donatas Abraitis [Mon, 12 Aug 2024 06:39:22 +0000 (09:39 +0300)]
Merge pull request #16556 from donaldsharp/mgmt_ignore

mgmtd: Add to .gitignore for mgmtd_testc program

8 months agoMerge pull request #16420 from pguibert6WIND/trap_rfc4382
Donatas Abraitis [Mon, 12 Aug 2024 06:38:58 +0000 (09:38 +0300)]
Merge pull request #16420 from pguibert6WIND/trap_rfc4382

bgpd: add bgp snmp traps rfc4382 command

8 months agoMerge pull request #16554 from donaldsharp/zebra_ensure_no_use_after_free
Donatas Abraitis [Mon, 12 Aug 2024 04:59:42 +0000 (07:59 +0300)]
Merge pull request #16554 from donaldsharp/zebra_ensure_no_use_after_free

zebra: Ensure non-equal id's are not same nhg's

8 months agobgpd, doc: add bgp snmp traps rfc4382 command 16420/head
Philippe Guibert [Thu, 18 Jul 2024 12:43:45 +0000 (14:43 +0200)]
bgpd, doc: add bgp snmp traps rfc4382 command

Add a trap command to disable or enable the traps defined by
the RFC4382.

Signed-off-by: Philippe Guibert <philippe.guibert@6wind.com>
8 months agobgpd: Move evpn_overlay to a pointer 16549/head
Donatas Abraitis [Sun, 11 Aug 2024 10:59:13 +0000 (13:59 +0300)]
bgpd: Move evpn_overlay to a pointer

Before this convertion:

```
/* --- cacheline 3 boundary (192 bytes) --- */
struct bgp_attr_encap_subtlv * encap_subtlvs;    /*   192     8 */
struct bgp_attr_encap_subtlv * vnc_subtlvs;      /*   200     8 */
struct bgp_route_evpn      evpn_overlay;         /*   208    36 */
```

After this convertion:

```
/* --- cacheline 3 boundary (192 bytes) --- */
struct bgp_attr_encap_subtlv * encap_subtlvs;    /*   192     8 */
struct bgp_attr_encap_subtlv * vnc_subtlvs;      /*   200     8 */
struct bgp_route_evpn *    evpn_overlay;         /*   208     8 */
```

Saving 28 bytes when EVPN is not used.

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agodoc: Document on how to run specific daemons with unified config in topotests 16534/head
Donatas Abraitis [Sun, 11 Aug 2024 10:47:08 +0000 (13:47 +0300)]
doc: Document on how to run specific daemons with unified config in topotests

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agotests: Convert self.unified_config to boolean
Donatas Abraitis [Sun, 11 Aug 2024 09:51:53 +0000 (12:51 +0300)]
tests: Convert self.unified_config to boolean

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agoMerge pull request #16542 from donaldsharp/vtysh_stupidly_large
Donatas Abraitis [Sun, 11 Aug 2024 08:43:46 +0000 (11:43 +0300)]
Merge pull request #16542 from donaldsharp/vtysh_stupidly_large

lib: Don't print warning if not a daemon

8 months agomgmtd: Add to .gitignore for mgmtd_testc program 16556/head
Donald Sharp [Sun, 11 Aug 2024 00:21:27 +0000 (20:21 -0400)]
mgmtd: Add to .gitignore for mgmtd_testc program

This program, mgmtd_testc, is built with the
--enable-mgmtd-test-be-client configure option
but it is not .gitignore'd.  Let's fix that

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16548 from opensourcerouting/fix/reduce_attr_a_bit
Donald Sharp [Sat, 10 Aug 2024 23:51:10 +0000 (19:51 -0400)]
Merge pull request #16548 from opensourcerouting/fix/reduce_attr_a_bit

Shrink a couple bytes of struct attr

8 months agoMerge pull request #16551 from idryzhov/distrib-del
Donald Sharp [Sat, 10 Aug 2024 23:50:26 +0000 (19:50 -0400)]
Merge pull request #16551 from idryzhov/distrib-del

lib: fix distribute-list deletion

8 months agozebra: Ensure non-equal id's are not same nhg's 16554/head
Donald Sharp [Sat, 10 Aug 2024 23:43:08 +0000 (19:43 -0400)]
zebra: Ensure non-equal id's are not same nhg's

The function zebra_nhg_hash_equal is only used
as a hash function for storage of NHG's and retrieval.
If you have say two nhg's:

31 (25/26)
32 (25/26)

This function would return them as being equal.  Which
of course leads to the problem when you attempt to
hash_release 32 but release 31 from the hash.  Then later
when you attempt to do hash comparisons 32 has actually
been freed leaving to use after free situations and shit
goes down hill fast.

This hash is only used as part of the hash comparison
function for nexthop group storage.  Since this is so
let's always return the 31/32 nhg's are not equal at all.

We possibly have a different problem where we are creating
31 and 32 ( when 31 should have just been used instead of 32 )
but we need to prevent any type of hash release problem at all.
This supercedes any other issue( that should be tracked down
on it's own ).  Since you can have use after free situation
that leads to a crash -vs- some possible nexthop group duplication
which is very minor in comparison.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16529 from idryzhov/fix-load-config
Christian Hopps [Sat, 10 Aug 2024 08:10:34 +0000 (04:10 -0400)]
Merge pull request #16529 from idryzhov/fix-load-config

mgmtd: don't add implicit state data when reading config from file

8 months agoMerge pull request #16511 from oplklum/master
Christian Hopps [Sat, 10 Aug 2024 07:46:11 +0000 (03:46 -0400)]
Merge pull request #16511 from oplklum/master

Fix LYD_NEW_PATH_OUTPUT issue to support libyang v3.x

8 months agolib: Fix LYD_NEW_PATH_OUTPUT issue to support libyang v3.x 16511/head
Lu.Mao [Thu, 1 Aug 2024 01:54:14 +0000 (09:54 +0800)]
lib: Fix LYD_NEW_PATH_OUTPUT issue to support libyang v3.x

Fix the LYD_NEW_PATH_OUTPUT undeclared error to support the latest libyang v3.x version,
and also compatible with old version.

Signed-off-by: Lu Mao <lu.mao@molex.com>
8 months agolib: fix distribute-list deletion 16551/head
Igor Ryzhov [Fri, 9 Aug 2024 22:32:55 +0000 (01:32 +0300)]
lib: fix distribute-list deletion

When a whole distribute-list is deleted (can be done only using API),
all its children must be cleaned up manually.

Fixes #16538

Signed-off-by: Igor Ryzhov <idryzhov@gmail.com>
8 months agobgpd: Shrink rmap_change_flags to 2-bytes 16548/head
Donatas Abraitis [Fri, 9 Aug 2024 13:33:52 +0000 (16:33 +0300)]
bgpd: Shrink rmap_change_flags to 2-bytes

4 bytes is not needed for this thing clearly.

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agobgpd: Reduce encap_tunneltype to 1 byte
Donatas Abraitis [Fri, 9 Aug 2024 13:32:02 +0000 (16:32 +0300)]
bgpd: Reduce encap_tunneltype to 1 byte

It's not used as a bitmask, no point to use it as 2 bytes.

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agoisisd: fix memory handling in isis_adj_process_threeway() 16545/head
Mark Stapp [Fri, 9 Aug 2024 14:08:21 +0000 (10:08 -0400)]
isisd: fix memory handling in isis_adj_process_threeway()

The adj_process_threeway() api may call the adj_state_change()
api, which may delete the adj struct being examined. Change the
signature so that callers pass a ptr-to-ptr so that they will
see that deletion.

Signed-off-by: Mark Stapp <mjs@cisco.com>
8 months agoMerge pull request #16539 from donaldsharp/tests_memory_shut
Donatas Abraitis [Fri, 9 Aug 2024 10:30:30 +0000 (13:30 +0300)]
Merge pull request #16539 from donaldsharp/tests_memory_shut

Tests memory shut

8 months agoMerge pull request #16535 from pguibert6WIND/srv6_nexthop_context
Donatas Abraitis [Thu, 8 Aug 2024 19:39:34 +0000 (22:39 +0300)]
Merge pull request #16535 from pguibert6WIND/srv6_nexthop_context

lib: add seg6localContext json attribute in nexthop information

8 months agolib: Don't print warning if not a daemon 16542/head
Donald Sharp [Thu, 8 Aug 2024 18:58:04 +0000 (14:58 -0400)]
lib: Don't print warning if not a daemon

vtysh will print out the `stupidly large FD limit` upon
every run of the program if the ulimit is set stupidly
large.  Prevent this from being displayed for vtysh.

Fixes: #16516
Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16531 from idryzhov/fix-rip-show-distrib
Donald Sharp [Thu, 8 Aug 2024 18:28:32 +0000 (14:28 -0400)]
Merge pull request #16531 from idryzhov/fix-rip-show-distrib

ripd: fix show run output for distribute-list

8 months agoisisd, lib: Cleanup linked list associated with snmp 16539/head
Donald Sharp [Thu, 8 Aug 2024 18:04:42 +0000 (14:04 -0400)]
isisd, lib: Cleanup linked list associated with snmp

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agolib: Cleanup memory associated with modules on shutdown
Donald Sharp [Thu, 8 Aug 2024 17:54:12 +0000 (13:54 -0400)]
lib: Cleanup memory associated with modules on shutdown

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoisisd: Free up isis master list of instances
Donald Sharp [Thu, 8 Aug 2024 17:52:37 +0000 (13:52 -0400)]
isisd: Free up isis master list of instances

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoisisd: Cleanup leaked hash on shut in circuit
Donald Sharp [Thu, 8 Aug 2024 17:17:42 +0000 (13:17 -0400)]
isisd: Cleanup leaked hash on shut in circuit

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoisisd: Free up memory associated with rm/vrf's
Donald Sharp [Thu, 8 Aug 2024 17:09:34 +0000 (13:09 -0400)]
isisd: Free up memory associated with rm/vrf's

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agosharpd: Eliminate leaked list for locator-chunks
Donald Sharp [Thu, 8 Aug 2024 16:01:14 +0000 (12:01 -0400)]
sharpd: Eliminate leaked list for locator-chunks

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
8 months agoMerge pull request #16526 from opensourcerouting/fix/invalid_escape_chars_frr-reload.py
Jafar Al-Gharaibeh [Thu, 8 Aug 2024 16:31:48 +0000 (12:31 -0400)]
Merge pull request #16526 from opensourcerouting/fix/invalid_escape_chars_frr-reload.py

tools: Fix python string escape warnings for frr-reload.py

8 months agoMerge pull request #16530 from idryzhov/fix-no-distrib-crash
Donald Sharp [Thu, 8 Aug 2024 12:22:18 +0000 (08:22 -0400)]
Merge pull request #16530 from idryzhov/fix-no-distrib-crash

lib: fix crash on distribute-list delete

8 months agolib: add seg6localContext json attribute in nexthop information 16535/head
Philippe Guibert [Thu, 8 Aug 2024 08:05:45 +0000 (10:05 +0200)]
lib: add seg6localContext json attribute in nexthop information

Some srv6 behaviors have a context attached that is visible if
no json is requested:

> # show ipv6 route
> [..]
> B>* 2001:db8:1:1:100::/128 [20/0] is directly connected, vrf10, seg6local End.DT6 table 10, weight 1, 00:00:14
> B>* 2001:db8:1:1:200::/128 [20/0] is directly connected, vrf20, seg6local End.DT6 table 20, weight 1, 00:00:14
>

The json does not dump this attribute:
> # show ipv6 route 2001:db8:1:1:100::/128 json
> [..]
>      "nexthops":[
>        {
>          "flags":3,
>          "fib":true,
>          "directlyConnected":true,
>          "interfaceIndex":6,
>          "interfaceName":"vrf10",
>          "active":true,
>          "weight":1,
>          "seg6local":{
>            "action":"End.DT6"
>          },
>        }
>

Add the json support for this.

>      "nexthops":[
>        {
>          "flags":3,
>          "fib":true,
>          "directlyConnected":true,
>          "interfaceIndex":6,
>          "interfaceName":"vrf10",
>          "active":true,
>          "weight":1,
>          "seg6local":{
>            "action":"End.DT6"
>          },
>          "seg6localContext":{
>            "table":10
>          }
>        }
>

Signed-off-by: Philippe Guibert <philippe.guibert@6wind.com>
8 months agotools: Fix python string escape warnings for frr-reload.py 16526/head
Donatas Abraitis [Wed, 7 Aug 2024 14:46:57 +0000 (17:46 +0300)]
tools: Fix python string escape warnings for frr-reload.py

When using a regex (or anything that uses `\?` escapes) in python, raw
strings (`r"content"`) should be used so python doesn't consume the
escapes itself.  Otherwise we get either broken behavior and/or
`SyntaxWarning: invalid escape sequence '\['`

Fixes: 8916953b534f64a7545860ad5b4b36dc2544f33a ("build: fix a few python string escape warnings")
Fixes: https://github.com/FRRouting/frr/issues/16522
Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agoripd: fix show run output for distribute-list 16531/head
Igor Ryzhov [Wed, 7 Aug 2024 22:25:02 +0000 (01:25 +0300)]
ripd: fix show run output for distribute-list

CLI show callbacks should be defined in frr_ripd_cli_info instead of
frr_ripd_info, because only the former is loaded by mgmtd and only its
callbacks are getting called for config output.

Signed-off-by: Igor Ryzhov <idryzhov@gmail.com>
8 months agolib: fix crash on distribute-list delete 16530/head
Igor Ryzhov [Wed, 7 Aug 2024 22:17:11 +0000 (01:17 +0300)]
lib: fix crash on distribute-list delete

The destroy callback must be executed only once on APPLY stage.

Fixes #16528

Signed-off-by: Igor Ryzhov <idryzhov@gmail.com>
8 months agoMerge pull request #16525 from opensourcerouting/fix/remove_BGP_UPDATE_DELAY_MINMAX
Donald Sharp [Wed, 7 Aug 2024 22:10:56 +0000 (18:10 -0400)]
Merge pull request #16525 from opensourcerouting/fix/remove_BGP_UPDATE_DELAY_MINMAX

bgpd: Remove BGP_UPDATE_DELAY_MIN/MAX

8 months agomgmtd: don't add implicit state data when reading config from file 16529/head
Igor Ryzhov [Wed, 7 Aug 2024 21:40:51 +0000 (00:40 +0300)]
mgmtd: don't add implicit state data when reading config from file

When mgmt reads configuration from file, it shouldn't add implicit state
data to the candidate datastore. Configuration datastores like candidate
should never store state, otherwise they fail validation.

Fixes #15814

Signed-off-by: Igor Ryzhov <idryzhov@gmail.com>
8 months agoMerge pull request #16523 from LabNConsulting/chopps/fix-mgmt-rpc-test
Donald Sharp [Wed, 7 Aug 2024 17:27:39 +0000 (13:27 -0400)]
Merge pull request #16523 from LabNConsulting/chopps/fix-mgmt-rpc-test

tests: wait for test client to connect before running test

8 months agobgpd: Remove BGP_UPDATE_DELAY_MIN/MAX 16525/head
Donatas Abraitis [Wed, 7 Aug 2024 14:39:28 +0000 (17:39 +0300)]
bgpd: Remove BGP_UPDATE_DELAY_MIN/MAX

Found randomly, and seems not used anymore.

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agotests: wait for test client to connect before running test 16523/head
Christian Hopps [Wed, 7 Aug 2024 13:27:57 +0000 (09:27 -0400)]
tests: wait for test client to connect before running test

Vtysh has been improved to startup very quickly this exposed a race in this
test, where the `clear ip rip...` command ran before the test client that
handles it had finished connecting to mgmtd. Add a retried check for the test
client being connected before issuing the `clear ip rip ...` test command.

Signed-off-by: Christian Hopps <chopps@labn.net>
8 months agoMerge pull request #16521 from opensourcerouting/fix/capability_toggles
Donald Sharp [Wed, 7 Aug 2024 13:24:48 +0000 (09:24 -0400)]
Merge pull request #16521 from opensourcerouting/fix/capability_toggles

bgpd: Clear previously allocated capabilities values before parsing a new OPEN

8 months agobgpd: Clear previously allocated capabilities values before parsing a new OPEN 16521/head
Donatas Abraitis [Tue, 6 Aug 2024 15:19:40 +0000 (18:19 +0300)]
bgpd: Clear previously allocated capabilities values before parsing a new OPEN

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
8 months agoMerge pull request #16501 from donaldsharp/preprocess_vtysh
Mark Stapp [Fri, 2 Aug 2024 11:27:04 +0000 (07:27 -0400)]
Merge pull request #16501 from donaldsharp/preprocess_vtysh

Preprocess vtysh

8 months agoMerge pull request #16510 from donaldsharp/test_timing_fixes
Jafar Al-Gharaibeh [Thu, 1 Aug 2024 16:45:09 +0000 (12:45 -0400)]
Merge pull request #16510 from donaldsharp/test_timing_fixes

Test timing fixes