blob: 1dfac9a41b33affe9dd2102eb191f8a674f76a5c [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_TRACE_PROCESSOR_TRACE_PROCESSOR_H_
#define SRC_TRACE_PROCESSOR_TRACE_PROCESSOR_H_
#include <atomic>
#include <functional>
#include <memory>
#include "src/trace_processor/basic_types.h"
#include "src/trace_processor/scoped_db.h"
#include "src/trace_processor/trace_processor_context.h"
namespace perfetto {
namespace protos {
class RawQueryArgs;
class RawQueryResult;
} // namespace protos
namespace trace_processor {
// Coordinates the loading of traces from an arbitrary source and allows
// execution of SQL queries on the events in these traces.
class TraceProcessor {
public:
struct Config {
OptimizationMode optimization_mode = OptimizationMode::kMaxBandwidth;
uint64_t window_size_ns = 10 * 1000 * 1000 * 1000ULL; // 10 seconds.
};
explicit TraceProcessor(const Config&);
~TraceProcessor();
// The entry point to push trace data into the processor. The trace format
// will be automatically discovered on the first push call. It is possible
// to make queries between two pushes.
// Returns true if parsing has been succeeding so far, false if some
// unrecoverable error happened. If this happens, the TraceProcessor will
// ignore the following Parse() requests and drop data on the floor.
bool Parse(std::unique_ptr<uint8_t[]>, size_t);
// When parsing a bounded file (as opposite to streaming from a device) this
// function should be called when the last chunk of the file has been passed
// into Parse(). This allows to flush the events queued in the ordering stage,
// without having to wait for their time window to expire.
void NotifyEndOfFile();
// Executes a SQLite query on the loaded portion of the trace. |result| will
// be invoked once after the result of the query is available.
void ExecuteQuery(const protos::RawQueryArgs&,
std::function<void(const protos::RawQueryResult&)>);
// Interrupts the current query. Typically used by Ctrl-C handler.
void InterruptQuery();
private:
ScopedDb db_; // Keep first.
TraceProcessorContext context_;
bool unrecoverable_parse_error_ = false;
// This is atomic because it is set by the CTRL-C signal handler and we need
// to prevent single-flow compiler optimizations in ExecuteQuery().
std::atomic<bool> query_interrupted_{false};
};
// When set, logs SQLite actions on the console.
void EnableSQLiteVtableDebugging();
} // namespace trace_processor
} // namespace perfetto
#endif // SRC_TRACE_PROCESSOR_TRACE_PROCESSOR_H_