diff options
author | Qiang Yu <[email protected]> | 2019-08-25 17:24:26 +0800 |
---|---|---|
committer | Qiang Yu <[email protected]> | 2019-09-23 09:48:50 +0800 |
commit | 4ed569eed771a1b70b485430c8b595d817232b1c (patch) | |
tree | 1089f5acc80baf34a14f922d15cad6d7135db4fd /src/gallium/drivers/lima | |
parent | afbaed906d7ba89467b177e768c36f29d6053ad0 (diff) |
lima: don't use damage system when full damage
Some time weston set full damage region. It is
more effient to use the cached pp stream instead
of dynamically create one.
Reviewed-and-Tested-by: Vasily Khoruzhick <[email protected]>
Signed-off-by: Qiang Yu <[email protected]>
Diffstat (limited to 'src/gallium/drivers/lima')
-rw-r--r-- | src/gallium/drivers/lima/lima_resource.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/gallium/drivers/lima/lima_resource.c b/src/gallium/drivers/lima/lima_resource.c index b2e33f4d3ff..2f9081c3d11 100644 --- a/src/gallium/drivers/lima/lima_resource.c +++ b/src/gallium/drivers/lima/lima_resource.c @@ -365,6 +365,20 @@ lima_resource_set_damage_region(struct pipe_screen *pscreen, if (!nrects) return; + /* check full damage + * + * TODO: currently only check if there is any single damage + * region that can cover the full render target; there may + * be some accurate way, but a single window size damage + * region is most of the case from weston + */ + for (i = 0; i < nrects; i++) { + if (rects[i].x <= 0 && rects[i].y <= 0 && + rects[i].x + rects[i].width >= pres->width0 && + rects[i].y + rects[i].height >= pres->height0) + return; + } + damage->region = CALLOC(nrects, sizeof(*damage->region)); if (!damage->region) return; |