1 /*
2 * Copyright (C) 2021 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 #include "perfetto/tracing/internal/tracing_backend_fake.h"
18
19 #include "perfetto/base/task_runner.h"
20 #include "perfetto/ext/base/weak_ptr.h"
21 #include "perfetto/ext/tracing/core/consumer.h"
22 #include "perfetto/ext/tracing/core/producer.h"
23 #include "perfetto/ext/tracing/core/trace_writer.h"
24 #include "perfetto/ext/tracing/core/tracing_service.h"
25
26 namespace perfetto {
27 namespace internal {
28
29 namespace {
30
31 class UnsupportedProducerEndpoint : public ProducerEndpoint {
32 public:
UnsupportedProducerEndpoint(Producer * producer,base::TaskRunner * task_runner)33 UnsupportedProducerEndpoint(Producer* producer, base::TaskRunner* task_runner)
34 : producer_(producer), task_runner_(task_runner) {
35 // The SDK will attempt to reconnect the producer, so instead we allow it
36 // to connect successfully, but never start any sessions.
37 auto weak_ptr = weak_ptr_factory_.GetWeakPtr();
38 task_runner_->PostTask([weak_ptr] {
39 if (weak_ptr)
40 weak_ptr->producer_->OnConnect();
41 });
42 }
~UnsupportedProducerEndpoint()43 ~UnsupportedProducerEndpoint() override { producer_->OnDisconnect(); }
44
RegisterDataSource(const DataSourceDescriptor &)45 void RegisterDataSource(const DataSourceDescriptor&) override {}
UpdateDataSource(const DataSourceDescriptor &)46 void UpdateDataSource(const DataSourceDescriptor&) override {}
UnregisterDataSource(const std::string &)47 void UnregisterDataSource(const std::string& /*name*/) override {}
48
RegisterTraceWriter(uint32_t,uint32_t)49 void RegisterTraceWriter(uint32_t /*writer_id*/,
50 uint32_t /*target_buffer*/) override {}
UnregisterTraceWriter(uint32_t)51 void UnregisterTraceWriter(uint32_t /*writer_id*/) override {}
52
CommitData(const CommitDataRequest &,CommitDataCallback callback={})53 void CommitData(const CommitDataRequest&,
54 CommitDataCallback callback = {}) override {
55 callback();
56 }
57
shared_memory() const58 SharedMemory* shared_memory() const override { return nullptr; }
shared_buffer_page_size_kb() const59 size_t shared_buffer_page_size_kb() const override { return 0; }
60
CreateTraceWriter(BufferID,BufferExhaustedPolicy=BufferExhaustedPolicy::kDefault)61 std::unique_ptr<TraceWriter> CreateTraceWriter(
62 BufferID /*target_buffer*/,
63 BufferExhaustedPolicy = BufferExhaustedPolicy::kDefault) override {
64 return nullptr;
65 }
66
MaybeSharedMemoryArbiter()67 SharedMemoryArbiter* MaybeSharedMemoryArbiter() override { return nullptr; }
IsShmemProvidedByProducer() const68 bool IsShmemProvidedByProducer() const override { return false; }
69
NotifyFlushComplete(FlushRequestID)70 void NotifyFlushComplete(FlushRequestID) override {}
NotifyDataSourceStarted(DataSourceInstanceID)71 void NotifyDataSourceStarted(DataSourceInstanceID) override {}
NotifyDataSourceStopped(DataSourceInstanceID)72 void NotifyDataSourceStopped(DataSourceInstanceID) override {}
ActivateTriggers(const std::vector<std::string> &)73 void ActivateTriggers(const std::vector<std::string>&) override {}
74
Sync(std::function<void ()> callback)75 void Sync(std::function<void()> callback) override { callback(); }
76
77 private:
78 Producer* const producer_;
79 base::TaskRunner* const task_runner_;
80 base::WeakPtrFactory<UnsupportedProducerEndpoint> weak_ptr_factory_{
81 this}; // Keep last.
82 };
83
84 class UnsupportedConsumerEndpoint : public ConsumerEndpoint {
85 public:
UnsupportedConsumerEndpoint(Consumer * consumer,base::TaskRunner * task_runner)86 UnsupportedConsumerEndpoint(Consumer* consumer, base::TaskRunner* task_runner)
87 : consumer_(consumer), task_runner_(task_runner) {
88 // The SDK will not to reconnect the consumer, so we just disconnect it
89 // immediately, which will cancel the tracing session.
90 auto weak_this = weak_ptr_factory_.GetWeakPtr();
91 task_runner_->PostTask([weak_this] {
92 if (weak_this)
93 weak_this->consumer_->OnDisconnect();
94 });
95 }
96 ~UnsupportedConsumerEndpoint() override = default;
97
EnableTracing(const TraceConfig &,base::ScopedFile=base::ScopedFile ())98 void EnableTracing(const TraceConfig&,
99 base::ScopedFile = base::ScopedFile()) override {}
ChangeTraceConfig(const TraceConfig &)100 void ChangeTraceConfig(const TraceConfig&) override {}
101
StartTracing()102 void StartTracing() override {}
DisableTracing()103 void DisableTracing() override {}
104
Flush(uint32_t,FlushCallback callback)105 void Flush(uint32_t /*timeout_ms*/, FlushCallback callback) override {
106 callback(/*success=*/false);
107 }
108
ReadBuffers()109 void ReadBuffers() override {}
FreeBuffers()110 void FreeBuffers() override {}
111
Detach(const std::string &)112 void Detach(const std::string& /*key*/) override {}
Attach(const std::string &)113 void Attach(const std::string& /*key*/) override {}
114
GetTraceStats()115 void GetTraceStats() override {}
ObserveEvents(uint32_t)116 void ObserveEvents(uint32_t /*events_mask*/) override {}
QueryServiceState(QueryServiceStateCallback)117 void QueryServiceState(QueryServiceStateCallback) override {}
QueryCapabilities(QueryCapabilitiesCallback)118 void QueryCapabilities(QueryCapabilitiesCallback) override {}
119
SaveTraceForBugreport(SaveTraceForBugreportCallback)120 void SaveTraceForBugreport(SaveTraceForBugreportCallback) override {}
121
122 private:
123 Consumer* const consumer_;
124 base::TaskRunner* const task_runner_;
125 base::WeakPtrFactory<UnsupportedConsumerEndpoint> weak_ptr_factory_{
126 this}; // Keep last.
127 };
128
129 } // namespace
130
131 // static
GetInstance()132 TracingBackend* TracingBackendFake::GetInstance() {
133 static auto* instance = new TracingBackendFake();
134 return instance;
135 }
136
137 TracingBackendFake::TracingBackendFake() = default;
138
ConnectProducer(const ConnectProducerArgs & args)139 std::unique_ptr<ProducerEndpoint> TracingBackendFake::ConnectProducer(
140 const ConnectProducerArgs& args) {
141 return std::unique_ptr<ProducerEndpoint>(
142 new UnsupportedProducerEndpoint(args.producer, args.task_runner));
143 }
144
ConnectConsumer(const ConnectConsumerArgs & args)145 std::unique_ptr<ConsumerEndpoint> TracingBackendFake::ConnectConsumer(
146 const ConnectConsumerArgs& args) {
147 return std::unique_ptr<ConsumerEndpoint>(
148 new UnsupportedConsumerEndpoint(args.consumer, args.task_runner));
149 }
150
151 } // namespace internal
152 } // namespace perfetto
153