blob: d3936b386648093c7f85eae9bd123bb09ec88b6e [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
17#define LOG_TAG "hwc-layer"
18
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
27// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
28HWC2::Error HwcLayer::SetCursorPosition(int32_t /*x*/, int32_t /*y*/) {
29 return HWC2::Error::None;
30}
31
32HWC2::Error HwcLayer::SetLayerBlendMode(int32_t mode) {
33 switch (static_cast<HWC2::BlendMode>(mode)) {
34 case HWC2::BlendMode::None:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020035 blend_mode_ = BufferBlendMode::kNone;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020036 break;
37 case HWC2::BlendMode::Premultiplied:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020038 blend_mode_ = BufferBlendMode::kPreMult;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020039 break;
40 case HWC2::BlendMode::Coverage:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020041 blend_mode_ = BufferBlendMode::kCoverage;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020042 break;
43 default:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020044 ALOGE("Unknown blending mode b=%d", blend_mode_);
45 blend_mode_ = BufferBlendMode::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020046 break;
47 }
48 return HWC2::Error::None;
49}
50
51/* Find API details at:
52 * https://cs.android.com/android/platform/superproject/+/android-11.0.0_r3:hardware/libhardware/include/hardware/hwcomposer2.h;l=2314
53 */
54HWC2::Error HwcLayer::SetLayerBuffer(buffer_handle_t buffer,
55 int32_t acquire_fence) {
Roman Stratiienko76892782023-01-16 17:15:53 +020056 acquire_fence_ = MakeUniqueFd(acquire_fence);
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020057 buffer_handle_ = buffer;
58 buffer_handle_updated_ = true;
59
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020060 return HWC2::Error::None;
61}
62
63// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
64HWC2::Error HwcLayer::SetLayerColor(hwc_color_t /*color*/) {
65 // TODO(nobody): Put to client composition here?
66 return HWC2::Error::None;
67}
68
69HWC2::Error HwcLayer::SetLayerCompositionType(int32_t type) {
70 sf_type_ = static_cast<HWC2::Composition>(type);
71 return HWC2::Error::None;
72}
73
74HWC2::Error HwcLayer::SetLayerDataspace(int32_t dataspace) {
75 switch (dataspace & HAL_DATASPACE_STANDARD_MASK) {
76 case HAL_DATASPACE_STANDARD_BT709:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020077 color_space_ = BufferColorSpace::kItuRec709;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020078 break;
79 case HAL_DATASPACE_STANDARD_BT601_625:
80 case HAL_DATASPACE_STANDARD_BT601_625_UNADJUSTED:
81 case HAL_DATASPACE_STANDARD_BT601_525:
82 case HAL_DATASPACE_STANDARD_BT601_525_UNADJUSTED:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020083 color_space_ = BufferColorSpace::kItuRec601;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020084 break;
85 case HAL_DATASPACE_STANDARD_BT2020:
86 case HAL_DATASPACE_STANDARD_BT2020_CONSTANT_LUMINANCE:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020087 color_space_ = BufferColorSpace::kItuRec2020;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020088 break;
89 default:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020090 color_space_ = BufferColorSpace::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020091 }
92
93 switch (dataspace & HAL_DATASPACE_RANGE_MASK) {
94 case HAL_DATASPACE_RANGE_FULL:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020095 sample_range_ = BufferSampleRange::kFullRange;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020096 break;
97 case HAL_DATASPACE_RANGE_LIMITED:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +020098 sample_range_ = BufferSampleRange::kLimitedRange;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +020099 break;
100 default:
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200101 sample_range_ = BufferSampleRange::kUndefined;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200102 }
103 return HWC2::Error::None;
104}
105
106HWC2::Error HwcLayer::SetLayerDisplayFrame(hwc_rect_t frame) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200107 layer_data_.pi.display_frame = frame;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200108 return HWC2::Error::None;
109}
110
111HWC2::Error HwcLayer::SetLayerPlaneAlpha(float alpha) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200112 layer_data_.pi.alpha = std::lround(alpha * UINT16_MAX);
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200113 return HWC2::Error::None;
114}
115
116// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
117HWC2::Error HwcLayer::SetLayerSidebandStream(
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200118 const native_handle_t* /*stream*/) {
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200119 // TODO(nobody): We don't support sideband
120 return HWC2::Error::Unsupported;
121}
122
123HWC2::Error HwcLayer::SetLayerSourceCrop(hwc_frect_t crop) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200124 layer_data_.pi.source_crop = crop;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200125 return HWC2::Error::None;
126}
127
128// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
129HWC2::Error HwcLayer::SetLayerSurfaceDamage(hwc_region_t /*damage*/) {
130 // TODO(nobody): We don't use surface damage, marking as unsupported
131 return HWC2::Error::None;
132}
133
134HWC2::Error HwcLayer::SetLayerTransform(int32_t transform) {
135 uint32_t l_transform = 0;
136
137 // 270* and 180* cannot be combined with flips. More specifically, they
138 // already contain both horizontal and vertical flips, so those fields are
139 // redundant in this case. 90* rotation can be combined with either horizontal
140 // flip or vertical flip, so treat it differently
141 if (transform == HWC_TRANSFORM_ROT_270) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200142 l_transform = LayerTransform::kRotate270;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200143 } else if (transform == HWC_TRANSFORM_ROT_180) {
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200144 l_transform = LayerTransform::kRotate180;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200145 } else {
146 if ((transform & HWC_TRANSFORM_FLIP_H) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200147 l_transform |= LayerTransform::kFlipH;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200148 if ((transform & HWC_TRANSFORM_FLIP_V) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200149 l_transform |= LayerTransform::kFlipV;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200150 if ((transform & HWC_TRANSFORM_ROT_90) != 0)
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200151 l_transform |= LayerTransform::kRotate90;
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200152 }
153
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200154 layer_data_.pi.transform = static_cast<LayerTransform>(l_transform);
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200155 return HWC2::Error::None;
156}
157
158// NOLINTNEXTLINE(readability-convert-member-functions-to-static)
159HWC2::Error HwcLayer::SetLayerVisibleRegion(hwc_region_t /*visible*/) {
160 // TODO(nobody): We don't use this information, marking as unsupported
161 return HWC2::Error::None;
162}
163
164HWC2::Error HwcLayer::SetLayerZOrder(uint32_t order) {
165 z_order_ = order;
166 return HWC2::Error::None;
167}
168
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200169void HwcLayer::ImportFb() {
170 if (!IsLayerUsableAsDevice() || !buffer_handle_updated_) {
171 return;
172 }
173 buffer_handle_updated_ = false;
174
175 layer_data_.fb = {};
176
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300177 auto unique_id = BufferInfoGetter::GetInstance()->GetUniqueId(buffer_handle_);
178 if (unique_id && SwChainGetBufferFromCache(*unique_id)) {
179 return;
180 }
181
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200182 layer_data_.bi = BufferInfoGetter::GetInstance()->GetBoInfo(buffer_handle_);
183 if (!layer_data_.bi) {
184 ALOGW("Unable to get buffer information (0x%p)", buffer_handle_);
185 bi_get_failed_ = true;
186 return;
187 }
188
189 layer_data_
190 .fb = parent_->GetPipe().device->GetDrmFbImporter().GetOrCreateFbId(
191 &layer_data_.bi.value());
192
193 if (!layer_data_.fb) {
194 ALOGV("Unable to create framebuffer object for buffer 0x%p",
195 buffer_handle_);
196 fb_import_failed_ = true;
197 return;
198 }
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300199
200 if (unique_id) {
201 SwChainAddCurrentBuffer(*unique_id);
202 }
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200203}
204
205void HwcLayer::PopulateLayerData(bool test) {
206 ImportFb();
207
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300208 if (!layer_data_.bi) {
209 ALOGE("%s: Invalid state", __func__);
210 return;
211 }
212
Roman Stratiienko4b2cc482022-02-21 14:53:58 +0200213 if (blend_mode_ != BufferBlendMode::kUndefined) {
214 layer_data_.bi->blend_mode = blend_mode_;
215 }
216 if (color_space_ != BufferColorSpace::kUndefined) {
217 layer_data_.bi->color_space = color_space_;
218 }
219 if (sample_range_ != BufferSampleRange::kUndefined) {
220 layer_data_.bi->sample_range = sample_range_;
221 }
222
223 if (!test) {
224 layer_data_.acquire_fence = std::move(acquire_fence_);
225 }
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200226}
227
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300228/* SwapChain Cache */
229
230bool HwcLayer::SwChainGetBufferFromCache(BufferUniqueId unique_id) {
231 if (swchain_lookup_table_.count(unique_id) == 0) {
232 return false;
233 }
234
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300235 auto seq = swchain_lookup_table_[unique_id];
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300236
237 if (swchain_cache_.count(seq) == 0) {
238 return false;
239 }
240
241 auto& el = swchain_cache_[seq];
242 if (!el.bi) {
243 return false;
244 }
245
246 layer_data_.bi = el.bi;
247 layer_data_.fb = el.fb;
248
249 return true;
250}
251
252void HwcLayer::SwChainReassemble(BufferUniqueId unique_id) {
253 if (swchain_lookup_table_.count(unique_id) != 0) {
254 if (swchain_lookup_table_[unique_id] ==
255 int(swchain_lookup_table_.size()) - 1) {
256 /* Skip same buffer */
257 return;
258 }
259 if (swchain_lookup_table_[unique_id] == 0) {
260 swchain_reassembled_ = true;
261 return;
262 }
263 /* Tracking error */
264 SwChainClearCache();
265 return;
266 }
267
268 swchain_lookup_table_[unique_id] = int(swchain_lookup_table_.size());
269}
270
271void HwcLayer::SwChainAddCurrentBuffer(BufferUniqueId unique_id) {
272 if (!swchain_reassembled_) {
273 SwChainReassemble(unique_id);
274 }
275
276 if (swchain_reassembled_) {
277 if (swchain_lookup_table_.count(unique_id) == 0) {
278 SwChainClearCache();
279 return;
280 }
281
Roman Stratiienkoa7913de2022-10-20 13:18:57 +0300282 auto seq = swchain_lookup_table_[unique_id];
Roman Stratiienkoa32f9072022-05-13 12:12:20 +0300283
284 if (swchain_cache_.count(seq) == 0) {
285 swchain_cache_[seq] = {};
286 }
287
288 swchain_cache_[seq].bi = layer_data_.bi;
289 swchain_cache_[seq].fb = layer_data_.fb;
290 }
291}
292
293void HwcLayer::SwChainClearCache() {
294 swchain_cache_.clear();
295 swchain_lookup_table_.clear();
296 swchain_reassembled_ = false;
297}
298
Roman Stratiienko03fd35c2022-01-04 14:30:37 +0200299} // namespace android