freebsd kernel with SKQ
Go to file
Konstantin Belousov 84cdea97e5 Right now, the process' p_boundary_count counter is decremented by the
suspended thread itself, on the return path from
thread_suspend_check().  A consequence is that return from
thread_single_end(SINGLE_BOUNDARY) may leave p_boundary_count
non-zero, it might be even equal to the threads count.

Now, assume that we have two threads in the process, both calling
execve(2).  Suppose that the first thread won the race to be the
suspension thread, and that afterward its exec failed for any reason.
After the first thread did thread_single_end(SINGLE_BOUNDARY), second
thread becomes the process suspension thread and checks
p_boundary_count.  The non-zero value of the count allows the
suspension loop to finish without actually suspending some threads.
In other words, we enter exec code with some threads not suspended.

Fix this by decrementing p_boundary_count in the
thread_single_end()->thread_unsuspend_one() during marking the thread
as runnable.  This way, a return from thread_single_end() guarantees
that the counter is cleared.  We do not care whether the unsuspended
thread has a chance to run.

Add some asserts to ensure the state of the process when single
boundary suspension is lifted.  Also make thread_unuspend_one()
static.

In collaboration with:	pho
Sponsored by:	The FreeBSD Foundation
MFC after:	1 week
2015-05-15 07:54:31 +00:00
bin date(1): Make -r behave like GNU's version when the option can not be 2015-05-07 20:54:38 +00:00
cddl ctf_add_type(): when looking up an integer or floating point type in the 2015-05-10 21:39:24 +00:00
contrib MFV r282927,r282928,r282930 (kientzle): 2015-05-14 22:35:26 +00:00
crypto Use proper CHAN_TCP_PACKET_DEFAULT for agent forwarding when HPN disabled. 2015-04-02 18:43:25 +00:00
etc Revert r282672. 2015-05-11 00:16:32 +00:00
games fortune/tools/do_uniq.py 2015-04-02 22:42:23 +00:00
gnu Replace groff's soelim by soeliminate(1) renamed soelim(1) 2015-05-01 20:08:25 +00:00
include No need for result_use_check attribute in reallocf(3). 2015-05-01 20:40:48 +00:00
kerberos5 Add a ${CP} alias for copying files in the build. 2015-01-16 21:39:08 +00:00
lib Update to ELF Tool Chain r3197 2015-05-14 19:48:15 +00:00
libexec Remove historical GNUC test 2015-05-06 15:29:11 +00:00
release Avoid polluting the filesystem when not necessary. 2015-05-12 01:27:58 +00:00
rescue Significant upgrades to sa(4) and mt(1). 2015-02-23 21:59:30 +00:00
sbin Document RCTL events in devd.conf(5). 2015-05-13 12:02:51 +00:00
secure Add the openssl header for arm64. As it is based on MACHINE_CPUARCH it 2015-03-24 14:16:14 +00:00
share kbdmap(1): Correct menu title: keyboards have a layout, not a language 2015-05-14 18:09:56 +00:00
sys Right now, the process' p_boundary_count counter is decremented by the 2015-05-15 07:54:31 +00:00
tests Fix typo. It should have been atf_tc_skip, not atf_skip 2015-04-29 19:08:11 +00:00
tools Fix make delete-old for gperf and GCC/CXX options 2015-05-06 15:20:50 +00:00
usr.bin vtfontcvt: Allow 6 digits in verbose output 2015-05-14 20:17:53 +00:00
usr.sbin Bump the size of the blockif scatter-gather list to 67. 2015-05-14 21:08:48 +00:00
.arcconfig Phabricator: enable "history.immutable": 2015-04-30 00:27:53 +00:00
.arclint phabricator related changes: 2015-04-20 20:33:22 +00:00
COPYRIGHT Bump copyright year. 2014-12-31 10:00:43 +00:00
LOCKS Explicitly require Security Officer's approval for kernel PRNG bits. 2013-09-17 14:19:05 +00:00
MAINTAINERS Remove cokane@ from MAINTAINERS for 3dfx(4)/tdfx(4) because their email 2014-11-25 05:25:12 +00:00
Makefile Don't add arm64 to universe builds if the user provided a TARGETS list 2015-04-28 17:13:05 +00:00
Makefile.inc1 Remove redundant csu subdir logic 2015-05-12 17:53:22 +00:00
ObsoleteFiles.inc libyaml.so.1 are actually libraries and should only be removed during 2015-05-14 17:49:01 +00:00
README README: changes and fixups 2015-04-19 07:16:44 +00:00
UPDATING Add a note about the replacement of GNU groff's soelim(1) 2015-05-01 21:26:40 +00:00

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

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)
and http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/makeworld.html
for more information, including setting make(1) variables.

The `buildkernel` and `installkernel` targets build and install
the kernel and the modules (see below).  Please see the top of
the Makefile in this directory for more information on the
standard build targets and compile-time flags.

Building a kernel is a somewhat more involved process.  See build(7), config(8),
and http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html
for more information.

Note: If you want to build and install the kernel with the
`buildkernel` and `installkernel` targets, you might need to build
world before.  More information is available in the handbook.

The kernel configuration files reside in the sys/<arch>/conf
sub-directory.  GENERIC is the default configuration used in release builds.
NOTES contains entries and documentation for all possible
devices, not just those commonly used.


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.

games		Amusements.

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.

sys		Kernel sources.

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:

  http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/synching.html