/* 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_video_decoder_dev.idl modified Tue Oct 29 00:32:59 2013. */ #ifndef PPAPI_C_DEV_PPB_VIDEO_DECODER_DEV_H_ #define PPAPI_C_DEV_PPB_VIDEO_DECODER_DEV_H_ #include "ppapi/c/dev/pp_video_dev.h" #include "ppapi/c/pp_bool.h" #include "ppapi/c/pp_completion_callback.h" #include "ppapi/c/pp_instance.h" #include "ppapi/c/pp_macros.h" #include "ppapi/c/pp_resource.h" #include "ppapi/c/pp_size.h" #include "ppapi/c/pp_stdint.h" #define PPB_VIDEODECODER_DEV_INTERFACE_0_16 "PPB_VideoDecoder(Dev);0.16" #define PPB_VIDEODECODER_DEV_INTERFACE PPB_VIDEODECODER_DEV_INTERFACE_0_16 /** * @file * This file defines the PPB_VideoDecoder_Dev interface. */ /** * @addtogroup Interfaces * @{ */ /** * Video decoder interface. * * Typical usage: * - Use Create() to create & configure a new PPB_VideoDecoder_Dev resource. * - Call Decode() to decode some video data. * - Receive ProvidePictureBuffers callback * - Supply the decoder with textures using AssignPictureBuffers. * - Receive PictureReady callbacks * - Hand the textures back to the decoder using ReusePictureBuffer. * - To signal EOS to the decoder: call Flush() and wait for NotifyFlushDone * callback. * - To reset the decoder (e.g. to implement Seek): call Reset() and wait for * NotifyResetDone callback. * - To tear down the decoder call Destroy(). * * See PPP_VideoDecoder_Dev for the notifications the decoder may send the * plugin. */ struct PPB_VideoDecoder_Dev_0_16 { /** * Creates & initializes a video decoder. * * Parameters: * |instance| pointer to the plugin instance. * |context| a PPB_Graphics3D resource in which decoding will happen. * |profile| the video stream's format profile. * * The created decoder is returned as PP_Resource. 0 means failure. */ PP_Resource (*Create)(PP_Instance instance, PP_Resource context, PP_VideoDecoder_Profile profile); /** * Tests whether |resource| is a video decoder created through Create * function of this interface. * * Parameters: * |resource| is handle to resource to test. * * Returns true if is a video decoder, false otherwise. */ PP_Bool (*IsVideoDecoder)(PP_Resource resource); /** * Dispatches bitstream buffer to the decoder. * * Parameters: * |video_decoder| is the previously created handle to the decoder resource. * |bitstream_buffer| is the bitstream buffer that contains at most one * input frame. * |callback| will be called when |bitstream_buffer| has been processed by * the decoder. * * Returns an error code from pp_errors.h. */ int32_t (*Decode)(PP_Resource video_decoder, const struct PP_VideoBitstreamBuffer_Dev* bitstream_buffer, struct PP_CompletionCallback callback); /** * Provides the decoder with texture-backed picture buffers for video * decoding. * * This function should be called when the plugin has its * ProvidePictureBuffers method called. The decoder will stall until it has * received all the buffers it's asked for. * * Parameters: * |video_decoder| is the previously created handle to the decoder resource. * |no_of_buffers| how many buffers are behind picture buffer pointer. * |buffers| contains the reference to the picture buffer that was * allocated. */ void (*AssignPictureBuffers)(PP_Resource video_decoder, uint32_t no_of_buffers, const struct PP_PictureBuffer_Dev buffers[]); /** * Tells the decoder to reuse the given picture buffer. Typical use of this * function is to call from PictureReady callback to recycle picture buffer * back to the decoder after blitting the image so that decoder can use the * image for output again. * * Parameters: * |video_decoder| is the previously created handle to the decoder resource. * |picture_buffer_id| contains the id of the picture buffer that was * processed. */ void (*ReusePictureBuffer)(PP_Resource video_decoder, int32_t picture_buffer_id); /** * Flush input and output buffers in the decoder. Any pending inputs are * decoded and pending outputs are delivered to the plugin. Once done * flushing, the decoder will call |callback|. * * Parameters: * |video_decoder| is the previously created handle to the decoder resource. * |callback| is one-time callback that will be called once the flushing * request has been completed. * * Returns an error code from pp_errors.h. */ int32_t (*Flush)(PP_Resource video_decoder, struct PP_CompletionCallback callback); /** * Reset the decoder as quickly as possible. Pending inputs and outputs are * dropped and the decoder is put back into a state ready to receive further * Decode() calls. |callback| will be called when the reset is done. * * Parameters: * |video_decoder| is the previously created handle to the decoder resource. * |callback| is one-time callback that will be called once the reset * request has been completed. * * Returns an error code from pp_errors.h. */ int32_t (*Reset)(PP_Resource video_decoder, struct PP_CompletionCallback callback); /** * Tear down the decoder as quickly as possible. Pending inputs and outputs * are dropped and the decoder frees all of its resources. Although resources * may be freed asynchronously, after this method returns no more callbacks * will be made on the client. Any resources held by the client at that point * may be freed. * * Parameters: * |video_decoder| is the previously created handle to the decoder resource. */ void (*Destroy)(PP_Resource video_decoder); }; typedef struct PPB_VideoDecoder_Dev_0_16 PPB_VideoDecoder_Dev; /** * @} */ #endif /* PPAPI_C_DEV_PPB_VIDEO_DECODER_DEV_H_ */