| 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 "content/common/gpu/media/vaapi_wrapper.h" | 5 #include "content/common/gpu/media/vaapi_wrapper.h" |
| 6 | 6 |
| 7 #include <dlfcn.h> | 7 #include <dlfcn.h> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/callback_helpers.h" | 10 #include "base/callback_helpers.h" |
| (...skipping 96 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 107 required_attribs.insert( | 107 required_attribs.insert( |
| 108 required_attribs.end(), | 108 required_attribs.end(), |
| 109 kEncodeVAConfigAttribs, | 109 kEncodeVAConfigAttribs, |
| 110 kEncodeVAConfigAttribs + arraysize(kEncodeVAConfigAttribs)); | 110 kEncodeVAConfigAttribs + arraysize(kEncodeVAConfigAttribs)); |
| 111 } | 111 } |
| 112 return required_attribs; | 112 return required_attribs; |
| 113 } | 113 } |
| 114 | 114 |
| 115 VASurface::VASurface(VASurfaceID va_surface_id, | 115 VASurface::VASurface(VASurfaceID va_surface_id, |
| 116 const gfx::Size& size, | 116 const gfx::Size& size, |
| 117 unsigned int format, |
| 117 const ReleaseCB& release_cb) | 118 const ReleaseCB& release_cb) |
| 118 : va_surface_id_(va_surface_id), size_(size), release_cb_(release_cb) { | 119 : va_surface_id_(va_surface_id), |
| 120 size_(size), |
| 121 format_(format), |
| 122 release_cb_(release_cb) { |
| 119 DCHECK(!release_cb_.is_null()); | 123 DCHECK(!release_cb_.is_null()); |
| 120 } | 124 } |
| 121 | 125 |
| 122 VASurface::~VASurface() { | 126 VASurface::~VASurface() { |
| 123 release_cb_.Run(va_surface_id_); | 127 release_cb_.Run(va_surface_id_); |
| 124 } | 128 } |
| 125 | 129 |
| 126 VaapiWrapper::VaapiWrapper() | 130 VaapiWrapper::VaapiWrapper() |
| 127 : va_display_(NULL), | 131 : va_surface_format_(0), |
| 132 va_display_(NULL), |
| 128 va_config_id_(VA_INVALID_ID), | 133 va_config_id_(VA_INVALID_ID), |
| 129 va_context_id_(VA_INVALID_ID), | 134 va_context_id_(VA_INVALID_ID), |
| 130 va_vpp_config_id_(VA_INVALID_ID), | 135 va_vpp_config_id_(VA_INVALID_ID), |
| 131 va_vpp_context_id_(VA_INVALID_ID), | 136 va_vpp_context_id_(VA_INVALID_ID), |
| 132 va_vpp_buffer_id_(VA_INVALID_ID) { | 137 va_vpp_buffer_id_(VA_INVALID_ID) { |
| 133 va_lock_ = va_display_state_.Get().va_lock(); | 138 va_lock_ = va_display_state_.Get().va_lock(); |
| 134 } | 139 } |
| 135 | 140 |
| 136 VaapiWrapper::~VaapiWrapper() { | 141 VaapiWrapper::~VaapiWrapper() { |
| 137 DestroyPendingBuffers(); | 142 DestroyPendingBuffers(); |
| (...skipping 366 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 504 | 509 |
| 505 bool VaapiWrapper::CreateSurfaces(unsigned int va_format, | 510 bool VaapiWrapper::CreateSurfaces(unsigned int va_format, |
| 506 const gfx::Size& size, | 511 const gfx::Size& size, |
| 507 size_t num_surfaces, | 512 size_t num_surfaces, |
| 508 std::vector<VASurfaceID>* va_surfaces) { | 513 std::vector<VASurfaceID>* va_surfaces) { |
| 509 base::AutoLock auto_lock(*va_lock_); | 514 base::AutoLock auto_lock(*va_lock_); |
| 510 DVLOG(2) << "Creating " << num_surfaces << " surfaces"; | 515 DVLOG(2) << "Creating " << num_surfaces << " surfaces"; |
| 511 | 516 |
| 512 DCHECK(va_surfaces->empty()); | 517 DCHECK(va_surfaces->empty()); |
| 513 DCHECK(va_surface_ids_.empty()); | 518 DCHECK(va_surface_ids_.empty()); |
| 519 DCHECK_EQ(va_surface_format_, 0u); |
| 514 va_surface_ids_.resize(num_surfaces); | 520 va_surface_ids_.resize(num_surfaces); |
| 515 | 521 |
| 516 // Allocate surfaces in driver. | 522 // Allocate surfaces in driver. |
| 517 VAStatus va_res = | 523 VAStatus va_res = |
| 518 vaCreateSurfaces(va_display_, va_format, size.width(), size.height(), | 524 vaCreateSurfaces(va_display_, va_format, size.width(), size.height(), |
| 519 &va_surface_ids_[0], va_surface_ids_.size(), NULL, 0); | 525 &va_surface_ids_[0], va_surface_ids_.size(), NULL, 0); |
| 520 | 526 |
| 521 VA_LOG_ON_ERROR(va_res, "vaCreateSurfaces failed"); | 527 VA_LOG_ON_ERROR(va_res, "vaCreateSurfaces failed"); |
| 522 if (va_res != VA_STATUS_SUCCESS) { | 528 if (va_res != VA_STATUS_SUCCESS) { |
| 523 va_surface_ids_.clear(); | 529 va_surface_ids_.clear(); |
| 524 return false; | 530 return false; |
| 525 } | 531 } |
| 526 | 532 |
| 527 // And create a context associated with them. | 533 // And create a context associated with them. |
| 528 va_res = vaCreateContext(va_display_, va_config_id_, | 534 va_res = vaCreateContext(va_display_, va_config_id_, |
| 529 size.width(), size.height(), VA_PROGRESSIVE, | 535 size.width(), size.height(), VA_PROGRESSIVE, |
| 530 &va_surface_ids_[0], va_surface_ids_.size(), | 536 &va_surface_ids_[0], va_surface_ids_.size(), |
| 531 &va_context_id_); | 537 &va_context_id_); |
| 532 | 538 |
| 533 VA_LOG_ON_ERROR(va_res, "vaCreateContext failed"); | 539 VA_LOG_ON_ERROR(va_res, "vaCreateContext failed"); |
| 534 if (va_res != VA_STATUS_SUCCESS) { | 540 if (va_res != VA_STATUS_SUCCESS) { |
| 535 DestroySurfaces(); | 541 DestroySurfaces(); |
| 536 return false; | 542 return false; |
| 537 } | 543 } |
| 538 | 544 |
| 539 *va_surfaces = va_surface_ids_; | 545 *va_surfaces = va_surface_ids_; |
| 546 va_surface_format_ = va_format; |
| 540 return true; | 547 return true; |
| 541 } | 548 } |
| 542 | 549 |
| 543 void VaapiWrapper::DestroySurfaces() { | 550 void VaapiWrapper::DestroySurfaces() { |
| 544 base::AutoLock auto_lock(*va_lock_); | 551 base::AutoLock auto_lock(*va_lock_); |
| 545 DVLOG(2) << "Destroying " << va_surface_ids_.size() << " surfaces"; | 552 DVLOG(2) << "Destroying " << va_surface_ids_.size() << " surfaces"; |
| 546 | 553 |
| 547 if (va_context_id_ != VA_INVALID_ID) { | 554 if (va_context_id_ != VA_INVALID_ID) { |
| 548 VAStatus va_res = vaDestroyContext(va_display_, va_context_id_); | 555 VAStatus va_res = vaDestroyContext(va_display_, va_context_id_); |
| 549 VA_LOG_ON_ERROR(va_res, "vaDestroyContext failed"); | 556 VA_LOG_ON_ERROR(va_res, "vaDestroyContext failed"); |
| 550 } | 557 } |
| 551 | 558 |
| 552 if (!va_surface_ids_.empty()) { | 559 if (!va_surface_ids_.empty()) { |
| 553 VAStatus va_res = vaDestroySurfaces(va_display_, &va_surface_ids_[0], | 560 VAStatus va_res = vaDestroySurfaces(va_display_, &va_surface_ids_[0], |
| 554 va_surface_ids_.size()); | 561 va_surface_ids_.size()); |
| 555 VA_LOG_ON_ERROR(va_res, "vaDestroySurfaces failed"); | 562 VA_LOG_ON_ERROR(va_res, "vaDestroySurfaces failed"); |
| 556 } | 563 } |
| 557 | 564 |
| 558 va_surface_ids_.clear(); | 565 va_surface_ids_.clear(); |
| 559 va_context_id_ = VA_INVALID_ID; | 566 va_context_id_ = VA_INVALID_ID; |
| 567 va_surface_format_ = 0; |
| 560 } | 568 } |
| 561 | 569 |
| 562 scoped_refptr<VASurface> VaapiWrapper::CreateUnownedSurface( | 570 scoped_refptr<VASurface> VaapiWrapper::CreateUnownedSurface( |
| 563 unsigned int va_format, | 571 unsigned int va_format, |
| 564 const gfx::Size& size, | 572 const gfx::Size& size, |
| 565 const std::vector<VASurfaceAttrib>& va_attribs) { | 573 const std::vector<VASurfaceAttrib>& va_attribs) { |
| 566 base::AutoLock auto_lock(*va_lock_); | 574 base::AutoLock auto_lock(*va_lock_); |
| 567 | 575 |
| 568 std::vector<VASurfaceAttrib> attribs(va_attribs); | 576 std::vector<VASurfaceAttrib> attribs(va_attribs); |
| 569 VASurfaceID va_surface_id; | 577 VASurfaceID va_surface_id; |
| 570 VAStatus va_res = | 578 VAStatus va_res = |
| 571 vaCreateSurfaces(va_display_, va_format, size.width(), size.height(), | 579 vaCreateSurfaces(va_display_, va_format, size.width(), size.height(), |
| 572 &va_surface_id, 1, &attribs[0], attribs.size()); | 580 &va_surface_id, 1, &attribs[0], attribs.size()); |
| 573 | 581 |
| 574 scoped_refptr<VASurface> va_surface; | 582 scoped_refptr<VASurface> va_surface; |
| 575 VA_SUCCESS_OR_RETURN(va_res, "Failed to create unowned VASurface", | 583 VA_SUCCESS_OR_RETURN(va_res, "Failed to create unowned VASurface", |
| 576 va_surface); | 584 va_surface); |
| 577 | 585 |
| 578 // This is safe to use Unretained() here, because the VDA takes care | 586 // This is safe to use Unretained() here, because the VDA takes care |
| 579 // of the destruction order. All the surfaces will be destroyed | 587 // of the destruction order. All the surfaces will be destroyed |
| 580 // before VaapiWrapper. | 588 // before VaapiWrapper. |
| 581 va_surface = new VASurface( | 589 va_surface = new VASurface( |
| 582 va_surface_id, size, | 590 va_surface_id, size, va_format, |
| 583 base::Bind(&VaapiWrapper::DestroyUnownedSurface, base::Unretained(this))); | 591 base::Bind(&VaapiWrapper::DestroyUnownedSurface, base::Unretained(this))); |
| 584 | 592 |
| 585 return va_surface; | 593 return va_surface; |
| 586 } | 594 } |
| 587 | 595 |
| 588 void VaapiWrapper::DestroyUnownedSurface(VASurfaceID va_surface_id) { | 596 void VaapiWrapper::DestroyUnownedSurface(VASurfaceID va_surface_id) { |
| 589 base::AutoLock auto_lock(*va_lock_); | 597 base::AutoLock auto_lock(*va_lock_); |
| 590 | 598 |
| 591 VAStatus va_res = vaDestroySurfaces(va_display_, &va_surface_id, 1); | 599 VAStatus va_res = vaDestroySurfaces(va_display_, &va_surface_id, 1); |
| 592 VA_LOG_ON_ERROR(va_res, "vaDestroySurfaces on surface failed"); | 600 VA_LOG_ON_ERROR(va_res, "vaDestroySurfaces on surface failed"); |
| (...skipping 558 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1151 drm_fd_.reset(HANDLE_EINTR(dup(fd))); | 1159 drm_fd_.reset(HANDLE_EINTR(dup(fd))); |
| 1152 } | 1160 } |
| 1153 #endif // USE_OZONE | 1161 #endif // USE_OZONE |
| 1154 | 1162 |
| 1155 bool VaapiWrapper::VADisplayState::VAAPIVersionLessThan(int major, int minor) { | 1163 bool VaapiWrapper::VADisplayState::VAAPIVersionLessThan(int major, int minor) { |
| 1156 return (major_version_ < major) || | 1164 return (major_version_ < major) || |
| 1157 (major_version_ == major && minor_version_ < minor); | 1165 (major_version_ == major && minor_version_ < minor); |
| 1158 } | 1166 } |
| 1159 | 1167 |
| 1160 } // namespace content | 1168 } // namespace content |
| OLD | NEW |