[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Xen-devel] [PATCH v3 4/7] sysctl: Add sysctl interface for querying PCI topology
 
- To: Andrew Cooper <andrew.cooper3@xxxxxxxxxx>, jbeulich@xxxxxxxx, keir@xxxxxxx,	ian.jackson@xxxxxxxxxxxxx, ian.campbell@xxxxxxxxxx,	stefano.stabellini@xxxxxxxxxxxxx, wei.liu2@xxxxxxxxxx
 
- From: Boris Ostrovsky <boris.ostrovsky@xxxxxxxxxx>
 
- Date: Tue, 10 Feb 2015 10:06:21 -0500
 
- Cc: dario.faggioli@xxxxxxxxxx, port-xen@xxxxxxxxxx, ufimtseva@xxxxxxxxx,	xen-devel@xxxxxxxxxxxxx
 
- Delivery-date: Tue, 10 Feb 2015 15:06:36 +0000
 
- List-id: Xen developer discussion <xen-devel.lists.xen.org>
 
 
 
On 02/10/2015 09:54 AM, Andrew Cooper wrote:
 
On 10/02/15 14:45, Boris Ostrovsky wrote:
 
On 02/10/2015 06:13 AM, Andrew Cooper wrote:
 
On 09/02/15 20:04, Boris Ostrovsky wrote:
 
Signed-off-by: Boris Ostrovsky <boris.ostrovsky@xxxxxxxxxx>
---
   xen/common/sysctl.c         |   73
+++++++++++++++++++++++++++++++++++++++++++
   xen/include/public/sysctl.h |   29 +++++++++++++++++
   2 files changed, 102 insertions(+), 0 deletions(-)
diff --git a/xen/common/sysctl.c b/xen/common/sysctl.c
index 30c5806..ea6557f 100644
--- a/xen/common/sysctl.c
+++ b/xen/common/sysctl.c
@@ -384,7 +384,80 @@ long
do_sysctl(XEN_GUEST_HANDLE_PARAM(xen_sysctl_t) u_sysctl)
           xfree(cputopo);
       }
       break;
+#ifdef HAS_PCI
+    case XEN_SYSCTL_pcitopoinfo:
+    {
+        xen_sysctl_pcitopoinfo_t *ti = &op->u.pcitopoinfo;
+        physdev_pci_device_t *devs;
+        uint8_t *nodes;
+        unsigned int first_dev, i;
+        int num_devs;
+
+        num_devs = ti->num_devs - ti->first_dev;
+
+        if ( guest_handle_is_null(ti->devs) ||
+             guest_handle_is_null(ti->nodes) ||
+             (num_devs <= 0) )
+        {
+            ret = -EINVAL;
+            break;
+        }
+
+        devs = xmalloc_array(physdev_pci_device_t, num_devs);
+        nodes = xmalloc_array(uint8_t, num_devs);
 
You can do all of this without any memory allocation at all, which will
simplify your error handling substantially.
Something along the lines of
for(...)
{
      copy one physdev_pci_device_t from the guest
      do the lookup
      copy one node id back to the guest
}
 
I am trying to avoid doing multiple copies. For lots of devices (IIRC,
you said you had a system with a few thousand), having two copies per
loop will add up, I think.
 
 
copy_to/from_guest() is not expensive.  It is a straight memcpy with an
extable guards for pagefaults.
 
 
 True, but still why do this inside a loop? xmalloc() of less than a page 
is not that expensive, is it?
 (The downside is that when we have really lots of devices we may be 
asking for more than one page. I know that we try not to do this but 
again, I think the expense would be amortised over long loops.).
-boris
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel
 
 
    
     |