You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

97 lines
4.1KB

  1. /*
  2. * Copyright (C) 2003 Ivan Kalvachev
  3. *
  4. * This file is part of FFmpeg.
  5. *
  6. * FFmpeg is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2.1 of the License, or (at your option) any later version.
  10. *
  11. * FFmpeg is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public
  17. * License along with FFmpeg; if not, write to the Free Software
  18. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  19. */
  20. #ifndef AVCODEC_XVMC_H
  21. #define AVCODEC_XVMC_H
  22. #include <X11/extensions/XvMC.h>
  23. #include "avcodec.h"
  24. #if LIBAVCODEC_VERSION_MAJOR < 53
  25. #define AV_XVMC_STATE_DISPLAY_PENDING 1 /** the surface should be shown, the video driver manipulates this */
  26. #define AV_XVMC_STATE_PREDICTION 2 /** the surface is needed for prediction, the codec manipulates this */
  27. #define AV_XVMC_STATE_OSD_SOURCE 4 /** the surface is needed for subpicture rendering */
  28. #endif
  29. #define AV_XVMC_RENDER_MAGIC 0x1DC711C0 /**< magic value to ensure that regular pixel routines haven't corrupted the struct
  30. the number is 1337 speak for the letters IDCT MCo (motion compensation) */
  31. struct xvmc_pix_fmt {
  32. /** Set by the calling application.
  33. Once set these values are not supposed to be modified.
  34. */
  35. //@{
  36. int xvmc_id; ///< used as a check against memory corruption by regular pixel routines or other API structures
  37. short* data_blocks;
  38. XvMCMacroBlock* mv_blocks;
  39. int total_number_of_mv_blocks;
  40. int total_number_of_data_blocks;
  41. int idct; ///< indicate that IDCT acceleration level is used
  42. int unsigned_intra; ///< +-128 for intra pictures after clipping
  43. XvMCSurface* p_surface; ///< pointer to rendered surface, never changed
  44. //}@
  45. /** Set by the decoder before calling draw_horiz_band(),
  46. needed by the XvMCRenderSurface function. */
  47. //@{
  48. XvMCSurface* p_past_surface; ///< pointer to the past surface
  49. XvMCSurface* p_future_surface; ///< pointer to the future prediction surface
  50. unsigned int picture_structure; ///< top/bottom field or frame
  51. unsigned int flags; ///< XVMC_SECOND_FIELD - 1st or 2nd field in the sequence
  52. //}@
  53. /** Offset in the mv array for the current slice:
  54. - application - zeros it on get_buffer().
  55. A successful draw_horiz_band() may increment it
  56. with filled_mb_block_num or zero both.
  57. - libavcodec - unchanged
  58. */
  59. int start_mv_blocks_num;
  60. /** Processed mv blocks in this slice:
  61. - application - zeros it on get_buffer() or after successful draw_horiz_band()
  62. - libavcodec - increment with one of each stored MB
  63. */
  64. int filled_mv_blocks_num;
  65. /** Offset to the next free data block. The mv_blocks hold number pointing to the data blocks.
  66. - application - zeroes it on get_buffer() and after successful draw_horiz_band()
  67. - libvcodec - each macroblock increases it with the number of coded blocks in it.
  68. */
  69. int next_free_data_block_num;
  70. /** extensions may be placed here */
  71. #if LIBAVCODEC_VERSION_MAJOR < 53
  72. //@{
  73. /** State - used to work around limitations in the MPlayer video system.
  74. 0 - Surface is not used.
  75. 1 - Surface is still held in application to be displayed or is still visible.
  76. 2 - Surface is still held in libavcodec buffer for prediction.
  77. */
  78. int state;
  79. void* p_osd_target_surface_render; ///< pointer to the surface where the subpicture is rendered
  80. //}@
  81. #endif
  82. };
  83. #endif /* AVCODEC_XVMC_H */