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.

172 lines
6.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_ID 0x1DC711C0 /**< special 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. /** The field contains the special constant value AV_XVMC_ID.
  37. It is used as a test that the application correctly uses the API,
  38. and that there is no corruption caused by pixel routines.
  39. - application - set during initialization
  40. - libavcodec - unchanged
  41. */
  42. int xvmc_id;
  43. /** Pointer to the block array allocated by XvMCCreateBlocks()
  44. it contains differential pixel data (in MoCo mode)
  45. or coefficients for IDCT.
  46. - application - set during initialization
  47. - libavcodec - unchanged
  48. */
  49. short* data_blocks;
  50. /** Pointer to the macroblock description array allocated by
  51. XvMCCreateMacroBlocks().
  52. - application - set during initialization
  53. - libavcodec - unchanged
  54. */
  55. XvMCMacroBlock* mv_blocks;
  56. /** Number of macroblock descriptions that can be stored in the mv_blocks
  57. array.
  58. - application - set during initialization
  59. - libavcodec - unchanged
  60. */
  61. int allocated_mv_blocks;
  62. /** Number of blocks that can be stored at once in the data_blocks array.
  63. - application - set during initialization
  64. - libavcodec - unchanged
  65. */
  66. int allocated_data_blocks;
  67. /** Indicates that the hardware would interpret data_blocks as IDCT
  68. coefficients and perform IDCT on them.
  69. - application - set during initialization
  70. - libavcodec - unchanged
  71. */
  72. int idct;
  73. /** In MoCo mode it indicates that intra macroblocks are assumed to be in
  74. unsigned format; same as the XVMC_INTRA_UNSIGNED flag.
  75. - application - set during initialization
  76. - libavcodec - unchanged
  77. */
  78. int unsigned_intra;
  79. /** Pointer to the surface allocated by XvMCCreateSurface().
  80. It identifies the frame and its state on the video hardware.
  81. - application - set during initialization
  82. - libavcodec - unchanged
  83. */
  84. XvMCSurface* p_surface;
  85. //}@
  86. /** Set by the decoder before calling ff_draw_horiz_band(),
  87. needed by the XvMCRenderSurface function. */
  88. //@{
  89. /** Pointer to the surface used as past reference
  90. - application - unchanged
  91. - libavcodec - set
  92. */
  93. XvMCSurface* p_past_surface;
  94. /** Pointer to the surface used as future reference
  95. - application - unchanged
  96. - libavcodec - set
  97. */
  98. XvMCSurface* p_future_surface;
  99. /** top/bottom field or frame
  100. - application - unchanged
  101. - libavcodec - set
  102. */
  103. unsigned int picture_structure;
  104. /** XVMC_SECOND_FIELD - 1st or 2nd field in the sequence
  105. - application - unchanged
  106. - libavcodec - set
  107. */
  108. unsigned int flags;
  109. //}@
  110. /** Offset in the mv array for the current slice.
  111. Macroblocks described before that offset are assumed to have already
  112. been passed to the hardware.
  113. - application - zeroes it on get_buffer().
  114. A successful ff_draw_horiz_band() may increment it
  115. with filled_mb_block_num or zero both.
  116. - libavcodec - unchanged
  117. */
  118. int start_mv_blocks_num;
  119. /** Number of mv blocks that are filled by libavcodec and have to be
  120. passed to the hardware.
  121. - application - zeroes it on get_buffer() or after successful
  122. ff_draw_horiz_band().
  123. - libavcodec - increment with one of each stored MB
  124. */
  125. int filled_mv_blocks_num;
  126. /** Offset to the next free data block. The mv_blocks field holds a number
  127. pointing to the data blocks.
  128. - application - zeroes it on get_buffer() and after successful
  129. ff_draw_horiz_band().
  130. - libavcodec - each macroblock increases it with the number
  131. of coded blocks it contains.
  132. */
  133. int next_free_data_block_num;
  134. /** extensions may be placed here */
  135. #if LIBAVCODEC_VERSION_MAJOR < 53
  136. //@{
  137. /** State - used to work around limitations in the MPlayer video system.
  138. 0 - Surface is not used.
  139. 1 - Surface is still held in application to be displayed or is
  140. still visible.
  141. 2 - Surface is still held in libavcodec buffer for prediction.
  142. */
  143. int state;
  144. /** pointer to the surface where the subpicture is rendered */
  145. void* p_osd_target_surface_render;
  146. //}@
  147. #endif
  148. };
  149. #endif /* AVCODEC_XVMC_H */