1 | //===- TGTimer.cpp - TableGen Timer implementation --------------*- C++ -*-===// |
---|---|
2 | // |
3 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
4 | // See https://llvm.org/LICENSE.txt for license information. |
5 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
6 | // |
7 | //===----------------------------------------------------------------------===// |
8 | // |
9 | // Implement the tablegen timer class. |
10 | // |
11 | //===----------------------------------------------------------------------===// |
12 | |
13 | #include "llvm/TableGen/TGTimer.h" |
14 | using namespace llvm; |
15 | |
16 | // These functions implement the phase timing facility. Starting a timer |
17 | // when one is already running stops the running one. |
18 | void TGTimer::startTimer(StringRef Name) { |
19 | if (!TimingGroup) |
20 | return; |
21 | if (LastTimer && LastTimer->isRunning()) { |
22 | LastTimer->stopTimer(); |
23 | if (BackendTimer) { |
24 | LastTimer->clear(); |
25 | BackendTimer = false; |
26 | } |
27 | } |
28 | |
29 | LastTimer = std::make_unique<Timer>(args: "", args&: Name, args&: *TimingGroup); |
30 | LastTimer->startTimer(); |
31 | } |
32 | |
33 | void TGTimer::stopTimer() { |
34 | if (!TimingGroup) |
35 | return; |
36 | |
37 | assert(LastTimer && "No phase timer was started"); |
38 | LastTimer->stopTimer(); |
39 | } |
40 | |
41 | void TGTimer::startBackendTimer(StringRef Name) { |
42 | if (!TimingGroup) |
43 | return; |
44 | |
45 | startTimer(Name); |
46 | BackendTimer = true; |
47 | } |
48 | |
49 | void TGTimer::stopBackendTimer() { |
50 | if (!TimingGroup || !BackendTimer) |
51 | return; |
52 | stopTimer(); |
53 | BackendTimer = false; |
54 | } |
55 |