qemu-devel
[Top][All Lists]
Advanced

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

Re: [PATCH v3 8/9] pnv/xive2: Fail VST entry address computation if tabl


From: Cédric Le Goater
Subject: Re: [PATCH v3 8/9] pnv/xive2: Fail VST entry address computation if table has no VSD
Date: Tue, 16 Jul 2024 22:19:16 +0200
User-agent: Mozilla Thunderbird

On 7/16/24 21:56, Michael Kowal wrote:
From: Frederic Barrat <fbarrat@linux.ibm.com>

Fail VST entry address computation if firmware doesn't define a descriptor
for one of the Virtualization Structure Tables (VST), there's no point in
trying to compute the address of its entry.  Abort the operation and log
an error.

Signed-off-by: Frederic Barrat <fbarrat@linux.ibm.com>
Signed-off-by: Michael Kowal <kowal@linux.vnet.ibm.com>

Reviewed-by: Cédric Le Goater <clg@redhat.com>

Thanks,

C.


---
  hw/intc/pnv_xive2.c | 5 +++++
  1 file changed, 5 insertions(+)

diff --git a/hw/intc/pnv_xive2.c b/hw/intc/pnv_xive2.c
index dab4c169a4..9fe3ec9a67 100644
--- a/hw/intc/pnv_xive2.c
+++ b/hw/intc/pnv_xive2.c
@@ -244,6 +244,11 @@ static uint64_t pnv_xive2_vst_addr(PnvXive2 *xive, 
uint32_t type, uint8_t blk,
      }
vsd = xive->vsds[type][blk];
+    if (vsd == 0) {
+        xive2_error(xive, "VST: vsd == 0 block id %d for VST %s %d !?",
+                   blk, info->name, idx);
+        return 0;
+    }
/* Remote VST access */
      if (GETFIELD(VSD_MODE, vsd) == VSD_MODE_FORWARD) {




reply via email to

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