|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [PATCH v3 2/3] xen/pci: Move x86 specific code to x86 directory.
Hello Stefano,
> On 17 Nov 2020, at 1:20 am, Stefano Stabellini <sstabellini@xxxxxxxxxx> wrote:
>
> On Mon, 16 Nov 2020, Rahul Singh wrote:
>> passthrough/pci.c file is common for all architecture, but there is x86
>> specific code in this file.
>>
>> Move x86 specific code to the drivers/passthrough/io.c file to avoid
>> compilation error for other architecture.
>>
>> As drivers/passthrough/io.c is compiled only for x86 move it to
>> x86 directory and rename it to hvm.c.
>>
>> No functional change.
>>
>> Signed-off-by: Rahul Singh <rahul.singh@xxxxxxx>
>
> This patch breaks the x86 build if you disable CONFIG_HVM:
>
> prelink-efi.o: In function `pci_release_devices':
> /local/repos/xen-upstream/xen/drivers/passthrough/pci.c:900: undefined
> reference to `arch_pci_clean_pirqs'
> Makefile:209: recipe for target '/local/repos/xen-upstream/xen/xen.efi' failed
>
>
Thanks for reviewing the code.
I will fix the build and will send the v3 patch.
Regards,
Rahul
>
>> ---
>>
>> Changes in v3:
>> - fixed typo
>> - As per suggestion move the code to the file io.c and move that file to
>> x86 directory and rename it hvm.c
>>
>> ---
>> xen/drivers/passthrough/Makefile | 3 -
>> xen/drivers/passthrough/pci.c | 78 +--------------------
>> xen/drivers/passthrough/x86/Makefile | 1 +
>> xen/drivers/passthrough/{io.c => x86/hvm.c} | 66 +++++++++++++++++
>> xen/drivers/passthrough/x86/iommu.c | 7 ++
>> xen/include/xen/pci.h | 2 +
>> 6 files changed, 77 insertions(+), 80 deletions(-)
>> rename xen/drivers/passthrough/{io.c => x86/hvm.c} (95%)
>>
>> diff --git a/xen/drivers/passthrough/Makefile
>> b/xen/drivers/passthrough/Makefile
>> index e973e16c74..cc646612c7 100644
>> --- a/xen/drivers/passthrough/Makefile
>> +++ b/xen/drivers/passthrough/Makefile
>> @@ -6,6 +6,3 @@ obj-$(CONFIG_ARM) += arm/
>> obj-y += iommu.o
>> obj-$(CONFIG_HAS_PCI) += pci.o
>> obj-$(CONFIG_HAS_DEVICE_TREE) += device_tree.o
>> -
>> -x86-$(CONFIG_HVM) := io.o
>> -obj-$(CONFIG_X86) += $(x86-y)
>> diff --git a/xen/drivers/passthrough/pci.c b/xen/drivers/passthrough/pci.c
>> index 51e584127e..e8a28df126 100644
>> --- a/xen/drivers/passthrough/pci.c
>> +++ b/xen/drivers/passthrough/pci.c
>> @@ -14,9 +14,6 @@
>> * this program; If not, see <http://www.gnu.org/licenses/>.
>> */
>>
>> -#include <xen/sched.h>
>> -#include <xen/pci.h>
>> -#include <xen/pci_regs.h>
>> #include <xen/pci_ids.h>
>> #include <xen/list.h>
>> #include <xen/prefetch.h>
>> @@ -24,7 +21,6 @@
>> #include <xen/irq.h>
>> #include <xen/param.h>
>> #include <xen/vm_event.h>
>> -#include <asm/hvm/irq.h>
>> #include <xen/delay.h>
>> #include <xen/keyhandler.h>
>> #include <xen/event.h>
>> @@ -842,71 +838,6 @@ int pci_remove_device(u16 seg, u8 bus, u8 devfn)
>> return ret;
>> }
>>
>> -static int pci_clean_dpci_irq(struct domain *d,
>> - struct hvm_pirq_dpci *pirq_dpci, void *arg)
>> -{
>> - struct dev_intx_gsi_link *digl, *tmp;
>> -
>> - pirq_guest_unbind(d, dpci_pirq(pirq_dpci));
>> -
>> - if ( pt_irq_need_timer(pirq_dpci->flags) )
>> - kill_timer(&pirq_dpci->timer);
>> -
>> - list_for_each_entry_safe ( digl, tmp, &pirq_dpci->digl_list, list )
>> - {
>> - list_del(&digl->list);
>> - xfree(digl);
>> - }
>> -
>> - radix_tree_delete(&d->pirq_tree, dpci_pirq(pirq_dpci)->pirq);
>> -
>> - if ( !pt_pirq_softirq_active(pirq_dpci) )
>> - return 0;
>> -
>> - domain_get_irq_dpci(d)->pending_pirq_dpci = pirq_dpci;
>> -
>> - return -ERESTART;
>> -}
>> -
>> -static int pci_clean_dpci_irqs(struct domain *d)
>> -{
>> - struct hvm_irq_dpci *hvm_irq_dpci = NULL;
>> -
>> - if ( !is_iommu_enabled(d) )
>> - return 0;
>> -
>> - if ( !is_hvm_domain(d) )
>> - return 0;
>> -
>> - spin_lock(&d->event_lock);
>> - hvm_irq_dpci = domain_get_irq_dpci(d);
>> - if ( hvm_irq_dpci != NULL )
>> - {
>> - int ret = 0;
>> -
>> - if ( hvm_irq_dpci->pending_pirq_dpci )
>> - {
>> - if ( pt_pirq_softirq_active(hvm_irq_dpci->pending_pirq_dpci) )
>> - ret = -ERESTART;
>> - else
>> - hvm_irq_dpci->pending_pirq_dpci = NULL;
>> - }
>> -
>> - if ( !ret )
>> - ret = pt_pirq_iterate(d, pci_clean_dpci_irq, NULL);
>> - if ( ret )
>> - {
>> - spin_unlock(&d->event_lock);
>> - return ret;
>> - }
>> -
>> - hvm_domain_irq(d)->dpci = NULL;
>> - free_hvm_irq_dpci(hvm_irq_dpci);
>> - }
>> - spin_unlock(&d->event_lock);
>> - return 0;
>> -}
>> -
>> /* Caller should hold the pcidevs_lock */
>> static int deassign_device(struct domain *d, uint16_t seg, uint8_t bus,
>> uint8_t devfn)
>> @@ -966,7 +897,7 @@ int pci_release_devices(struct domain *d)
>> int ret;
>>
>> pcidevs_lock();
>> - ret = pci_clean_dpci_irqs(d);
>> + ret = arch_pci_clean_pirqs(d);
>> if ( ret )
>> {
>> pcidevs_unlock();
>> @@ -1370,13 +1301,6 @@ static int __init setup_dump_pcidevs(void)
>> }
>> __initcall(setup_dump_pcidevs);
>>
>> -int iommu_update_ire_from_msi(
>> - struct msi_desc *msi_desc, struct msi_msg *msg)
>> -{
>> - return iommu_intremap
>> - ? iommu_call(&iommu_ops, update_ire_from_msi, msi_desc, msg) : 0;
>> -}
>> -
>> static int iommu_add_device(struct pci_dev *pdev)
>> {
>> const struct domain_iommu *hd;
>> diff --git a/xen/drivers/passthrough/x86/Makefile
>> b/xen/drivers/passthrough/x86/Makefile
>> index a70cf9460d..69284a5d19 100644
>> --- a/xen/drivers/passthrough/x86/Makefile
>> +++ b/xen/drivers/passthrough/x86/Makefile
>> @@ -1,2 +1,3 @@
>> obj-y += ats.o
>> obj-y += iommu.o
>> +obj-$(CONFIG_HVM) += hvm.o
>> diff --git a/xen/drivers/passthrough/io.c b/xen/drivers/passthrough/x86/hvm.c
>> similarity index 95%
>> rename from xen/drivers/passthrough/io.c
>> rename to xen/drivers/passthrough/x86/hvm.c
>> index 6b1305a3e5..41cfa2e200 100644
>> --- a/xen/drivers/passthrough/io.c
>> +++ b/xen/drivers/passthrough/x86/hvm.c
>> @@ -1036,6 +1036,72 @@ unlock:
>> spin_unlock(&d->event_lock);
>> }
>>
>> +static int pci_clean_dpci_irq(struct domain *d,
>> + struct hvm_pirq_dpci *pirq_dpci, void *arg)
>> +{
>> + struct dev_intx_gsi_link *digl, *tmp;
>> +
>> + pirq_guest_unbind(d, dpci_pirq(pirq_dpci));
>> +
>> + if ( pt_irq_need_timer(pirq_dpci->flags) )
>> + kill_timer(&pirq_dpci->timer);
>> +
>> + list_for_each_entry_safe ( digl, tmp, &pirq_dpci->digl_list, list )
>> + {
>> + list_del(&digl->list);
>> + xfree(digl);
>> + }
>> +
>> + radix_tree_delete(&d->pirq_tree, dpci_pirq(pirq_dpci)->pirq);
>> +
>> + if ( !pt_pirq_softirq_active(pirq_dpci) )
>> + return 0;
>> +
>> + domain_get_irq_dpci(d)->pending_pirq_dpci = pirq_dpci;
>> +
>> + return -ERESTART;
>> +}
>> +
>> +int arch_pci_clean_pirqs(struct domain *d)
>> +{
>> + struct hvm_irq_dpci *hvm_irq_dpci = NULL;
>> +
>> + if ( !is_iommu_enabled(d) )
>> + return 0;
>> +
>> + if ( !is_hvm_domain(d) )
>> + return 0;
>> +
>> + spin_lock(&d->event_lock);
>> + hvm_irq_dpci = domain_get_irq_dpci(d);
>> + if ( hvm_irq_dpci != NULL )
>> + {
>> + int ret = 0;
>> +
>> + if ( hvm_irq_dpci->pending_pirq_dpci )
>> + {
>> + if ( pt_pirq_softirq_active(hvm_irq_dpci->pending_pirq_dpci) )
>> + ret = -ERESTART;
>> + else
>> + hvm_irq_dpci->pending_pirq_dpci = NULL;
>> + }
>> +
>> + if ( !ret )
>> + ret = pt_pirq_iterate(d, pci_clean_dpci_irq, NULL);
>> + if ( ret )
>> + {
>> + spin_unlock(&d->event_lock);
>> + return ret;
>> + }
>> +
>> + hvm_domain_irq(d)->dpci = NULL;
>> + free_hvm_irq_dpci(hvm_irq_dpci);
>> + }
>> + spin_unlock(&d->event_lock);
>> +
>> + return 0;
>> +}
>> +
>> /*
>> * Note: 'pt_pirq_softirq_reset' can clear the STATE_SCHED before we get to
>> * doing it. If that is the case we let 'pt_pirq_softirq_reset' do
>> ref-counting.
>> diff --git a/xen/drivers/passthrough/x86/iommu.c
>> b/xen/drivers/passthrough/x86/iommu.c
>> index f17b1820f4..875e67b53b 100644
>> --- a/xen/drivers/passthrough/x86/iommu.c
>> +++ b/xen/drivers/passthrough/x86/iommu.c
>> @@ -308,6 +308,13 @@ struct page_info *iommu_alloc_pgtable(struct domain *d)
>> return pg;
>> }
>>
>> +int iommu_update_ire_from_msi(
>> + struct msi_desc *msi_desc, struct msi_msg *msg)
>> +{
>> + return iommu_intremap
>> + ? iommu_call(&iommu_ops, update_ire_from_msi, msi_desc, msg) : 0;
>> +}
>> +
>> /*
>> * Local variables:
>> * mode: C
>> diff --git a/xen/include/xen/pci.h b/xen/include/xen/pci.h
>> index 20a54a5bb4..78d83afe64 100644
>> --- a/xen/include/xen/pci.h
>> +++ b/xen/include/xen/pci.h
>> @@ -208,4 +208,6 @@ int msixtbl_pt_register(struct domain *, struct pirq *,
>> uint64_t gtable);
>> void msixtbl_pt_unregister(struct domain *, struct pirq *);
>> void msixtbl_pt_cleanup(struct domain *d);
>>
>> +int arch_pci_clean_pirqs(struct domain *d);
>> +
>> #endif /* __XEN_PCI_H__ */
>> --
>> 2.17.1
>>
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |