From: Nikolay Aleksandrov <[email protected]>

We can have both errors and we'll return the second one, fix it to
return an error at a time as it's normal. I've overlooked this in my
previous set.

Signed-off-by: Nikolay Aleksandrov <[email protected]>
---
 net/ipv4/ipmr.c | 8 +++++---
 1 file changed, 5 insertions(+), 3 deletions(-)

diff --git a/net/ipv4/ipmr.c b/net/ipv4/ipmr.c
index 322fdc6ac75b..6c24a16299c7 100644
--- a/net/ipv4/ipmr.c
+++ b/net/ipv4/ipmr.c
@@ -1284,12 +1284,14 @@ int ip_mroute_setsockopt(struct sock *sk, int optname, 
char __user *optval,
 
        switch (optname) {
        case MRT_INIT:
-               if (optlen != sizeof(int))
+               if (optlen != sizeof(int)) {
                        ret = -EINVAL;
-               if (rtnl_dereference(mrt->mroute_sk))
+                       break;
+               }
+               if (rtnl_dereference(mrt->mroute_sk)) {
                        ret = -EADDRINUSE;
-               if (ret)
                        break;
+               }
 
                ret = ip_ra_control(sk, 1, mrtsock_destruct);
                if (ret == 0) {
-- 
2.4.3

--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to