| Index: ppapi/c/dev/ppb_graphics_3d_trusted_dev.h
 | 
| ===================================================================
 | 
| --- ppapi/c/dev/ppb_graphics_3d_trusted_dev.h	(revision 0)
 | 
| +++ ppapi/c/dev/ppb_graphics_3d_trusted_dev.h	(revision 0)
 | 
| @@ -0,0 +1,104 @@
 | 
| +// Copyright (c) 2011 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.
 | 
| +
 | 
| +#ifndef PPAPI_C_DEV_PPB_GRAPHICS_3D_TRUSTED_DEV_H_
 | 
| +#define PPAPI_C_DEV_PPB_GRAPHICS_3D_TRUSTED_DEV_H_
 | 
| +
 | 
| +#include "ppapi/c/pp_bool.h"
 | 
| +#include "ppapi/c/pp_instance.h"
 | 
| +#include "ppapi/c/pp_resource.h"
 | 
| +#include "ppapi/c/pp_stdint.h"
 | 
| +
 | 
| +#define PPB_GRAPHICS_3D_TRUSTED_DEV_INTERFACE_0_1 \
 | 
| +    "PPB_Graphics3DTrusted(Dev);0.1"
 | 
| +#define PPB_GRAPHICS_3D_TRUSTED_DEV_INTERFACE \
 | 
| +    PPB_GRAPHICS_3D_TRUSTED_DEV_INTERFACE_0_1
 | 
| +
 | 
| +typedef enum {
 | 
| +  PPB_GRAPHICS3D_TRUSTED_ERROR_OK,
 | 
| +  PPB_GRAPHICS3D_TRUSTED_ERROR_GENERICERROR,
 | 
| +  PPB_GRAPHICS3D_TRUSTED_ERROR_INVALIDARGUMENTS,
 | 
| +  PPB_GRAPHICS3D_TRUSTED_ERROR_INVALIDSIZE,
 | 
| +  PPB_GRAPHICS3D_TRUSTED_ERROR_LOSTCONTEXT,
 | 
| +  PPB_GRAPHICS3D_TRUSTED_ERROR_OUTOFBOUNDS,
 | 
| +  PPB_GRAPHICS3D_TRUSTED_ERROR_UNKNOWNCOMMAND
 | 
| +} PPB_Graphics3DTrustedError;
 | 
| +
 | 
| +struct PP_Graphics3DTrustedState {
 | 
| +  // Size of the command buffer in command buffer entries.
 | 
| +  int32_t num_entries;
 | 
| +
 | 
| +  // The offset (in entries) from which the reader is reading.
 | 
| +  int32_t get_offset;
 | 
| +
 | 
| +  // The offset (in entries) at which the writer is writing.
 | 
| +  int32_t put_offset;
 | 
| +
 | 
| +  // The current token value. This is used by the writer to defer
 | 
| +  // changes to shared memory objects until the reader has reached a certain
 | 
| +  // point in the command buffer. The reader is responsible for updating the
 | 
| +  // token value, for example in response to an asynchronous set token command
 | 
| +  // embedded in the command buffer. The default token value is zero.
 | 
| +  int32_t token;
 | 
| +
 | 
| +  // Error status.
 | 
| +  PPB_Graphics3DTrustedError error;
 | 
| +
 | 
| +  // Generation index of this state. The generation index is incremented every
 | 
| +  // time a new state is retrieved from the command processor, so that
 | 
| +  // consistency can be kept even if IPC messages are processed out-of-order.
 | 
| +  uint32_t generation;
 | 
| +};
 | 
| +
 | 
| +struct PPB_Graphics3DTrusted_Dev {
 | 
| +  // Creates a raw Graphics3D resource. A raw Graphics3D is intended to be used
 | 
| +  // with the trusted interface, through the command buffer (for proxying).
 | 
| +  PP_Resource (*CreateRaw)(PP_Instance instance_id,
 | 
| +                           PP_Config3D_Dev config,
 | 
| +                           PP_Resource share_context,
 | 
| +                           const int32_t* attrib_list);
 | 
| +
 | 
| +  // Initializes the command buffer with the given size.
 | 
| +  PP_Bool (*InitCommandBuffer)(PP_Resource context_id, int32_t size);
 | 
| +
 | 
| +  // Gets the ring buffer for the command buffer.
 | 
| +  PP_Bool (*GetRingBuffer)(PP_Resource context_id,
 | 
| +                           int* shm_handle,
 | 
| +                           uint32_t* shm_size);
 | 
| +
 | 
| +  // Returns the current state.
 | 
| +  struct PP_Graphics3DTrustedState (*GetState)(PP_Resource context);
 | 
| +
 | 
| +  // Create a transfer buffer and return a handle that uniquely
 | 
| +  // identifies it or -1 on error.
 | 
| +  int32_t (*CreateTransferBuffer)(PP_Resource context, uint32_t size);
 | 
| +
 | 
| +  // Destroy a transfer buffer and recycle the handle.
 | 
| +  PP_Bool (*DestroyTransferBuffer)(PP_Resource context, int32_t id);
 | 
| +
 | 
| +  // Get the transfer buffer associated with a handle.
 | 
| +  PP_Bool (*GetTransferBuffer)(PP_Resource context,
 | 
| +                               int32_t id,
 | 
| +                               int* shm_handle,
 | 
| +                               uint32_t* shm_size);
 | 
| +
 | 
| +  // The writer calls this to update its put offset.
 | 
| +  PP_Bool (*Flush)(PP_Resource context, int32_t put_offset);
 | 
| +
 | 
| +  // The writer calls this to update its put offset. This function returns the
 | 
| +  // reader's most recent get offset. Does not return until after the put offset
 | 
| +  // change callback has been invoked.
 | 
| +  struct PP_Graphics3DTrustedState (*FlushSync)(PP_Resource context,
 | 
| +                                                int32_t put_offset);
 | 
| +
 | 
| +  // Like FlushSync, but returns before processing commands if the get offset is
 | 
| +  // different than last_known_get. Allows synchronization with the command
 | 
| +  // processor without forcing immediate command execution.
 | 
| +  struct PP_Graphics3DTrustedState (*FlushSyncFast)(PP_Resource context,
 | 
| +                                                    int32_t put_offset,
 | 
| +                                                    int32_t last_known_get);
 | 
| +};
 | 
| +
 | 
| +#endif  // PPAPI_C_DEV_PPB_GRAPHICS_3D_TRUSTED_DEV_H_
 | 
| +
 | 
| 
 | 
| Property changes on: ppapi/c/dev/ppb_graphics_3d_trusted_dev.h
 | 
| ___________________________________________________________________
 | 
| Added: svn:eol-style
 | 
|    + LF
 | 
| 
 | 
| 
 |