Jolt Physics
A multi core friendly Game Physics Engine
Loading...
Searching...
No Matches
Profiler.inl
Go to the documentation of this file.
1// Jolt Physics Library (https://github.com/jrouwe/JoltPhysics)
2// SPDX-FileCopyrightText: 2021 Jorrit Rouwe
3// SPDX-License-Identifier: MIT
4
6
8// ProfileThread
10
11ProfileThread::ProfileThread(const string_view &inThreadName) :
12 mThreadName(inThreadName)
13{
15}
16
21
23// ProfileMeasurement
25
27{
29 if (current_thread == nullptr)
30 {
31 // Thread not instrumented
32 mSample = nullptr;
33 }
34 else if (current_thread->mCurrentSample < ProfileThread::cMaxSamples)
35 {
36 // Get pointer to write data to
37 mSample = &current_thread->mSamples[current_thread->mCurrentSample++];
38
39 // Start constructing sample (will end up on stack)
40 mTemp.mName = inName;
41 mTemp.mColor = inColor;
42
43 // Collect start sample last
45 }
46 else
47 {
48 // Out of samples
49 if (!sOutOfSamplesReported)
50 {
51 Trace("ProfileMeasurement: Too many samples, some data will be lost!");
52 sOutOfSamplesReported = true;
53 }
54 mSample = nullptr;
55 }
56}
57
59{
60 if (mSample != nullptr)
61 {
62 // Finalize sample
64
65 // Write it to the memory buffer bypassing the cache
66 static_assert(sizeof(ProfileSample) == 32, "Assume 32 bytes");
67 static_assert(alignof(ProfileSample) == 16, "Assume 16 byte alignment");
68 #if defined(JPH_USE_SSE)
69 const __m128i *src = reinterpret_cast<const __m128i *>(&mTemp);
70 __m128i *dst = reinterpret_cast<__m128i *>(mSample);
71 __m128i val = _mm_loadu_si128(src);
72 _mm_stream_si128(dst, val);
73 val = _mm_loadu_si128(src + 1);
74 _mm_stream_si128(dst + 1, val);
75 #elif defined(JPH_USE_NEON)
76 const int *src = reinterpret_cast<const int *>(&mTemp);
77 int *dst = reinterpret_cast<int *>(mSample);
78 int32x4_t val = vld1q_s32(src);
79 vst1q_s32(dst, val);
80 val = vld1q_s32(src + 4);
81 vst1q_s32(dst + 4, val);
82 #else
83 memcpy(mSample, &mTemp, sizeof(ProfileSample));
84 #endif
85 mSample = nullptr;
86 }
87}
88
#define JPH_NAMESPACE_END
Definition Core.h:379
std::uint32_t uint32
Definition Core.h:456
#define JPH_NAMESPACE_BEGIN
Definition Core.h:373
TraceFunction Trace
Definition IssueReporting.cpp:18
JPH_NAMESPACE_BEGIN JPH_INLINE uint64 GetProcessorTickCount()
Functionality to get the processors cycle counter.
Definition TickCounter.h:26
ProfileMeasurement(const char *inName, uint32 inColor=0)
Constructor.
Definition Profiler.inl:26
~ProfileMeasurement()
Definition Profiler.inl:58
Definition Profiler.h:187
uint32 mColor
Color to use for this sample.
Definition Profiler.h:192
uint64 mEndCycle
Cycle counter at end of measurement.
Definition Profiler.h:196
JPH_OVERRIDE_NEW_DELETE const char * mName
User defined name of this item.
Definition Profiler.h:191
uint64 mStartCycle
Cycle counter at start of measurement.
Definition Profiler.h:195
Collects all samples of a single thread.
Definition Profiler.h:201
ProfileSample mSamples[cMaxSamples]
Buffer of samples.
Definition Profiler.h:212
uint mCurrentSample
Next position to write a sample to.
Definition Profiler.h:213
~ProfileThread()
Definition Profiler.inl:17
JPH_OVERRIDE_NEW_DELETE ProfileThread(const string_view &inThreadName)
Constructor.
Definition Profiler.inl:11
static ProfileThread * sGetInstance()
Definition Profiler.h:220
static const uint cMaxSamples
Definition Profiler.h:209
void RemoveThread(ProfileThread *inThread)
Remove a thread from being instrumented.
Definition Profiler.cpp:95
void AddThread(ProfileThread *inThread)
Add a thread to be instrumented.
Definition Profiler.cpp:88
static Profiler * sInstance
Singleton instance.
Definition Profiler.h:117