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. */
  21. enum zs_mapmode {
  22. ZS_MM_RW, /* normal read-write mapping */
  23. ZS_MM_RO, /* read-only (no copy-out at unmap time) */
  24. ZS_MM_WO /* write-only (no copy-in at map time) */
  25. /*
  26. * NOTE: ZS_MM_WO should only be used for initializing new
  27. * (uninitialized) allocations. Partial writes to already
  28. * initialized allocations should use ZS_MM_RW to preserve the
  29. * existing data.
  30. */
  31. };
  32. struct zs_pool_stats {
  33. /* How many pages were migrated (freed) */
  34. atomic_long_t pages_compacted;
  35. };
  36. struct zs_pool;
  37. struct zs_pool *zs_create_pool(const char *name);
  38. void zs_destroy_pool(struct zs_pool *pool);
  39. unsigned long zs_malloc(struct zs_pool *pool, size_t size, gfp_t flags);
  40. void zs_free(struct zs_pool *pool, unsigned long obj);
  41. size_t zs_huge_class_size(struct zs_pool *pool);
  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