Index: ui/ozone/platform/drm/host/drm_overlay_candidates_host.cc |
diff --git a/ui/ozone/platform/drm/host/drm_overlay_candidates_host.cc b/ui/ozone/platform/drm/host/drm_overlay_candidates_host.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..61fe49f13f86a3dc892bad64a147778725df8188 |
--- /dev/null |
+++ b/ui/ozone/platform/drm/host/drm_overlay_candidates_host.cc |
@@ -0,0 +1,120 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#include "ui/ozone/platform/drm/host/drm_overlay_candidates_host.h" |
+ |
+#include <algorithm> |
+ |
+#include "ui/gfx/geometry/rect_conversions.h" |
+#include "ui/ozone/common/gpu/ozone_gpu_message_params.h" |
+#include "ui/ozone/platform/drm/host/drm_gpu_platform_support_host.h" |
+ |
+namespace ui { |
+ |
+namespace { |
+const size_t kMaxCacheSize = 100; |
+} // namespace |
+ |
+bool DrmOverlayCandidatesHost::OverlayCompare::operator()( |
+ const OverlayCheck_Params& l, |
+ const OverlayCheck_Params& r) { |
+ if (l.plane_z_order < r.plane_z_order) |
+ return true; |
+ if (l.plane_z_order > r.plane_z_order) |
+ return false; |
+ if (l.display_rect < r.display_rect) |
+ return true; |
+ if (l.display_rect != r.display_rect) |
+ return false; |
+ if (l.format < r.format) |
+ return true; |
+ if (l.format > r.format) |
+ return false; |
+ if (l.transform < r.transform) |
+ return true; |
+ if (l.transform > r.transform) |
+ return false; |
+ if (l.buffer_size.width() < r.buffer_size.width()) |
+ return true; |
+ if (l.buffer_size.width() > r.buffer_size.width()) |
+ return false; |
+ return l.buffer_size.height() < r.buffer_size.height(); |
+} |
+ |
+DrmOverlayCandidatesHost::DrmOverlayCandidatesHost( |
+ gfx::AcceleratedWidget widget, |
+ DrmGpuPlatformSupportHost* platform_support) |
+ : widget_(widget), |
+ platform_support_(platform_support), |
+ cache_(kMaxCacheSize) { |
+} |
+ |
+DrmOverlayCandidatesHost::~DrmOverlayCandidatesHost() { |
+} |
+ |
+void DrmOverlayCandidatesHost::CheckOverlaySupport( |
+ OverlaySurfaceCandidateList* candidates) { |
+ if (candidates->size() == 2) |
+ CheckSingleOverlay(candidates); |
+} |
+ |
+void DrmOverlayCandidatesHost::CheckSingleOverlay( |
+ OverlaySurfaceCandidateList* candidates) { |
+ OverlayCandidatesOzone::OverlaySurfaceCandidate* first = &(*candidates)[0]; |
+ OverlayCandidatesOzone::OverlaySurfaceCandidate* second = &(*candidates)[1]; |
+ OverlayCandidatesOzone::OverlaySurfaceCandidate* overlay; |
+ if (first->plane_z_order == 0) { |
+ overlay = second; |
+ } else if (second->plane_z_order == 0) { |
+ overlay = first; |
+ } else { |
+ return; |
+ } |
+ // 0.01 constant chosen to match DCHECKs in gfx::ToNearestRect and avoid |
+ // that code asserting on quads that we accept. |
+ if (!gfx::IsNearestRectWithinDistance(overlay->display_rect, 0.01f)) |
+ return; |
+ if (overlay->transform == gfx::OVERLAY_TRANSFORM_INVALID) |
+ return; |
+ |
+ OverlayCheck_Params lookup(*overlay); |
+ auto iter = cache_.Get(lookup); |
+ if (iter == cache_.end()) { |
+ cache_.Put(lookup, false); |
+ SendRequest(*candidates, lookup); |
+ } else { |
+ overlay->overlay_handled = iter->second; |
+ } |
+} |
+ |
+void DrmOverlayCandidatesHost::SendRequest( |
+ const OverlaySurfaceCandidateList& candidates, |
+ const OverlayCheck_Params& check) { |
+ if (!platform_support_->IsConnected()) |
+ return; |
+ pending_checks_.push_back(check); |
+ std::vector<OverlayCheck_Params> list; |
+ for (const auto& candidate : candidates) |
+ list.push_back(OverlayCheck_Params(candidate)); |
+ platform_support_->CheckOverlayCapabilities(widget_, list); |
+} |
+ |
+void DrmOverlayCandidatesHost::OnOverlayResult(bool* handled, |
+ gfx::AcceleratedWidget widget, |
+ bool result) { |
+ if (widget != widget_) |
+ return; |
+ *handled = true; |
+ DCHECK(!pending_checks_.empty()); |
+ ProcessResult(pending_checks_.front(), result); |
+ pending_checks_.pop_front(); |
+} |
+ |
+void DrmOverlayCandidatesHost::ProcessResult(const OverlayCheck_Params& check, |
+ bool result) { |
+ if (result) |
+ cache_.Put(check, true); |
+} |
+ |
+} // namespace ui |