data_interface.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /*
  2. * StarPU
  3. * Copyright (C) INRIA 2008-2009 (see AUTHORS file)
  4. *
  5. * This program is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU Lesser General Public License as published by
  7. * the Free Software Foundation; either version 2.1 of the License, or (at
  8. * your option) any later version.
  9. *
  10. * This program is distributed in the hope that it will be useful, but
  11. * WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  13. *
  14. * See the GNU Lesser General Public License in COPYING.LGPL for more details.
  15. */
  16. #ifndef __DATA_INTERFACE_H__
  17. #define __DATA_INTERFACE_H__
  18. #include <starpu.h>
  19. #include <common/config.h>
  20. #ifdef USE_GORDON
  21. /* to get the gordon_strideSize_t data structure from gordon */
  22. #include <gordon.h>
  23. #endif
  24. struct starpu_data_interface_ops_t {
  25. void (*register_data_handle)(starpu_data_handle handle,
  26. uint32_t home_node, void *interface);
  27. size_t (*allocate_data_on_node)(starpu_data_handle handle, uint32_t node);
  28. void (*liberate_data_on_node)(void *interface, uint32_t node);
  29. const struct copy_data_methods_s *copy_methods;
  30. size_t (*get_size)(starpu_data_handle handle);
  31. uint32_t (*footprint)(starpu_data_handle handle);
  32. void (*display)(starpu_data_handle handle, FILE *f);
  33. #ifdef USE_GORDON
  34. int (*convert_to_gordon)(void *interface, uint64_t *ptr, gordon_strideSize_t *ss);
  35. #endif
  36. /* an identifier that is unique to each interface */
  37. unsigned interfaceid;
  38. size_t interface_size;
  39. };
  40. void register_data_handle(starpu_data_handle *handleptr, uint32_t home_node,
  41. void *interface,
  42. struct starpu_data_interface_ops_t *ops);
  43. #endif // __DATA_INTERFACE_H__