summaryrefslogtreecommitdiff
path: root/drivers/md/dm-thin-metadata.h
diff options
context:
space:
mode:
authorDavid Jeffery <djeffery@redhat.com>2019-09-16 20:15:14 +0300
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2019-12-17 21:56:14 +0300
commitf020809b8450598ae7ae83d7f480463acf9486ac (patch)
treed3af3d032a3be86221ed870ef722a45c50fff07c /drivers/md/dm-thin-metadata.h
parenta11fab7708329fd902d721fe8f2b1b628da35de9 (diff)
downloadlinux-f020809b8450598ae7ae83d7f480463acf9486ac.tar.xz
md: improve handling of bio with REQ_PREFLUSH in md_flush_request()
commit 775d78319f1ceb32be8eb3b1202ccdc60e9cb7f1 upstream. If pers->make_request fails in md_flush_request(), the bio is lost. To fix this, pass back a bool to indicate if the original make_request call should continue to handle the I/O and instead of assuming the flush logic will push it to completion. Convert md_flush_request to return a bool and no longer calls the raid driver's make_request function. If the return is true, then the md flush logic has or will complete the bio and the md make_request call is done. If false, then the md make_request function needs to keep processing like it is a normal bio. Let the original call to md_handle_request handle any need to retry sending the bio to the raid driver's make_request function should it be needed. Also mark md_flush_request and the make_request function pointer as __must_check to issue warnings should these critical return values be ignored. Fixes: 2bc13b83e629 ("md: batch flush requests.") Cc: stable@vger.kernel.org # # v4.19+ Cc: NeilBrown <neilb@suse.com> Signed-off-by: David Jeffery <djeffery@redhat.com> Reviewed-by: Xiao Ni <xni@redhat.com> Signed-off-by: Song Liu <songliubraving@fb.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/md/dm-thin-metadata.h')
0 files changed, 0 insertions, 0 deletions