diff options
author | Ivan Kalvachev <ikalvachev@gmail.com> | 2009-02-16 18:16:23 +0000 |
---|---|---|
committer | Ivan Kalvachev <ikalvachev@gmail.com> | 2009-02-16 18:16:23 +0000 |
commit | e7de624bccb15feab361bc8bb1888cf9030764b7 (patch) | |
tree | 5c2e7fb5a19d29fe3ec7adc2cc89225663ee0997 | |
parent | 87ad63c0f96e37f7ccb55b0a4d8e5662b81561ff (diff) | |
download | ffmpeg-e7de624bccb15feab361bc8bb1888cf9030764b7.tar.gz |
Improvements in xvmc structure fields descriptions.
Originally committed as revision 17383 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r-- | libavcodec/xvmc.h | 48 |
1 files changed, 24 insertions, 24 deletions
diff --git a/libavcodec/xvmc.h b/libavcodec/xvmc.h index 93d684c933..29da9308bb 100644 --- a/libavcodec/xvmc.h +++ b/libavcodec/xvmc.h @@ -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. |