diff options
author | Sage Weil <sage@newdream.net> | 2010-03-16 21:39:28 +0100 |
---|---|---|
committer | Sage Weil <sage@newdream.net> | 2010-03-23 15:46:53 +0100 |
commit | cdc2ce056a3620139056b60ad7f6d355ad13f445 (patch) | |
tree | 1aed7f66612d13beeeec6e2c191f19eff44d1054 /fs/select.c | |
parent | ceph: drop unnecessary WARN_ON in caps migration (diff) | |
download | linux-cdc2ce056a3620139056b60ad7f6d355ad13f445.tar.xz linux-cdc2ce056a3620139056b60ad7f6d355ad13f445.zip |
ceph: fix session locking in handle_caps, ceph_check_caps
Passing a session pointer to ceph_check_caps() used to mean it would leave
the session mutex locked. That wasn't always possible if it wasn't passed
CHECK_CAPS_AUTHONLY. If could unlock the passed session and lock a
differet session mutex, which was clearly wrong, and also emitted a
warning when it a racing CPU retook it and we did an unlock from the wrong
context.
This was only a problem when there was more than one MDS.
First, make ceph_check_caps unconditionally drop the session mutex, so that
it is free to lock other sessions as needed. Then adjust the one caller
that passes in a session (handle_cap_grant) accordingly.
Signed-off-by: Sage Weil <sage@newdream.net>
Diffstat (limited to 'fs/select.c')
0 files changed, 0 insertions, 0 deletions