blob: 3c76553cfe571f8e1ed427bc56154f0c7e000f4e [file] [log] [blame]
Thomas Gleixner25763b32019-05-28 10:10:09 -07001/* SPDX-License-Identifier: GPL-2.0-only */
Alexei Starovoitove19494e2016-03-07 21:57:14 -08002/* Copyright (c) 2016 Facebook
Alexei Starovoitove19494e2016-03-07 21:57:14 -08003 */
4#ifndef __PERCPU_FREELIST_H__
5#define __PERCPU_FREELIST_H__
6#include <linux/spinlock.h>
7#include <linux/percpu.h>
8
9struct pcpu_freelist_head {
10 struct pcpu_freelist_node *first;
11 raw_spinlock_t lock;
12};
13
14struct pcpu_freelist {
15 struct pcpu_freelist_head __percpu *freelist;
Song Liu39d8f0d2020-10-05 09:58:38 -070016 struct pcpu_freelist_head extralist;
Alexei Starovoitove19494e2016-03-07 21:57:14 -080017};
18
19struct pcpu_freelist_node {
20 struct pcpu_freelist_node *next;
21};
22
Alexei Starovoitova89fac52019-01-30 18:12:43 -080023/* pcpu_freelist_* do spin_lock_irqsave. */
Alexei Starovoitove19494e2016-03-07 21:57:14 -080024void pcpu_freelist_push(struct pcpu_freelist *, struct pcpu_freelist_node *);
25struct pcpu_freelist_node *pcpu_freelist_pop(struct pcpu_freelist *);
Alexei Starovoitova89fac52019-01-30 18:12:43 -080026/* __pcpu_freelist_* do spin_lock only. caller must disable irqs. */
27void __pcpu_freelist_push(struct pcpu_freelist *, struct pcpu_freelist_node *);
28struct pcpu_freelist_node *__pcpu_freelist_pop(struct pcpu_freelist *);
Alexei Starovoitove19494e2016-03-07 21:57:14 -080029void pcpu_freelist_populate(struct pcpu_freelist *s, void *buf, u32 elem_size,
30 u32 nr_elems);
31int pcpu_freelist_init(struct pcpu_freelist *);
32void pcpu_freelist_destroy(struct pcpu_freelist *s);
33#endif