Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 #include <dlfcn.h> | 5 #include <dlfcn.h> |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "content/common/gpu/media/vaapi_wrapper.h" | 9 #include "content/common/gpu/media/vaapi_wrapper.h" |
| 10 | 10 |
| (...skipping 40 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 51 int num_attribs, | 51 int num_attribs, |
| 52 VAConfigID *config_id); | 52 VAConfigID *config_id); |
| 53 typedef VAStatus (*VaapiCreateContext)(VADisplay dpy, | 53 typedef VAStatus (*VaapiCreateContext)(VADisplay dpy, |
| 54 VAConfigID config_id, | 54 VAConfigID config_id, |
| 55 int picture_width, | 55 int picture_width, |
| 56 int picture_height, | 56 int picture_height, |
| 57 int flag, | 57 int flag, |
| 58 VASurfaceID *render_targets, | 58 VASurfaceID *render_targets, |
| 59 int num_render_targets, | 59 int num_render_targets, |
| 60 VAContextID *context); | 60 VAContextID *context); |
| 61 typedef VAStatus (*VaapiCreateSurfaces)(VADisplay dpy, | 61 // In VAAPI version < 0.34, vaCreateSurface has 6 parameters, but in VAAPI |
| 62 int width, | 62 // version >= 0.34, vaCreateSurface has 8 parameters. |
| 63 int height, | 63 // TODO(chihchung): Remove the old path once ChromeOS updates to 1.2.1. |
|
chihchung
2013/11/21 06:45:19
TODO Added.
| |
| 64 int format, | 64 typedef void *VaapiCreateSurfaces; |
| 65 int num_surfaces, | 65 typedef VAStatus (*VaapiCreateSurfaces6)(VADisplay dpy, |
| 66 VASurfaceID *surfaces); | 66 int width, |
| 67 int height, | |
| 68 int format, | |
| 69 int num_surfaces, | |
| 70 VASurfaceID *surfaces); | |
| 71 typedef VAStatus (*VaapiCreateSurfaces8)(VADisplay dpy, | |
| 72 unsigned int format, | |
| 73 unsigned int width, | |
| 74 unsigned int height, | |
| 75 VASurfaceID *surfaces, | |
| 76 unsigned int num_surfaces, | |
| 77 VASurfaceAttrib *attrib_list, | |
| 78 unsigned int num_attribs); | |
| 67 typedef VAStatus (*VaapiDestroyBuffer)(VADisplay dpy, VABufferID buffer_id); | 79 typedef VAStatus (*VaapiDestroyBuffer)(VADisplay dpy, VABufferID buffer_id); |
| 68 typedef VAStatus (*VaapiDestroyConfig)(VADisplay dpy, VAConfigID config_id); | 80 typedef VAStatus (*VaapiDestroyConfig)(VADisplay dpy, VAConfigID config_id); |
| 69 typedef VAStatus (*VaapiDestroyContext)(VADisplay dpy, VAContextID context); | 81 typedef VAStatus (*VaapiDestroyContext)(VADisplay dpy, VAContextID context); |
| 70 typedef VAStatus (*VaapiDestroySurfaces)(VADisplay dpy, | 82 typedef VAStatus (*VaapiDestroySurfaces)(VADisplay dpy, |
| 71 VASurfaceID *surfaces, | 83 VASurfaceID *surfaces, |
| 72 int num_surfaces); | 84 int num_surfaces); |
| 73 typedef int (*VaapiDisplayIsValid)(VADisplay dpy); | 85 typedef int (*VaapiDisplayIsValid)(VADisplay dpy); |
| 74 typedef VAStatus (*VaapiEndPicture)(VADisplay dpy, VAContextID context); | 86 typedef VAStatus (*VaapiEndPicture)(VADisplay dpy, VAContextID context); |
| 75 typedef const char* (*VaapiErrorStr)(VAStatus error_status); | 87 typedef const char* (*VaapiErrorStr)(VAStatus error_status); |
| 76 typedef VAStatus (*VaapiGetConfigAttributes)(VADisplay dpy, | 88 typedef VAStatus (*VaapiGetConfigAttributes)(VADisplay dpy, |
| (...skipping 123 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 200 DVLOG(1) << "Unsupported profile"; | 212 DVLOG(1) << "Unsupported profile"; |
| 201 return false; | 213 return false; |
| 202 } | 214 } |
| 203 | 215 |
| 204 va_display_ = VAAPI_GetDisplay(x_display); | 216 va_display_ = VAAPI_GetDisplay(x_display); |
| 205 if (!VAAPI_DisplayIsValid(va_display_)) { | 217 if (!VAAPI_DisplayIsValid(va_display_)) { |
| 206 DVLOG(1) << "Could not get a valid VA display"; | 218 DVLOG(1) << "Could not get a valid VA display"; |
| 207 return false; | 219 return false; |
| 208 } | 220 } |
| 209 | 221 |
| 210 int major_version, minor_version; | |
| 211 VAStatus va_res; | 222 VAStatus va_res; |
| 212 va_res = VAAPI_Initialize(va_display_, &major_version, &minor_version); | 223 va_res = VAAPI_Initialize(va_display_, &major_version_, &minor_version_); |
| 213 VA_SUCCESS_OR_RETURN(va_res, "vaInitialize failed", false); | 224 VA_SUCCESS_OR_RETURN(va_res, "vaInitialize failed", false); |
| 214 DVLOG(1) << "VAAPI version: " << major_version << "." << minor_version; | 225 DVLOG(1) << "VAAPI version: " << major_version_ << "." << minor_version_; |
| 215 | 226 |
| 216 VAConfigAttrib attrib = {VAConfigAttribRTFormat, 0}; | 227 VAConfigAttrib attrib = {VAConfigAttribRTFormat, 0}; |
| 217 | 228 |
| 218 const VAEntrypoint kEntrypoint = VAEntrypointVLD; | 229 const VAEntrypoint kEntrypoint = VAEntrypointVLD; |
| 219 va_res = VAAPI_GetConfigAttributes(va_display_, va_profile, kEntrypoint, | 230 va_res = VAAPI_GetConfigAttributes(va_display_, va_profile, kEntrypoint, |
| 220 &attrib, 1); | 231 &attrib, 1); |
| 221 VA_SUCCESS_OR_RETURN(va_res, "vaGetConfigAttributes failed", false); | 232 VA_SUCCESS_OR_RETURN(va_res, "vaGetConfigAttributes failed", false); |
| 222 | 233 |
| 223 if (!(attrib.value & VA_RT_FORMAT_YUV420)) { | 234 if (!(attrib.value & VA_RT_FORMAT_YUV420)) { |
| 224 DVLOG(1) << "YUV420 not supported by this VAAPI implementation"; | 235 DVLOG(1) << "YUV420 not supported by this VAAPI implementation"; |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 242 | 253 |
| 243 if (va_display_) { | 254 if (va_display_) { |
| 244 VAStatus va_res = VAAPI_Terminate(va_display_); | 255 VAStatus va_res = VAAPI_Terminate(va_display_); |
| 245 VA_LOG_ON_ERROR(va_res, "vaTerminate failed"); | 256 VA_LOG_ON_ERROR(va_res, "vaTerminate failed"); |
| 246 } | 257 } |
| 247 | 258 |
| 248 va_config_id_ = VA_INVALID_ID; | 259 va_config_id_ = VA_INVALID_ID; |
| 249 va_display_ = NULL; | 260 va_display_ = NULL; |
| 250 } | 261 } |
| 251 | 262 |
| 263 bool VaapiWrapper::VAAPIVersionLessThan(int major, int minor) { | |
| 264 return (major_version_ < major) || | |
| 265 (major_version_ == major && minor_version_ < minor); | |
| 266 } | |
| 267 | |
| 252 bool VaapiWrapper::CreateSurfaces(gfx::Size size, | 268 bool VaapiWrapper::CreateSurfaces(gfx::Size size, |
| 253 size_t num_surfaces, | 269 size_t num_surfaces, |
| 254 std::vector<VASurfaceID>* va_surfaces) { | 270 std::vector<VASurfaceID>* va_surfaces) { |
| 255 base::AutoLock auto_lock(va_lock_); | 271 base::AutoLock auto_lock(va_lock_); |
| 256 DVLOG(2) << "Creating " << num_surfaces << " surfaces"; | 272 DVLOG(2) << "Creating " << num_surfaces << " surfaces"; |
| 257 | 273 |
| 258 DCHECK(va_surfaces->empty()); | 274 DCHECK(va_surfaces->empty()); |
| 259 DCHECK(va_surface_ids_.empty()); | 275 DCHECK(va_surface_ids_.empty()); |
| 260 va_surface_ids_.resize(num_surfaces); | 276 va_surface_ids_.resize(num_surfaces); |
| 261 | 277 |
| 262 // Allocate surfaces in driver. | 278 // Allocate surfaces in driver. |
| 263 VAStatus va_res = VAAPI_CreateSurfaces(va_display_, | 279 VAStatus va_res; |
| 264 size.width(), size.height(), | 280 if (VAAPIVersionLessThan(0, 34)) { |
| 265 VA_RT_FORMAT_YUV420, | 281 va_res = reinterpret_cast<VaapiCreateSurfaces6>(VAAPI_CreateSurfaces)( |
| 266 va_surface_ids_.size(), | 282 va_display_, |
| 267 &va_surface_ids_[0]); | 283 size.width(), size.height(), |
| 284 VA_RT_FORMAT_YUV420, | |
| 285 va_surface_ids_.size(), | |
| 286 &va_surface_ids_[0]); | |
| 287 } else { | |
| 288 va_res = reinterpret_cast<VaapiCreateSurfaces8>(VAAPI_CreateSurfaces)( | |
| 289 va_display_, | |
| 290 VA_RT_FORMAT_YUV420, | |
| 291 size.width(), size.height(), | |
| 292 &va_surface_ids_[0], | |
| 293 va_surface_ids_.size(), | |
| 294 NULL, 0); | |
| 295 } | |
| 296 | |
| 268 VA_LOG_ON_ERROR(va_res, "vaCreateSurfaces failed"); | 297 VA_LOG_ON_ERROR(va_res, "vaCreateSurfaces failed"); |
| 269 if (va_res != VA_STATUS_SUCCESS) { | 298 if (va_res != VA_STATUS_SUCCESS) { |
| 270 va_surface_ids_.clear(); | 299 va_surface_ids_.clear(); |
| 271 return false; | 300 return false; |
| 272 } | 301 } |
| 273 | 302 |
| 274 // And create a context associated with them. | 303 // And create a context associated with them. |
| 275 va_res = VAAPI_CreateContext(va_display_, va_config_id_, | 304 va_res = VAAPI_CreateContext(va_display_, va_config_id_, |
| 276 size.width(), size.height(), VA_PROGRESSIVE, | 305 size.width(), size.height(), VA_PROGRESSIVE, |
| 277 &va_surface_ids_[0], va_surface_ids_.size(), | 306 &va_surface_ids_[0], va_surface_ids_.size(), |
| (...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 446 VAAPI_DLSYM_OR_RETURN_ON_ERROR(PutSurface, vaapi_x11_handle); | 475 VAAPI_DLSYM_OR_RETURN_ON_ERROR(PutSurface, vaapi_x11_handle); |
| 447 VAAPI_DLSYM_OR_RETURN_ON_ERROR(RenderPicture, vaapi_handle); | 476 VAAPI_DLSYM_OR_RETURN_ON_ERROR(RenderPicture, vaapi_handle); |
| 448 VAAPI_DLSYM_OR_RETURN_ON_ERROR(SyncSurface, vaapi_handle); | 477 VAAPI_DLSYM_OR_RETURN_ON_ERROR(SyncSurface, vaapi_handle); |
| 449 VAAPI_DLSYM_OR_RETURN_ON_ERROR(Terminate, vaapi_handle); | 478 VAAPI_DLSYM_OR_RETURN_ON_ERROR(Terminate, vaapi_handle); |
| 450 #undef VAAPI_DLSYM | 479 #undef VAAPI_DLSYM |
| 451 | 480 |
| 452 return true; | 481 return true; |
| 453 } | 482 } |
| 454 | 483 |
| 455 } // namespace content | 484 } // namespace content |
| OLD | NEW |