From c2a44a0ff4761568f1c60f56da9120a3be8d8b56 Mon Sep 17 00:00:00 2001 From: Flavio Leitner Date: Fri, 24 Aug 2007 22:16:39 -0700 Subject: [PATCH] --- yaml --- r: 64533 b: refs/heads/master c: a96fb49be3dd2031f722bf32af6ed7db965b60f7 h: refs/heads/master i: 64531: 5e6944585c6dc31d634c9953320a94495bd2fc43 v: v3 --- [refs] | 2 +- trunk/net/ipv4/ip_sockglue.c | 4 ++++ trunk/net/ipv6/ipv6_sockglue.c | 4 ++++ 3 files changed, 9 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 3efa307a7a1d..51aeb8c88edd 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 36d98d3edce12c8f9ffd33f8f5d23ce728380925 +refs/heads/master: a96fb49be3dd2031f722bf32af6ed7db965b60f7 diff --git a/trunk/net/ipv4/ip_sockglue.c b/trunk/net/ipv4/ip_sockglue.c index 4d544573f48a..6b420aedcdcf 100644 --- a/trunk/net/ipv4/ip_sockglue.c +++ b/trunk/net/ipv4/ip_sockglue.c @@ -625,6 +625,10 @@ static int do_ip_setsockopt(struct sock *sk, int level, { struct ip_mreqn mreq; + err = -EPROTO; + if (inet_sk(sk)->is_icsk) + break; + if (optlen < sizeof(struct ip_mreq)) goto e_inval; err = -EFAULT; diff --git a/trunk/net/ipv6/ipv6_sockglue.c b/trunk/net/ipv6/ipv6_sockglue.c index 761a910f4f97..6b038aa72e88 100644 --- a/trunk/net/ipv6/ipv6_sockglue.c +++ b/trunk/net/ipv6/ipv6_sockglue.c @@ -554,6 +554,10 @@ static int do_ipv6_setsockopt(struct sock *sk, int level, int optname, { struct ipv6_mreq mreq; + retv = -EPROTO; + if (inet_sk(sk)->is_icsk) + break; + retv = -EFAULT; if (copy_from_user(&mreq, optval, sizeof(struct ipv6_mreq))) break;