freebsd kernel with SKQ
Go to file
Alexander V. Chernikov fedeb08b6a Introduce scalable route multipath.
This change is based on the nexthop objects landed in D24232.

The change introduces the concept of nexthop groups.
Each group contains the collection of nexthops with their
 relative weights and a dataplane-optimized structure to enable
 efficient nexthop selection.

Simular to the nexthops, nexthop groups are immutable. Dataplane part
 gets compiled during group creation and is basically an array of
 nexthop pointers, compiled w.r.t their weights.

With this change, `rt_nhop` field of `struct rtentry` contains either
 nexthop or nexthop group. They are distinguished by the presense of
 NHF_MULTIPATH flag.
All dataplane lookup functions returns pointer to the nexthop object,
leaving nexhop groups details inside routing subsystem.

User-visible changes:

The change is intended to be backward-compatible: all non-mpath operations
 should work as before with ROUTE_MPATH and net.route.multipath=1.

All routes now comes with weight, default weight is 1, maximum is 2^24-1.

Current maximum multipath group width is statically set to 64.
 This will become sysctl-tunable in the followup changes.

Using functionality:
* Recompile kernel with ROUTE_MPATH
* set net.route.multipath to 1

route add -6 2001:db8::/32 2001:db8::2 -weight 10
route add -6 2001:db8::/32 2001:db8::3 -weight 20

netstat -6On

Nexthop groups data

Internet6:
GrpIdx  NhIdx     Weight   Slots                                 Gateway     Netif  Refcnt
1         ------- ------- ------- --------------------------------------- ---------       1
              13      10       1                             2001:db8::2     vlan2
              14      20       2                             2001:db8::3     vlan2

Next steps:
* Land outbound hashing for locally-originated routes ( D26523 ).
* Fix net/bird multipath (net/frr seems to work fine)
* Add ROUTE_MPATH to GENERIC
* Set net.route.multipath=1 by default

Tested by:	olivier
Reviewed by:	glebius
Relnotes:	yes
Differential Revision:	https://reviews.freebsd.org/D26449
2020-10-03 10:47:17 +00:00
.github/workflows Update OpenZFS to 2.0.0-rc3-gfc5966 2020-10-01 23:09:24 +00:00
bin cp: tests: fix weird 20 insertion 2020-09-23 03:02:45 +00:00
cddl Do a sweep and remove most WARNS=6 settings 2020-10-01 01:10:51 +00:00
contrib tmpfs tests: check for built-in tmpfs module 2020-10-02 00:52:31 +00:00
crypto Merge OpenSSL 1.1.1h. 2020-09-22 16:18:31 +00:00
etc cp: add some basic tests 2020-09-23 03:01:14 +00:00
gnu Do a sweep and remove most WARNS=6 settings 2020-10-01 01:10:51 +00:00
include Update OpenZFS to 2.0.0-rc3-gfc5966 2020-10-01 23:09:24 +00:00
kerberos5 Fix a noisy -Wundef warning when bootstrapping tools 2020-09-10 15:37:15 +00:00
lib newlocale(3): Fix a memory leak. 2020-10-02 18:35:55 +00:00
libexec Do a sweep and remove most WARNS=6 settings 2020-10-01 01:10:51 +00:00
release [PowerPC64LE] Add release building script for powerpc64le. 2020-09-23 01:13:29 +00:00
rescue loader: zfs should support bootonce an nextboot 2020-09-21 09:01:10 +00:00
sbin Do a sweep and remove most WARNS=6 settings 2020-10-01 01:10:51 +00:00
secure Merge OpenSSL 1.1.1h. 2020-09-22 16:18:31 +00:00
share netmap: minor documentation fix 2020-10-03 09:36:33 +00:00
stand Correct the documented size of kern.msgbufsize 2020-10-02 15:37:51 +00:00
sys Introduce scalable route multipath. 2020-10-03 10:47:17 +00:00
targets Add WITH_CLANG_FORMAT option 2020-06-24 17:03:42 +00:00
tests fusefs tests: quell Coverity "Argument cannot be negative" warnings 2020-10-02 17:06:05 +00:00
tools netmap: minor documentation fix 2020-10-03 09:36:33 +00:00
usr.bin Introduce scalable route multipath. 2020-10-03 10:47:17 +00:00
usr.sbin Don't ignore the return value from gethostname(3). It probably 2020-10-01 18:56:44 +00:00
.arcconfig
.arclint arc lint: ignore /tests/ in chmod 2017-12-19 03:38:06 +00:00
.cirrus.yml Cirrus-CI: skip svn_head branch 2020-09-19 13:55:26 +00:00
.clang-format Move vm_page_dump bitset array definition to MI code 2020-09-21 22:20:37 +00:00
.gitattributes Add a basic clang-format configuration file 2019-06-07 15:23:52 +00:00
.gitignore .gitignore: Add LINT kernel configurations generated into SRCDIR 2019-08-10 18:22:22 +00:00
COPYRIGHT Happy New Year 2020! 2019-12-31 16:01:36 +00:00
LOCKS LOCKS: update current locks 2018-06-09 03:08:04 +00:00
MAINTAINERS Add a pointer to csprng@ for the CSPRNG driver. This is enforced anyway by 2020-09-01 08:02:12 +00:00
Makefile [PowerPC64LE] Set up powerpc.powerpc64le architecture 2020-09-22 23:49:30 +00:00
Makefile.inc1 Makefile.inc1: sysent: allow subordinate sysent targets to run in parallel 2020-09-30 00:47:57 +00:00
Makefile.libcompat Add WITH_/WITHOUT_CLEAN option to replace NO_CLEAN 2020-09-08 00:44:35 +00:00
Makefile.sys.inc AUTO_OBJ: For all top-level targets enforce using an OBJDIR. 2017-12-05 21:29:47 +00:00
ObsoleteFiles.inc tests: move the memfd tests over to sys/posixshm 2020-09-23 19:54:59 +00:00
README Import OpenSSL 1.1.1h. 2020-09-22 14:27:08 +00:00
README.md README: add generic notes about GENERIC and NOTES 2018-06-17 19:44:24 +00:00
RELNOTES Add an entry to RELNOTES for the NFS over TLS kernel support. 2020-08-30 21:46:29 +00:00
UPDATING fix typo imorted -> imported. 2020-09-26 04:06:16 +00:00

FreeBSD Source:

This is the top level of the FreeBSD source directory. This file was last revised on: FreeBSD

FreeBSD is an operating system used to power modern servers, desktops, and embedded platforms. A large community has continually developed it for more than thirty years. Its advanced networking, security, and storage features have made FreeBSD the platform of choice for many of the busiest web sites and most pervasive embedded networking and storage devices.

For copyright information, please see the file COPYRIGHT in this directory. Additional copyright information also exists for some sources in this tree - please see the specific source directories for more information.

The Makefile in this directory supports a number of targets for building components (or all) of the FreeBSD source tree. See build(7), config(8), https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html, and https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html for more information, including setting make(1) variables.

Source Roadmap:

bin		System/user commands.

cddl		Various commands and libraries under the Common Development
		and Distribution License.

contrib		Packages contributed by 3rd parties.

crypto		Cryptography stuff (see crypto/README).

etc		Template files for /etc.

gnu		Various commands and libraries under the GNU Public License.
		Please see gnu/COPYING* for more information.

include		System include files.

kerberos5	Kerberos5 (Heimdal) package.

lib		System libraries.

libexec		System daemons.

release		Release building Makefile & associated tools.

rescue		Build system for statically linked /rescue utilities.

sbin		System commands.

secure		Cryptographic libraries and commands.

share		Shared resources.

stand		Boot loader sources.

sys		Kernel sources.

sys/<arch>/conf Kernel configuration files. GENERIC is the configuration
		used in release builds. NOTES contains documentation of
		all possible entries.

tests		Regression tests which can be run by Kyua.  See tests/README
		for additional information.

tools		Utilities for regression testing and miscellaneous tasks.

usr.bin		User commands.

usr.sbin	System administration commands.

For information on synchronizing your source tree with one or more of the FreeBSD Project's development branches, please see:

https://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/current-stable.html