FreeBSD src
Go to file
Mark Johnston fdb987bebd inpcb: Split PCB hash tables
Currently we use a single hash table per PCB database for connected and
bound PCBs.  Since we started using net_epoch to synchronize hash table
lookups, there's been a bug, noted in a comment above in_pcbrehash():
connecting a socket can cause an inpcb to move between hash chains, and
this can cause a concurrent lookup to follow the wrong linkage pointers.
I believe this could cause rare, spurious ECONNREFUSED errors in the
worse case.

Address the problem by introducing a second hash table and adding more
linkage pointers to struct inpcb.  Now the database has one table each
for connected and unconnected sockets.

When inserting an inpcb into the hash table, in_pcbinhash() now looks at
the foreign address of the inpcb to figure out which table to use.  This
ensures that queue linkage pointers are stable until the socket is
disconnected, so the problem described above goes away.  There is also a
small benefit in that in_pcblookup_*() can now search just one of the
two possible hash buckets.

I also made the "rehash" parameter of in(6)_pcbconnect() unused.  This
parameter seems confusing and it is simpler to let the inpcb code figure
out what to do using the existing INP_INHASHLIST flag.

UDP sockets pose a special problem since they can be connected and
disconnected multiple times during their lifecycle.  To handle this, the
patch plugs a hole in the inpcb structure and uses it to store an SMR
sequence number.  When an inpcb is disconnected - an operation which
requires the global PCB database hash lock - the write sequence number
is advanced, and in order to reconnect, the connecting thread must wait
for readers to drain before reusing the inpcb's hash chain linkage
pointers.

raw_ip (ab)uses the hash table without using the corresponding
accessors.  Since there are now two hash tables, it arbitrarily uses the
"connected" table for all of its PCBs.  This will be addressed in some
way in the future.

inp interators which specify a hash bucket will only visit connected
PCBs.  This is not really correct, but nothing in the tree uses that
functionality except raw_ip, which as mentioned above places all of its
PCBs in the "connected" table and so is unaffected.

Discussed with:	glebius
Tested by:	glebius
Sponsored by:	Klara, Inc.
Sponsored by:	Modirum MDPay
Differential Revision:	https://reviews.freebsd.org/D38569
2023-04-20 12:13:06 -04:00
.cirrus-ci Cirrus-CI: add some timing info on pkg install failure 2021-08-04 15:02:00 -04:00
.github .github: Test DISK_IMAGE_TOOLS_BOOTSTRAP in CI 2023-03-15 00:06:53 +00:00
bin Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
cddl Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
contrib ee: Remove two set but unused variables. 2023-04-18 12:53:32 -07:00
crypto openssh: restore PrintLastLog option 2023-04-19 21:17:59 -04:00
etc libcasper: Move helper libraries from /lib/casper to /lib. 2023-03-29 15:04:28 -07:00
gnu Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
include libc: bsort_s() requires both __BSD_VISIBLE and __EXT1_VISIBLE 2023-04-19 22:12:04 +02:00
kerberos5 Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
lib libz: Move NO_WDEPRECATED_NON_PROTOTYPE below include of bsd.lib.mk. 2023-04-19 10:53:02 -07:00
libexec network.subr: adjust regex for wlans_xxxxx rc.conf entries 2023-04-20 14:30:42 +00:00
release release: Remove "All Rights Reserved" from FreeBSD Foundation copyrights 2023-04-17 10:56:59 -04:00
rescue Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
sbin Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
secure Update/fix Makefile.depend for userland 2023-04-18 17:14:23 -07:00
share vmrun.sh: Fix a typo in usage() 2023-04-20 14:45:13 +02:00
stand stand: Remove a double word in a source code comment 2023-04-20 11:11:18 +02:00
sys inpcb: Split PCB hash tables 2023-04-20 12:13:06 -04:00
targets Makefile.xtras: fix show-valid-targets 2023-04-19 18:59:53 -07:00
tests tests: fix netlink type parsing. 2023-04-18 14:09:47 +00:00
tools stress2: Added comment of fixed problem. Enable test 2023-04-19 09:26:29 +02:00
usr.bin netstat: document that PCB information can't be read from corefiles 2023-04-19 12:15:35 +02:00
usr.sbin tzsetup(8): update paths to zone tab and tzdata source 2023-04-19 13:56:58 +02:00
.arcconfig arcanist: use FreeBSD/git project repository instead of FreeBSD/svn 2022-08-23 14:16:41 +00:00
.arclint arc lint: ignore /tests/ in chmod 2017-12-19 03:38:06 +00:00
.cirrus.yml Cirrus-CI: Run check-ldirs in include/ 2023-04-19 16:58:54 +01:00
.clang-format clang-format: Add bitset loop macros 2021-09-21 12:08:01 -04:00
.git-blame-ignore-revs Add git-blame ignore file 2023-01-23 15:27:25 -05:00
.gitattributes Add a basic clang-format configuration file 2019-06-07 15:23:52 +00:00
.gitignore .gitignore: Ignore LSP generated .cache 2023-03-07 10:04:18 -05:00
CONTRIBUTING.md CONTRIBUTING.md: Fix checkstyle9.pl name 2023-03-27 16:23:13 -04:00
COPYRIGHT Happy New Year 2023! 2023-01-01 13:44:43 +08:00
LOCKS LOCKS: update current locks 2018-06-09 03:08:04 +00:00
MAINTAINERS MAINTAINERS: Remove myself from OpenSSL maintenance 2023-03-28 15:44:26 -04:00
Makefile Remove the riscv64sf architecture. 2023-04-12 11:09:27 -07:00
Makefile.inc1 Stop stripping 'sf' suffixes from architecture names. 2023-04-12 11:11:02 -07:00
Makefile.libcompat libcompat: avoid installing include files twice 2022-11-16 19:15:20 -05: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 ObsoleteFiles.inc: add more obsolete files 2023-04-19 15:51:19 +00:00
README.md README.md: link to the list of supported platforms 2022-11-01 12:20:55 -03:00
RELNOTES RELNOTES: Add entries for two new NFS features 2023-04-16 12:34:52 -07:00
UPDATING UPDATING: Document arm video devices renaming. 2023-03-17 13:35:03 +01:00

FreeBSD Source:

This is the top level of the FreeBSD source directory.

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), FreeBSD handbook on building userland, and Handbook for kernels for more information, including setting make(1) variables.

For information on the CPU architectures and platforms supported by FreeBSD, see the FreeBSD website's Platforms page.

Source Roadmap:

Directory Description
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 Commands and libraries under the GNU General Public License (GPL) or Lesser General Public License (LGPL). Please see gnu/COPYING and gnu/COPYING.LIB 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 (see sys/README.md).
targets Support for experimental DIRDEPS_BUILD
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 FreeBSD Handbook.