[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-devel] [PATCH v7 00/21] Virtual NUMA for PV and HVM



Hi all

This is version 7 of this series rebased on top of master.

This patch series implements virtual NUMA support for both PV and HVM guest.
That is, admin can configure via libxl what virtual NUMA topology the guest
sees.

This is the stage 1 (basic vNUMA support) and part of stage 2 (vNUMA-ware
ballooning, hypervisor side) described in my previous email to xen-devel [0].

This series is broken into several parts:

1. xen patches: vNUMA debug output and vNUMA-aware memory hypercall support.
2. libxc/libxl support for PV vNUMA.
3. libxc/libxl/hypervisor support for HVM vNUMA.
4. xl vNUMA configuration documentation and parser.

One significant difference from Elena's work is that this patch series makes
use of multiple vmemranges should there be a memory hole, instead of shrinking
ram. This matches the behaviour of real hardware.

The vNUMA auto placement algorithm is missing at the moment and Dario is
working on it.

This series can be found at:
 git://xenbits.xen.org/people/liuw/xen.git wip.vnuma-v5

With this series, the following configuration can be used to enabled virtual
NUMA support, and it works for both PV and HVM guests.

vnuma = [ [ "pnode=0","size=3000","vcpus=0-3","vdistances=10,20"  ],
          [ "pnode=0","size=3000","vcpus=4-7","vdistances=20,10"  ],
        ]

For example output of guest NUMA information, please look at [1].

In terms of libxl / libxc internal, things are broken into several
parts:

1. libxl interface

Users of libxl can only specify how many vnodes a guest can have, but
currently they have no control over the actual memory layout. Note that
it's fairly easy to export the interface to control memory layout in the
future.

2. libxl internal

It generates some internal vNUMA configurations when building domain,
then transform them into libxc representations. It also validates vNUMA
configuration along the line.

3. libxc internal

Libxc does what it's told to do. It doesn't do anything smart (in fact,
I delibrately didn't put any smart logic inside it). Libxc will also
report back some information in HVM case to libxl but that's it.

Wei.

[0] <20141111173606.GC21312@xxxxxxxxxxxxxxxxxxxxx>
[1] <1416582421-10789-1-git-send-email-wei.liu2@xxxxxxxxxx>

Patches marked with "A" have already been acked. Hypervisor side patch and
toolstack side patches can be applied independently.

Wei Liu (21):
    xen: make two memory hypercalls vNUMA-aware

    libxc: duplicate snippet to allocate p2m_host array
 A  libxc: add p2m_size to xc_dom_image
 A  libxc: allocate memory with vNUMA information for PV guest
 A  libxl: introduce vNUMA types
 A  libxl: add vmemrange to libxl__domain_build_state
 A  libxl: introduce libxl__vnuma_config_check
 A  libxl: x86: factor out e820_host_sanitize
 A  libxl: functions to build vmemranges for PV guest
 A  libxl: build, check and pass vNUMA info to Xen for PV guest
 A  libxc: indentation change to xc_hvm_build_x86.c
 A  libxc: allocate memory with vNUMA information for HVM guest
 A  libxl: build, check and pass vNUMA info to Xen for HVM guest
 A  libxl: disallow memory relocation when vNUMA is enabled
    libxl: define LIBXL_HAVE_VNUMA

 A  libxlu: rework internal representation of setting
 A  libxlu: nested list support
    libxlu: record location when parsing values
 A  libxlu: introduce new APIs
 A  xl: introduce xcalloc
    xl: vNUMA support

 docs/man/xl.cfg.pod.5          |  59 +++++++++-
 tools/libxc/include/xc_dom.h   |  13 ++-
 tools/libxc/include/xenguest.h |  13 +++
 tools/libxc/xc_dom_arm.c       |   1 +
 tools/libxc/xc_dom_core.c      |   8 +-
 tools/libxc/xc_dom_x86.c       | 129 +++++++++++++++++----
 tools/libxc/xc_hvm_build_x86.c | 237 +++++++++++++++++++++++++-------------
 tools/libxl/Makefile           |   2 +-
 tools/libxl/libxl.h            |   7 ++
 tools/libxl/libxl_arch.h       |   6 +
 tools/libxl/libxl_arm.c        |   8 ++
 tools/libxl/libxl_create.c     |   9 ++
 tools/libxl/libxl_dm.c         |   6 +-
 tools/libxl/libxl_dom.c        | 120 ++++++++++++++++++++
 tools/libxl/libxl_internal.h   |  24 ++++
 tools/libxl/libxl_types.idl    |  10 ++
 tools/libxl/libxl_vnuma.c      | 252 +++++++++++++++++++++++++++++++++++++++++
 tools/libxl/libxl_x86.c        | 110 ++++++++++++++++--
 tools/libxl/libxlu_cfg.c       | 211 +++++++++++++++++++++++++---------
 tools/libxl/libxlu_cfg_i.h     |  14 ++-
 tools/libxl/libxlu_cfg_y.c     |  46 ++++----
 tools/libxl/libxlu_cfg_y.h     |   2 +-
 tools/libxl/libxlu_cfg_y.y     |  14 +--
 tools/libxl/libxlu_internal.h  |  25 +++-
 tools/libxl/libxlutil.h        |  13 +++
 tools/libxl/xl_cmdimpl.c       | 168 ++++++++++++++++++++++++++-
 xen/common/kernel.c            |   2 +-
 xen/common/memory.c            |  55 +++++++--
 xen/include/public/features.h  |   3 +
 xen/include/public/memory.h    |   2 +
 30 files changed, 1341 insertions(+), 228 deletions(-)
 create mode 100644 tools/libxl/libxl_vnuma.c

-- 
1.9.1


_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel


 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.