Commit 25b6badd authored by Patrick McHardy's avatar Patrick McHardy Committed by Greg Kroah-Hartman

[PATCH] NETFILTER: SCTP conntrack: fix infinite loop (CVE-2006-1527)

[NETFILTER]: SCTP conntrack: fix infinite loop

fix infinite loop in the SCTP-netfilter code: check SCTP chunk size to
guarantee progress of for_each_sctp_chunk(). (all other uses of
for_each_sctp_chunk() are preceded by do_basic_checks(), so this fix
should be complete.)

Based on patch from Ingo Molnar <mingo@elte.hu>
Signed-off-by: default avatarPatrick McHardy <kaber@trash.net>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 42a46c74
...@@ -235,12 +235,15 @@ static int do_basic_checks(struct ip_conntrack *conntrack, ...@@ -235,12 +235,15 @@ static int do_basic_checks(struct ip_conntrack *conntrack,
flag = 1; flag = 1;
} }
/* Cookie Ack/Echo chunks not the first OR /*
Init / Init Ack / Shutdown compl chunks not the only chunks */ * Cookie Ack/Echo chunks not the first OR
if ((sch->type == SCTP_CID_COOKIE_ACK * Init / Init Ack / Shutdown compl chunks not the only chunks
* OR zero-length.
*/
if (((sch->type == SCTP_CID_COOKIE_ACK
|| sch->type == SCTP_CID_COOKIE_ECHO || sch->type == SCTP_CID_COOKIE_ECHO
|| flag) || flag)
&& count !=0 ) { && count !=0) || !sch->length) {
DEBUGP("Basic checks failed\n"); DEBUGP("Basic checks failed\n");
return 1; return 1;
} }
......
...@@ -240,12 +240,15 @@ static int do_basic_checks(struct nf_conn *conntrack, ...@@ -240,12 +240,15 @@ static int do_basic_checks(struct nf_conn *conntrack,
flag = 1; flag = 1;
} }
/* Cookie Ack/Echo chunks not the first OR /*
Init / Init Ack / Shutdown compl chunks not the only chunks */ * Cookie Ack/Echo chunks not the first OR
if ((sch->type == SCTP_CID_COOKIE_ACK * Init / Init Ack / Shutdown compl chunks not the only chunks
* OR zero-length.
*/
if (((sch->type == SCTP_CID_COOKIE_ACK
|| sch->type == SCTP_CID_COOKIE_ECHO || sch->type == SCTP_CID_COOKIE_ECHO
|| flag) || flag)
&& count !=0 ) { && count !=0) || !sch->length) {
DEBUGP("Basic checks failed\n"); DEBUGP("Basic checks failed\n");
return 1; return 1;
} }
......
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