blob: 81643cf8a1c43ea5d7a61aba0722fd2c37e55f2c [file] [log] [blame]
Greg Kroah-Hartmanb2441312017-11-01 15:07:57 +01001/* SPDX-License-Identifier: GPL-2.0 */
Gregory CLEMENT8cb2d8b2016-03-14 09:39:04 +01002#ifndef _HWBM_H
3#define _HWBM_H
4
5struct hwbm_pool {
6 /* Capacity of the pool */
7 int size;
8 /* Size of the buffers managed */
9 int frag_size;
10 /* Number of buffers currently used by this pool */
11 int buf_num;
12 /* constructor called during alocation */
13 int (*construct)(struct hwbm_pool *bm_pool, void *buf);
14 /* protect acces to the buffer counter*/
Sebastian Andrzej Siewior6dcdd882019-06-07 21:20:40 +020015 struct mutex buf_lock;
Gregory CLEMENT8cb2d8b2016-03-14 09:39:04 +010016 /* private data */
17 void *priv;
18};
19#ifdef CONFIG_HWBM
20void hwbm_buf_free(struct hwbm_pool *bm_pool, void *buf);
21int hwbm_pool_refill(struct hwbm_pool *bm_pool, gfp_t gfp);
Sebastian Andrzej Siewior6dcdd882019-06-07 21:20:40 +020022int hwbm_pool_add(struct hwbm_pool *bm_pool, unsigned int buf_num);
Gregory CLEMENT8cb2d8b2016-03-14 09:39:04 +010023#else
24void hwbm_buf_free(struct hwbm_pool *bm_pool, void *buf) {}
25int hwbm_pool_refill(struct hwbm_pool *bm_pool, gfp_t gfp) { return 0; }
Sebastian Andrzej Siewior6dcdd882019-06-07 21:20:40 +020026int hwbm_pool_add(struct hwbm_pool *bm_pool, unsigned int buf_num)
Gregory CLEMENT8cb2d8b2016-03-14 09:39:04 +010027{ return 0; }
28#endif /* CONFIG_HWBM */
29#endif /* _HWBM_H */