diff options
author | Jammy Zhou <Jammy.Zhou@amd.com> | 2015-05-08 05:29:40 -0400 |
---|---|---|
committer | Alex Deucher <alexander.deucher@amd.com> | 2015-06-03 21:03:29 -0400 |
commit | 66b3cf2ab38f47db2d07fe24a00972fbf822cd74 (patch) | |
tree | 6082b677c1369f69094a4540546f0b3d0affb3d0 /drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c | |
parent | 74a5d1656e165d5457be64b4d78d3259c2946e93 (diff) |
drm/amdgpu: add ctx_id to the WAIT_CS IOCTL (v4)
It is required to support fence per context.
v2: add amdgpu_ctx_get/put
v3: improve get/put
v4: squash hlock fix
Signed-off-by: Jammy Zhou <Jammy.Zhou@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Diffstat (limited to 'drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c')
-rw-r--r-- | drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c index ffbe9aa9f232..86b93245bf9d 100644 --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_cs.c | |||
@@ -768,8 +768,13 @@ int amdgpu_cs_wait_ioctl(struct drm_device *dev, void *data, | |||
768 | uint64_t seq[AMDGPU_MAX_RINGS] = {0}; | 768 | uint64_t seq[AMDGPU_MAX_RINGS] = {0}; |
769 | struct amdgpu_ring *ring = NULL; | 769 | struct amdgpu_ring *ring = NULL; |
770 | unsigned long timeout = amdgpu_gem_timeout(wait->in.timeout); | 770 | unsigned long timeout = amdgpu_gem_timeout(wait->in.timeout); |
771 | struct amdgpu_ctx *ctx; | ||
771 | long r; | 772 | long r; |
772 | 773 | ||
774 | ctx = amdgpu_ctx_get(filp->driver_priv, wait->in.ctx_id); | ||
775 | if (ctx == NULL) | ||
776 | return -EINVAL; | ||
777 | |||
773 | r = amdgpu_cs_get_ring(adev, wait->in.ip_type, wait->in.ip_instance, | 778 | r = amdgpu_cs_get_ring(adev, wait->in.ip_type, wait->in.ip_instance, |
774 | wait->in.ring, &ring); | 779 | wait->in.ring, &ring); |
775 | if (r) | 780 | if (r) |
@@ -778,6 +783,7 @@ int amdgpu_cs_wait_ioctl(struct drm_device *dev, void *data, | |||
778 | seq[ring->idx] = wait->in.handle; | 783 | seq[ring->idx] = wait->in.handle; |
779 | 784 | ||
780 | r = amdgpu_fence_wait_seq_timeout(adev, seq, true, timeout); | 785 | r = amdgpu_fence_wait_seq_timeout(adev, seq, true, timeout); |
786 | amdgpu_ctx_put(ctx); | ||
781 | if (r < 0) | 787 | if (r < 0) |
782 | return r; | 788 | return r; |
783 | 789 | ||