|
[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 |