From 7d8bf14e48a12079ddda5b9d579b62afc80f9e9f Mon Sep 17 00:00:00 2001 From: Zhen Kong <zkong@codeaurora.org> Date: Mon, 27 Feb 2017 13:41:07 -0800 Subject: [PATCH] qseecom: add mutex around qseecom_set_client_mem_param Add mutex around qseecom_set_client_mem_param to prevent an ioctl thread modifying and corrupting data which is being processed by another ioctl in the other thread Bug: 34327981 Change-Id: I0cfb8afab4001c2913be693dfe44c761b9568893 Signed-off-by: Zhen Kong <zkong@codeaurora.org> --- drivers/misc/qseecom.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/drivers/misc/qseecom.c b/drivers/misc/qseecom.c index 282238ee6bfc..5dc73eecb3cf 100644 --- a/drivers/misc/qseecom.c +++ b/drivers/misc/qseecom.c @@ -3871,7 +3871,11 @@ static long qseecom_ioctl(struct file *file, unsigned cmd, break; } pr_debug("SET_MEM_PARAM: qseecom addr = 0x%x\n", (u32)data); + mutex_lock(&app_access_lock); + atomic_inc(&data->ioctl_count); ret = qseecom_set_client_mem_param(data, argp); + atomic_dec(&data->ioctl_count); + mutex_unlock(&app_access_lock); if (ret) pr_err("failed Qqseecom_set_mem_param request: %d\n", ret); -- GitLab