null_blk: replace null_process_cmd() call in null_zone_write()
authorShin'ichiro Kawasaki <shinichiro.kawasaki@wdc.com>
Wed, 26 Feb 2025 10:06:11 +0000 (19:06 +0900)
committerJens Axboe <axboe@kernel.dk>
Mon, 3 Mar 2025 18:17:52 +0000 (11:17 -0700)
As a preparation to support partial data transfer due to badblocks,
replace the null_process_cmd() call in null_zone_write() with equivalent
calls to null_handle_badblocks() and null_handle_memory_backed(). This
commit does not change behavior. It will enable null_handle_badblocks()
to return the size of partial data transfer in the following commit,
allowing null_zone_write() to move write pointers appropriately.

Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com>
Signed-off-by: Shin'ichiro Kawasaki <shinichiro.kawasaki@wdc.com>
Link: https://lore.kernel.org/r/20250226100613.1622564-4-shinichiro.kawasaki@wdc.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
drivers/block/null_blk/main.c
drivers/block/null_blk/null_blk.h
drivers/block/null_blk/zoned.c

index 2a060a6ea8c0b1c296067758103318c4854599f5..87037cb375c94e5767ad070f04eacabfa28e47de 100644 (file)
@@ -1309,9 +1309,8 @@ static inline blk_status_t null_handle_throttled(struct nullb_cmd *cmd)
        return sts;
 }
 
-static inline blk_status_t null_handle_badblocks(struct nullb_cmd *cmd,
-                                                sector_t sector,
-                                                sector_t nr_sectors)
+blk_status_t null_handle_badblocks(struct nullb_cmd *cmd, sector_t sector,
+                                  sector_t nr_sectors)
 {
        struct badblocks *bb = &cmd->nq->dev->badblocks;
        sector_t first_bad;
@@ -1326,10 +1325,8 @@ static inline blk_status_t null_handle_badblocks(struct nullb_cmd *cmd,
        return BLK_STS_IOERR;
 }
 
-static inline blk_status_t null_handle_memory_backed(struct nullb_cmd *cmd,
-                                                    enum req_op op,
-                                                    sector_t sector,
-                                                    sector_t nr_sectors)
+blk_status_t null_handle_memory_backed(struct nullb_cmd *cmd, enum req_op op,
+                                      sector_t sector, sector_t nr_sectors)
 {
        struct nullb_device *dev = cmd->nq->dev;
 
index 3c4c07f0418b06593a3074843316c249be3d05f8..ee60f3a8879671d62a42cbdd72dfc88e72aba35a 100644 (file)
@@ -132,6 +132,11 @@ blk_status_t null_handle_discard(struct nullb_device *dev, sector_t sector,
                                 sector_t nr_sectors);
 blk_status_t null_process_cmd(struct nullb_cmd *cmd, enum req_op op,
                              sector_t sector, unsigned int nr_sectors);
+blk_status_t null_handle_badblocks(struct nullb_cmd *cmd, sector_t sector,
+                                  sector_t nr_sectors);
+blk_status_t null_handle_memory_backed(struct nullb_cmd *cmd, enum req_op op,
+                                      sector_t sector, sector_t nr_sectors);
+
 
 #ifdef CONFIG_BLK_DEV_ZONED
 int null_init_zoned_dev(struct nullb_device *dev, struct queue_limits *lim);
index 0d5f9bf952292ec90bfa5bd89f267cab38431355..7677f6cf23f4665d4453ca57ccf74c4e9c3f4a16 100644 (file)
@@ -412,9 +412,18 @@ static blk_status_t null_zone_write(struct nullb_cmd *cmd, sector_t sector,
                zone->cond = BLK_ZONE_COND_IMP_OPEN;
        }
 
-       ret = null_process_cmd(cmd, REQ_OP_WRITE, sector, nr_sectors);
-       if (ret != BLK_STS_OK)
-               goto unlock_zone;
+       if (dev->badblocks.shift != -1) {
+               ret = null_handle_badblocks(cmd, sector, nr_sectors);
+               if (ret != BLK_STS_OK)
+                       goto unlock_zone;
+       }
+
+       if (dev->memory_backed) {
+               ret = null_handle_memory_backed(cmd, REQ_OP_WRITE, sector,
+                                               nr_sectors);
+               if (ret != BLK_STS_OK)
+                       goto unlock_zone;
+       }
 
        zone->wp += nr_sectors;
        if (zone->wp == zone->start + zone->capacity) {