/*
* Copyright (C) 2019 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/perfetto_cmd/trigger_producer.h"
#include <memory>
#include "perfetto/base/logging.h"
#include "perfetto/tracing/core/producer.h"
#include "perfetto/tracing/ipc/producer_ipc_client.h"
#include "src/tracing/ipc/default_socket.h"
namespace perfetto {
class DataSourceConfig;
TriggerProducer::TriggerProducer(base::TaskRunner* task_runner,
std::function<void(bool)> callback,
const std::vector<std::string>* const triggers)
: task_runner_(task_runner),
callback_(std::move(callback)),
triggers_(triggers),
producer_endpoint_(ProducerIPCClient::Connect(GetProducerSocket(),
this,
"perfetto_cmd_producer",
task_runner)),
weak_factory_(this) {
// Give the socket up to 10 seconds to attach and send the triggers before
// reporting a failure.
auto weak_this = weak_factory_.GetWeakPtr();
task_runner_->PostDelayedTask(
[weak_this]() {
if (!weak_this || weak_this->issued_callback_)
return;
weak_this->issued_callback_ = true;
weak_this->callback_(false);
},
10000);
}
TriggerProducer::~TriggerProducer() {}
void TriggerProducer::OnConnect() {
PERFETTO_DLOG("Producer connected, sending triggers.");
// Send activation signal.
producer_endpoint_->ActivateTriggers(*triggers_);
auto weak_this = weak_factory_.GetWeakPtr();
task_runner_->PostTask([weak_this]() {
if (!weak_this || weak_this->issued_callback_)
return;
weak_this->issued_callback_ = true;
weak_this->callback_(true);
});
}
void TriggerProducer::OnDisconnect() {}
void TriggerProducer::OnTracingSetup() {}
void TriggerProducer::SetupDataSource(DataSourceInstanceID,
const DataSourceConfig&) {
PERFETTO_DFATAL("Attempted to SetupDataSource() on commandline producer");
}
void TriggerProducer::StartDataSource(DataSourceInstanceID,
const DataSourceConfig&) {
PERFETTO_DFATAL("Attempted to StartDataSource() on commandline producer");
}
void TriggerProducer::StopDataSource(DataSourceInstanceID) {
PERFETTO_DFATAL("Attempted to StopDataSource() on commandline producer");
}
void TriggerProducer::Flush(FlushRequestID,
const DataSourceInstanceID*,
size_t) {
PERFETTO_DFATAL("Attempted to Flush() on commandline producer");
}
void TriggerProducer::ClearIncrementalState(const DataSourceInstanceID*,
size_t) {
PERFETTO_DFATAL(
"Attempted to ClearIncrementalState() on commandline producer");
}
} // namespace perfetto