17#ifndef __DATA_INTERFACE_H__
18#define __DATA_INTERFACE_H__
23#include <common/config.h>
29#pragma GCC visibility push(hidden)
37 struct starpu_variable_interface variable;
38 struct starpu_vector_interface vector;
39 struct starpu_matrix_interface matrix;
40 struct starpu_block_interface
block;
41 struct starpu_tensor_interface tensor;
42 struct starpu_csr_interface csr;
43 struct starpu_bcsr_interface bcsr;
44 struct starpu_coo_interface coo;
50void _starpu_data_free_interfaces(starpu_data_handle_t handle);
52extern int _starpu_data_handle_init(starpu_data_handle_t handle,
struct starpu_data_interface_ops *interface_ops,
unsigned int mf_node);
53void _starpu_data_initialize_per_worker(starpu_data_handle_t handle);
55extern struct starpu_arbiter *_starpu_global_arbiter;
56extern void _starpu_data_interface_init(
void);
57extern int __starpu_data_check_not_busy(starpu_data_handle_t handle) STARPU_ATTRIBUTE_WARN_UNUSED_RESULT;
58#define _starpu_data_check_not_busy(handle) \
59 (STARPU_UNLIKELY(!handle->busy_count && \
60 (handle->busy_waiting || handle->lazy_unregister)) ? \
61 __starpu_data_check_not_busy(handle) : 0)
62extern void _starpu_data_interface_shutdown(
void);
64struct starpu_data_interface_ops *_starpu_data_interface_get_ops(
unsigned interface_id) STARPU_ATTRIBUTE_VISIBILITY_DEFAULT;
66#define _starpu_data_is_multiformat_handle(handle) handle->ops->is_multiformat
68void _starpu_data_deinitialize_submit_noplan(starpu_data_handle_t handle);
70void _starpu_data_invalidate_submit_noplan(starpu_data_handle_t handle);
72#pragma GCC visibility pop
struct starpu_data_interface_ops starpu_interface_multiformat_ops
Definition data_interface.h:35