blob: 228e3ddd954e30fa45dbd0d491872d44d4885102 [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
Roman Stratiienkob671fab2022-01-29 00:50:22 +020032auto DrmPlane::CreateInstance(DrmDevice &dev, uint32_t plane_id)
33 -> std::unique_ptr<DrmPlane> {
Roman Stratiienko76892782023-01-16 17:15:53 +020034 auto p = MakeDrmModePlaneUnique(*dev.GetFd(), plane_id);
Roman Stratiienkob671fab2022-01-29 00:50:22 +020035 if (!p) {
36 ALOGE("Failed to get plane %d", plane_id);
37 return {};
38 }
39
40 auto plane = std::unique_ptr<DrmPlane>(new DrmPlane(dev, std::move(p)));
41
42 if (plane->Init() != 0) {
43 ALOGE("Failed to init plane %d", plane_id);
44 return {};
45 }
46
47 return plane;
Sean Paul6a55e9f2015-04-30 15:31:06 -040048}
49
Sean Paul6a55e9f2015-04-30 15:31:06 -040050int DrmPlane::Init() {
Roman Stratiienkob671fab2022-01-29 00:50:22 +020051 // NOLINTNEXTLINE(cppcoreguidelines-pro-bounds-pointer-arithmetic)
52 formats_ = {plane_->formats, plane_->formats + plane_->count_formats};
53
Sean Paul6a55e9f2015-04-30 15:31:06 -040054 DrmProperty p;
55
Roman Stratiienko0b063882021-09-30 10:15:05 +030056 if (!GetPlaneProperty("type", p)) {
57 return -ENOTSUP;
Sean Paul6a55e9f2015-04-30 15:31:06 -040058 }
59
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020060 auto type = p.GetValue();
61 if (!type) {
Sean Paul6a55e9f2015-04-30 15:31:06 -040062 ALOGE("Failed to get plane type property value");
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020063 return -EINVAL;
Sean Paul6a55e9f2015-04-30 15:31:06 -040064 }
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020065 switch (*type) {
Sean Paul6a55e9f2015-04-30 15:31:06 -040066 case DRM_PLANE_TYPE_OVERLAY:
67 case DRM_PLANE_TYPE_PRIMARY:
68 case DRM_PLANE_TYPE_CURSOR:
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020069 type_ = (uint32_t)*type;
Sean Paul6a55e9f2015-04-30 15:31:06 -040070 break;
71 default:
Roman Stratiienkoabd8e532022-12-06 23:31:33 +020072 ALOGE("Invalid plane type %" PRIu64, *type);
Sean Paul6a55e9f2015-04-30 15:31:06 -040073 return -EINVAL;
74 }
75
Roman Stratiienko0b063882021-09-30 10:15:05 +030076 if (!GetPlaneProperty("CRTC_ID", crtc_property_) ||
77 !GetPlaneProperty("FB_ID", fb_property_) ||
78 !GetPlaneProperty("CRTC_X", crtc_x_property_) ||
79 !GetPlaneProperty("CRTC_Y", crtc_y_property_) ||
80 !GetPlaneProperty("CRTC_W", crtc_w_property_) ||
81 !GetPlaneProperty("CRTC_H", crtc_h_property_) ||
82 !GetPlaneProperty("SRC_X", src_x_property_) ||
83 !GetPlaneProperty("SRC_Y", src_y_property_) ||
84 !GetPlaneProperty("SRC_W", src_w_property_) ||
85 !GetPlaneProperty("SRC_H", src_h_property_)) {
86 return -ENOTSUP;
Sean Paul6a55e9f2015-04-30 15:31:06 -040087 }
88
Roman Stratiienko0b063882021-09-30 10:15:05 +030089 GetPlaneProperty("zpos", zpos_property_, Presence::kOptional);
Sean Paul6a55e9f2015-04-30 15:31:06 -040090
Roman Stratiienko0b063882021-09-30 10:15:05 +030091 if (GetPlaneProperty("rotation", rotation_property_, Presence::kOptional)) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020092 rotation_property_.AddEnumToMap("rotate-0", LayerTransform::kIdentity,
Roman Stratiienko24a4c182021-09-29 12:59:54 +030093 transform_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020094 rotation_property_.AddEnumToMap("rotate-90", LayerTransform::kRotate90,
Roman Stratiienko24a4c182021-09-29 12:59:54 +030095 transform_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020096 rotation_property_.AddEnumToMap("rotate-180", LayerTransform::kRotate180,
Roman Stratiienko24a4c182021-09-29 12:59:54 +030097 transform_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020098 rotation_property_.AddEnumToMap("rotate-270", LayerTransform::kRotate270,
Roman Stratiienko24a4c182021-09-29 12:59:54 +030099 transform_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200100 rotation_property_.AddEnumToMap("reflect-x", LayerTransform::kFlipH,
Roman Stratiienko24a4c182021-09-29 12:59:54 +0300101 transform_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200102 rotation_property_.AddEnumToMap("reflect-y", LayerTransform::kFlipV,
Roman Stratiienko24a4c182021-09-29 12:59:54 +0300103 transform_enum_map_);
Roman Stratiienko24a4c182021-09-29 12:59:54 +0300104 }
Sean Paul1c4c3262015-07-14 15:51:52 -0400105
Roman Stratiienko0b063882021-09-30 10:15:05 +0300106 GetPlaneProperty("alpha", alpha_property_, Presence::kOptional);
Sean Pauld8aefb62015-10-15 15:17:31 -0400107
Roman Stratiienko0b063882021-09-30 10:15:05 +0300108 if (GetPlaneProperty("pixel blend mode", blend_property_,
109 Presence::kOptional)) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200110 blend_property_.AddEnumToMap("Pre-multiplied", BufferBlendMode::kPreMult,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300111 blending_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200112 blend_property_.AddEnumToMap("Coverage", BufferBlendMode::kCoverage,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300113 blending_enum_map_);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200114 blend_property_.AddEnumToMap("None", BufferBlendMode::kNone,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300115 blending_enum_map_);
Roman Stratiienko5063d532021-09-29 12:47:31 +0300116 }
Lowry Li9b6cafd2018-08-28 17:58:21 +0800117
Roman Stratiienko0b063882021-09-30 10:15:05 +0300118 GetPlaneProperty("IN_FENCE_FD", in_fence_fd_property_, Presence::kOptional);
Robert Fossa09220c2016-09-30 10:27:23 -0400119
Matvii Zorin8338c342020-09-08 16:12:51 +0300120 if (HasNonRgbFormat()) {
Roman Stratiienko0b063882021-09-30 10:15:05 +0300121 if (GetPlaneProperty("COLOR_ENCODING", color_encoding_propery_,
122 Presence::kOptional)) {
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300123 color_encoding_propery_.AddEnumToMap("ITU-R BT.709 YCbCr",
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200124 BufferColorSpace::kItuRec709,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300125 color_encoding_enum_map_);
126 color_encoding_propery_.AddEnumToMap("ITU-R BT.601 YCbCr",
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200127 BufferColorSpace::kItuRec601,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300128 color_encoding_enum_map_);
129 color_encoding_propery_.AddEnumToMap("ITU-R BT.2020 YCbCr",
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200130 BufferColorSpace::kItuRec2020,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300131 color_encoding_enum_map_);
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300132 }
Matvii Zorin8338c342020-09-08 16:12:51 +0300133
Roman Stratiienko0b063882021-09-30 10:15:05 +0300134 if (GetPlaneProperty("COLOR_RANGE", color_range_property_,
135 Presence::kOptional)) {
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300136 color_range_property_.AddEnumToMap("YCbCr full range",
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200137 BufferSampleRange::kFullRange,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300138 color_range_enum_map_);
139 color_range_property_.AddEnumToMap("YCbCr limited range",
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200140 BufferSampleRange::kLimitedRange,
Roman Stratiienko0f679aa2021-09-29 12:59:48 +0300141 color_range_enum_map_);
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300142 }
Matvii Zorin8338c342020-09-08 16:12:51 +0300143 }
144
Sean Paul6a55e9f2015-04-30 15:31:06 -0400145 return 0;
146}
147
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200148bool DrmPlane::IsCrtcSupported(const DrmCrtc &crtc) const {
Roman Stratiienkoabd8e532022-12-06 23:31:33 +0200149 auto crtc_prop_optval = crtc_property_.GetValue();
150 auto crtc_prop_val = crtc_prop_optval ? *crtc_prop_optval : 0;
151
152 if (crtc_prop_val != 0 && crtc_prop_val != crtc.GetId() &&
Yongqin Liu7ee6a9e2021-12-11 20:39:05 +0800153 GetType() == DRM_PLANE_TYPE_PRIMARY) {
154 // Some DRM driver such as omap_drm allows sharing primary plane between
155 // CRTCs, but the primay plane could not be shared if it has been used by
156 // any CRTC already, which is protected by the plane_switching_crtc function
157 // in the kernel drivers/gpu/drm/drm_atomic.c file.
158 // The current drm_hwc design is not ready to support such scenario yet,
159 // so adding the CRTC status check here to workaorund for now.
Roman Stratiienkoabd8e532022-12-06 23:31:33 +0200160 ALOGW("%s: This Plane(id=%d) is activated for Crtc(id=%" PRIu64
161 "), could not be used for Crtc (id=%d)",
162 __FUNCTION__, GetId(), crtc_prop_val, crtc.GetId());
Yongqin Liu7ee6a9e2021-12-11 20:39:05 +0800163 return false;
164 }
165
Roman Stratiienko10be8752022-01-30 20:28:46 +0200166 return ((1 << crtc.GetIndexInResArray()) & plane_->possible_crtcs) != 0;
Sean Paul6a55e9f2015-04-30 15:31:06 -0400167}
168
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200169bool DrmPlane::IsValidForLayer(LayerData *layer) {
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300170 if (layer == nullptr || !layer->bi) {
171 ALOGE("%s: Invalid parameters", __func__);
172 return false;
173 }
174
Roman Stratiienko24a4c182021-09-29 12:59:54 +0300175 if (!rotation_property_) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200176 if (layer->pi.transform != LayerTransform::kIdentity) {
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200177 ALOGV("No rotation property on plane %d", GetId());
Benjamin Lib00b28d2021-05-09 08:52:18 -0700178 return false;
179 }
180 } else {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200181 if (transform_enum_map_.count(layer->pi.transform) == 0) {
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200182 ALOGV("Transform is not supported on plane %d", GetId());
Roman Stratiienko24a4c182021-09-29 12:59:54 +0300183 return false;
Benjamin Lib00b28d2021-05-09 08:52:18 -0700184 }
Matvii Zorin67a89d32021-01-31 14:45:05 +0200185 }
186
Roman Stratiienkoabd8e532022-12-06 23:31:33 +0200187 if (!alpha_property_ && layer->pi.alpha != UINT16_MAX) {
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200188 ALOGV("Alpha is not supported on plane %d", GetId());
Matvii Zorin67a89d32021-01-31 14:45:05 +0200189 return false;
190 }
191
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200192 if (blending_enum_map_.count(layer->bi->blend_mode) == 0 &&
193 layer->bi->blend_mode != BufferBlendMode::kNone &&
194 layer->bi->blend_mode != BufferBlendMode::kPreMult) {
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200195 ALOGV("Blending is not supported on plane %d", GetId());
Roman Stratiienko5063d532021-09-29 12:47:31 +0300196 return false;
Matvii Zorin67a89d32021-01-31 14:45:05 +0200197 }
198
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300199 auto format = layer->bi->format;
Matvii Zorin67a89d32021-01-31 14:45:05 +0200200 if (!IsFormatSupported(format)) {
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200201 ALOGV("Plane %d does not supports %c%c%c%c format", GetId(), format,
Matvii Zorin67a89d32021-01-31 14:45:05 +0200202 format >> 8, format >> 16, format >> 24);
203 return false;
204 }
205
206 return true;
207}
208
Roman Kovalivskyi859b6072020-03-26 05:03:39 +0200209bool DrmPlane::IsFormatSupported(uint32_t format) const {
210 return std::find(std::begin(formats_), std::end(formats_), format) !=
211 std::end(formats_);
212}
213
Matvii Zorin8338c342020-09-08 16:12:51 +0300214bool DrmPlane::HasNonRgbFormat() const {
215 return std::find_if_not(std::begin(formats_), std::end(formats_),
216 [](uint32_t format) {
217 return BufferInfoGetter::IsDrmFormatRgb(format);
218 }) != std::end(formats_);
219}
220
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200221static uint64_t ToDrmRotation(LayerTransform transform) {
Roman Stratiienko6662f712021-09-29 12:52:22 +0300222 uint64_t rotation = 0;
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200223 if ((transform & LayerTransform::kFlipH) != 0)
Roman Stratiienko6662f712021-09-29 12:52:22 +0300224 rotation |= DRM_MODE_REFLECT_X;
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200225 if ((transform & LayerTransform::kFlipV) != 0)
Roman Stratiienko6662f712021-09-29 12:52:22 +0300226 rotation |= DRM_MODE_REFLECT_Y;
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200227 if ((transform & LayerTransform::kRotate90) != 0)
Roman Stratiienko6662f712021-09-29 12:52:22 +0300228 rotation |= DRM_MODE_ROTATE_90;
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200229 else if ((transform & LayerTransform::kRotate180) != 0)
Roman Stratiienko6662f712021-09-29 12:52:22 +0300230 rotation |= DRM_MODE_ROTATE_180;
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200231 else if ((transform & LayerTransform::kRotate270) != 0)
Roman Stratiienko6662f712021-09-29 12:52:22 +0300232 rotation |= DRM_MODE_ROTATE_270;
233 else
234 rotation |= DRM_MODE_ROTATE_0;
235
236 return rotation;
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 Stratiienko0dbe6392021-09-29 12:47:16 +0300246 uint32_t zpos, uint32_t crtc_id) -> int {
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300247 if (!layer.fb || !layer.bi) {
248 ALOGE("%s: Invalid arguments", __func__);
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300249 return -EINVAL;
250 }
251
Roman Stratiienkoabd8e532022-12-06 23:31:33 +0200252 if (zpos_property_ && !zpos_property_.IsImmutable()) {
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300253 uint64_t min_zpos = 0;
254
255 // Ignore ret and use min_zpos as 0 by default
Roman Stratiienkoabd8e532022-12-06 23:31:33 +0200256 std::tie(std::ignore, min_zpos) = zpos_property_.RangeMin();
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300257
258 if (!zpos_property_.AtomicSet(pset, zpos + min_zpos)) {
259 return -EINVAL;
260 }
261 }
262
Roman Stratiienko6662f712021-09-29 12:52:22 +0300263 if (layer.acquire_fence &&
Roman Stratiienko76892782023-01-16 17:15:53 +0200264 !in_fence_fd_property_.AtomicSet(pset, *layer.acquire_fence)) {
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300265 return -EINVAL;
266 }
267
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200268 auto &disp = layer.pi.display_frame;
269 auto &src = layer.pi.source_crop;
Roman Stratiienko6662f712021-09-29 12:52:22 +0300270 if (!crtc_property_.AtomicSet(pset, crtc_id) ||
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200271 !fb_property_.AtomicSet(pset, layer.fb->GetFbId()) ||
272 !crtc_x_property_.AtomicSet(pset, disp.left) ||
273 !crtc_y_property_.AtomicSet(pset, disp.top) ||
274 !crtc_w_property_.AtomicSet(pset, disp.right - disp.left) ||
275 !crtc_h_property_.AtomicSet(pset, disp.bottom - disp.top) ||
276 !src_x_property_.AtomicSet(pset, To1616FixPt(src.left)) ||
277 !src_y_property_.AtomicSet(pset, To1616FixPt(src.top)) ||
278 !src_w_property_.AtomicSet(pset, To1616FixPt(src.right - src.left)) ||
279 !src_h_property_.AtomicSet(pset, To1616FixPt(src.bottom - src.top))) {
Roman Stratiienko6662f712021-09-29 12:52:22 +0300280 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300281 }
282
Roman Stratiienko6662f712021-09-29 12:52:22 +0300283 if (rotation_property_ &&
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200284 !rotation_property_.AtomicSet(pset, ToDrmRotation(layer.pi.transform))) {
Roman Stratiienko6662f712021-09-29 12:52:22 +0300285 return -EINVAL;
286 }
287
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200288 if (alpha_property_ && !alpha_property_.AtomicSet(pset, layer.pi.alpha)) {
Roman Stratiienko6662f712021-09-29 12:52:22 +0300289 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300290 }
291
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200292 if (blending_enum_map_.count(layer.bi->blend_mode) != 0 &&
293 !blend_property_.AtomicSet(pset,
294 blending_enum_map_[layer.bi->blend_mode])) {
Roman Stratiienko5063d532021-09-29 12:47:31 +0300295 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300296 }
297
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200298 if (color_encoding_enum_map_.count(layer.bi->color_space) != 0 &&
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300299 !color_encoding_propery_
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200300 .AtomicSet(pset, color_encoding_enum_map_[layer.bi->color_space])) {
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300301 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300302 }
303
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200304 if (color_range_enum_map_.count(layer.bi->sample_range) != 0 &&
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300305 !color_range_property_
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200306 .AtomicSet(pset, color_range_enum_map_[layer.bi->sample_range])) {
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300307 return -EINVAL;
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300308 }
Roman Stratiienko4f1effa2021-09-29 12:47:26 +0300309
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300310 return 0;
Sean Paul6a55e9f2015-04-30 15:31:06 -0400311}
312
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300313auto DrmPlane::AtomicDisablePlane(drmModeAtomicReq &pset) -> int {
314 if (!crtc_property_.AtomicSet(pset, 0) || !fb_property_.AtomicSet(pset, 0)) {
315 return -EINVAL;
316 }
Sean Paul6a55e9f2015-04-30 15:31:06 -0400317
Roman Stratiienko0dbe6392021-09-29 12:47:16 +0300318 return 0;
Sean Paul6a55e9f2015-04-30 15:31:06 -0400319}
Sean Paul1c4c3262015-07-14 15:51:52 -0400320
Roman Stratiienko0b063882021-09-30 10:15:05 +0300321auto DrmPlane::GetPlaneProperty(const char *prop_name, DrmProperty &property,
322 Presence presence) -> bool {
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300323 auto err = drm_->GetProperty(GetId(), DRM_MODE_OBJECT_PLANE, prop_name,
324 &property);
Roman Stratiienko0b063882021-09-30 10:15:05 +0300325 if (err != 0) {
326 if (presence == Presence::kMandatory) {
327 ALOGE("Could not get mandatory property \"%s\" from plane %d", prop_name,
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200328 GetId());
Roman Stratiienko0b063882021-09-30 10:15:05 +0300329 } else {
330 ALOGV("Could not get optional property \"%s\" from plane %d", prop_name,
Roman Stratiienkob671fab2022-01-29 00:50:22 +0200331 GetId());
Roman Stratiienko0b063882021-09-30 10:15:05 +0300332 }
333 return false;
334 }
335
336 return true;
337}
338
Sean Paulf72cccd2018-08-27 13:59:08 -0400339} // namespace android