|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [XEN PATCH v10 4/5] tools: Add new function to get gsi from dev
On 2024/6/20 22:38, Anthony PERARD wrote:
> On Mon, Jun 17, 2024 at 05:00:34PM +0800, Jiqian Chen wrote:
>> diff --git a/tools/include/xencall.h b/tools/include/xencall.h
>> index fc95ed0fe58e..750aab070323 100644
>> --- a/tools/include/xencall.h
>> +++ b/tools/include/xencall.h
>> @@ -113,6 +113,8 @@ int xencall5(xencall_handle *xcall, unsigned int op,
>> uint64_t arg1, uint64_t arg2, uint64_t arg3,
>> uint64_t arg4, uint64_t arg5);
>>
>> +int xen_oscall_gsi_from_dev(xencall_handle *xcall, unsigned int sbdf);
>
> I don't think that an appropriate library for this new feature.
> libxencall is a generic lib to make hypercall.
Do you have a suggested place to put this new function?
This new function is to get gsi of a pci device, and only depend on the dom0
kernel, doesn't need to interact with hypervisor.
>
>> /* Variant(s) of the above, as needed, returning "long" instead of "int". */
>> long xencall2L(xencall_handle *xcall, unsigned int op,
>> uint64_t arg1, uint64_t arg2);
>> diff --git a/tools/include/xenctrl.h b/tools/include/xenctrl.h
>> index 9ceca0cffc2f..a0381f74d24b 100644
>> --- a/tools/include/xenctrl.h
>> +++ b/tools/include/xenctrl.h
>> @@ -1641,6 +1641,8 @@ int xc_physdev_unmap_pirq(xc_interface *xch,
>> uint32_t domid,
>> int pirq);
>>
>> +int xc_physdev_gsi_from_dev(xc_interface *xch, uint32_t sbdf);
>> +
>> /*
>> * LOGGING AND ERROR REPORTING
>> */
>> diff --git a/tools/libs/call/core.c b/tools/libs/call/core.c
>> index 02c4f8e1aefa..6dae50c9a6ba 100644
>> --- a/tools/libs/call/core.c
>> +++ b/tools/libs/call/core.c
>> @@ -173,6 +173,11 @@ int xencall5(xencall_handle *xcall, unsigned int op,
>> return osdep_hypercall(xcall, &call);
>> }
>>
>> +int xen_oscall_gsi_from_dev(xencall_handle *xcall, unsigned int sbdf)
>> +{
>> + return osdep_oscall(xcall, sbdf);
>> +}
>> +
>> /*
>> * Local variables:
>> * mode: C
>> diff --git a/tools/libs/call/libxencall.map b/tools/libs/call/libxencall.map
>> index d18a3174e9dc..b92a0b5dc12c 100644
>> --- a/tools/libs/call/libxencall.map
>> +++ b/tools/libs/call/libxencall.map
>> @@ -10,6 +10,8 @@ VERS_1.0 {
>> xencall4;
>> xencall5;
>>
>> + xen_oscall_gsi_from_dev;
>
> FYI, never change already released version of a library, this would add
> a new function to libxencall.1.0. Instead, when adding a new function
> to a library that is supposed to be stable (they have a *.map file in
> xen case), add it to a new section, that woud be VERS_1.4 in this case.
> But libxencall isn't approriate for this new function, so just for
> future reference.
>
>> xencall_alloc_buffer;
>> xencall_free_buffer;
>> xencall_alloc_buffer_pages;
>> diff --git a/tools/libs/call/linux.c b/tools/libs/call/linux.c
>> index 6d588e6bea8f..92c740e176f2 100644
>> --- a/tools/libs/call/linux.c
>> +++ b/tools/libs/call/linux.c
>> @@ -85,6 +85,21 @@ long osdep_hypercall(xencall_handle *xcall,
>> privcmd_hypercall_t *hypercall)
>> return ioctl(xcall->fd, IOCTL_PRIVCMD_HYPERCALL, hypercall);
>> }
>>
>> +int osdep_oscall(xencall_handle *xcall, unsigned int sbdf)
>> +{
>> + privcmd_gsi_from_dev_t dev_gsi = {
>> + .sbdf = sbdf,
>> + .gsi = -1,
>> + };
>> +
>> + if (ioctl(xcall->fd, IOCTL_PRIVCMD_GSI_FROM_DEV, &dev_gsi)) {
>
> Looks like libxencall is only for hypercall, and so I don't think
> it's the right place to introducing another ioctl() call.
It seems IOCTL_PRIVCMD_HYPERCALL is for hypercall.
What I do here is to introduce new call into privcmd fd.
Maybe I can open "/dev/xen/privcmd" directly, so that I don't have to add the
*_oscal function.
>
>> + PERROR("failed to get gsi from dev");
>> + return -1;
>> + }
>> +
>> + return dev_gsi.gsi;
>> +}
>> +
>> static void *alloc_pages_bufdev(xencall_handle *xcall, size_t npages)
>> {
>> void *p;
>> diff --git a/tools/libs/call/private.h b/tools/libs/call/private.h
>> index 9c3aa432efe2..cd6eb5a3e66f 100644
>> --- a/tools/libs/call/private.h
>> +++ b/tools/libs/call/private.h
>> @@ -57,6 +57,15 @@ int osdep_xencall_close(xencall_handle *xcall);
>>
>> long osdep_hypercall(xencall_handle *xcall, privcmd_hypercall_t *hypercall);
>>
>> +#if defined(__linux__)
>> +int osdep_oscall(xencall_handle *xcall, unsigned int sbdf);
>> +#else
>> +static inline int osdep_oscall(xencall_handle *xcall, unsigned int sbdf)
>> +{
>> + return -1;
>> +}
>> +#endif
>> +
>> void *osdep_alloc_pages(xencall_handle *xcall, size_t nr_pages);
>> void osdep_free_pages(xencall_handle *xcall, void *p, size_t nr_pages);
>>
>> diff --git a/tools/libs/ctrl/xc_physdev.c b/tools/libs/ctrl/xc_physdev.c
>> index 460a8e779ce8..c1458f3a38b5 100644
>> --- a/tools/libs/ctrl/xc_physdev.c
>> +++ b/tools/libs/ctrl/xc_physdev.c
>> @@ -111,3 +111,7 @@ int xc_physdev_unmap_pirq(xc_interface *xch,
>> return rc;
>> }
>>
>> +int xc_physdev_gsi_from_dev(xc_interface *xch, uint32_t sbdf)
>> +{
>
> I'm not sure if this is the best place for this new function, but I
> can't find another one, so that will do.
Thanks.
>
>> + return xen_oscall_gsi_from_dev(xch->xcall, sbdf);
>> +}
>> diff --git a/tools/libs/light/Makefile b/tools/libs/light/Makefile
>> index 37e4d1670986..6b616d5ee9b6 100644
>> --- a/tools/libs/light/Makefile
>> +++ b/tools/libs/light/Makefile
>> @@ -40,7 +40,7 @@ OBJS-$(CONFIG_X86) += $(ACPI_OBJS)
>>
>> CFLAGS += -Wno-format-zero-length -Wmissing-declarations -Wformat-nonliteral
>>
>> -CFLAGS-$(CONFIG_X86) += -DCONFIG_PCI_SUPP_LEGACY_IRQ
>> +CFLAGS-$(CONFIG_X86) += -DCONFIG_PCI_SUPP_LEGACY_IRQ -DCONFIG_X86
>>
>> OBJS-$(CONFIG_X86) += libxl_cpuid.o
>> OBJS-$(CONFIG_X86) += libxl_x86.o
>> diff --git a/tools/libs/light/libxl_pci.c b/tools/libs/light/libxl_pci.c
>> index 96cb4da0794e..376f91759ac6 100644
>> --- a/tools/libs/light/libxl_pci.c
>> +++ b/tools/libs/light/libxl_pci.c
>> @@ -1406,6 +1406,12 @@ static bool pci_supp_legacy_irq(void)
>> #endif
>> }
>>
>> +#define PCI_DEVID(bus, devfn)\
>> + ((((uint16_t)(bus)) << 8) | ((devfn) & 0xff))
>> +
>> +#define PCI_SBDF(seg, bus, devfn) \
>> + ((((uint32_t)(seg)) << 16) | (PCI_DEVID(bus, devfn)))
>> +
>> static void pci_add_dm_done(libxl__egc *egc,
>> pci_add_state *pas,
>> int rc)
>> @@ -1418,6 +1424,10 @@ static void pci_add_dm_done(libxl__egc *egc,
>> unsigned long long start, end, flags, size;
>> int irq, i;
>> int r;
>> +#ifdef CONFIG_X86
>> + int gsi;
>> + uint32_t sbdf;
>> +#endif
>> uint32_t flag = XEN_DOMCTL_DEV_RDM_RELAXED;
>> uint32_t domainid = domid;
>> bool isstubdom = libxl_is_stubdom(ctx, domid, &domainid);
>> @@ -1486,6 +1496,18 @@ static void pci_add_dm_done(libxl__egc *egc,
>> goto out_no_irq;
>> }
>> if ((fscanf(f, "%u", &irq) == 1) && irq) {
>> +#ifdef CONFIG_X86
>
> Could you avoid these #ifdef, and move the new arch specific code (and
> maybe existing code) into libxl_x86.c ? There's already examples of arch
> specific code.
OK, will do in next version.
>
>> + sbdf = PCI_SBDF(pci->domain, pci->bus,
>> + (PCI_DEVFN(pci->dev, pci->func)));
>> + gsi = xc_physdev_gsi_from_dev(ctx->xch, sbdf);
>> + /*
>> + * Old kernel version may not support this function,
>> + * so if fail, keep using irq; if success, use gsi
>> + */
>> + if (gsi > 0) {
>> + irq = gsi;
>> + }
>> +#endif
>> r = xc_physdev_map_pirq(ctx->xch, domid, irq, &irq);
>> if (r < 0) {
>> LOGED(ERROR, domainid, "xc_physdev_map_pirq irq=%d (error=%d)",
>> @@ -2172,6 +2194,10 @@ static void pci_remove_detached(libxl__egc *egc,
>> int irq = 0, i, stubdomid = 0;
>> const char *sysfs_path;
>> FILE *f;
>> +#ifdef CONFIG_X86
>> + int gsi;
>> + uint32_t sbdf;
>> +#endif
>> uint32_t domainid = prs->domid;
>> bool isstubdom;
>>
>> @@ -2239,6 +2265,18 @@ skip_bar:
>> }
>>
>> if ((fscanf(f, "%u", &irq) == 1) && irq) {
>> +#ifdef CONFIG_X86
>> + sbdf = PCI_SBDF(pci->domain, pci->bus,
>> + (PCI_DEVFN(pci->dev, pci->func)));
>> + gsi = xc_physdev_gsi_from_dev(ctx->xch, sbdf);
>> + /*
>> + * Old kernel version may not support this function,
>> + * so if fail, keep using irq; if success, use gsi
>> + */
>> + if (gsi > 0) {
>> + irq = gsi;
>> + }
>> +#endif
>> rc = xc_physdev_unmap_pirq(ctx->xch, domid, irq);
>> if (rc < 0) {
>> /*
>
> Thanks,
>
--
Best regards,
Jiqian Chen.
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |