[FreeBSD-Announce] FreeBSD Security Advisory FreeBSD-SA-14:19.tcp
Andriy Gapon
avg at FreeBSD.org
Tue Sep 16 12:49:33 UTC 2014
On 16/09/2014 13:14, FreeBSD Security Advisories wrote:
> =============================================================================
> FreeBSD-SA-14:19.tcp Security Advisory
> The FreeBSD Project
>
> Topic: Denial of Service in TCP packet processing
>
> Category: core
> Module: inet
> Announced: 2014-09-16
> Credits: Jonathan Looney (Juniper SIRT)
> Affects: All supported versions of FreeBSD.
Does the issue affect head aka CURRENT as well?
> Corrected: 2014-09-16 09:48:35UTC (stable/10, 10.1-PRERELEASE)
> 2014-09-16 09:48:35 UTC (stable/10, 10.1-BETA1-p1)
> 2014-09-16 09:50:19 UTC (releng/10.0, 10.0-RELEASE-p9)
> 2014-09-16 09:49:11 UTC (stable/9, 9.3-STABLE)
> 2014-09-16 09:50:19 UTC (releng/9.3, 9.3-RELEASE-p2)
> 2014-09-16 09:50:19 UTC (releng/9.2, 9.2-RELEASE-p12)
> 2014-09-16 09:50:19 UTC (releng/9.1, 9.1-RELEASE-p19)
> 2014-09-16 09:49:11 UTC (stable/8, 8.4-STABLE)
> 2014-09-16 09:50:19 UTC (releng/8.4, 8.4-RELEASE-p16)
> CVE Name: CVE-2004-0230
>
> For general information regarding FreeBSD Security Advisories,
> including descriptions of the fields above, security branches, and the
> following sections, please visit <URL:http://security.FreeBSD.org/>.
>
> I. Background
>
> The Transmission Control Protocol (TCP) of the TCP/IP protocol suite
> provides a connection-oriented, reliable, sequence-preserving data
> stream service. New TCP connections are initiated using special SYN
> flag in a datagram. Sequencing of data is controlled by 32-bit sequence
> numbers, that start with a random value and are increased using modulo
> 2**32 arithmetic. TCP endpoints maintain a window of expected, and
> thus allowed, sequence numbers for a connection.
>
> II. Problem Description
>
> When a segment with the SYN flag for an already existing connection arrives,
> the TCP stack tears down the connection, bypassing a check that the
> sequence number in the segment is in the expected window.
>
> III. Impact
>
> An attacker who has the ability to spoof IP traffic can tear down a
> TCP connection by sending only 2 packets, if they know both TCP port
> numbers. In case one of the two port numbers is unknown, a successful
> attack requires less than 2**17 packets spoofed, which can be
> generated within less than a second on a decent connection to the
> Internet.
>
> IV. Workaround
>
> It is possible to defend against these attacks with stateful traffic
> inspection using a firewall. This can be done by enabling pf(4) on
> the system and creating states for every connection. Even a default
> ruleset to allow all traffic would be sufficient to mitigate this
> issue.
>
> V. Solution
>
> Perform one of the following:
>
> 1) Upgrade your vulnerable system to a supported FreeBSD stable or
> release / security branch (releng) dated after the correction date.
>
> 2) To update your vulnerable system via a source code patch:
>
> The following patches have been verified to apply to the applicable
> FreeBSD release branches.
>
> a) Download the relevant patch from the location below, and verify the
> detached PGP signature using your PGP utility.
>
> # fetch http://security.FreeBSD.org/patches/SA-14:19/tcp.patch
> # fetch http://security.FreeBSD.org/patches/SA-14:19/tcp.patch.asc
> # gpg --verify tcp.patch.asc
>
> b) Apply the patch. Execute the following commands as root:
>
> # cd /usr/src
> # patch < /path/to/patch
>
> c) Recompile your kernel as described in
> <URL:http://www.FreeBSD.org/handbook/kernelconfig.html> and reboot the
> system.
>
> 3) To update your vulnerable system via a binary patch:
>
> Systems running a RELEASE version of FreeBSD on the i386 or amd64
> platforms can be updated via the freebsd-update(8) utility:
>
> # freebsd-update fetch
> # freebsd-update install
>
> VI. Correction details
>
> The following list contains the correction revision numbers for each
> affected branch.
>
> Branch/path Revision
> -------------------------------------------------------------------------
> stable/8/ r271668
> releng/8.4/ r271669
> stable/9/ r271668
> releng/9.1/ r271669
> releng/9.2/ r271669
> releng/9.3/ r271669
> stable/10/ r271667
> releng/10.0/ r271669
> -------------------------------------------------------------------------
>
> To see which files were modified by a particular revision, run the
> following command, replacing NNNNNN with the revision number, on a
> machine with Subversion installed:
>
> # svn diff -cNNNNNN --summarize svn://svn.freebsd.org/base
>
> Or visit the following URL, replacing NNNNNN with the revision number:
>
> <URL:http://svnweb.freebsd.org/base?view=revision&revision=NNNNNN>
>
> VII. References
>
> <URL:http://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2004-0230>
>
> The latest revision of this advisory is available at
> <URL:http://security.FreeBSD.org/advisories/FreeBSD-SA-14:19.tcp.asc>
> _______________________________________________
> freebsd-announce at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-announce
> To unsubscribe, send any mail to "freebsd-announce-unsubscribe at freebsd.org"
>
--
Andriy Gapon
More information about the freebsd-security
mailing list