12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879 |
- /* StarPU --- Runtime system for heterogeneous multicore architectures.
- *
- * Copyright (C) 2010-2016 Université de Bordeaux
- * Copyright (C) 2010, 2011, 2012, 2013, 2016 CNRS
- *
- * StarPU is free software; you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License as published by
- * the Free Software Foundation; either version 2.1 of the License, or (at
- * your option) any later version.
- *
- * StarPU is distributed in the hope that it will be useful, but
- * WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- *
- * See the GNU Lesser General Public License in COPYING.LGPL for more details.
- */
- #ifndef __STARPU_STDLIB_H__
- #define __STARPU_STDLIB_H__
- #include <starpu.h>
- #ifdef __cplusplus
- extern "C"
- {
- #endif
- #define STARPU_MALLOC_PINNED ((1ULL)<<1)
- #define STARPU_MALLOC_COUNT ((1ULL)<<2)
- #define STARPU_MALLOC_NORECLAIM ((1ULL)<<3)
- #define STARPU_MEMORY_WAIT ((1ULL)<<4)
- #define STARPU_MEMORY_OVERFLOW ((1ULL)<<5)
- #define STARPU_MALLOC_SIMULATION_FOLDED ((1ULL)<<6)
- void starpu_malloc_set_align(size_t align);
- int starpu_malloc(void **A, size_t dim) STARPU_ATTRIBUTE_ALLOC_SIZE(2);
- int starpu_free(void *A);
- int starpu_malloc_flags(void **A, size_t dim, int flags) STARPU_ATTRIBUTE_ALLOC_SIZE(2);
- int starpu_free_flags(void *A, size_t dim, int flags);
- int starpu_memory_pin(void *addr, size_t size);
- int starpu_memory_unpin(void *addr, size_t size);
- starpu_ssize_t starpu_memory_get_total(unsigned node);
- starpu_ssize_t starpu_memory_get_available(unsigned node);
- starpu_ssize_t starpu_memory_get_total_all_nodes();
- starpu_ssize_t starpu_memory_get_available_all_nodes();
- void starpu_memory_wait_available(unsigned node, size_t size);
- /**
- * Try to allocate memory on the given node
- *
- * @param size amount of memory to allocate
- * @param node node where the memory is to be allocated
- * @return 1 if the given amount of memory was allocated on the given node
- */
- int starpu_memory_allocate(unsigned node, size_t size, int flags);
- /**
- * Indicates the given amount of memory is going to be deallocated from the given node
- *
- * @param size amount of memory to be deallocated
- * @param node node where the memory is going to be deallocated
- */
- void starpu_memory_deallocate(unsigned node, size_t size);
- void starpu_sleep(float nb_sec);
- #ifdef __cplusplus
- }
- #endif
- #endif /* __STARPU_STDLIB_H__ */
|