Merge "Support P010 with Gralloc2 on Gralloc1 passthrough" am: 89142b4935 am: 96ee08d953 am: a0f7f8486e

Original change: https://android-review.googlesource.com/c/platform/hardware/interfaces/+/2208777

Change-Id: Ic9f268469d3bf3407691d7b407f81ad36bfa2914
Signed-off-by: Automerger Merge Worker <android-build-automerger-merge-worker@system.gserviceaccount.com>
This commit is contained in:
Jason Macnak 2022-09-15 16:28:47 +00:00 committed by Automerger Merge Worker
commit 68dc613d33

View file

@ -259,19 +259,22 @@ class Gralloc1HalImpl : public Hal {
for (int i = 0; i < 3; i++) {
const auto& plane = flex.planes[i];
// must have 8-bit depth
if (plane.bits_per_component != 8 || plane.bits_used != 8) {
// Must be a positive multiple of 8.
if (plane.bits_per_component <= 0 || (plane.bits_per_component % 8) != 0) {
return false;
}
// Must be between 1 and bits_per_component, inclusive.
if (plane.bits_used < 1 || plane.bits_used > plane.bits_per_component) {
return false;
}
if (plane.component == FLEX_COMPONENT_Y) {
// Y must not be interleaved
if (plane.h_increment != 1) {
if (plane.h_increment != 1 && plane.h_increment != 2) {
return false;
}
} else {
// Cb and Cr can be interleaved
if (plane.h_increment != 1 && plane.h_increment != 2) {
if (plane.h_increment != 1 && plane.h_increment != 2 && plane.h_increment != 4) {
return false;
}
}