FreeBSD src
Go to file
Konstantin Belousov a113b17f10 Do not read sigfastblock word on syscall entry.
On machines with SMAP, fueword executes two serializing instructions
which can be seen in microbenchmarks.

As a measure to restore microbenchmark numbers, only read the word on
the attempt to deliver signal in ast().  If the word is set, signal is
not delivered and word is kept, preventing interruption of
interruptible sleeps by signals until userspace calls
sigfastblock(UNBLOCK) which clears the word.

This way, the spurious EINTR that userspace can see while in critical
section is on first interruptible sleep, if a signal is pending, and
on signal posting.  It is believed that it is not important for rtld
and lbithr critical sections.  It might be visible for the application
code e.g. for the callback of dl_iterate_phdr(3), but again the belief
is that the non-compliance is acceptable.  Most important is that the
retry of the sleeping syscall does not interrupt unless additional
signal is posted.

For now I added the knob kern.sigfastblock_fetch_always to enable the
word read on syscall entry to be able to diagnose possible issues due
to spurious EINTR.

While there, do some code restructuting to have all sigfastblock()
handling located in kern_sig.c.

Reviewed by:	jeff
Discussed with:	mjg
Tested by:	pho
Sponsored by:	The FreeBSD Foundation
Differential revision:	https://reviews.freebsd.org/D23622
2020-02-20 15:34:02 +00:00
bin Improve performance of "read" built-in command when using a seekable 2020-02-20 03:01:27 +00:00
cddl sack_newdata and snd_recover hold the same value. Therefore, use only 2020-02-13 15:14:46 +00:00
contrib Update to 6.2-20200215 2020-02-19 17:09:08 +00:00
crypto Update version in openssh FREEBSD-vendor metadata 2020-02-14 22:32:33 +00:00
etc Remove /usr/include/ssp from BSD.include.dist after r356356 2020-02-14 19:31:24 +00:00
gnu remove stale gnu/lib/csu directory 2020-02-03 13:50:15 +00:00
include Add pthread_peekjoin_np(3). 2020-02-15 23:25:39 +00:00
kerberos5 Update Makefile.depend files 2019-12-11 17:37:53 +00:00
lib ncurses: bump shlib number to version 9 2020-02-20 09:12:07 +00:00
libexec r357895: fix typo in the relocation name for i386 IRELATIVE. 2020-02-14 12:59:27 +00:00
release caroot pkg: pass through the pkg -r rootdir as DESTDIR 2020-02-19 02:35:43 +00:00
rescue Remove unused defines since r147075 2019-07-12 04:44:50 +00:00
sbin Make ping6(1) return code consistent with the man page. 2020-02-15 15:39:53 +00:00
secure pkgbase: fix caroot packaging and add post-install script 2020-01-29 18:47:08 +00:00
share Actually install hwpstate_intel.4. 2020-02-20 06:45:51 +00:00
stand efi_register_handles() is missing NULL pointer check 2020-02-20 09:02:59 +00:00
sys Do not read sigfastblock word on syscall entry. 2020-02-20 15:34:02 +00:00
targets retire BSD_CRTBEGIN option 2020-01-31 18:04:04 +00:00
tests bridge tests: Remove unneeded 'All rights reserved.' 2020-02-19 16:44:16 +00:00
tools nanobsd: add WITHOUT_LLVM_COV, akin to WITHOUT_GCOV 2020-02-19 16:23:21 +00:00
usr.bin truss: fix shm_open2 oversight (BinString -> Name) 2020-02-19 15:12:01 +00:00
usr.sbin Bump PROTOMAX. 2020-02-20 06:03:41 +00:00
.arcconfig callsign isn't required anymore 2016-09-29 06:19:45 +00:00
.arclint arc lint: ignore /tests/ in chmod 2017-12-19 03:38:06 +00:00
.cirrus.yml Cirrus-CI: increase timeout to 120m 2020-02-19 15:56:40 +00:00
.clang-format Add a basic clang-format configuration file 2019-06-07 15:23:52 +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 Move all sources from the llvm project into contrib/llvm-project. 2019-12-20 19:53:05 +00:00
Makefile Per the firm plan, start to remove sparc64 2020-02-02 11:37:27 +00:00
Makefile.inc1 Take LINKER_FREEBSD_VERSION from numerical field after dash 2020-02-19 21:12:59 +00:00
Makefile.libcompat libcompat: build 32-bit rtld and ldd as part of "everything" 2019-11-07 22:58:10 +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 ncurses: bump shlib number to version 9 2020-02-20 09:12:07 +00:00
README README: add generic notes about GENERIC and NOTES 2018-06-17 19:44:24 +00:00
README.md README: add generic notes about GENERIC and NOTES 2018-06-17 19:44:24 +00:00
RELNOTES Add elf2aout removal 2020-02-06 18:00:50 +00:00
UPDATING Update the UPDATING information now that ncurses shlib has been bumped 2020-02-20 09:33:14 +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