android_kernel_google_msm/net/ceph
Josh Durgin 542a39ac9d libceph: resend all writes after the osdmap loses the full flag
commit 9a1ea2dbff upstream.

With the current full handling, there is a race between osds and
clients getting the first map marked full. If the osd wins, it will
return -ENOSPC to any writes, but the client may already have writes
in flight. This results in the client getting the error and
propagating it up the stack. For rbd, the block layer turns this into
EIO, which can cause corruption in filesystems above it.

To avoid this race, osds are being changed to drop writes that came
from clients with an osdmap older than the last osdmap marked full.
In order for this to work, clients must resend all writes after they
encounter a full -> not full transition in the osdmap. osds will wait
for an updated map instead of processing a request from a client with
a newer map, so resent writes will not be dropped by the osd unless
there is another not full -> full transition.

This approach requires both osds and clients to be fixed to avoid the
race. Old clients talking to osds with this fix may hang instead of
returning EIO and potentially corrupting an fs. New clients talking to
old osds have the same behavior as before if they encounter this race.

Fixes: http://tracker.ceph.com/issues/6938

Reviewed-by: Sage Weil <sage@inktank.com>
Signed-off-by: Josh Durgin <josh.durgin@inktank.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2014-03-30 21:40:30 -07:00
..
crush crush: fix memory leak when destroying tree buckets 2012-11-26 11:38:03 -08:00
armor.c libceph: Fix base64-decoding when input ends in newline. 2011-03-15 09:14:02 -07:00
auth.c libceph: wrap auth methods in a mutex 2013-06-20 11:58:47 -07:00
auth_none.c libceph: Fix NULL pointer dereference in auth client code 2013-07-13 11:03:40 -07:00
auth_none.h
auth_x.c libceph: wrap auth ops in wrapper functions 2013-06-20 11:58:47 -07:00
auth_x.h libceph: add update_authorizer auth method 2013-06-20 11:58:46 -07:00
auth_x_protocol.h
buffer.c
ceph_common.c libceph: remove 'osdtimeout' option 2013-01-17 08:51:20 -08:00
ceph_fs.c ceph: fix file mode calculation 2011-07-19 11:25:04 -07:00
ceph_hash.c
ceph_strings.c
crypto.c libceph: fix crypto key null deref, memory leak 2012-11-26 11:38:42 -08:00
crypto.h libceph: fix crypto key null deref, memory leak 2012-11-26 11:38:42 -08:00
debugfs.c libceph: delay debugfs initialization until we learn global_id 2012-11-26 11:38:43 -08:00
Kconfig ceph: use kernel DNS resolver 2011-10-25 16:10:16 -07:00
Makefile
messenger.c libceph: clear messenger auth_retry flag when we authenticate 2013-06-20 11:58:46 -07:00
mon_client.c libceph: wrap auth ops in wrapper functions 2013-06-20 11:58:47 -07:00
msgpool.c libceph: initialize msgpool message types 2012-11-26 11:38:38 -08:00
osd_client.c libceph: resend all writes after the osdmap loses the full flag 2014-03-30 21:40:30 -07:00
osdmap.c libceph: fix osdmap decode error paths 2013-01-17 08:51:19 -08:00
pagelist.c
pagevec.c