[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] Re: [Xen-devel] [PATCH 02 of 11 v5] xen, libxc: introduce xc_nodemap_t
>>> On 10.04.13 at 18:05, Dario Faggioli <dario.faggioli@xxxxxxxxxx> wrote: > And its handling functions, following suit from xc_cpumap_t. > > Signed-off-by: Dario Faggioli <dario.faggioli@xxxxxxxxxx> > Acked-by: George Dunlap <george.dunlap@xxxxxxxxxxxxx> > Acked-by: Juergen Gross <juergen.gross@xxxxxxxxxxxxxx> > --- > Changes from v2: > * Discriminating between statically allocated nodemask_t and > dynamically allocated nodemask_var_t is not really necesssary, > given the maximum number of nodes won't ever grow that much, > so killed that hunk, as suggested during review. > > diff --git a/tools/libxc/xc_misc.c b/tools/libxc/xc_misc.c > --- a/tools/libxc/xc_misc.c > +++ b/tools/libxc/xc_misc.c > @@ -54,6 +54,11 @@ int xc_get_cpumap_size(xc_interface *xch > return (xc_get_max_cpus(xch) + 7) / 8; > } > > +int xc_get_nodemap_size(xc_interface *xch) > +{ > + return (xc_get_max_nodes(xch) + 7) / 8; > +} > + > xc_cpumap_t xc_cpumap_alloc(xc_interface *xch) > { > int sz; > @@ -64,6 +69,16 @@ xc_cpumap_t xc_cpumap_alloc(xc_interface > return calloc(1, sz); > } > > +xc_nodemap_t xc_nodemap_alloc(xc_interface *xch) > +{ > + int sz; > + > + sz = xc_get_nodemap_size(xch); > + if (sz == 0) > + return NULL; > + return calloc(1, sz); > +} > + > int xc_readconsolering(xc_interface *xch, > char *buffer, > unsigned int *pnr_chars, > diff --git a/tools/libxc/xenctrl.h b/tools/libxc/xenctrl.h > --- a/tools/libxc/xenctrl.h > +++ b/tools/libxc/xenctrl.h > @@ -330,12 +330,20 @@ int xc_get_cpumap_size(xc_interface *xch > /* allocate a cpumap */ > xc_cpumap_t xc_cpumap_alloc(xc_interface *xch); > > - /* > +/* > * NODEMAP handling > */ > +typedef uint8_t *xc_nodemap_t; > + > /* return maximum number of NUMA nodes the hypervisor supports */ > int xc_get_max_nodes(xc_interface *xch); > > +/* return array size for nodemap */ > +int xc_get_nodemap_size(xc_interface *xch); > + > +/* allocate a nodemap */ > +xc_nodemap_t xc_nodemap_alloc(xc_interface *xch); > + > /* > * DOMAIN DEBUGGING FUNCTIONS > */ > diff --git a/xen/common/domctl.c b/xen/common/domctl.c > --- a/xen/common/domctl.c > +++ b/xen/common/domctl.c > @@ -117,6 +117,20 @@ int xenctl_bitmap_to_cpumask(cpumask_var > return err; > } > > +int nodemask_to_xenctl_bitmap(struct xenctl_bitmap *xenctl_nodemap, > + const nodemask_t *nodemask) > +{ > + return bitmap_to_xenctl_bitmap(xenctl_nodemap, cpumask_bits(nodemask), This can hardly be cpumask_bits(). If you don't have a similar node mask accessor already, you should create one rather than abusing the CPU mask one. Jan > + MAX_NUMNODES); > +} > + > +int xenctl_bitmap_to_nodemask(nodemask_t *nodemask, > + const struct xenctl_bitmap *xenctl_nodemap) > +{ > + return xenctl_bitmap_to_bitmap(nodes_addr(*nodemask), xenctl_nodemap, > + MAX_NUMNODES); > +} > + > static inline int is_free_domid(domid_t dom) > { > struct domain *d; _______________________________________________ Xen-devel mailing list Xen-devel@xxxxxxxxxxxxx http://lists.xen.org/xen-devel
|
Lists.xenproject.org is hosted with RackSpace, monitoring our |