Arquivos
hhvm/hphp/util/lock.cpp
T
Tim Starling 998951619f update copyright date
We did not intend to imply our copyrights last forever

Closes #759
2013-06-03 12:43:56 -07:00

66 linhas
2.4 KiB
C++

/*
+----------------------------------------------------------------------+
| HipHop for PHP |
+----------------------------------------------------------------------+
| Copyright (c) 2010-2013 Facebook, Inc. (http://www.facebook.com) |
+----------------------------------------------------------------------+
| This source file is subject to version 3.01 of the PHP license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.php.net/license/3_01.txt |
| If you did not receive a copy of the PHP license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| license@php.net so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
*/
#include "hphp/util/lock.h"
#include "hphp/util/stack_trace.h"
namespace HPHP {
///////////////////////////////////////////////////////////////////////////////
LockProfiler::PFUNC_PROFILE LockProfiler::s_pfunc_profile = nullptr;
bool LockProfiler::s_profile = false;
int LockProfiler::s_profile_sampling = 1000;
LockProfiler::LockProfiler(bool profile) : m_profiling(false) {
if (s_profile && s_pfunc_profile && profile &&
s_profile_sampling && (rand() % s_profile_sampling) == 0) {
m_profiling = true;
#if defined(__APPLE__)
gettimeofday(&m_lockTime, nullptr);
#else
clock_gettime(CLOCK_MONOTONIC, &m_lockTime);
#endif
}
}
LockProfiler::~LockProfiler() {
if (m_profiling) {
#if defined(__APPLE__)
timeval unlockTime;
unlockTime.tv_sec = 0;
unlockTime.tv_usec = 0;
gettimeofday(&unlockTime, nullptr);
time_t dsec = unlockTime.tv_sec - m_lockTime.tv_sec;
long dnsec = unlockTime.tv_usec - m_lockTime.tv_usec;
int64_t dusec = dsec * 1000000 + dnsec;
#else
timespec unlockTime;
unlockTime.tv_sec = 0;
unlockTime.tv_nsec = 0;
clock_gettime(CLOCK_MONOTONIC, &unlockTime);
time_t dsec = unlockTime.tv_sec - m_lockTime.tv_sec;
long dnsec = unlockTime.tv_nsec - m_lockTime.tv_nsec;
int64_t dusec = dsec * 1000000 + dnsec / 1000;
#endif
StackTrace st;
s_pfunc_profile(st.hexEncode(3, 9), dusec);
}
}
///////////////////////////////////////////////////////////////////////////////
}