mirror of https://git.ffmpeg.org/ffmpeg.git
Improvements in xvmc structure fields descriptions.
Originally committed as revision 17383 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
87ad63c0f9
commit
e7de624bcc
|
@ -34,10 +34,6 @@
|
|||
the number is 1337 speak for the letters IDCT MCo (motion compensation) */
|
||||
|
||||
struct xvmc_pix_fmt {
|
||||
/** Set by the calling application.
|
||||
Once set these values are not supposed to be modified.
|
||||
*/
|
||||
//@{
|
||||
/** The field contains the special constant value AV_XVMC_ID.
|
||||
It is used as a test that the application correctly uses the API,
|
||||
and that there is no corruption caused by pixel routines.
|
||||
|
@ -46,18 +42,19 @@ struct xvmc_pix_fmt {
|
|||
*/
|
||||
int xvmc_id;
|
||||
|
||||
/** Pointer to the block array allocated by XvMCCreateBlocks()
|
||||
it contains differential pixel data (in MoCo mode)
|
||||
or coefficients for IDCT.
|
||||
- application - set during initialization
|
||||
- libavcodec - unchanged
|
||||
/** Pointer to the block array allocated by XvMCCreateBlocks().
|
||||
The array is have to be freed by XvMCDestroyBlocks().
|
||||
Each 64 values represent one data block of
|
||||
differential pixel data (in MoCo mode) or coefficients for IDCT.
|
||||
- application - set the pointer during initialization
|
||||
- libavcodec - fills coefficients/pixel data into the array
|
||||
*/
|
||||
short* data_blocks;
|
||||
|
||||
/** Pointer to the macroblock description array allocated by
|
||||
XvMCCreateMacroBlocks().
|
||||
- application - set during initialization
|
||||
- libavcodec - unchanged
|
||||
XvMCCreateMacroBlocks() and freed by XvMCDestroyMacroBlocks().
|
||||
- application - set the pointer during initialization
|
||||
- libavcodec - fills description data into the array
|
||||
*/
|
||||
XvMCMacroBlock* mv_blocks;
|
||||
|
||||
|
@ -89,12 +86,12 @@ struct xvmc_pix_fmt {
|
|||
int unsigned_intra;
|
||||
|
||||
/** Pointer to the surface allocated by XvMCCreateSurface().
|
||||
It have to be freed by XvMCDestroySurface() on application exit.
|
||||
It identifies the frame and its state on the video hardware.
|
||||
- application - set during initialization
|
||||
- libavcodec - unchanged
|
||||
*/
|
||||
XvMCSurface* p_surface;
|
||||
//}@
|
||||
|
||||
/** Set by the decoder before calling ff_draw_horiz_band(),
|
||||
needed by the XvMCRenderSurface function. */
|
||||
|
@ -124,9 +121,8 @@ struct xvmc_pix_fmt {
|
|||
unsigned int flags;
|
||||
//}@
|
||||
|
||||
/** Offset in the mv array for the current slice.
|
||||
Macroblocks described before that offset are assumed to have already
|
||||
been passed to the hardware.
|
||||
/** Number of macro block descriptions in the mv_blocks array
|
||||
that have already been passed to the hardware.
|
||||
- application - zeroes it on get_buffer().
|
||||
A successful ff_draw_horiz_band() may increment it
|
||||
with filled_mb_block_num or zero both.
|
||||
|
@ -134,19 +130,23 @@ struct xvmc_pix_fmt {
|
|||
*/
|
||||
int start_mv_blocks_num;
|
||||
|
||||
/** Number of mv blocks that are filled by libavcodec and have to be
|
||||
passed to the hardware.
|
||||
/** Number of new macro blocks descriptions in mv_blocks array
|
||||
that are filled by libavcodec and have to be passed to the hardware.
|
||||
- application - zeroes it on get_buffer() or after successful
|
||||
ff_draw_horiz_band().
|
||||
- libavcodec - increment with one of each stored MB
|
||||
*/
|
||||
int filled_mv_blocks_num;
|
||||
|
||||
/** Offset to the next free data block. The mv_blocks field holds a number
|
||||
pointing to the data blocks.
|
||||
- application - zeroes it on get_buffer() and after successful
|
||||
ff_draw_horiz_band().
|
||||
- libavcodec - each macroblock increases it with the number
|
||||
/** Number of the the next free data block.
|
||||
One data block is 64 short values in data_blocks array.
|
||||
All blocks before this one are already claimed by filling their number
|
||||
in the corresponding blocks description structure field,
|
||||
that are hold in mv_blocks array.
|
||||
- application - zeroes it on get_buffer().
|
||||
A successful ff_draw_horiz_band() may zero it together
|
||||
with start_mb_blocks_num.
|
||||
- libavcodec - each decoded macroblock increases it with the number
|
||||
of coded blocks it contains.
|
||||
*/
|
||||
int next_free_data_block_num;
|
||||
|
@ -154,7 +154,7 @@ struct xvmc_pix_fmt {
|
|||
/** extensions may be placed here */
|
||||
#if LIBAVCODEC_VERSION_MAJOR < 53
|
||||
//@{
|
||||
/** State - used to work around limitations in the MPlayer video system.
|
||||
/** State flags used to work around limitations in the MPlayer video system.
|
||||
0 - Surface is not used.
|
||||
1 - Surface is still held in application to be displayed or is
|
||||
still visible.
|
||||
|
|
Loading…
Reference in New Issue