xref: /aosp_15_r20/test/dittosuite/src/tracer.cpp (revision 6fa2df46f119dce7527f5beb2814eca0e6f886ac)
1*6fa2df46SAndroid Build Coastguard Worker // Copyright (C) 2023 The Android Open Source Project
2*6fa2df46SAndroid Build Coastguard Worker //
3*6fa2df46SAndroid Build Coastguard Worker // Licensed under the Apache License, Version 2.0 (the "License");
4*6fa2df46SAndroid Build Coastguard Worker // you may not use this file except in compliance with the License.
5*6fa2df46SAndroid Build Coastguard Worker // You may obtain a copy of the License at
6*6fa2df46SAndroid Build Coastguard Worker //
7*6fa2df46SAndroid Build Coastguard Worker //      http://www.apache.org/licenses/LICENSE-2.0
8*6fa2df46SAndroid Build Coastguard Worker //
9*6fa2df46SAndroid Build Coastguard Worker // Unless required by applicable law or agreed to in writing, software
10*6fa2df46SAndroid Build Coastguard Worker // distributed under the License is distributed on an "AS IS" BASIS,
11*6fa2df46SAndroid Build Coastguard Worker // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*6fa2df46SAndroid Build Coastguard Worker // See the License for the specific language governing permissions and
13*6fa2df46SAndroid Build Coastguard Worker // limitations under the License.
14*6fa2df46SAndroid Build Coastguard Worker 
15*6fa2df46SAndroid Build Coastguard Worker #include <ditto/logger.h>
16*6fa2df46SAndroid Build Coastguard Worker #include <ditto/tracer.h>
17*6fa2df46SAndroid Build Coastguard Worker 
18*6fa2df46SAndroid Build Coastguard Worker #include <google/protobuf/util/json_util.h>
19*6fa2df46SAndroid Build Coastguard Worker 
20*6fa2df46SAndroid Build Coastguard Worker #include <cstdarg>
21*6fa2df46SAndroid Build Coastguard Worker #include <unistd.h>
22*6fa2df46SAndroid Build Coastguard Worker 
23*6fa2df46SAndroid Build Coastguard Worker namespace dittosuite {
24*6fa2df46SAndroid Build Coastguard Worker 
random_string(int len)25*6fa2df46SAndroid Build Coastguard Worker std::string random_string(int len) {
26*6fa2df46SAndroid Build Coastguard Worker   std::string char_set;
27*6fa2df46SAndroid Build Coastguard Worker   for (char c = '0'; c <= '9'; ++c) {
28*6fa2df46SAndroid Build Coastguard Worker     char_set += c;
29*6fa2df46SAndroid Build Coastguard Worker   }
30*6fa2df46SAndroid Build Coastguard Worker   for (char c = 'a'; c <= 'z'; ++c) {
31*6fa2df46SAndroid Build Coastguard Worker     char_set += c;
32*6fa2df46SAndroid Build Coastguard Worker   }
33*6fa2df46SAndroid Build Coastguard Worker   for (char c = 'A'; c <= 'Z'; ++c) {
34*6fa2df46SAndroid Build Coastguard Worker     char_set += c;
35*6fa2df46SAndroid Build Coastguard Worker   }
36*6fa2df46SAndroid Build Coastguard Worker 
37*6fa2df46SAndroid Build Coastguard Worker   std::string ret;
38*6fa2df46SAndroid Build Coastguard Worker 
39*6fa2df46SAndroid Build Coastguard Worker   ret.reserve(len);
40*6fa2df46SAndroid Build Coastguard Worker   for (int i = 0; i < len; ++i) {
41*6fa2df46SAndroid Build Coastguard Worker     ret += char_set[rand() % (char_set.length())];
42*6fa2df46SAndroid Build Coastguard Worker   }
43*6fa2df46SAndroid Build Coastguard Worker 
44*6fa2df46SAndroid Build Coastguard Worker   return ret;
45*6fa2df46SAndroid Build Coastguard Worker }
46*6fa2df46SAndroid Build Coastguard Worker 
StartSession(std::unique_ptr<dittosuiteproto::Benchmark> benchmark)47*6fa2df46SAndroid Build Coastguard Worker void Tracer::StartSession(std::unique_ptr<dittosuiteproto::Benchmark> benchmark) {
48*6fa2df46SAndroid Build Coastguard Worker   if (!trace_marker_.good()) {
49*6fa2df46SAndroid Build Coastguard Worker     return;
50*6fa2df46SAndroid Build Coastguard Worker   }
51*6fa2df46SAndroid Build Coastguard Worker 
52*6fa2df46SAndroid Build Coastguard Worker   std::string benchmark_dump;
53*6fa2df46SAndroid Build Coastguard Worker   google::protobuf::util::JsonPrintOptions options;
54*6fa2df46SAndroid Build Coastguard Worker 
55*6fa2df46SAndroid Build Coastguard Worker   auto status = google::protobuf::util::MessageToJsonString(*benchmark, &benchmark_dump, options);
56*6fa2df46SAndroid Build Coastguard Worker 
57*6fa2df46SAndroid Build Coastguard Worker   if (!status.ok()) {
58*6fa2df46SAndroid Build Coastguard Worker     LOGF("Unable to dump benchmark into string");
59*6fa2df46SAndroid Build Coastguard Worker   }
60*6fa2df46SAndroid Build Coastguard Worker 
61*6fa2df46SAndroid Build Coastguard Worker   id_ = random_string(16);
62*6fa2df46SAndroid Build Coastguard Worker 
63*6fa2df46SAndroid Build Coastguard Worker   trace_marker_ << trace_format("B", std::to_string(getpid()), "Session", benchmark_dump, id_);
64*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.write("\0", 1);
65*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.flush();
66*6fa2df46SAndroid Build Coastguard Worker }
67*6fa2df46SAndroid Build Coastguard Worker 
Start(const std::string & splice)68*6fa2df46SAndroid Build Coastguard Worker void Tracer::Start(const std::string& splice) {
69*6fa2df46SAndroid Build Coastguard Worker   if (!trace_marker_.good()) {
70*6fa2df46SAndroid Build Coastguard Worker     return;
71*6fa2df46SAndroid Build Coastguard Worker   }
72*6fa2df46SAndroid Build Coastguard Worker 
73*6fa2df46SAndroid Build Coastguard Worker   trace_marker_ << trace_format("B", std::to_string(getpid()), splice);
74*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.write("\0", 1);
75*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.flush();
76*6fa2df46SAndroid Build Coastguard Worker }
77*6fa2df46SAndroid Build Coastguard Worker 
End(const std::string & splice)78*6fa2df46SAndroid Build Coastguard Worker void Tracer::End(const std::string& splice) {
79*6fa2df46SAndroid Build Coastguard Worker   if (!trace_marker_.good()) {
80*6fa2df46SAndroid Build Coastguard Worker     return;
81*6fa2df46SAndroid Build Coastguard Worker   }
82*6fa2df46SAndroid Build Coastguard Worker 
83*6fa2df46SAndroid Build Coastguard Worker   trace_marker_ << trace_format("E", std::to_string(getpid()), splice);
84*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.write("\0", 1);
85*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.flush();
86*6fa2df46SAndroid Build Coastguard Worker }
87*6fa2df46SAndroid Build Coastguard Worker 
Tracer()88*6fa2df46SAndroid Build Coastguard Worker Tracer::Tracer() {
89*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.open("/sys/kernel/tracing/trace_marker",
90*6fa2df46SAndroid Build Coastguard Worker                      std::ofstream::out | std::ofstream::binary);
91*6fa2df46SAndroid Build Coastguard Worker   if (!trace_marker_.good()) {
92*6fa2df46SAndroid Build Coastguard Worker     LOGW("Unable to open trace_marker");
93*6fa2df46SAndroid Build Coastguard Worker   }
94*6fa2df46SAndroid Build Coastguard Worker }
95*6fa2df46SAndroid Build Coastguard Worker 
~Tracer()96*6fa2df46SAndroid Build Coastguard Worker Tracer::~Tracer() {
97*6fa2df46SAndroid Build Coastguard Worker   if (!trace_marker_.good()) {
98*6fa2df46SAndroid Build Coastguard Worker     return;
99*6fa2df46SAndroid Build Coastguard Worker   }
100*6fa2df46SAndroid Build Coastguard Worker 
101*6fa2df46SAndroid Build Coastguard Worker   trace_marker_ << trace_format("E", std::to_string(getpid()), "Session", id_);
102*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.write("\0", 1);
103*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.flush();
104*6fa2df46SAndroid Build Coastguard Worker 
105*6fa2df46SAndroid Build Coastguard Worker   trace_marker_.close();
106*6fa2df46SAndroid Build Coastguard Worker }
107*6fa2df46SAndroid Build Coastguard Worker 
108*6fa2df46SAndroid Build Coastguard Worker }  // namespace dittosuite
109