Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 184513
b: refs/heads/master
c: c76284a
h: refs/heads/master
i:
  184511: 4c941b0
v: v3
  • Loading branch information
Michael Chan authored and David S. Miller committed Feb 26, 2010
1 parent f7322cc commit 4ea92d4
Show file tree
Hide file tree
Showing 2 changed files with 14 additions and 25 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: d02a5e6c2fba8b114c44cf05085fca07180f37f1
refs/heads/master: c76284af9ec8a010c502a70249cb74b3bb69ec6f
37 changes: 13 additions & 24 deletions trunk/drivers/net/cnic.c
Original file line number Diff line number Diff line change
Expand Up @@ -2860,8 +2860,8 @@ static int cnic_get_route(struct cnic_sock *csk, struct cnic_sockaddr *saddr)
{
struct cnic_dev *dev = csk->dev;
struct cnic_local *cp = dev->cnic_priv;
int is_v6, err, rc = -ENETUNREACH;
struct dst_entry *dst;
int is_v6, rc = 0;
struct dst_entry *dst = NULL;
struct net_device *realdev;
u32 local_port;

Expand All @@ -2877,39 +2877,31 @@ static int cnic_get_route(struct cnic_sock *csk, struct cnic_sockaddr *saddr)
clear_bit(SK_F_IPV6, &csk->flags);

if (is_v6) {
#if defined(CONFIG_IPV6) || (defined(CONFIG_IPV6_MODULE) && defined(MODULE))
set_bit(SK_F_IPV6, &csk->flags);
err = cnic_get_v6_route(&saddr->remote.v6, &dst);
if (err)
return err;

if (!dst || dst->error || !dst->dev)
goto err_out;
cnic_get_v6_route(&saddr->remote.v6, &dst);

memcpy(&csk->dst_ip[0], &saddr->remote.v6.sin6_addr,
sizeof(struct in6_addr));
csk->dst_port = saddr->remote.v6.sin6_port;
local_port = saddr->local.v6.sin6_port;
#else
return rc;
#endif

} else {
err = cnic_get_v4_route(&saddr->remote.v4, &dst);
if (err)
return err;

if (!dst || dst->error || !dst->dev)
goto err_out;
cnic_get_v4_route(&saddr->remote.v4, &dst);

csk->dst_ip[0] = saddr->remote.v4.sin_addr.s_addr;
csk->dst_port = saddr->remote.v4.sin_port;
local_port = saddr->local.v4.sin_port;
}

csk->vlan_id = cnic_get_vlan(dst->dev, &realdev);
if (realdev != dev->netdev)
goto err_out;
csk->vlan_id = 0;
csk->mtu = dev->netdev->mtu;
if (dst && dst->dev) {
u16 vlan = cnic_get_vlan(dst->dev, &realdev);
if (realdev == dev->netdev) {
csk->vlan_id = vlan;
csk->mtu = dst_mtu(dst);
}
}

if (local_port >= CNIC_LOCAL_PORT_MIN &&
local_port < CNIC_LOCAL_PORT_MAX) {
Expand All @@ -2927,9 +2919,6 @@ static int cnic_get_route(struct cnic_sock *csk, struct cnic_sockaddr *saddr)
}
csk->src_port = local_port;

csk->mtu = dst_mtu(dst);
rc = 0;

err_out:
dst_release(dst);
return rc;
Expand Down

0 comments on commit 4ea92d4

Please sign in to comment.