-
Notifications
You must be signed in to change notification settings - Fork 326
/
Copy pathpath.proto
497 lines (445 loc) · 14.1 KB
/
path.proto
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
// Copyright (C) 2017 Google Inc.
//
// 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.
syntax = "proto3";
import "core/image/image.proto";
import "gapis/service/box/box.proto";
import "gapis/vertex/vertex.proto";
package path;
option java_package = "com.google.gapid.proto.service.path";
option java_outer_classname = "Path";
option go_package = "github.com/google/gapid/gapis/service/path";
// Any is a oneof union of all the path types.
message Any {
oneof path {
API API = 1;
ArrayIndex array_index = 2;
As as = 3;
Blob blob = 4;
Capture capture = 5;
Command command = 6;
Commands commands = 7;
CommandTree command_tree = 8;
CommandTreeNode command_tree_node = 9;
CommandTreeNodeForCommand command_tree_node_for_command = 10;
ConstantSet constant_set = 11;
Context context = 12;
Contexts contexts = 13;
Device device = 14;
DeviceTraceConfiguration traceConfig = 15;
Events events = 16;
FramebufferObservation FBO = 17;
Field field = 18;
GlobalState global_state = 19;
ImageInfo image_info = 20;
MapIndex map_index = 21;
Memory memory = 22;
Mesh mesh = 23;
Metrics metrics = 24;
Messages messages = 25;
MultiResourceData multi_resource_data = 26;
Parameter parameter = 27;
Report report = 28;
ResourceData resource_data = 29;
Resources resources = 30;
Result result = 31;
Slice slice = 32;
State state = 33;
StateTree state_tree = 34;
StateTreeNode state_tree_node = 35;
StateTreeNodeForPath state_tree_node_for_path = 36;
Stats stats = 37;
Thumbnail thumbnail = 38;
}
}
// ID is a 20-byte identifier.
message ID {
bytes data = 1;
}
// ArrayIndex is path to a element in an array or slice.
message ArrayIndex {
uint64 index = 1;
oneof array {
Field field = 2;
Slice slice = 3;
ArrayIndex array_index = 4;
MapIndex map_index = 5;
Report report = 6;
Parameter parameter = 7;
}
}
// API is a path to an API.
message API {
ID ID = 1;
}
// As casts or transforms the object to the requested type.
message As {
oneof to {
image.Format image_format = 1;
vertex.BufferFormat vertex_buffer_format = 2;
}
oneof from {
Field field = 3;
Slice slice = 4;
ArrayIndex array_index = 5;
MapIndex map_index = 6;
ImageInfo image_info = 7;
ResourceData resource_data = 8;
Mesh mesh = 9;
}
}
// Blob is a path to a blob of data.
message Blob {
// id is the identifier of the data.
ID ID = 1;
}
// Capture is a path to a capture.
// Resolves to a service.Capture.
message Capture {
ID ID = 1;
// Whether to exclude the memory ranges when fetching this capture.
bool exclude_memory_ranges = 2;
}
// Command is the path to a command in the capture.
// Resolves to a service.Command.
message Command {
Capture capture = 1;
// Indices of this command in the capture.
// If there is more than one index, then the index refers to a sub-command.
repeated uint64 indices = 2;
}
// Commands is a path to a list of commands in a capture.
// Resolves to a service.Commands.
message Commands {
Capture capture = 1;
// The index of the first command in the interval.
// If there is more than one index, then the index refers to a sub-command.
repeated uint64 from = 2;
// The index of the last command in the interval.
// If there is more than one index, then the index refers to a sub-command.
repeated uint64 to = 4;
}
// ConstantSet is a path to an enumerator of constants.
// Resolves to a service.ConstantSet.
message ConstantSet {
API API = 1;
uint32 index = 2;
}
// Events is a path to a list of events in a capture.
// Resolves to a service.Events.
message Events {
Capture capture = 1;
CommandFilter filter = 2;
bool draw_calls = 3;
bool transform_feedbacks = 4;
bool first_in_frame = 5;
bool last_in_frame = 6;
bool clears = 7;
bool user_markers = 8;
bool push_user_markers = 9;
bool pop_user_markers = 10;
bool framebuffer_observations = 11;
bool all_commands = 12;
bool include_timing = 13;
}
// Parameter is the path to a single parameter on a command.
message Parameter {
string name = 1;
Command command = 2;
}
// Result is the path to the result value of a command.
message Result {
Command command = 1;
}
// Threads is path to a list of threads in a capture.
message Threads {
Capture capture = 1;
}
// Thread is a path to a single thread in a capture.
message Thread {
Capture capture = 1;
uint64 ID = 2;
}
// Messages is path to a list of messages stored in the capture
message Messages {
Capture capture = 1;
}
// Contexts is path to a list of contexts in a capture.
message Contexts {
Capture capture = 1;
}
// Context is a path to a single context in a capture.
message Context {
Capture capture = 1;
ID ID = 2;
}
// Device is a path to a device used for replay.
message Device {
ID ID = 1;
}
// DeviceTraceConfiguration is a path to the tracing config for a device
message DeviceTraceConfiguration {
Device device = 1;
}
// FramebufferObservation is a path to a framebuffer observation image at the
// specified command. It resolves to an image.Info.
message FramebufferObservation {
Command command = 1;
}
// Field is a path to a field in a struct.
message Field {
string name = 1;
oneof struct {
Field field = 2;
Slice slice = 3;
ArrayIndex array_index = 4;
MapIndex map_index = 5;
State state = 6;
GlobalState global_state = 7;
Parameter parameter = 8;
}
}
// CommandFilter are the optional filters applied to CommandTrees and Events.
message CommandFilter {
// context filters the commands to the specified context.
ID context = 1;
// thread filters the commands to those with the specified threads.
repeated uint64 threads = 2;
}
// CommandTree is a path to a hierarchy of command tree nodes.
// Resolves to a service.CommandTree.
message CommandTree {
// The capture to get the tree for.
Capture capture = 1;
// The command filter used to create the tree.
CommandFilter filter = 2;
// If true then commands will be grouped by API.
bool group_by_api = 3;
// If true then commands will be grouped by context.
bool group_by_context = 4;
// If true then commands will be grouped by thread.
bool group_by_thread = 5;
// If true then commands will be grouped by draw calls.
bool group_by_draw_call = 6;
// If true then commands will be grouped by transform feedback calls.
bool group_by_transform_feedback = 7;
// If true then commands will be grouped by frame.
bool group_by_frame = 8;
// If true then commands will be grouped by user markers.
bool group_by_user_markers = 9;
// If true and grouping by context, 'no context' groups will be created.
bool include_no_context_groups = 10;
// If true and grouping by frames, commands after the last frame will be
// grouped into an 'incomplete frame' group. Only if there is at least one
// complete frame.
bool allow_incomplete_frame = 11;
// If positive, synthetic sub-nodes are created for nodes with more than
// this many children.
int32 max_children = 12;
// If positive, synthetic sub-nodes are created for long spans of commands
// between groups. This ensures the groups do not get lost in the noise.
int32 max_neighbours = 13;
}
// CommandTreeNode is a path to a command tree node.
// Resolves to a service.CommandTreeNode.
message CommandTreeNode {
// Unique identifier of the command tree.
ID tree = 1;
// Descending child indices starting from the root CommandTreeNode.
repeated uint64 indices = 2;
}
// CommandTreeNodeForCommand is a path to a command tree node, resolved from a
// Command path and a CommandTree identifier. It is used to locate the
// CommandTreeNode for a given command.
// Resolves to a path.CommandTreeNode.
message CommandTreeNodeForCommand {
// Unique identifier of the command tree.
ID tree = 1;
// The command path.
Command command = 2;
}
// ImageInfo is a path that refers to a image.Info.
message ImageInfo {
image.ID ID = 1; // The ImageInfo's unique identifier.
}
// MapIndex is a path to a value held inside a map.
message MapIndex {
oneof key {
box.Value box = 1;
}
oneof map {
Field field = 2;
Slice slice = 3;
ArrayIndex array_index = 4;
MapIndex map_index = 5;
State state = 6;
Parameter parameter = 7;
}
}
// Memory is a path to a region of memory.
// Resolves to a service.Memory.
message Memory {
// Base address of the region of memory.
uint64 address = 1;
// Size in bytes of the region of memory.
uint64 size = 2;
// The pool identifier.
uint32 pool = 3;
// The memory follows this command.
Command after = 4;
// If true then the actual memory bytes will be missing from in the
// service.Memory. Useful for discovering memory ranges touched.
bool exclude_data = 5;
// If true, only the observations at the given command are included.
// I.e, the returned service.Memory.observed will be empty.
bool exclude_observed = 6;
}
// Mesh is a path to a mesh representation of an object.
message Mesh {
MeshOptions options = 1;
oneof object {
Command command = 2;
CommandTreeNode command_tree_node = 3;
}
}
// MeshOptions provides parameters for the mesh returned by a Mesh path resolve.
message MeshOptions {
// If true then normals are calculated from each face.
bool faceted = 1;
// If true, the actual data will be missing from the vertex.Buffers. This
// can be used to fetch the metadata about the mesh and all its vertex
// buffers, without the overhead of fetching all the buffer data.
bool exclude_data = 2;
// Hints that override the semantic guessing. Maps vertex attribute names to
// their intentended semantic type.
message SemanticHint {
string name = 1;
vertex.Semantic.Type type = 2;
}
repeated SemanticHint vertex_semantics = 3;
}
// Metrics requests a set of metrics for a given command. Resolves to
// service.Metrics.
message Metrics {
// The command after which to get the metrics from.
Command command = 1;
// Whether to get the memory breakdown metrics.
bool memory_breakdown = 2;
}
// Report is a path to a list of report items for a capture.
message Report {
Capture capture = 1;
// The optional path the the device used to generate replay information.
Device device = 2;
// The optional filter to apply to the report items.
CommandFilter filter = 3;
// Whether to display the replay to the original surface while in progress.
bool display_to_surface = 4;
}
// Resources is a path to a list of resources used in a capture.
message Resources {
Capture capture = 1;
}
// ResourceData is a path to a single resource snapshot at a given point in an
// command stream.
message ResourceData {
ID ID = 1;
Command after = 2;
}
// MultiResourceData is a path to a set of resource snapshots at a given point
// in a command stream.
message MultiResourceData {
Command after = 1;
repeated ID IDs = 2;
}
// Slice is a path to a subslice of a slice or array.
message Slice {
uint64 start = 1;
uint64 end = 2;
oneof array {
Field field = 3;
Slice slice = 4;
ArrayIndex array_index = 5;
MapIndex map_index = 6;
Parameter parameter = 7;
}
}
// State is a path to a subset of the GlobalState at a point in a capture.
message State {
Command after = 1;
// If non-nil, then the state is filtered to the specified context.
ID context = 2;
}
// GlobalState is an path node to the absolute global state after a specfied
// command. GlobalStates are used where stable paths are required, such as
// locating state tree nodes.
message GlobalState {
path.Command after = 1;
}
// StateTree is a path to a hierarchy of state tree nodes.
// Resolves to a service.StateTree.
message StateTree {
State state = 1;
// If positive, expanded arrays/slices with more elements than this limit
// will be restructured to have up to two extra levels of tree nodes, each
// with at most this many children. If the array has more elements than this
// number cubed, the array root node will contain more than this many child
// nodes.
int32 array_group_size = 2;
}
// StateTreeNode is a path to a state tree node.
// Resolves to a service.StateTreeNode.
message StateTreeNode {
// Unique identifier of the state tree.
ID tree = 1;
// Descending child indices starting from the root StateTreeNode.
repeated uint64 indices = 2;
}
// StateTreeNodeForPath is a path to a state tree node, resolved from another
// path. It is used to locate the relevant StateTreeNode for a path to a state
// member variable.
// Resolves to a path.StateTreeNode.
message StateTreeNodeForPath {
// Unique identifier of the state tree.
ID tree = 1;
// The path to the state member to look for.
Any member = 2;
}
// Stats requests statistics for a given capture. Resolves to service.Stats.
message Stats {
// The capture to analyze
Capture capture = 1;
// Whether to compute draw calls per frame statistics
bool draw_call = 2;
}
// Thumbnail is a path to a thumbnail image representing the object.
message Thumbnail {
// The desired maximum width of the thumbnail image.
// If DesiredMaxWidth <= 0, then no limits will be placed on the width.
uint32 desired_max_width = 1;
// The desired maximum height of the thumbnail image.
// If DesiredMaxHeight <= 0, then no limits will be placed on the height.
uint32 desired_max_height = 2;
// If requested thumbnail format. If nil, then return the native format.
image.Format desired_format = 3;
oneof object {
ResourceData resource = 4;
Command command = 5;
CommandTreeNode command_tree_node = 6;
}
bool disable_optimization = 7;
}
message ResolveConfig {
// The device to use for any replays when resolving paths.
path.Device replay_device = 1;
}