helper.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2011, 2012, 2013, 2016 CNRS
  4. *
  5. * StarPU 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. * StarPU 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 _TESTS_HELPER_H
  17. #define _TESTS_HELPER_H
  18. #include <errno.h>
  19. #include <common/utils.h>
  20. #ifdef STARPU_HAVE_VALGRIND_H
  21. #include <valgrind/valgrind.h>
  22. #endif
  23. #ifdef STARPU_HAVE_HELGRIND_H
  24. #include <valgrind/helgrind.h>
  25. #endif
  26. #define STARPU_TEST_SKIPPED 77
  27. //void *ALL_IS_OK = (void *)123456789L;
  28. //void *ALL_IS_NOT_OK = (void *)987654321L;
  29. //
  30. //#define STARPU_CHECK_MALLOC(ptr) {if (!ptr) { fprintf(stderr, "starpu_malloc failed\n"); return 1; }}
  31. //#define STARPU_CHECK_MALLOC_HAS_FAILED(ptr) {if (ptr) { fprintf(stderr, "starpu_malloc should have failed\n"); return 1; }}
  32. //#define STARPU_CHECK_MALLOC_THREAD(ptr) {if (!ptr) { fprintf(stderr, "starpu_malloc failed\n"); return ALL_IS_NOT_OK; }}
  33. //#define STARPU_CHECK_MALLOC_HAS_FAILED_THREAD(ptr) {if (ptr) { fprintf(stderr, "starpu_malloc should have failed\n"); return ALL_IS_NOT_OK; }}
  34. //#define STARPU_CHECK_RETURN_VALUE_THREAD(err, message) {if (err < 0) { perror(message); return ALL_IS_NOT_OK; }}
  35. //#define STARPU_CHECK_RETURN_VALUE_IS_THREAD(err, value, message) {if (err >= 0 || errno != value) { perror(message); return ALL_IS_NOT_OK; }}
  36. //#define STARPU_TEST_OUTPUT
  37. #define FPRINTF(ofile, fmt, ...) do { if (!getenv("STARPU_SSILENT")) {fprintf(ofile, fmt, ## __VA_ARGS__); }} while(0)
  38. #if defined(STARPU_HAVE_VALGRIND_H) && !defined(STARPU_VALGRIND_FULL)
  39. static int _starpu_valgrind_print_once STARPU_ATTRIBUTE_UNUSED = 0;
  40. # define STARPU_SKIP_IF_VALGRIND \
  41. do \
  42. { \
  43. if(STARPU_RUNNING_ON_VALGRIND) \
  44. { \
  45. STARPU_HG_DISABLE_CHECKING(_starpu_valgrind_print_once); \
  46. if (!_starpu_valgrind_print_once) \
  47. { \
  48. FPRINTF(stderr, "Running on valgrind, skipping the actual computations\n"); \
  49. _starpu_valgrind_print_once = 1; \
  50. } \
  51. return; \
  52. } \
  53. } while(0)
  54. # define STARPU_SKIP_IF_VALGRIND_RETURN_ZERO \
  55. do \
  56. { \
  57. if(STARPU_RUNNING_ON_VALGRIND) \
  58. { \
  59. STARPU_HG_DISABLE_CHECKING(_starpu_valgrind_print_once); \
  60. if (!_starpu_valgrind_print_once) \
  61. { \
  62. FPRINTF(stderr, "Running on valgrind, skipping the actual computations\n"); \
  63. _starpu_valgrind_print_once = 1; \
  64. } \
  65. return 0; \
  66. } \
  67. } while(0)
  68. # define STARPU_RETURN(ret) \
  69. do \
  70. { \
  71. if(STARPU_RUNNING_ON_VALGRIND) \
  72. { \
  73. FPRINTF(stderr, "Running on valgrind, ignoring return value\n"); \
  74. return 0; \
  75. } \
  76. else return ret; \
  77. } while(0)
  78. #else /* defined(STARPU_HAVE_VALGRIND_H) && !defined(STARPU_VALGRIND_FULL) */
  79. # define STARPU_RETURN(ret) return ret
  80. # define STARPU_SKIP_IF_VALGRIND
  81. # define STARPU_SKIP_IF_VALGRIND_RETURN_ZERO
  82. #endif /* defined(STARPU_HAVE_VALGRIND_H) && !defined(STARPU_VALGRIND_FULL) */
  83. #ifndef ANNOTATE_HAPPENS_BEFORE
  84. #define ANNOTATE_HAPPENS_BEFORE(obj) ((void)0)
  85. #endif
  86. #ifndef ANNOTATE_HAPPENS_BEFORE_FORGET_ALL
  87. #define ANNOTATE_HAPPENS_BEFORE_FORGET_ALL(obj) ((void)0)
  88. #endif
  89. #ifndef ANNOTATE_HAPPENS_AFTER
  90. #define ANNOTATE_HAPPENS_AFTER(obj) ((void)0)
  91. #endif
  92. #endif /* _TESTS_HELPER_H */