smcinvoke : file private data validation which is sent by userspace
a validation added to check whether retrieved struct smcinvoke_file_data inside the function get_server_id belongs to g_smcinvoke_fops or not. Change-Id: I50bce93ab89759b4fdcb76e41f699d8199771fbd Signed-off-by: Pavan Bobba <quic_pav@quicinc.com>
This commit is contained in:

committed by
Gerrit - the friendly Code Review server

parent
56d39957f0
commit
d577197ff2
@@ -625,15 +625,13 @@ static uint16_t get_server_id(int cb_server_fd)
|
||||
struct smcinvoke_file_data *svr_cxt = NULL;
|
||||
struct file *tmp_filp = fget(cb_server_fd);
|
||||
|
||||
if (!tmp_filp)
|
||||
if (!tmp_filp || !FILE_IS_REMOTE_OBJ(tmp_filp))
|
||||
return server_id;
|
||||
|
||||
svr_cxt = tmp_filp->private_data;
|
||||
if (svr_cxt && svr_cxt->context_type == SMCINVOKE_OBJ_TYPE_SERVER)
|
||||
server_id = svr_cxt->server_id;
|
||||
|
||||
if (tmp_filp)
|
||||
fput(tmp_filp);
|
||||
fput(tmp_filp);
|
||||
|
||||
return server_id;
|
||||
}
|
||||
|
Reference in New Issue
Block a user