msm: mdss: release all overlay resources on last fb release

There are cases where the last frame buffer reference is released from a
different pid than the one who originally allocated the resource.
In these cases we can still deallocate all resources currently allocated
as we know that all references on fb dev have been released.

This issue was previously fixed by a42150bd. But later it again resurfaced
with 831a828.

Change-Id: Ie35194b1e11ae90ff886b1be22cf02c842a76d1a
Signed-off-by: Ujwal Patel <ujwalp@codeaurora.org>
diff --git a/drivers/video/msm/mdss/mdss_fb.c b/drivers/video/msm/mdss/mdss_fb.c
index 81473db..80f7892 100644
--- a/drivers/video/msm/mdss/mdss_fb.c
+++ b/drivers/video/msm/mdss/mdss_fb.c
@@ -1176,6 +1176,8 @@
 	struct mdss_fb_proc_info *pinfo = NULL, *temp_pinfo = NULL;
 	int ret = 0;
 	int pid = current->tgid;
+	bool unknown_pid = true;
+	struct task_struct *task;
 
 	if (!mfd->ref_cnt) {
 		pr_info("try to close unopened fb %d!\n", mfd->index);
@@ -1190,6 +1192,7 @@
 		if (!release_all && (pinfo->pid != pid))
 			continue;
 
+		unknown_pid = false;
 		pr_debug("found process entry pid=%d ref=%d\n", pinfo->pid,
 			pinfo->ref_cnt);
 
@@ -1215,6 +1218,20 @@
 		}
 	}
 
+	if (unknown_pid) {
+		task = current->group_leader;
+		pr_debug("unknown process %s pid=%d mfd->ref_cnt=%d\n",
+			task->comm, pid, mfd->ref_cnt);
+
+		mfd->ref_cnt--;
+		if (mfd->mdp.release_fnc) {
+			ret = mfd->mdp.release_fnc(mfd);
+			if (ret)
+				pr_err("error releasing fb%d pid=%d\n",
+					mfd->index, pinfo->pid);
+		}
+	}
+
 	if (!mfd->ref_cnt) {
 		ret = mdss_fb_blank_sub(FB_BLANK_POWERDOWN, info,
 			mfd->op_enable);