diff options
| author | Sage Weil <sage@inktank.com> | 2012-05-16 15:16:38 -0500 | 
|---|---|---|
| committer | Sage Weil <sage@inktank.com> | 2012-05-18 17:36:00 -0700 | 
| commit | 35f9f8a09e1e88e31bd34a1e645ca0e5f070dd5c (patch) | |
| tree | c7bc4a1dba445ea2e250decbf9b88282ee37cb3f /lib/cpu-notifier-error-inject.c | |
| parent | 3da54776e2c0385c32d143fd497a7f40a88e29dd (diff) | |
libceph: avoid unregistering osd request when not registered
There is a race between two __unregister_request() callers: the
reply path and the ceph_osdc_wait_request().  If we get a reply
*and* the timeout expires at roughly the same time, both callers
will try to unregister the request, and the second one will do bad
things.
Simply check if the request is still already unregistered; if so,
return immediately and do nothing.
Fixes http://tracker.newdream.net/issues/2420
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Alex Elder <elder@inktank.com>
Diffstat (limited to 'lib/cpu-notifier-error-inject.c')
0 files changed, 0 insertions, 0 deletions
