p_video_decoder.h revision d3770d6229d95e9beb67358ae2b2c8824ed3ae58
1/************************************************************************** 2 * 3 * Copyright 2009 Younes Manton. 4 * All Rights Reserved. 5 * 6 * Permission is hereby granted, free of charge, to any person obtaining a 7 * copy of this software and associated documentation files (the 8 * "Software"), to deal in the Software without restriction, including 9 * without limitation the rights to use, copy, modify, merge, publish, 10 * distribute, sub license, and/or sell copies of the Software, and to 11 * permit persons to whom the Software is furnished to do so, subject to 12 * the following conditions: 13 * 14 * The above copyright notice and this permission notice (including the 15 * next paragraph) shall be included in all copies or substantial portions 16 * of the Software. 17 * 18 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS 19 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF 20 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT. 21 * IN NO EVENT SHALL TUNGSTEN GRAPHICS AND/OR ITS SUPPLIERS BE LIABLE FOR 22 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, 23 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE 24 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. 25 * 26 **************************************************************************/ 27 28#ifndef PIPE_VIDEO_CONTEXT_H 29#define PIPE_VIDEO_CONTEXT_H 30 31#ifdef __cplusplus 32extern "C" { 33#endif 34 35#include <pipe/p_video_state.h> 36 37struct pipe_screen; 38struct pipe_surface; 39struct pipe_macroblock; 40struct pipe_picture_desc; 41struct pipe_fence_handle; 42 43/** 44 * Gallium video decoder for a specific codec/profile 45 */ 46struct pipe_video_decoder 47{ 48 struct pipe_context *context; 49 50 enum pipe_video_profile profile; 51 enum pipe_video_entrypoint entrypoint; 52 enum pipe_video_chroma_format chroma_format; 53 unsigned width; 54 unsigned height; 55 56 /** 57 * destroy this video decoder 58 */ 59 void (*destroy)(struct pipe_video_decoder *decoder); 60 61 /** 62 * Creates a decoder buffer 63 */ 64 void *(*create_buffer)(struct pipe_video_decoder *decoder); 65 66 /** 67 * Destroys a decoder buffer 68 */ 69 void (*destroy_buffer)(struct pipe_video_decoder *decoder, void *buffer); 70 71 /** 72 * set the current decoder buffer 73 */ 74 void (*set_decode_buffer)(struct pipe_video_decoder *decoder, void *buffer); 75 76 /** 77 * set the picture parameters for the next frame 78 * only used for bitstream decoding 79 */ 80 void (*set_picture_parameters)(struct pipe_video_decoder *decoder, 81 struct pipe_picture_desc *picture); 82 83 /** 84 * set the quantification matrixes 85 */ 86 void (*set_quant_matrix)(struct pipe_video_decoder *decoder, 87 const uint8_t intra_matrix[64], 88 const uint8_t non_intra_matrix[64]); 89 90 /** 91 * set target where video data is decoded to 92 */ 93 void (*set_decode_target)(struct pipe_video_decoder *decoder, 94 struct pipe_video_buffer *target); 95 96 /** 97 * set reference frames for motion compensation 98 */ 99 void (*set_reference_frames)(struct pipe_video_decoder *decoder, 100 struct pipe_video_buffer **ref_frames, 101 unsigned num_ref_frames); 102 103 /** 104 * start decoding of a new frame 105 */ 106 void (*begin_frame)(struct pipe_video_decoder *decoder); 107 108 /** 109 * decode a macroblock 110 */ 111 void (*decode_macroblock)(struct pipe_video_decoder *decoder, 112 const struct pipe_macroblock *macroblocks, 113 unsigned num_macroblocks); 114 115 /** 116 * decode a bitstream 117 */ 118 void (*decode_bitstream)(struct pipe_video_decoder *decoder, 119 unsigned num_bytes, const void *data); 120 121 /** 122 * end decoding of the current frame 123 */ 124 void (*end_frame)(struct pipe_video_decoder *decoder); 125 126 /** 127 * flush any outstanding command buffers to the hardware 128 * should be called before a video_buffer is acessed by the state tracker again 129 */ 130 void (*flush)(struct pipe_video_decoder *decoder); 131}; 132 133/** 134 * output for decoding / input for displaying 135 */ 136struct pipe_video_buffer 137{ 138 struct pipe_context *context; 139 140 enum pipe_format buffer_format; 141 enum pipe_video_chroma_format chroma_format; 142 unsigned width; 143 unsigned height; 144 145 /** 146 * destroy this video buffer 147 */ 148 void (*destroy)(struct pipe_video_buffer *buffer); 149 150 /** 151 * get a individual sampler view for each plane 152 */ 153 struct pipe_sampler_view **(*get_sampler_view_planes)(struct pipe_video_buffer *buffer); 154 155 /** 156 * get a individual sampler view for each component 157 */ 158 struct pipe_sampler_view **(*get_sampler_view_components)(struct pipe_video_buffer *buffer); 159 160 /** 161 * get a individual surfaces for each plane 162 */ 163 struct pipe_surface **(*get_surfaces)(struct pipe_video_buffer *buffer); 164}; 165 166#ifdef __cplusplus 167} 168#endif 169 170#endif /* PIPE_VIDEO_CONTEXT_H */ 171