Add LayerCommand.blockingRegion

This hint tells the HWC that it may use a blocking feature to skip a
portion of the layer's buffer.

Bug: 212736475
Test: TODO (b/213361853)
Change-Id: Ib0fa41e56196feeff201637d5599830d2565da2b
This commit is contained in:
Leon Scroggins III
2022-01-04 13:33:11 -05:00
parent b9d017c22f
commit 536f04e354
3 changed files with 16 additions and 0 deletions

View File

@@ -54,4 +54,5 @@ parcelable LayerCommand {
@nullable android.hardware.graphics.composer3.WhitePointNits whitePointNits;
@nullable android.hardware.graphics.composer3.PerFrameMetadata[] perFrameMetadata;
@nullable android.hardware.graphics.composer3.PerFrameMetadataBlob[] perFrameMetadataBlob;
@nullable android.hardware.graphics.common.Rect[] blockingRegion;
}

View File

@@ -264,4 +264,15 @@ parcelable LayerCommand {
* This command may be called every frame.
*/
@nullable PerFrameMetadataBlob[] perFrameMetadataBlob;
/**
* Specifies a region of the layer that is transparent and may be skipped
* by the DPU, e.g. using a blocking region, in order to save power. This
* is only a hint, so the composition of the layer must look the same
* whether or not this region is skipped.
*
* The region is in screen space and must not exceed the dimensions of
* the screen.
*/
@nullable Rect[] blockingRegion;
}

View File

@@ -213,6 +213,10 @@ class ComposerClientWriter {
.whitePointNits.emplace(WhitePointNits{.nits = whitePointNits});
}
void setLayerBlockingRegion(int64_t display, int64_t layer, const std::vector<Rect>& blocking) {
getLayerCommand(display, layer).blockingRegion.emplace(blocking.begin(), blocking.end());
}
const std::vector<DisplayCommand>& getPendingCommands() {
flushLayerCommand();
flushDisplayCommand();