diff options
author | David S. Miller <davem@davemloft.net> | 2011-01-04 14:57:25 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2011-01-04 14:57:25 -0500 |
commit | dbbe68bb12b34f3e450da7a73c20e6fa1f85d63a (patch) | |
tree | 10f8363cbf5e428c0cb5614959e37b67a7e0cfa2 /net | |
parent | 7b26e5ebd8b27b0126a84ae7f9a42aa8293d6c48 (diff) | |
parent | 9fc3bbb4a752f108cf096d96640f3b548bbbce6c (diff) |
Merge branch 'master' of master.kernel.org:/pub/scm/linux/kernel/git/davem/net-2.6
Diffstat (limited to 'net')
-rw-r--r-- | net/bridge/br_multicast.c | 28 | ||||
-rw-r--r-- | net/bridge/br_stp_bpdu.c | 2 | ||||
-rw-r--r-- | net/can/bcm.c | 4 | ||||
-rw-r--r-- | net/ipv4/route.c | 8 |
4 files changed, 28 insertions, 14 deletions
diff --git a/net/bridge/br_multicast.c b/net/bridge/br_multicast.c index f03e2e98cd4..f701a21acb3 100644 --- a/net/bridge/br_multicast.c +++ b/net/bridge/br_multicast.c | |||
@@ -1451,7 +1451,7 @@ static int br_multicast_ipv6_rcv(struct net_bridge *br, | |||
1451 | struct net_bridge_port *port, | 1451 | struct net_bridge_port *port, |
1452 | struct sk_buff *skb) | 1452 | struct sk_buff *skb) |
1453 | { | 1453 | { |
1454 | struct sk_buff *skb2 = skb; | 1454 | struct sk_buff *skb2; |
1455 | struct ipv6hdr *ip6h; | 1455 | struct ipv6hdr *ip6h; |
1456 | struct icmp6hdr *icmp6h; | 1456 | struct icmp6hdr *icmp6h; |
1457 | u8 nexthdr; | 1457 | u8 nexthdr; |
@@ -1490,15 +1490,15 @@ static int br_multicast_ipv6_rcv(struct net_bridge *br, | |||
1490 | if (!skb2) | 1490 | if (!skb2) |
1491 | return -ENOMEM; | 1491 | return -ENOMEM; |
1492 | 1492 | ||
1493 | err = -EINVAL; | ||
1494 | if (!pskb_may_pull(skb2, offset + sizeof(struct icmp6hdr))) | ||
1495 | goto out; | ||
1496 | |||
1493 | len -= offset - skb_network_offset(skb2); | 1497 | len -= offset - skb_network_offset(skb2); |
1494 | 1498 | ||
1495 | __skb_pull(skb2, offset); | 1499 | __skb_pull(skb2, offset); |
1496 | skb_reset_transport_header(skb2); | 1500 | skb_reset_transport_header(skb2); |
1497 | 1501 | ||
1498 | err = -EINVAL; | ||
1499 | if (!pskb_may_pull(skb2, sizeof(*icmp6h))) | ||
1500 | goto out; | ||
1501 | |||
1502 | icmp6h = icmp6_hdr(skb2); | 1502 | icmp6h = icmp6_hdr(skb2); |
1503 | 1503 | ||
1504 | switch (icmp6h->icmp6_type) { | 1504 | switch (icmp6h->icmp6_type) { |
@@ -1537,7 +1537,12 @@ static int br_multicast_ipv6_rcv(struct net_bridge *br, | |||
1537 | switch (icmp6h->icmp6_type) { | 1537 | switch (icmp6h->icmp6_type) { |
1538 | case ICMPV6_MGM_REPORT: | 1538 | case ICMPV6_MGM_REPORT: |
1539 | { | 1539 | { |
1540 | struct mld_msg *mld = (struct mld_msg *)icmp6h; | 1540 | struct mld_msg *mld; |
1541 | if (!pskb_may_pull(skb2, sizeof(*mld))) { | ||
1542 | err = -EINVAL; | ||
1543 | goto out; | ||
1544 | } | ||
1545 | mld = (struct mld_msg *)skb_transport_header(skb2); | ||
1541 | BR_INPUT_SKB_CB(skb2)->mrouters_only = 1; | 1546 | BR_INPUT_SKB_CB(skb2)->mrouters_only = 1; |
1542 | err = br_ip6_multicast_add_group(br, port, &mld->mld_mca); | 1547 | err = br_ip6_multicast_add_group(br, port, &mld->mld_mca); |
1543 | break; | 1548 | break; |
@@ -1550,15 +1555,18 @@ static int br_multicast_ipv6_rcv(struct net_bridge *br, | |||
1550 | break; | 1555 | break; |
1551 | case ICMPV6_MGM_REDUCTION: | 1556 | case ICMPV6_MGM_REDUCTION: |
1552 | { | 1557 | { |
1553 | struct mld_msg *mld = (struct mld_msg *)icmp6h; | 1558 | struct mld_msg *mld; |
1559 | if (!pskb_may_pull(skb2, sizeof(*mld))) { | ||
1560 | err = -EINVAL; | ||
1561 | goto out; | ||
1562 | } | ||
1563 | mld = (struct mld_msg *)skb_transport_header(skb2); | ||
1554 | br_ip6_multicast_leave_group(br, port, &mld->mld_mca); | 1564 | br_ip6_multicast_leave_group(br, port, &mld->mld_mca); |
1555 | } | 1565 | } |
1556 | } | 1566 | } |
1557 | 1567 | ||
1558 | out: | 1568 | out: |
1559 | __skb_push(skb2, offset); | 1569 | kfree_skb(skb2); |
1560 | if (skb2 != skb) | ||
1561 | kfree_skb(skb2); | ||
1562 | return err; | 1570 | return err; |
1563 | } | 1571 | } |
1564 | #endif | 1572 | #endif |
diff --git a/net/bridge/br_stp_bpdu.c b/net/bridge/br_stp_bpdu.c index 3d9a55d3822..289646ec9b7 100644 --- a/net/bridge/br_stp_bpdu.c +++ b/net/bridge/br_stp_bpdu.c | |||
@@ -50,6 +50,8 @@ static void br_send_bpdu(struct net_bridge_port *p, | |||
50 | 50 | ||
51 | llc_mac_hdr_init(skb, p->dev->dev_addr, p->br->group_addr); | 51 | llc_mac_hdr_init(skb, p->dev->dev_addr, p->br->group_addr); |
52 | 52 | ||
53 | skb_reset_mac_header(skb); | ||
54 | |||
53 | NF_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_OUT, skb, NULL, skb->dev, | 55 | NF_HOOK(NFPROTO_BRIDGE, NF_BR_LOCAL_OUT, skb, NULL, skb->dev, |
54 | dev_queue_xmit); | 56 | dev_queue_xmit); |
55 | } | 57 | } |
diff --git a/net/can/bcm.c b/net/can/bcm.c index 6faa8256e10..9d5e8accfab 100644 --- a/net/can/bcm.c +++ b/net/can/bcm.c | |||
@@ -125,7 +125,7 @@ struct bcm_sock { | |||
125 | struct list_head tx_ops; | 125 | struct list_head tx_ops; |
126 | unsigned long dropped_usr_msgs; | 126 | unsigned long dropped_usr_msgs; |
127 | struct proc_dir_entry *bcm_proc_read; | 127 | struct proc_dir_entry *bcm_proc_read; |
128 | char procname [20]; /* pointer printed in ASCII with \0 */ | 128 | char procname [32]; /* inode number in decimal with \0 */ |
129 | }; | 129 | }; |
130 | 130 | ||
131 | static inline struct bcm_sock *bcm_sk(const struct sock *sk) | 131 | static inline struct bcm_sock *bcm_sk(const struct sock *sk) |
@@ -1521,7 +1521,7 @@ static int bcm_connect(struct socket *sock, struct sockaddr *uaddr, int len, | |||
1521 | 1521 | ||
1522 | if (proc_dir) { | 1522 | if (proc_dir) { |
1523 | /* unique socket address as filename */ | 1523 | /* unique socket address as filename */ |
1524 | sprintf(bo->procname, "%p", sock); | 1524 | sprintf(bo->procname, "%lu", sock_i_ino(sk)); |
1525 | bo->bcm_proc_read = proc_create_data(bo->procname, 0644, | 1525 | bo->bcm_proc_read = proc_create_data(bo->procname, 0644, |
1526 | proc_dir, | 1526 | proc_dir, |
1527 | &bcm_proc_fops, sk); | 1527 | &bcm_proc_fops, sk); |
diff --git a/net/ipv4/route.c b/net/ipv4/route.c index f1defb7d88e..351dc4e8524 100644 --- a/net/ipv4/route.c +++ b/net/ipv4/route.c | |||
@@ -2626,8 +2626,12 @@ static int ip_route_output_slow(struct net *net, struct rtable **rp, | |||
2626 | } | 2626 | } |
2627 | 2627 | ||
2628 | if (res.type == RTN_LOCAL) { | 2628 | if (res.type == RTN_LOCAL) { |
2629 | if (!fl.fl4_src) | 2629 | if (!fl.fl4_src) { |
2630 | fl.fl4_src = fl.fl4_dst; | 2630 | if (res.fi->fib_prefsrc) |
2631 | fl.fl4_src = res.fi->fib_prefsrc; | ||
2632 | else | ||
2633 | fl.fl4_src = fl.fl4_dst; | ||
2634 | } | ||
2631 | dev_out = net->loopback_dev; | 2635 | dev_out = net->loopback_dev; |
2632 | fl.oif = dev_out->ifindex; | 2636 | fl.oif = dev_out->ifindex; |
2633 | res.fi = NULL; | 2637 | res.fi = NULL; |