summaryrefslogtreecommitdiffstats
path: root/src/rocksdb/test_util/mock_time_env.cc
blob: 23888e69e3f9550e9661df4d4ab57e515ceb3084 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
// Copyright (c) 2011-present, Facebook, Inc.  All rights reserved.
//  This source code is licensed under both the GPLv2 (found in the
//  COPYING file in the root directory) and Apache 2.0 License
//  (found in the LICENSE.Apache file in the root directory).

#include "test_util/mock_time_env.h"

#include "test_util/sync_point.h"

namespace ROCKSDB_NAMESPACE {

// TODO: this is a workaround for the different behavior on different platform
// for timedwait timeout. Ideally timedwait API should be moved to env.
// details: PR #7101.
void MockSystemClock::InstallTimedWaitFixCallback() {
#ifndef NDEBUG
  SyncPoint::GetInstance()->DisableProcessing();
  SyncPoint::GetInstance()->ClearAllCallBacks();
#ifdef OS_MACOSX
  // This is an alternate way (vs. SpecialEnv) of dealing with the fact
  // that on some platforms, pthread_cond_timedwait does not appear to
  // release the lock for other threads to operate if the deadline time
  // is already passed. (TimedWait calls are currently a bad abstraction
  // because the deadline parameter is usually computed from Env time,
  // but is interpreted in real clock time.)
  SyncPoint::GetInstance()->SetCallBack(
      "InstrumentedCondVar::TimedWaitInternal", [&](void* arg) {
        uint64_t time_us = *reinterpret_cast<uint64_t*>(arg);
        if (time_us < this->RealNowMicros()) {
          *reinterpret_cast<uint64_t*>(arg) = this->RealNowMicros() + 1000;
        }
      });
#endif  // OS_MACOSX
  SyncPoint::GetInstance()->EnableProcessing();
#endif  // !NDEBUG
}

}  // namespace ROCKSDB_NAMESPACE