diff options
| author | 2012-03-26 17:32:44 -0700 | |
|---|---|---|
| committer | 2012-03-28 09:54:34 -0700 | |
| commit | b18dafc86bb879d2f38a1743985d7ceb283c2f4d (patch) | |
| tree | 447070f77406615aebadaef03018d634c0da922c /tools/perf/scripts/python/sched-migration.py | |
| parent | Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux (diff) | |
| download | wireguard-linux-b18dafc86bb879d2f38a1743985d7ceb283c2f4d.tar.xz wireguard-linux-b18dafc86bb879d2f38a1743985d7ceb283c2f4d.zip | |
vfs: fix d_ancestor() case in d_materialize_unique
In d_materialise_unique() there are 3 subcases to the 'aliased dentry'
case; in two subcases the inode i_lock is properly released but this
does not occur in the -ELOOP subcase.
This seems to have been introduced by commit 1836750115f2 ("fix loop
checks in d_materialise_unique()").
Signed-off-by: Michel Lespinasse <walken@google.com>
Cc: stable@vger.kernel.org # v3.0+
[ Added a comment, and moved the unlock to where we generate the -ELOOP,
  which seems to be more natural.
  You probably can't actually trigger this without a buggy network file
  server - d_materialize_unique() is for finding aliases on non-local
  filesystems, and the d_ancestor() case is for a hardlinked directory
  loop.
  But we should be robust in the case of such buggy servers anyway. ]
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'tools/perf/scripts/python/sched-migration.py')
0 files changed, 0 insertions, 0 deletions
