starpu_stdlib.h 2.4 KB

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