]> git.proxmox.com Git - mirror_frr.git/log
mirror_frr.git
12 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

12 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

12 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

12 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

12 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.

12 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>
12 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()

12 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

12 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>
12 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>
12 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

12 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

12 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>
12 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>
12 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

12 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>
12 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>
12 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>
12 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>
12 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

12 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

12 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>
12 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

13 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>
13 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>
13 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>
13 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>
13 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

13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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

13 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

13 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

13 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>
13 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>
13 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

13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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

13 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

13 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>
13 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>
13 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>
13 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

13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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

13 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 +/-

13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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

13 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

13 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

13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 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>
13 months agoisisd: clarify ifdef fabricd
Louis Scalbert [Mon, 27 Feb 2023 15:54:09 +0000 (16:54 +0100)]
isisd: clarify ifdef fabricd

clarify ifdef fabricd

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agoisisd: fix typo in indef fabricd comment
Louis Scalbert [Mon, 27 Feb 2023 13:51:53 +0000 (14:51 +0100)]
isisd: fix typo in indef fabricd comment

fix typo in indef fabricd comment

Fixes: 20bd27e2aa ("isisd, yang: add configuration model and callback stubs")
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agoisisd: add affinity-map configuration hooks
Louis Scalbert [Thu, 10 Nov 2022 15:36:08 +0000 (16:36 +0100)]
isisd: add affinity-map configuration hooks

Add affinity-map hooks to check the utilization of affinity-map in
flex-algo contexts before its deletion and to update local TLVs when the
affinity-map bit-position is updated.

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agoisisd: add support of (ti-)lfa to flex-algo
Louis Scalbert [Mon, 12 Dec 2022 16:22:56 +0000 (17:22 +0100)]
isisd: add support of (ti-)lfa to flex-algo

Add support of (ti-)lfa to flex-algo

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agoisisd: fix merging flex-algo route nodes
Eric Kinzie [Fri, 1 Apr 2022 00:47:30 +0000 (00:47 +0000)]
isisd: fix merging flex-algo route nodes

As isis_route_verify_merge() builds a new route table, each (src,dst)
new node in the table is created by merging data from the same (src,dst)
pair present in all route tables.  However, as it iterates over those
route nodes and copies SR data into the newly created node, it repeatedly
overwrites the isis_route_info pointer.  This, in turn, pollutes the
isis_route_info structures in all of the other tables with partially
updated SR data.

After a route is deleted, this leaves pointers to freed memory in one
of the route trees.

Fixes: 26b0598f6b6f ("isisd: fix isis_route_merge_verify logic")
Signed-off-by: Eric Kinzie <ekinzie@labn.net>
13 months agoisisd: merge algorithm tables
Hiroki Shirokura [Fri, 21 Jan 2022 16:02:54 +0000 (16:02 +0000)]
isisd: merge algorithm tables

Create a temporary "merge" route table that contains the routing
information from all algorithms and install the merge route table
into the FIB.

Signed-off-by: Hiroki Shirokura <hiroki.shirokura@linecorp.com>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agoisisd: calculate flex-algo constraint spf
Hiroki Shirokura [Fri, 21 Jan 2022 14:54:15 +0000 (14:54 +0000)]
isisd: calculate flex-algo constraint spf

Take into account the flex-algo affinity constraints to compute the SPF
tree.

Signed-off-by: Hiroki Shirokura <hiroki.shirokura@linecorp.com>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agoisisd: add isis flex-algo lsp advertisement
Hiroki Shirokura [Tue, 4 Jan 2022 01:31:45 +0000 (01:31 +0000)]
isisd: add isis flex-algo lsp advertisement

Deal with the packing and unpacking of following Flex-Algo
Sub-Sub-TLVs:

- Router Capability (already defined TLV 242)
- List of the Flex-Algo Definitions (Sub-TLV 26)
- Exclude admin group (Sub-Sub-TLV 1)
                - Include-any admin group (Sub-Sub-TLV 2)
                - Include-all admin group (Sub-Sub-TLV 3)
                - Flags (for prefix-metric) (Sub-Sub-TLV 4)

This commit splits data into multiple router capability TLVs if needed
because a TLV cannot contains more than 255 bytes.

Note that the list of SR Algorithm (Sub-TLV 19) within Router Capability
(TLV 242) is already set in a previous commit.

Signed-off-by: Hiroki Shirokura <hiroki.shirokura@linecorp.com>
Signed-off-by: Eric Kinzie <ekinzie@labn.net>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agoisisd: add ASLA support
Louis Scalbert [Mon, 12 Dec 2022 15:00:58 +0000 (16:00 +0100)]
isisd: add ASLA support

Add the support of ASLA with the following TLV:

- Extended IS Reachability (already defined TLV 22)
        - Application-Specific Link Attributes (Sub-TLV 16)
          (to enable the Flex-Algo flag on a link)
                - Admin-group (Sub-Sub-TLV 3)
                - Extended Admin-group (Sub-Sub-TLV 14)

Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agoisisd: add isis flex-algo configuration frontend
Hiroki Shirokura [Sat, 18 Dec 2021 08:54:52 +0000 (08:54 +0000)]
isisd: add isis flex-algo configuration frontend

Add the frontend functions for the flex-algo configuration.

Signed-off-by: Hiroki Shirokura <hiroki.shirokura@linecorp.com>
Signed-off-by: Eric Kinzie <ekinzie@labn.net>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>
13 months agostyle: add format checker config that matches FRR style standards
Christian Hopps [Tue, 18 Apr 2023 09:12:58 +0000 (05:12 -0400)]
style: add format checker config that matches FRR style standards

Also move .dir-locals.el to a sample file. This file should not be
in the repository as it affects the user's ability to modify it.

Signed-off-by: Christian Hopps <chopps@labn.net>
13 months agoospfd: Force Opaque LSA & co to default VRF
Olivier Dugeon [Fri, 7 Apr 2023 20:48:24 +0000 (22:48 +0200)]
ospfd: Force Opaque LSA & co to default VRF

Ospf segfault when Router Information is enabled in a non default VRF,
see issue #13144.

This patch forces vrf_id to default VRF for Opaque LSA and extension based
on Opaque LSA: Router Information, Traffic Engineering, Extended Prefix,
Extended Link and Segment Routing. Indeed, non default VRF is not yet
supported for Opaque LSA & co.

Signed-off-by: Olivier Dugeon <olivier.dugeon@orange.com>
13 months agoisisd: add isis flex-algo configuration backend
Hiroki Shirokura [Sat, 18 Dec 2021 08:23:16 +0000 (08:23 +0000)]
isisd: add isis flex-algo configuration backend

Add the backend functions for the flex-algo configuration.

Signed-off-by: Hiroki Shirokura <hiroki.shirokura@linecorp.com>
Signed-off-by: Eric Kinzie <ekinzie@labn.net>
Signed-off-by: Louis Scalbert <louis.scalbert@6wind.com>