Jens, These patches address potential issues with zone write plugging. The first 2 patches fix handling of REQ_NOWAIT BIOs as these can be "failed" after going through the zone write plugging and changing the target zone plug zone write pointer offset. Patch 3 is a bigger fix and address a potential deadlock issue due to the zone write plugging internally issuing zone report operations to recover from write errors. This zone report operation is removed by this patch and replaced with an automatic recovery when the BIO issuer execute a zone report. This change in behavior results in a problem with REQ_OP_WRITE_ZEROES handling and failures in the dm-zoned device mapper. That is fixed in patch 4. I will followup these fixes with a cleanup of the report zones API and its callback function interface to clean it up as patch 4 introduces an indirect user callback call that is not very pretty. Changes from v2: - Added review tags from Christoph to patch 1 and 2. - Reversed the order of patch 3 and 4. Patch 3 now includes some code that was implemented in "block: Prevent potential deadlocks in zone write plug error recovery" in v2. - Adjusted and improved the commit messages of patch 3 and 4. Changes from v1: - Fixed kdoc comment for blkdev_issue_zone_zeroout() in patch 4 Damien Le Moal (4): block: Use a zone write plug BIO work for REQ_NOWAIT BIOs block: Ignore REQ_NOWAIT for zone reset and zone finish operations dm: Fix dm-zoned-reclaim zone write pointer alignment block: Prevent potential deadlocks in zone write plug error recovery block/blk-zoned.c | 506 +++++++++++++++------------------- drivers/md/dm-zoned-reclaim.c | 6 +- include/linux/blkdev.h | 5 +- 3 files changed, 229 insertions(+), 288 deletions(-) -- 2.47.1