Commit 9c48e1ea authored by Patrick McHardy's avatar Patrick McHardy Committed by Chris Wright

[PATCH] NETFILTER: SCTP conntrack: fix crash triggered by packet without chunks [CVE-2006-2934]

When a packet without any chunks is received, the newconntrack variable
in sctp_packet contains an out of bounds value that is used to look up an
pointer from the array of timeouts, which is then dereferenced, resulting
in a crash. Make sure at least a single chunk is present.

Problem noticed by George A. Theall <theall@tenablesecurity.com>
Signed-off-by: default avatarPatrick McHardy <kaber@trash.net>
Signed-off-by: default avatarChris Wright <chrisw@sous-sol.org>
parent 27162bf7
...@@ -254,7 +254,7 @@ static int do_basic_checks(struct ip_conntrack *conntrack, ...@@ -254,7 +254,7 @@ static int do_basic_checks(struct ip_conntrack *conntrack,
} }
DEBUGP("Basic checks passed\n"); DEBUGP("Basic checks passed\n");
return 0; return count == 0;
} }
static int new_state(enum ip_conntrack_dir dir, static int new_state(enum ip_conntrack_dir dir,
......
...@@ -259,7 +259,7 @@ static int do_basic_checks(struct nf_conn *conntrack, ...@@ -259,7 +259,7 @@ static int do_basic_checks(struct nf_conn *conntrack,
} }
DEBUGP("Basic checks passed\n"); DEBUGP("Basic checks passed\n");
return 0; return count == 0;
} }
static int new_state(enum ip_conntrack_dir dir, static int new_state(enum ip_conntrack_dir dir,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment