FreeBSD src
Go to file
Gleb Smirnoff 3220a2121c FreeBSD-SA-14:19.tcp raised attention to the state of our stack
towards blind SYN/RST spoofed attack.

Originally our stack used in-window checks for incoming SYN/RST
as proposed by RFC793. Later, circa 2003 the RST attack was
mitigated using the technique described in P. Watson
"Slipping in the window" paper [1].

After that, the checks were only relaxed for the sake of
compatibility with some buggy TCP stacks. First, r192912
introduced the vulnerability, just fixed by aforementioned SA.
Second, r167310 had slightly relaxed the default RST checks,
instead of utilizing net.inet.tcp.insecure_rst sysctl.

In 2010 a new technique for mitigation of these attacks was
proposed in RFC5961 [2]. The idea is to send a "challenge ACK"
packet to the peer, to verify that packet arrived isn't spoofed.
If peer receives challenge ACK it should regenerate its RST or
SYN with correct sequence number. This should not only protect
against attacks, but also improve communication with broken
stacks, so authors of reverted r167310 and r192912 won't be
disappointed.

[1] http://bandwidthco.com/whitepapers/netforensics/tcpip/TCP Reset Attacks.pdf
[2] http://www.rfc-editor.org/rfc/rfc5961.txt

Changes made:

o Revert r167310.
o Implement "challenge ACK" protection as specificed in RFC5961
  against RST attack. On by default.
  - Carefully preserve r138098, which handles empty window edge
    case, not described by the RFC.
  - Update net.inet.tcp.insecure_rst description.
o Implement "challenge ACK" protection as specificed in RFC5961
  against SYN attack. On by default.
  - Provide net.inet.tcp.insecure_syn sysctl, to turn off
    RFC5961 protection.

The changes were tested at Netflix. The tested box didn't show
any anomalies compared to control box, except slightly increased
number of TCP connection in LAST_ACK state.

Reviewed by:	rrs
Sponsored by:	Netflix
Sponsored by:	Nginx, Inc.
2014-09-16 11:07:25 +00:00
bin Vendor import of OpenPAM Ourouparia. 2014-09-15 09:40:30 +00:00
cddl MFV r271516: 2014-09-13 17:30:46 +00:00
contrib Upgrade to OpenPAM Ourouparia. 2014-09-15 13:40:09 +00:00
crypto Include the gssapi_krb5 library in KRB5_LDFLAGS. 2014-09-08 19:00:13 +00:00
etc Fix a typo; master server for iprop service should be singular. 2014-09-16 05:45:38 +00:00
games Update the freebsd-tips example to use drill instead of dig since bind is no longer in base 2014-07-25 14:47:44 +00:00
gnu Add gnugrep.1 to CLEANFILES. 2014-08-26 19:36:34 +00:00
include Vendor import of OpenPAM Ourouparia. 2014-09-15 09:40:30 +00:00
kerberos5 Revert r267233 for now. PIE support needs to be reworked. 2014-08-19 15:04:32 +00:00
lib Bump .Dd for the content change done to access(2) in r271655 2014-09-16 00:59:08 +00:00
libexec Import HyperV Key-Value Pair (KVP) driver and daemon code by Microsoft, 2014-09-13 02:15:31 +00:00
release Create /tmp/bsdinstall_etc even if we aren't starting the installer so that 2014-09-13 20:09:02 +00:00
rescue Add zdb into rescue environment. 2014-08-20 00:14:41 +00:00
sbin Add DEF_CLONE_CMD_ARG2 2014-09-14 22:10:35 +00:00
secure Fix typo (LIBLDNSADD -> LIBLDNS) to fix "make checkdpadd" 2014-08-19 18:27:43 +00:00
share Add a brief description of CTLFLAG_VNET flag. Since the VIMAGE is 2014-09-15 11:14:23 +00:00
sys FreeBSD-SA-14:19.tcp raised attention to the state of our stack 2014-09-16 11:07:25 +00:00
tests Abort the create_socket test if socket creation fails. 2014-09-10 14:57:26 +00:00
tools Import HyperV Key-Value Pair (KVP) driver and daemon code by Microsoft, 2014-09-13 02:15:31 +00:00
usr.bin Add the new iscsi(4) man page 2014-09-13 18:40:12 +00:00
usr.sbin Fix two small nits in ctl.conf(5). 2014-09-14 08:35:44 +00:00
.arcconfig Update the URL to the phabricator instance. 2014-08-14 16:25:43 +00:00
.arclint arc: add linting for python files 2014-06-02 00:21:42 +00:00
COPYRIGHT Bump copyright year. 2013-12-31 12:18:10 +00:00
LOCKS Explicitly require Security Officer's approval for kernel PRNG bits. 2013-09-17 14:19:05 +00:00
MAINTAINERS add myself as opencrypto maintainer as I'm doing some work in the 2014-08-11 19:03:20 +00:00
Makefile Revert r271159, Mis-patched the tree. 2014-09-05 14:35:34 +00:00
Makefile.inc1 Revert r267233 for now. PIE support needs to be reworked. 2014-08-19 15:04:32 +00:00
ObsoleteFiles.inc Catch up to gcc 3.3 -> 3.4 upgrade. 2014-08-24 21:21:54 +00:00
README Vendor import of OpenPAM Ourouparia. 2014-09-15 09:40:30 +00:00
UPDATING Make mmap() of the console device when using ofwfb work like other supported 2014-07-29 23:11:05 +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, the most
commonly used one being ``world'', which rebuilds and installs
everything in the FreeBSD system from the source tree except the
kernel, the kernel-modules and the contents of /etc.  The ``world''
target should only be used in cases where the source tree has not
changed from the currently running version.  See:
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, documentation
for which can be found at:
   http://www.freebsd.org/doc/en_US.ISO8859-1/books/handbook/kernelconfig.html
And in the config(8) man page.
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 sample kernel configuration files reside in the sys/<arch>/conf
sub-directory (assuming that you've installed the kernel sources), the
file named GENERIC being the one used to build your initial installation
kernel.  The file NOTES contains entries and documentation for all possible
devices, not just those commonly used.  It is the successor of the ancient
LINT file, but in contrast to LINT, it is not buildable as a kernel but a
pure reference and documentation file.


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.

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