changeset 8931:9f596cd79411 libavcodec

Describe all fields in xvmc struct.
author iive
date Sun, 15 Feb 2009 20:13:00 +0000
parents 8987e082c09f
children f647961ab2ac
files xvmc.h
diffstat 1 files changed, 74 insertions(+), 10 deletions(-) [+]
line wrap: on
line diff
--- a/xvmc.h	Sun Feb 15 19:10:16 2009 +0000
+++ b/xvmc.h	Sun Feb 15 20:13:00 2009 +0000
@@ -38,28 +38,92 @@
     Once set these values are not supposed to be modified.
 */
 //@{
-    int             xvmc_id;                      ///< used as a check against memory corruption by regular pixel routines or other API structures
+    /** The field contains special constant value.
+        It is used as test whenever the application knows the calling API,
+        and that there is no corruption caused by pixel routines.
+        - application - set during initialization
+        - libavcodec  - unchanged
+    */
+    int             xvmc_id;
 
+    /** Pointer to the block array allocated by XvMCCreateBlocks()
+        it contins differential pixel data (in MoCo mode)
+        or coefficients for IDCT.
+        - application - set during initialization
+        - libavcodec  - unchanged
+    */
     short*          data_blocks;
+
+    /** Pointer to the macroblock description array allocated by XvMCCreateMacroBlocks().
+        - application - set during initialization
+        - libavcodec  - unchanged
+    */
     XvMCMacroBlock* mv_blocks;
+
+    /** Number of all MB descriptions that could be stored in the mv_blocks array.
+        - application - set during initialization
+        - libavcodec  - unchanged
+    */
     int             total_number_of_mv_blocks;
+
+    /** Number of all blocks that could be stored at once in the data_blocks array.
+        - application - set during initialization
+        - libavcodec  - unchanged
+    */
     int             total_number_of_data_blocks;
-    int             idct;                         ///< indicate that IDCT acceleration level is used
-    int             unsigned_intra;               ///< +-128 for intra pictures after clipping
-    XvMCSurface*    p_surface;                    ///< pointer to rendered surface, never changed
+
+    /** Indicates that the hardware would interpret data_blocks as IDCT cefficients
+        and perform IDCT on them.
+        - application - set during initialization
+        - libavcodec  - unchanged
+    */
+    int             idct;
+
+    /** In MoCo mode it indicates that Intra MB are assumed to be in unsigned format
+        Same as XVMC_INTRA_UNSIGNED flag.
+        - application - set during initialization
+        - libavcodec  - unchanged
+    */
+    int             unsigned_intra;
+
+    /** Pointer to the Surface allocated by XvMCCreateSurface().
+        It identifies the frame on the video hardware and its state.
+        - application - set during initialization
+        - libavcodec  - unchanged
+    */
+    XvMCSurface*    p_surface;
 //}@
 
 /** Set by the decoder before calling draw_horiz_band(),
     needed by the XvMCRenderSurface function. */
 //@{
-    XvMCSurface*    p_past_surface;               ///< pointer to the past surface
-    XvMCSurface*    p_future_surface;             ///< pointer to the future prediction surface
+    /** Pointer to the surface used as past reference
+        - application - unchanged
+        - libavcodec  - set
+    */
+    XvMCSurface*    p_past_surface;
+
+    /**Pointer to the surface used as future reference
+        - application - unchanged
+        - libavcodec  - set
+    */
+    XvMCSurface*    p_future_surface;
 
-    unsigned int    picture_structure;            ///< top/bottom field or frame
-    unsigned int    flags;                        ///< XVMC_SECOND_FIELD - 1st or 2nd field in the sequence
+    /** top/bottom field or frame
+        - application - unchanged
+        - libavcodec  - set
+    */
+    unsigned int    picture_structure;
+
+    /**XVMC_SECOND_FIELD - 1st or 2nd field in the sequence
+        - application - unchanged
+        - libavcodec  - set
+    */
+    unsigned int    flags;
 //}@
 
-    /** Offset in the mv array for the current slice:
+    /** Offset in the mv array for the current slice.
+        Macroblocks described before that offset are assumed to be already passed to the hardware.
         - application - zeros it on get_buffer().
                         A successful draw_horiz_band() may increment it
                         with filled_mb_block_num or zero both.
@@ -67,7 +131,7 @@
     */
     int             start_mv_blocks_num;
 
-    /** Processed mv blocks in this slice:
+    /** Number of mv blocks that are filled by libavcodec and have to be passed to the hardware.
         - application - zeros it on get_buffer() or after successful draw_horiz_band()
         - libavcodec  - increment with one of each stored MB
     */