qemu-devel
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

Re: [PATCH 2/2] ppc/pnv: fix check on return value of blk_getlength()


From: Philippe Mathieu-Daudé
Subject: Re: [PATCH 2/2] ppc/pnv: fix check on return value of blk_getlength()
Date: Tue, 7 Jan 2020 19:23:29 +0100
User-agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.2

On 1/7/20 6:18 PM, Cédric Le Goater wrote:
blk_getlength() returns an int64_t but the result is stored in a
uint32_t. Errors (negative values) won't be caught by the check in
pnv_pnor_realize() and blk_blockalign() will allocate a very large
buffer in such cases.

Fixes Coverity issue CID 1412226.

Signed-off-by: Cédric Le Goater <address@hidden>
---
  include/hw/ppc/pnv_pnor.h | 2 +-
  hw/ppc/pnv_pnor.c         | 2 +-
  2 files changed, 2 insertions(+), 2 deletions(-)

diff --git a/include/hw/ppc/pnv_pnor.h b/include/hw/ppc/pnv_pnor.h
index c3dd28643cae..4f96abdfb402 100644
--- a/include/hw/ppc/pnv_pnor.h
+++ b/include/hw/ppc/pnv_pnor.h
@@ -23,7 +23,7 @@ typedef struct PnvPnor {
      BlockBackend   *blk;
uint8_t *storage;
-    uint32_t       size;
+    int64_t        size;
      MemoryRegion   mmio;
  } PnvPnor;
diff --git a/hw/ppc/pnv_pnor.c b/hw/ppc/pnv_pnor.c
index 0e86ae2feae6..b061106d1c0c 100644
--- a/hw/ppc/pnv_pnor.c
+++ b/hw/ppc/pnv_pnor.c
@@ -111,7 +111,7 @@ static void pnv_pnor_realize(DeviceState *dev, Error **errp)
  }
static Property pnv_pnor_properties[] = {
-    DEFINE_PROP_UINT32("size", PnvPnor, size, 128 << 20),
+    DEFINE_PROP_INT64("size", PnvPnor, size, 128 << 20),

If you respin the series please consider using '128 * MiB' here.

Reviewed-by: Philippe Mathieu-Daudé <address@hidden>

      DEFINE_PROP_DRIVE("drive", PnvPnor, blk),
      DEFINE_PROP_END_OF_LIST(),
  };





reply via email to

[Prev in Thread] Current Thread [Next in Thread]