blob: e2b20f453ebf49dd3fdf9e0ed144bae4ede748e3 [file] [log] [blame]
Roman Stratiienko03fd35c2022-01-04 14:30:37 +02001/*
2 * Copyright (C) 2022 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"
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020018
19#include "HwcLayer.h"
20
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020021#include "HwcDisplay.h"
22#include "bufferinfo/BufferInfoGetter.h"
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020023#include "utils/log.h"
24
25namespace android {
26
Drew Davenporta241a772024-09-24 11:26:30 -060027void HwcLayer::SetLayerProperties(const LayerProperties& layer_properties) {
28 if (layer_properties.blend_mode) {
29 blend_mode_ = layer_properties.blend_mode.value();
30 }
31}
32
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020033// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
34HWC2::Error HwcLayer::SetCursorPosition(int32_t /*x*/, int32_t /*y*/) {
35 return HWC2::Error::None;
36}
37
38HWC2::Error HwcLayer::SetLayerBlendMode(int32_t mode) {
39 switch (static_cast<HWC2::BlendMode>(mode)) {
40 case HWC2::BlendMode::None:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020041 blend_mode_ = BufferBlendMode::kNone;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020042 break;
43 case HWC2::BlendMode::Premultiplied:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020044 blend_mode_ = BufferBlendMode::kPreMult;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020045 break;
46 case HWC2::BlendMode::Coverage:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020047 blend_mode_ = BufferBlendMode::kCoverage;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020048 break;
49 default:
John Stultz71d983d2024-02-13 20:40:36 -080050 ALOGE("Unknown blending mode b=%d", mode);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020051 blend_mode_ = BufferBlendMode::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020052 break;
53 }
54 return HWC2::Error::None;
55}
56
57/* Find API details at:
58 * https://cs.android.com/android/platform/superproject/+/android-11.0.0_r3:hardware/libhardware/include/hardware/hwcomposer2.h;l=2314
59 */
60HWC2::Error HwcLayer::SetLayerBuffer(buffer_handle_t buffer,
61 int32_t acquire_fence) {
Roman Stratiienko359a9d32023-01-16 17:41:07 +020062 layer_data_.acquire_fence = MakeSharedFd(acquire_fence);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020063 buffer_handle_ = buffer;
64 buffer_handle_updated_ = true;
65
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020066 return HWC2::Error::None;
67}
68
69// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
70HWC2::Error HwcLayer::SetLayerColor(hwc_color_t /*color*/) {
71 // TODO(nobody): Put to client composition here?
72 return HWC2::Error::None;
73}
74
75HWC2::Error HwcLayer::SetLayerCompositionType(int32_t type) {
76 sf_type_ = static_cast<HWC2::Composition>(type);
77 return HWC2::Error::None;
78}
79
80HWC2::Error HwcLayer::SetLayerDataspace(int32_t dataspace) {
81 switch (dataspace & HAL_DATASPACE_STANDARD_MASK) {
82 case HAL_DATASPACE_STANDARD_BT709:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020083 color_space_ = BufferColorSpace::kItuRec709;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020084 break;
85 case HAL_DATASPACE_STANDARD_BT601_625:
86 case HAL_DATASPACE_STANDARD_BT601_625_UNADJUSTED:
87 case HAL_DATASPACE_STANDARD_BT601_525:
88 case HAL_DATASPACE_STANDARD_BT601_525_UNADJUSTED:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020089 color_space_ = BufferColorSpace::kItuRec601;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020090 break;
91 case HAL_DATASPACE_STANDARD_BT2020:
92 case HAL_DATASPACE_STANDARD_BT2020_CONSTANT_LUMINANCE:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020093 color_space_ = BufferColorSpace::kItuRec2020;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020094 break;
95 default:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020096 color_space_ = BufferColorSpace::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020097 }
98
99 switch (dataspace & HAL_DATASPACE_RANGE_MASK) {
100 case HAL_DATASPACE_RANGE_FULL:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200101 sample_range_ = BufferSampleRange::kFullRange;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200102 break;
103 case HAL_DATASPACE_RANGE_LIMITED:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200104 sample_range_ = BufferSampleRange::kLimitedRange;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200105 break;
106 default:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200107 sample_range_ = BufferSampleRange::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200108 }
109 return HWC2::Error::None;
110}
111
112HWC2::Error HwcLayer::SetLayerDisplayFrame(hwc_rect_t frame) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200113 layer_data_.pi.display_frame = frame;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200114 return HWC2::Error::None;
115}
116
117HWC2::Error HwcLayer::SetLayerPlaneAlpha(float alpha) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200118 layer_data_.pi.alpha = std::lround(alpha * UINT16_MAX);
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200119 return HWC2::Error::None;
120}
121
122// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
123HWC2::Error HwcLayer::SetLayerSidebandStream(
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200124 const native_handle_t* /*stream*/) {
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200125 // TODO(nobody): We don't support sideband
126 return HWC2::Error::Unsupported;
127}
128
129HWC2::Error HwcLayer::SetLayerSourceCrop(hwc_frect_t crop) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200130 layer_data_.pi.source_crop = crop;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200131 return HWC2::Error::None;
132}
133
134// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
135HWC2::Error HwcLayer::SetLayerSurfaceDamage(hwc_region_t /*damage*/) {
136 // TODO(nobody): We don't use surface damage, marking as unsupported
137 return HWC2::Error::None;
138}
139
140HWC2::Error HwcLayer::SetLayerTransform(int32_t transform) {
141 uint32_t l_transform = 0;
142
143 // 270* and 180* cannot be combined with flips. More specifically, they
144 // already contain both horizontal and vertical flips, so those fields are
145 // redundant in this case. 90* rotation can be combined with either horizontal
146 // flip or vertical flip, so treat it differently
147 if (transform == HWC_TRANSFORM_ROT_270) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200148 l_transform = LayerTransform::kRotate270;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200149 } else if (transform == HWC_TRANSFORM_ROT_180) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200150 l_transform = LayerTransform::kRotate180;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200151 } else {
152 if ((transform & HWC_TRANSFORM_FLIP_H) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200153 l_transform |= LayerTransform::kFlipH;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200154 if ((transform & HWC_TRANSFORM_FLIP_V) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200155 l_transform |= LayerTransform::kFlipV;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200156 if ((transform & HWC_TRANSFORM_ROT_90) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200157 l_transform |= LayerTransform::kRotate90;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200158 }
159
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200160 layer_data_.pi.transform = static_cast<LayerTransform>(l_transform);
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200161 return HWC2::Error::None;
162}
163
164// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
165HWC2::Error HwcLayer::SetLayerVisibleRegion(hwc_region_t /*visible*/) {
166 // TODO(nobody): We don't use this information, marking as unsupported
167 return HWC2::Error::None;
168}
169
170HWC2::Error HwcLayer::SetLayerZOrder(uint32_t order) {
171 z_order_ = order;
172 return HWC2::Error::None;
173}
174
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200175void HwcLayer::ImportFb() {
176 if (!IsLayerUsableAsDevice() || !buffer_handle_updated_) {
177 return;
178 }
179 buffer_handle_updated_ = false;
180
181 layer_data_.fb = {};
182
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300183 auto unique_id = BufferInfoGetter::GetInstance()->GetUniqueId(buffer_handle_);
184 if (unique_id && SwChainGetBufferFromCache(*unique_id)) {
185 return;
186 }
187
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200188 layer_data_.bi = BufferInfoGetter::GetInstance()->GetBoInfo(buffer_handle_);
189 if (!layer_data_.bi) {
190 ALOGW("Unable to get buffer information (0x%p)", buffer_handle_);
191 bi_get_failed_ = true;
192 return;
193 }
194
195 layer_data_
196 .fb = parent_->GetPipe().device->GetDrmFbImporter().GetOrCreateFbId(
197 &layer_data_.bi.value());
198
199 if (!layer_data_.fb) {
200 ALOGV("Unable to create framebuffer object for buffer 0x%p",
201 buffer_handle_);
202 fb_import_failed_ = true;
203 return;
204 }
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300205
206 if (unique_id) {
207 SwChainAddCurrentBuffer(*unique_id);
208 }
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200209}
210
Roman Stratiienko359a9d32023-01-16 17:41:07 +0200211void HwcLayer::PopulateLayerData() {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200212 ImportFb();
213
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300214 if (!layer_data_.bi) {
215 ALOGE("%s: Invalid state", __func__);
216 return;
217 }
218
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200219 if (blend_mode_ != BufferBlendMode::kUndefined) {
220 layer_data_.bi->blend_mode = blend_mode_;
221 }
222 if (color_space_ != BufferColorSpace::kUndefined) {
223 layer_data_.bi->color_space = color_space_;
224 }
225 if (sample_range_ != BufferSampleRange::kUndefined) {
226 layer_data_.bi->sample_range = sample_range_;
227 }
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200228}
229
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300230/* SwapChain Cache */
231
232bool HwcLayer::SwChainGetBufferFromCache(BufferUniqueId unique_id) {
233 if (swchain_lookup_table_.count(unique_id) == 0) {
234 return false;
235 }
236
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300237 auto seq = swchain_lookup_table_[unique_id];
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300238
239 if (swchain_cache_.count(seq) == 0) {
240 return false;
241 }
242
243 auto& el = swchain_cache_[seq];
244 if (!el.bi) {
245 return false;
246 }
247
248 layer_data_.bi = el.bi;
249 layer_data_.fb = el.fb;
250
251 return true;
252}
253
254void HwcLayer::SwChainReassemble(BufferUniqueId unique_id) {
255 if (swchain_lookup_table_.count(unique_id) != 0) {
256 if (swchain_lookup_table_[unique_id] ==
257 int(swchain_lookup_table_.size()) - 1) {
258 /* Skip same buffer */
259 return;
260 }
261 if (swchain_lookup_table_[unique_id] == 0) {
262 swchain_reassembled_ = true;
263 return;
264 }
265 /* Tracking error */
266 SwChainClearCache();
267 return;
268 }
269
270 swchain_lookup_table_[unique_id] = int(swchain_lookup_table_.size());
271}
272
273void HwcLayer::SwChainAddCurrentBuffer(BufferUniqueId unique_id) {
274 if (!swchain_reassembled_) {
275 SwChainReassemble(unique_id);
276 }
277
278 if (swchain_reassembled_) {
279 if (swchain_lookup_table_.count(unique_id) == 0) {
280 SwChainClearCache();
281 return;
282 }
283
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300284 auto seq = swchain_lookup_table_[unique_id];
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300285
286 if (swchain_cache_.count(seq) == 0) {
287 swchain_cache_[seq] = {};
288 }
289
290 swchain_cache_[seq].bi = layer_data_.bi;
291 swchain_cache_[seq].fb = layer_data_.fb;
292 }
293}
294
295void HwcLayer::SwChainClearCache() {
296 swchain_cache_.clear();
297 swchain_lookup_table_.clear();
298 swchain_reassembled_ = false;
299}
300
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200301} // namespace android