helper.h 3.8 KB

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