timemory 3.3.0
Modular C++ Toolkit for Performance Analysis and Logging. Profiling API and Tools for C, C++, CUDA, Fortran, and Python. The C++ template API is essentially a framework to creating tools: it is designed to provide a unifying interface for recording various performance measurements alongside data logging and interfaces to other tools.
timemory_c.h
Go to the documentation of this file.
1// MIT License
2//
3// Copyright (c) 2020, The Regents of the University of California,
4// through Lawrence Berkeley National Laboratory (subject to receipt of any
5// required approvals from the U.S. Dept. of Energy). All rights reserved.
6//
7// Permission is hereby granted, free of charge, to any person obtaining a copy
8// of this software and associated documentation files (the "Software"), to deal
9// in the Software without restriction, including without limitation the rights
10// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11// copies of the Software, and to permit persons to whom the Software is
12// furnished to do so, subject to the following conditions:
13//
14// The above copyright notice and this permission notice shall be included in all
15// copies or substantial portions of the Software.
16//
17// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
23// SOFTWARE.
24
25#pragma once
26
27#include <stdbool.h>
28#include <stddef.h>
29#include <stdint.h>
30#include <stdio.h>
31#include <stdlib.h>
32#include <string.h>
33
34#if defined(DISABLE_TIMEMORY) || defined(TIMEMORY_DISABLED)
35
36# define TIMEMORY_C_SETTINGS_INIT \
37 {}
38# define TIMEMORY_C_INIT(...)
39# define TIMEMORY_C_AUTO_LABEL(...) ""
40# define TIMEMORY_C_BLANK_AUTO_TIMER(...) NULL
41# define TIMEMORY_C_BASIC_AUTO_TIMER(...) NULL
42# define TIMEMORY_C_AUTO_TIMER(...) NULL
43# define FREE_TIMEMORY_C_AUTO_TIMER(...)
44# define TIMEMORY_C_BASIC_AUTO_TUPLE(...) NULL
45# define TIMEMORY_C_BLANK_AUTO_TUPLE(...) NULL
46# define TIMEMORY_C_AUTO_TUPLE(...) NULL
47# define FREE_TIMEMORY_C_AUTO_TUPLE(...)
48
49#else // !defined(DISABLE_TIMEMORY)
50
53# include "timemory/enum.h"
54
55//======================================================================================//
56//
57// C timemory macros
58//
59//======================================================================================//
60
61# define TIMEMORY_C_SETTINGS_INIT { 1, -1, -1, -1, -1, -1, -1, -1, -1 };
62# define TIMEMORY_C_INIT(argc, argv, settings) c_timemory_init(argc, argv, settings)
63# define TIMEMORY_C_FINALIZE() c_timemory_finalize()
64
65//--------------------------------------------------------------------------------------//
66
67# define TIMEMORY_C_BLANK_LABEL(c_str) c_str
68
69# define TIMEMORY_C_BASIC_LABEL(c_str) c_timemory_basic_label(__FUNCTION__, c_str)
70
71# define TIMEMORY_C_LABEL(c_str) \
72 c_timemory_label(__FUNCTION__, __FILE__, __LINE__, c_str)
73
74//--------------------------------------------------------------------------------------//
75
76# define TIMEMORY_C_BLANK_AUTO_TIMER(c_str) \
77 c_timemory_create_auto_timer(TIMEMORY_C_BLANK_LABEL(c_str))
78
79# define TIMEMORY_C_BASIC_AUTO_TIMER(c_str) \
80 c_timemory_create_auto_timer(TIMEMORY_C_BASIC_LABEL(c_str))
81
82# define TIMEMORY_C_AUTO_TIMER(c_str) \
83 c_timemory_create_auto_timer(TIMEMORY_C_LABEL(c_str))
84
85# define FREE_TIMEMORY_C_AUTO_TIMER(ctimer) \
86 c_timemory_delete_auto_timer((void*) ctimer)
87
88//--------------------------------------------------------------------------------------//
89
90# define TIMEMORY_C_BLANK_MARKER(c_str, ...) \
91 c_timemory_create_auto_tuple(TIMEMORY_C_BLANK_LABEL(c_str), __VA_ARGS__, \
92 TIMEMORY_COMPONENTS_END)
93
94# define TIMEMORY_C_BASIC_MARKER(c_str, ...) \
95 c_timemory_create_auto_tuple(TIMEMORY_C_BASIC_LABEL(c_str), __VA_ARGS__, \
96 TIMEMORY_COMPONENTS_END)
97
98# define TIMEMORY_C_MARKER(c_str, ...) \
99 c_timemory_create_auto_tuple(TIMEMORY_C_LABEL(c_str), __VA_ARGS__, \
100 TIMEMORY_COMPONENTS_END)
101
102# define FREE_TIMEMORY_C_MARKER(ctimer) c_timemory_delete_auto_tuple((void*) ctimer)
103
104//--------------------------------------------------------------------------------------//
105
106#endif // !defined(DISABLE_TIMEMORY)