blob: b021ee5c4406593f96cfdc70939dfa70f88965ec [file] [log] [blame]
/*
* Copyright (C) 2018 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.
*/
#ifndef SRC_TRACED_PROBES_PROBES_PRODUCER_H_
#define SRC_TRACED_PROBES_PROBES_PRODUCER_H_
#include <functional>
#include <memory>
#include <unordered_map>
#include <utility>
#include "perfetto/base/task_runner.h"
#include "perfetto/ext/base/watchdog.h"
#include "perfetto/ext/base/weak_ptr.h"
#include "perfetto/ext/tracing/core/producer.h"
#include "perfetto/ext/tracing/core/trace_writer.h"
#include "perfetto/ext/tracing/core/tracing_service.h"
#include "src/traced/probes/filesystem/inode_file_data_source.h"
#include "src/traced/probes/ftrace/ftrace_controller.h"
#include "src/traced/probes/ftrace/ftrace_metadata.h"
#include "protos/perfetto/trace/filesystem/inode_file_map.pbzero.h"
namespace perfetto {
class ProbesDataSource;
const uint64_t kLRUInodeCacheSize = 1000;
class ProbesProducer : public Producer, public FtraceController::Observer {
public:
ProbesProducer();
~ProbesProducer() override;
static ProbesProducer* GetInstance();
// Producer Impl:
void OnConnect() override;
void OnDisconnect() override;
void SetupDataSource(DataSourceInstanceID, const DataSourceConfig&) override;
void StartDataSource(DataSourceInstanceID, const DataSourceConfig&) override;
void StopDataSource(DataSourceInstanceID) override;
void OnTracingSetup() override;
void Flush(FlushRequestID,
const DataSourceInstanceID* data_source_ids,
size_t num_data_sources) override;
void ClearIncrementalState(const DataSourceInstanceID* data_source_ids,
size_t num_data_sources) override;
// FtraceController::Observer implementation.
void OnFtraceDataWrittenIntoDataSourceBuffers() override;
// Our Impl
void ConnectWithRetries(const char* socket_name,
base::TaskRunner* task_runner);
// Constructs an instance of a data source of type T.
template <typename T>
std::unique_ptr<ProbesDataSource> CreateDSInstance(
TracingSessionID session_id,
const DataSourceConfig& config);
void ActivateTrigger(std::string trigger);
// Calls `cb` when all data sources have been registered.
void SetAllDataSourcesRegisteredCb(std::function<void()> cb) {
all_data_sources_registered_cb_ = cb;
}
private:
static ProbesProducer* instance_;
enum State {
kNotStarted = 0,
kNotConnected,
kConnecting,
kConnected,
};
ProbesProducer(const ProbesProducer&) = delete;
ProbesProducer& operator=(const ProbesProducer&) = delete;
void Connect();
void Restart();
void ResetConnectionBackoff();
void IncreaseConnectionBackoff();
void OnDataSourceFlushComplete(FlushRequestID, DataSourceInstanceID);
void OnFlushTimeout(FlushRequestID);
State state_ = kNotStarted;
base::TaskRunner* task_runner_ = nullptr;
std::unique_ptr<TracingService::ProducerEndpoint> endpoint_;
std::unique_ptr<FtraceController> ftrace_;
bool ftrace_creation_failed_ = false;
uint32_t connection_backoff_ms_ = 0;
const char* socket_name_ = nullptr;
// Owning map for all active data sources.
std::unordered_map<DataSourceInstanceID, std::unique_ptr<ProbesDataSource>>
data_sources_;
// Keeps (pointers to) data sources grouped by session id and data source
// type. The pointers do not own the data sources (they're owned by
// data_sources_).
//
// const ProbesDataSource::Descriptor* identifies the type.
//
// Used by OnFtraceDataWrittenIntoDataSourceBuffers().
std::unordered_map<
TracingSessionID,
std::unordered_multimap<const ProbesDataSource::Descriptor*,
ProbesDataSource*>>
session_data_sources_;
std::unordered_multimap<FlushRequestID, DataSourceInstanceID>
pending_flushes_;
std::function<void()> all_data_sources_registered_cb_;
std::unordered_map<DataSourceInstanceID, base::Watchdog::Timer> watchdogs_;
LRUInodeCache cache_{kLRUInodeCacheSize};
std::map<BlockDeviceID, std::unordered_map<Inode, InodeMapValue>>
system_inodes_;
base::WeakPtrFactory<ProbesProducer> weak_factory_; // Keep last.
};
} // namespace perfetto
#endif // SRC_TRACED_PROBES_PROBES_PRODUCER_H_