From: Keir Fraser <keir.fraser@eu.citrix.com>
To: Dulloor <dulloor@gmail.com>
Cc: "xen-devel@lists.xensource.com" <xen-devel@lists.xensource.com>
Subject: Re: [XEN][vNUMA][PATCH 3/9] public interface
Date: Mon, 5 Jul 2010 11:23:23 +0100 [thread overview]
Message-ID: <C857712B.19688%keir.fraser@eu.citrix.com> (raw)
In-Reply-To: <AANLkTikHJJcTkRa_9GP-S3Nf2TbT9KKMqk95U9Euy-Ws@mail.gmail.com>
> +#ifndef __XEN_PUBLIC_DOM_NUMA_X86_H__
> +#define __XEN_PUBLIC_DOM_NUMA_X86_H__
> +
> +/* struct xc_cpumask : static structure */
> +#define XEN_CPUMASK_BITS_PER_BYTE 8
> +#define XEN_CPUMASK_BITS_TO_BYTES(bits) \
> + (((bits)+XEN_CPUMASK_BITS_PER_BYTE-1)/XEN_CPUMASK_BITS_PER_BYTE)
>
> +#define XEN_MAX_VCPUS 128
> +#define XEN_CPUMASK_DECLARE_BITMAP(name,bits) \
> + uint8_t name[XEN_CPUMASK_BITS_TO_BYTES(bits)]
> +struct xen_cpumask{ XEN_CPUMASK_DECLARE_BITMAP(bits, XEN_MAX_VCPUS); };
> +#define XEN_CPUMASK_BITMAP(maskp) ((maskp)->bits)
What are xc_cpumask (a libxc concept) related definitions doing in a
hypervisor public header? These aren't even used in this header file. Below
I suggest a vcpu_to_vnode[] array, which probably gets rid of the need for
this bitmask stuff anyway.
> +#define XEN_MAX_VNODES 4
A small number to be statically defined. Better to make your structure
extensible I think, perhaps including pointers out to vnode-indexed arrays?
> +/* vnodes are 1GB-aligned */
> +#define XEN_MIN_VNODE_SHIFT (30)
> +
> +struct xen_vnode_info {
> + uint8_t vnode_id;
> + uint8_t mnode_id;
How do vnodes and mnodes differ? Why should a guest care about or need to
know about both, whatever they are?
> + uint32_t nr_pages;
Not an address range? Is that implicitly worked out somehow? Should be
commented, but even better just a <start,end> range explicitly given?
> + struct xen_cpumask vcpu_mask; /* vnode_to_vcpumask */
> +};
Why not have a single integer array vcpu_to_vnode[] in the main
xen_domain_numa_info structure?
> +#define XEN_DOM_NUMA_INTERFACE_VERSION 0x01
> +
> +#define XEN_DOM_NUMA_CONFINE 0x01
> +#define XEN_DOM_NUMA_SPLIT 0x02
> +#define XEN_DOM_NUMA_STRIPE 0x03
> +#define XEN_DOM_NUMA_DONTCARE 0x04
What should the guest do with these? You're rather light on comments in this
critical interface-defining header file.
> +struct xen_domain_numa_info {
> + uint8_t version;
> + uint8_t type;
> +
> + uint8_t nr_vcpus;
> + uint8_t nr_vnodes;
> +
> + /* XXX: hvm_info_table uses 32-bit for high_mem_pgend,
> + * so we should be fine 32-bits too*/
> + uint32_t nr_pages;
If this is going to be visible outside HVMloader (e.g., in PV guests) then
just make it a uint64_aligned_t and be done with it.
> + /* Only (nr_vnodes) entries are filled */
> + struct xen_vnode_info vnode_info[XEN_MAX_VNODES];
> + /* Only (nr_vnodes*nr_vnodes) entries are filled */
> + uint8_t vnode_distance[XEN_MAX_VNODES*XEN_MAX_VNODES];
As suggested above, make these pointers out to dynamic-sized arrays. No need
for XEN_MAX_VNODES at all.
-- Keir
> +};
> +
> +#endif
On 05/07/2010 09:52, "Dulloor" <dulloor@gmail.com> wrote:
> oops .. sorry, here it is.
>
> -dulloor
>
> On Mon, Jul 5, 2010 at 12:39 AM, Keir Fraser <keir.fraser@eu.citrix.com>
> wrote:
>> This patch is incomplete.
>>
>>
>> On 03/07/2010 00:54, "Dulloor" <dulloor@gmail.com> wrote:
>>
>>> Implement the structure that will be shared with hvmloader (with HVMs)
>>> and directly with the VMs (with PV).
>>>
>>> -dulloor
>>>
>>> Signed-off-by : Dulloor <dulloor@gmail.com>
>>
>>
>>
next prev parent reply other threads:[~2010-07-05 10:23 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <1BEA8649F0C00540AB2811D7922ECB6C9338B4CC@orsmsx507.amr.corp.intel.com>
2010-07-02 23:54 ` [XEN][vNUMA][PATCH 3/9] public interface Dulloor
2010-07-05 7:39 ` Keir Fraser
2010-07-05 8:52 ` Dulloor
2010-07-05 10:23 ` Keir Fraser [this message]
2010-07-06 5:57 ` Dulloor
2010-07-06 12:57 ` Keir Fraser
2010-07-06 17:52 ` Dulloor
2010-08-01 22:02 ` [vNUMA v2][PATCH 2/8] " Dulloor
2010-08-03 12:40 ` Andre Przywara
2010-08-03 15:24 ` Dulloor
2010-08-03 13:37 ` Andre Przywara
2010-08-03 14:10 ` Keir Fraser
2010-08-03 15:43 ` Dulloor
2010-08-03 15:52 ` Keir Fraser
2010-08-03 17:24 ` Dulloor
2010-08-03 19:52 ` Keir Fraser
2010-08-03 20:32 ` Dulloor
2010-08-03 21:55 ` Andre Przywara
2010-08-04 5:27 ` Keir Fraser
2010-08-04 5:48 ` Dulloor
2010-08-04 7:01 ` Andre Przywara
2010-08-04 8:45 ` Keir Fraser
2010-08-04 13:34 ` Dan Magenheimer
2010-08-03 21:35 ` Andre Przywara
2010-08-03 15:54 ` Keir Fraser
2010-08-03 15:32 ` Dulloor
2010-08-03 21:21 ` Andre Przywara
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=C857712B.19688%keir.fraser@eu.citrix.com \
--to=keir.fraser@eu.citrix.com \
--cc=dulloor@gmail.com \
--cc=xen-devel@lists.xensource.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).