StarPU Internal Handbook
disk.h
Go to the documentation of this file.
1 /* StarPU --- Runtime system for heterogeneous multicore architectures.
2  *
3  * Copyright (C) 2013-2021 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
4  * Copyright (C) 2013 Corentin Salingue
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 
18 #ifndef __DISK_H__
19 #define __DISK_H__
20 
23 #define STARPU_DISK_ALL 1
24 #define STARPU_DISK_NO_RECLAIM 2
25 
26 #ifdef __cplusplus
27 extern "C"
28 {
29 #endif
30 
31 #include <datawizard/copy_driver.h>
32 #include <datawizard/malloc.h>
33 
35 void * _starpu_disk_alloc (unsigned node, size_t size) STARPU_ATTRIBUTE_MALLOC;
36 
37 void _starpu_disk_free (unsigned node, void *obj, size_t size);
39 int _starpu_disk_read(unsigned src_node, unsigned dst_node, void *obj, void *buf, off_t offset, size_t size, struct _starpu_async_channel * async_channel);
41 int _starpu_disk_write(unsigned src_node, unsigned dst_node, void *obj, void *buf, off_t offset, size_t size, struct _starpu_async_channel * async_channel);
42 
43 int _starpu_disk_full_read(unsigned src_node, unsigned dst_node, void * obj, void ** ptr, size_t * size, struct _starpu_async_channel * async_channel);
44 int _starpu_disk_full_write(unsigned src_node, unsigned dst_node, void * obj, void * ptr, size_t size, struct _starpu_async_channel * async_channel);
45 
46 int _starpu_disk_copy(unsigned node_src, void* obj_src, off_t offset_src, unsigned node_dst, void* obj_dst, off_t offset_dst, size_t size, struct _starpu_async_channel * async_channel);
47 
49 void starpu_disk_wait_request(struct _starpu_async_channel *async_channel);
52 void starpu_disk_free_request(struct _starpu_async_channel *async_channel);
53 
55 int _starpu_disk_can_copy(unsigned node1, unsigned node2);
56 
58 void _starpu_set_disk_flag(unsigned node, int flag);
59 int _starpu_get_disk_flag(unsigned node);
60 
63 
64 void _starpu_swap_init(void);
65 
66 #ifdef __cplusplus
67 }
68 #endif
69 
70 #endif /* __DISK_H__ */
Definition: copy_driver.h:127
int starpu_disk_test_request(struct _starpu_async_channel *async_channel)
int _starpu_disk_write(unsigned src_node, unsigned dst_node, void *obj, void *buf, off_t offset, size_t size, struct _starpu_async_channel *async_channel)
void _starpu_set_disk_flag(unsigned node, int flag)
void starpu_disk_wait_request(struct _starpu_async_channel *async_channel)
void * _starpu_disk_alloc(unsigned node, size_t size) STARPU_ATTRIBUTE_MALLOC
void _starpu_disk_unregister(void)
int _starpu_disk_can_copy(unsigned node1, unsigned node2)
int _starpu_disk_read(unsigned src_node, unsigned dst_node, void *obj, void *buf, off_t offset, size_t size, struct _starpu_async_channel *async_channel)