annotate foosdk/sdk/pfc/timers.h @ 1:20d02a178406 default tip

*: check in everything else yay
author Paper <paper@tflc.us>
date Mon, 05 Jan 2026 02:15:46 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
1 #pragma once
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
2
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
3 #include "string_base.h"
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
4
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
5 #if defined(_MSC_VER) && (defined(_M_IX86) || defined(_M_X64))
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
6
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
7 #define PFC_HAVE_PROFILER
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
8
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
9 #include <intrin.h>
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
10 namespace pfc {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
11 class profiler_static {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
12 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
13 profiler_static(const char * p_name);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
14 ~profiler_static();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
15 void add_time(t_int64 delta) { total_time += delta;num_called++; }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
16 private:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
17 const char * name;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
18 t_uint64 total_time, num_called;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
19 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
20
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
21 class profiler_local {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
22 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
23 profiler_local(profiler_static * p_owner) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
24 owner = p_owner;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
25 start = __rdtsc();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
26 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
27 ~profiler_local() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
28 t_int64 end = __rdtsc();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
29 owner->add_time(end - start);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
30 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
31 private:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
32 t_int64 start;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
33 profiler_static * owner;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
34 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
35
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
36 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
37 #define profiler(name) \
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
38 static pfc::profiler_static profiler_static_##name(#name); \
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
39 pfc::profiler_local profiler_local_##name(&profiler_static_##name);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
40
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
41
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
42 #endif
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
43
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
44 #ifdef _WIN32
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
45
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
46 namespace pfc {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
47 typedef uint64_t tickcount_t;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
48 inline tickcount_t getTickCount() { return GetTickCount64(); }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
49
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
50 class hires_timer {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
51 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
52 hires_timer() : m_start() {}
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
53 static hires_timer create_and_start() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
54 hires_timer t; t.start(); return t;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
55 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
56 void start() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
57 m_start = g_query();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
58 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
59 double query() const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
60 return _query( g_query() );
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
61 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
62 double query_reset() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
63 t_uint64 current = g_query();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
64 double ret = _query(current);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
65 m_start = current;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
66 return ret;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
67 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
68 pfc::string8 queryString(unsigned precision = 6) const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
69 return pfc::format_time_ex( query(), precision ).get_ptr();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
70 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
71 private:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
72 double _query(t_uint64 p_val) const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
73 return (double)( p_val - m_start ) * m_mul;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
74 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
75 static t_uint64 g_query() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
76 LARGE_INTEGER val;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
77 if (!QueryPerformanceCounter(&val)) throw pfc::exception_not_implemented();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
78 return val.QuadPart;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
79 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
80 static double init_mul() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
81 return 1.0 / (double)g_query_freq();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
82 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
83 static t_uint64 g_query_freq() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
84 LARGE_INTEGER val;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
85 if (!QueryPerformanceFrequency(&val)) throw pfc::exception_not_implemented();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
86 PFC_ASSERT(val.QuadPart > 0);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
87 return val.QuadPart;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
88 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
89 t_uint64 m_start;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
90 double m_mul = init_mul();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
91 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
92
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
93 class lores_timer {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
94 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
95 lores_timer() {}
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
96 static lores_timer create_and_start() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
97 lores_timer t; t.start(); return t;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
98 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
99 void start() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
100 _start(getTickCount());
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
101 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
102
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
103 double query() const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
104 return _query(getTickCount());
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
105 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
106 double query_reset() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
107 tickcount_t time = getTickCount();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
108 double ret = _query(time);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
109 _start(time);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
110 return ret;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
111 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
112 pfc::string8 queryString(unsigned precision = 3) const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
113 return pfc::format_time_ex( query(), precision ).get_ptr();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
114 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
115 private:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
116 void _start(tickcount_t p_time) {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
117 m_start = p_time;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
118 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
119 double _query(tickcount_t p_time) const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
120 return (double)(p_time - m_start) / 1000.0;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
121 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
122 t_uint64 m_start = 0;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
123 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
124
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
125 class media_timer {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
126 typedef DWORD val_t;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
127 static val_t _now() { return timeGetTime(); }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
128 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
129 void start() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
130 _start(_now());
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
131 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
132 double query() const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
133 return _query(_now());
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
134 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
135 double query_reset() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
136 auto now = _now();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
137 double ret = _query(now);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
138 _start(now);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
139 return ret;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
140 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
141 pfc::string8 queryString(unsigned precision = 3) const {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
142 return pfc::format_time_ex(query(), precision).get_ptr();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
143 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
144 static media_timer create_and_start() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
145 media_timer t; t.start(); return t;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
146 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
147 private:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
148 void _start(val_t t) { m_start = t; }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
149 double _query(val_t t) const { return (t - m_start) / 1000.0; }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
150 val_t m_start = 0;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
151 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
152 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
153 #else // not _WIN32
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
154
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
155 namespace pfc {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
156
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
157 class hires_timer {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
158 public:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
159 hires_timer() : m_start() {}
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
160 void start();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
161 double query() const;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
162 double query_reset();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
163 pfc::string8 queryString(unsigned precision = 3) const;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
164
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
165 static hires_timer create_and_start() {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
166 hires_timer t; t.start(); return t;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
167 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
168 private:
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
169 double m_start;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
170 };
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
171
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
172 typedef hires_timer lores_timer;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
173 typedef hires_timer media_timer;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
174
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
175 }
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
176
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
177 #endif // _WIN32
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
178
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
179 #ifndef _WIN32
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
180 struct timespec;
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
181 #endif
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
182
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
183 namespace pfc {
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
184 uint64_t fileTimeWtoU(uint64_t ft);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
185 uint64_t fileTimeUtoW(uint64_t ft);
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
186 #ifndef _WIN32
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
187 uint64_t fileTimeUtoW( timespec const & ts );
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
188 #endif
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
189 uint64_t fileTimeNow();
20d02a178406 *: check in everything else
Paper <paper@tflc.us>
parents:
diff changeset
190 }