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.
extern.hpp
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/**
26 * \headerfile "timemory/ert/extern.hpp"
27 * Extern template declarations
28 *
29 */
30
31#pragma once
32
33#include "timemory/backends/device.hpp"
37#include "timemory/ert/data.hpp"
42
43#if defined(TIMEMORY_USE_CUDA)
44# include "timemory/components/cuda/backends.hpp"
45#endif
46
47namespace tim
48{
49namespace ert
50{
51//
52//--------------------------------------------------------------------------------------//
53//
54// Don't enter this block while compiling CUDA
55//
56//--------------------------------------------------------------------------------------//
57//
58TIMEMORY_DECLARE_ERT_EXTERN_TEMPLATE(class exec_data<component::ert_timer>)
59//
61 class counter<device::cpu, float, component::ert_timer>)
63 class counter<device::cpu, double, component::ert_timer>)
64//
66 struct configuration<device::cpu, float, component::ert_timer>)
68 struct configuration<device::cpu, double, component::ert_timer>)
69//
71 struct executor<device::cpu, float, component::ert_timer>)
73 struct executor<device::cpu, double, component::ert_timer>)
74//
75//--------------------------------------------------------------------------------------//
76//
77// Don't enter this block while compiling C++
78//
79//--------------------------------------------------------------------------------------//
80//
82 class counter<device::gpu, float, component::ert_timer>)
84 class counter<device::gpu, double, component::ert_timer>)
85//
86#if defined(TIMEMORY_USE_CUDA_HALF)
88 class counter<device::gpu, cuda::fp16_t, component::ert_timer>)
89#endif
90//
92 struct configuration<device::gpu, float, component::ert_timer>)
94 struct configuration<device::gpu, double, component::ert_timer>)
95//
97 struct executor<device::gpu, float, component::ert_timer>)
99 struct executor<device::gpu, double, component::ert_timer>)
100//
101#if defined(TIMEMORY_USE_CUDA_HALF)
103 struct configuration<device::gpu, cuda::fp16_t, component::ert_timer>)
104//
106 struct executor<device::gpu, cuda::fp16_t, component::ert_timer>)
107#endif
108//
109} // namespace ert
110} // namespace tim
#define TIMEMORY_DECLARE_ERT_EXTERN_TEMPLATE_GPU(...)
Definition: macros.hpp:103
#define TIMEMORY_DECLARE_ERT_EXTERN_TEMPLATE_CPU(...)
Definition: macros.hpp:81
#define TIMEMORY_DECLARE_ERT_EXTERN_TEMPLATE(...)
Definition: macros.hpp:51
Definition: kokkosp.cpp:39