blob: 9f2888e1758070d82841bf1f67df2338e9854221 [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 }
Drew Davenportac9681e2024-09-24 12:17:34 -060031 if (layer_properties.color_space) {
32 color_space_ = layer_properties.color_space.value();
33 }
34 if (layer_properties.sample_range) {
35 sample_range_ = layer_properties.sample_range.value();
36 }
Drew Davenport1b0d8b72024-09-24 15:31:38 -060037 if (layer_properties.composition_type) {
38 sf_type_ = layer_properties.composition_type.value();
39 }
Drew Davenporta241a772024-09-24 11:26:30 -060040}
41
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020042// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
43HWC2::Error HwcLayer::SetCursorPosition(int32_t /*x*/, int32_t /*y*/) {
44 return HWC2::Error::None;
45}
46
47HWC2::Error HwcLayer::SetLayerBlendMode(int32_t mode) {
48 switch (static_cast<HWC2::BlendMode>(mode)) {
49 case HWC2::BlendMode::None:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020050 blend_mode_ = BufferBlendMode::kNone;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020051 break;
52 case HWC2::BlendMode::Premultiplied:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020053 blend_mode_ = BufferBlendMode::kPreMult;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020054 break;
55 case HWC2::BlendMode::Coverage:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020056 blend_mode_ = BufferBlendMode::kCoverage;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020057 break;
58 default:
John Stultz71d983d2024-02-13 20:40:36 -080059 ALOGE("Unknown blending mode b=%d", mode);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020060 blend_mode_ = BufferBlendMode::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020061 break;
62 }
63 return HWC2::Error::None;
64}
65
66/* Find API details at:
67 * https://cs.android.com/android/platform/superproject/+/android-11.0.0_r3:hardware/libhardware/include/hardware/hwcomposer2.h;l=2314
68 */
69HWC2::Error HwcLayer::SetLayerBuffer(buffer_handle_t buffer,
70 int32_t acquire_fence) {
Roman Stratiienko359a9d32023-01-16 17:41:07 +020071 layer_data_.acquire_fence = MakeSharedFd(acquire_fence);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020072 buffer_handle_ = buffer;
73 buffer_handle_updated_ = true;
74
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020075 return HWC2::Error::None;
76}
77
78// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
79HWC2::Error HwcLayer::SetLayerColor(hwc_color_t /*color*/) {
80 // TODO(nobody): Put to client composition here?
81 return HWC2::Error::None;
82}
83
84HWC2::Error HwcLayer::SetLayerCompositionType(int32_t type) {
85 sf_type_ = static_cast<HWC2::Composition>(type);
86 return HWC2::Error::None;
87}
88
89HWC2::Error HwcLayer::SetLayerDataspace(int32_t dataspace) {
90 switch (dataspace & HAL_DATASPACE_STANDARD_MASK) {
91 case HAL_DATASPACE_STANDARD_BT709:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020092 color_space_ = BufferColorSpace::kItuRec709;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020093 break;
94 case HAL_DATASPACE_STANDARD_BT601_625:
95 case HAL_DATASPACE_STANDARD_BT601_625_UNADJUSTED:
96 case HAL_DATASPACE_STANDARD_BT601_525:
97 case HAL_DATASPACE_STANDARD_BT601_525_UNADJUSTED:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020098 color_space_ = BufferColorSpace::kItuRec601;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020099 break;
100 case HAL_DATASPACE_STANDARD_BT2020:
101 case HAL_DATASPACE_STANDARD_BT2020_CONSTANT_LUMINANCE:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200102 color_space_ = BufferColorSpace::kItuRec2020;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200103 break;
104 default:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200105 color_space_ = BufferColorSpace::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200106 }
107
108 switch (dataspace & HAL_DATASPACE_RANGE_MASK) {
109 case HAL_DATASPACE_RANGE_FULL:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200110 sample_range_ = BufferSampleRange::kFullRange;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200111 break;
112 case HAL_DATASPACE_RANGE_LIMITED:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200113 sample_range_ = BufferSampleRange::kLimitedRange;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200114 break;
115 default:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200116 sample_range_ = BufferSampleRange::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200117 }
118 return HWC2::Error::None;
119}
120
121HWC2::Error HwcLayer::SetLayerDisplayFrame(hwc_rect_t frame) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200122 layer_data_.pi.display_frame = frame;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200123 return HWC2::Error::None;
124}
125
126HWC2::Error HwcLayer::SetLayerPlaneAlpha(float alpha) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200127 layer_data_.pi.alpha = std::lround(alpha * UINT16_MAX);
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200128 return HWC2::Error::None;
129}
130
131// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
132HWC2::Error HwcLayer::SetLayerSidebandStream(
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200133 const native_handle_t* /*stream*/) {
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200134 // TODO(nobody): We don't support sideband
135 return HWC2::Error::Unsupported;
136}
137
138HWC2::Error HwcLayer::SetLayerSourceCrop(hwc_frect_t crop) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200139 layer_data_.pi.source_crop = crop;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200140 return HWC2::Error::None;
141}
142
143// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
144HWC2::Error HwcLayer::SetLayerSurfaceDamage(hwc_region_t /*damage*/) {
145 // TODO(nobody): We don't use surface damage, marking as unsupported
146 return HWC2::Error::None;
147}
148
149HWC2::Error HwcLayer::SetLayerTransform(int32_t transform) {
150 uint32_t l_transform = 0;
151
152 // 270* and 180* cannot be combined with flips. More specifically, they
153 // already contain both horizontal and vertical flips, so those fields are
154 // redundant in this case. 90* rotation can be combined with either horizontal
155 // flip or vertical flip, so treat it differently
156 if (transform == HWC_TRANSFORM_ROT_270) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200157 l_transform = LayerTransform::kRotate270;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200158 } else if (transform == HWC_TRANSFORM_ROT_180) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200159 l_transform = LayerTransform::kRotate180;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200160 } else {
161 if ((transform & HWC_TRANSFORM_FLIP_H) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200162 l_transform |= LayerTransform::kFlipH;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200163 if ((transform & HWC_TRANSFORM_FLIP_V) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200164 l_transform |= LayerTransform::kFlipV;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200165 if ((transform & HWC_TRANSFORM_ROT_90) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200166 l_transform |= LayerTransform::kRotate90;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200167 }
168
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200169 layer_data_.pi.transform = static_cast<LayerTransform>(l_transform);
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200170 return HWC2::Error::None;
171}
172
173// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
174HWC2::Error HwcLayer::SetLayerVisibleRegion(hwc_region_t /*visible*/) {
175 // TODO(nobody): We don't use this information, marking as unsupported
176 return HWC2::Error::None;
177}
178
179HWC2::Error HwcLayer::SetLayerZOrder(uint32_t order) {
180 z_order_ = order;
181 return HWC2::Error::None;
182}
183
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200184void HwcLayer::ImportFb() {
185 if (!IsLayerUsableAsDevice() || !buffer_handle_updated_) {
186 return;
187 }
188 buffer_handle_updated_ = false;
189
190 layer_data_.fb = {};
191
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300192 auto unique_id = BufferInfoGetter::GetInstance()->GetUniqueId(buffer_handle_);
193 if (unique_id && SwChainGetBufferFromCache(*unique_id)) {
194 return;
195 }
196
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200197 layer_data_.bi = BufferInfoGetter::GetInstance()->GetBoInfo(buffer_handle_);
198 if (!layer_data_.bi) {
199 ALOGW("Unable to get buffer information (0x%p)", buffer_handle_);
200 bi_get_failed_ = true;
201 return;
202 }
203
204 layer_data_
205 .fb = parent_->GetPipe().device->GetDrmFbImporter().GetOrCreateFbId(
206 &layer_data_.bi.value());
207
208 if (!layer_data_.fb) {
209 ALOGV("Unable to create framebuffer object for buffer 0x%p",
210 buffer_handle_);
211 fb_import_failed_ = true;
212 return;
213 }
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300214
215 if (unique_id) {
216 SwChainAddCurrentBuffer(*unique_id);
217 }
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200218}
219
Roman Stratiienko359a9d32023-01-16 17:41:07 +0200220void HwcLayer::PopulateLayerData() {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200221 ImportFb();
222
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300223 if (!layer_data_.bi) {
224 ALOGE("%s: Invalid state", __func__);
225 return;
226 }
227
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200228 if (blend_mode_ != BufferBlendMode::kUndefined) {
229 layer_data_.bi->blend_mode = blend_mode_;
230 }
231 if (color_space_ != BufferColorSpace::kUndefined) {
232 layer_data_.bi->color_space = color_space_;
233 }
234 if (sample_range_ != BufferSampleRange::kUndefined) {
235 layer_data_.bi->sample_range = sample_range_;
236 }
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200237}
238
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300239/* SwapChain Cache */
240
241bool HwcLayer::SwChainGetBufferFromCache(BufferUniqueId unique_id) {
242 if (swchain_lookup_table_.count(unique_id) == 0) {
243 return false;
244 }
245
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300246 auto seq = swchain_lookup_table_[unique_id];
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300247
248 if (swchain_cache_.count(seq) == 0) {
249 return false;
250 }
251
252 auto& el = swchain_cache_[seq];
253 if (!el.bi) {
254 return false;
255 }
256
257 layer_data_.bi = el.bi;
258 layer_data_.fb = el.fb;
259
260 return true;
261}
262
263void HwcLayer::SwChainReassemble(BufferUniqueId unique_id) {
264 if (swchain_lookup_table_.count(unique_id) != 0) {
265 if (swchain_lookup_table_[unique_id] ==
266 int(swchain_lookup_table_.size()) - 1) {
267 /* Skip same buffer */
268 return;
269 }
270 if (swchain_lookup_table_[unique_id] == 0) {
271 swchain_reassembled_ = true;
272 return;
273 }
274 /* Tracking error */
275 SwChainClearCache();
276 return;
277 }
278
279 swchain_lookup_table_[unique_id] = int(swchain_lookup_table_.size());
280}
281
282void HwcLayer::SwChainAddCurrentBuffer(BufferUniqueId unique_id) {
283 if (!swchain_reassembled_) {
284 SwChainReassemble(unique_id);
285 }
286
287 if (swchain_reassembled_) {
288 if (swchain_lookup_table_.count(unique_id) == 0) {
289 SwChainClearCache();
290 return;
291 }
292
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300293 auto seq = swchain_lookup_table_[unique_id];
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300294
295 if (swchain_cache_.count(seq) == 0) {
296 swchain_cache_[seq] = {};
297 }
298
299 swchain_cache_[seq].bi = layer_data_.bi;
300 swchain_cache_[seq].fb = layer_data_.fb;
301 }
302}
303
304void HwcLayer::SwChainClearCache() {
305 swchain_cache_.clear();
306 swchain_lookup_table_.clear();
307 swchain_reassembled_ = false;
308}
309
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200310} // namespace android