diff options
author | RongQing.Li <roy.qing.li@gmail.com> | 2012-02-22 02:10:50 +0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2012-02-23 00:30:14 +0400 |
commit | 0541743b4b35f2ddc9e490b4e354930168b60d23 (patch) | |
tree | 009a1520ba99c4150f96e3a8a79b5b21929a8028 /drivers | |
parent | 5095d64db1b978bdb31d30fed9e47dbf04f729be (diff) | |
download | linux-0541743b4b35f2ddc9e490b4e354930168b60d23.tar.xz |
ethernet/broadcom: ip6_route_output() never returns NULL.
ip6_route_output() never returns NULL, so it is wrong to
check if the return value is NULL.
Signed-off-by: RongQing.Li <roy.qing.li@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/net/ethernet/broadcom/cnic.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/drivers/net/ethernet/broadcom/cnic.c b/drivers/net/ethernet/broadcom/cnic.c index dd3a0a232ea0..818a573669e6 100644 --- a/drivers/net/ethernet/broadcom/cnic.c +++ b/drivers/net/ethernet/broadcom/cnic.c @@ -3584,7 +3584,11 @@ static int cnic_get_v6_route(struct sockaddr_in6 *dst_addr, fl6.flowi6_oif = dst_addr->sin6_scope_id; *dst = ip6_route_output(&init_net, NULL, &fl6); - if (*dst) + if ((*dst)->error) { + dst_release(*dst); + *dst = NULL; + return -ENETUNREACH; + } else return 0; #endif |