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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
|
/************************************************************************************
Filename : Util_LatencyTest2Reader.h
Content : Shared functionality for the DK2 latency tester
Created : July 8, 2014
Authors : Volga Aksoy, Chris Taylor
Copyright : Copyright 2014 Oculus VR, LLC All Rights reserved.
Licensed under the Oculus VR Rift SDK License Version 3.2 (the "License");
you may not use the Oculus VR Rift SDK except in compliance with the License,
which is provided at the time of installation or download, or which
otherwise accompanies this software in either electronic or hard copy form.
You may obtain a copy of the License at
http://www.oculusvr.com/licenses/LICENSE-3.2
Unless required by applicable law or agreed to in writing, the Oculus VR SDK
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*************************************************************************************/
#ifndef OVR_Util_LatencyTest2_State_h
#define OVR_Util_LatencyTest2_State_h
#include "Kernel/OVR_Lockless.h"
namespace OVR { namespace Util {
enum LatencyTester2Constants
{
LT2_ColorIncrement = 32,
LT2_PixelTestThreshold = LT2_ColorIncrement / 3,
LT2_IncrementCount = 256 / LT2_ColorIncrement,
LT2_TimeoutWaitingForColorDetected = 1000 // 1 second
};
//-------------------------------------------------------------------------------------
// FrameTimeRecord
// Describes frame scan-out time used for latency testing.
struct OVR_ALIGNAS(8) FrameTimeRecord
{
int32_t ReadbackIndex;
int32_t Pad;
double TimeSeconds;
// Utility functions to convert color to readBack indices and back.
// The purpose of ReadbackIndex is to allow direct comparison by value.
static bool ColorToReadbackIndex(int *readbackIndex, unsigned char color);
static unsigned char ReadbackIndexToColor(int readbackIndex);
};
//-----------------------------------------------------------------------------
// FrameTimeRecordSet
// FrameTimeRecordSet is a container holding multiple consecutive frame timing records
// returned from the lock-less state. Used by FrameTimeManager.
struct OVR_ALIGNAS(8) FrameTimeRecordSet
{
enum {
RecordCount = 4,
RecordMask = RecordCount - 1
};
FrameTimeRecord Records[RecordCount];
int32_t NextWriteIndex;
int32_t Pad4;
FrameTimeRecordSet();
void AddValue(int readValue, double timeSeconds);
// Matching should be done starting from NextWrite index
// until wrap-around
const FrameTimeRecord& operator [] (int i) const;
const FrameTimeRecord& GetMostRecentFrame();
// Advances I to absolute color index
bool FindReadbackIndex(int* i, int readbackIndex) const;
bool IsAllZeroes() const;
};
}} // namespace OVR::Util
#endif // OVR_Util_LatencyTest2_State_h
|