Commit 8b631f9c authored by Christoph Hellwig's avatar Christoph Hellwig Committed by Jens Axboe

null_blk: remove the bio based I/O path

The bio based I/O path complicates null_blk and also make various
data structures, including the per-command one way bigger than
required for the main request based interface.   As the bio-based
path is mostly used by stacking drivers and simple memory based
drivers, and brd is a good example driver for the latter there is
no need to have a bio based path in null_blk.  Remove the path
to simplify the driver and make future block layer API changes
simpler by not having to deal with the complex two API setup in
null_blk.

Note that the queue_mode field in struct nullb_device is kept as
that is simpler than having two different places to check the
value and fully open coding the debugfs helpers as the existing
ones won't work without a named struct member.
Signed-off-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarDamien Le Moal <dlemoal@kernel.org>
Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
Reviewed-by: default avatarJohannes Thumshirn <johannes.thumshirn@wdc.com>
Tested-by: default avatarDamien Le Moal <dlemoal@kernel.org>
Link: https://lore.kernel.org/r/20240220093248.3290292-2-hch@lst.deSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 616f8766
This diff is collapsed.
...@@ -16,11 +16,6 @@ ...@@ -16,11 +16,6 @@
#include <linux/mutex.h> #include <linux/mutex.h>
struct nullb_cmd { struct nullb_cmd {
union {
struct request *rq;
struct bio *bio;
};
unsigned int tag;
blk_status_t error; blk_status_t error;
bool fake_timeout; bool fake_timeout;
struct nullb_queue *nq; struct nullb_queue *nq;
...@@ -28,16 +23,11 @@ struct nullb_cmd { ...@@ -28,16 +23,11 @@ struct nullb_cmd {
}; };
struct nullb_queue { struct nullb_queue {
unsigned long *tag_map;
wait_queue_head_t wait;
unsigned int queue_depth;
struct nullb_device *dev; struct nullb_device *dev;
unsigned int requeue_selection; unsigned int requeue_selection;
struct list_head poll_list; struct list_head poll_list;
spinlock_t poll_lock; spinlock_t poll_lock;
struct nullb_cmd *cmds;
}; };
struct nullb_zone { struct nullb_zone {
...@@ -60,13 +50,6 @@ struct nullb_zone { ...@@ -60,13 +50,6 @@ struct nullb_zone {
unsigned int capacity; unsigned int capacity;
}; };
/* Queue modes */
enum {
NULL_Q_BIO = 0,
NULL_Q_RQ = 1,
NULL_Q_MQ = 2,
};
struct nullb_device { struct nullb_device {
struct nullb *nullb; struct nullb *nullb;
struct config_group group; struct config_group group;
......
...@@ -41,10 +41,11 @@ TRACE_EVENT(nullb_zone_op, ...@@ -41,10 +41,11 @@ TRACE_EVENT(nullb_zone_op,
__field(unsigned int, zone_cond) __field(unsigned int, zone_cond)
), ),
TP_fast_assign( TP_fast_assign(
__entry->op = req_op(cmd->rq); __entry->op = req_op(blk_mq_rq_from_pdu(cmd));
__entry->zone_no = zone_no; __entry->zone_no = zone_no;
__entry->zone_cond = zone_cond; __entry->zone_cond = zone_cond;
__assign_disk_name(__entry->disk, cmd->rq->q->disk); __assign_disk_name(__entry->disk,
blk_mq_rq_from_pdu(cmd)->q->disk);
), ),
TP_printk("%s req=%-15s zone_no=%u zone_cond=%-10s", TP_printk("%s req=%-15s zone_no=%u zone_cond=%-10s",
__print_disk_name(__entry->disk), __print_disk_name(__entry->disk),
......
...@@ -168,10 +168,7 @@ int null_register_zoned_dev(struct nullb *nullb) ...@@ -168,10 +168,7 @@ int null_register_zoned_dev(struct nullb *nullb)
disk_set_max_open_zones(nullb->disk, dev->zone_max_open); disk_set_max_open_zones(nullb->disk, dev->zone_max_open);
disk_set_max_active_zones(nullb->disk, dev->zone_max_active); disk_set_max_active_zones(nullb->disk, dev->zone_max_active);
if (queue_is_mq(q))
return blk_revalidate_disk_zones(nullb->disk, NULL); return blk_revalidate_disk_zones(nullb->disk, NULL);
return 0;
} }
void null_free_zoned_dev(struct nullb_device *dev) void null_free_zoned_dev(struct nullb_device *dev)
...@@ -394,10 +391,7 @@ static blk_status_t null_zone_write(struct nullb_cmd *cmd, sector_t sector, ...@@ -394,10 +391,7 @@ static blk_status_t null_zone_write(struct nullb_cmd *cmd, sector_t sector,
*/ */
if (append) { if (append) {
sector = zone->wp; sector = zone->wp;
if (dev->queue_mode == NULL_Q_MQ) blk_mq_rq_from_pdu(cmd)->__sector = sector;
cmd->rq->__sector = sector;
else
cmd->bio->bi_iter.bi_sector = sector;
} else if (sector != zone->wp) { } else if (sector != zone->wp) {
ret = BLK_STS_IOERR; ret = BLK_STS_IOERR;
goto unlock; goto unlock;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment