aboutsummaryrefslogtreecommitdiff
path: root/src/trace_processor/importers/ftrace/iostat_tracker.cc
blob: 27e576204197de68c48940404f471f2d47d4b0ea (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
/*
 * Copyright (C) 2022 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

#include "src/trace_processor/importers/ftrace/iostat_tracker.h"
#include "protos/perfetto/trace/ftrace/f2fs.pbzero.h"
#include "src/trace_processor/importers/common/event_tracker.h"
#include "src/trace_processor/importers/common/track_tracker.h"

namespace perfetto {
namespace trace_processor {

static constexpr char kF2fsIostatTag[] = "f2fs_iostat";
static constexpr char kF2fsIostatLatencyTag[] = "f2fs_iostat_latency";

IostatTracker::IostatTracker(TraceProcessorContext* context)
    : context_(context) {}

std::string IostatTracker::GetDeviceName(uint64_t dev_num) {
  std::string dev_name = std::to_string((dev_num & 0xFF00) >> 8) + ":" +
                         std::to_string(dev_num & 0xFF);
  return "[" + dev_name + "]";
}

void IostatTracker::ParseF2fsIostat(int64_t timestamp,
                                    protozero::ConstBytes blob) {
  protos::pbzero::F2fsIostatFtraceEvent::Decoder evt(blob.data, blob.size);
  std::string tagPrefix =
      std::string(kF2fsIostatTag) + "." + GetDeviceName(evt.dev());
  auto push_counter = [this, timestamp, tagPrefix](const char* counter_name,
                                                   uint64_t value) {
    std::string track_name = tagPrefix + "." + std::string(counter_name);
    StringId string_id = context_->storage->InternString(track_name.c_str());
    TrackId track =
        context_->track_tracker->InternGlobalCounterTrack(string_id);
    context_->event_tracker->PushCounter(timestamp, static_cast<double>(value),
                                         track);
  };

  push_counter("write_app_total", evt.app_wio());
  push_counter("write_app_direct", evt.app_dio());
  push_counter("write_app_buffered", evt.app_bio());
  push_counter("write_app_mapped", evt.app_mio());
  push_counter("write_fs_data", evt.fs_dio());
  push_counter("write_fs_node", evt.fs_nio());
  push_counter("write_fs_meta", evt.fs_mio());
  push_counter("write_gc_data", evt.fs_gc_dio());
  push_counter("write_gc_node", evt.fs_gc_nio());
  push_counter("write_cp_data", evt.fs_cp_dio());
  push_counter("write_cp_node", evt.fs_cp_nio());
  push_counter("write_cp_meta", evt.fs_cp_mio());
  push_counter("read_app_total", evt.app_rio());
  push_counter("read_app_direct", evt.app_drio());
  push_counter("read_app_buffered", evt.app_brio());
  push_counter("read_app_mapped", evt.app_mrio());
  push_counter("read_fs_data", evt.fs_drio());
  push_counter("read_fs_gdata", evt.fs_gdrio());
  push_counter("read_fs_cdata", evt.fs_cdrio());
  push_counter("read_fs_node", evt.fs_nrio());
  push_counter("read_fs_meta", evt.fs_mrio());
  push_counter("other_fs_discard", evt.fs_discard());
}

void IostatTracker::ParseF2fsIostatLatency(int64_t timestamp,
                                           protozero::ConstBytes blob) {
  protos::pbzero::F2fsIostatLatencyFtraceEvent::Decoder evt(blob.data,
                                                            blob.size);
  std::string tagPrefix =
      std::string(kF2fsIostatLatencyTag) + "." + GetDeviceName(evt.dev());
  auto push_counter = [this, timestamp, tagPrefix](const char* counter_name,
                                                   uint64_t value) {
    std::string track_name = tagPrefix + "." + std::string(counter_name);
    StringId string_id = context_->storage->InternString(track_name.c_str());
    TrackId track =
        context_->track_tracker->InternGlobalCounterTrack(string_id);
    context_->event_tracker->PushCounter(timestamp, static_cast<double>(value),
                                         track);
  };

  push_counter("read_data_peak", evt.d_rd_peak());
  push_counter("read_data_avg", evt.d_rd_avg());
  push_counter("read_data_cnt", evt.d_rd_cnt());
  push_counter("read_node_peak", evt.n_rd_peak());
  push_counter("read_node_avg", evt.n_rd_avg());
  push_counter("read_node_cnt", evt.n_rd_cnt());
  push_counter("read_meta_peak", evt.m_rd_peak());
  push_counter("read_meta_avg", evt.m_rd_avg());
  push_counter("read_meta_cnt", evt.m_rd_cnt());
  push_counter("write_sync_data_peak", evt.d_wr_s_peak());
  push_counter("write_sync_data_avg", evt.d_wr_s_avg());
  push_counter("write_sync_data_cnt", evt.d_wr_s_cnt());
  push_counter("write_sync_node_peak", evt.n_wr_s_peak());
  push_counter("write_sync_node_avg", evt.n_wr_s_avg());
  push_counter("write_sync_node_cnt", evt.n_wr_s_cnt());
  push_counter("write_sync_meta_peak", evt.m_wr_s_peak());
  push_counter("write_sync_meta_avg", evt.m_wr_s_avg());
  push_counter("write_sync_meta_cnt", evt.m_wr_s_cnt());
  push_counter("write_async_data_peak", evt.d_wr_as_peak());
  push_counter("write_async_data_avg", evt.d_wr_as_avg());
  push_counter("write_async_data_cnt", evt.d_wr_as_cnt());
  push_counter("write_async_node_peak", evt.n_wr_as_peak());
  push_counter("write_async_node_avg", evt.n_wr_as_avg());
  push_counter("write_async_node_cnt", evt.n_wr_as_cnt());
  push_counter("write_async_meta_peak", evt.m_wr_as_peak());
  push_counter("write_async_meta_avg", evt.m_wr_as_avg());
  push_counter("write_async_meta_cnt", evt.m_wr_as_cnt());
}

}  // namespace trace_processor
}  // namespace perfetto