File: GPUQREngine_Timing.hpp

package info (click to toggle)
suitesparse 1%3A5.8.1%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 152,716 kB
  • sloc: ansic: 774,385; cpp: 24,213; makefile: 6,310; fortran: 1,927; java: 1,826; csh: 1,686; ruby: 725; sh: 535; perl: 225; python: 209; sed: 164; awk: 60
file content (46 lines) | stat: -rw-r--r-- 1,440 bytes parent folder | download | duplicates (4)
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
// =============================================================================
// === GPUQREngine/Include/GPUQREngine_timing.hpp ==============================
// =============================================================================
//
// Contains timing macros that wrap GPU timing logic, using cudaEvents.
//
// =============================================================================


#ifndef GPUQRENGINE_TIMING_HPP
#define GPUQRENGINE_TIMING_HPP

#ifdef TIMING

// create the timer
#define TIMER_INIT()                            \
cudaEvent_t start, stop ;                       \
cudaEventCreate(&start) ;                       \
cudaEventCreate(&stop) ;                        \

// start the timer
#define TIMER_START()                           \
cudaEventRecord(start, 0);                      \

// stop the timer and get the time since the last tic
// t is the time since the last TIMER_START()
#define TIMER_STOP(t)                           \
cudaEventRecord(stop, 0);                       \
cudaThreadSynchronize();                        \
cudaEventElapsedTime(&(t), start, stop);        \

// destroy the timer
#define TIMER_FINISH()                          \
cudaEventDestroy(start);                        \
cudaEventDestroy(stop);                         \

#else

// compile with no timing
#define TIMER_INIT() ;
#define TIMER_START() ;
#define TIMER_STOP(t) ;
#define TIMER_FINISH() ;

#endif
#endif