Signed-off-by: Christoph Hellwig <[email protected]>
---
 drivers/nvme/host/core.c | 10 ++++++++++
 drivers/nvme/host/nvme.h |  1 +
 2 files changed, 11 insertions(+)

diff --git a/drivers/nvme/host/core.c b/drivers/nvme/host/core.c
index 8a3c3e32a704..e86d07589f18 100644
--- a/drivers/nvme/host/core.c
+++ b/drivers/nvme/host/core.c
@@ -926,6 +926,15 @@ static void __nvme_revalidate_disk(struct gendisk *disk, 
struct nvme_id_ns *id)
        ns->pi_type = pi_type;
        blk_queue_logical_block_size(ns->queue, bs);
 
+       /*
+        * Advertisze the maximum atomic write size.  Don't bother with the
+        * per-namespace values due to their alignment constraints.
+        */
+       if (ns->ctrl->awupf > 1) {
+               blk_queue_max_atomic_write_sectors(ns->queue,
+                       (ns->ctrl->awupf + 1) << (ns->lba_shift - 9));
+       }
+
        if (ns->ms && !blk_get_integrity(disk) && !ns->ext)
                nvme_init_integrity(ns);
        if (ns->ms && !(ns->ms == 8 && ns->pi_type) && !blk_get_integrity(disk))
@@ -1232,6 +1241,7 @@ int nvme_init_identify(struct nvme_ctrl *ctrl)
 
        ctrl->vid = le16_to_cpu(id->vid);
        ctrl->oncs = le16_to_cpup(&id->oncs);
+       ctrl->awupf = le16_to_cpu(id->awupf);
        atomic_set(&ctrl->abort_limit, id->acl + 1);
        ctrl->vwc = id->vwc;
        ctrl->cntlid = le16_to_cpup(&id->cntlid);
diff --git a/drivers/nvme/host/nvme.h b/drivers/nvme/host/nvme.h
index aead6d08ed2c..020ffd6f7863 100644
--- a/drivers/nvme/host/nvme.h
+++ b/drivers/nvme/host/nvme.h
@@ -143,6 +143,7 @@ struct nvme_ctrl {
        u32 vs;
        u32 sgls;
        u16 kas;
+       u16 awupf;
        unsigned int kato;
        bool subsystem;
        unsigned long quirks;
-- 
2.11.0

Reply via email to