OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 <drm_fourcc.h> | |
dnicoara
2015/08/27 13:21:56
empty line between C and C++ includes
kalyank
2015/08/27 16:07:10
Done.
| |
5 #include <vector> | 6 #include <vector> |
6 | 7 |
7 #include "base/memory/scoped_ptr.h" | 8 #include "base/memory/scoped_ptr.h" |
8 #include "testing/gtest/include/gtest/gtest.h" | 9 #include "testing/gtest/include/gtest/gtest.h" |
9 #include "ui/ozone/platform/drm/gpu/crtc_controller.h" | 10 #include "ui/ozone/platform/drm/gpu/crtc_controller.h" |
10 #include "ui/ozone/platform/drm/gpu/hardware_display_controller.h" | 11 #include "ui/ozone/platform/drm/gpu/hardware_display_controller.h" |
11 #include "ui/ozone/platform/drm/gpu/hardware_display_plane.h" | 12 #include "ui/ozone/platform/drm/gpu/hardware_display_plane.h" |
12 #include "ui/ozone/platform/drm/gpu/hardware_display_plane_manager.h" | 13 #include "ui/ozone/platform/drm/gpu/hardware_display_plane_manager.h" |
13 #include "ui/ozone/platform/drm/gpu/hardware_display_plane_manager_legacy.h" | 14 #include "ui/ozone/platform/drm/gpu/hardware_display_plane_manager_legacy.h" |
14 #include "ui/ozone/platform/drm/gpu/overlay_plane.h" | 15 #include "ui/ozone/platform/drm/gpu/overlay_plane.h" |
15 #include "ui/ozone/platform/drm/gpu/scanout_buffer.h" | 16 #include "ui/ozone/platform/drm/gpu/scanout_buffer.h" |
16 #include "ui/ozone/platform/drm/test/mock_drm_device.h" | 17 #include "ui/ozone/platform/drm/test/mock_drm_device.h" |
17 | 18 |
18 namespace { | 19 namespace { |
19 | 20 |
20 struct FakePlaneInfo { | 21 struct FakePlaneInfo { |
21 uint32_t id; | 22 uint32_t id; |
22 uint32_t allowed_crtc_mask; | 23 uint32_t allowed_crtc_mask; |
23 }; | 24 }; |
24 | 25 |
25 const FakePlaneInfo kOnePlanePerCrtc[] = {{10, 1}, {20, 2}}; | 26 const FakePlaneInfo kOnePlanePerCrtc[] = {{10, 1}, {20, 2}}; |
26 const FakePlaneInfo kTwoPlanesPerCrtc[] = {{10, 1}, {11, 1}, {20, 2}, {21, 2}}; | 27 const FakePlaneInfo kTwoPlanesPerCrtc[] = {{10, 1}, {11, 1}, {20, 2}, {21, 2}}; |
27 const FakePlaneInfo kOnePlanePerCrtcWithShared[] = {{10, 1}, {20, 2}, {50, 3}}; | 28 const FakePlaneInfo kOnePlanePerCrtcWithShared[] = {{10, 1}, {20, 2}, {50, 3}}; |
29 const uint32_t kDummyFormat = 0; | |
28 | 30 |
29 class FakeScanoutBuffer : public ui::ScanoutBuffer { | 31 class FakeScanoutBuffer : public ui::ScanoutBuffer { |
30 public: | 32 public: |
31 FakeScanoutBuffer() {} | 33 FakeScanoutBuffer(uint32_t format) : format_(format) {} |
32 | 34 |
33 // ui::ScanoutBuffer: | 35 // ui::ScanoutBuffer: |
34 uint32_t GetFramebufferId() const override { return 1; } | 36 uint32_t GetFramebufferId() const override { return 1; } |
35 uint32_t GetHandle() const override { return 0; } | 37 uint32_t GetHandle() const override { return 0; } |
36 gfx::Size GetSize() const override { return gfx::Size(1, 1); } | 38 gfx::Size GetSize() const override { return gfx::Size(1, 1); } |
37 uint32_t GetFormat() const override { return 0; } | 39 void SetFramebufferPixelFormat(uint32_t format) { format_ = format; } |
40 uint32_t GetFramebufferPixelFormat() const override { return format_; } | |
38 | 41 |
39 protected: | 42 protected: |
40 ~FakeScanoutBuffer() override {} | 43 ~FakeScanoutBuffer() override {} |
44 uint32_t format_; | |
41 }; | 45 }; |
42 | 46 |
43 class FakePlaneManager : public ui::HardwareDisplayPlaneManager { | 47 class FakePlaneManager : public ui::HardwareDisplayPlaneManager { |
44 public: | 48 public: |
45 FakePlaneManager() : plane_count_(0) {} | 49 FakePlaneManager() : plane_count_(0) {} |
46 ~FakePlaneManager() override {} | 50 ~FakePlaneManager() override {} |
47 | 51 |
48 // Normally we'd use DRM to figure out the controller configuration. But we | 52 // Normally we'd use DRM to figure out the controller configuration. But we |
49 // can't use DRM in unit tests, so we just create a fake configuration. | 53 // can't use DRM in unit tests, so we just create a fake configuration. |
50 void InitForTest(const FakePlaneInfo* planes, | 54 void InitForTest(const FakePlaneInfo* planes, |
51 size_t count, | 55 size_t count, |
52 const std::vector<uint32_t>& crtcs) { | 56 const std::vector<uint32_t>& crtcs) { |
53 crtcs_ = crtcs; | 57 crtcs_ = crtcs; |
54 for (size_t i = 0; i < count; i++) { | 58 for (size_t i = 0; i < count; i++) { |
55 planes_.push_back(new ui::HardwareDisplayPlane( | 59 scoped_ptr<ui::HardwareDisplayPlane> plane(new ui::HardwareDisplayPlane( |
56 planes[i].id, planes[i].allowed_crtc_mask)); | 60 planes[i].id, planes[i].allowed_crtc_mask)); |
61 // Add support to test more formats. | |
62 plane->Initialize(drm_, std::vector<uint32_t>(1, DRM_FORMAT_XRGB8888), | |
63 false, true); | |
64 planes_.push_back(plane.Pass()); | |
57 } | 65 } |
58 // The real HDPM uses sorted planes, so sort them for consistency. | 66 // The real HDPM uses sorted planes, so sort them for consistency. |
59 std::sort(planes_.begin(), planes_.end(), | 67 std::sort(planes_.begin(), planes_.end(), |
60 [](ui::HardwareDisplayPlane* l, ui::HardwareDisplayPlane* r) { | 68 [](ui::HardwareDisplayPlane* l, ui::HardwareDisplayPlane* r) { |
61 return l->plane_id() < r->plane_id(); | 69 return l->plane_id() < r->plane_id(); |
62 }); | 70 }); |
63 } | 71 } |
64 | 72 |
65 bool Commit(ui::HardwareDisplayPlaneList* plane_list, | 73 bool Commit(ui::HardwareDisplayPlaneList* plane_list, |
66 bool is_sync, | 74 bool is_sync, |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
100 scoped_ptr<FakePlaneManager> plane_manager_; | 108 scoped_ptr<FakePlaneManager> plane_manager_; |
101 ui::HardwareDisplayPlaneList state_; | 109 ui::HardwareDisplayPlaneList state_; |
102 std::vector<uint32_t> default_crtcs_; | 110 std::vector<uint32_t> default_crtcs_; |
103 scoped_refptr<ui::ScanoutBuffer> fake_buffer_; | 111 scoped_refptr<ui::ScanoutBuffer> fake_buffer_; |
104 | 112 |
105 private: | 113 private: |
106 DISALLOW_COPY_AND_ASSIGN(HardwareDisplayPlaneManagerTest); | 114 DISALLOW_COPY_AND_ASSIGN(HardwareDisplayPlaneManagerTest); |
107 }; | 115 }; |
108 | 116 |
109 void HardwareDisplayPlaneManagerTest::SetUp() { | 117 void HardwareDisplayPlaneManagerTest::SetUp() { |
110 fake_buffer_ = new FakeScanoutBuffer(); | 118 fake_buffer_ = new FakeScanoutBuffer(DRM_FORMAT_XRGB8888); |
111 plane_manager_.reset(new FakePlaneManager()); | 119 plane_manager_.reset(new FakePlaneManager()); |
112 default_crtcs_.push_back(100); | 120 default_crtcs_.push_back(100); |
113 default_crtcs_.push_back(200); | 121 default_crtcs_.push_back(200); |
114 } | 122 } |
115 | 123 |
116 TEST_F(HardwareDisplayPlaneManagerTest, SinglePlaneAssignment) { | 124 TEST_F(HardwareDisplayPlaneManagerTest, SinglePlaneAssignment) { |
117 ui::OverlayPlaneList assigns; | 125 ui::OverlayPlaneList assigns; |
118 assigns.push_back(ui::OverlayPlane(fake_buffer_)); | 126 assigns.push_back(ui::OverlayPlane(fake_buffer_)); |
119 plane_manager_->InitForTest(kOnePlanePerCrtc, arraysize(kOnePlanePerCrtc), | 127 plane_manager_->InitForTest(kOnePlanePerCrtc, arraysize(kOnePlanePerCrtc), |
120 default_crtcs_); | 128 default_crtcs_); |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
225 default_crtcs_); | 233 default_crtcs_); |
226 | 234 |
227 EXPECT_TRUE(plane_manager_->AssignOverlayPlanes(&state_, assigns, | 235 EXPECT_TRUE(plane_manager_->AssignOverlayPlanes(&state_, assigns, |
228 default_crtcs_[1], nullptr)); | 236 default_crtcs_[1], nullptr)); |
229 EXPECT_EQ(2, plane_manager_->plane_count()); | 237 EXPECT_EQ(2, plane_manager_->plane_count()); |
230 // The shared plane is now unavailable for use by the other CRTC. | 238 // The shared plane is now unavailable for use by the other CRTC. |
231 EXPECT_FALSE(plane_manager_->AssignOverlayPlanes(&state_, assigns, | 239 EXPECT_FALSE(plane_manager_->AssignOverlayPlanes(&state_, assigns, |
232 default_crtcs_[0], nullptr)); | 240 default_crtcs_[0], nullptr)); |
233 } | 241 } |
234 | 242 |
243 TEST_F(HardwareDisplayPlaneManagerTest, CheckFramebufferFormatMatch) { | |
244 ui::OverlayPlaneList assigns; | |
245 scoped_refptr<FakeScanoutBuffer> buffer = new FakeScanoutBuffer(kDummyFormat); | |
246 assigns.push_back(ui::OverlayPlane(buffer)); | |
247 plane_manager_->InitForTest(kOnePlanePerCrtc, arraysize(kOnePlanePerCrtc), | |
248 default_crtcs_); | |
249 plane_manager_->BeginFrame(&state_); | |
250 // This should return false as plane manager creates planes which support | |
251 // DRM_FORMAT_XRGB8888 while buffer returns kDummyFormat as its pixelFormat. | |
252 EXPECT_FALSE(plane_manager_->AssignOverlayPlanes(&state_, assigns, | |
253 default_crtcs_[0], nullptr)); | |
254 buffer->SetFramebufferPixelFormat(DRM_FORMAT_XRGB8888); | |
255 plane_manager_->BeginFrame(&state_); | |
256 EXPECT_TRUE(plane_manager_->AssignOverlayPlanes(&state_, assigns, | |
257 default_crtcs_[0], nullptr)); | |
258 buffer->SetFramebufferPixelFormat(DRM_FORMAT_ARGB8888); | |
259 plane_manager_->BeginFrame(&state_); | |
260 EXPECT_FALSE(plane_manager_->AssignOverlayPlanes(&state_, assigns, | |
261 default_crtcs_[0], nullptr)); | |
262 } | |
263 | |
235 TEST(HardwareDisplayPlaneManagerLegacyTest, UnusedPlanesAreReleased) { | 264 TEST(HardwareDisplayPlaneManagerLegacyTest, UnusedPlanesAreReleased) { |
236 std::vector<uint32_t> crtcs; | 265 std::vector<uint32_t> crtcs; |
237 crtcs.push_back(100); | 266 crtcs.push_back(100); |
238 scoped_refptr<ui::MockDrmDevice> drm = new ui::MockDrmDevice(false, crtcs, 2); | 267 scoped_refptr<ui::MockDrmDevice> drm = new ui::MockDrmDevice(false, crtcs, 2); |
239 ui::OverlayPlaneList assigns; | 268 ui::OverlayPlaneList assigns; |
240 scoped_refptr<FakeScanoutBuffer> fake_buffer = new FakeScanoutBuffer(); | 269 scoped_refptr<FakeScanoutBuffer> fake_buffer = |
270 new FakeScanoutBuffer(DRM_FORMAT_XRGB8888); | |
241 assigns.push_back(ui::OverlayPlane(fake_buffer)); | 271 assigns.push_back(ui::OverlayPlane(fake_buffer)); |
242 assigns.push_back(ui::OverlayPlane(fake_buffer)); | 272 assigns.push_back(ui::OverlayPlane(fake_buffer)); |
243 ui::HardwareDisplayPlaneList hdpl; | 273 ui::HardwareDisplayPlaneList hdpl; |
244 ui::CrtcController crtc(drm, crtcs[0], 0); | 274 ui::CrtcController crtc(drm, crtcs[0], 0); |
245 drm->plane_manager()->BeginFrame(&hdpl); | 275 drm->plane_manager()->BeginFrame(&hdpl); |
246 EXPECT_TRUE(drm->plane_manager()->AssignOverlayPlanes(&hdpl, assigns, | 276 EXPECT_TRUE(drm->plane_manager()->AssignOverlayPlanes(&hdpl, assigns, |
247 crtcs[0], &crtc)); | 277 crtcs[0], &crtc)); |
248 EXPECT_TRUE(drm->plane_manager()->Commit(&hdpl, false, false)); | 278 EXPECT_TRUE(drm->plane_manager()->Commit(&hdpl, false, false)); |
249 assigns.clear(); | 279 assigns.clear(); |
250 assigns.push_back(ui::OverlayPlane(fake_buffer)); | 280 assigns.push_back(ui::OverlayPlane(fake_buffer)); |
251 drm->plane_manager()->BeginFrame(&hdpl); | 281 drm->plane_manager()->BeginFrame(&hdpl); |
252 EXPECT_TRUE(drm->plane_manager()->AssignOverlayPlanes(&hdpl, assigns, | 282 EXPECT_TRUE(drm->plane_manager()->AssignOverlayPlanes(&hdpl, assigns, |
253 crtcs[0], &crtc)); | 283 crtcs[0], &crtc)); |
254 EXPECT_EQ(0, drm->get_overlay_clear_call_count()); | 284 EXPECT_EQ(0, drm->get_overlay_clear_call_count()); |
255 EXPECT_TRUE(drm->plane_manager()->Commit(&hdpl, false, false)); | 285 EXPECT_TRUE(drm->plane_manager()->Commit(&hdpl, false, false)); |
256 EXPECT_EQ(1, drm->get_overlay_clear_call_count()); | 286 EXPECT_EQ(1, drm->get_overlay_clear_call_count()); |
257 } | 287 } |
258 | 288 |
259 } // namespace | 289 } // namespace |
OLD | NEW |