libxl__xswait_state xswait;
libxl__ev_qmp qmp;
libxl__ev_time timeout;
- libxl_device_pci *pci;
+ libxl_device_pci pci;
libxl_domid pci_domid;
} pci_add_state;
/* Convenience aliases */
libxl_domid domid = pas->domid;
- libxl_device_pci *pci = pas->pci;
+ libxl_device_pci *pci = &pas->pci;
rc = check_qemu_running(gc, domid, xswa, rc, state);
if (rc == ERROR_NOT_READY)
/* Convenience aliases */
libxl_domid domid = pas->domid;
- libxl_device_pci *pci = pas->pci;
+ libxl_device_pci *pci = &pas->pci;
libxl__ev_qmp *const qmp = &pas->qmp;
rc = libxl__ev_time_register_rel(ao, &pas->timeout,
int dev_slot, dev_func;
/* Convenience aliases */
- libxl_device_pci *pci = pas->pci;
+ libxl_device_pci *pci = &pas->pci;
if (rc) goto out;
/* Convenience aliases */
bool starting = pas->starting;
- libxl_device_pci *pci = pas->pci;
+ libxl_device_pci *pci = &pas->pci;
bool hvm = libxl__domain_type(gc, domid) == LIBXL_DOMAIN_TYPE_HVM;
libxl__ev_qmp_dispose(gc, &pas->qmp);
GCNEW(pas);
pas->aodev = aodev;
pas->domid = domid;
- pas->pci = pci;
+
+ libxl_device_pci_copy(CTX, &pas->pci, pci);
+ pci = &pas->pci;
+
pas->starting = starting;
pas->callback = device_pci_add_stubdom_done;
stubdomid = libxl_get_stubdom_id(ctx, domid);
if (stubdomid != 0) {
- libxl_device_pci *pci_s;
-
- 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, pas); /* must be last */
/* Convenience aliases */
libxl_domid domid = pas->domid;
- libxl_device_pci *pci = pas->pci;
+ libxl_device_pci *pci = &pas->pci;
if (rc) goto out;
EGC_GC;
libxl__ao_device *aodev = pas->aodev;
libxl_domid domid = pas->domid;
- libxl_device_pci *pci = pas->pci;
+ libxl_device_pci *pci = &pas->pci;
if (rc) {
LOGD(ERROR, domid,
rc);
pci_info_xs_remove(gc, pci, "domid");
}
+ libxl_device_pci_dispose(pci);
aodev->rc = rc;
aodev->callback(egc, aodev);
}
typedef struct pci_remove_state {
libxl__ao_device *aodev;
libxl_domid domid;
- libxl_device_pci *pci;
+ libxl_device_pci pci;
bool force;
bool hvm;
unsigned int orig_vdev;
{
STATE_AO_GC(prs->aodev->ao);
libxl_ctx *ctx = libxl__gc_owner(gc);
- libxl_device_pci *assigned;
+ libxl_device_pci *pcis;
+ bool attached;
uint32_t domid = prs->domid;
libxl_domain_type type = libxl__domain_type(gc, domid);
- libxl_device_pci *pci = prs->pci;
+ libxl_device_pci *pci = &prs->pci;
int rc, num;
uint32_t domainid = domid;
- assigned = libxl_device_pci_list(ctx, domid, &num);
- if (assigned == NULL) {
+ pcis = libxl_device_pci_list(ctx, domid, &num);
+ if (!pcis) {
rc = ERROR_FAIL;
goto out_fail;
}
- libxl__ptr_add(gc, assigned);
+
+ attached = is_pci_in_array(pcis, num, pci->domain,
+ pci->bus, pci->dev, pci->func);
+ libxl_device_pci_list_free(pcis, num);
rc = ERROR_INVAL;
- if ( !is_pci_in_array(assigned, num, pci->domain,
- pci->bus, pci->dev, pci->func) ) {
+ if (!attached) {
LOGD(ERROR, domainid, "PCI device not attached to this domain");
goto out_fail;
}
/* Convenience aliases */
libxl_domid domid = prs->domid;
- libxl_device_pci *const pci = prs->pci;
+ libxl_device_pci *const pci = &prs->pci;
rc = check_qemu_running(gc, domid, xswa, rc, state);
if (rc == ERROR_NOT_READY)
int rc;
/* Convenience aliases */
- libxl_device_pci *const pci = prs->pci;
+ libxl_device_pci *const pci = &prs->pci;
rc = libxl__ev_time_register_rel(ao, &prs->timeout,
pci_remove_timeout,
/* Convenience aliases */
libxl__ao *const ao = prs->aodev->ao;
- libxl_device_pci *const pci = prs->pci;
+ libxl_device_pci *const pci = &prs->pci;
if (rc) goto out;
pci_remove_state *prs = CONTAINER_OF(ev, *prs, timeout);
/* Convenience aliases */
- libxl_device_pci *const pci = prs->pci;
+ libxl_device_pci *const pci = &prs->pci;
LOGD(WARN, prs->domid, "timed out waiting for DM to remove "
PCI_PT_QDEV_ID, pci->bus, pci->dev, pci->func);
bool isstubdom;
/* Convenience aliases */
- libxl_device_pci *const pci = prs->pci;
+ libxl_device_pci *const pci = &prs->pci;
libxl_domid domid = prs->domid;
/* Cleaning QMP states ASAP */
if (rc) goto out;
- libxl__device_pci_remove_xenstore(gc, prs->domid, prs->pci);
+ libxl__device_pci_remove_xenstore(gc, prs->domid, &prs->pci);
out:
device_pci_remove_common_next(egc, prs, rc);
}
GCNEW(prs);
prs->aodev = aodev;
prs->domid = domid;
- prs->pci = pci;
+
+ libxl_device_pci_copy(CTX, &prs->pci, pci);
+ pci = &prs->pci;
+
prs->force = force;
libxl__xswait_init(&prs->xswait);
libxl__ev_qmp_init(&prs->qmp);
EGC_GC;
/* Convenience aliases */
- libxl_device_pci *const pci = prs->pci;
+ libxl_device_pci *const pci = &prs->pci;
libxl__ao_device *const aodev = prs->aodev;
const unsigned int pfunc_mask = prs->pfunc_mask;
const unsigned int orig_vdev = prs->orig_vdev;
if (!rc) pci_info_xs_remove(gc, pci, "domid");
+ libxl_device_pci_dispose(pci);
aodev->rc = rc;
aodev->callback(egc, aodev);
}
pcis = libxl_device_pci_list(CTX, domid, &num);
if ( pcis == NULL )
return;
- libxl__ptr_add(gc, pcis);
for (i = 0; i < num; i++) {
/* Force remove on shutdown since, on HVM, qemu will not always
libxl__device_pci_remove_common(egc, domid, pcis + i, true,
aodev);
}
+
+ libxl_device_pci_list_free(pcis, num);
}
int libxl__grant_vga_iomem_permission(libxl__gc *gc, const uint32_t domid,