diff options
author | Miao Xie <miaox@cn.fujitsu.com> | 2008-07-30 08:57:58 +0200 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2008-07-30 08:57:58 +0200 |
commit | 4a36702e016947a0ce6c0c024673bb5b16d3f618 (patch) | |
tree | 16ae893432a4ea9677a2856bd1ae3d6bc65cc46e | |
parent | Merge branch 'master' of git://git.kernel.org/pub/scm/linux/kernel/git/linvil... (diff) | |
download | linux-4a36702e016947a0ce6c0c024673bb5b16d3f618.tar.xz linux-4a36702e016947a0ce6c0c024673bb5b16d3f618.zip |
IPv6: datagram_send_ctl() should exit immediately when an error occured
When an error occured, datagram_send_ctl() should exit immediately rather than
continue to run the for loop. Otherwise, the variable err might be changed and
the error might be hidden.
Fix this bug by using "goto" instead of "break".
Signed-off-by: Miao Xie <miaox@cn.fujitsu.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | net/ipv6/datagram.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/net/ipv6/datagram.c b/net/ipv6/datagram.c index f7b535dec860..410046a8cc91 100644 --- a/net/ipv6/datagram.c +++ b/net/ipv6/datagram.c @@ -732,7 +732,7 @@ int datagram_send_ctl(struct net *net, LIMIT_NETDEBUG(KERN_DEBUG "invalid cmsg type: %d\n", cmsg->cmsg_type); err = -EINVAL; - break; + goto exit_f; } } |