blob: 2251a78e88c0dae144bb4e152ab2549c87eb8ae9 [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
Sean Paul468a7542024-07-16 19:50:58 +000017#define LOG_TAG "drmhwc"
Sean Paul6a55e9f2015-04-30 15:31:06 -040018
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"
Roman Stratiienko4e15bfc2025-01-23 01:55:21 +020028#include "compositor/LayerData.h"
Roman Stratiienkod518a052021-02-25 19:15:14 +020029#include "utils/log.h"
Sean Paul6a55e9f2015-04-30 15:31:06 -040030
31namespace android {
32
Roman Stratiienkob671fab2022-01-29 00:50:22 +020033auto DrmPlane::CreateInstance(DrmDevice &dev, uint32_t plane_id)
34 -> std::unique_ptr<DrmPlane> {
Roman Stratiienko76892782023-01-16 17:15:53 +020035 auto p = MakeDrmModePlaneUnique(*dev.GetFd(), plane_id);
Roman Stratiienkob671fab2022-01-29 00:50:22 +020036 if (!p) {
37 ALOGE("Failed to get plane %d", plane_id);
38 return {};
39 }
40
41 auto plane = std::unique_ptr<DrmPlane>(new DrmPlane(dev, std::move(p)));
42
43 if (plane->Init() != 0) {
44 ALOGE("Failed to init plane %d", plane_id);
45 return {};
46 }
47
48 return plane;
Sean Paul6a55e9f2015-04-30 15:31:06 -040049}
50
Sean Paul6a55e9f2015-04-30 15:31:06 -040051int DrmPlane::Init() {
Roman Stratiienkob671fab2022-01-29 00:50:22 +020052 // NOLINTNEXTLINE(cppcoreguidelines-pro-bounds-pointer-arithmetic)
53 formats_ = {plane_->formats, plane_->formats + plane_->count_formats};
54
Sean Paul6a55e9f2015-04-30 15:31:06 -040055 DrmProperty p;
56
Roman Stratiienko0b063882021-09-30 10:15:05 +030057 if (!GetPlaneProperty("type", p)) {
58 return -ENOTSUP;
Sean Paul6a55e9f2015-04-30 15:31:06 -040059 }
60
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020061 auto type = p.GetValue();
62 if (!type) {
Sean Paul6a55e9f2015-04-30 15:31:06 -040063 ALOGE("Failed to get plane type property value");
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020064 return -EINVAL;
Sean Paul6a55e9f2015-04-30 15:31:06 -040065 }
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020066 switch (*type) {
Sean Paul6a55e9f2015-04-30 15:31:06 -040067 case DRM_PLANE_TYPE_OVERLAY:
68 case DRM_PLANE_TYPE_PRIMARY:
69 case DRM_PLANE_TYPE_CURSOR:
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020070 type_ = (uint32_t)*type;
Sean Paul6a55e9f2015-04-30 15:31:06 -040071 break;
72 default:
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020073 ALOGE("Invalid plane type %" PRIu64, *type);
Sean Paul6a55e9f2015-04-30 15:31:06 -040074 return -EINVAL;
75 }
76
Roman Stratiienko0b063882021-09-30 10:15:05 +030077 if (!GetPlaneProperty("CRTC_ID", crtc_property_) ||
78 !GetPlaneProperty("FB_ID", fb_property_) ||
79 !GetPlaneProperty("CRTC_X", crtc_x_property_) ||
80 !GetPlaneProperty("CRTC_Y", crtc_y_property_) ||
81 !GetPlaneProperty("CRTC_W", crtc_w_property_) ||
82 !GetPlaneProperty("CRTC_H", crtc_h_property_) ||
83 !GetPlaneProperty("SRC_X", src_x_property_) ||
84 !GetPlaneProperty("SRC_Y", src_y_property_) ||
85 !GetPlaneProperty("SRC_W", src_w_property_) ||
86 !GetPlaneProperty("SRC_H", src_h_property_)) {
87 return -ENOTSUP;
Sean Paul6a55e9f2015-04-30 15:31:06 -040088 }
89
Roman Stratiienko0b063882021-09-30 10:15:05 +030090 GetPlaneProperty("zpos", zpos_property_, Presence::kOptional);
Sean Paul6a55e9f2015-04-30 15:31:06 -040091
Roman Stratiienko0b063882021-09-30 10:15:05 +030092 if (GetPlaneProperty("rotation", rotation_property_, Presence::kOptional)) {
Roman Stratiienkoda2fcf62025-01-23 17:47:03 +020093 rotation_property_.GetEnumMask(transform_enum_mask_);
Roman Stratiienko24a4c182021-09-29 12:59:54 +030094 }
Sean Paul1c4c3262015-07-14 15:51:52 -040095
Roman Stratiienko0b063882021-09-30 10:15:05 +030096 GetPlaneProperty("alpha", alpha_property_, Presence::kOptional);
Sean Pauld8aefb62015-10-15 15:17:31 -040097
Roman Stratiienko0b063882021-09-30 10:15:05 +030098 if (GetPlaneProperty("pixel blend mode", blend_property_,
99 Presence::kOptional)) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200100 blend_property_.AddEnumToMap("Pre-multiplied", BufferBlendMode::kPreMult,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300101 blending_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200102 blend_property_.AddEnumToMap("Coverage", BufferBlendMode::kCoverage,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300103 blending_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200104 blend_property_.AddEnumToMap("None", BufferBlendMode::kNone,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300105 blending_enum_map_);
Roman Stratiienko5063d532021-09-29 12:47:31 +0300106 }
Lowry Li9b6cafd2018-08-28 17:58:21 +0800107
Roman Stratiienko0b063882021-09-30 10:15:05 +0300108 GetPlaneProperty("IN_FENCE_FD", in_fence_fd_property_, Presence::kOptional);
Robert Fossa09220c2016-09-30 10:27:23 -0400109
Matvii Zorin8338c342020-09-08 16:12:51 +0300110 if (HasNonRgbFormat()) {
Andrew Wolfersc88294c2024-12-12 14:33:15 +0000111 if (GetPlaneProperty("COLOR_ENCODING", color_encoding_property_,
Roman Stratiienko0b063882021-09-30 10:15:05 +0300112 Presence::kOptional)) {
Andrew Wolfersc88294c2024-12-12 14:33:15 +0000113 color_encoding_property_.AddEnumToMap("ITU-R BT.709 YCbCr",
114 BufferColorSpace::kItuRec709,
115 color_encoding_enum_map_);
116 color_encoding_property_.AddEnumToMap("ITU-R BT.601 YCbCr",
117 BufferColorSpace::kItuRec601,
118 color_encoding_enum_map_);
119 color_encoding_property_.AddEnumToMap("ITU-R BT.2020 YCbCr",
120 BufferColorSpace::kItuRec2020,
121 color_encoding_enum_map_);
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300122 }
Matvii Zorin8338c342020-09-08 16:12:51 +0300123
Roman Stratiienko0b063882021-09-30 10:15:05 +0300124 if (GetPlaneProperty("COLOR_RANGE", color_range_property_,
125 Presence::kOptional)) {
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300126 color_range_property_.AddEnumToMap("YCbCr full range",
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200127 BufferSampleRange::kFullRange,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300128 color_range_enum_map_);
129 color_range_property_.AddEnumToMap("YCbCr limited range",
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200130 BufferSampleRange::kLimitedRange,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300131 color_range_enum_map_);
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300132 }
Matvii Zorin8338c342020-09-08 16:12:51 +0300133 }
134
Andrew Wolfersbf7d29a2024-12-12 17:43:46 +0000135 if (type_ == DRM_PLANE_TYPE_CURSOR &&
136 GetPlaneProperty("SIZE_HINTS", size_hints_property_,
137 Presence::kOptional)) {
138 size_hints_property_.GetBlobData(size_hints_);
139 }
140
Sean Paul6a55e9f2015-04-30 15:31:06 -0400141 return 0;
142}
143
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200144bool DrmPlane::IsCrtcSupported(const DrmCrtc &crtc) const {
Roman Stratiienkoabd8e532022-12-06 23:31:33 +0200145 auto crtc_prop_optval = crtc_property_.GetValue();
146 auto crtc_prop_val = crtc_prop_optval ? *crtc_prop_optval : 0;
147
148 if (crtc_prop_val != 0 && crtc_prop_val != crtc.GetId() &&
Yongqin Liu7ee6a9e2021-12-11 20:39:05 +0800149 GetType() == DRM_PLANE_TYPE_PRIMARY) {
150 // Some DRM driver such as omap_drm allows sharing primary plane between
Sean Paul634c89c2024-10-24 19:17:29 +0000151 // CRTCs, but the primary plane could not be shared if it has been used by
Yongqin Liu7ee6a9e2021-12-11 20:39:05 +0800152 // any CRTC already, which is protected by the plane_switching_crtc function
153 // in the kernel drivers/gpu/drm/drm_atomic.c file.
154 // The current drm_hwc design is not ready to support such scenario yet,
Andrew Wolfersc88294c2024-12-12 14:33:15 +0000155 // so adding the CRTC status check here to workaround for now.
Yongqin Liu7ee6a9e2021-12-11 20:39:05 +0800156 return false;
157 }
158
Roman Stratiienko10be8752022-01-30 20:28:46 +0200159 return ((1 << crtc.GetIndexInResArray()) & plane_->possible_crtcs) != 0;
Sean Paul6a55e9f2015-04-30 15:31:06 -0400160}
161
Roman Stratiienkoda2fcf62025-01-23 17:47:03 +0200162static uint64_t ToDrmRotation(LayerTransform transform) {
163 /* DRM/KMS uses counter-clockwise rotations, while HWC API uses
164 * clockwise. That's why 90 and 270 are swapped here.
165 */
166 uint64_t rotation = DRM_MODE_ROTATE_0;
167
168 if (transform.rotate90) {
169 rotation |= DRM_MODE_ROTATE_270;
170 }
171
172 if (transform.hflip) {
173 rotation |= DRM_MODE_REFLECT_X;
174 }
175
176 if (transform.vflip) {
177 rotation |= DRM_MODE_REFLECT_Y;
178 }
179
180 // TODO(nobody): Respect transform_enum_mask_ to find alternative rotation
181 // values
182
183 return rotation;
184}
185
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200186bool DrmPlane::IsValidForLayer(LayerData *layer) {
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300187 if (layer == nullptr || !layer->bi) {
188 ALOGE("%s: Invalid parameters", __func__);
189 return false;
190 }
191
Roman Stratiienkoda2fcf62025-01-23 17:47:03 +0200192 uint64_t drm_rotation = ToDrmRotation(layer->pi.transform);
193 if ((drm_rotation & transform_enum_mask_) != drm_rotation) {
194 ALOGV("Transform is not supported on plane %d", GetId());
195 return false;
Matvii Zorin67a89d32021-01-31 14:45:05 +0200196 }
197
Andrew Wolfersfdd43712025-02-11 21:18:22 +0000198 if (!alpha_property_ && layer->pi.alpha != kAlphaOpaque) {
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200199 ALOGV("Alpha is not supported on plane %d", GetId());
Matvii Zorin67a89d32021-01-31 14:45:05 +0200200 return false;
201 }
202
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200203 if (blending_enum_map_.count(layer->bi->blend_mode) == 0 &&
204 layer->bi->blend_mode != BufferBlendMode::kNone &&
205 layer->bi->blend_mode != BufferBlendMode::kPreMult) {
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200206 ALOGV("Blending is not supported on plane %d", GetId());
Roman Stratiienko5063d532021-09-29 12:47:31 +0300207 return false;
Matvii Zorin67a89d32021-01-31 14:45:05 +0200208 }
209
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300210 auto format = layer->bi->format;
Matvii Zorin67a89d32021-01-31 14:45:05 +0200211 if (!IsFormatSupported(format)) {
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200212 ALOGV("Plane %d does not supports %c%c%c%c format", GetId(), format,
Matvii Zorin67a89d32021-01-31 14:45:05 +0200213 format >> 8, format >> 16, format >> 24);
214 return false;
215 }
216
Andrew Wolfers45cb3e82025-02-26 20:17:53 +0000217 if (type_ == DRM_PLANE_TYPE_CURSOR &&
218 !IsBufferValidForCursorPlane(layer->bi.value())) {
219 ALOGV("Buffer size %dx%d is not supported by cursor plane %d",
220 layer->bi->width, layer->bi->height, GetId());
221 return false;
222 }
223
Matvii Zorin67a89d32021-01-31 14:45:05 +0200224 return true;
225}
226
Roman Kovalivskyi859b6072020-03-26 05:03:39 +0200227bool DrmPlane::IsFormatSupported(uint32_t format) const {
228 return std::find(std::begin(formats_), std::end(formats_), format) !=
229 std::end(formats_);
230}
231
Matvii Zorin8338c342020-09-08 16:12:51 +0300232bool DrmPlane::HasNonRgbFormat() const {
233 return std::find_if_not(std::begin(formats_), std::end(formats_),
234 [](uint32_t format) {
235 return BufferInfoGetter::IsDrmFormatRgb(format);
236 }) != std::end(formats_);
237}
238
Roman Stratiienko57b9ba32021-12-30 19:20:53 +0200239/* Convert float to 16.16 fixed point */
240static int To1616FixPt(float in) {
241 constexpr int kBitShift = 16;
242 return int(in * (1 << kBitShift));
243}
244
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200245auto DrmPlane::AtomicSetState(drmModeAtomicReq &pset, LayerData &layer,
Roman Stratiienko4e15bfc2025-01-23 01:55:21 +0200246 uint32_t zpos, uint32_t crtc_id,
247 DstRectInfo &whole_display_rect) -> int {
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300248 if (!layer.fb || !layer.bi) {
249 ALOGE("%s: Invalid arguments", __func__);
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300250 return -EINVAL;
251 }
252
Roman Stratiienkoabd8e532022-12-06 23:31:33 +0200253 if (zpos_property_ && !zpos_property_.IsImmutable()) {
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300254 uint64_t min_zpos = 0;
255
256 // Ignore ret and use min_zpos as 0 by default
Roman Stratiienkoabd8e532022-12-06 23:31:33 +0200257 std::tie(std::ignore, min_zpos) = zpos_property_.RangeMin();
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300258
259 if (!zpos_property_.AtomicSet(pset, zpos + min_zpos)) {
260 return -EINVAL;
261 }
262 }
263
Roman Stratiienko6662f712021-09-29 12:52:22 +0300264 if (layer.acquire_fence &&
Roman Stratiienko76892782023-01-16 17:15:53 +0200265 !in_fence_fd_property_.AtomicSet(pset, *layer.acquire_fence)) {
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300266 return -EINVAL;
267 }
268
Roman Stratiienko4e15bfc2025-01-23 01:55:21 +0200269 auto opt_disp = layer.pi.display_frame.i_rect;
270 if (!layer.pi.display_frame.i_rect) {
271 opt_disp = whole_display_rect.i_rect;
272 }
273
274 auto opt_src = layer.pi.source_crop.f_rect;
275 if (!layer.pi.source_crop.f_rect) {
276 opt_src = {0.0F, 0.0F, float(layer.bi->width), float(layer.bi->height)};
277 }
278
279 if (!opt_disp || !opt_src) {
280 ALOGE("%s: Invalid display frame or source crop", __func__);
281 return -EINVAL;
282 }
283
284 auto disp = opt_disp.value();
285 auto src = opt_src.value();
286
Andrew Wolferse5ca88b2024-12-03 16:31:05 +0000287 if (type_ == DRM_PLANE_TYPE_CURSOR) {
288 disp.right = disp.left + static_cast<int>(layer.bi->width);
289 disp.bottom = disp.top + static_cast<int>(layer.bi->height);
290 src = {0, 0, static_cast<float>(layer.bi->width),
291 static_cast<float>(layer.bi->height)};
292 }
293
Roman Stratiienko6662f712021-09-29 12:52:22 +0300294 if (!crtc_property_.AtomicSet(pset, crtc_id) ||
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200295 !fb_property_.AtomicSet(pset, layer.fb->GetFbId()) ||
296 !crtc_x_property_.AtomicSet(pset, disp.left) ||
297 !crtc_y_property_.AtomicSet(pset, disp.top) ||
298 !crtc_w_property_.AtomicSet(pset, disp.right - disp.left) ||
299 !crtc_h_property_.AtomicSet(pset, disp.bottom - disp.top) ||
300 !src_x_property_.AtomicSet(pset, To1616FixPt(src.left)) ||
301 !src_y_property_.AtomicSet(pset, To1616FixPt(src.top)) ||
302 !src_w_property_.AtomicSet(pset, To1616FixPt(src.right - src.left)) ||
303 !src_h_property_.AtomicSet(pset, To1616FixPt(src.bottom - src.top))) {
Roman Stratiienko6662f712021-09-29 12:52:22 +0300304 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300305 }
306
Roman Stratiienko6662f712021-09-29 12:52:22 +0300307 if (rotation_property_ &&
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200308 !rotation_property_.AtomicSet(pset, ToDrmRotation(layer.pi.transform))) {
Roman Stratiienko6662f712021-09-29 12:52:22 +0300309 return -EINVAL;
310 }
311
Roman Stratiienkofb9fed52025-01-23 02:25:12 +0200312 if (alpha_property_ &&
313 !alpha_property_.AtomicSet(pset,
314 std::lround(layer.pi.alpha * UINT16_MAX))) {
Roman Stratiienko6662f712021-09-29 12:52:22 +0300315 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300316 }
317
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200318 if (blending_enum_map_.count(layer.bi->blend_mode) != 0 &&
319 !blend_property_.AtomicSet(pset,
320 blending_enum_map_[layer.bi->blend_mode])) {
Roman Stratiienko5063d532021-09-29 12:47:31 +0300321 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300322 }
323
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200324 if (color_encoding_enum_map_.count(layer.bi->color_space) != 0 &&
Andrew Wolfersc88294c2024-12-12 14:33:15 +0000325 !color_encoding_property_
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200326 .AtomicSet(pset, color_encoding_enum_map_[layer.bi->color_space])) {
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300327 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300328 }
329
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200330 if (color_range_enum_map_.count(layer.bi->sample_range) != 0 &&
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300331 !color_range_property_
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200332 .AtomicSet(pset, color_range_enum_map_[layer.bi->sample_range])) {
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300333 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300334 }
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300335
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300336 return 0;
Sean Paul6a55e9f2015-04-30 15:31:06 -0400337}
338
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300339auto DrmPlane::AtomicDisablePlane(drmModeAtomicReq &pset) -> int {
340 if (!crtc_property_.AtomicSet(pset, 0) || !fb_property_.AtomicSet(pset, 0)) {
341 return -EINVAL;
342 }
Sean Paul6a55e9f2015-04-30 15:31:06 -0400343
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300344 return 0;
Sean Paul6a55e9f2015-04-30 15:31:06 -0400345}
Sean Paul1c4c3262015-07-14 15:51:52 -0400346
Roman Stratiienko0b063882021-09-30 10:15:05 +0300347auto DrmPlane::GetPlaneProperty(const char *prop_name, DrmProperty &property,
348 Presence presence) -> bool {
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300349 auto err = drm_->GetProperty(GetId(), DRM_MODE_OBJECT_PLANE, prop_name,
350 &property);
Roman Stratiienko0b063882021-09-30 10:15:05 +0300351 if (err != 0) {
352 if (presence == Presence::kMandatory) {
353 ALOGE("Could not get mandatory property \"%s\" from plane %d", prop_name,
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200354 GetId());
Roman Stratiienko0b063882021-09-30 10:15:05 +0300355 } else {
356 ALOGV("Could not get optional property \"%s\" from plane %d", prop_name,
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200357 GetId());
Roman Stratiienko0b063882021-09-30 10:15:05 +0300358 }
359 return false;
360 }
361
362 return true;
363}
364
Andrew Wolfers45cb3e82025-02-26 20:17:53 +0000365bool DrmPlane::HasCursorSizeConstraints() const {
366 return drm_->GetCapCursorSize().has_value() || !size_hints_.empty();
367}
368
369bool DrmPlane::IsBufferValidForCursorPlane(const BufferInfo &bi) const {
370 if (std::find_if(size_hints_.begin(), size_hints_.end(),
371 [&](const auto &hint) -> bool {
372 return bi.width == hint.width && bi.height == hint.height;
373 }) != size_hints_.end()) {
374 return true;
375 }
376
377 const auto &cap_size = drm_->GetCapCursorSize();
378 return cap_size.has_value() && bi.width == cap_size->first &&
379 bi.height == cap_size->second;
380}
381
Sean Paulf72cccd2018-08-27 13:59:08 -0400382} // namespace android