summaryrefslogtreecommitdiffstats
path: root/hwc
diff options
context:
space:
mode:
authorJamie Gennis <jgennis@google.com>2011-11-09 12:44:07 -0800
committerAndroid Git Automerger <android-git-automerger@android.com>2011-11-11 11:48:08 -0800
commit9c9ebe25afb64c11ba414684a9e0a017a0eb5f56 (patch)
tree5103d6f517318135de49e6b1dfa44d8a729c76b9 /hwc
parent44b70e321b11782413ac4f05a395e9d67e446099 (diff)
downloadhardware_ti_omap4-9c9ebe25afb64c11ba414684a9e0a017a0eb5f56.zip
hardware_ti_omap4-9c9ebe25afb64c11ba414684a9e0a017a0eb5f56.tar.gz
hardware_ti_omap4-9c9ebe25afb64c11ba414684a9e0a017a0eb5f56.tar.bz2
HWC: Only invalidate on idle when blending
Change-Id: I6e07129502f59f26768895c30dcdb50b01011738
Diffstat (limited to 'hwc')
-rw-r--r--hwc/hwc.c36
1 files changed, 27 insertions, 9 deletions
diff --git a/hwc/hwc.c b/hwc/hwc.c
index 5eaa8ba..19fef2f 100644
--- a/hwc/hwc.c
+++ b/hwc/hwc.c
@@ -135,6 +135,7 @@ struct omap4_hwc_device {
int flags_rgb_order;
int flags_nv12_only;
int idle;
+ int ovls_blending;
int force_sgx;
};
@@ -1066,6 +1067,19 @@ static int omap4_hwc_prepare(struct hwc_composer_device *dev, hwc_layer_list_t*
}
}
+ /* see if any of the (non-backmost) overlays are doing blending */
+ hwc_dev->ovls_blending = 0;
+ for (i = 1; list && i < list->numHwLayers; i++) {
+ hwc_layer_t *layer = &list->hwLayers[i];
+ IMG_native_handle_t *handle = (IMG_native_handle_t *)layer->handle;
+ if (layer->compositionType == HWC_FRAMEBUFFER)
+ continue;
+ if ((layer->flags & HWC_SKIP_LAYER) || !layer->handle)
+ continue;
+ if (is_BLENDED(layer->blending))
+ hwc_dev->ovls_blending = 1;
+ }
+
/* if scaling GFX (e.g. only 1 scaled surface) use a VID pipe */
if (scaled_gfx)
dsscomp->ovls[0].cfg.ix = dsscomp->num_ovls;
@@ -1500,7 +1514,7 @@ static void *omap4_hwc_hdmi_thread(void *data)
omap4_hwc_device_t *hwc_dev = data;
static char uevent_desc[4096];
struct pollfd fds[2];
- int prev_force_sgx = 0;
+ int invalidate = 0;
int timeout;
int err;
@@ -1520,14 +1534,18 @@ static void *omap4_hwc_hdmi_thread(void *data)
if (err == 0) {
if (hwc_dev->idle) {
- pthread_mutex_lock(&hwc_dev->lock);
- prev_force_sgx = hwc_dev->force_sgx;
- hwc_dev->force_sgx = 2;
- pthread_mutex_unlock(&hwc_dev->lock);
-
- if (!prev_force_sgx && hwc_dev->procs && hwc_dev->procs->invalidate) {
- hwc_dev->procs->invalidate(hwc_dev->procs);
- timeout = -1;
+ if (hwc_dev->procs && hwc_dev->procs->invalidate) {
+ pthread_mutex_lock(&hwc_dev->lock);
+ invalidate = !hwc_dev->force_sgx && hwc_dev->ovls_blending;
+ if (invalidate) {
+ hwc_dev->force_sgx = 2;
+ }
+ pthread_mutex_unlock(&hwc_dev->lock);
+
+ if (invalidate) {
+ hwc_dev->procs->invalidate(hwc_dev->procs);
+ timeout = -1;
+ }
}
continue;