Revision f2efc6e60089c99c342a6b7da47f1037e06c4296 authored by Shirish S on 30 October 2019, 08:50:46 UTC, committed by Alex Deucher on 06 November 2019, 20:26:53 UTC
[Why]

doing kthread_park()/unpark() from drm_sched_entity_fini
while GPU reset is in progress defeats all the purpose of
drm_sched_stop->kthread_park.
If drm_sched_entity_fini->kthread_unpark() happens AFTER
drm_sched_stop->kthread_park nothing prevents from another
(third) thread to keep submitting job to HW which will be
picked up by the unparked scheduler thread and try to submit
to HW but fail because the HW ring is deactivated.

[How]
grab the reset lock before calling drm_sched_entity_fini()

Signed-off-by: Shirish S <shirish.s@amd.com>
Suggested-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Andrey Grodzovsky <andrey.grodzovsky@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
1 parent 576daab
History
File Mode Size
blocklayout
filelayout
flexfilelayout
Kconfig -rw-r--r-- 5.9 KB
Makefile -rw-r--r-- 1.3 KB
cache_lib.c -rw-r--r-- 3.8 KB
cache_lib.h -rw-r--r-- 1.0 KB
callback.c -rw-r--r-- 11.2 KB
callback.h -rw-r--r-- 5.3 KB
callback_proc.c -rw-r--r-- 18.9 KB
callback_xdr.c -rw-r--r-- 26.9 KB
client.c -rw-r--r-- 33.3 KB
delegation.c -rw-r--r-- 33.3 KB
delegation.h -rw-r--r-- 3.4 KB
dir.c -rw-r--r-- 66.3 KB
direct.c -rw-r--r-- 28.3 KB
dns_resolve.c -rw-r--r-- 10.3 KB
dns_resolve.h -rw-r--r-- 851 bytes
export.c -rw-r--r-- 4.1 KB
file.c -rw-r--r-- 21.7 KB
fscache-index.c -rw-r--r-- 3.9 KB
fscache.c -rw-r--r-- 14.0 KB
fscache.h -rw-r--r-- 6.7 KB
getroot.c -rw-r--r-- 3.3 KB
inode.c -rw-r--r-- 62.3 KB
internal.h -rw-r--r-- 23.9 KB
io.c -rw-r--r-- 4.1 KB
iostat.h -rw-r--r-- 1.8 KB
mount_clnt.c -rw-r--r-- 12.4 KB
namespace.c -rw-r--r-- 7.0 KB
netns.h -rw-r--r-- 1006 bytes
nfs.h -rw-r--r-- 1.0 KB
nfs2super.c -rw-r--r-- 610 bytes
nfs2xdr.c -rw-r--r-- 26.0 KB
nfs3_fs.h -rw-r--r-- 1.1 KB
nfs3acl.c -rw-r--r-- 7.9 KB
nfs3client.c -rw-r--r-- 3.2 KB
nfs3proc.c -rw-r--r-- 25.3 KB
nfs3super.c -rw-r--r-- 690 bytes
nfs3xdr.c -rw-r--r-- 55.7 KB
nfs42.h -rw-r--r-- 968 bytes
nfs42proc.c -rw-r--r-- 23.9 KB
nfs42xdr.c -rw-r--r-- 20.7 KB
nfs4_fs.h -rw-r--r-- 20.3 KB
nfs4client.c -rw-r--r-- 33.0 KB
nfs4file.c -rw-r--r-- 7.1 KB
nfs4getroot.c -rw-r--r-- 1011 bytes
nfs4idmap.c -rw-r--r-- 19.9 KB
nfs4idmap.h -rw-r--r-- 2.7 KB
nfs4namespace.c -rw-r--r-- 12.7 KB
nfs4proc.c -rw-r--r-- 267.8 KB
nfs4renewd.c -rw-r--r-- 4.7 KB
nfs4session.c -rw-r--r-- 16.8 KB
nfs4session.h -rw-r--r-- 5.2 KB
nfs4state.c -rw-r--r-- 68.8 KB
nfs4super.c -rw-r--r-- 8.7 KB
nfs4sysctl.c -rw-r--r-- 1.4 KB
nfs4trace.c -rw-r--r-- 912 bytes
nfs4trace.h -rw-r--r-- 53.4 KB
nfs4xdr.c -rw-r--r-- 197.8 KB
nfsroot.c -rw-r--r-- 9.5 KB
nfstrace.c -rw-r--r-- 374 bytes
nfstrace.h -rw-r--r-- 30.3 KB
pagelist.c -rw-r--r-- 34.3 KB
pnfs.c -rw-r--r-- 82.3 KB
pnfs.h -rw-r--r-- 25.0 KB
pnfs_dev.c -rw-r--r-- 9.9 KB
pnfs_nfs.c -rw-r--r-- 23.7 KB
proc.c -rw-r--r-- 18.9 KB
read.c -rw-r--r-- 12.2 KB
super.c -rw-r--r-- 77.9 KB
symlink.c -rw-r--r-- 1.8 KB
sysctl.c -rw-r--r-- 1.3 KB
sysfs.c -rw-r--r-- 4.1 KB
sysfs.h -rw-r--r-- 497 bytes
unlink.c -rw-r--r-- 14.0 KB
write.c -rw-r--r-- 57.4 KB

back to top