提交 8d44c98a 编写于 作者: J Joe Thornber 提交者: Alasdair G Kergon

dm persistent data: always unlock superblock in dm_bm_flush_and_unlock

Unlock the superblock even if initial dm_bufio_write_dirty_buffers fails.

Also, remove redundant flush calls.  dm_bm_flush_and_unlock's calls to
dm_bufio_write_dirty_buffers already result in dm_bufio_issue_flush
being called.

This avoids warnings about unflushed dirty buffers from bufio.
Signed-off-by: NJoe Thornber <ejt@redhat.com>
Signed-off-by: NMike Snitzer <snitzer@redhat.com>
Signed-off-by: NAlasdair G Kergon <agk@redhat.com>
上级 60049701
...@@ -587,22 +587,14 @@ int dm_bm_flush_and_unlock(struct dm_block_manager *bm, ...@@ -587,22 +587,14 @@ int dm_bm_flush_and_unlock(struct dm_block_manager *bm,
int r; int r;
r = dm_bufio_write_dirty_buffers(to_bufio(bm)); r = dm_bufio_write_dirty_buffers(to_bufio(bm));
if (unlikely(r)) if (unlikely(r)) {
return r; dm_bm_unlock(superblock);
r = dm_bufio_issue_flush(to_bufio(bm));
if (unlikely(r))
return r; return r;
}
dm_bm_unlock(superblock); dm_bm_unlock(superblock);
r = dm_bufio_write_dirty_buffers(to_bufio(bm)); return dm_bufio_write_dirty_buffers(to_bufio(bm));
if (unlikely(r))
return r;
r = dm_bufio_issue_flush(to_bufio(bm));
if (unlikely(r))
return r;
return 0;
} }
u32 dm_bm_checksum(const void *data, size_t len, u32 init_xor) u32 dm_bm_checksum(const void *data, size_t len, u32 init_xor)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册
新手
引导
客服 返回
顶部