VirtualBox

source: vbox/trunk/include/VBox/vmm/stam.h@ 60646

Last change on this file since 60646 was 58125, checked in by vboxsync, 9 years ago

oops

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
File size: 42.6 KB
Line 
1/** @file
2 * STAM - Statistics Manager.
3 */
4
5/*
6 * Copyright (C) 2006-2015 Oracle Corporation
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * The contents of this file may alternatively be used under the terms
17 * of the Common Development and Distribution License Version 1.0
18 * (CDDL) only, as it comes in the "COPYING.CDDL" file of the
19 * VirtualBox OSE distribution, in which case the provisions of the
20 * CDDL are applicable instead of those of the GPL.
21 *
22 * You may elect to license modified versions of this file under the
23 * terms and conditions of either the GPL or the CDDL or both.
24 */
25
26#ifndef ___VBox_vmm_stam_h
27#define ___VBox_vmm_stam_h
28
29#include <VBox/types.h>
30#include <iprt/stdarg.h>
31#ifdef _MSC_VER
32# if _MSC_VER >= 1400
33# include <intrin.h>
34# endif
35#endif
36
37RT_C_DECLS_BEGIN
38
39/** @defgroup grp_stam The Statistics Manager API
40 * @ingroup grp_vmm
41 * @{
42 */
43
44#if defined(VBOX_WITHOUT_RELEASE_STATISTICS) && defined(VBOX_WITH_STATISTICS)
45# error "Both VBOX_WITHOUT_RELEASE_STATISTICS and VBOX_WITH_STATISTICS are defined! Make up your mind!"
46#endif
47
48
49/** @def STAM_GET_TS
50 * Gets the CPU timestamp counter.
51 *
52 * @param u64 The 64-bit variable which the timestamp shall be saved in.
53 */
54#ifdef __GNUC__
55# if defined(RT_ARCH_X86)
56 /* This produces optimal assembler code for x86 but does not work for AMD64 ('A' means 'either rax or rdx') */
57# define STAM_GET_TS(u64) __asm__ __volatile__ ("rdtsc\n\t" : "=A" (u64))
58# elif defined(RT_ARCH_AMD64)
59# define STAM_GET_TS(u64) \
60 do { uint64_t low; uint64_t high; \
61 __asm__ __volatile__ ("rdtsc\n\t" : "=a"(low), "=d"(high)); \
62 (u64) = ((high << 32) | low); \
63 } while (0)
64# endif
65#else
66# if _MSC_VER >= 1400
67# pragma intrinsic(__rdtsc)
68# define STAM_GET_TS(u64) \
69 do { (u64) = __rdtsc(); } while (0)
70# else
71# define STAM_GET_TS(u64) \
72 do { \
73 uint64_t u64Tmp; \
74 __asm { \
75 __asm rdtsc \
76 __asm mov dword ptr [u64Tmp], eax \
77 __asm mov dword ptr [u64Tmp + 4], edx \
78 } \
79 (u64) = u64Tmp; \
80 } while (0)
81# endif
82#endif
83
84
85/** @def STAM_REL_STATS
86 * Code for inclusion only when VBOX_WITH_STATISTICS is defined.
87 * @param code A code block enclosed in {}.
88 */
89#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
90# define STAM_REL_STATS(code) do code while(0)
91#else
92# define STAM_REL_STATS(code) do {} while(0)
93#endif
94/** @def STAM_STATS
95 * Code for inclusion only when VBOX_WITH_STATISTICS is defined.
96 * @param code A code block enclosed in {}.
97 */
98#ifdef VBOX_WITH_STATISTICS
99# define STAM_STATS(code) STAM_REL_STATS(code)
100#else
101# define STAM_STATS(code) do {} while(0)
102#endif
103
104
105/**
106 * Sample type.
107 */
108typedef enum STAMTYPE
109{
110 /** Invalid entry. */
111 STAMTYPE_INVALID = 0,
112 /** Generic counter. */
113 STAMTYPE_COUNTER,
114 /** Profiling of an function. */
115 STAMTYPE_PROFILE,
116 /** Profiling of an operation. */
117 STAMTYPE_PROFILE_ADV,
118 /** Ratio of A to B, uint32_t types. Not reset. */
119 STAMTYPE_RATIO_U32,
120 /** Ratio of A to B, uint32_t types. Reset both to 0. */
121 STAMTYPE_RATIO_U32_RESET,
122 /** Callback. */
123 STAMTYPE_CALLBACK,
124 /** Generic unsigned 8-bit value. Not reset. */
125 STAMTYPE_U8,
126 /** Generic unsigned 8-bit value. Reset to 0. */
127 STAMTYPE_U8_RESET,
128 /** Generic hexadecimal unsigned 8-bit value. Not reset. */
129 STAMTYPE_X8,
130 /** Generic hexadecimal unsigned 8-bit value. Reset to 0. */
131 STAMTYPE_X8_RESET,
132 /** Generic unsigned 16-bit value. Not reset. */
133 STAMTYPE_U16,
134 /** Generic unsigned 16-bit value. Reset to 0. */
135 STAMTYPE_U16_RESET,
136 /** Generic hexadecimal unsigned 16-bit value. Not reset. */
137 STAMTYPE_X16,
138 /** Generic hexadecimal unsigned 16-bit value. Reset to 0. */
139 STAMTYPE_X16_RESET,
140 /** Generic unsigned 32-bit value. Not reset. */
141 STAMTYPE_U32,
142 /** Generic unsigned 32-bit value. Reset to 0. */
143 STAMTYPE_U32_RESET,
144 /** Generic hexadecimal unsigned 32-bit value. Not reset. */
145 STAMTYPE_X32,
146 /** Generic hexadecimal unsigned 32-bit value. Reset to 0. */
147 STAMTYPE_X32_RESET,
148 /** Generic unsigned 64-bit value. Not reset. */
149 STAMTYPE_U64,
150 /** Generic unsigned 64-bit value. Reset to 0. */
151 STAMTYPE_U64_RESET,
152 /** Generic hexadecimal unsigned 64-bit value. Not reset. */
153 STAMTYPE_X64,
154 /** Generic hexadecimal unsigned 64-bit value. Reset to 0. */
155 STAMTYPE_X64_RESET,
156 /** Generic boolean value. Not reset. */
157 STAMTYPE_BOOL,
158 /** Generic boolean value. Reset to false. */
159 STAMTYPE_BOOL_RESET,
160 /** The end (exclusive). */
161 STAMTYPE_END
162} STAMTYPE;
163
164/**
165 * Sample visibility type.
166 */
167typedef enum STAMVISIBILITY
168{
169 /** Invalid entry. */
170 STAMVISIBILITY_INVALID = 0,
171 /** Always visible. */
172 STAMVISIBILITY_ALWAYS,
173 /** Only visible when used (/hit). */
174 STAMVISIBILITY_USED,
175 /** Not visible in the GUI. */
176 STAMVISIBILITY_NOT_GUI,
177 /** The end (exclusive). */
178 STAMVISIBILITY_END
179} STAMVISIBILITY;
180
181/**
182 * Sample unit.
183 */
184typedef enum STAMUNIT
185{
186 /** Invalid entry .*/
187 STAMUNIT_INVALID = 0,
188 /** No unit. */
189 STAMUNIT_NONE,
190 /** Number of calls. */
191 STAMUNIT_CALLS,
192 /** Count of whatever. */
193 STAMUNIT_COUNT,
194 /** Count of bytes. */
195 STAMUNIT_BYTES,
196 /** Count of bytes. */
197 STAMUNIT_PAGES,
198 /** Error count. */
199 STAMUNIT_ERRORS,
200 /** Number of occurences. */
201 STAMUNIT_OCCURENCES,
202 /** Ticks. */
203 STAMUNIT_TICKS,
204 /** Ticks per call. */
205 STAMUNIT_TICKS_PER_CALL,
206 /** Ticks per occurence. */
207 STAMUNIT_TICKS_PER_OCCURENCE,
208 /** Ratio of good vs. bad. */
209 STAMUNIT_GOOD_BAD,
210 /** Megabytes. */
211 STAMUNIT_MEGABYTES,
212 /** Kilobytes. */
213 STAMUNIT_KILOBYTES,
214 /** Nano seconds. */
215 STAMUNIT_NS,
216 /** Nanoseconds per call. */
217 STAMUNIT_NS_PER_CALL,
218 /** Nanoseconds per call. */
219 STAMUNIT_NS_PER_OCCURENCE,
220 /** Percentage. */
221 STAMUNIT_PCT,
222 /** Hertz. */
223 STAMUNIT_HZ,
224 /** The end (exclusive). */
225 STAMUNIT_END
226} STAMUNIT;
227
228
229/** @def STAM_REL_U8_INC
230 * Increments a uint8_t sample by one.
231 *
232 * @param pCounter Pointer to the uint8_t variable to operate on.
233 */
234#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
235# define STAM_REL_U8_INC(pCounter) \
236 do { ++*(pCounter); } while (0)
237#else
238# define STAM_REL_U8_INC(pCounter) do { } while (0)
239#endif
240/** @def STAM_U8_INC
241 * Increments a uint8_t sample by one.
242 *
243 * @param pCounter Pointer to the uint8_t variable to operate on.
244 */
245#ifdef VBOX_WITH_STATISTICS
246# define STAM_U8_INC(pCounter) STAM_REL_U8_INC(pCounter)
247#else
248# define STAM_U8_INC(pCounter) do { } while (0)
249#endif
250
251
252/** @def STAM_REL_U8_DEC
253 * Decrements a uint8_t sample by one.
254 *
255 * @param pCounter Pointer to the uint8_t variable to operate on.
256 */
257#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
258# define STAM_REL_U8_DEC(pCounter) \
259 do { --*(pCounter); } while (0)
260#else
261# define STAM_REL_U8_DEC(pCounter) do { } while (0)
262#endif
263/** @def STAM_U8_DEC
264 * Decrements a uint8_t sample by one.
265 *
266 * @param pCounter Pointer to the uint8_t variable to operate on.
267 */
268#ifdef VBOX_WITH_STATISTICS
269# define STAM_U8_DEC(pCounter) STAM_REL_U8_DEC(pCounter)
270#else
271# define STAM_U8_DEC(pCounter) do { } while (0)
272#endif
273
274
275/** @def STAM_REL_U8_ADD
276 * Increments a uint8_t sample by a value.
277 *
278 * @param pCounter Pointer to the uint8_t variable to operate on.
279 * @param Addend The value to add.
280 */
281#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
282# define STAM_REL_U8_ADD(pCounter, Addend) \
283 do { *(pCounter) += (Addend); } while (0)
284#else
285# define STAM_REL_U8_ADD(pCounter, Addend) do { } while (0)
286#endif
287/** @def STAM_U8_ADD
288 * Increments a uint8_t sample by a value.
289 *
290 * @param pCounter Pointer to the uint8_t variable to operate on.
291 * @param Addend The value to add.
292 */
293#ifdef VBOX_WITH_STATISTICS
294# define STAM_U8_ADD(pCounter, Addend) STAM_REL_U8_ADD(pCounter, Addend
295#else
296# define STAM_U8_ADD(pCounter, Addend) do { } while (0)
297#endif
298
299
300/** @def STAM_REL_U16_INC
301 * Increments a uint16_t sample by one.
302 *
303 * @param pCounter Pointer to the uint16_t variable to operate on.
304 */
305#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
306# define STAM_REL_U16_INC(pCounter) \
307 do { ++*(pCounter); } while (0)
308#else
309# define STAM_REL_U16_INC(pCounter) do { } while (0)
310#endif
311/** @def STAM_U16_INC
312 * Increments a uint16_t sample by one.
313 *
314 * @param pCounter Pointer to the uint16_t variable to operate on.
315 */
316#ifdef VBOX_WITH_STATISTICS
317# define STAM_U16_INC(pCounter) STAM_REL_U16_INC(pCounter)
318#else
319# define STAM_U16_INC(pCounter) do { } while (0)
320#endif
321
322
323/** @def STAM_REL_U16_DEC
324 * Decrements a uint16_t sample by one.
325 *
326 * @param pCounter Pointer to the uint16_t variable to operate on.
327 */
328#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
329# define STAM_REL_U16_DEC(pCounter) \
330 do { --*(pCounter); } while (0)
331#else
332# define STAM_REL_U16_DEC(pCounter) do { } while (0)
333#endif
334/** @def STAM_U16_DEC
335 * Decrements a uint16_t sample by one.
336 *
337 * @param pCounter Pointer to the uint16_t variable to operate on.
338 */
339#ifdef VBOX_WITH_STATISTICS
340# define STAM_U16_DEC(pCounter) STAM_REL_U16_DEC(pCounter)
341#else
342# define STAM_U16_DEC(pCounter) do { } while (0)
343#endif
344
345
346/** @def STAM_REL_U16_ADD
347 * Increments a uint16_t sample by a value.
348 *
349 * @param pCounter Pointer to the uint16_t variable to operate on.
350 * @param Addend The value to add.
351 */
352#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
353# define STAM_REL_U16_ADD(pCounter, Addend) \
354 do { *(pCounter) += (Addend); } while (0)
355#else
356# define STAM_REL_U16_ADD(pCounter, Addend) do { } while (0)
357#endif
358/** @def STAM_U16_ADD
359 * Increments a uint16_t sample by a value.
360 *
361 * @param pCounter Pointer to the uint16_t variable to operate on.
362 * @param Addend The value to add.
363 */
364#ifdef VBOX_WITH_STATISTICS
365# define STAM_U16_ADD(pCounter, Addend) STAM_REL_U16_ADD(pCounter, Addend)
366#else
367# define STAM_U16_ADD(pCounter, Addend) do { } while (0)
368#endif
369
370
371/** @def STAM_REL_U32_INC
372 * Increments a uint32_t sample by one.
373 *
374 * @param pCounter Pointer to the uint32_t variable to operate on.
375 */
376#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
377# define STAM_REL_U32_INC(pCounter) \
378 do { ++*(pCounter); } while (0)
379#else
380# define STAM_REL_U32_INC(pCounter) do { } while (0)
381#endif
382/** @def STAM_U32_INC
383 * Increments a uint32_t sample by one.
384 *
385 * @param pCounter Pointer to the uint32_t variable to operate on.
386 */
387#ifdef VBOX_WITH_STATISTICS
388# define STAM_U32_INC(pCounter) STAM_REL_U32_INC(pCounter)
389#else
390# define STAM_U32_INC(pCounter) do { } while (0)
391#endif
392
393
394/** @def STAM_REL_U32_DEC
395 * Decrements a uint32_t sample by one.
396 *
397 * @param pCounter Pointer to the uint32_t variable to operate on.
398 */
399#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
400# define STAM_REL_U32_DEC(pCounter) \
401 do { --*(pCounter); } while (0)
402#else
403# define STAM_REL_U32_DEC(pCounter) do { } while (0)
404#endif
405/** @def STAM_U32_DEC
406 * Decrements a uint32_t sample by one.
407 *
408 * @param pCounter Pointer to the uint32_t variable to operate on.
409 */
410#ifdef VBOX_WITH_STATISTICS
411# define STAM_U32_DEC(pCounter) STAM_REL_U32_DEC(pCounter)
412#else
413# define STAM_U32_DEC(pCounter) do { } while (0)
414#endif
415
416
417/** @def STAM_REL_U32_ADD
418 * Increments a uint32_t sample by value.
419 *
420 * @param pCounter Pointer to the uint32_t variable to operate on.
421 * @param Addend The value to add.
422 */
423#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
424# define STAM_REL_U32_ADD(pCounter, Addend) \
425 do { *(pCounter) += (Addend); } while (0)
426#else
427# define STAM_REL_U32_ADD(pCounter, Addend) do { } while (0)
428#endif
429/** @def STAM_U32_ADD
430 * Increments a uint32_t sample by value.
431 *
432 * @param pCounter Pointer to the uint32_t variable to operate on.
433 * @param Addend The value to add.
434 */
435#ifdef VBOX_WITH_STATISTICS
436# define STAM_U32_ADD(pCounter, Addend) STAM_REL_U32_ADD(pCounter, Addend)
437#else
438# define STAM_U32_ADD(pCounter, Addend) do { } while (0)
439#endif
440
441
442/** @def STAM_REL_U64_INC
443 * Increments a uint64_t sample by one.
444 *
445 * @param pCounter Pointer to the uint64_t variable to operate on.
446 */
447#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
448# define STAM_REL_U64_INC(pCounter) \
449 do { ++*(pCounter); } while (0)
450#else
451# define STAM_REL_U64_INC(pCounter) do { } while (0)
452#endif
453/** @def STAM_U64_INC
454 * Increments a uint64_t sample by one.
455 *
456 * @param pCounter Pointer to the uint64_t variable to operate on.
457 */
458#ifdef VBOX_WITH_STATISTICS
459# define STAM_U64_INC(pCounter) STAM_REL_U64_INC(pCounter)
460#else
461# define STAM_U64_INC(pCounter) do { } while (0)
462#endif
463
464
465/** @def STAM_REL_U64_DEC
466 * Decrements a uint64_t sample by one.
467 *
468 * @param pCounter Pointer to the uint64_t variable to operate on.
469 */
470#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
471# define STAM_REL_U64_DEC(pCounter) \
472 do { --*(pCounter); } while (0)
473#else
474# define STAM_REL_U64_DEC(pCounter) do { } while (0)
475#endif
476/** @def STAM_U64_DEC
477 * Decrements a uint64_t sample by one.
478 *
479 * @param pCounter Pointer to the uint64_t variable to operate on.
480 */
481#ifdef VBOX_WITH_STATISTICS
482# define STAM_U64_DEC(pCounter) STAM_REL_U64_DEC(pCounter)
483#else
484# define STAM_U64_DEC(pCounter) do { } while (0)
485#endif
486
487
488/** @def STAM_REL_U64_ADD
489 * Increments a uint64_t sample by a value.
490 *
491 * @param pCounter Pointer to the uint64_t variable to operate on.
492 * @param Addend The value to add.
493 */
494#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
495# define STAM_REL_U64_ADD(pCounter, Addend) \
496 do { *(pCounter) += (Addend); } while (0)
497#else
498# define STAM_REL_U64_ADD(pCounter, Addend) do { } while (0)
499#endif
500/** @def STAM_U64_ADD
501 * Increments a uint64_t sample by a value.
502 *
503 * @param pCounter Pointer to the uint64_t variable to operate on.
504 * @param Addend The value to add.
505 */
506#ifdef VBOX_WITH_STATISTICS
507# define STAM_U64_ADD(pCounter, Addend) STAM_REL_U64_ADD(pCounter, Addend)
508#else
509# define STAM_U64_ADD(pCounter, Addend) do { } while (0)
510#endif
511
512
513/**
514 * Counter sample - STAMTYPE_COUNTER.
515 */
516typedef struct STAMCOUNTER
517{
518 /** The current count. */
519 volatile uint64_t c;
520} STAMCOUNTER;
521/** Pointer to a counter. */
522typedef STAMCOUNTER *PSTAMCOUNTER;
523/** Pointer to a const counter. */
524typedef const STAMCOUNTER *PCSTAMCOUNTER;
525
526
527/** @def STAM_REL_COUNTER_INC
528 * Increments a counter sample by one.
529 *
530 * @param pCounter Pointer to the STAMCOUNTER structure to operate on.
531 */
532#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
533# define STAM_REL_COUNTER_INC(pCounter) \
534 do { (pCounter)->c++; } while (0)
535#else
536# define STAM_REL_COUNTER_INC(pCounter) do { } while (0)
537#endif
538/** @def STAM_COUNTER_INC
539 * Increments a counter sample by one.
540 *
541 * @param pCounter Pointer to the STAMCOUNTER structure to operate on.
542 */
543#ifdef VBOX_WITH_STATISTICS
544# define STAM_COUNTER_INC(pCounter) STAM_REL_COUNTER_INC(pCounter)
545#else
546# define STAM_COUNTER_INC(pCounter) do { } while (0)
547#endif
548
549
550/** @def STAM_REL_COUNTER_DEC
551 * Decrements a counter sample by one.
552 *
553 * @param pCounter Pointer to the STAMCOUNTER structure to operate on.
554 */
555#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
556# define STAM_REL_COUNTER_DEC(pCounter) \
557 do { (pCounter)->c--; } while (0)
558#else
559# define STAM_REL_COUNTER_DEC(pCounter) do { } while (0)
560#endif
561/** @def STAM_COUNTER_DEC
562 * Decrements a counter sample by one.
563 *
564 * @param pCounter Pointer to the STAMCOUNTER structure to operate on.
565 */
566#ifdef VBOX_WITH_STATISTICS
567# define STAM_COUNTER_DEC(pCounter) STAM_REL_COUNTER_DEC(pCounter)
568#else
569# define STAM_COUNTER_DEC(pCounter) do { } while (0)
570#endif
571
572
573/** @def STAM_REL_COUNTER_ADD
574 * Increments a counter sample by a value.
575 *
576 * @param pCounter Pointer to the STAMCOUNTER structure to operate on.
577 * @param Addend The value to add to the counter.
578 */
579#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
580# define STAM_REL_COUNTER_ADD(pCounter, Addend) \
581 do { (pCounter)->c += (Addend); } while (0)
582#else
583# define STAM_REL_COUNTER_ADD(pCounter, Addend) do { } while (0)
584#endif
585/** @def STAM_COUNTER_ADD
586 * Increments a counter sample by a value.
587 *
588 * @param pCounter Pointer to the STAMCOUNTER structure to operate on.
589 * @param Addend The value to add to the counter.
590 */
591#ifdef VBOX_WITH_STATISTICS
592# define STAM_COUNTER_ADD(pCounter, Addend) STAM_REL_COUNTER_ADD(pCounter, Addend)
593#else
594# define STAM_COUNTER_ADD(pCounter, Addend) do { } while (0)
595#endif
596
597
598/** @def STAM_REL_COUNTER_RESET
599 * Resets the statistics sample.
600 */
601#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
602# define STAM_REL_COUNTER_RESET(pCounter) do { (pCounter)->c = 0; } while (0)
603#else
604# define STAM_REL_COUNTER_RESET(pCounter) do { } while (0)
605#endif
606/** @def STAM_COUNTER_RESET
607 * Resets the statistics sample.
608 */
609#ifdef VBOX_WITH_STATISTICS
610# define STAM_COUNTER_RESET(pCounter) STAM_REL_COUNTER_RESET(pCounter)
611#else
612# define STAM_COUNTER_RESET(pCounter) do { } while (0)
613#endif
614
615
616
617/**
618 * Profiling sample - STAMTYPE_PROFILE.
619 */
620typedef struct STAMPROFILE
621{
622 /** Number of periods. */
623 volatile uint64_t cPeriods;
624 /** Total count of ticks. */
625 volatile uint64_t cTicks;
626 /** Maximum tick count during a sampling. */
627 volatile uint64_t cTicksMax;
628 /** Minimum tick count during a sampling. */
629 volatile uint64_t cTicksMin;
630} STAMPROFILE;
631/** Pointer to a profile sample. */
632typedef STAMPROFILE *PSTAMPROFILE;
633/** Pointer to a const profile sample. */
634typedef const STAMPROFILE *PCSTAMPROFILE;
635
636
637/** @def STAM_REL_PROFILE_ADD_PERIOD
638 * Adds a period.
639 *
640 * @param pProfile Pointer to the STAMPROFILE structure to operate on.
641 * @param cTicksInPeriod The number of tick (or whatever) of the preiod
642 * being added. This is only referenced once.
643 */
644#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
645# define STAM_REL_PROFILE_ADD_PERIOD(pProfile, cTicksInPeriod) \
646 do { \
647 uint64_t const StamPrefix_cTicks = (cTicksInPeriod); \
648 (pProfile)->cTicks += StamPrefix_cTicks; \
649 (pProfile)->cPeriods++; \
650 if ((pProfile)->cTicksMax < StamPrefix_cTicks) \
651 (pProfile)->cTicksMax = StamPrefix_cTicks; \
652 if ((pProfile)->cTicksMin > StamPrefix_cTicks) \
653 (pProfile)->cTicksMin = StamPrefix_cTicks; \
654 } while (0)
655#else
656# define STAM_REL_PROFILE_ADD_PERIOD(pProfile, cTicksInPeriod) do { } while (0)
657#endif
658/** @def STAM_PROFILE_ADD_PERIOD
659 * Adds a period.
660 *
661 * @param pProfile Pointer to the STAMPROFILE structure to operate on.
662 * @param cTicksInPeriod The number of tick (or whatever) of the preiod
663 * being added. This is only referenced once.
664 */
665#ifdef VBOX_WITH_STATISTICS
666# define STAM_PROFILE_ADD_PERIOD(pProfile, cTicksInPeriod) STAM_REL_PROFILE_ADD_PERIOD(pProfile, cTicksInPeriod)
667#else
668# define STAM_PROFILE_ADD_PERIOD(pProfile, cTicksInPeriod) do { } while (0)
669#endif
670
671
672/** @def STAM_REL_PROFILE_START
673 * Samples the start time of a profiling period.
674 *
675 * @param pProfile Pointer to the STAMPROFILE structure to operate on.
676 * @param Prefix Identifier prefix used to internal variables.
677 *
678 * @remarks Declears a stack variable that will be used by related macros.
679 */
680#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
681# define STAM_REL_PROFILE_START(pProfile, Prefix) \
682 uint64_t Prefix##_tsStart; \
683 STAM_GET_TS(Prefix##_tsStart)
684#else
685# define STAM_REL_PROFILE_START(pProfile, Prefix) do { } while (0)
686#endif
687/** @def STAM_PROFILE_START
688 * Samples the start time of a profiling period.
689 *
690 * @param pProfile Pointer to the STAMPROFILE structure to operate on.
691 * @param Prefix Identifier prefix used to internal variables.
692 *
693 * @remarks Declears a stack variable that will be used by related macros.
694 */
695#ifdef VBOX_WITH_STATISTICS
696# define STAM_PROFILE_START(pProfile, Prefix) STAM_REL_PROFILE_START(pProfile, Prefix)
697#else
698# define STAM_PROFILE_START(pProfile, Prefix) do { } while (0)
699#endif
700
701/** @def STAM_REL_PROFILE_STOP
702 * Samples the stop time of a profiling period and updates the sample.
703 *
704 * @param pProfile Pointer to the STAMPROFILE structure to operate on.
705 * @param Prefix Identifier prefix used to internal variables.
706 */
707#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
708# define STAM_REL_PROFILE_STOP(pProfile, Prefix) \
709 do { \
710 uint64_t Prefix##_cTicks; \
711 STAM_GET_TS(Prefix##_cTicks); \
712 Prefix##_cTicks -= Prefix##_tsStart; \
713 (pProfile)->cTicks += Prefix##_cTicks; \
714 (pProfile)->cPeriods++; \
715 if ((pProfile)->cTicksMax < Prefix##_cTicks) \
716 (pProfile)->cTicksMax = Prefix##_cTicks; \
717 if ((pProfile)->cTicksMin > Prefix##_cTicks) \
718 (pProfile)->cTicksMin = Prefix##_cTicks; \
719 } while (0)
720#else
721# define STAM_REL_PROFILE_STOP(pProfile, Prefix) do { } while (0)
722#endif
723/** @def STAM_PROFILE_STOP
724 * Samples the stop time of a profiling period and updates the sample.
725 *
726 * @param pProfile Pointer to the STAMPROFILE structure to operate on.
727 * @param Prefix Identifier prefix used to internal variables.
728 */
729#ifdef VBOX_WITH_STATISTICS
730# define STAM_PROFILE_STOP(pProfile, Prefix) STAM_REL_PROFILE_STOP(pProfile, Prefix)
731#else
732# define STAM_PROFILE_STOP(pProfile, Prefix) do { } while (0)
733#endif
734
735
736/** @def STAM_REL_PROFILE_STOP_EX
737 * Samples the stop time of a profiling period and updates both the sample
738 * and an attribution sample.
739 *
740 * @param pProfile Pointer to the STAMPROFILE structure to operate on.
741 * @param pProfile2 Pointer to the STAMPROFILE structure which this
742 * interval should be attributed to as well. This may be NULL.
743 * @param Prefix Identifier prefix used to internal variables.
744 */
745#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
746# define STAM_REL_PROFILE_STOP_EX(pProfile, pProfile2, Prefix) \
747 do { \
748 uint64_t Prefix##_cTicks; \
749 STAM_GET_TS(Prefix##_cTicks); \
750 Prefix##_cTicks -= Prefix##_tsStart; \
751 (pProfile)->cTicks += Prefix##_cTicks; \
752 (pProfile)->cPeriods++; \
753 if ((pProfile)->cTicksMax < Prefix##_cTicks) \
754 (pProfile)->cTicksMax = Prefix##_cTicks; \
755 if ((pProfile)->cTicksMin > Prefix##_cTicks) \
756 (pProfile)->cTicksMin = Prefix##_cTicks; \
757 \
758 if ((pProfile2)) \
759 { \
760 (pProfile2)->cTicks += Prefix##_cTicks; \
761 (pProfile2)->cPeriods++; \
762 if ((pProfile2)->cTicksMax < Prefix##_cTicks) \
763 (pProfile2)->cTicksMax = Prefix##_cTicks; \
764 if ((pProfile2)->cTicksMin > Prefix##_cTicks) \
765 (pProfile2)->cTicksMin = Prefix##_cTicks; \
766 } \
767 } while (0)
768#else
769# define STAM_REL_PROFILE_STOP_EX(pProfile, pProfile2, Prefix) do { } while (0)
770#endif
771/** @def STAM_PROFILE_STOP_EX
772 * Samples the stop time of a profiling period and updates both the sample
773 * and an attribution sample.
774 *
775 * @param pProfile Pointer to the STAMPROFILE structure to operate on.
776 * @param pProfile2 Pointer to the STAMPROFILE structure which this
777 * interval should be attributed to as well. This may be NULL.
778 * @param Prefix Identifier prefix used to internal variables.
779 */
780#ifdef VBOX_WITH_STATISTICS
781# define STAM_PROFILE_STOP_EX(pProfile, pProfile2, Prefix) STAM_REL_PROFILE_STOP_EX(pProfile, pProfile2, Prefix)
782#else
783# define STAM_PROFILE_STOP_EX(pProfile, pProfile2, Prefix) do { } while (0)
784#endif
785
786
787/**
788 * Advanced profiling sample - STAMTYPE_PROFILE_ADV.
789 *
790 * Identical to a STAMPROFILE sample, but the start timestamp
791 * is stored after the STAMPROFILE structure so the sampling
792 * can start and stop in different functions.
793 */
794typedef struct STAMPROFILEADV
795{
796 /** The STAMPROFILE core. */
797 STAMPROFILE Core;
798 /** The start timestamp. */
799 volatile uint64_t tsStart;
800} STAMPROFILEADV;
801/** Pointer to a advanced profile sample. */
802typedef STAMPROFILEADV *PSTAMPROFILEADV;
803/** Pointer to a const advanced profile sample. */
804typedef const STAMPROFILEADV *PCSTAMPROFILEADV;
805
806
807/** @def STAM_REL_PROFILE_ADV_START
808 * Samples the start time of a profiling period.
809 *
810 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
811 * @param Prefix Identifier prefix used to internal variables.
812 */
813#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
814# define STAM_REL_PROFILE_ADV_START(pProfileAdv, Prefix) \
815 STAM_GET_TS((pProfileAdv)->tsStart)
816#else
817# define STAM_REL_PROFILE_ADV_START(pProfileAdv, Prefix) do { } while (0)
818#endif
819/** @def STAM_PROFILE_ADV_START
820 * Samples the start time of a profiling period.
821 *
822 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
823 * @param Prefix Identifier prefix used to internal variables.
824 */
825#ifdef VBOX_WITH_STATISTICS
826# define STAM_PROFILE_ADV_START(pProfileAdv, Prefix) STAM_REL_PROFILE_ADV_START(pProfileAdv, Prefix)
827#else
828# define STAM_PROFILE_ADV_START(pProfileAdv, Prefix) do { } while (0)
829#endif
830
831
832/** @def STAM_REL_PROFILE_ADV_STOP
833 * Samples the stop time of a profiling period (if running) and updates the
834 * sample.
835 *
836 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
837 * @param Prefix Identifier prefix used to internal variables.
838 */
839#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
840# define STAM_REL_PROFILE_ADV_STOP(pProfileAdv, Prefix) \
841 do { \
842 if ((pProfileAdv)->tsStart) \
843 { \
844 uint64_t Prefix##_cTicks; \
845 STAM_GET_TS(Prefix##_cTicks); \
846 Prefix##_cTicks -= (pProfileAdv)->tsStart; \
847 (pProfileAdv)->tsStart = 0; \
848 (pProfileAdv)->Core.cTicks += Prefix##_cTicks; \
849 (pProfileAdv)->Core.cPeriods++; \
850 if ((pProfileAdv)->Core.cTicksMax < Prefix##_cTicks) \
851 (pProfileAdv)->Core.cTicksMax = Prefix##_cTicks; \
852 if ((pProfileAdv)->Core.cTicksMin > Prefix##_cTicks) \
853 (pProfileAdv)->Core.cTicksMin = Prefix##_cTicks; \
854 } \
855 } while (0)
856#else
857# define STAM_REL_PROFILE_ADV_STOP(pProfileAdv, Prefix) do { } while (0)
858#endif
859/** @def STAM_PROFILE_ADV_STOP
860 * Samples the stop time of a profiling period (if running) and updates the
861 * sample.
862 *
863 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
864 * @param Prefix Identifier prefix used to internal variables.
865 */
866#ifdef VBOX_WITH_STATISTICS
867# define STAM_PROFILE_ADV_STOP(pProfileAdv, Prefix) STAM_REL_PROFILE_ADV_STOP(pProfileAdv, Prefix)
868#else
869# define STAM_PROFILE_ADV_STOP(pProfileAdv, Prefix) do { } while (0)
870#endif
871
872
873/** @def STAM_REL_PROFILE_ADV_STOP_START
874 * Stops one profile counter (if running) and starts another one.
875 *
876 * @param pProfileAdv1 Pointer to the STAMPROFILEADV structure to stop.
877 * @param pProfileAdv2 Pointer to the STAMPROFILEADV structure to start.
878 * @param Prefix Identifier prefix used to internal variables.
879 */
880#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
881# define STAM_REL_PROFILE_ADV_STOP_START(pProfileAdv1, pProfileAdv2, Prefix) \
882 do { \
883 uint64_t Prefix##_cTicks; \
884 STAM_GET_TS(Prefix##_cTicks); \
885 (pProfileAdv2)->tsStart = Prefix##_cTicks; \
886 if ((pProfileAdv1)->tsStart) \
887 { \
888 Prefix##_cTicks -= (pProfileAdv1)->tsStart; \
889 (pProfileAdv1)->tsStart = 0; \
890 (pProfileAdv1)->Core.cTicks += Prefix##_cTicks; \
891 (pProfileAdv1)->Core.cPeriods++; \
892 if ((pProfileAdv1)->Core.cTicksMax < Prefix##_cTicks) \
893 (pProfileAdv1)->Core.cTicksMax = Prefix##_cTicks; \
894 if ((pProfileAdv1)->Core.cTicksMin > Prefix##_cTicks) \
895 (pProfileAdv1)->Core.cTicksMin = Prefix##_cTicks; \
896 } \
897 } while (0)
898#else
899# define STAM_REL_PROFILE_ADV_STOP_START(pProfileAdv1, pProfileAdv2, Prefix) \
900 do { } while (0)
901#endif
902/** @def STAM_PROFILE_ADV_STOP_START
903 * Samples the stop time of a profiling period (if running) and updates the
904 * sample.
905 *
906 * @param pProfileAdv1 Pointer to the STAMPROFILEADV structure to stop.
907 * @param pProfileAdv2 Pointer to the STAMPROFILEADV structure to start.
908 * @param Prefix Identifier prefix used to internal variables.
909 */
910#ifdef VBOX_WITH_STATISTICS
911# define STAM_PROFILE_ADV_STOP_START(pProfileAdv1, pProfileAdv2, Prefix) \
912 STAM_REL_PROFILE_ADV_STOP_START(pProfileAdv1, pProfileAdv2, Prefix)
913#else
914# define STAM_PROFILE_ADV_STOP_START(pProfileAdv1, pProfileAdv2, Prefix) \
915 do { } while (0)
916#endif
917
918
919/** @def STAM_REL_PROFILE_ADV_SUSPEND
920 * Suspends the sampling for a while. This can be useful to exclude parts
921 * covered by other samples without screwing up the count, and average+min times.
922 *
923 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
924 * @param Prefix Identifier prefix used to internal variables. The prefix
925 * must match that of the resume one since it stores the
926 * suspend time in a stack variable.
927 */
928#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
929# define STAM_REL_PROFILE_ADV_SUSPEND(pProfileAdv, Prefix) \
930 uint64_t Prefix##_tsSuspend; \
931 STAM_GET_TS(Prefix##_tsSuspend)
932#else
933# define STAM_REL_PROFILE_ADV_SUSPEND(pProfileAdv, Prefix) do { } while (0)
934#endif
935/** @def STAM_PROFILE_ADV_SUSPEND
936 * Suspends the sampling for a while. This can be useful to exclude parts
937 * covered by other samples without screwing up the count, and average+min times.
938 *
939 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
940 * @param Prefix Identifier prefix used to internal variables. The prefix
941 * must match that of the resume one since it stores the
942 * suspend time in a stack variable.
943 */
944#ifdef VBOX_WITH_STATISTICS
945# define STAM_PROFILE_ADV_SUSPEND(pProfileAdv, Prefix) STAM_REL_PROFILE_ADV_SUSPEND(pProfileAdv, Prefix)
946#else
947# define STAM_PROFILE_ADV_SUSPEND(pProfileAdv, Prefix) do { } while (0)
948#endif
949
950
951/** @def STAM_REL_PROFILE_ADV_RESUME
952 * Counter to STAM_REL_PROFILE_ADV_SUSPEND.
953 *
954 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
955 * @param Prefix Identifier prefix used to internal variables. This must
956 * match the one used with the SUSPEND!
957 */
958#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
959# define STAM_REL_PROFILE_ADV_RESUME(pProfileAdv, Prefix) \
960 do { \
961 uint64_t Prefix##_tsNow; \
962 STAM_GET_TS(Prefix##_tsNow); \
963 (pProfileAdv)->tsStart += Prefix##_tsNow - Prefix##_tsSuspend; \
964 } while (0)
965#else
966# define STAM_REL_PROFILE_ADV_RESUME(pProfileAdv, Prefix) do { } while (0)
967#endif
968/** @def STAM_PROFILE_ADV_RESUME
969 * Counter to STAM_PROFILE_ADV_SUSPEND.
970 *
971 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
972 * @param Prefix Identifier prefix used to internal variables. This must
973 * match the one used with the SUSPEND!
974 */
975#ifdef VBOX_WITH_STATISTICS
976# define STAM_PROFILE_ADV_RESUME(pProfileAdv, Prefix) STAM_REL_PROFILE_ADV_RESUME(pProfileAdv, Prefix)
977#else
978# define STAM_PROFILE_ADV_RESUME(pProfileAdv, Prefix) do { } while (0)
979#endif
980
981
982/** @def STAM_REL_PROFILE_ADV_STOP_EX
983 * Samples the stop time of a profiling period (if running) and updates both
984 * the sample and an attribution sample.
985 *
986 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
987 * @param pProfile2 Pointer to the STAMPROFILE structure which this
988 * interval should be attributed to as well. This may be NULL.
989 * @param Prefix Identifier prefix used to internal variables.
990 */
991#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
992# define STAM_REL_PROFILE_ADV_STOP_EX(pProfileAdv, pProfile2, Prefix) \
993 do { \
994 if ((pProfileAdv)->tsStart) \
995 { \
996 uint64_t Prefix##_cTicks; \
997 STAM_GET_TS(Prefix##_cTicks); \
998 Prefix##_cTicks -= (pProfileAdv)->tsStart; \
999 (pProfileAdv)->tsStart = 0; \
1000 (pProfileAdv)->Core.cTicks += Prefix##_cTicks; \
1001 (pProfileAdv)->Core.cPeriods++; \
1002 if ((pProfileAdv)->Core.cTicksMax < Prefix##_cTicks) \
1003 (pProfileAdv)->Core.cTicksMax = Prefix##_cTicks; \
1004 if ((pProfileAdv)->Core.cTicksMin > Prefix##_cTicks) \
1005 (pProfileAdv)->Core.cTicksMin = Prefix##_cTicks; \
1006 if ((pProfile2)) \
1007 { \
1008 (pProfile2)->cTicks += Prefix##_cTicks; \
1009 (pProfile2)->cPeriods++; \
1010 if ((pProfile2)->cTicksMax < Prefix##_cTicks) \
1011 (pProfile2)->cTicksMax = Prefix##_cTicks; \
1012 if ((pProfile2)->cTicksMin > Prefix##_cTicks) \
1013 (pProfile2)->cTicksMin = Prefix##_cTicks; \
1014 } \
1015 } \
1016 } while (0)
1017#else
1018# define STAM_REL_PROFILE_ADV_STOP_EX(pProfileAdv, pProfile2, Prefix) do { } while (0)
1019#endif
1020/** @def STAM_PROFILE_ADV_STOP_EX
1021 * Samples the stop time of a profiling period (if running) and updates both
1022 * the sample and an attribution sample.
1023 *
1024 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
1025 * @param pProfile2 Pointer to the STAMPROFILE structure which this
1026 * interval should be attributed to as well. This may be NULL.
1027 * @param Prefix Identifier prefix used to internal variables.
1028 */
1029#ifdef VBOX_WITH_STATISTICS
1030# define STAM_PROFILE_ADV_STOP_EX(pProfileAdv, pProfile2, Prefix) STAM_REL_PROFILE_ADV_STOP_EX(pProfileAdv, pProfile2, Prefix)
1031#else
1032# define STAM_PROFILE_ADV_STOP_EX(pProfileAdv, pProfile2, Prefix) do { } while (0)
1033#endif
1034
1035/** @def STAM_REL_PROFILE_ADV_IS_RUNNING
1036 * Checks if it is running.
1037 *
1038 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
1039 */
1040#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
1041# define STAM_REL_PROFILE_ADV_IS_RUNNING(pProfileAdv) (pProfileAdv)->tsStart
1042#else
1043# define STAM_REL_PROFILE_ADV_IS_RUNNING(pProfileAdv) (false)
1044#endif
1045/** @def STAM_PROFILE_ADV_IS_RUNNING
1046 * Checks if it is running.
1047 *
1048 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
1049 */
1050#ifdef VBOX_WITH_STATISTICS
1051# define STAM_PROFILE_ADV_IS_RUNNING(pProfileAdv) STAM_REL_PROFILE_ADV_IS_RUNNING(pProfileAdv)
1052#else
1053# define STAM_PROFILE_ADV_IS_RUNNING(pProfileAdv) (false)
1054#endif
1055
1056/** @def STAM_REL_PROFILE_ADV_SET_STOPPED
1057 * Marks the profile counter as stopped.
1058 *
1059 * This is for avoiding screwups in twisty code.
1060 *
1061 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
1062 */
1063#ifndef VBOX_WITHOUT_RELEASE_STATISTICS
1064# define STAM_REL_PROFILE_ADV_SET_STOPPED(pProfileAdv) do { (pProfileAdv)->tsStart = 0; } while (0)
1065#else
1066# define STAM_REL_PROFILE_ADV_SET_STOPPED(pProfileAdv) do { } while (0)
1067#endif
1068/** @def STAM_PROFILE_ADV_SET_STOPPED
1069 * Marks the profile counter as stopped.
1070 *
1071 * This is for avoiding screwups in twisty code.
1072 *
1073 * @param pProfileAdv Pointer to the STAMPROFILEADV structure to operate on.
1074 */
1075#ifdef VBOX_WITH_STATISTICS
1076# define STAM_PROFILE_ADV_SET_STOPPED(pProfileAdv) STAM_REL_PROFILE_ADV_SET_STOPPED(pProfileAdv)
1077#else
1078# define STAM_PROFILE_ADV_SET_STOPPED(pProfileAdv) do { } while (0)
1079#endif
1080
1081
1082/**
1083 * Ratio of A to B, uint32_t types.
1084 * @remark Use STAM_STATS or STAM_REL_STATS for modifying A & B values.
1085 */
1086typedef struct STAMRATIOU32
1087{
1088 /** Sample A. */
1089 uint32_t volatile u32A;
1090 /** Sample B. */
1091 uint32_t volatile u32B;
1092} STAMRATIOU32;
1093/** Pointer to a uint32_t ratio. */
1094typedef STAMRATIOU32 *PSTAMRATIOU32;
1095/** Pointer to const a uint32_t ratio. */
1096typedef const STAMRATIOU32 *PCSTAMRATIOU32;
1097
1098
1099
1100
1101/** @defgroup grp_stam_r3 The STAM Host Context Ring 3 API
1102 * @{
1103 */
1104
1105VMMR3DECL(int) STAMR3InitUVM(PUVM pUVM);
1106VMMR3DECL(void) STAMR3TermUVM(PUVM pUVM);
1107VMMR3DECL(int) STAMR3RegisterU(PUVM pUVM, void *pvSample, STAMTYPE enmType, STAMVISIBILITY enmVisibility,
1108 const char *pszName, STAMUNIT enmUnit, const char *pszDesc);
1109VMMR3DECL(int) STAMR3Register(PVM pVM, void *pvSample, STAMTYPE enmType, STAMVISIBILITY enmVisibility,
1110 const char *pszName, STAMUNIT enmUnit, const char *pszDesc);
1111
1112/** @def STAM_REL_REG
1113 * Registers a statistics sample.
1114 *
1115 * @param pVM The cross context VM structure.
1116 * @param pvSample Pointer to the sample.
1117 * @param enmType Sample type. This indicates what pvSample is pointing at.
1118 * @param pszName Sample name. The name is on this form "/<component>/<sample>".
1119 * Further nesting is possible.
1120 * @param enmUnit Sample unit.
1121 * @param pszDesc Sample description.
1122 */
1123#define STAM_REL_REG(pVM, pvSample, enmType, pszName, enmUnit, pszDesc) \
1124 STAM_REL_STATS({ int rcStam = STAMR3Register(pVM, pvSample, enmType, STAMVISIBILITY_ALWAYS, pszName, enmUnit, pszDesc); \
1125 AssertRC(rcStam); })
1126/** @def STAM_REG
1127 * Registers a statistics sample if statistics are enabled.
1128 *
1129 * @param pVM The cross context VM structure.
1130 * @param pvSample Pointer to the sample.
1131 * @param enmType Sample type. This indicates what pvSample is pointing at.
1132 * @param pszName Sample name. The name is on this form "/<component>/<sample>".
1133 * Further nesting is possible.
1134 * @param enmUnit Sample unit.
1135 * @param pszDesc Sample description.
1136 */
1137#define STAM_REG(pVM, pvSample, enmType, pszName, enmUnit, pszDesc) \
1138 STAM_STATS({STAM_REL_REG(pVM, pvSample, enmType, pszName, enmUnit, pszDesc);})
1139
1140/** @def STAM_REL_REG_USED
1141 * Registers a statistics sample which only shows when used.
1142 *
1143 * @param pVM The cross context VM structure.
1144 * @param pvSample Pointer to the sample.
1145 * @param enmType Sample type. This indicates what pvSample is pointing at.
1146 * @param pszName Sample name. The name is on this form "/<component>/<sample>".
1147 * Further nesting is possible.
1148 * @param enmUnit Sample unit.
1149 * @param pszDesc Sample description.
1150 */
1151#define STAM_REL_REG_USED(pVM, pvSample, enmType, pszName, enmUnit, pszDesc) \
1152 STAM_REL_STATS({ int rcStam = STAMR3Register(pVM, pvSample, enmType, STAMVISIBILITY_USED, pszName, enmUnit, pszDesc); \
1153 AssertRC(rcStam);})
1154/** @def STAM_REG_USED
1155 * Registers a statistics sample which only shows when used, if statistics are enabled.
1156 *
1157 * @param pVM The cross context VM structure.
1158 * @param pvSample Pointer to the sample.
1159 * @param enmType Sample type. This indicates what pvSample is pointing at.
1160 * @param pszName Sample name. The name is on this form "/<component>/<sample>".
1161 * Further nesting is possible.
1162 * @param enmUnit Sample unit.
1163 * @param pszDesc Sample description.
1164 */
1165#define STAM_REG_USED(pVM, pvSample, enmType, pszName, enmUnit, pszDesc) \
1166 STAM_STATS({ STAM_REL_REG_USED(pVM, pvSample, enmType, pszName, enmUnit, pszDesc); })
1167
1168VMMR3DECL(int) STAMR3RegisterFU(PUVM pUVM, void *pvSample, STAMTYPE enmType, STAMVISIBILITY enmVisibility, STAMUNIT enmUnit,
1169 const char *pszDesc, const char *pszName, ...) RT_IPRT_FORMAT_ATTR(7, 8);
1170VMMR3DECL(int) STAMR3RegisterF(PVM pVM, void *pvSample, STAMTYPE enmType, STAMVISIBILITY enmVisibility, STAMUNIT enmUnit,
1171 const char *pszDesc, const char *pszName, ...) RT_IPRT_FORMAT_ATTR(7, 8);
1172VMMR3DECL(int) STAMR3RegisterVU(PUVM pUVM, void *pvSample, STAMTYPE enmType, STAMVISIBILITY enmVisibility, STAMUNIT enmUnit,
1173 const char *pszDesc, const char *pszName, va_list args) RT_IPRT_FORMAT_ATTR(7, 0);
1174VMMR3DECL(int) STAMR3RegisterV(PVM pVM, void *pvSample, STAMTYPE enmType, STAMVISIBILITY enmVisibility, STAMUNIT enmUnit,
1175 const char *pszDesc, const char *pszName, va_list args) RT_IPRT_FORMAT_ATTR(7, 0);
1176
1177/**
1178 * Resets the sample.
1179 * @param pVM The cross context VM structure.
1180 * @param pvSample The sample registered using STAMR3RegisterCallback.
1181 */
1182typedef void FNSTAMR3CALLBACKRESET(PVM pVM, void *pvSample);
1183/** Pointer to a STAM sample reset callback. */
1184typedef FNSTAMR3CALLBACKRESET *PFNSTAMR3CALLBACKRESET;
1185
1186/**
1187 * Prints the sample into the buffer.
1188 *
1189 * @param pVM The cross context VM structure.
1190 * @param pvSample The sample registered using STAMR3RegisterCallback.
1191 * @param pszBuf The buffer to print into.
1192 * @param cchBuf The size of the buffer.
1193 */
1194typedef void FNSTAMR3CALLBACKPRINT(PVM pVM, void *pvSample, char *pszBuf, size_t cchBuf);
1195/** Pointer to a STAM sample print callback. */
1196typedef FNSTAMR3CALLBACKPRINT *PFNSTAMR3CALLBACKPRINT;
1197
1198VMMR3DECL(int) STAMR3RegisterCallback(PVM pVM, void *pvSample, STAMVISIBILITY enmVisibility, STAMUNIT enmUnit,
1199 PFNSTAMR3CALLBACKRESET pfnReset, PFNSTAMR3CALLBACKPRINT pfnPrint,
1200 const char *pszDesc, const char *pszName, ...) RT_IPRT_FORMAT_ATTR(8, 9);
1201VMMR3DECL(int) STAMR3RegisterCallbackV(PVM pVM, void *pvSample, STAMVISIBILITY enmVisibility, STAMUNIT enmUnit,
1202 PFNSTAMR3CALLBACKRESET pfnReset, PFNSTAMR3CALLBACKPRINT pfnPrint,
1203 const char *pszDesc, const char *pszName, va_list args) RT_IPRT_FORMAT_ATTR(8, 0);
1204VMMR3DECL(int) STAMR3Deregister(PUVM pUVM, const char *pszPat);
1205VMMR3DECL(int) STAMR3DeregisterF(PUVM pUVM, const char *pszPatFmt, ...) RT_IPRT_FORMAT_ATTR(2, 3);
1206VMMR3DECL(int) STAMR3DeregisterV(PUVM pUVM, const char *pszPatFmt, va_list va) RT_IPRT_FORMAT_ATTR(2, 0);
1207VMMR3DECL(int) STAMR3DeregisterByAddr(PUVM pUVM, void *pvSample);
1208
1209VMMR3DECL(int) STAMR3Reset(PUVM pUVM, const char *pszPat);
1210VMMR3DECL(int) STAMR3Snapshot(PUVM pUVM, const char *pszPat, char **ppszSnapshot, size_t *pcchSnapshot, bool fWithDesc);
1211VMMR3DECL(int) STAMR3SnapshotFree(PUVM pUVM, char *pszSnapshot);
1212VMMR3DECL(int) STAMR3Dump(PUVM pUVM, const char *pszPat);
1213VMMR3DECL(int) STAMR3DumpToReleaseLog(PUVM pUVM, const char *pszPat);
1214VMMR3DECL(int) STAMR3Print(PUVM pUVM, const char *pszPat);
1215
1216/**
1217 * Callback function for STAMR3Enum().
1218 *
1219 * @returns non-zero to halt the enumeration.
1220 *
1221 * @param pszName The name of the sample.
1222 * @param enmType The type.
1223 * @param pvSample Pointer to the data. enmType indicates the format of this data.
1224 * @param enmUnit The unit.
1225 * @param enmVisibility The visibility.
1226 * @param pszDesc The description.
1227 * @param pvUser The pvUser argument given to STAMR3Enum().
1228 */
1229typedef DECLCALLBACK(int) FNSTAMR3ENUM(const char *pszName, STAMTYPE enmType, void *pvSample, STAMUNIT enmUnit,
1230 STAMVISIBILITY enmVisiblity, const char *pszDesc, void *pvUser);
1231/** Pointer to a FNSTAMR3ENUM(). */
1232typedef FNSTAMR3ENUM *PFNSTAMR3ENUM;
1233
1234VMMR3DECL(int) STAMR3Enum(PUVM pUVM, const char *pszPat, PFNSTAMR3ENUM pfnEnum, void *pvUser);
1235VMMR3DECL(const char *) STAMR3GetUnit(STAMUNIT enmUnit);
1236
1237/** @} */
1238
1239/** @} */
1240
1241RT_C_DECLS_END
1242
1243#endif
1244
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette