xref: /aosp_15_r20/external/stg/runtime.cc (revision 9e3b08ae94a55201065475453d799e8b1378bea6)
1*9e3b08aeSAndroid Build Coastguard Worker // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
2*9e3b08aeSAndroid Build Coastguard Worker // -*- mode: C++ -*-
3*9e3b08aeSAndroid Build Coastguard Worker //
4*9e3b08aeSAndroid Build Coastguard Worker // Copyright 2021-2023 Google LLC
5*9e3b08aeSAndroid Build Coastguard Worker //
6*9e3b08aeSAndroid Build Coastguard Worker // Licensed under the Apache License v2.0 with LLVM Exceptions (the
7*9e3b08aeSAndroid Build Coastguard Worker // "License"); you may not use this file except in compliance with the
8*9e3b08aeSAndroid Build Coastguard Worker // License.  You may obtain a copy of the License at
9*9e3b08aeSAndroid Build Coastguard Worker //
10*9e3b08aeSAndroid Build Coastguard Worker //     https://llvm.org/LICENSE.txt
11*9e3b08aeSAndroid Build Coastguard Worker //
12*9e3b08aeSAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
13*9e3b08aeSAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
14*9e3b08aeSAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15*9e3b08aeSAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
16*9e3b08aeSAndroid Build Coastguard Worker // limitations under the License.
17*9e3b08aeSAndroid Build Coastguard Worker //
18*9e3b08aeSAndroid Build Coastguard Worker // Author: Giuliano Procida
19*9e3b08aeSAndroid Build Coastguard Worker 
20*9e3b08aeSAndroid Build Coastguard Worker #include "runtime.h"
21*9e3b08aeSAndroid Build Coastguard Worker 
22*9e3b08aeSAndroid Build Coastguard Worker #include <time.h>
23*9e3b08aeSAndroid Build Coastguard Worker 
24*9e3b08aeSAndroid Build Coastguard Worker #include <iomanip>
25*9e3b08aeSAndroid Build Coastguard Worker #include <ostream>
26*9e3b08aeSAndroid Build Coastguard Worker 
27*9e3b08aeSAndroid Build Coastguard Worker namespace stg {
28*9e3b08aeSAndroid Build Coastguard Worker 
operator <<(std::ostream & os,const Frequencies & frequencies)29*9e3b08aeSAndroid Build Coastguard Worker std::ostream& operator<<(std::ostream& os, const Frequencies& frequencies) {
30*9e3b08aeSAndroid Build Coastguard Worker   bool separate = false;
31*9e3b08aeSAndroid Build Coastguard Worker   for (const auto& [item, frequency] : frequencies.counts) {
32*9e3b08aeSAndroid Build Coastguard Worker     if (separate) {
33*9e3b08aeSAndroid Build Coastguard Worker       os << ' ';
34*9e3b08aeSAndroid Build Coastguard Worker     } else {
35*9e3b08aeSAndroid Build Coastguard Worker       separate = true;
36*9e3b08aeSAndroid Build Coastguard Worker     }
37*9e3b08aeSAndroid Build Coastguard Worker     os << '[' << item << "]=" << frequency;
38*9e3b08aeSAndroid Build Coastguard Worker   }
39*9e3b08aeSAndroid Build Coastguard Worker   return os;
40*9e3b08aeSAndroid Build Coastguard Worker }
41*9e3b08aeSAndroid Build Coastguard Worker 
operator <<(std::ostream & os,const Nanoseconds & value)42*9e3b08aeSAndroid Build Coastguard Worker std::ostream& operator<<(std::ostream& os, const Nanoseconds& value) {
43*9e3b08aeSAndroid Build Coastguard Worker   const auto millis = value.ns / 1'000'000;
44*9e3b08aeSAndroid Build Coastguard Worker   const auto nanos = value.ns % 1'000'000;
45*9e3b08aeSAndroid Build Coastguard Worker   // fill needs to be reset; width is reset automatically
46*9e3b08aeSAndroid Build Coastguard Worker   return os << millis << '.' << std::setfill('0') << std::setw(6) << nanos
47*9e3b08aeSAndroid Build Coastguard Worker             << std::setfill(' ') << " ms";
48*9e3b08aeSAndroid Build Coastguard Worker }
49*9e3b08aeSAndroid Build Coastguard Worker 
Time(Runtime & runtime,const char * name)50*9e3b08aeSAndroid Build Coastguard Worker Time::Time(Runtime& runtime, const char* name)
51*9e3b08aeSAndroid Build Coastguard Worker     : runtime_(runtime), name_(name) {
52*9e3b08aeSAndroid Build Coastguard Worker   clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &start_);
53*9e3b08aeSAndroid Build Coastguard Worker }
54*9e3b08aeSAndroid Build Coastguard Worker 
~Time()55*9e3b08aeSAndroid Build Coastguard Worker Time::~Time() {
56*9e3b08aeSAndroid Build Coastguard Worker   struct timespec finish;
57*9e3b08aeSAndroid Build Coastguard Worker   clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &finish);
58*9e3b08aeSAndroid Build Coastguard Worker   const auto seconds = finish.tv_sec - start_.tv_sec;
59*9e3b08aeSAndroid Build Coastguard Worker   const auto nanos = finish.tv_nsec - start_.tv_nsec;
60*9e3b08aeSAndroid Build Coastguard Worker   const Nanoseconds value(seconds * 1'000'000'000 + nanos);
61*9e3b08aeSAndroid Build Coastguard Worker   runtime_.PrintMetric(name_, value);
62*9e3b08aeSAndroid Build Coastguard Worker }
63*9e3b08aeSAndroid Build Coastguard Worker 
Counter(Runtime & runtime,const char * name)64*9e3b08aeSAndroid Build Coastguard Worker Counter::Counter(Runtime& runtime, const char* name)
65*9e3b08aeSAndroid Build Coastguard Worker     : runtime_(runtime), name_(name), value_(0) {
66*9e3b08aeSAndroid Build Coastguard Worker }
67*9e3b08aeSAndroid Build Coastguard Worker 
~Counter()68*9e3b08aeSAndroid Build Coastguard Worker Counter::~Counter() {
69*9e3b08aeSAndroid Build Coastguard Worker   runtime_.PrintMetric(name_, value_);
70*9e3b08aeSAndroid Build Coastguard Worker }
71*9e3b08aeSAndroid Build Coastguard Worker 
Histogram(Runtime & runtime,const char * name)72*9e3b08aeSAndroid Build Coastguard Worker Histogram::Histogram(Runtime& runtime, const char* name)
73*9e3b08aeSAndroid Build Coastguard Worker     : runtime_(runtime), name_(name) {
74*9e3b08aeSAndroid Build Coastguard Worker }
75*9e3b08aeSAndroid Build Coastguard Worker 
~Histogram()76*9e3b08aeSAndroid Build Coastguard Worker Histogram::~Histogram() {
77*9e3b08aeSAndroid Build Coastguard Worker   runtime_.PrintMetric(name_, frequencies_);
78*9e3b08aeSAndroid Build Coastguard Worker }
79*9e3b08aeSAndroid Build Coastguard Worker 
80*9e3b08aeSAndroid Build Coastguard Worker }  // namespace stg
81