blob: b1845ce9c4c52ff80c8a53fadbdd9b55a70d9598 [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
20#include <unistd.h>
21
Primiano Tuccide82dae2018-06-04 16:17:49 +020022#include <bitset>
23#include <condition_variable>
Primiano Tuccifd8240d2018-08-01 09:34:54 +010024#include <functional>
Primiano Tuccide82dae2018-06-04 16:17:49 +020025#include <map>
26#include <memory>
27#include <mutex>
28#include <set>
29#include <string>
Primiano Tuccide82dae2018-06-04 16:17:49 +020030
Eric Seckler57c89d92018-10-26 15:11:55 +010031#include "perfetto/base/gtest_prod_util.h"
Primiano Tuccide82dae2018-06-04 16:17:49 +020032#include "perfetto/base/task_runner.h"
Primiano Tuccifd8240d2018-08-01 09:34:54 +010033#include "perfetto/base/utils.h"
Primiano Tuccide82dae2018-06-04 16:17:49 +020034#include "perfetto/base/weak_ptr.h"
Primiano Tuccifd8240d2018-08-01 09:34:54 +010035#include "src/traced/probes/ftrace/ftrace_config.h"
Primiano Tuccide82dae2018-06-04 16:17:49 +020036
37namespace perfetto {
38
Primiano Tuccifd8240d2018-08-01 09:34:54 +010039class CpuReader;
40class FtraceConfigMuxer;
41class FtraceDataSource;
42class FtraceProcfs;
43class ProtoTranslationTable;
44struct FtraceStats;
Primiano Tuccide82dae2018-06-04 16:17:49 +020045
46// Method of last resort to reset ftrace state.
47void HardResetFtraceState();
48
Primiano Tuccide82dae2018-06-04 16:17:49 +020049// Utility class for controlling ftrace.
50class FtraceController {
51 public:
Primiano Tuccif9d9c732018-11-28 21:16:15 +000052 static const char* const kTracingPaths[];
53
Primiano Tuccifd8240d2018-08-01 09:34:54 +010054 class Observer {
55 public:
56 virtual ~Observer();
57 virtual void OnFtraceDataWrittenIntoDataSourceBuffers() = 0;
58 };
Primiano Tuccide82dae2018-06-04 16:17:49 +020059
Primiano Tuccifd8240d2018-08-01 09:34:54 +010060 // The passed Observer must outlive the returned FtraceController instance.
61 static std::unique_ptr<FtraceController> Create(base::TaskRunner*, Observer*);
62 virtual ~FtraceController();
Primiano Tuccide82dae2018-06-04 16:17:49 +020063
64 void DisableAllEvents();
65 void WriteTraceMarker(const std::string& s);
66 void ClearTrace();
67
Primiano Tuccifd8240d2018-08-01 09:34:54 +010068 bool AddDataSource(FtraceDataSource*) PERFETTO_WARN_UNUSED_RESULT;
Primiano Tucci8a0dc5d2018-10-02 12:51:11 +010069 bool StartDataSource(FtraceDataSource*);
Primiano Tuccifd8240d2018-08-01 09:34:54 +010070 void RemoveDataSource(FtraceDataSource*);
71
72 void DumpFtraceStats(FtraceStats*);
73
74 base::WeakPtr<FtraceController> GetWeakPtr() {
75 return weak_factory_.GetWeakPtr();
76 }
77
Primiano Tuccide82dae2018-06-04 16:17:49 +020078 protected:
79 // Protected for testing.
80 FtraceController(std::unique_ptr<FtraceProcfs>,
81 std::unique_ptr<ProtoTranslationTable>,
82 std::unique_ptr<FtraceConfigMuxer>,
Primiano Tuccifd8240d2018-08-01 09:34:54 +010083 base::TaskRunner*,
84 Observer*);
Primiano Tuccide82dae2018-06-04 16:17:49 +020085
Primiano Tuccifd8240d2018-08-01 09:34:54 +010086 virtual void OnDrainCpuForTesting(size_t /*cpu*/) {}
Primiano Tuccide82dae2018-06-04 16:17:49 +020087
88 // Protected and virtual for testing.
89 virtual uint64_t NowMs() const;
90
91 private:
Primiano Tuccide82dae2018-06-04 16:17:49 +020092 friend class TestFtraceController;
93 FRIEND_TEST(FtraceControllerIntegrationTest, EnableDisableEvent);
94
95 FtraceController(const FtraceController&) = delete;
96 FtraceController& operator=(const FtraceController&) = delete;
97
98 // Called on a worker thread when |cpu| has at least one page of data
99 // available for reading.
100 void OnDataAvailable(base::WeakPtr<FtraceController>,
101 size_t generation,
102 size_t cpu,
103 uint32_t drain_period_ms);
104
105 static void DrainCPUs(base::WeakPtr<FtraceController>, size_t generation);
106 static void UnblockReaders(const base::WeakPtr<FtraceController>&);
107
108 uint32_t GetDrainPeriodMs();
109
Primiano Tuccide82dae2018-06-04 16:17:49 +0200110 void StartIfNeeded();
111 void StopIfNeeded();
112
113 // Begin lock-protected members.
114 std::mutex lock_;
115 std::condition_variable data_drained_;
Hector Dearmanc8339932018-08-10 11:22:46 +0100116 std::bitset<base::kMaxCpus> cpus_to_drain_;
Primiano Tuccide82dae2018-06-04 16:17:49 +0200117 bool listening_for_raw_trace_data_ = false;
118 // End lock-protected members.
119
Primiano Tuccifd8240d2018-08-01 09:34:54 +0100120 base::TaskRunner* const task_runner_;
121 Observer* const observer_;
Primiano Tuccide82dae2018-06-04 16:17:49 +0200122 std::unique_ptr<FtraceProcfs> ftrace_procfs_;
123 std::unique_ptr<ProtoTranslationTable> table_;
124 std::unique_ptr<FtraceConfigMuxer> ftrace_config_muxer_;
125 size_t generation_ = 0;
126 bool atrace_running_ = false;
Primiano Tuccib6de48b2018-07-26 16:00:44 +0100127 std::map<size_t, std::unique_ptr<CpuReader>> cpu_readers_;
Primiano Tuccifd8240d2018-08-01 09:34:54 +0100128 std::set<FtraceDataSource*> data_sources_;
Primiano Tucci8a0dc5d2018-10-02 12:51:11 +0100129 std::set<FtraceDataSource*> started_data_sources_;
Primiano Tuccifd8240d2018-08-01 09:34:54 +0100130 base::WeakPtrFactory<FtraceController> weak_factory_; // Keep last.
Primiano Tuccide82dae2018-06-04 16:17:49 +0200131 PERFETTO_THREAD_CHECKER(thread_checker_)
132};
133
134} // namespace perfetto
135
136#endif // SRC_TRACED_PROBES_FTRACE_FTRACE_CONTROLLER_H_