blob: eca8d84d99bf2297f3b212cae08f9105dcc78317 [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001// SPDX-License-Identifier: GPL-2.0
David S. Miller44e36b42006-08-24 04:50:50 -07002/* xfrm_hash.c: Common hash table code.
3 *
4 * Copyright (C) 2006 David S. Miller (davem@davemloft.net)
5 */
6
7#include <linux/kernel.h>
8#include <linux/mm.h>
Mike Rapoport57c8a662018-10-30 15:09:49 -07009#include <linux/memblock.h>
David S. Miller44e36b42006-08-24 04:50:50 -070010#include <linux/vmalloc.h>
11#include <linux/slab.h>
12#include <linux/xfrm.h>
13
14#include "xfrm_hash.h"
15
16struct hlist_head *xfrm_hash_alloc(unsigned int sz)
17{
18 struct hlist_head *n;
19
20 if (sz <= PAGE_SIZE)
Joonwoo Parkdcaee952007-11-26 23:23:21 +080021 n = kzalloc(sz, GFP_KERNEL);
David S. Miller44e36b42006-08-24 04:50:50 -070022 else if (hashdist)
Eric Dumazet7a1c8e52010-11-20 07:46:35 +000023 n = vzalloc(sz);
David S. Miller44e36b42006-08-24 04:50:50 -070024 else
25 n = (struct hlist_head *)
Joonwoo Parkdcaee952007-11-26 23:23:21 +080026 __get_free_pages(GFP_KERNEL | __GFP_NOWARN | __GFP_ZERO,
Herbert Xu6253db02007-05-14 02:19:11 -070027 get_order(sz));
David S. Miller44e36b42006-08-24 04:50:50 -070028
David S. Miller44e36b42006-08-24 04:50:50 -070029 return n;
30}
31
32void xfrm_hash_free(struct hlist_head *n, unsigned int sz)
33{
34 if (sz <= PAGE_SIZE)
35 kfree(n);
36 else if (hashdist)
37 vfree(n);
38 else
39 free_pages((unsigned long)n, get_order(sz));
40}