All of lore.kernel.org
 help / color / mirror / Atom feed
From: Paul Durrant <paul@xen.org>
To: xen-devel@lists.xenproject.org
Cc: Paul Durrant <pdurrant@amazon.com>,
	Ian Jackson <iwj@xenproject.org>, Wei Liu <wl@xen.org>
Subject: [PATCH 07/25] libxl: stop using aodev->device_config in libxl__device_pci_add()...
Date: Fri, 23 Oct 2020 16:22:56 +0000	[thread overview]
Message-ID: <20201023162314.2235-8-paul@xen.org> (raw)
In-Reply-To: <20201023162314.2235-1-paul@xen.org>

From: Paul Durrant <pdurrant@amazon.com>

... to hold a pointer to the device.

There is already a 'pci' field in 'pci_add_state' so simply use that from
the start. This also allows the 'pci' (#3) argument to be dropped from
do_pci_add().

NOTE: This patch also changes the type of the 'pci_domid' field in
      'pci_add_state' from 'int' to 'libxl_domid' which is more appropriate
      given what the field is used for.

Signed-off-by: Paul Durrant <pdurrant@amazon.com>
---
Cc: Ian Jackson <iwj@xenproject.org>
Cc: Wei Liu <wl@xen.org>
---
 tools/libs/light/libxl_pci.c | 19 +++++++------------
 1 file changed, 7 insertions(+), 12 deletions(-)

diff --git a/tools/libs/light/libxl_pci.c b/tools/libs/light/libxl_pci.c
index 97889fda49..b8d8cc6a69 100644
--- a/tools/libs/light/libxl_pci.c
+++ b/tools/libs/light/libxl_pci.c
@@ -1055,7 +1055,7 @@ typedef struct pci_add_state {
     libxl__ev_qmp qmp;
     libxl__ev_time timeout;
     libxl_device_pci *pci;
-    int pci_domid;
+    libxl_domid pci_domid;
 } pci_add_state;
 
 static void pci_add_qemu_trad_watch_state_cb(libxl__egc *egc,
@@ -1072,7 +1072,6 @@ static void pci_add_dm_done(libxl__egc *,
 
 static void do_pci_add(libxl__egc *egc,
                        libxl_domid domid,
-                       libxl_device_pci *pci,
                        pci_add_state *pas)
 {
     STATE_AO_GC(pas->aodev->ao);
@@ -1082,7 +1081,6 @@ static void do_pci_add(libxl__egc *egc,
     /* init pci_add_state */
     libxl__xswait_init(&pas->xswait);
     libxl__ev_qmp_init(&pas->qmp);
-    pas->pci = pci;
     pas->pci_domid = domid;
     libxl__ev_time_init(&pas->timeout);
 
@@ -1544,13 +1542,10 @@ void libxl__device_pci_add(libxl__egc *egc, uint32_t domid,
     int stubdomid = 0;
     pci_add_state *pas;
 
-    /* Store *pci to be used by callbacks */
-    aodev->device_config = pci;
-    aodev->device_type = &libxl__pci_devtype;
-
     GCNEW(pas);
     pas->aodev = aodev;
     pas->domid = domid;
+    pas->pci = pci;
     pas->starting = starting;
     pas->callback = device_pci_add_stubdom_done;
 
@@ -1604,9 +1599,10 @@ void libxl__device_pci_add(libxl__egc *egc, uint32_t domid,
         GCNEW(pci_s);
         libxl_device_pci_init(pci_s);
         libxl_device_pci_copy(CTX, pci_s, pci);
+        pas->pci = pci_s;
         pas->callback = device_pci_add_stubdom_wait;
 
-        do_pci_add(egc, stubdomid, pci_s, pas); /* must be last */
+        do_pci_add(egc, stubdomid, pas); /* must be last */
         return;
     }
 
@@ -1661,9 +1657,8 @@ static void device_pci_add_stubdom_done(libxl__egc *egc,
     int i;
 
     /* Convenience aliases */
-    libxl__ao_device *aodev = pas->aodev;
     libxl_domid domid = pas->domid;
-    libxl_device_pci *pci = aodev->device_config;
+    libxl_device_pci *pci = pas->pci;
 
     if (rc) goto out;
 
@@ -1698,7 +1693,7 @@ static void device_pci_add_stubdom_done(libxl__egc *egc,
                 pci->vdevfn = orig_vdev;
             }
             pas->callback = device_pci_add_done;
-            do_pci_add(egc, domid, pci, pas); /* must be last */
+            do_pci_add(egc, domid, pas); /* must be last */
             return;
         }
     }
@@ -1714,7 +1709,7 @@ static void device_pci_add_done(libxl__egc *egc,
     EGC_GC;
     libxl__ao_device *aodev = pas->aodev;
     libxl_domid domid = pas->domid;
-    libxl_device_pci *pci = aodev->device_config;
+    libxl_device_pci *pci = pas->pci;
 
     if (rc) {
         LOGD(ERROR, domid,
-- 
2.11.0



  parent reply	other threads:[~2020-10-23 16:23 UTC|newest]

Thread overview: 27+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-10-23 16:22 [PATCH 00/25] xl / libxl: named PCI pass-through devices Paul Durrant
2020-10-23 16:22 ` [PATCH 01/25] xl / libxl: s/pcidev/pci and remove DEFINE_DEVICE_TYPE_STRUCT_X Paul Durrant
2020-10-23 16:22 ` [PATCH 02/25] libxl: use LIBXL_DEFINE_DEVICE_LIST for pci devices Paul Durrant
2020-10-23 16:22 ` [PATCH 03/25] libxl: use LIBXL_DEFINE_DEVICE_LIST for nic devices Paul Durrant
2020-10-23 16:22 ` [PATCH 04/25] libxl: s/domainid/domid/g in libxl_pci.c Paul Durrant
2020-10-23 16:22 ` [PATCH 05/25] libxl: s/detatched/detached " Paul Durrant
2020-10-23 16:22 ` [PATCH 06/25] libxl: remove extraneous arguments to do_pci_remove() " Paul Durrant
2020-10-23 16:22 ` Paul Durrant [this message]
2020-10-23 16:22 ` [PATCH 08/25] libxl: generalise 'driver_path' xenstore access functions " Paul Durrant
2020-10-23 16:22 ` [PATCH 09/25] libxl: remove unnecessary check from libxl__device_pci_add() Paul Durrant
2020-10-23 16:22 ` [PATCH 10/25] libxl: remove get_all_assigned_devices() from libxl_pci.c Paul Durrant
2020-10-23 16:23 ` [PATCH 11/25] libxl: make sure callers of libxl_device_pci_list() free the list after use Paul Durrant
2020-10-23 16:23 ` [PATCH 12/25] libxl: add libxl_device_pci_assignable_list_free() Paul Durrant
2020-10-23 16:23 ` [PATCH 13/25] libxl: use COMPARE_PCI() macro is_pci_in_array() Paul Durrant
2020-10-23 16:23 ` [PATCH 14/25] libxl: add/recover 'rdm_policy' to/from PCI backend in xenstore Paul Durrant
2020-10-23 16:23 ` [PATCH 15/25] libxl: Make sure devices added by pci-attach are reflected in the config Paul Durrant
2020-10-23 16:23 ` [PATCH 16/25] docs/man: extract documentation of PCI_SPEC_STRING from the xl.cfg manpage Paul Durrant
2020-10-23 16:23 ` [PATCH 17/25] docs/man: improve documentation of PCI_SPEC_STRING Paul Durrant
2020-10-23 16:23 ` [PATCH 18/25] docs/man: fix xl(1) documentation for 'pci' operations Paul Durrant
2020-10-23 16:23 ` [PATCH 19/25] libxl: introduce 'libxl_pci_bdf' in the idl Paul Durrant
2020-10-23 16:23 ` [PATCH 20/25] libxlu: introduce xlu_pci_parse_spec_string() Paul Durrant
2020-10-23 16:23 ` [PATCH 21/25] libxl: modify libxl_device_pci_assignable_add/remove/list/list_free() Paul Durrant
2020-10-23 16:23 ` [PATCH 22/25] docs/man: modify xl(1) in preparation for naming of assignable devices Paul Durrant
2020-10-23 16:23 ` [PATCH 23/25] xl / libxl: support " Paul Durrant
2020-10-23 16:23 ` [PATCH 24/25] docs/man: modify xl-pci-configuration(5) to add 'name' field to PCI_SPEC_STRING Paul Durrant
2020-10-23 16:23 ` [PATCH 25/25] xl / libxl: support 'xl pci-attach/detach' by name Paul Durrant
2020-10-26  9:10 ` [PATCH 00/25] xl / libxl: named PCI pass-through devices Christian Lindig

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20201023162314.2235-8-paul@xen.org \
    --to=paul@xen.org \
    --cc=iwj@xenproject.org \
    --cc=pdurrant@amazon.com \
    --cc=wl@xen.org \
    --cc=xen-devel@lists.xenproject.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.