PthreadMocks.cc 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. /**
  2. * Licensed to the Apache Software Foundation (ASF) under one
  3. * or more contributor license agreements. See the NOTICE file
  4. * distributed with this work for additional information
  5. * regarding copyright ownership. The ASF licenses this file
  6. * to you under the Apache License, Version 2.0 (the
  7. * "License"); you may not use this file except in compliance
  8. * with the License. You may obtain a copy of the License at
  9. *
  10. * http://www.apache.org/licenses/LICENSE-2.0
  11. *
  12. * Unless required by applicable law or agreed to in writing, software
  13. * distributed under the License is distributed on an "AS IS" BASIS,
  14. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  15. * See the License for the specific language governing permissions and
  16. * limitations under the License.
  17. */
  18. #include "PthreadMocks.h"
  19. MockPthreadsBase* MockPthreadsBase::mock_=0;
  20. #undef USING_DUMA
  21. #ifndef USING_DUMA
  22. int pthread_cond_broadcast (pthread_cond_t *c){
  23. if(!MockPthreadsBase::mock_)
  24. return LIBC_SYMBOLS.pthread_cond_broadcast(c);
  25. return MockPthreadsBase::mock_->pthread_cond_broadcast(c);
  26. }
  27. int pthread_cond_destroy (pthread_cond_t *c){
  28. if(!MockPthreadsBase::mock_)
  29. return LIBC_SYMBOLS.pthread_cond_destroy(c);
  30. return MockPthreadsBase::mock_->pthread_cond_destroy(c);
  31. }
  32. int pthread_cond_init (pthread_cond_t *c, const pthread_condattr_t *a){
  33. if(!MockPthreadsBase::mock_)
  34. return LIBC_SYMBOLS.pthread_cond_init(c,a);
  35. return MockPthreadsBase::mock_->pthread_cond_init(c,a);
  36. }
  37. int pthread_cond_signal (pthread_cond_t *c){
  38. if(!MockPthreadsBase::mock_)
  39. return LIBC_SYMBOLS.pthread_cond_signal(c);
  40. return MockPthreadsBase::mock_->pthread_cond_signal(c);
  41. }
  42. int pthread_cond_timedwait (pthread_cond_t *c,
  43. pthread_mutex_t *m, const struct timespec *t){
  44. if(!MockPthreadsBase::mock_)
  45. return LIBC_SYMBOLS.pthread_cond_timedwait(c,m,t);
  46. return MockPthreadsBase::mock_->pthread_cond_timedwait(c,m,t);
  47. }
  48. int pthread_cond_wait (pthread_cond_t *c, pthread_mutex_t *m){
  49. if(!MockPthreadsBase::mock_)
  50. return LIBC_SYMBOLS.pthread_cond_wait(c,m);
  51. return MockPthreadsBase::mock_->pthread_cond_wait(c,m);
  52. }
  53. int pthread_create (pthread_t *t, const pthread_attr_t *a,
  54. void *(*f)(void *), void *d){
  55. if(!MockPthreadsBase::mock_)
  56. return LIBC_SYMBOLS.pthread_create(t,a,f,d);
  57. return MockPthreadsBase::mock_->pthread_create(t,a,f,d);
  58. }
  59. int pthread_detach(pthread_t t){
  60. if(!MockPthreadsBase::mock_)
  61. return LIBC_SYMBOLS.pthread_detach(t);
  62. return MockPthreadsBase::mock_->pthread_detach(t);
  63. }
  64. int pthread_join (pthread_t t, void **r){
  65. if(!MockPthreadsBase::mock_)
  66. return LIBC_SYMBOLS.pthread_join(t,r);
  67. return MockPthreadsBase::mock_->pthread_join(t,r);
  68. }
  69. int pthread_mutex_destroy (pthread_mutex_t *m){
  70. if(!MockPthreadsBase::mock_)
  71. return LIBC_SYMBOLS.pthread_mutex_destroy(m);
  72. return MockPthreadsBase::mock_->pthread_mutex_destroy(m);
  73. }
  74. int pthread_mutex_init (pthread_mutex_t *m, const pthread_mutexattr_t *a){
  75. if(!MockPthreadsBase::mock_)
  76. return LIBC_SYMBOLS.pthread_mutex_init(m,a);
  77. return MockPthreadsBase::mock_->pthread_mutex_init(m,a);
  78. }
  79. DECLARE_WRAPPER(int,pthread_mutex_lock,(pthread_mutex_t *m)){
  80. if(!MockPthreadsBase::mock_)
  81. return CALL_REAL(pthread_mutex_lock,(m));
  82. return MockPthreadsBase::mock_->pthread_mutex_lock(m);
  83. }
  84. int pthread_mutex_trylock (pthread_mutex_t *m){
  85. if(!MockPthreadsBase::mock_)
  86. return LIBC_SYMBOLS.pthread_mutex_trylock(m);
  87. return MockPthreadsBase::mock_->pthread_mutex_trylock(m);
  88. }
  89. DECLARE_WRAPPER(int,pthread_mutex_unlock,(pthread_mutex_t *m)){
  90. if(!MockPthreadsBase::mock_)
  91. return CALL_REAL(pthread_mutex_unlock,(m));
  92. return MockPthreadsBase::mock_->pthread_mutex_unlock(m);
  93. }
  94. #endif
  95. CheckedPthread::ThreadMap CheckedPthread::tmap_;
  96. CheckedPthread::MutexMap CheckedPthread::mmap_;
  97. CheckedPthread::CVMap CheckedPthread::cvmap_;
  98. Mutex CheckedPthread::mx;