blob: 06d0f58e35f363cd438efbb6963ac282716751b5 [file] [log] [blame]
// Copyright 2016 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef GARNET_BIN_KTRACE_PROVIDER_APP_H_
#define GARNET_BIN_KTRACE_PROVIDER_APP_H_
#include <lib/sys/cpp/component_context.h>
#include <lib/trace/observer.h>
#include <fbl/unique_fd.h>
#include "garnet/bin/ktrace_provider/log_importer.h"
#include "src/lib/fxl/command_line.h"
namespace ktrace_provider {
class App {
public:
explicit App(const fxl::CommandLine& command_line);
~App();
private:
void UpdateState();
void StartKTrace(uint32_t group_mask, bool retain_current_data);
void StopKTrace();
std::unique_ptr<sys::ComponentContext> component_context_;
trace::TraceObserver trace_observer_;
LogImporter log_importer_;
uint32_t current_group_mask_ = 0u;
// This context keeps the trace context alive until we've written our trace
// records, which doesn't happen until after tracing has stopped.
trace_prolonged_context_t* context_ = nullptr;
App(const App&) = delete;
App(App&&) = delete;
App& operator=(const App&) = delete;
App& operator=(App&&) = delete;
};
} // namespace ktrace_provider
#endif // GARNET_BIN_KTRACE_PROVIDER_APP_H_