Commit 96392961 authored by Daniel Wagner's avatar Daniel Wagner Committed by Keith Busch

nvme: repack struct nvme_ns_head

ns_id, lba_shift and ms are always accessed for every read/write I/O in
nvme_setup_rw. By grouping these variables into one cacheline we can
safe some cycles.

4k sequential reads:

           baseline   patched
Bandwidth: 1620       1634
IOPs       66345579   66910939
Reviewed-by: default avatarChristoph Hellwig <hch@lst.de>
Reviewed-by: default avatarSagi Grimberg <sagi@grimberg.me>
Reviewed-by: default avatarHannes Reinecke <hare@suse.de>
Signed-off-by: default avatarDaniel Wagner <dwagner@suse.de>
Signed-off-by: default avatarKeith Busch <kbusch@kernel.org>
parent a1a825ab
...@@ -440,21 +440,21 @@ struct nvme_ns_head { ...@@ -440,21 +440,21 @@ struct nvme_ns_head {
struct list_head list; struct list_head list;
struct srcu_struct srcu; struct srcu_struct srcu;
struct nvme_subsystem *subsys; struct nvme_subsystem *subsys;
unsigned ns_id;
struct nvme_ns_ids ids; struct nvme_ns_ids ids;
struct list_head entry; struct list_head entry;
struct kref ref; struct kref ref;
bool shared; bool shared;
int instance; int instance;
struct nvme_effects_log *effects; struct nvme_effects_log *effects;
u64 nuse;
unsigned ns_id;
int lba_shift; int lba_shift;
u16 ms; u16 ms;
u16 pi_size; u16 pi_size;
u16 sgs;
u32 sws;
u64 nuse;
u8 pi_type; u8 pi_type;
u8 guard_type; u8 guard_type;
u16 sgs;
u32 sws;
#ifdef CONFIG_BLK_DEV_ZONED #ifdef CONFIG_BLK_DEV_ZONED
u64 zsze; u64 zsze;
#endif #endif
......
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