summaryrefslogtreecommitdiff
path: root/libavcodec/xvmc.h
diff options
context:
space:
mode:
authorIvan Kalvachev <ikalvachev@gmail.com>2009-02-16 18:16:23 +0000
committerIvan Kalvachev <ikalvachev@gmail.com>2009-02-16 18:16:23 +0000
commite7de624bccb15feab361bc8bb1888cf9030764b7 (patch)
tree5c2e7fb5a19d29fe3ec7adc2cc89225663ee0997 /libavcodec/xvmc.h
parent87ad63c0f96e37f7ccb55b0a4d8e5662b81561ff (diff)
Improvements in xvmc structure fields descriptions.
Originally committed as revision 17383 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/xvmc.h')
-rw-r--r--libavcodec/xvmc.h48
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.