| /* |
| * 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. |
| */ |
| |
| // Use proto3 syntax as an optimization. The difference is that proto2 stores |
| // unknown fields seen while decoding in an internal buffer (std::string) while |
| // proto3 completely drops them. Since during validation we only need to check |
| // for the presence of the trusted fields below, we can use proto3 as a way to |
| // speed up this process. |
| // |
| // See https://developers.google.com/protocol-buffers/docs/proto3#unknowns and |
| // https://android-review.googlesource.com/c/platform/external/perfetto/+/ |
| // 591673#17 for details. |
| syntax = "proto3"; |
| option optimize_for = LITE_RUNTIME; |
| |
| import "perfetto/common/trace_stats.proto"; |
| import "perfetto/config/trace_config.proto"; |
| import "perfetto/trace/clock_snapshot.proto"; |
| import "perfetto/trace/system_info.proto"; |
| import "perfetto/trace/trigger.proto"; |
| |
| package perfetto.protos; |
| |
| // This proto contains trusted fields of TracePacket which may only be generated |
| // by the service (as opposed to the untrusted producers). Note that the field |
| // ids here must be kept in sync with TracePacket. |
| // This protobuf serves two purposes: |
| // 1. Security validation of packets (see packet_stream_validator.cc) |
| // 2. Avoid bloating the service binary with symbols for all possible trace |
| // protos. The service doesn't really care about all the protos in the trace, |
| // is just passes them through. |
| message TrustedPacket { |
| // User id of the producer which generated this packet. |
| // The oneof boilerplate here is required to tell the difference between |
| // uid == 0 and uid not set (the writer uses proto2). |
| oneof optional_trusted_uid { int32 trusted_uid = 3; }; |
| |
| oneof optional_trusted_packet_sequence_id { |
| uint32 trusted_packet_sequence_id = 10; |
| } |
| |
| ClockSnapshot clock_snapshot = 6; |
| uint64 timestamp = 8; |
| TraceConfig trace_config = 33; |
| TraceStats trace_stats = 35; |
| bytes synchronization_marker = 36; |
| bool previous_packet_dropped = 42; |
| SystemInfo system_info = 45; |
| Trigger trigger = 46; |
| } |