From: Ian Jackson Date: Thu, 16 Apr 2009 10:47:04 +0000 (+0100) Subject: passthrough: guest MSI config on disable X-Git-Url: http://xenbits.xensource.com/gitweb?a=commitdiff_plain;h=527f1caa1122162d5f1a3f02d66d956b652378fe;p=xenclient%2Fioemu.git passthrough: guest MSI config on disable It's possible for a guest to change the MSI vector or flags when MSI is disabled, after it's first initialized. This patch handles the address and data update when it's disabled. Signed-off-by: Qing He --- diff --git a/hw/pass-through.c b/hw/pass-through.c index 11382fd4..710acbfa 100644 --- a/hw/pass-through.c +++ b/hw/pass-through.c @@ -3436,7 +3436,7 @@ static int pt_msgaddr32_reg_write(struct pt_dev *ptdev, /* update MSI */ if (cfg_entry->data != old_addr) { - if (ptdev->msi->flags & PCI_MSI_FLAGS_ENABLE) + if (ptdev->msi->flags & PT_MSI_MAPPED) pt_msi_update(ptdev); } @@ -3474,7 +3474,7 @@ static int pt_msgaddr64_reg_write(struct pt_dev *ptdev, /* update MSI */ if (cfg_entry->data != old_addr) { - if (ptdev->msi->flags & PCI_MSI_FLAGS_ENABLE) + if (ptdev->msi->flags & PT_MSI_MAPPED) pt_msi_update(ptdev); } @@ -3516,7 +3516,7 @@ static int pt_msgdata_reg_write(struct pt_dev *ptdev, /* update MSI */ if (cfg_entry->data != old_data) { - if (flags & PCI_MSI_FLAGS_ENABLE) + if (flags & PT_MSI_MAPPED) pt_msi_update(ptdev); } diff --git a/hw/pt-msi.c b/hw/pt-msi.c index 4a54ba33..9f4a3b3e 100644 --- a/hw/pt-msi.c +++ b/hw/pt-msi.c @@ -110,10 +110,6 @@ uint32_t __get_msi_gflags(uint32_t data, uint64_t addr) return result; } -/* - * Update msi mapping, usually called when MSI enabled, - * except the first time - */ int pt_msi_update(struct pt_dev *d) { uint8_t gvec = 0; @@ -126,7 +122,8 @@ int pt_msi_update(struct pt_dev *d) addr = (uint64_t)d->msi->addr_hi << 32 | d->msi->addr_lo; gflags = __get_msi_gflags(d->msi->data, addr); - PT_LOG("Update msi with pirq %x gvec %x\n", d->msi->pirq, gvec); + PT_LOG("Update msi with pirq %x gvec %x gflags %x\n", + d->msi->pirq, gvec, gflags); ret = xc_domain_update_msi_irq(xc_handle, domid, gvec, d->msi->pirq, gflags, 0);