starpu_stdlib.h 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2010-2015 Université de Bordeaux
  4. * Copyright (C) 2010, 2011, 2012, 2013 CNRS
  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)<<2)
  26. #define STARPU_MALLOC_NORECLAIM ((1ULL)<<3)
  27. #define STARPU_MEMORY_WAIT ((1ULL)<<4)
  28. #define STARPU_MEMORY_OVERFLOW ((1ULL)<<5)
  29. void starpu_malloc_set_align(size_t align);
  30. int starpu_malloc(void **A, size_t dim);
  31. int starpu_free(void *A);
  32. int starpu_malloc_flags(void **A, size_t dim, int flags);
  33. int starpu_free_flags(void *A, size_t dim, int flags);
  34. int starpu_memory_pin(void *addr, size_t size);
  35. int starpu_memory_unpin(void *addr, size_t size);
  36. starpu_ssize_t starpu_memory_get_total(unsigned node);
  37. starpu_ssize_t starpu_memory_get_available(unsigned node);
  38. void starpu_memory_wait_available(unsigned node, size_t size);
  39. /**
  40. * Try to allocate memory on the given node
  41. *
  42. * @param size amount of memory to allocate
  43. * @param node node where the memory is to be allocated
  44. * @return 1 if the given amount of memory was allocated on the given node
  45. */
  46. int starpu_memory_allocate(unsigned node, size_t size, int flags);
  47. /**
  48. * Indicates the given amount of memory is going to be deallocated from the given node
  49. *
  50. * @param size amount of memory to be deallocated
  51. * @param node node where the memory is going to be deallocated
  52. */
  53. void starpu_memory_deallocate(unsigned node, size_t size);
  54. #ifdef __cplusplus
  55. }
  56. #endif
  57. #endif /* __STARPU_STDLIB_H__ */