mirror of
https://github.com/torvalds/linux.git
synced 2026-06-10 07:32:29 +02:00
libceph: (re)initialize bio_iter on start of message receive
(cherry picked from commit a410702697)
Previously, we were opportunistically initializing the bio_iter if it
appeared to be uninitialized in the middle of the read path. The problem
is that a sequence like:
- start reading message
- initialize bio_iter
- read half a message
- messenger fault, reconnect
- restart reading message
- ** bio_iter now non-NULL, not reinitialized **
- read past end of bio, crash
Instead, initialize the bio_iter unconditionally when we allocate/claim
the message for read.
Signed-off-by: Sage Weil <sage@inktank.com>
Reviewed-by: Alex Elder <elder@inktank.com>
Reviewed-by: Yehuda Sadeh <yehuda@inktank.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
d43841ef76
commit
175c4c20d2
|
|
@ -1872,6 +1872,11 @@ static int read_partial_message(struct ceph_connection *con)
|
|||
else
|
||||
con->in_msg_pos.page_pos = 0;
|
||||
con->in_msg_pos.data_pos = 0;
|
||||
|
||||
#ifdef CONFIG_BLOCK
|
||||
if (m->bio)
|
||||
init_bio_iter(m->bio, &m->bio_iter, &m->bio_seg);
|
||||
#endif
|
||||
}
|
||||
|
||||
/* front */
|
||||
|
|
@ -1888,10 +1893,6 @@ static int read_partial_message(struct ceph_connection *con)
|
|||
if (ret <= 0)
|
||||
return ret;
|
||||
}
|
||||
#ifdef CONFIG_BLOCK
|
||||
if (m->bio && !m->bio_iter)
|
||||
init_bio_iter(m->bio, &m->bio_iter, &m->bio_seg);
|
||||
#endif
|
||||
|
||||
/* (page) data */
|
||||
while (con->in_msg_pos.data_pos < data_len) {
|
||||
|
|
@ -1902,7 +1903,7 @@ static int read_partial_message(struct ceph_connection *con)
|
|||
return ret;
|
||||
#ifdef CONFIG_BLOCK
|
||||
} else if (m->bio) {
|
||||
|
||||
BUG_ON(!m->bio_iter);
|
||||
ret = read_partial_message_bio(con,
|
||||
&m->bio_iter, &m->bio_seg,
|
||||
data_len, do_datacrc);
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user