hwc: Call MSMFB_DISPLAY_COMMIT even if FB handle is null.
Call MSMFB_DISPLAY_COMMIT for primary FB even if FB handle is null.
This is already done for external FB.
Change-Id: I5c405f933ce0fd99df6813acea45169802c54226
diff --git a/libgralloc/framebuffer.cpp b/libgralloc/framebuffer.cpp
index 961d2b6..3f67e5e 100644
--- a/libgralloc/framebuffer.cpp
+++ b/libgralloc/framebuffer.cpp
@@ -86,24 +86,15 @@
static int fb_post(struct framebuffer_device_t* dev, buffer_handle_t buffer)
{
-
- fb_context_t* ctx = (fb_context_t*) dev;
-
- private_handle_t *hnd = static_cast<private_handle_t*>
- (const_cast<native_handle_t*>(buffer));
private_module_t* m =
reinterpret_cast<private_module_t*>(dev->common.module);
-
- if (hnd) {
- m->info.activate = FB_ACTIVATE_VBL | FB_ACTIVATE_FORCE;
- m->info.yoffset = hnd->offset / m->finfo.line_length;
- m->commit.var = m->info;
- m->commit.flags |= MDP_DISPLAY_COMMIT_OVERLAY;
- if (ioctl(m->framebuffer->fd, MSMFB_DISPLAY_COMMIT, &m->commit) == -1) {
- ALOGE("%s: MSMFB_DISPLAY_COMMIT ioctl failed, err: %s", __FUNCTION__,
- strerror(errno));
- return -errno;
- }
+ struct mdp_display_commit prim_commit;
+ memset(&prim_commit, 0, sizeof(struct mdp_display_commit));
+ prim_commit.flags = MDP_DISPLAY_COMMIT_OVERLAY;
+ if (ioctl(m->framebuffer->fd, MSMFB_DISPLAY_COMMIT, &prim_commit) == -1) {
+ ALOGE("%s: MSMFB_DISPLAY_COMMIT for primary failed, str: %s",
+ __FUNCTION__, strerror(errno));
+ return -errno;
}
return 0;
}
diff --git a/libhwcomposer/hwc.cpp b/libhwcomposer/hwc.cpp
index 130f263..6a0e0ee 100644
--- a/libhwcomposer/hwc.cpp
+++ b/libhwcomposer/hwc.cpp
@@ -332,10 +332,10 @@
ret = -1;
}
}
- if (ctx->mFbDev->post(ctx->mFbDev, fbLayer->handle)) {
- ALOGE("%s: ctx->mFbDev->post fail!", __FUNCTION__);
- return -1;
- }
+ }
+ if (ctx->mFbDev->post(ctx->mFbDev, fbLayer->handle)) {
+ ALOGE("%s: ctx->mFbDev->post fail!", __FUNCTION__);
+ return -1;
}
}
return ret;