Chromium Code Reviews| 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 |