We forgot to use __GFP_HIGHMEM in several __vmalloc() calls. In ceph, add the missing flag. In fib_trie.c, xfrm_hash.c and request_sock.c, using vzalloc() is cleaner and allows using HIGHMEM pages as well. Signed-off-by: Eric Dumazet <eric.dumazet@gmail.com> Signed-off-by: David S. Miller <davem@davemloft.net>
		
			
				
	
	
		
			39 lines
		
	
	
	
		
			766 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			39 lines
		
	
	
	
		
			766 B
			
		
	
	
	
		
			C
		
	
	
	
	
	
/* xfrm_hash.c: Common hash table code.
 | 
						|
 *
 | 
						|
 * Copyright (C) 2006 David S. Miller (davem@davemloft.net)
 | 
						|
 */
 | 
						|
 | 
						|
#include <linux/kernel.h>
 | 
						|
#include <linux/mm.h>
 | 
						|
#include <linux/bootmem.h>
 | 
						|
#include <linux/vmalloc.h>
 | 
						|
#include <linux/slab.h>
 | 
						|
#include <linux/xfrm.h>
 | 
						|
 | 
						|
#include "xfrm_hash.h"
 | 
						|
 | 
						|
struct hlist_head *xfrm_hash_alloc(unsigned int sz)
 | 
						|
{
 | 
						|
	struct hlist_head *n;
 | 
						|
 | 
						|
	if (sz <= PAGE_SIZE)
 | 
						|
		n = kzalloc(sz, GFP_KERNEL);
 | 
						|
	else if (hashdist)
 | 
						|
		n = vzalloc(sz);
 | 
						|
	else
 | 
						|
		n = (struct hlist_head *)
 | 
						|
			__get_free_pages(GFP_KERNEL | __GFP_NOWARN | __GFP_ZERO,
 | 
						|
					 get_order(sz));
 | 
						|
 | 
						|
	return n;
 | 
						|
}
 | 
						|
 | 
						|
void xfrm_hash_free(struct hlist_head *n, unsigned int sz)
 | 
						|
{
 | 
						|
	if (sz <= PAGE_SIZE)
 | 
						|
		kfree(n);
 | 
						|
	else if (hashdist)
 | 
						|
		vfree(n);
 | 
						|
	else
 | 
						|
		free_pages((unsigned long)n, get_order(sz));
 | 
						|
}
 |