blob: b2af95937d35889d91a3410bba1a1385515a8d0c [file] [log] [blame]
Primiano Tuccide82dae2018-06-04 16:17:49 +02001/*
2 * Copyright (C) 2017 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef SRC_TRACED_PROBES_FTRACE_FTRACE_CONTROLLER_H_
18#define SRC_TRACED_PROBES_FTRACE_FTRACE_CONTROLLER_H_
19
Primiano Tuccic1855302018-12-06 10:36:55 +000020#include <stdint.h>
Primiano Tuccide82dae2018-06-04 16:17:49 +020021#include <unistd.h>
22
Primiano Tuccide82dae2018-06-04 16:17:49 +020023#include <bitset>
Primiano Tuccifd8240d2018-08-01 09:34:54 +010024#include <functional>
Primiano Tuccide82dae2018-06-04 16:17:49 +020025#include <map>
26#include <memory>
Primiano Tuccide82dae2018-06-04 16:17:49 +020027#include <set>
28#include <string>
Primiano Tuccide82dae2018-06-04 16:17:49 +020029
Eric Seckler57c89d92018-10-26 15:11:55 +010030#include "perfetto/base/gtest_prod_util.h"
Primiano Tuccide82dae2018-06-04 16:17:49 +020031#include "perfetto/base/task_runner.h"
Primiano Tuccifd8240d2018-08-01 09:34:54 +010032#include "perfetto/base/utils.h"
Primiano Tuccide82dae2018-06-04 16:17:49 +020033#include "perfetto/base/weak_ptr.h"
Primiano Tuccic1855302018-12-06 10:36:55 +000034#include "perfetto/tracing/core/basic_types.h"
Primiano Tucci0f2f3b42019-05-21 19:37:01 +010035#include "src/traced/probes/ftrace/ftrace_config_utils.h"
Primiano Tuccic1855302018-12-06 10:36:55 +000036#include "src/traced/probes/ftrace/ftrace_thread_sync.h"
Primiano Tuccide82dae2018-06-04 16:17:49 +020037
38namespace perfetto {
39
Primiano Tuccifd8240d2018-08-01 09:34:54 +010040class CpuReader;
41class FtraceConfigMuxer;
42class FtraceDataSource;
43class FtraceProcfs;
44class ProtoTranslationTable;
45struct FtraceStats;
Primiano Tuccide82dae2018-06-04 16:17:49 +020046
47// Method of last resort to reset ftrace state.
48void HardResetFtraceState();
49
Primiano Tuccide82dae2018-06-04 16:17:49 +020050// Utility class for controlling ftrace.
51class FtraceController {
52 public:
Primiano Tuccif9d9c732018-11-28 21:16:15 +000053 static const char* const kTracingPaths[];
54
Primiano Tuccifd8240d2018-08-01 09:34:54 +010055 class Observer {
56 public:
57 virtual ~Observer();
58 virtual void OnFtraceDataWrittenIntoDataSourceBuffers() = 0;
59 };
Primiano Tuccide82dae2018-06-04 16:17:49 +020060
Primiano Tuccifd8240d2018-08-01 09:34:54 +010061 // The passed Observer must outlive the returned FtraceController instance.
62 static std::unique_ptr<FtraceController> Create(base::TaskRunner*, Observer*);
63 virtual ~FtraceController();
Primiano Tuccide82dae2018-06-04 16:17:49 +020064
Primiano Tuccic1855302018-12-06 10:36:55 +000065 // These two methods are called by CpuReader(s) from their worker threads.
66 static void OnCpuReaderRead(size_t cpu, int generation, FtraceThreadSync*);
67 static void OnCpuReaderFlush(size_t cpu, int generation, FtraceThreadSync*);
68
Primiano Tuccide82dae2018-06-04 16:17:49 +020069 void DisableAllEvents();
70 void WriteTraceMarker(const std::string& s);
71 void ClearTrace();
72
Primiano Tuccifd8240d2018-08-01 09:34:54 +010073 bool AddDataSource(FtraceDataSource*) PERFETTO_WARN_UNUSED_RESULT;
Primiano Tucci8a0dc5d2018-10-02 12:51:11 +010074 bool StartDataSource(FtraceDataSource*);
Primiano Tuccifd8240d2018-08-01 09:34:54 +010075 void RemoveDataSource(FtraceDataSource*);
76
Primiano Tuccic1855302018-12-06 10:36:55 +000077 // Force a read of the ftrace buffers, including kernel buffer pages that
78 // are not full. Will call OnFtraceFlushComplete() on all
79 // |started_data_sources_| once all workers have flushed (or timed out).
80 void Flush(FlushRequestID);
81
Primiano Tuccifd8240d2018-08-01 09:34:54 +010082 void DumpFtraceStats(FtraceStats*);
83
84 base::WeakPtr<FtraceController> GetWeakPtr() {
85 return weak_factory_.GetWeakPtr();
86 }
87
Primiano Tuccide82dae2018-06-04 16:17:49 +020088 protected:
89 // Protected for testing.
90 FtraceController(std::unique_ptr<FtraceProcfs>,
91 std::unique_ptr<ProtoTranslationTable>,
92 std::unique_ptr<FtraceConfigMuxer>,
Primiano Tuccifd8240d2018-08-01 09:34:54 +010093 base::TaskRunner*,
94 Observer*);
Primiano Tuccide82dae2018-06-04 16:17:49 +020095
Primiano Tuccifd8240d2018-08-01 09:34:54 +010096 virtual void OnDrainCpuForTesting(size_t /*cpu*/) {}
Primiano Tuccide82dae2018-06-04 16:17:49 +020097
98 // Protected and virtual for testing.
99 virtual uint64_t NowMs() const;
100
101 private:
Primiano Tuccide82dae2018-06-04 16:17:49 +0200102 friend class TestFtraceController;
103 FRIEND_TEST(FtraceControllerIntegrationTest, EnableDisableEvent);
104
105 FtraceController(const FtraceController&) = delete;
106 FtraceController& operator=(const FtraceController&) = delete;
107
Primiano Tuccic1855302018-12-06 10:36:55 +0000108 void OnFlushTimeout(FlushRequestID);
109 void DrainCPUs(int generation);
110 void UnblockReaders();
111 void NotifyFlushCompleteToStartedDataSources(FlushRequestID);
112 void IssueThreadSyncCmd(FtraceThreadSync::Cmd,
113 std::unique_lock<std::mutex> = {});
Primiano Tuccide82dae2018-06-04 16:17:49 +0200114
115 uint32_t GetDrainPeriodMs();
116
Primiano Tuccide82dae2018-06-04 16:17:49 +0200117 void StartIfNeeded();
118 void StopIfNeeded();
119
Primiano Tuccifd8240d2018-08-01 09:34:54 +0100120 base::TaskRunner* const task_runner_;
121 Observer* const observer_;
Primiano Tuccic1855302018-12-06 10:36:55 +0000122 FtraceThreadSync thread_sync_;
Primiano Tuccide82dae2018-06-04 16:17:49 +0200123 std::unique_ptr<FtraceProcfs> ftrace_procfs_;
124 std::unique_ptr<ProtoTranslationTable> table_;
125 std::unique_ptr<FtraceConfigMuxer> ftrace_config_muxer_;
Primiano Tuccic1855302018-12-06 10:36:55 +0000126 int generation_ = 0;
127 FlushRequestID cur_flush_request_id_ = 0;
Primiano Tuccide82dae2018-06-04 16:17:49 +0200128 bool atrace_running_ = false;
Primiano Tuccic1855302018-12-06 10:36:55 +0000129 std::vector<std::unique_ptr<CpuReader>> cpu_readers_;
Primiano Tuccifd8240d2018-08-01 09:34:54 +0100130 std::set<FtraceDataSource*> data_sources_;
Primiano Tucci8a0dc5d2018-10-02 12:51:11 +0100131 std::set<FtraceDataSource*> started_data_sources_;
Primiano Tuccide82dae2018-06-04 16:17:49 +0200132 PERFETTO_THREAD_CHECKER(thread_checker_)
Florian Mayer0bc1bd62019-03-29 11:32:03 +0000133 base::WeakPtrFactory<FtraceController> weak_factory_; // Keep last.
Primiano Tuccide82dae2018-06-04 16:17:49 +0200134};
135
136} // namespace perfetto
137
138#endif // SRC_TRACED_PROBES_FTRACE_FTRACE_CONTROLLER_H_