I figured something out.  This appears to be the commit with the fix:

$ git show 1e64facc015e16d8e4efa239feaeda9e4e9aeb04
commit 1e64facc015e16d8e4efa239feaeda9e4e9aeb04 (HEAD)
Author: Dmitry Tikhov <ddtik...@gmail.com>
Date:   Tue Apr 12 11:59:09 2022 +0300

    hw/nvme: fix narrowing conversion
    
    Since nlbas is of type int, it does not work with large namespace size
    values, e.g., 9 TB size of file backing namespace and 8 byte metadata
    with 4096 bytes lbasz gives negative nlbas value, which is later
    promoted to negative int64_t type value and results in negative
    ns->moff which breaks namespace
    
    Signed-off-by: Dmitry Tikhov <ddtik...@gmail.com>
    Reviewed-by: Klaus Jensen <k.jen...@samsung.com>
    Signed-off-by: Klaus Jensen <k.jen...@samsung.com>

diff --git a/hw/nvme/ns.c b/hw/nvme/ns.c
index 324f53ea0c..af6504fad2 100644
--- a/hw/nvme/ns.c
+++ b/hw/nvme/ns.c
@@ -29,7 +29,8 @@ void nvme_ns_init_format(NvmeNamespace *ns)
 {
     NvmeIdNs *id_ns = &ns->id_ns;
     BlockDriverInfo bdi;
-    int npdg, nlbas, ret;
+    int npdg, ret;
+    int64_t nlbas;
 
     ns->lbaf = id_ns->lbaf[NVME_ID_NS_FLBAS_INDEX(id_ns->flbas)];
     ns->lbasz = 1 << ns->lbaf.ds;
@@ -42,7 +43,7 @@ void nvme_ns_init_format(NvmeNamespace *ns)
     id_ns->ncap = id_ns->nsze;
     id_ns->nuse = id_ns->ncap;
 
-    ns->moff = (int64_t)nlbas << ns->lbaf.ds;
+    ns->moff = nlbas << ns->lbaf.ds;
 
     npdg = ns->blkconf.discard_granularity / ns->lbasz;

-- 
You received this bug notification because you are a member of Ubuntu
Bugs, which is subscribed to Ubuntu.
https://bugs.launchpad.net/bugs/2098896

Title:
  nvme disks 1TiB or greater show incorrect size

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/qemu/+bug/2098896/+subscriptions


-- 
ubuntu-bugs mailing list
ubuntu-bugs@lists.ubuntu.com
https://lists.ubuntu.com/mailman/listinfo/ubuntu-bugs

Reply via email to