zsmalloc.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. /*
  2. * zsmalloc memory allocator
  3. *
  4. * Copyright (C) 2011 Nitin Gupta
  5. * Copyright (C) 2012, 2013 Minchan Kim
  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. #ifndef _ZS_MALLOC_H_
  14. #define _ZS_MALLOC_H_
  15. #include <linux/types.h>
  16. /*
  17. * zsmalloc mapping modes
  18. *
  19. * NOTE: These only make a difference when a mapped object spans pages.
  20. * They also have no effect when PGTABLE_MAPPING is selected.
  21. */
  22. enum zs_mapmode {
  23. ZS_MM_RW, /* normal read-write mapping */
  24. ZS_MM_RO, /* read-only (no copy-out at unmap time) */
  25. ZS_MM_WO /* write-only (no copy-in at map time) */
  26. /*
  27. * NOTE: ZS_MM_WO should only be used for initializing new
  28. * (uninitialized) allocations. Partial writes to already
  29. * initialized allocations should use ZS_MM_RW to preserve the
  30. * existing data.
  31. */
  32. };
  33. struct zs_pool_stats {
  34. /* How many pages were migrated (freed) */
  35. unsigned long pages_compacted;
  36. };
  37. struct zs_pool;
  38. struct zs_pool *zs_create_pool(const char *name);
  39. void zs_destroy_pool(struct zs_pool *pool);
  40. unsigned long zs_malloc(struct zs_pool *pool, size_t size, gfp_t flags);
  41. void zs_free(struct zs_pool *pool, unsigned long obj);
  42. void *zs_map_object(struct zs_pool *pool, unsigned long handle,
  43. enum zs_mapmode mm);
  44. void zs_unmap_object(struct zs_pool *pool, unsigned long handle);
  45. unsigned long zs_get_total_pages(struct zs_pool *pool);
  46. unsigned long zs_compact(struct zs_pool *pool);
  47. void zs_pool_stats(struct zs_pool *pool, struct zs_pool_stats *stats);
  48. #endif