summaryrefslogtreecommitdiff
path: root/scripts/gcc-plugins/structleak_plugin.c
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2023-10-31 07:23:35 +0300
committerAl Viro <viro@zeniv.linux.org.uk>2023-11-25 10:33:42 +0300
commitb06c684d3984ef64e792ec3e89889c96cab97b5e (patch)
treec1f0d16c9ac339a158c33fcb7240250d5019abf8 /scripts/gcc-plugins/structleak_plugin.c
parentee0c82503dcd0d14cc1ad53da18d32a04f612c4c (diff)
downloadlinux-b06c684d3984ef64e792ec3e89889c96cab97b5e.tar.xz
dentry_kill(): don't bother with retain_dentry() on slow path
We have already checked it and dentry used to look not worthy of keeping. The only hard obstacle to evicting dentry is non-zero refcount; everything else is advisory - e.g. memory pressure could evict any dentry found with refcount zero. On the slow path in dentry_kill() we had dropped and regained ->d_lock; we must recheck the refcount, but everything else is not worth bothering with. Note that filesystem can not count upon ->d_delete() being called for dentry - not even once. Again, memory pressure (as well as d_prune_aliases(), or attempted rmdir() of ancestor, or...) will not call ->d_delete() at all. So from the correctness point of view we are fine doing the check only once. And it makes things simpler down the road. Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'scripts/gcc-plugins/structleak_plugin.c')
0 files changed, 0 insertions, 0 deletions