qemu-devel
[Top][All Lists]
Advanced

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

Re: [PATCH v1 07/12] include/hw/xen/xen_common: return error from xen_cr


From: Julien Grall
Subject: Re: [PATCH v1 07/12] include/hw/xen/xen_common: return error from xen_create_ioreq_server
Date: Sun, 16 Oct 2022 18:53:11 +0100
User-agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10.15; rv:102.0) Gecko/20100101 Thunderbird/102.3.3

Hi Vikram,

On 15/10/2022 06:07, Vikram Garhwal wrote:
From: Stefano Stabellini <stefano.stabellini@amd.com>

This is done to prepare for enabling xenpv support for ARM architecture.
On ARM it is possible to have a functioning xenpv machine with only the
PV backends and no IOREQ server. If the IOREQ server creation fails,
continue to the PV backends initialization.

Signed-off-by: Stefano Stabellini <stefano.stabellini@amd.com>
---
  include/hw/xen/xen_common.h | 12 +++++++-----
  1 file changed, 7 insertions(+), 5 deletions(-)

diff --git a/include/hw/xen/xen_common.h b/include/hw/xen/xen_common.h
index 77ce17d8a4..c2d2f36bde 100644
--- a/include/hw/xen/xen_common.h
+++ b/include/hw/xen/xen_common.h
@@ -467,8 +467,8 @@ static inline void xen_unmap_pcidev(domid_t dom,
  {
  }
-static inline void xen_create_ioreq_server(domid_t dom,
-                                           ioservid_t *ioservid)
+static inline int xen_create_ioreq_server(domid_t dom,
+                                          ioservid_t *ioservid)
  {

I think there is a return missing here.

  }
@@ -600,8 +600,8 @@ static inline void xen_unmap_pcidev(domid_t dom,
                                                    PCI_FUNC(pci_dev->devfn));
  }
-static inline void xen_create_ioreq_server(domid_t dom,
-                                           ioservid_t *ioservid)
+static inline int xen_create_ioreq_server(domid_t dom,
+                                          ioservid_t *ioservid)
  {
      int rc = xendevicemodel_create_ioreq_server(xen_dmod, dom,
                                                  HVM_IOREQSRV_BUFIOREQ_ATOMIC,
@@ -609,12 +609,14 @@ static inline void xen_create_ioreq_server(domid_t dom,
if (rc == 0) {
          trace_xen_ioreq_server_create(*ioservid);
-        return;
+        return rc;
      }
*ioservid = 0;
      use_default_ioreq_server = true;
      trace_xen_default_ioreq_server();
+
+    return rc;
  }
static inline void xen_destroy_ioreq_server(domid_t dom,

Cheers,

--
Julien Grall



reply via email to

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