OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #ifndef CONTENT_COMMON_GPU_MEDIA_OMX_VIDEO_DECODE_ACCELERATOR_H_ | 5 #ifndef CONTENT_COMMON_GPU_MEDIA_OMX_VIDEO_DECODE_ACCELERATOR_H_ |
6 #define CONTENT_COMMON_GPU_MEDIA_OMX_VIDEO_DECODE_ACCELERATOR_H_ | 6 #define CONTENT_COMMON_GPU_MEDIA_OMX_VIDEO_DECODE_ACCELERATOR_H_ |
7 | 7 |
8 #include <dlfcn.h> | 8 #include <dlfcn.h> |
9 #include <map> | 9 #include <map> |
10 #include <queue> | 10 #include <queue> |
(...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
63 // DESTROYING or ERRORING. | 63 // DESTROYING or ERRORING. |
64 enum CurrentStateChange { | 64 enum CurrentStateChange { |
65 NO_TRANSITION, // Not in the middle of a transition. | 65 NO_TRANSITION, // Not in the middle of a transition. |
66 INITIALIZING, | 66 INITIALIZING, |
67 FLUSHING, | 67 FLUSHING, |
68 RESETTING, | 68 RESETTING, |
69 DESTROYING, | 69 DESTROYING, |
70 ERRORING, // Trumps all other transitions; no recovery is possible. | 70 ERRORING, // Trumps all other transitions; no recovery is possible. |
71 }; | 71 }; |
72 | 72 |
| 73 // Add codecs as we get HW that supports them (and which are supported by SW |
| 74 // decode!). |
| 75 enum Codec { |
| 76 UNKNOWN, |
| 77 H264, |
| 78 VP8 |
| 79 }; |
| 80 |
73 // Helper struct for keeping track of the relationship between an OMX output | 81 // Helper struct for keeping track of the relationship between an OMX output |
74 // buffer and the PictureBuffer it points to. | 82 // buffer and the PictureBuffer it points to. |
75 struct OutputPicture { | 83 struct OutputPicture { |
76 OutputPicture(media::PictureBuffer p_b, OMX_BUFFERHEADERTYPE* o_b_h, | 84 OutputPicture(media::PictureBuffer p_b, OMX_BUFFERHEADERTYPE* o_b_h, |
77 EGLImageKHR e_i) | 85 EGLImageKHR e_i) |
78 : picture_buffer(p_b), omx_buffer_header(o_b_h), egl_image(e_i) {} | 86 : picture_buffer(p_b), omx_buffer_header(o_b_h), egl_image(e_i) {} |
79 media::PictureBuffer picture_buffer; | 87 media::PictureBuffer picture_buffer; |
80 OMX_BUFFERHEADERTYPE* omx_buffer_header; | 88 OMX_BUFFERHEADERTYPE* omx_buffer_header; |
81 EGLImageKHR egl_image; | 89 EGLImageKHR egl_image; |
82 }; | 90 }; |
(...skipping 106 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
189 // before NotifyResetDone is sent. | 197 // before NotifyResetDone is sent. |
190 std::vector<int> queued_picture_buffer_ids_; | 198 std::vector<int> queued_picture_buffer_ids_; |
191 | 199 |
192 // To expose client callbacks from VideoDecodeAccelerator. | 200 // To expose client callbacks from VideoDecodeAccelerator. |
193 // NOTE: all calls to this object *MUST* be executed in message_loop_. | 201 // NOTE: all calls to this object *MUST* be executed in message_loop_. |
194 Client* client_; | 202 Client* client_; |
195 | 203 |
196 scoped_ptr<Gles2TextureToEglImageTranslator> texture_to_egl_image_translator_; | 204 scoped_ptr<Gles2TextureToEglImageTranslator> texture_to_egl_image_translator_; |
197 | 205 |
198 // These members are only used during Initialization. | 206 // These members are only used during Initialization. |
199 // OMX_AVCProfile requested during Initialization. | 207 Codec codec_; |
200 uint32 profile_; | 208 uint32 h264_profile_; // OMX_AVCProfile requested during Initialization. |
201 bool component_name_is_nvidia_h264ext_; | 209 bool component_name_is_nvidia_h264ext_; |
202 | 210 |
203 // Method to handle events | 211 // Method to handle events |
204 void EventHandlerCompleteTask(OMX_EVENTTYPE event, | 212 void EventHandlerCompleteTask(OMX_EVENTTYPE event, |
205 OMX_U32 data1, | 213 OMX_U32 data1, |
206 OMX_U32 data2); | 214 OMX_U32 data2); |
207 | 215 |
208 // Method to receive buffers from component's input port | 216 // Method to receive buffers from component's input port |
209 void EmptyBufferDoneTask(OMX_BUFFERHEADERTYPE* buffer); | 217 void EmptyBufferDoneTask(OMX_BUFFERHEADERTYPE* buffer); |
210 | 218 |
(...skipping 14 matching lines...) Expand all Loading... |
225 OMX_PTR event_data); | 233 OMX_PTR event_data); |
226 static OMX_ERRORTYPE EmptyBufferCallback(OMX_HANDLETYPE component, | 234 static OMX_ERRORTYPE EmptyBufferCallback(OMX_HANDLETYPE component, |
227 OMX_PTR priv_data, | 235 OMX_PTR priv_data, |
228 OMX_BUFFERHEADERTYPE* buffer); | 236 OMX_BUFFERHEADERTYPE* buffer); |
229 static OMX_ERRORTYPE FillBufferCallback(OMX_HANDLETYPE component, | 237 static OMX_ERRORTYPE FillBufferCallback(OMX_HANDLETYPE component, |
230 OMX_PTR priv_data, | 238 OMX_PTR priv_data, |
231 OMX_BUFFERHEADERTYPE* buffer); | 239 OMX_BUFFERHEADERTYPE* buffer); |
232 }; | 240 }; |
233 | 241 |
234 #endif // CONTENT_COMMON_GPU_MEDIA_OMX_VIDEO_DECODE_ACCELERATOR_H_ | 242 #endif // CONTENT_COMMON_GPU_MEDIA_OMX_VIDEO_DECODE_ACCELERATOR_H_ |
OLD | NEW |