summaryrefslogtreecommitdiff
path: root/drivers/gpu/nvgpu/gk20a/channel_sync_gk20a.c
diff options
context:
space:
mode:
authorDeepak Nibade <dnibade@nvidia.com>2014-04-01 12:14:50 +0530
committerTerje Bergstrom <tbergstrom@nvidia.com>2014-04-07 02:40:20 -0700
commit66a3430f1785c40f7822087a8b5410ae3075829c (patch)
treec2c70c1f374c39eae831f645095c3057f58e72cf /drivers/gpu/nvgpu/gk20a/channel_sync_gk20a.c
parentc669750fadb752b7680de2db59a8c07735e712ab (diff)
gpu: nvgpu: gk20a: add syncpt id checks
add valid syncpt id checks when syncpt id is extracted from fence fd Bug 1448825 Change-Id: I0f1722aad60e7644b8f490f24cf18a3b80f8583c Signed-off-by: Deepak Nibade <dnibade@nvidia.com> Reviewed-on: http://git-master/r/390572 Reviewed-by: Terje Bergstrom <tbergstrom@nvidia.com>
Diffstat (limited to 'drivers/gpu/nvgpu/gk20a/channel_sync_gk20a.c')
-rw-r--r--drivers/gpu/nvgpu/gk20a/channel_sync_gk20a.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/drivers/gpu/nvgpu/gk20a/channel_sync_gk20a.c b/drivers/gpu/nvgpu/gk20a/channel_sync_gk20a.c
index 291036db93a9..851ae18b31bd 100644
--- a/drivers/gpu/nvgpu/gk20a/channel_sync_gk20a.c
+++ b/drivers/gpu/nvgpu/gk20a/channel_sync_gk20a.c
@@ -119,6 +119,16 @@ int gk20a_channel_syncpt_wait_fd(struct gk20a_channel_sync *s, int fd,
if (!sync_fence)
return -EINVAL;
+ /* validate syncpt ids */
+ list_for_each_entry(pt, &sync_fence->pt_list_head, pt_list) {
+ u32 wait_id = nvhost_sync_pt_id(pt);
+ if (!wait_id ||
+ wait_id >= nvhost_syncpt_nb_pts_ext(sp->host1x_pdev)) {
+ sync_fence_put(sync_fence);
+ return -EINVAL;
+ }
+ }
+
num_wait_cmds = nvhost_sync_num_pts(sync_fence);
gk20a_channel_alloc_priv_cmdbuf(c, 4 * num_wait_cmds, &wait_cmd);
if (wait_cmd == NULL) {