starpu_stdlib.h 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2010-2014 Université de Bordeaux
  4. * Copyright (C) 2010, 2011, 2012, 2013 Centre National de la Recherche Scientifique
  5. *
  6. * StarPU is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU Lesser General Public License as published by
  8. * the Free Software Foundation; either version 2.1 of the License, or (at
  9. * your option) any later version.
  10. *
  11. * StarPU is distributed in the hope that it will be useful, but
  12. * WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  14. *
  15. * See the GNU Lesser General Public License in COPYING.LGPL for more details.
  16. */
  17. #ifndef __STARPU_STDLIB_H__
  18. #define __STARPU_STDLIB_H__
  19. #include <starpu.h>
  20. #ifdef __cplusplus
  21. extern "C"
  22. {
  23. #endif
  24. #define STARPU_MALLOC_PINNED ((1ULL)<<1)
  25. #define STARPU_MALLOC_COUNT ((1ULL)<<3)
  26. #define STARPU_MALLOC_NORECLAIM ((1ULL)<<4)
  27. void starpu_malloc_set_align(size_t align);
  28. int starpu_malloc(void **A, size_t dim);
  29. int starpu_free(void *A);
  30. int starpu_malloc_flags(void **A, size_t dim, int flags);
  31. int starpu_free_flags(void *A, size_t dim, int flags);
  32. starpu_ssize_t starpu_memory_get_total(unsigned node);
  33. starpu_ssize_t starpu_memory_get_available(unsigned node);
  34. #define STARPU_MEMORY_WAIT (1)
  35. #define STARPU_MEMORY_OVERFLOW (2)
  36. /**
  37. * Try to allocate memory on the given node
  38. *
  39. * @param size amount of memory to allocate
  40. * @param node node where the memory is to be allocated
  41. * @return 1 if the given amount of memory was allocated on the given node
  42. */
  43. int starpu_memory_allocate(unsigned node, size_t size, int flags);
  44. /**
  45. * Indicates the given amount of memory is going to be deallocated from the given node
  46. *
  47. * @param size amount of memory to be deallocated
  48. * @param node node where the memory is going to be deallocated
  49. */
  50. void starpu_memory_deallocate(unsigned node, size_t size);
  51. #ifdef __cplusplus
  52. }
  53. #endif
  54. #endif /* __STARPU_STDLIB_H__ */