zsmalloc.h 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  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;
  34. struct zs_pool *zs_create_pool(gfp_t flags);
  35. void zs_destroy_pool(struct zs_pool *pool);
  36. unsigned long zs_malloc(struct zs_pool *pool, size_t size);
  37. void zs_free(struct zs_pool *pool, unsigned long obj);
  38. void *zs_map_object(struct zs_pool *pool, unsigned long handle,
  39. enum zs_mapmode mm);
  40. void zs_unmap_object(struct zs_pool *pool, unsigned long handle);
  41. unsigned long zs_get_total_pages(struct zs_pool *pool);
  42. #endif