|
|
|
@ -28,17 +28,17 @@ |
|
|
|
|
#if LIBAVCODEC_VERSION_MAJOR < 53 |
|
|
|
|
#define AV_XVMC_STATE_DISPLAY_PENDING 1 /** the surface should be shown, the video driver manipulates this */ |
|
|
|
|
#define AV_XVMC_STATE_PREDICTION 2 /** the surface is needed for prediction, the codec manipulates this */ |
|
|
|
|
#define AV_XVMC_STATE_OSD_SOURCE 4 /** this surface is needed for subpicture rendering */ |
|
|
|
|
#define AV_XVMC_STATE_OSD_SOURCE 4 /** the surface is needed for subpicture rendering */ |
|
|
|
|
#endif |
|
|
|
|
#define AV_XVMC_RENDER_MAGIC 0x1DC711C0 /**< magic value to ensure that regular pixel routines haven't corrupted the struct |
|
|
|
|
the number is 1337 speak for the letters IDCT MCo (motion compensation) */ |
|
|
|
|
|
|
|
|
|
struct xvmc_pix_fmt { |
|
|
|
|
/** Set by calling application
|
|
|
|
|
/** Set by the calling application.
|
|
|
|
|
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 structure
|
|
|
|
|
int xvmc_id; ///< used as a check against memory corruption by regular pixel routines or other API structures
|
|
|
|
|
|
|
|
|
|
short* data_blocks; |
|
|
|
|
XvMCMacroBlock* mv_blocks; |
|
|
|
@ -49,8 +49,8 @@ struct xvmc_pix_fmt { |
|
|
|
|
XvMCSurface* p_surface; ///< pointer to rendered surface, never changed
|
|
|
|
|
//}@
|
|
|
|
|
|
|
|
|
|
/** Set by the decoder before calling draw_horiz_band()
|
|
|
|
|
need by the XvMCRenderSurface function */ |
|
|
|
|
/** 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
|
|
|
|
@ -61,7 +61,7 @@ struct xvmc_pix_fmt { |
|
|
|
|
|
|
|
|
|
/** Offset in the mv array for the current slice:
|
|
|
|
|
- application - zeros it on get_buffer(). |
|
|
|
|
successful draw_horiz_band() may increment it |
|
|
|
|
A successful draw_horiz_band() may increment it |
|
|
|
|
with filled_mb_block_num or zero both. |
|
|
|
|
- libavcodec - unchanged |
|
|
|
|
*/ |
|
|
|
@ -82,13 +82,13 @@ struct xvmc_pix_fmt { |
|
|
|
|
/** extensions may be placed here */ |
|
|
|
|
#if LIBAVCODEC_VERSION_MAJOR < 53 |
|
|
|
|
//@{
|
|
|
|
|
/** State - used to workaround limitations in MPlayer video system.
|
|
|
|
|
0 - Surface not used |
|
|
|
|
1 - Surface is still hold in application to be displayed or is still visible. |
|
|
|
|
2 - Surface is still hold in libavcodec buffer for prediction |
|
|
|
|
/** State - 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. |
|
|
|
|
2 - Surface is still held in libavcodec buffer for prediction. |
|
|
|
|
*/ |
|
|
|
|
int state; |
|
|
|
|
void* p_osd_target_surface_render; ///< pointer to the surface where subpicture is rendered
|
|
|
|
|
void* p_osd_target_surface_render; ///< pointer to the surface where the subpicture is rendered
|
|
|
|
|
//}@
|
|
|
|
|
#endif |
|
|
|
|
}; |
|
|
|
|