OLD | NEW |
---|---|
1 /* Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 /* Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 * Use of this source code is governed by a BSD-style license that can be | 2 * Use of this source code is governed by a BSD-style license that can be |
3 * found in the LICENSE file. | 3 * found in the LICENSE file. |
4 */ | 4 */ |
5 | 5 |
6 /** | 6 /** |
7 * This file defines the <code>PPB_Trace_Event</code> interface. It is meant | 7 * This file defines the <code>PPB_Trace_Event</code> interface. It is meant |
8 * to be used in plugins as the API that trace macros from trace_event.h use. | 8 * to be used in plugins as the API that trace macros from trace_event.h use. |
9 */ | 9 */ |
10 | 10 |
11 label Chrome { | 11 label Chrome { |
12 M25 = 0.1 | 12 M25 = 0.1, |
13 M29 = 0.2 | |
13 }; | 14 }; |
14 | 15 |
15 interface PPB_Trace_Event_Dev { | 16 interface PPB_Trace_Event_Dev { |
16 /** | 17 /** |
17 * Gets a pointer to a character for identifying a category name in the | 18 * Gets a pointer to a character for identifying a category name in the |
18 * tracing system as well as for being able to early exit in client-side | 19 * tracing system as well as for being able to early exit in client-side |
19 * tracing code. | 20 * tracing code. |
20 * | 21 * |
21 * NB: This mem_t return value should technically be const, but return values | 22 * NB: This mem_t return value should technically be const, but return values |
22 * for Pepper IDL of mem_t type are not const. The same is true for the arg | 23 * for Pepper IDL of mem_t type are not const. The same is true for the arg |
(...skipping 13 matching lines...) Expand all Loading... | |
36 [in] mem_t category_enabled, | 37 [in] mem_t category_enabled, |
37 [in] cstr_t name, | 38 [in] cstr_t name, |
38 [in] uint64_t id, | 39 [in] uint64_t id, |
39 [in] uint32_t num_args, | 40 [in] uint32_t num_args, |
40 [in, size_as=num_args] str_t[] arg_names, | 41 [in, size_as=num_args] str_t[] arg_names, |
41 [in, size_as=num_args] uint8_t[] arg_types, | 42 [in, size_as=num_args] uint8_t[] arg_types, |
42 [in, size_as=num_args] uint64_t[] arg_values, | 43 [in, size_as=num_args] uint64_t[] arg_values, |
43 [in] uint8_t flags); | 44 [in] uint8_t flags); |
44 | 45 |
45 /** | 46 /** |
47 * Version of the above interface that allows specifying a custom thread id | |
48 * and timestamp. This is useful for when tracing data cannot be registered | |
49 * in real time. For example, this could be used by storing timestamps | |
50 * internally and then registering the events retroactively. | |
51 */ | |
52 [version=0.2] | |
53 void AddTraceEventWithThreadIdAndTimestamp( | |
54 [in] int8_t phase, | |
55 [in] mem_t category_enabled, | |
56 [in] cstr_t name, | |
57 [in] uint64_t id, | |
58 [in] int32_t thread_id, | |
59 [in] int64_t timestamp, | |
dmichael (off chromium)
2013/06/25 22:19:27
What do you think of a typedef or struct for the t
grosse
2013/06/25 23:16:39
Done.
| |
60 [in] uint32_t num_args, | |
61 [in, size_as=num_args] str_t[] arg_names, | |
62 [in, size_as=num_args] uint8_t[] arg_types, | |
63 [in, size_as=num_args] uint64_t[] arg_values, | |
64 [in] uint8_t flags); | |
65 | |
66 /** | |
67 * Get the current clock value. Since this uses the same function as the trace | |
68 * events use internally, it can be used to create events with explicit time | |
69 * stamps. | |
70 */ | |
71 [version=0.2] | |
72 int64_t Now(); | |
73 | |
74 /** | |
46 * Sets the thread name of the calling thread in the tracing system so it will | 75 * Sets the thread name of the calling thread in the tracing system so it will |
47 * show up properly in chrome://tracing. | 76 * show up properly in chrome://tracing. |
48 */ | 77 */ |
49 void SetThreadName([in] cstr_t thread_name); | 78 void SetThreadName([in] cstr_t thread_name); |
50 }; | 79 }; |
OLD | NEW |