diff options
| author | Olof Johansson <olof@lixom.net> | 2012-11-25 21:34:34 -0800 | 
|---|---|---|
| committer | Olof Johansson <olof@lixom.net> | 2012-11-25 21:34:34 -0800 | 
| commit | 0f9cb211ba5db93d488fe6b154138231fdd0e22d (patch) | |
| tree | 293871b042e9ebc49b1d783f1b110eef541ddc97 /net/ipv4/tcp_metrics.c | |
| parent | 007108a2279123ad6639b6c653ad1a731febb60f (diff) | |
| parent | 9489e9dcae718d5fde988e4a684a0f55b5f94d17 (diff) | |
| download | olio-linux-3.10-0f9cb211ba5db93d488fe6b154138231fdd0e22d.tar.xz olio-linux-3.10-0f9cb211ba5db93d488fe6b154138231fdd0e22d.zip  | |
Merge tag 'v3.7-rc7' into next/cleanup
Merging in mainline back to next/cleanup since it has collected a few
conflicts between fixes going upstream and some of the cleanup patches.
Git doesn't auto-resolve some of them, and they're mostly noise so let's
take care of it locally.
Conflicts are in:
	arch/arm/mach-omap2/omap_hwmod_44xx_data.c
	arch/arm/plat-omap/i2c.c
	drivers/video/omap2/dss/dss.c
Signed-off-by: Olof Johansson <olof@lixom.net>
Diffstat (limited to 'net/ipv4/tcp_metrics.c')
| -rw-r--r-- | net/ipv4/tcp_metrics.c | 12 | 
1 files changed, 9 insertions, 3 deletions
diff --git a/net/ipv4/tcp_metrics.c b/net/ipv4/tcp_metrics.c index 53bc5847bfa..f696d7c2e9f 100644 --- a/net/ipv4/tcp_metrics.c +++ b/net/ipv4/tcp_metrics.c @@ -1,7 +1,6 @@  #include <linux/rcupdate.h>  #include <linux/spinlock.h>  #include <linux/jiffies.h> -#include <linux/bootmem.h>  #include <linux/module.h>  #include <linux/cache.h>  #include <linux/slab.h> @@ -9,6 +8,7 @@  #include <linux/tcp.h>  #include <linux/hash.h>  #include <linux/tcp_metrics.h> +#include <linux/vmalloc.h>  #include <net/inet_connection_sock.h>  #include <net/net_namespace.h> @@ -1034,7 +1034,10 @@ static int __net_init tcp_net_metrics_init(struct net *net)  	net->ipv4.tcp_metrics_hash_log = order_base_2(slots);  	size = sizeof(struct tcpm_hash_bucket) << net->ipv4.tcp_metrics_hash_log; -	net->ipv4.tcp_metrics_hash = kzalloc(size, GFP_KERNEL); +	net->ipv4.tcp_metrics_hash = kzalloc(size, GFP_KERNEL | __GFP_NOWARN); +	if (!net->ipv4.tcp_metrics_hash) +		net->ipv4.tcp_metrics_hash = vzalloc(size); +  	if (!net->ipv4.tcp_metrics_hash)  		return -ENOMEM; @@ -1055,7 +1058,10 @@ static void __net_exit tcp_net_metrics_exit(struct net *net)  			tm = next;  		}  	} -	kfree(net->ipv4.tcp_metrics_hash); +	if (is_vmalloc_addr(net->ipv4.tcp_metrics_hash)) +		vfree(net->ipv4.tcp_metrics_hash); +	else +		kfree(net->ipv4.tcp_metrics_hash);  }  static __net_initdata struct pernet_operations tcp_net_metrics_ops = {  |