118 lines
4.2 KiB
118 lines
4.2 KiB
/* Copyright (c) 2012 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.
|
|
*/
|
|
|
|
/* From dev/ppb_trace_event_dev.idl modified Tue Jun 25 16:12:08 2013. */
|
|
|
|
#ifndef PPAPI_C_DEV_PPB_TRACE_EVENT_DEV_H_
|
|
#define PPAPI_C_DEV_PPB_TRACE_EVENT_DEV_H_
|
|
|
|
#include "ppapi/c/pp_macros.h"
|
|
#include "ppapi/c/pp_stdint.h"
|
|
|
|
#define PPB_TRACE_EVENT_DEV_INTERFACE_0_1 "PPB_Trace_Event(Dev);0.1"
|
|
#define PPB_TRACE_EVENT_DEV_INTERFACE_0_2 "PPB_Trace_Event(Dev);0.2"
|
|
#define PPB_TRACE_EVENT_DEV_INTERFACE PPB_TRACE_EVENT_DEV_INTERFACE_0_2
|
|
|
|
/**
|
|
* @file
|
|
* This file defines the <code>PPB_Trace_Event</code> interface. It is meant
|
|
* to be used in plugins as the API that trace macros from trace_event.h use.
|
|
*/
|
|
|
|
|
|
/**
|
|
* @addtogroup Typedefs
|
|
* @{
|
|
*/
|
|
/**
|
|
* A trace event timestamp.
|
|
*/
|
|
typedef int64_t PP_TraceEventTime;
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
/**
|
|
* @addtogroup Interfaces
|
|
* @{
|
|
*/
|
|
struct PPB_Trace_Event_Dev_0_2 {
|
|
/**
|
|
* Gets a pointer to a character for identifying a category name in the
|
|
* tracing system as well as for being able to early exit in client-side
|
|
* tracing code.
|
|
*
|
|
* NB: This mem_t return value should technically be const, but return values
|
|
* for Pepper IDL of mem_t type are not const. The same is true for the arg
|
|
* |category_enabled| for AddTraceEvent.
|
|
*/
|
|
void* (*GetCategoryEnabled)(const char* category_name);
|
|
/**
|
|
* Adds a trace event to the platform tracing system. This function call is
|
|
* usually the result of a TRACE_* macro from trace_event.h when tracing and
|
|
* the category of the particular trace are enabled. It is not advisable to
|
|
* call this function on its own; it is really only meant to be used by the
|
|
* trace macros.
|
|
*/
|
|
void (*AddTraceEvent)(int8_t phase,
|
|
const void* category_enabled,
|
|
const char* name,
|
|
uint64_t id,
|
|
uint32_t num_args,
|
|
const char* arg_names[],
|
|
const uint8_t arg_types[],
|
|
const uint64_t arg_values[],
|
|
uint8_t flags);
|
|
/**
|
|
* Version of the above interface that allows specifying a custom thread id
|
|
* and timestamp. This is useful for when tracing data cannot be registered
|
|
* in real time. For example, this could be used by storing timestamps
|
|
* internally and then registering the events retroactively.
|
|
*/
|
|
void (*AddTraceEventWithThreadIdAndTimestamp)(int8_t phase,
|
|
const void* category_enabled,
|
|
const char* name,
|
|
uint64_t id,
|
|
int32_t thread_id,
|
|
PP_TraceEventTime timestamp,
|
|
uint32_t num_args,
|
|
const char* arg_names[],
|
|
const uint8_t arg_types[],
|
|
const uint64_t arg_values[],
|
|
uint8_t flags);
|
|
/**
|
|
* Get the current clock value. Since this uses the same function as the trace
|
|
* events use internally, it can be used to create events with explicit time
|
|
* stamps.
|
|
*/
|
|
PP_TraceEventTime (*Now)(void);
|
|
/**
|
|
* Sets the thread name of the calling thread in the tracing system so it will
|
|
* show up properly in chrome://tracing.
|
|
*/
|
|
void (*SetThreadName)(const char* thread_name);
|
|
};
|
|
|
|
typedef struct PPB_Trace_Event_Dev_0_2 PPB_Trace_Event_Dev;
|
|
|
|
struct PPB_Trace_Event_Dev_0_1 {
|
|
void* (*GetCategoryEnabled)(const char* category_name);
|
|
void (*AddTraceEvent)(int8_t phase,
|
|
const void* category_enabled,
|
|
const char* name,
|
|
uint64_t id,
|
|
uint32_t num_args,
|
|
const char* arg_names[],
|
|
const uint8_t arg_types[],
|
|
const uint64_t arg_values[],
|
|
uint8_t flags);
|
|
void (*SetThreadName)(const char* thread_name);
|
|
};
|
|
/**
|
|
* @}
|
|
*/
|
|
|
|
#endif /* PPAPI_C_DEV_PPB_TRACE_EVENT_DEV_H_ */
|
|
|
|
|