On 2016å¹´07æ??12æ?¥ 20:05, Christian König wrote: > From: Christian König <christian.koenig at amd.com> > > Otherwise we can run into the following situation: > > 1. Process A grabs ID 1 for ring 0. > 2. Process B grabs ID 1 for ring 0. > 3. Process A grabs ID 1 for ring 1. > 4. Process A tries to reuse ID1 for ring 0 but things he doesn't need to flush. > > v2: check the context of the flush fence instead of messing with the owner field. > > Signed-off-by: Christian König <christian.koenig at amd.com> The set is Reviewed-by: Chunming Zhou <david1.zhou at amd.com> > --- > drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c | 9 ++++++--- > 1 file changed, 6 insertions(+), 3 deletions(-) > > diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c > index f8615a4..57337d4 100644 > --- a/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c > +++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_vm.c > @@ -185,6 +185,7 @@ int amdgpu_vm_grab_id(struct amdgpu_vm *vm, struct amdgpu_ring *ring, > struct amdgpu_job *job) > { > struct amdgpu_device *adev = ring->adev; > + uint64_t fence_context = adev->fence_context + ring->idx; > struct fence *updates = sync->last_vm_update; > struct amdgpu_vm_id *id, *idle; > struct fence **fences; > @@ -244,7 +245,6 @@ int amdgpu_vm_grab_id(struct amdgpu_vm *vm, struct amdgpu_ring *ring, > i = ring->idx; > do { > struct fence *flushed; > - bool same_ring = ring->idx == i; > > id = vm->ids[i++]; > if (i == AMDGPU_MAX_RINGS) > @@ -262,8 +262,11 @@ int amdgpu_vm_grab_id(struct amdgpu_vm *vm, struct amdgpu_ring *ring, > if (job->vm_pd_addr != id->pd_gpu_addr) > continue; > > - if (!same_ring && > - (!id->last_flush || !fence_is_signaled(id->last_flush))) > + if (!id->last_flush) > + continue; > + > + if (id->last_flush->context != fence_context && > + !fence_is_signaled(id->last_flush)) > continue; > > flushed = id->flushed_updates;