Nitin Gupta | 61989a8 | 2012-01-09 16:51:56 -0600 | [diff] [blame] | 1 | /* |
| 2 | * zsmalloc memory allocator |
| 3 | * |
| 4 | * Copyright (C) 2011 Nitin Gupta |
Minchan Kim | 31fc00b | 2014-01-30 15:45:55 -0800 | [diff] [blame] | 5 | * Copyright (C) 2012, 2013 Minchan Kim |
Nitin Gupta | 61989a8 | 2012-01-09 16:51:56 -0600 | [diff] [blame] | 6 | * |
| 7 | * This code is released using a dual license strategy: BSD/GPL |
| 8 | * You can choose the license that better fits your requirements. |
| 9 | * |
| 10 | * Released under the terms of 3-clause BSD License |
| 11 | * Released under the terms of GNU General Public License Version 2.0 |
| 12 | */ |
| 13 | |
| 14 | #ifndef _ZS_MALLOC_H_ |
| 15 | #define _ZS_MALLOC_H_ |
| 16 | |
| 17 | #include <linux/types.h> |
| 18 | |
Seth Jennings | b741851 | 2012-07-02 16:15:52 -0500 | [diff] [blame] | 19 | /* |
| 20 | * zsmalloc mapping modes |
| 21 | * |
Nitin Cupta | c3e3e88 | 2013-12-11 11:04:37 +0900 | [diff] [blame] | 22 | * NOTE: These only make a difference when a mapped object spans pages. |
| 23 | * They also have no effect when PGTABLE_MAPPING is selected. |
Sara Bird | 396b7fd | 2013-05-20 15:18:14 -0400 | [diff] [blame] | 24 | */ |
Seth Jennings | b741851 | 2012-07-02 16:15:52 -0500 | [diff] [blame] | 25 | enum zs_mapmode { |
| 26 | ZS_MM_RW, /* normal read-write mapping */ |
| 27 | ZS_MM_RO, /* read-only (no copy-out at unmap time) */ |
| 28 | ZS_MM_WO /* write-only (no copy-in at map time) */ |
Nitin Cupta | c3e3e88 | 2013-12-11 11:04:37 +0900 | [diff] [blame] | 29 | /* |
| 30 | * NOTE: ZS_MM_WO should only be used for initializing new |
| 31 | * (uninitialized) allocations. Partial writes to already |
| 32 | * initialized allocations should use ZS_MM_RW to preserve the |
| 33 | * existing data. |
| 34 | */ |
Seth Jennings | b741851 | 2012-07-02 16:15:52 -0500 | [diff] [blame] | 35 | }; |
| 36 | |
Sergey Senozhatsky | 7d3f393 | 2015-09-08 15:04:35 -0700 | [diff] [blame] | 37 | struct zs_pool_stats { |
Sergey Senozhatsky | 860c707 | 2015-09-08 15:04:38 -0700 | [diff] [blame] | 38 | /* How many pages were migrated (freed) */ |
| 39 | unsigned long pages_compacted; |
Sergey Senozhatsky | 7d3f393 | 2015-09-08 15:04:35 -0700 | [diff] [blame] | 40 | }; |
| 41 | |
Nitin Gupta | 61989a8 | 2012-01-09 16:51:56 -0600 | [diff] [blame] | 42 | struct zs_pool; |
| 43 | |
Sergey Senozhatsky | d0d8da2 | 2016-05-20 16:59:48 -0700 | [diff] [blame] | 44 | struct zs_pool *zs_create_pool(const char *name); |
Nitin Gupta | 61989a8 | 2012-01-09 16:51:56 -0600 | [diff] [blame] | 45 | void zs_destroy_pool(struct zs_pool *pool); |
| 46 | |
Sergey Senozhatsky | d0d8da2 | 2016-05-20 16:59:48 -0700 | [diff] [blame] | 47 | unsigned long zs_malloc(struct zs_pool *pool, size_t size, gfp_t flags); |
Minchan Kim | c234434 | 2012-06-08 15:39:25 +0900 | [diff] [blame] | 48 | void zs_free(struct zs_pool *pool, unsigned long obj); |
Nitin Gupta | 61989a8 | 2012-01-09 16:51:56 -0600 | [diff] [blame] | 49 | |
Seth Jennings | b741851 | 2012-07-02 16:15:52 -0500 | [diff] [blame] | 50 | void *zs_map_object(struct zs_pool *pool, unsigned long handle, |
| 51 | enum zs_mapmode mm); |
Minchan Kim | c234434 | 2012-06-08 15:39:25 +0900 | [diff] [blame] | 52 | void zs_unmap_object(struct zs_pool *pool, unsigned long handle); |
Nitin Gupta | 61989a8 | 2012-01-09 16:51:56 -0600 | [diff] [blame] | 53 | |
Minchan Kim | 722cdc1 | 2014-10-09 15:29:50 -0700 | [diff] [blame] | 54 | unsigned long zs_get_total_pages(struct zs_pool *pool); |
Minchan Kim | 312fcae | 2015-04-15 16:15:30 -0700 | [diff] [blame] | 55 | unsigned long zs_compact(struct zs_pool *pool); |
Nitin Gupta | 61989a8 | 2012-01-09 16:51:56 -0600 | [diff] [blame] | 56 | |
Sergey Senozhatsky | 7d3f393 | 2015-09-08 15:04:35 -0700 | [diff] [blame] | 57 | void zs_pool_stats(struct zs_pool *pool, struct zs_pool_stats *stats); |
Nitin Gupta | 61989a8 | 2012-01-09 16:51:56 -0600 | [diff] [blame] | 58 | #endif |