
Replaces SyncChannel::Send, RenderProcessHostImpl::Send, and GpuChannelHost::Send trace events with typed trace events. Also adds a utility to convert the IPC class ID to a corresponding protobuf enum. Corresponding proto buffer definitions for these events were added in aosp/1180211. Typed trace events will allow inclusion of the event arguments in slow reports data in the future. The trace format is protocol-buffer based under the hood already (see docs.perfetto.dev for details), this patch adds strong typing for the arguments of the respective events only. TBR: sunnyps@chromium.org Bug: 644264 Change-Id: I91c71230e62161b08faec889bf9eb70639ae0b5e Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/1950986 Commit-Queue: Eric Seckler <eseckler@chromium.org> Reviewed-by: Alex Moshchuk <alexmos@chromium.org> Reviewed-by: Ken Rockot <rockot@google.com> Cr-Commit-Position: refs/heads/master@{#730120}
34 lines
1.3 KiB
C++
34 lines
1.3 KiB
C++
// Copyright 2019 The Chromium 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 IPC_TRACE_IPC_MESSAGE_H_
|
|
#define IPC_TRACE_IPC_MESSAGE_H_
|
|
|
|
#include <stdint.h>
|
|
|
|
#include "base/component_export.h"
|
|
#include "services/tracing/public/cpp/perfetto/macros.h"
|
|
#include "third_party/perfetto/protos/perfetto/trace/track_event/chrome_legacy_ipc.pbzero.h"
|
|
|
|
// When tracing is enabled, emits a trace event with the given category and
|
|
// event name and typed arguments for the message's type (message class and line
|
|
// number).
|
|
#define TRACE_IPC_MESSAGE_SEND(category, name, msg) \
|
|
TRACE_EVENT(category, name, [msg](perfetto::EventContext ctx) { \
|
|
IPC::WriteIpcMessageIdAsProtozero(msg->type(), \
|
|
ctx.event()->set_chrome_legacy_ipc()); \
|
|
});
|
|
|
|
namespace IPC {
|
|
|
|
// Converts |message_id| into its message class and line number parts and writes
|
|
// them to the protozero message |ChromeLegacyIpc| for trace events.
|
|
void COMPONENT_EXPORT(IPC)
|
|
WriteIpcMessageIdAsProtozero(uint32_t message_id,
|
|
perfetto::protos::pbzero::ChromeLegacyIpc*);
|
|
|
|
} // namespace IPC
|
|
|
|
#endif // IPC_TRACE_IPC_MESSAGE_H_
|