]> git.proxmox.com Git - mirror_frr.git/log
mirror_frr.git
14 months agoisisd: fix a memory leak in isis_spftree_clear()
Louis Scalbert [Thu, 27 Apr 2023 12:50:47 +0000 (14:50 +0200)]
isisd: fix a memory leak in isis_spftree_clear()

isis_spftree_clear() calls:
  - _isis_spftree_del() to partially delete a spftree instance
    without freeing spftree->route_table and
    spftree->route_table_backup.
  - then _isis_spftree_init() that allocates new spftree->route_table
    and spftree->route_table_backup.

As a consequence, the previous table instances are not referenced and
not freed.

Free the route tables before allocating new ones.

Fixes: 860b75b40e ("isisd: calculate flex-algo constraint spf")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd, lib: clarify sizeof on flex-algo memory allocation
Louis Scalbert [Thu, 27 Apr 2023 09:52:03 +0000 (11:52 +0200)]
isisd, lib: clarify sizeof on flex-algo memory allocation

Use the struct instead of the pointer for flex-algo memory allocation.

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: fix flex-algo data memory leak at algorithm removal
Louis Scalbert [Tue, 25 Apr 2023 11:08:21 +0000 (13:08 +0200)]
isisd: fix flex-algo data memory leak at algorithm removal

Fix a flex-algo data memory leak when a specific algorithm is removed.

Fixes: 7f198e063c ("isisd: add isis flex-algo base interface")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd, lib: fix flex-algo database memory leak at area destruction
Louis Scalbert [Mon, 24 Apr 2023 16:19:03 +0000 (18:19 +0200)]
isisd, lib: fix flex-algo database memory leak at area destruction

Free flex-algorithm database memory when an IS-IS area is destroyed.

Fixes: 735fb37db1 ("lib: add library for igp flexible-algorithm")
Fixes: 7f198e063c ("isisd: add isis flex-algo base interface")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agolib: dispatch flex_algo_delete()
Louis Scalbert [Thu, 27 Apr 2023 13:16:28 +0000 (15:16 +0200)]
lib: dispatch flex_algo_delete()

Dispatch flex_algo_delete() to prepare the next commit. Cosmetic change.

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agolib: move flex_algo_delete() just after flex_algo_alloc()
Louis Scalbert [Thu, 27 Apr 2023 13:11:42 +0000 (15:11 +0200)]
lib: move flex_algo_delete() just after flex_algo_alloc()

Move flex_algo_delete() just after flex_algo_alloc(). No change on code.

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agolib: clarify flex-algo mtype
Louis Scalbert [Thu, 27 Apr 2023 13:05:42 +0000 (15:05 +0200)]
lib: clarify flex-algo mtype

Clarify flex-algo MTYPE by creating a specific MTYPE definition to the
database of flex-algo information.

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoMerge pull request #13386 from donaldsharp/bgp_received_routes
Donatas Abraitis [Wed, 26 Apr 2023 08:07:00 +0000 (11:07 +0300)]
Merge pull request #13386 from donaldsharp/bgp_received_routes

bgpd: Fix `received-routes detail`

14 months agoMerge pull request #13368 from Keelan10/nhrpd-memory-leak
Donatas Abraitis [Wed, 26 Apr 2023 05:57:52 +0000 (08:57 +0300)]
Merge pull request #13368 from Keelan10/nhrpd-memory-leak

nhrpd: Fix nhrpd memory leak

14 months agobgpd: Fix `received-routes detail`
Donald Sharp [Tue, 25 Apr 2023 19:35:19 +0000 (15:35 -0400)]
bgpd: Fix `received-routes detail`

The command `show bgp ipv4 uni neigh A.B.C.D received-routes detail`
was not displaying anything.

Fix the code to display the received routes from the ones that
have been filtered.  In this case we need to fudge up a bgp_dest
and a bgp_path_info to make it work.

Old output:

janelle.pinkbelly.org# show bgp ipv4 uni neighbors 192.168.119.224 received-routes detail
BGP table version is 1711405, local router ID is 192.168.44.1, vrf id 0
Default local pref 100, local AS 64539

Total number of prefixes 3 (3 filtered)
janelle.pinkbelly.org#

New output:

janelle.pinkbelly.org# show bgp ipv4 uni neighbors 192.168.119.224 received-routes detail
BGP table version is 0, local router ID is 192.168.44.1, vrf id 0
Default local pref 100, local AS 64539
BGP routing table entry for 1.2.3.0/24, version 0
Paths: (1 available, no best path)
  Not advertised to any peer
  3291, (aggregated by 3291 192.168.122.1)
    192.168.119.224 (inaccessible, import-check enabled) from 192.168.119.224 (192.168.122.1)
      Origin IGP, metric 0, invalid, external, atomic-aggregate, rpki validation-state: not found
      Community: 55:66
      Last update: Fri Apr 14 08:46:48 2023
BGP routing table entry for 1.2.3.4/32, version 0
Paths: (1 available, no best path)
  Not advertised to any peer
  3291
    192.168.119.224 (inaccessible, import-check enabled) from 192.168.119.224 (192.168.122.1)
      Origin IGP, metric 0, invalid, external, rpki validation-state: not found
      Community: 33:44
      Last update: Fri Apr 14 08:46:48 2023
BGP routing table entry for 1.2.3.5/32, version 0
Paths: (1 available, no best path)
  Not advertised to any peer
  3291
    192.168.119.224 (inaccessible, import-check enabled) from 192.168.119.224 (192.168.122.1)
      Origin IGP, metric 0, invalid, external, rpki validation-state: not found
      Community: 33:44
      Last update: Fri Apr 14 08:46:48 2023

Total number of prefixes 3 (3 filtered)
janelle.pinkbelly.org# show bgp ipv4 uni
No BGP prefixes displayed, 0 exist
janelle.pinkbelly.org#

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agoMerge pull request #13374 from opensourcerouting/build-fix-rmap-yang
Mark Stapp [Tue, 25 Apr 2023 19:26:19 +0000 (15:26 -0400)]
Merge pull request #13374 from opensourcerouting/build-fix-rmap-yang

build: fix frr-if-rmap.yang model embedding

14 months agoMerge pull request #13246 from opensourcerouting/rip-bfd
Russ White [Tue, 25 Apr 2023 15:54:32 +0000 (11:54 -0400)]
Merge pull request #13246 from opensourcerouting/rip-bfd

ripd: support BFD integration

14 months agoMerge pull request #13326 from opensourcerouting/feature/rip_topotest_distribute_list
Russ White [Tue, 25 Apr 2023 15:07:31 +0000 (11:07 -0400)]
Merge pull request #13326 from opensourcerouting/feature/rip_topotest_distribute_list

ripd: Create non default passive interface if defined so

14 months agoMerge pull request #13310 from opensourcerouting/feature/bgpd_node_target_extended_co...
Russ White [Tue, 25 Apr 2023 15:06:23 +0000 (11:06 -0400)]
Merge pull request #13310 from opensourcerouting/feature/bgpd_node_target_extended_community

bgpd: Add Node Target Extended Communities support

14 months agoMerge pull request #13375 from LabNConsulting/chopps/fix-style-issues
Donald Sharp [Tue, 25 Apr 2023 11:28:46 +0000 (07:28 -0400)]
Merge pull request #13375 from LabNConsulting/chopps/fix-style-issues

lib: fix style warns and get rid of "!" for success

14 months agoMerge pull request #13373 from LabNConsulting/chopps/fix-pytestconfig
Donald Sharp [Mon, 24 Apr 2023 22:02:49 +0000 (18:02 -0400)]
Merge pull request #13373 from LabNConsulting/chopps/fix-pytestconfig

fix missed passing pytestconfig arg.

14 months agolib: fix style warns and get rid of "!" for success
Christian Hopps [Mon, 24 Apr 2023 15:20:48 +0000 (11:20 -0400)]
lib: fix style warns and get rid of "!" for success

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agobuild: fix frr-if-rmap.yang model embedding
David Lamparter [Mon, 24 Apr 2023 15:00:55 +0000 (17:00 +0200)]
build: fix frr-if-rmap.yang model embedding

This was missed somewhere along the line, causing ripd to not start.

Signed-off-by: David Lamparter <equinox@opensourcerouting.org>
14 months agoMerge pull request #13149 from pushpasis/mgmt_cleanup_zlog
Christian Hopps [Mon, 24 Apr 2023 15:00:08 +0000 (11:00 -0400)]
Merge pull request #13149 from pushpasis/mgmt_cleanup_zlog

mgmtd, lib: Cleanup zlog_err()

14 months agoMerge pull request #13330 from chiragshah6/fdev1
Donatas Abraitis [Mon, 24 Apr 2023 13:51:10 +0000 (16:51 +0300)]
Merge pull request #13330 from chiragshah6/fdev1

zebra: EVPN handle duplicate detected local mac delete event

14 months agotests: fix missed passing pytestconfig arg
Christian Hopps [Mon, 24 Apr 2023 13:22:42 +0000 (09:22 -0400)]
tests: fix missed passing pytestconfig arg

Remove the local ConfigOptionProxy and actually use the munet one.

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: import munet 0.13.2
Christian Hopps [Mon, 24 Apr 2023 13:47:23 +0000 (09:47 -0400)]
tests: import munet 0.13.2

fixed ConfigOptionsProxy bug

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agoMerge pull request #13365 from LabNConsulting/chopps/add-perf-option
Donald Sharp [Mon, 24 Apr 2023 11:38:45 +0000 (07:38 -0400)]
Merge pull request #13365 from LabNConsulting/chopps/add-perf-option

Add ability to profile daemons in topotest with --perf

14 months agoMerge pull request #13361 from LabNConsulting/chopps/munet-cfgopt-and-native
Donatas Abraitis [Mon, 24 Apr 2023 10:50:36 +0000 (13:50 +0300)]
Merge pull request #13361 from LabNConsulting/chopps/munet-cfgopt-and-native

cfgopt in munet and native config support and example

14 months agonhrpd: Fix nhrpd memory leak
Keelan10 [Mon, 24 Apr 2023 07:00:20 +0000 (11:00 +0400)]
nhrpd: Fix nhrpd memory leak

Free NHRP peers associated with an interface when NHS is deleted on shutdown

Signed-off-by: Keelan Cannoo <keelan.cannoo@icloud.com>
14 months agodoc: document --perf and --perf-options, and a bit of cleanup
Christian Hopps [Mon, 24 Apr 2023 01:56:38 +0000 (21:56 -0400)]
doc: document --perf and --perf-options, and a bit of cleanup

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: add --perf and --perf-options for profiling daemons
Christian Hopps [Mon, 24 Apr 2023 01:53:44 +0000 (21:53 -0400)]
tests: add --perf and --perf-options for profiling daemons

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agoMerge pull request #13350 from opensourcerouting/typesafe-fixes-20230421
Donald Sharp [Sun, 23 Apr 2023 19:06:59 +0000 (15:06 -0400)]
Merge pull request #13350 from opensourcerouting/typesafe-fixes-20230421

lib: typesafe shenanigans

14 months agotests: add an example of using munet native config
Christian Hopps [Sun, 23 Apr 2023 12:26:41 +0000 (08:26 -0400)]
tests: add an example of using munet native config

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: enable using munet native configs
Christian Hopps [Sun, 23 Apr 2023 12:25:51 +0000 (08:25 -0400)]
tests: enable using munet native configs

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: munet now supports cfgopt directly
Christian Hopps [Sun, 23 Apr 2023 13:17:35 +0000 (09:17 -0400)]
tests: munet now supports cfgopt directly

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: import munet version 0.13.1
Christian Hopps [Sun, 23 Apr 2023 05:29:49 +0000 (01:29 -0400)]
tests: import munet version 0.13.1

- adds more generic config option handling than pytestconfig
- Change to search order for kinds.yaml

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agoMerge pull request #13358 from zmw12306/ignore_nonzero_flags
Donald Sharp [Sun, 23 Apr 2023 11:25:30 +0000 (07:25 -0400)]
Merge pull request #13358 from zmw12306/ignore_nonzero_flags

14 months agoMerge pull request #13360 from LabNConsulting/chopps/munet-fixes
Donald Sharp [Sun, 23 Apr 2023 11:18:07 +0000 (07:18 -0400)]
Merge pull request #13360 from LabNConsulting/chopps/munet-fixes

14 months agotests: import munet version 0.12.16
Christian Hopps [Sun, 23 Apr 2023 05:29:49 +0000 (01:29 -0400)]
tests: import munet version 0.12.16

Fixes bad fixed path use and rootcmd functionality to run things
in the root namespace (all but pid at least).

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agoMerge pull request #13332 from LabNConsulting/chopps/new-opts
Donald Sharp [Sat, 22 Apr 2023 23:51:05 +0000 (19:51 -0400)]
Merge pull request #13332 from LabNConsulting/chopps/new-opts

14 months agobabeld: ignore nonzero flag bits in Hello TLVs
zmw12306 [Sat, 22 Apr 2023 19:11:13 +0000 (15:11 -0400)]
babeld: ignore nonzero flag bits in Hello TLVs

Ignore all other bits(except U) in Hello TLVs, according to RFC8966
Signed-off-by: zmw12306 <zmw12306@gmail.com>
14 months agodoc: document new pytest options and cli commands
Christian Hopps [Wed, 19 Apr 2023 09:40:54 +0000 (05:40 -0400)]
doc: document new pytest options and cli commands

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agomunet: import 0.12.15
Christian Hopps [Thu, 20 Apr 2023 23:21:59 +0000 (19:21 -0400)]
munet: import 0.12.15

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: fix ASAN file cleanup and --asan-abort option
Christian Hopps [Sat, 22 Apr 2023 16:59:53 +0000 (12:59 -0400)]
tests: fix ASAN file cleanup and --asan-abort option

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agoMerge pull request #13349 from opensourcerouting/pim6-mld-coverity-20230421
Donald Sharp [Sat, 22 Apr 2023 15:02:51 +0000 (11:02 -0400)]
Merge pull request #13349 from opensourcerouting/pim6-mld-coverity-20230421

pimd: address some static analysis complaints

14 months agotests: will need new pid_exists if using pid namespaces
Christian Hopps [Fri, 21 Apr 2023 13:28:50 +0000 (09:28 -0400)]
tests: will need new pid_exists if using pid namespaces

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: restore per-node logging functionality
Christian Hopps [Wed, 19 Apr 2023 11:57:42 +0000 (07:57 -0400)]
tests: restore per-node logging functionality

After the munet switch we weren't passing the logger on to low-level
LinuxNamespace and thus Commander parent classes, so the lowest-level
`cmd_status` logs were missing from more specific log files in the run
directory.

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: fix check for daemon startup, remove sleep hack
Christian Hopps [Sat, 22 Apr 2023 01:59:33 +0000 (21:59 -0400)]
tests: fix check for daemon startup, remove sleep hack

- Remove the .pid and .vty files and then wait for them to show back up.
- Fix broken BGP GR test to not fail now that it's bug is exposed. It
only worked b/c when starting a daemon the pid file still existed and
blocked the bogus second BGP launch from happening.

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: add --logd option
Christian Hopps [Wed, 19 Apr 2023 04:48:11 +0000 (00:48 -0400)]
tests: add --logd option

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: add --pcap and --pause-at-end options
Christian Hopps [Wed, 19 Apr 2023 04:40:48 +0000 (00:40 -0400)]
tests: add --pcap and --pause-at-end options

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: cleanup access to pytest config
Christian Hopps [Wed, 19 Apr 2023 08:55:04 +0000 (04:55 -0400)]
tests: cleanup access to pytest config

Rather than create a new global dict and copy all the config into it, just
expose the pytest config globally and use it directly.

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agotests: blacken re-format
Christian Hopps [Wed, 19 Apr 2023 08:20:45 +0000 (04:20 -0400)]
tests: blacken re-format

Signed-off-by: Christian Hopps <chopps@labn.net>
14 months agoMerge pull request #13347 from donaldsharp/bgp_before_light
David Lamparter [Fri, 21 Apr 2023 16:23:17 +0000 (18:23 +0200)]
Merge pull request #13347 from donaldsharp/bgp_before_light

14 months agoMerge pull request #13345 from donaldsharp/pim_after_dark
David Lamparter [Fri, 21 Apr 2023 16:22:39 +0000 (18:22 +0200)]
Merge pull request #13345 from donaldsharp/pim_after_dark

14 months agoMerge pull request #13348 from donaldsharp/dplane_before_after
David Lamparter [Fri, 21 Apr 2023 16:22:22 +0000 (18:22 +0200)]
Merge pull request #13348 from donaldsharp/dplane_before_after

14 months agolib: fix _hash_member() crash w/ empty hash
David Lamparter [Fri, 21 Apr 2023 14:23:39 +0000 (16:23 +0200)]
lib: fix _hash_member() crash w/ empty hash

The typesafe hash _member() didn't check tabshift/count before
proceeding to look at the hash table, leading it to dereference a NULL
pointer when the hash table is in fact empty.

Test case added to tests/lib/test_typelist.

Note this function is not currently used anywhere.  Only lib/cspf.c uses
_member(), but it does so on a RB-tree rather than a hash.

Signed-off-by: David Lamparter <equinox@opensourcerouting.org>
14 months agolib: typesafe hash table breadcrumbs
David Lamparter [Fri, 21 Apr 2023 14:15:11 +0000 (16:15 +0200)]
lib: typesafe hash table breadcrumbs

Looking at the coverity report, it complains that tabshift could be
zero, resulting in a uint32_t shifted by 33 (which is undefined.)

As I was confused by the "+ 1", in addition to the SA assume(), leave
some breadcumbs for next time this comes up.

Signed-off-by: David Lamparter <equinox@opensourcerouting.org>
14 months agoMerge pull request #13327 from opensourcerouting/fix/rip_status_align
Donald Sharp [Fri, 21 Apr 2023 13:41:00 +0000 (09:41 -0400)]
Merge pull request #13327 from opensourcerouting/fix/rip_status_align

ripd: Align show ip rip status output for sources

14 months agopimd: annotate some pointers as non-null
David Lamparter [Fri, 21 Apr 2023 13:25:25 +0000 (15:25 +0200)]
pimd: annotate some pointers as non-null

... make static analysis happy.

Signed-off-by: David Lamparter <equinox@opensourcerouting.org>
14 months agopimd: harden MLD code loop boundaries
David Lamparter [Fri, 21 Apr 2023 13:14:43 +0000 (15:14 +0200)]
pimd: harden MLD code loop boundaries

Coverity complains about these being tainted/untrusted loop boundaries.
The way the code works, it's counting up groups/sources, but keeps
checking against remaining data length in the packet - which is
perfectly fine IMHO.  Except Coverity doesn't understand it :(

Signed-off-by: David Lamparter <equinox@opensourcerouting.org>
14 months agolib: Make coverity happy about close
Donald Sharp [Fri, 21 Apr 2023 13:12:08 +0000 (09:12 -0400)]
lib: Make coverity happy about close

The error condition handled both failure to open
and a fstat failure.  Just double check that the close
is appropriate to call.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agozebra: ctx has to be non NULL at this point
Donald Sharp [Fri, 21 Apr 2023 12:54:51 +0000 (08:54 -0400)]
zebra: ctx has to be non NULL at this point

Remove the pointer check for ctx.  At this point in the
function it has to be non null since we deref'ed it.
Additionally the alloc function that creates it cannot
fail.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agobgpd: Ensure bgp_vrf is non-null
Donald Sharp [Fri, 21 Apr 2023 12:04:06 +0000 (08:04 -0400)]
bgpd: Ensure bgp_vrf is non-null

If we attempt to get the bgp_vrf and it fails then
ensure that we don't just de-ref and crash.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agobgpd: Coverity mistakenly believes we can fall through
Donald Sharp [Fri, 21 Apr 2023 11:57:19 +0000 (07:57 -0400)]
bgpd: Coverity mistakenly believes we can fall through

Coverity has incorrectly found that a switch statement
can be fallen through.  It is missing the fact that the
previous case statement has a return through every path
it can get too.  Let's just appease coverity

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agobgpd: All paths have already de-refed rd_str
Donald Sharp [Fri, 21 Apr 2023 11:54:00 +0000 (07:54 -0400)]
bgpd: All paths have already de-refed rd_str

Coverity points out that rd_str has already been
deref'ed in all paths leading to this spot.  No
need to keep at it.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agopimd: Tell coverity what is really going on
Donald Sharp [Fri, 21 Apr 2023 11:38:11 +0000 (07:38 -0400)]
pimd: Tell coverity what is really going on

Fix a code path that coverity has decided a variable
is NULL when it never can be.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agopimd: Fix possible null of pim instance
Donald Sharp [Fri, 21 Apr 2023 11:08:53 +0000 (07:08 -0400)]
pimd: Fix possible null of pim instance

Coverity shows a path where the pim instance may
be null.  In this code path if we have no pim
vrf there is nothing to do anyway so just return

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agoMerge pull request #13334 from louis-6wind/flexalgo-fixes
Olivier Dugeon [Fri, 21 Apr 2023 06:58:22 +0000 (08:58 +0200)]
Merge pull request #13334 from louis-6wind/flexalgo-fixes

isisd: fixes for Flex-Algo

14 months agoMerge pull request #13341 from donaldsharp/bgp_lcommunity_crash
Jafar Al-Gharaibeh [Fri, 21 Apr 2023 05:54:45 +0000 (00:54 -0500)]
Merge pull request #13341 from donaldsharp/bgp_lcommunity_crash

bgpd: Fix lcom->str string length to correctly cover aliases

14 months agozebra:fix evpn dup detected local mac del event
Chirag Shah [Sat, 22 Oct 2022 23:00:14 +0000 (16:00 -0700)]
zebra:fix evpn dup detected local mac del event

The current local mac delete event send to flag with force
always which breaks the duplicate detected MACs where
it requires to be resynced from bgpd to earlier state.

Ticket:#3233019
Issue:3233019

Signed-off-by: Chirag Shah <chirag@nvidia.com>
14 months agozebra: evpn handle del event for dup detected mac
Chirag Shah [Wed, 1 Dec 2021 04:42:01 +0000 (20:42 -0800)]
zebra: evpn handle del event for dup detected mac

Upon receiving local mobility event for MAC + NEIGH,
both are detected as duplicate upon hitting DAD threshold.

Duplicated detected ( freezed) MAC + NEIGH are not known
to bgpd.

If locally learnt MAC + NEIGH are deleted in kernel,
the MAC is marked as AUTO after sending delete event
to bgpd.

Bgpd only reinstalls best route for MAC_IP route (NEIGH)
but not for MAC event.
This puts a situation where MAC is AUTO state and
associated neigh as remote.

Fix:
DUPLICATE + LOCAL MAC deletion, set MAC delete request
as reinstall from bgpd.

Ticket:#2873307
Reviewed By:
Testing Done:

Freeze MAC + two NEIGHs in local mobility event.
Delete MAC and NEIGH from kerenl.
bgp rsync remote mac route which puts MAC to remote state.

Signed-off-by: Chirag Shah <chirag@nvidia.com>
14 months agobgpd: Fix lcom->str string length to correctly cover aliases
Donald Sharp [Thu, 20 Apr 2023 20:27:20 +0000 (16:27 -0400)]
bgpd: Fix lcom->str string length to correctly cover aliases

If you have a very large number of large communities whose
string length happened to be greater than BUFSIZ FRR's bgpd
would crash.  This is because bgpd would write beyond
the end of the string.

Originally the code auto-calculated the string size appropriately
but commit ed0e57e3f079352714c3a3a8a5b0dddf4aadfe1d modified
the string length to be a hard coded BUFSIZ.  When a route-map
like this is added:

route-map LARGE-OUT permit 10
 set large-community 4635:0:0 4635:1:906 4635:1:2906 4635:1:4515 4635:1:4594 4635:1:4641 4635:1:4760 4635:1:7979 4635:1:9253 4635:1:9293 4635:1:9304 4635:1:9908 4635:1:13335 4635:1:16265 4635:1:17924 4635:1:18013 4635:1:20940 4635:1:22822 4635:1:24429 4635:1:24482 4635:1:32590 4635:1:32934 4635:1:36692 4635:1:38008 4635:1:38819 4635:1:41378 4635:1:45753 4635:1:46489 4635:1:49544 4635:1:51847 4635:1:54574 4635:1:54994 4635:1:55720 4635:1:56059 4635:1:57724 4635:1:65021 4635:1:134823 4635:1:136907 4635:1:146961 24115:0:24115 24115:1:906 24115:1:2906 24115:1:4515 24115:1:4594 24115:1:4641 24115:1:4760 24115:1:7979 24115:1:9253 24115:1:9293 24115:1:9304 24115:1:9908 24115:1:13335 24115:1:16265 24115:1:17924 24115:1:18013 24115:1:20940 24115:1:22822 24115:1:24429 24115:1:24482 24115:1:32590 24115:1:32934 24115:1:36692 24115:1:38008 24115:1:38819 24115:1:41378 24115:1:45753 24115:1:46489 24115:1:49544 24115:1:51847 24115:1:54574 24115:1:54994 24115:1:55720 24115:1:56059 24115:1:57724 24115:1:65021 24115:1:134823 24115:1:136907 24115:1:100000 24115:1:100001 24115:1:100002
exit

BGP would have issues and crash.

Modify the code to correctly determine the string length of the communities
and to also double check if the string has an alias and ensure that the
string is still sufficiently large enough.  If not auto size it again.

Signed-off-by: Donald Sharp <sharpd@nvidia.com>
14 months agoMerge pull request #12933 from Orange-OpenSource/link_state
Philippe Guibert [Thu, 20 Apr 2023 16:33:21 +0000 (18:33 +0200)]
Merge pull request #12933 from Orange-OpenSource/link_state

lib: Update edge key in link state database

14 months agoisisd: fix add an algorithm argument to show isis route
Louis Scalbert [Tue, 18 Apr 2023 15:35:41 +0000 (17:35 +0200)]
isisd: fix add an algorithm argument to show isis route

"show isis route algorithm ALGO json" display some text output before
printing the JSON one.

Do not print the text output in JSON mode.

Fixes: 0833c25180 ("isisd: add an algorithm argument to show isis route")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: fix potential null pointer in isis_affinity_map_update()
Louis Scalbert [Wed, 19 Apr 2023 13:11:36 +0000 (15:11 +0200)]
isisd: fix potential null pointer in isis_affinity_map_update()

Reported by coverity scanner #1560315

Do not attempt to update the affinity map if the main isis struct is not
yet created.

Fixes: 9a65cf35da ("isisd: add affinity-map configuration hooks")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: fix wrong pointer test in area_resign_level()
Louis Scalbert [Wed, 19 Apr 2023 13:07:46 +0000 (15:07 +0200)]
isisd: fix wrong pointer test in area_resign_level()

Fix a wrong pointer test issue reported by coverity scanner #1560314

Fixes: 860b75b40e ("isisd: calculate flex-algo constraint spf")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: fix potential null pointer in isis_affinity_map_check_use()
Louis Scalbert [Wed, 19 Apr 2023 12:59:57 +0000 (14:59 +0200)]
isisd: fix potential null pointer in isis_affinity_map_check_use()

Reported by coverity scanner #1560313

Do not consider the affinity map is in use if the main isis struct is
not yet created.

Fixes: 9a65cf35da ("isisd: add affinity-map configuration hooks")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: fix overrun in isis_flex_algo_constraint_drop()
Louis Scalbert [Wed, 19 Apr 2023 12:49:58 +0000 (14:49 +0200)]
isisd: fix overrun in isis_flex_algo_constraint_drop()

Coverity scanner reported the overrun issue #1560312 because
reach->id length is 7 bytes and we are trying to copy 8 bytes
(ie. ISIS_SYS_ID_LEN + 2).

Fix the issue by using the %pPN to display directly the 7 bytes
system-id.

Fixes: 860b75b40e ("isisd: calculate flex-algo constraint spf")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agotests: Align `show ip rip status` output in tests
Donatas Abraitis [Wed, 19 Apr 2023 19:08:03 +0000 (22:08 +0300)]
tests: Align `show ip rip status` output in tests

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
14 months agoMerge pull request #13329 from Pdoijode/pdoijode/bgp-attr-crash-fix
Donatas Abraitis [Wed, 19 Apr 2023 18:48:34 +0000 (21:48 +0300)]
Merge pull request #13329 from Pdoijode/pdoijode/bgp-attr-crash-fix

bgpd: Fix for ain->attr corruption during path update

14 months agoMerge pull request #13166 from Jafaral/ospf-external-metric
Donatas Abraitis [Wed, 19 Apr 2023 18:11:25 +0000 (21:11 +0300)]
Merge pull request #13166 from Jafaral/ospf-external-metric

ospfd: use rib metric as the base for set metric +/-

14 months agodoc: RIP BFD integration documentation
Rafael Zalamena [Tue, 28 Mar 2023 18:41:56 +0000 (15:41 -0300)]
doc: RIP BFD integration documentation

Let users know about the RIP BFD integration commands and increment the
used RFCs reference.

Signed-off-by: Rafael Zalamena <rzalamena@opensourcerouting.org>
14 months agotopotests: RIP BFD integration topology test
Rafael Zalamena [Mon, 27 Mar 2023 21:12:39 +0000 (18:12 -0300)]
topotests: RIP BFD integration topology test

Add new RIP topology to test the BFD integration and RIP ECMP:
shutdown a link and expect the RIP route change immediately instead of
regular RIP timer.

Signed-off-by: Rafael Zalamena <rzalamena@opensourcerouting.org>
14 months agoripd: support BFD integration
Renato Westphal [Thu, 14 Oct 2021 15:12:37 +0000 (12:12 -0300)]
ripd: support BFD integration

Implement RIP peer monitoring with BFD.

RFC 5882 Generic Application of Bidirectional Forwarding Detection
(BFD), Section 10.3 Interactions with RIP.

Co-authored-by: Renato Westphal <renato@opensourcerouting.org>
Signed-off-by: Rafael Zalamena <rzalamena@opensourcerouting.org>
14 months agobgpd: Fix for ain->attr corruption during path update
Pooja Jagadeesh Doijode [Wed, 19 Apr 2023 01:40:06 +0000 (18:40 -0700)]
bgpd: Fix for ain->attr corruption during path update

1. Consider a established L2VPN EVPN BGP peer with soft-reconfiguartion
   inbound configured

2. When the interface of this directly connected BGP peer is shutdown,
   bgp_soft_reconfig_table_update() is called, which memsets the evpn buffer
   and calls bgp_update() with received attributes stored in ain table(ain->attr).
   In bgp_update(), evpn_overlay attribute in ain->attr (which is an interned
   attr) was modified by doing a memcpy

3. Above action causes 2 attributes in the attrhash (which were previously different)
   to match!

4. Later during fsm change event of the peer, bgp_adj_in_remove() is called
   to clean up the ain->attr. But, because 2 attrs in attrhash match, it causes
   BGP to assert in bgp_attr_unintern()

Signed-off-by: Pooja Jagadeesh Doijode <pdoijode@nvidia.com>
14 months agoripd: Align show ip rip status output for sources
Donatas Abraitis [Tue, 18 Apr 2023 19:50:11 +0000 (22:50 +0300)]
ripd: Align show ip rip status output for sources

Before:
```
Routing Protocol is "rip"
  Sending updates every 5 seconds with +/-50%, next due in 0 seconds
  Timeout after 15 seconds, garbage collect after 10 seconds
  Outgoing update filter list for all interface is not set
  Incoming update filter list for all interface is not set
  Default redistribution metric is 1
  Redistributing:
  Default version control: send version 2, receive any version
    Interface        Send  Recv   Key-chain
    r1-eth0          2     1 2
  Routing for Networks:
    192.168.1.0/24
  Routing Information Sources:
    Gateway          BadPackets BadRoutes  Distance Last Update
    192.168.1.2              0         0       120   00:00:05
    192.168.1.3              0         0       120   00:00:04
  Distance: (default is 120)
```

After:
```
Routing Protocol is "rip"
  Sending updates every 5 seconds with +/-50%, next due in 4 seconds
  Timeout after 15 seconds, garbage collect after 10 seconds
  Outgoing update filter list for all interface is not set
  Incoming update filter list for all interface is not set
  Default redistribution metric is 1
  Redistributing:
  Default version control: send version 2, receive any version
    Interface        Send  Recv   Key-chain
    r1-eth0          2     1 2
  Routing for Networks:
    192.168.1.0/24
  Routing Information Sources:
    Gateway          BadPackets BadRoutes  Distance Last Update
    192.168.1.2               0         0       120    00:00:00
    192.168.1.3               0         0       120    00:00:04
  Distance: (default is 120)
```

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
14 months agotests: Check if RIPd passive-interface works as expected
Donatas Abraitis [Tue, 18 Apr 2023 19:37:53 +0000 (22:37 +0300)]
tests: Check if RIPd passive-interface works as expected

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
14 months agoripd: Create non default passive interface if defined so
Donatas Abraitis [Tue, 18 Apr 2023 18:19:34 +0000 (21:19 +0300)]
ripd: Create non default passive interface if defined so

Without this patch, it's never get non-passive and even listed under status:

Configuration:

```
router rip
 network 192.168.1.0/24
 network 10.10.10.1/32
 passive-interface default
 no passive-interface r2-eth0
 timers basic 5 15 10
exit
```

```
r2# do sh ip rip status
Routing Protocol is "rip"
  Sending updates every 5 seconds with +/-50%, next due in 4 seconds
  Timeout after 15 seconds, garbage collect after 10 seconds
  Outgoing update filter list for all interface is not set
  Incoming update filter list for all interface is not set
  Default redistribution metric is 1
  Redistributing:
  Default version control: send version 2, receive any version
    Interface        Send  Recv   Key-chain
    lo               2     1 2
    r2-eth0          2     1 2
  Routing for Networks:
    10.10.10.1/32
    192.168.1.0/24
  Passive Interface(s):
    lo
    r2-eth0
  Routing Information Sources:
    Gateway          BadPackets BadRoutes  Distance Last Update
    192.168.1.3              0         0       120   00:00:04
  Distance: (default is 120)
r2#
```

Signed-off-by: Donatas Abraitis <donatas@opensourcerouting.org>
14 months agoMerge pull request #13323 from LabNConsulting/style-update
Mark Stapp [Tue, 18 Apr 2023 17:13:35 +0000 (13:13 -0400)]
Merge pull request #13323 from LabNConsulting/style-update

style: add format checker config and remove .dir-locals.el

14 months agoMerge pull request #11667 from louis-6wind/flexalgo-mpls
Olivier Dugeon [Tue, 18 Apr 2023 12:45:30 +0000 (14:45 +0200)]
Merge pull request #11667 from louis-6wind/flexalgo-mpls

isisd: Flex-Algo for SR-MPLS

14 months agoMerge pull request #13236 from Orange-OpenSource/ospf-te
Russ White [Tue, 18 Apr 2023 12:32:20 +0000 (08:32 -0400)]
Merge pull request #13236 from Orange-OpenSource/ospf-te

ospfd: Force Opaque LSA & co to default VRF

14 months agodoc: add isisd flex-algo documentation
Louis Scalbert [Mon, 29 Aug 2022 11:32:20 +0000 (13:32 +0200)]
doc: add isisd flex-algo documentation

Add the isisd flex-algo documentation

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agodoc: fix debugging-isis reference
Louis Scalbert [Tue, 6 Sep 2022 14:25:55 +0000 (16:25 +0200)]
doc: fix debugging-isis reference

Debugging-isis tag was moved.

Move it to right place.

Fixes: 9389175b75 ("doc: add documentation for IS-IS Segment Routing")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agotests: add isis_sr_flex_algo_topo2 for flex-algo
Hiroki Shirokura [Sun, 21 Nov 2021 10:07:32 +0000 (10:07 +0000)]
tests: add isis_sr_flex_algo_topo2 for flex-algo

Add a topotest with 9 flex-algo routers to check each router's MPLS
table.

Signed-off-by: Hiroki Shirokura <hiroki.shirokura@linecorp.com>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agotests: add isis_sr_flex_algo_topo1 for flex-algo
Hiroki Shirokura [Sun, 21 Nov 2021 10:07:27 +0000 (10:07 +0000)]
tests: add isis_sr_flex_algo_topo1 for flex-algo

Add a topotest to check some Flex-Algo configuration changes.

Signed-off-by: Hiroki Shirokura <hiroki.shirokura@linecorp.com>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: add "show isis flex-algo" command
Louis Scalbert [Mon, 12 Dec 2022 15:12:41 +0000 (16:12 +0100)]
isisd: add "show isis flex-algo" command

Add the show isis flex-algo command to display the elected Flex-Algo
definitions and states (enabled/disabled).

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: add algorithm argument to show isis segment-routing node
Louis Scalbert [Mon, 12 Dec 2022 14:59:19 +0000 (15:59 +0100)]
isisd: add algorithm argument to show isis segment-routing node

Add algorithm argument to show isis segment-routing node

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: add an algorithm argument to show isis route
Louis Scalbert [Tue, 6 Sep 2022 15:08:57 +0000 (17:08 +0200)]
isisd: add an algorithm argument to show isis route

Add an optional algorithm argument to "show isis route" command.

Signed-off-by: Eric Kinzie <ekinzie@labn.net>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: add an algorithm argument to show isis topology
Louis Scalbert [Tue, 6 Sep 2022 15:06:55 +0000 (17:06 +0200)]
isisd: add an algorithm argument to show isis topology

Add an optional algorithm argument to "show isis topology" command.

Signed-off-by: Eric Kinzie <ekinzie@labn.net>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: add flex-algo info to spf extreme debug
Louis Scalbert [Tue, 30 Aug 2022 09:21:20 +0000 (11:21 +0200)]
isisd: add flex-algo info to spf extreme debug

Add flex-algo information ID to the SPF extreme debug mode.

Signed-off-by: Eric Kinzie <ekinzie@labn.net>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: add option to display isis routes as json
Eric Kinzie [Fri, 2 Sep 2022 14:33:52 +0000 (16:33 +0200)]
isisd: add option to display isis routes as json

Append an optional parameter to "show isis route [prefix-sid]" that
formats the output as a JSON array.

Signed-off-by: Eric Kinzie <ekinzie@labn.net>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: show non-zero algos in "show isis route prefix-sid" (2/2)
Eric Kinzie [Fri, 2 Sep 2022 14:33:43 +0000 (16:33 +0200)]
isisd: show non-zero algos in "show isis route prefix-sid" (2/2)

Show Prefix-SIDs and labels for all available Flex-Algos.

Signed-off-by: Eric Kinzie <ekinzie@labn.net>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agoisisd: show non-zero algos in "show isis route prefix-sid" (1/2)
Louis Scalbert [Mon, 12 Sep 2022 12:57:51 +0000 (14:57 +0200)]
isisd: show non-zero algos in "show isis route prefix-sid" (1/2)

Change the indentation to facilitate the reading of next commit.
No change on code.

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
14 months agolib: convert termtable to json
Eric Kinzie [Fri, 2 Sep 2022 14:33:21 +0000 (16:33 +0200)]
lib: convert termtable to json

Add a function that returns a JSON-C structure containing a representation
of a termtable.  This is intended to be a quick way to implement JSON
output to CLI commands.

Signed-off-by: Eric Kinzie <ekinzie@labn.net>