blob: 850765bb78fb06a4e321d8012161bfa26b09fe8d [file] [log] [blame]
// Copyright 2020 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.
syntax = "proto2";
import public "protos/perfetto/trace/track_event/track_event.proto";
package perfetto.protos;
enum ChromeAppState {
APP_STATE_FOREGROUND = 1;
APP_STATE_BACKGROUND = 2;
}
enum MemoryPressureLevel {
MEMORY_PRESSURE_LEVEL_NONE = 0;
MEMORY_PRESSURE_LEVEL_MODERATE = 1;
MEMORY_PRESSURE_LEVEL_CRITICAL = 2;
}
message ChromeMemoryPressureNotification {
optional MemoryPressureLevel level = 1;
// ID of interned source location where MemoryPressureListener was created
optional uint64 creation_location_iid = 2;
}
message ChromeTaskAnnotator {
optional uint32 ipc_hash = 1;
// The delay in microseconds that was specified, if any, when this task was
// posted. This is only valid for delayed tasks.
optional uint64 task_delay_us = 2;
}
message ChromeBrowserContext {
reserved 1;
optional string id = 2;
}
message ChromeProfileDestroyer {
optional fixed64 profile_ptr = 1;
optional bool is_off_the_record = 2;
optional string otr_profile_id = 3;
optional uint32 host_count_at_creation = 4;
optional uint32 host_count_at_destruction = 5;
optional fixed64 render_process_host_ptr = 6;
}
message ChromeTaskPostedToDisabledQueue {
optional string task_queue_name = 1;
optional uint64 time_since_disabled_ms = 2;
optional uint32 ipc_hash = 3;
optional uint64 source_location_iid = 4;
}
message ChromeRasterTask {
optional int64 source_frame_number = 1;
}
message ChromeMessagePumpForUI {
// The MSG defined in winuser.h.
optional uint32 message_id = 1;
}
// An enumeration specifying the reason of the RenderFrame deletion.
// This is copied from content/common/frame.mojom.
enum FrameDeleteIntention {
// The frame being deleted isn't a (speculative) main frame.
FRAME_DELETE_INTENTION_NOT_MAIN_FRAME = 0;
// The frame being deleted is a speculative main frame, and it is being
// deleted as part of the shutdown for that WebContents. The entire RenderView
// etc will be destroyed by a separate IPC sent later.
FRAME_DELETE_INTENTION_SPECULATIVE_MAIN_FRAME_FOR_SHUTDOWN = 1;
// The frame being deleted is a speculative main frame, and it is being
// deleted because the speculative navigation was cancelled. This is not part
// of shutdown.
FRAME_DELETE_INTENTION_SPECULATIVE_MAIN_FRAME_FOR_NAVIGATION_CANCELLED = 2;
}
message RenderFrameImplDeletion {
// The intent for the deletion.
optional FrameDeleteIntention intent = 1;
// Whether the frame that's about to be deleted has a pending navigation
// commit.
optional bool has_pending_commit = 2;
// Whether the frame that's about to be deleted has a pending cross-document
// navigation commit.
optional bool has_pending_cross_document_commit = 3;
// The FrameTreeNode ID of the frame that's about to be deleted.
optional uint64 frame_tree_node_id = 4;
}
// Matches content::ShouldSwapBrowsingInstance.
enum ShouldSwapBrowsingInstance {
// Was used for all "no BrowsingInstance swap" scenarios, now broken down in
// separate reasons.
SHOULD_SWAP_BROWSING_INSTANCE_NO = 0;
// Forced BrowsingInstance swap.
SHOULD_SWAP_BROWSING_INSTANCE_YES_FORCE_SWAP = 1;
// Proactive BrowsingInstance swap for cross-site navigation.
SHOULD_SWAP_BROWSING_INSTANCE_YES_CROSS_SITE_PROACTIVE_SWAP = 2;
// Proactive BrowsingInstance swap for same-site navigation.
SHOULD_SWAP_BROWSING_INSTANCE_YES_SAME_SITE_PROACTIVE_SWAP = 3;
SHOULD_SWAP_BROWSING_INSTANCE_NO_PROACTIVE_SWAP_DISABLED = 4;
SHOULD_SWAP_BROWSING_INSTANCE_NO_NOT_MAIN_FRAME = 5;
SHOULD_SWAP_BROWSING_INSTANCE_NO_HAS_RELATED_ACTIVE_CONTENTS = 6;
SHOULD_SWAP_BROWSING_INSTANCE_NO_DOES_NOT_HAVE_SITE = 7;
SHOULD_SWAP_BROWSING_INSTANCE_NO_SOURCE_URL_SCHEME_NOT_HTTP_OR_HTTPS = 8;
SHOULD_SWAP_BROWSING_INSTANCE_NO_DESTINATION_URL_SCHEME_NOT_HTTP_OR_HTTPS = 9;
SHOULD_SWAP_BROWSING_INSTANCE_NO_SAME_SITE_NAVIGATION = 10;
SHOULD_SWAP_BROWSING_INSTANCE_NO_RELOADING_ERROR_PAGE = 11;
SHOULD_SWAP_BROWSING_INSTANCE_NO_ALREADY_HAS_MATCHING_BROWSING_INSTANCE = 12;
SHOULD_SWAP_BROWSING_INSTANCE_NO_RENDERER_DEBUG_URL = 13;
SHOULD_SWAP_BROWSING_INSTANCE_NO_NOT_NEEDED_FOR_BACK_FORWARD_CACHE = 14;
SHOULD_SWAP_BROWSING_INSTANCE_NO_SAME_DOCUMENT_NAVIGATION = 15;
SHOULD_SWAP_BROWSING_INSTANCE_NO_SAME_URL_NAVIGATION = 16;
SHOULD_SWAP_BROWSING_INSTANCE_NO_WILL_REPLACE_ENTRY = 17;
SHOULD_SWAP_BROWSING_INSTANCE_NO_RELOAD = 18;
SHOULD_SWAP_BROWSING_INSTANCE_NO_GUEST = 19;
SHOULD_SWAP_BROWSING_INSTANCE_NO_HAS_NOT_COMMITTED_ANY_NAVIGATION = 20;
SHOULD_SWAP_BROWSING_INSTANCE_NO_UNLOAD_HANDLER_EXISTS_ON_SAME_SITE_NAVIGATION =
21;
}
message ShouldSwapBrowsingInstancesResult {
// The FrameTreeNode ID.
optional uint64 frame_tree_node_id = 1;
// Whether a navigation will do a BrowsingInstance swap or not.
optional ShouldSwapBrowsingInstance result = 2;
}
message FrameTreeNodeInfo {
// The FrameTreeNode ID.
optional uint64 frame_tree_node_id = 1;
// Whether the frame is a main frame or not.
optional bool is_main_frame = 2;
// Whether there's a speculative RenderFrameHost or not.
optional bool has_speculative_render_frame_host = 3;
}
message ChromeHashedPerformanceMark {
optional uint32 site_hash = 1;
optional string site = 2;
optional uint32 mark_hash = 3;
optional string mark = 4;
// A randomly generated unique identifier for a given ExecutionContext
// (document, worker, etc). Used to be able to correlate events in a process
// where there are multiple execution contexts from the same site.
optional uint32 execution_context_id = 5;
// Indicates the sequence number of this particular mark being emitted from
// a particular site in the scope of a single ExecutionContext. Typical
// sites emit batches of events that are correlated in time (a thing started,
// a thing reached a given milestone, a thing completed). When these events
// are intermixed it is useful to know which ones are semantically related.
// The value is generated by the content itself, but shifted by a fixed
// random offset at runtime so as to limit usage as a side channel.
optional uint32 sequence_number = 6;
}
message ChromeWebAppBadNavigate {
optional bool is_kiosk = 1;
optional bool has_hosted_app_controller = 2;
optional string app_name = 3;
optional uint32 system_app_type = 4;
optional bool web_app_provider_registry_ready = 5;
optional bool system_web_app_manager_synchronized = 6;
}
// These IDs are generated at compile time and differ for each chrome version.
// IDs are stable on for a given chrome version but are changing when resources
// are added or removed to chrome.
message ResourceBundle {
optional uint32 resource_id = 1;
}
// Information about RenderProcessHost.
message RenderProcessHost {
// Unique Id to identify the RenderProcessHost. This is the browser-side,
// persistent id for this RenderProcessHost that stays constant even across OS
// layer processes managed by this RenderProcessHost.
optional uint32 id = 1;
// See ProcessLock::ToString().
optional string process_lock = 2;
// The PID of the child process.
optional int32 child_process_id = 3;
// Details about the associated browser context.
optional ChromeBrowserContext browser_context = 4;
}
message RenderProcessHostListener {
// Routing ID of the listener to the RenderProcessHost, recorded when a new ID
// is added or when an ID is removed.
optional uint32 routing_id = 1;
}
message RenderProcessHostCleanup {
// Number of IPC listeners registered to the host when Cleanup() was called.
optional uint32 listener_count = 1;
// Number of "keep alive" references active in the RenderProcessHost, recorded
// when Cleanup() was called.
optional uint32 keep_alive_ref_count = 2;
// Number of "shutdown delay" references active in the RenderProcessHost,
// recorded when Cleanup() was called.
optional uint32 shutdown_delay_ref_count = 3;
// Number of "worker delay" references active in the RenderProcessHost,
// recorded when Cleanup() was called.
optional uint32 worker_ref_count = 4;
}
message ChildProcessLauncherPriority {
// True if the new priority set to background.
optional bool is_backgrounded = 1;
// True if the renderer proecss has pending views.
optional bool has_pending_views = 2;
// Importance of the child process in Android.
enum Importance {
IMPORTANCE_NORMAL = 1;
IMPORTANCE_MODERATE = 2;
IMPORTANCE_IMPORTANT = 3;
}
optional Importance importance = 3;
}
// Information that identifies a Chrome Extension.
message ChromeExtensionId {
// Unique id that identifies a Chrome Extension.
optional string extension_id = 1;
// Pseudonymized `extension_id` field (see also
// content::PseudonymizationUtil::PseudonymizeString method).
optional uint32 pseudonymized_extension_id = 2;
}
message SiteInstance {
// The ID of the SiteInstance.
optional int32 site_instance_id = 1;
// The ID of the BrowsingInstance that the SiteInstance belongs to.
optional int32 browsing_instance_id = 2;
// Whether the SiteInstance is the "default SiteInstance" or not. Non-isolated
// sites on Android are not assigned to their own specific per-site process,
// and shares SiteInstances with each other (the default SiteInstance).
optional bool is_default = 3;
// Whether this SiteInstance has a running process associated with it.
optional bool has_process = 4;
// Returns the total active WebContents count for this SiteInstance and all
// related SiteInstances in the same BrowsingInstance.
optional int32 related_active_contents_count = 5;
// The number of active RenderFrameHosts which belong to this SiteInstance.
optional int32 active_rfh_count = 6;
}
message RenderViewHost {
// The RenderViewHostMapId for the RenderViewHost.
optional int32 rvh_map_id = 1;
// The routing ID for the RenderViewHost.
optional int32 routing_id = 2;
// The process ID of the RenderViewHost.
optional int32 process_id = 3;
// Whether the RenderViewHost is in back/forward cache or not.
optional bool is_in_back_forward_cache = 4;
// Whether the renderer-side RenderView is created.
optional bool renderer_view_created = 5;
}
message RenderFrameProxyHost {
// The routing ID for the RenderFrameProxyHost.
optional int32 routing_id = 1;
// The process ID of the RenderFrameProxyHost.
optional int32 process_id = 2;
// The RenderViewHostMapId of the RenderViewHost associated with the
// RenderFrameProxyHost.
optional int32 rvh_map_id = 3;
// The SiteInstanceId of the SiteInstance associated with the
// RenderFrameProxyHost.
optional int32 site_instance_id = 4;
// Whether the renderer-side RenderFrameProxy is live or not.
optional bool is_render_frame_proxy_live = 5;
}
message AndroidView {
optional int32 id = 1;
optional int32 parent_id = 2;
optional bool is_shown = 3;
optional bool is_dirty = 4;
optional string class_name = 5;
optional string resource_name = 6;
}
message AndroidActivity {
optional string name = 1;
repeated AndroidView view = 2;
}
message AndroidViewDump {
repeated AndroidActivity activity = 1;
}
message ParkableStringCompressInBackground {
// The size of the string that is being compressed, in bytes.
optional int32 size_bytes = 1;
}
message ParkableStringUnpark {
// The size of the string that is being unparked, in bytes.
optional int32 size_bytes = 1;
// The elapsed time since the string was written to disk (in seconds), or -1
// if it hadn't yet been written to disk.
optional int32 time_since_last_disk_write_sec = 2;
}
message ChromeSamplingProfilerSampleCollected {
optional int32 frame_count = 1;
enum WriteStatus {
WRITE_STATUS_NONE = 0;
WRITE_STATUS_BUFFERING_SAMPLE = 1;
WRITE_STATUS_WRITING_BUFFERED = 2;
WRITE_STATUS_WRITING_TO_TRACE = 3;
}
optional WriteStatus write_status = 2;
}
// Reports the latency caused by each breakdown in the
// SendBeginMainFrameToCommit stage of the PipelineReporter.
message SendBeginMainFrameToCommitBreakdown {
// Handle input events breakdown
optional uint64 handle_input_events_us = 1;
// Animate breakdown
optional uint64 animate_us = 2;
// Style update breakdown
optional uint64 style_update_us = 3;
// Layout update breakdown
optional uint64 layout_update_us = 4;
// Prepaint breakdown
optional uint64 prepaint_us = 5;
// Compositing inputs breakdown
optional uint64 compositing_inputs_us = 6;
// Compositing assignments breakdown
optional uint64 compositing_assignments_us = 7;
// Paint breakdown
optional uint64 paint_us = 8;
// Composite commit breakdown
optional uint64 composite_commit_us = 9;
// Update layers breakdown
optional uint64 update_layers_us = 10;
// Beginmainsenttostarted breakdown
optional uint64 begin_main_sent_to_started_us = 11;
}
message ChromeTrackEvent {
// Extension range for Chrome: 1000-1999
// Next ID: 1026
extend TrackEvent {
optional ChromeAppState chrome_app_state = 1000;
optional ChromeMemoryPressureNotification
chrome_memory_pressure_notification = 1001;
optional ChromeTaskAnnotator chrome_task_annotator = 1002;
optional ChromeBrowserContext chrome_browser_context = 1003;
optional ChromeProfileDestroyer chrome_profile_destroyer = 1004;
optional ChromeTaskPostedToDisabledQueue
chrome_task_posted_to_disabled_queue = 1005;
optional ChromeRasterTask chrome_raster_task = 1006;
optional ChromeMessagePumpForUI chrome_message_pump_for_ui = 1007;
optional RenderFrameImplDeletion render_frame_impl_deletion = 1008;
optional ShouldSwapBrowsingInstancesResult
should_swap_browsing_instances_result = 1009;
optional FrameTreeNodeInfo frame_tree_node_info = 1010;
optional ChromeHashedPerformanceMark chrome_hashed_performance_mark = 1011;
optional RenderProcessHost render_process_host = 1012;
optional RenderProcessHostCleanup render_process_host_cleanup = 1013;
optional RenderProcessHostListener render_process_host_listener_changed =
1014;
optional ChildProcessLauncherPriority child_process_launcher_priority =
1015;
optional ResourceBundle resource_bundle = 1016;
optional ChromeWebAppBadNavigate chrome_web_app_bad_navigate = 1017;
optional ChromeExtensionId chrome_extension_id = 1018;
optional SiteInstance site_instance = 1019;
optional RenderViewHost render_view_host = 1020;
optional RenderFrameProxyHost render_frame_proxy_host = 1021;
optional AndroidViewDump android_view_dump = 1022;
optional ParkableStringCompressInBackground
parkable_string_compress_in_background = 1023;
optional ParkableStringUnpark parkable_string_unpark = 1024;
optional ChromeSamplingProfilerSampleCollected
chrome_sampling_profiler_sample_completed = 1025;
optional SendBeginMainFrameToCommitBreakdown
send_begin_mainframe_to_commit_breakdown = 1026;
}
}