//===- Timer.h ----------------------------------------------*- C++ -*-===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #ifndef LLD_COMMON_TIMER_H #define LLD_COMMON_TIMER_H #include "llvm/ADT/DenseMap.h" #include "llvm/ADT/StringRef.h" #include #include #include #include #include #include namespace lld { class Timer; struct ScopedTimer { explicit ScopedTimer(Timer &t); ~ScopedTimer(); void stop(); std::chrono::time_point startTime; Timer *t = nullptr; }; class Timer { public: Timer(llvm::StringRef name, Timer &parent); static Timer &root(); void addToTotal(std::chrono::nanoseconds time) { total += time.count(); } void print(); double millis() const; private: explicit Timer(llvm::StringRef name); void print(int depth, double totalDuration, bool recurse = true) const; std::atomic total; std::vector children; std::string name; }; } // namespace lld #endif