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:
commit
68dc613d33
1 changed files with 8 additions and 5 deletions
|
@ -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;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue