summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Yao <mark.yao@rock-chips.com>2016-07-01 19:10:34 +0000
committerandroid-build-merger <android-build-merger@google.com>2016-07-01 19:10:34 +0000
commite19443ea00d3b27622590b920819e53da68f7fda (patch)
tree7540263fd9441ccfd4de8b7c4dc378f1e34197e1
parentcda66b80878c0c0f0799a145b41895c1149da88a (diff)
parent19d91eec5357e7cebde797a48de8609ae3a89484 (diff)
downloaddrm_gralloc-e19443ea00d3b27622590b920819e53da68f7fda.tar.gz
am: 19d91eec53 Change-Id: I4e23e80ed6b8fdec3d5cfb983427591b8ab4597e
-rw-r--r--gralloc_drm.cpp11
1 files changed, 10 insertions, 1 deletions
diff --git a/gralloc_drm.cpp b/gralloc_drm.cpp
index 6f90a84..b0328b0 100644
--- a/gralloc_drm.cpp
+++ b/gralloc_drm.cpp
@@ -194,7 +194,15 @@ static struct gralloc_drm_bo_t *validate_handle(buffer_handle_t _handle,
*/
int gralloc_drm_handle_register(buffer_handle_t handle, struct gralloc_drm_t *drm)
{
- return (validate_handle(handle, drm)) ? 0 : -EINVAL;
+ struct gralloc_drm_bo_t *bo;
+
+ bo = validate_handle(handle, drm);
+ if (!bo)
+ return -EINVAL;
+
+ bo->refcount++;
+
+ return 0;
}
/*
@@ -208,6 +216,7 @@ int gralloc_drm_handle_unregister(buffer_handle_t handle)
if (!bo)
return -EINVAL;
+ gralloc_drm_bo_decref(bo);
if (bo->imported)
gralloc_drm_bo_decref(bo);