blob: b8411895379fcee15eaefe01aeeb4007fc2115b8 [file] [log] [blame]
Sean Paul6a55e9f2015-04-30 15:31:06 -04001/*
2 * Copyright (C) 2015 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#define LOG_TAG "hwc-drm-plane"
18
Roman Stratiienko13cc3662020-08-29 21:35:39 +030019#include "DrmPlane.h"
Sean Paul6a55e9f2015-04-30 15:31:06 -040020
Roman Stratiienko2640cd82021-02-26 17:49:40 +020021#include <algorithm>
Roman Stratiienkoe2f2c922021-02-13 10:57:47 +020022#include <cerrno>
Sean Paulf72cccd2018-08-27 13:59:08 -040023#include <cinttypes>
Roman Stratiienkoe2f2c922021-02-13 10:57:47 +020024#include <cstdint>
Sean Paul6a55e9f2015-04-30 15:31:06 -040025
Roman Stratiienko13cc3662020-08-29 21:35:39 +030026#include "DrmDevice.h"
Roman Stratiienkod518a052021-02-25 19:15:14 +020027#include "bufferinfo/BufferInfoGetter.h"
28#include "utils/log.h"
Sean Paul6a55e9f2015-04-30 15:31:06 -040029
30namespace android {
31
Alexandru Gheorghe0f5abd72018-05-01 14:37:10 +010032DrmPlane::DrmPlane(DrmDevice *drm, drmModePlanePtr p)
Roman Kovalivskyi859b6072020-03-26 05:03:39 +020033 : drm_(drm),
34 id_(p->plane_id),
35 possible_crtc_mask_(p->possible_crtcs),
36 formats_(p->formats, p->formats + p->count_formats) {
Sean Paul6a55e9f2015-04-30 15:31:06 -040037}
38
Sean Paul6a55e9f2015-04-30 15:31:06 -040039int DrmPlane::Init() {
40 DrmProperty p;
41
42 int ret = drm_->GetPlaneProperty(*this, "type", &p);
43 if (ret) {
44 ALOGE("Could not get plane type property");
45 return ret;
46 }
47
Roman Stratiienkob3b5c1e2021-02-15 13:44:19 +020048 uint64_t type = 0;
Sean Paulfc0b1da2019-03-06 09:48:42 -050049 std::tie(ret, type) = p.value();
Sean Paul6a55e9f2015-04-30 15:31:06 -040050 if (ret) {
51 ALOGE("Failed to get plane type property value");
52 return ret;
53 }
54 switch (type) {
55 case DRM_PLANE_TYPE_OVERLAY:
56 case DRM_PLANE_TYPE_PRIMARY:
57 case DRM_PLANE_TYPE_CURSOR:
58 type_ = (uint32_t)type;
59 break;
60 default:
Sean Paulf741c672016-05-11 13:49:38 -040061 ALOGE("Invalid plane type %" PRIu64, type);
Sean Paul6a55e9f2015-04-30 15:31:06 -040062 return -EINVAL;
63 }
64
65 ret = drm_->GetPlaneProperty(*this, "CRTC_ID", &crtc_property_);
66 if (ret) {
67 ALOGE("Could not get CRTC_ID property");
68 return ret;
69 }
70
71 ret = drm_->GetPlaneProperty(*this, "FB_ID", &fb_property_);
72 if (ret) {
73 ALOGE("Could not get FB_ID property");
74 return ret;
75 }
76
77 ret = drm_->GetPlaneProperty(*this, "CRTC_X", &crtc_x_property_);
78 if (ret) {
79 ALOGE("Could not get CRTC_X property");
80 return ret;
81 }
82
83 ret = drm_->GetPlaneProperty(*this, "CRTC_Y", &crtc_y_property_);
84 if (ret) {
85 ALOGE("Could not get CRTC_Y property");
86 return ret;
87 }
88
89 ret = drm_->GetPlaneProperty(*this, "CRTC_W", &crtc_w_property_);
90 if (ret) {
91 ALOGE("Could not get CRTC_W property");
92 return ret;
93 }
94
95 ret = drm_->GetPlaneProperty(*this, "CRTC_H", &crtc_h_property_);
96 if (ret) {
97 ALOGE("Could not get CRTC_H property");
98 return ret;
99 }
100
101 ret = drm_->GetPlaneProperty(*this, "SRC_X", &src_x_property_);
102 if (ret) {
103 ALOGE("Could not get SRC_X property");
104 return ret;
105 }
106
107 ret = drm_->GetPlaneProperty(*this, "SRC_Y", &src_y_property_);
108 if (ret) {
109 ALOGE("Could not get SRC_Y property");
110 return ret;
111 }
112
113 ret = drm_->GetPlaneProperty(*this, "SRC_W", &src_w_property_);
114 if (ret) {
115 ALOGE("Could not get SRC_W property");
116 return ret;
117 }
118
119 ret = drm_->GetPlaneProperty(*this, "SRC_H", &src_h_property_);
120 if (ret) {
121 ALOGE("Could not get SRC_H property");
122 return ret;
123 }
124
Alexandru Gheorgheea1c5e52018-09-17 10:48:54 +0100125 ret = drm_->GetPlaneProperty(*this, "zpos", &zpos_property_);
126 if (ret)
127 ALOGE("Could not get zpos property for plane %u", id());
128
Sean Paul1c4c3262015-07-14 15:51:52 -0400129 ret = drm_->GetPlaneProperty(*this, "rotation", &rotation_property_);
130 if (ret)
131 ALOGE("Could not get rotation property");
132
Sean Pauld8aefb62015-10-15 15:17:31 -0400133 ret = drm_->GetPlaneProperty(*this, "alpha", &alpha_property_);
134 if (ret)
135 ALOGI("Could not get alpha property");
136
Lowry Li9b6cafd2018-08-28 17:58:21 +0800137 ret = drm_->GetPlaneProperty(*this, "pixel blend mode", &blend_property_);
138 if (ret)
139 ALOGI("Could not get pixel blend mode property");
140
Robert Fossa09220c2016-09-30 10:27:23 -0400141 ret = drm_->GetPlaneProperty(*this, "IN_FENCE_FD", &in_fence_fd_property_);
142 if (ret)
143 ALOGI("Could not get IN_FENCE_FD property");
144
Matvii Zorin8338c342020-09-08 16:12:51 +0300145 if (HasNonRgbFormat()) {
146 ret = drm_->GetPlaneProperty(*this, "COLOR_ENCODING",
147 &color_encoding_propery_);
148 if (ret)
149 ALOGI("Could not get COLOR_ENCODING property");
150
151 ret = drm_->GetPlaneProperty(*this, "COLOR_RANGE", &color_range_property_);
152 if (ret)
153 ALOGI("Could not get COLOR_RANGE property");
154 }
155
Sean Paul6a55e9f2015-04-30 15:31:06 -0400156 return 0;
157}
158
159uint32_t DrmPlane::id() const {
160 return id_;
161}
162
163bool DrmPlane::GetCrtcSupported(const DrmCrtc &crtc) const {
Roman Stratiienkoe2f2c922021-02-13 10:57:47 +0200164 return ((1 << crtc.pipe()) & possible_crtc_mask_) != 0;
Sean Paul6a55e9f2015-04-30 15:31:06 -0400165}
166
Matvii Zorin67a89d32021-01-31 14:45:05 +0200167bool DrmPlane::IsValidForLayer(DrmHwcLayer *layer) {
168 if ((rotation_property_.id() == 0) &&
169 layer->transform != DrmHwcTransform::kIdentity) {
170 ALOGV("Rotation is not supported on plane %d", id_);
171 return false;
172 }
173
174 if (alpha_property_.id() == 0 && layer->alpha != 0xffff) {
175 ALOGV("Alpha is not supported on plane %d", id_);
176 return false;
177 }
178
179 if (blend_property_.id() == 0) {
180 if ((layer->blending != DrmHwcBlending::kNone) &&
181 (layer->blending != DrmHwcBlending::kPreMult)) {
182 ALOGV("Blending is not supported on plane %d", id_);
183 return false;
184 }
185 } else {
186 int ret = 0;
187 uint64_t blend = 0;
188
189 switch (layer->blending) {
190 case DrmHwcBlending::kPreMult:
191 std::tie(blend,
192 ret) = blend_property_.GetEnumValueWithName("Pre-multiplied");
193 break;
194 case DrmHwcBlending::kCoverage:
195 std::tie(blend, ret) = blend_property_.GetEnumValueWithName("Coverage");
196 break;
197 case DrmHwcBlending::kNone:
198 default:
199 std::tie(blend, ret) = blend_property_.GetEnumValueWithName("None");
200 break;
201 }
202 if (ret) {
203 ALOGV("Expected a valid blend mode on plane %d", id_);
204 return false;
205 }
206 }
207
208 uint32_t format = layer->buffer->format;
209 if (!IsFormatSupported(format)) {
210 ALOGV("Plane %d does not supports %c%c%c%c format", id_, format,
211 format >> 8, format >> 16, format >> 24);
212 return false;
213 }
214
215 return true;
216}
217
Sean Paul6a55e9f2015-04-30 15:31:06 -0400218uint32_t DrmPlane::type() const {
219 return type_;
220}
221
Roman Kovalivskyi859b6072020-03-26 05:03:39 +0200222bool DrmPlane::IsFormatSupported(uint32_t format) const {
223 return std::find(std::begin(formats_), std::end(formats_), format) !=
224 std::end(formats_);
225}
226
Matvii Zorin8338c342020-09-08 16:12:51 +0300227bool DrmPlane::HasNonRgbFormat() const {
228 return std::find_if_not(std::begin(formats_), std::end(formats_),
229 [](uint32_t format) {
230 return BufferInfoGetter::IsDrmFormatRgb(format);
231 }) != std::end(formats_);
232}
233
Sean Paul6a55e9f2015-04-30 15:31:06 -0400234const DrmProperty &DrmPlane::crtc_property() const {
235 return crtc_property_;
236}
237
238const DrmProperty &DrmPlane::fb_property() const {
239 return fb_property_;
240}
241
242const DrmProperty &DrmPlane::crtc_x_property() const {
243 return crtc_x_property_;
244}
245
246const DrmProperty &DrmPlane::crtc_y_property() const {
247 return crtc_y_property_;
248}
249
250const DrmProperty &DrmPlane::crtc_w_property() const {
251 return crtc_w_property_;
252}
253
254const DrmProperty &DrmPlane::crtc_h_property() const {
255 return crtc_h_property_;
256}
257
258const DrmProperty &DrmPlane::src_x_property() const {
259 return src_x_property_;
260}
261
262const DrmProperty &DrmPlane::src_y_property() const {
263 return src_y_property_;
264}
265
266const DrmProperty &DrmPlane::src_w_property() const {
267 return src_w_property_;
268}
269
270const DrmProperty &DrmPlane::src_h_property() const {
271 return src_h_property_;
272}
Sean Paul1c4c3262015-07-14 15:51:52 -0400273
Alexandru Gheorgheea1c5e52018-09-17 10:48:54 +0100274const DrmProperty &DrmPlane::zpos_property() const {
275 return zpos_property_;
276}
277
Sean Paul1c4c3262015-07-14 15:51:52 -0400278const DrmProperty &DrmPlane::rotation_property() const {
279 return rotation_property_;
280}
Sean Pauld8aefb62015-10-15 15:17:31 -0400281
282const DrmProperty &DrmPlane::alpha_property() const {
283 return alpha_property_;
284}
Robert Fossa09220c2016-09-30 10:27:23 -0400285
Lowry Li9b6cafd2018-08-28 17:58:21 +0800286const DrmProperty &DrmPlane::blend_property() const {
287 return blend_property_;
288}
289
Robert Fossa09220c2016-09-30 10:27:23 -0400290const DrmProperty &DrmPlane::in_fence_fd_property() const {
291 return in_fence_fd_property_;
292}
Matvii Zorin8338c342020-09-08 16:12:51 +0300293
294const DrmProperty &DrmPlane::color_encoding_propery() const {
295 return color_encoding_propery_;
296}
297
298const DrmProperty &DrmPlane::color_range_property() const {
299 return color_range_property_;
300}
Sean Paulf72cccd2018-08-27 13:59:08 -0400301} // namespace android