diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-12-27 13:40:30 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-12-27 13:40:30 -0500 |
commit | 7fd83b47cebb9e4fafab0ff9a058d2bebf29b8f5 (patch) | |
tree | eb669f55b4e144afd49349f4922b78009f938ccd /drivers/net | |
parent | ad4b3fb7ff9940bcdb1e4cd62bd189d10fa636ba (diff) | |
parent | ae782bb16c35ce27512beeda9be6024c88f85b08 (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
Pull networking fixes from David Miller:
1) GRE tunnel drivers don't set the transport header properly, they also
blindly deref the inner protocol ipv4 and needs some checks. Fixes
from Isaku Yamahata.
2) Fix sleeps while atomic in netdevice rename code, from Eric Dumazet.
3) Fix double-spinlock in solos-pci driver, from Dan Carpenter.
4) More ARP bug fixes. Fix lockdep splat in arp_solicit() and then the
bug accidentally added by that fix. From Eric Dumazet and Cong Wang.
5) Remove some __dev* annotations that slipped back in, as well as all
HOTPLUG references. From Greg KH
6) RDS protocol uses wrong interfaces to access scatter-gather elements,
causing a regression. From Mike Marciniszyn.
7) Fix build error in cpts driver, from Richard Cochran.
8) Fix arithmetic in packet scheduler, from Stefan Hasko.
9) Similarly, fix association during calculation of random backoff in
batman-adv. From Akinobu Mita.
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/net: (21 commits)
ipv6/ip6_gre: set transport header correctly
ipv4/ip_gre: set transport header correctly to gre header
IB/rds: suppress incompatible protocol when version is known
IB/rds: Correct ib_api use with gs_dma_address/sg_dma_len
net/vxlan: Use the underlying device index when joining/leaving multicast groups
tcp: should drop incoming frames without ACK flag set
netprio_cgroup: define sk_cgrp_prioidx only if NETPRIO_CGROUP is enabled
cpts: fix a run time warn_on.
cpts: fix build error by removing useless code.
batman-adv: fix random jitter calculation
arp: fix a regression in arp_solicit()
net: sched: integer overflow fix
CONFIG_HOTPLUG removal from networking core
Drivers: network: more __dev* removal
bridge: call br_netpoll_disable in br_add_if
ipv4: arp: fix a lockdep splat in arp_solicit()
tuntap: dont use a private kmem_cache
net: devnet_rename_seq should be a seqcount
ip_gre: fix possible use after free
ip_gre: make ipgre_tunnel_xmit() not parse network header as IP unconditionally
...
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/ethernet/marvell/mvmdio.c | 6 | ||||
-rw-r--r-- | drivers/net/ethernet/marvell/mvneta.c | 19 | ||||
-rw-r--r-- | drivers/net/ethernet/ti/cpts.c | 3 | ||||
-rw-r--r-- | drivers/net/ethernet/ti/cpts.h | 1 | ||||
-rw-r--r-- | drivers/net/tun.c | 24 | ||||
-rw-r--r-- | drivers/net/vxlan.c | 6 | ||||
-rw-r--r-- | drivers/net/wireless/rtlwifi/rtl8723ae/sw.c | 2 |
7 files changed, 21 insertions, 40 deletions
diff --git a/drivers/net/ethernet/marvell/mvmdio.c b/drivers/net/ethernet/marvell/mvmdio.c index 6d6002bab060..74f1c157a480 100644 --- a/drivers/net/ethernet/marvell/mvmdio.c +++ b/drivers/net/ethernet/marvell/mvmdio.c | |||
@@ -141,7 +141,7 @@ static int orion_mdio_reset(struct mii_bus *bus) | |||
141 | return 0; | 141 | return 0; |
142 | } | 142 | } |
143 | 143 | ||
144 | static int __devinit orion_mdio_probe(struct platform_device *pdev) | 144 | static int orion_mdio_probe(struct platform_device *pdev) |
145 | { | 145 | { |
146 | struct device_node *np = pdev->dev.of_node; | 146 | struct device_node *np = pdev->dev.of_node; |
147 | struct mii_bus *bus; | 147 | struct mii_bus *bus; |
@@ -197,7 +197,7 @@ static int __devinit orion_mdio_probe(struct platform_device *pdev) | |||
197 | return 0; | 197 | return 0; |
198 | } | 198 | } |
199 | 199 | ||
200 | static int __devexit orion_mdio_remove(struct platform_device *pdev) | 200 | static int orion_mdio_remove(struct platform_device *pdev) |
201 | { | 201 | { |
202 | struct mii_bus *bus = platform_get_drvdata(pdev); | 202 | struct mii_bus *bus = platform_get_drvdata(pdev); |
203 | mdiobus_unregister(bus); | 203 | mdiobus_unregister(bus); |
@@ -214,7 +214,7 @@ MODULE_DEVICE_TABLE(of, orion_mdio_match); | |||
214 | 214 | ||
215 | static struct platform_driver orion_mdio_driver = { | 215 | static struct platform_driver orion_mdio_driver = { |
216 | .probe = orion_mdio_probe, | 216 | .probe = orion_mdio_probe, |
217 | .remove = __devexit_p(orion_mdio_remove), | 217 | .remove = orion_mdio_remove, |
218 | .driver = { | 218 | .driver = { |
219 | .name = "orion-mdio", | 219 | .name = "orion-mdio", |
220 | .of_match_table = orion_mdio_match, | 220 | .of_match_table = orion_mdio_match, |
diff --git a/drivers/net/ethernet/marvell/mvneta.c b/drivers/net/ethernet/marvell/mvneta.c index 3f8086b9f5e5..b6025c305e10 100644 --- a/drivers/net/ethernet/marvell/mvneta.c +++ b/drivers/net/ethernet/marvell/mvneta.c | |||
@@ -635,7 +635,7 @@ static void mvneta_rxq_bm_disable(struct mvneta_port *pp, | |||
635 | 635 | ||
636 | 636 | ||
637 | /* Sets the RGMII Enable bit (RGMIIEn) in port MAC control register */ | 637 | /* Sets the RGMII Enable bit (RGMIIEn) in port MAC control register */ |
638 | static void __devinit mvneta_gmac_rgmii_set(struct mvneta_port *pp, int enable) | 638 | static void mvneta_gmac_rgmii_set(struct mvneta_port *pp, int enable) |
639 | { | 639 | { |
640 | u32 val; | 640 | u32 val; |
641 | 641 | ||
@@ -650,7 +650,7 @@ static void __devinit mvneta_gmac_rgmii_set(struct mvneta_port *pp, int enable) | |||
650 | } | 650 | } |
651 | 651 | ||
652 | /* Config SGMII port */ | 652 | /* Config SGMII port */ |
653 | static void __devinit mvneta_port_sgmii_config(struct mvneta_port *pp) | 653 | static void mvneta_port_sgmii_config(struct mvneta_port *pp) |
654 | { | 654 | { |
655 | u32 val; | 655 | u32 val; |
656 | 656 | ||
@@ -2564,7 +2564,7 @@ const struct ethtool_ops mvneta_eth_tool_ops = { | |||
2564 | }; | 2564 | }; |
2565 | 2565 | ||
2566 | /* Initialize hw */ | 2566 | /* Initialize hw */ |
2567 | static int __devinit mvneta_init(struct mvneta_port *pp, int phy_addr) | 2567 | static int mvneta_init(struct mvneta_port *pp, int phy_addr) |
2568 | { | 2568 | { |
2569 | int queue; | 2569 | int queue; |
2570 | 2570 | ||
@@ -2613,9 +2613,8 @@ static void mvneta_deinit(struct mvneta_port *pp) | |||
2613 | } | 2613 | } |
2614 | 2614 | ||
2615 | /* platform glue : initialize decoding windows */ | 2615 | /* platform glue : initialize decoding windows */ |
2616 | static void __devinit | 2616 | static void mvneta_conf_mbus_windows(struct mvneta_port *pp, |
2617 | mvneta_conf_mbus_windows(struct mvneta_port *pp, | 2617 | const struct mbus_dram_target_info *dram) |
2618 | const struct mbus_dram_target_info *dram) | ||
2619 | { | 2618 | { |
2620 | u32 win_enable; | 2619 | u32 win_enable; |
2621 | u32 win_protect; | 2620 | u32 win_protect; |
@@ -2648,7 +2647,7 @@ mvneta_conf_mbus_windows(struct mvneta_port *pp, | |||
2648 | } | 2647 | } |
2649 | 2648 | ||
2650 | /* Power up the port */ | 2649 | /* Power up the port */ |
2651 | static void __devinit mvneta_port_power_up(struct mvneta_port *pp, int phy_mode) | 2650 | static void mvneta_port_power_up(struct mvneta_port *pp, int phy_mode) |
2652 | { | 2651 | { |
2653 | u32 val; | 2652 | u32 val; |
2654 | 2653 | ||
@@ -2671,7 +2670,7 @@ static void __devinit mvneta_port_power_up(struct mvneta_port *pp, int phy_mode) | |||
2671 | } | 2670 | } |
2672 | 2671 | ||
2673 | /* Device initialization routine */ | 2672 | /* Device initialization routine */ |
2674 | static int __devinit mvneta_probe(struct platform_device *pdev) | 2673 | static int mvneta_probe(struct platform_device *pdev) |
2675 | { | 2674 | { |
2676 | const struct mbus_dram_target_info *dram_target_info; | 2675 | const struct mbus_dram_target_info *dram_target_info; |
2677 | struct device_node *dn = pdev->dev.of_node; | 2676 | struct device_node *dn = pdev->dev.of_node; |
@@ -2803,7 +2802,7 @@ err_free_netdev: | |||
2803 | } | 2802 | } |
2804 | 2803 | ||
2805 | /* Device removal routine */ | 2804 | /* Device removal routine */ |
2806 | static int __devexit mvneta_remove(struct platform_device *pdev) | 2805 | static int mvneta_remove(struct platform_device *pdev) |
2807 | { | 2806 | { |
2808 | struct net_device *dev = platform_get_drvdata(pdev); | 2807 | struct net_device *dev = platform_get_drvdata(pdev); |
2809 | struct mvneta_port *pp = netdev_priv(dev); | 2808 | struct mvneta_port *pp = netdev_priv(dev); |
@@ -2828,7 +2827,7 @@ MODULE_DEVICE_TABLE(of, mvneta_match); | |||
2828 | 2827 | ||
2829 | static struct platform_driver mvneta_driver = { | 2828 | static struct platform_driver mvneta_driver = { |
2830 | .probe = mvneta_probe, | 2829 | .probe = mvneta_probe, |
2831 | .remove = __devexit_p(mvneta_remove), | 2830 | .remove = mvneta_remove, |
2832 | .driver = { | 2831 | .driver = { |
2833 | .name = MVNETA_DRIVER_NAME, | 2832 | .name = MVNETA_DRIVER_NAME, |
2834 | .of_match_table = mvneta_match, | 2833 | .of_match_table = mvneta_match, |
diff --git a/drivers/net/ethernet/ti/cpts.c b/drivers/net/ethernet/ti/cpts.c index 5e62c1aeeffb..463597f919f1 100644 --- a/drivers/net/ethernet/ti/cpts.c +++ b/drivers/net/ethernet/ti/cpts.c | |||
@@ -247,8 +247,7 @@ static void cpts_clk_init(struct cpts *cpts) | |||
247 | cpts->refclk = NULL; | 247 | cpts->refclk = NULL; |
248 | return; | 248 | return; |
249 | } | 249 | } |
250 | clk_enable(cpts->refclk); | 250 | clk_prepare_enable(cpts->refclk); |
251 | cpts->freq = cpts->refclk->recalc(cpts->refclk); | ||
252 | } | 251 | } |
253 | 252 | ||
254 | static void cpts_clk_release(struct cpts *cpts) | 253 | static void cpts_clk_release(struct cpts *cpts) |
diff --git a/drivers/net/ethernet/ti/cpts.h b/drivers/net/ethernet/ti/cpts.h index e1bba3a496b2..fe993cdd7e23 100644 --- a/drivers/net/ethernet/ti/cpts.h +++ b/drivers/net/ethernet/ti/cpts.h | |||
@@ -120,7 +120,6 @@ struct cpts { | |||
120 | struct delayed_work overflow_work; | 120 | struct delayed_work overflow_work; |
121 | int phc_index; | 121 | int phc_index; |
122 | struct clk *refclk; | 122 | struct clk *refclk; |
123 | unsigned long freq; | ||
124 | struct list_head events; | 123 | struct list_head events; |
125 | struct list_head pool; | 124 | struct list_head pool; |
126 | struct cpts_event pool_data[CPTS_MAX_EVENTS]; | 125 | struct cpts_event pool_data[CPTS_MAX_EVENTS]; |
diff --git a/drivers/net/tun.c b/drivers/net/tun.c index 504f7f1cad94..fbd106edbe59 100644 --- a/drivers/net/tun.c +++ b/drivers/net/tun.c | |||
@@ -180,7 +180,6 @@ struct tun_struct { | |||
180 | int debug; | 180 | int debug; |
181 | #endif | 181 | #endif |
182 | spinlock_t lock; | 182 | spinlock_t lock; |
183 | struct kmem_cache *flow_cache; | ||
184 | struct hlist_head flows[TUN_NUM_FLOW_ENTRIES]; | 183 | struct hlist_head flows[TUN_NUM_FLOW_ENTRIES]; |
185 | struct timer_list flow_gc_timer; | 184 | struct timer_list flow_gc_timer; |
186 | unsigned long ageing_time; | 185 | unsigned long ageing_time; |
@@ -209,8 +208,8 @@ static struct tun_flow_entry *tun_flow_create(struct tun_struct *tun, | |||
209 | struct hlist_head *head, | 208 | struct hlist_head *head, |
210 | u32 rxhash, u16 queue_index) | 209 | u32 rxhash, u16 queue_index) |
211 | { | 210 | { |
212 | struct tun_flow_entry *e = kmem_cache_alloc(tun->flow_cache, | 211 | struct tun_flow_entry *e = kmalloc(sizeof(*e), GFP_ATOMIC); |
213 | GFP_ATOMIC); | 212 | |
214 | if (e) { | 213 | if (e) { |
215 | tun_debug(KERN_INFO, tun, "create flow: hash %u index %u\n", | 214 | tun_debug(KERN_INFO, tun, "create flow: hash %u index %u\n", |
216 | rxhash, queue_index); | 215 | rxhash, queue_index); |
@@ -223,19 +222,12 @@ static struct tun_flow_entry *tun_flow_create(struct tun_struct *tun, | |||
223 | return e; | 222 | return e; |
224 | } | 223 | } |
225 | 224 | ||
226 | static void tun_flow_free(struct rcu_head *head) | ||
227 | { | ||
228 | struct tun_flow_entry *e | ||
229 | = container_of(head, struct tun_flow_entry, rcu); | ||
230 | kmem_cache_free(e->tun->flow_cache, e); | ||
231 | } | ||
232 | |||
233 | static void tun_flow_delete(struct tun_struct *tun, struct tun_flow_entry *e) | 225 | static void tun_flow_delete(struct tun_struct *tun, struct tun_flow_entry *e) |
234 | { | 226 | { |
235 | tun_debug(KERN_INFO, tun, "delete flow: hash %u index %u\n", | 227 | tun_debug(KERN_INFO, tun, "delete flow: hash %u index %u\n", |
236 | e->rxhash, e->queue_index); | 228 | e->rxhash, e->queue_index); |
237 | hlist_del_rcu(&e->hash_link); | 229 | hlist_del_rcu(&e->hash_link); |
238 | call_rcu(&e->rcu, tun_flow_free); | 230 | kfree_rcu(e, rcu); |
239 | } | 231 | } |
240 | 232 | ||
241 | static void tun_flow_flush(struct tun_struct *tun) | 233 | static void tun_flow_flush(struct tun_struct *tun) |
@@ -833,12 +825,6 @@ static int tun_flow_init(struct tun_struct *tun) | |||
833 | { | 825 | { |
834 | int i; | 826 | int i; |
835 | 827 | ||
836 | tun->flow_cache = kmem_cache_create("tun_flow_cache", | ||
837 | sizeof(struct tun_flow_entry), 0, 0, | ||
838 | NULL); | ||
839 | if (!tun->flow_cache) | ||
840 | return -ENOMEM; | ||
841 | |||
842 | for (i = 0; i < TUN_NUM_FLOW_ENTRIES; i++) | 828 | for (i = 0; i < TUN_NUM_FLOW_ENTRIES; i++) |
843 | INIT_HLIST_HEAD(&tun->flows[i]); | 829 | INIT_HLIST_HEAD(&tun->flows[i]); |
844 | 830 | ||
@@ -854,10 +840,6 @@ static void tun_flow_uninit(struct tun_struct *tun) | |||
854 | { | 840 | { |
855 | del_timer_sync(&tun->flow_gc_timer); | 841 | del_timer_sync(&tun->flow_gc_timer); |
856 | tun_flow_flush(tun); | 842 | tun_flow_flush(tun); |
857 | |||
858 | /* Wait for completion of call_rcu()'s */ | ||
859 | rcu_barrier(); | ||
860 | kmem_cache_destroy(tun->flow_cache); | ||
861 | } | 843 | } |
862 | 844 | ||
863 | /* Initialize net device. */ | 845 | /* Initialize net device. */ |
diff --git a/drivers/net/vxlan.c b/drivers/net/vxlan.c index 3b3fdf648ea7..40f2cc135a49 100644 --- a/drivers/net/vxlan.c +++ b/drivers/net/vxlan.c | |||
@@ -505,7 +505,8 @@ static int vxlan_join_group(struct net_device *dev) | |||
505 | struct vxlan_net *vn = net_generic(dev_net(dev), vxlan_net_id); | 505 | struct vxlan_net *vn = net_generic(dev_net(dev), vxlan_net_id); |
506 | struct sock *sk = vn->sock->sk; | 506 | struct sock *sk = vn->sock->sk; |
507 | struct ip_mreqn mreq = { | 507 | struct ip_mreqn mreq = { |
508 | .imr_multiaddr.s_addr = vxlan->gaddr, | 508 | .imr_multiaddr.s_addr = vxlan->gaddr, |
509 | .imr_ifindex = vxlan->link, | ||
509 | }; | 510 | }; |
510 | int err; | 511 | int err; |
511 | 512 | ||
@@ -532,7 +533,8 @@ static int vxlan_leave_group(struct net_device *dev) | |||
532 | int err = 0; | 533 | int err = 0; |
533 | struct sock *sk = vn->sock->sk; | 534 | struct sock *sk = vn->sock->sk; |
534 | struct ip_mreqn mreq = { | 535 | struct ip_mreqn mreq = { |
535 | .imr_multiaddr.s_addr = vxlan->gaddr, | 536 | .imr_multiaddr.s_addr = vxlan->gaddr, |
537 | .imr_ifindex = vxlan->link, | ||
536 | }; | 538 | }; |
537 | 539 | ||
538 | /* Only leave group when last vxlan is done. */ | 540 | /* Only leave group when last vxlan is done. */ |
diff --git a/drivers/net/wireless/rtlwifi/rtl8723ae/sw.c b/drivers/net/wireless/rtlwifi/rtl8723ae/sw.c index 18b0bc51766b..bb7cc90bafb2 100644 --- a/drivers/net/wireless/rtlwifi/rtl8723ae/sw.c +++ b/drivers/net/wireless/rtlwifi/rtl8723ae/sw.c | |||
@@ -341,7 +341,7 @@ static struct rtl_hal_cfg rtl8723ae_hal_cfg = { | |||
341 | .maps[RTL_RC_HT_RATEMCS15] = DESC92_RATEMCS15, | 341 | .maps[RTL_RC_HT_RATEMCS15] = DESC92_RATEMCS15, |
342 | }; | 342 | }; |
343 | 343 | ||
344 | static struct pci_device_id rtl8723ae_pci_ids[] __devinitdata = { | 344 | static struct pci_device_id rtl8723ae_pci_ids[] = { |
345 | {RTL_PCI_DEVICE(PCI_VENDOR_ID_REALTEK, 0x8723, rtl8723ae_hal_cfg)}, | 345 | {RTL_PCI_DEVICE(PCI_VENDOR_ID_REALTEK, 0x8723, rtl8723ae_hal_cfg)}, |
346 | {}, | 346 | {}, |
347 | }; | 347 | }; |