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