Source code
Revision control
Copy as Markdown
Other Tools
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
#ifndef ProfilerThreadPlatformData_h
#define ProfilerThreadPlatformData_h
#include "mozilla/ProfilerUtils.h"
#if defined(__APPLE__)
# include <mach/mach_types.h>
#elif defined(__linux__) || defined(__ANDROID__) || defined(__FreeBSD__)
# include "mozilla/Maybe.h"
# include <time.h>
#endif
namespace mozilla::profiler {
class PlatformData {
#if (defined(_MSC_VER) || defined(__MINGW32__)) && defined(MOZ_GECKO_PROFILER)
public:
explicit PlatformData(ProfilerThreadId aThreadId);
~PlatformData();
// Faking win32's HANDLE, because #including "windows.h" here causes trouble
// (e.g., it #defines `Yield` as nothing!)
// This type is static_check'ed against HANDLE in platform-win32.cpp.
using WindowsHandle = void*;
WindowsHandle ProfiledThread() const { return mProfiledThread; }
private:
WindowsHandle mProfiledThread;
#elif defined(__APPLE__) && defined(MOZ_GECKO_PROFILER)
public:
explicit PlatformData(ProfilerThreadId aThreadId);
~PlatformData();
thread_act_t ProfiledThread() const { return mProfiledThread; }
private:
// Note: for mProfiledThread Mach primitives are used instead of pthread's
// because the latter doesn't provide thread manipulation primitives
// required. For details, consult "Mac OS X Internals" book, Section 7.3.
thread_act_t mProfiledThread;
#elif (defined(__linux__) || defined(__ANDROID__) || defined(__FreeBSD__)) && \
defined(MOZ_GECKO_PROFILER)
public:
explicit PlatformData(ProfilerThreadId aThreadId);
~PlatformData();
// Clock Id for this profiled thread. `Nothing` if `pthread_getcpuclockid`
// failed (e.g., if the system doesn't support per-thread clocks).
Maybe<clockid_t> GetClockId() const { return mClockId; }
private:
Maybe<clockid_t> mClockId;
#else
public:
explicit PlatformData(ProfilerThreadId aThreadId) {}
#endif
};
/**
* Return the number of nanoseconds of CPU time used since thread start.
*
* @return true on success.
*/
#if defined(MOZ_GECKO_PROFILER)
bool GetCpuTimeSinceThreadStartInNs(uint64_t* aResult,
const PlatformData& aPlatformData);
#else
static inline bool GetCpuTimeSinceThreadStartInNs(
uint64_t* aResult, const PlatformData& aPlatformData) {
return false;
}
#endif
} // namespace mozilla::profiler
#endif // ProfilerThreadPlatformData_h