qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
From: Igor Mammedov <imammedo@redhat.com>
To: "Michael S. Tsirkin" <mst@redhat.com>
Cc: peter.maydell@linaro.org, stefanha@redhat.com,
	stefanb@linux.vnet.ibm.com, qemu-devel@nongnu.org,
	chegu_vinod@hp.com, marcel.a@redhat.com, mjt@tls.msk.ru,
	mdroth@linux.vnet.ibm.com, armbru@redhat.com,
	vasilis.liaskovitis@profitbricks.com, quintela@redhat.com,
	kraxel@redhat.com, aliguori@amazon.com, hutao@cn.fujitsu.com,
	pbonzini@redhat.com, lcapitulino@redhat.com, afaerber@suse.de
Subject: Re: [Qemu-devel] [PATCH 00/27 RFC v7] ACPI memory hotplug
Date: Thu, 21 Nov 2013 14:39:10 +0100	[thread overview]
Message-ID: <20131121143910.066abec9@nial.usersys.redhat.com> (raw)
In-Reply-To: <20131121062056.GD19005@redhat.com>

On Thu, 21 Nov 2013 08:20:56 +0200
"Michael S. Tsirkin" <mst@redhat.com> wrote:

> On Thu, Nov 21, 2013 at 03:38:21AM +0100, Igor Mammedov wrote:
> > ---
> > What's new since v6:
> > 
> > * DIMM device is split to backend and frontend. Therefore following
> >   command/options were added for supporting it:
> > 
> >   For memdev backend:
> >       CLI: -memdev-add
> >       Monitor/QMP: memdev-add
> >           with options: 'id' and 'size'
> >   For dimm frontend:
> >       option "size" became readonly, pulling it's size from attached backend
> >       added option "memdev" for specifying backend by 'id'
> > 
> > * Added Q35 support
> > * Added support for 32 bit guests
> > * build for i386 emulator (not tested)
> 
> OK so a large patchset so did not review yet.  One question
> due to the dependency on bios honouring etc/reserved-memory-end: is
> there some way to detect old BIOS and fail memory hotplug?
version negotiation between ASL and hardware could be used to that effect.

QEMU could start with present but disabled memory hotplug and if
QEMU and BIOS ASL could come in agreement that both support it in
compatible way, it could be enabled.

> 
> > ---
> > 
> > This series allows to hotplug 'arbitrary' DIMM devices specifying size,
> > NUMA node mapping (guest side), slot and address where to map it, at runtime.
> > 
> > Due to ACPI limitation there is need to specify a number of possible
> > DIMM devices. For this task -m option was extended to support
> > following format:
> > 
> >   -m [mem=]RamSize[,slots=N,maxmem=M]
> > 
> > To allow memory hotplug user must specify a pair of additional parameters:
> >     'slots' - number of possible increments
> >     'maxmem' - max possible total memory size QEMU is allowed to use,
> >                including RamSize.
> > 
> > minimal monitor command syntax to hotplug DIMM device:
> > 
> >   memdev-add id=memX,size=1G
> >   device_add dimm,id=dimmX,memdev=memX
> > 
> > DIMM device provides following properties that could be used with
> > device_add / -device to alter default behavior:
> > 
> >   id    - unique string identifying device [mandatory]
> >   slot  - number in range [0-slots) [optional], if not specified
> >           the first free slot is used
> >   node  - NUMA node id [optional] (default: 0)
> >   size  - amount of memory to add, readonly derived from backing memdev
> >   start - guest's physical address where to plug DIMM [optional],
> >           if not specified the first gap in hotplug memory region
> >           that fits DIMM is used
> > 
> >  -device option could be used for adding potentially hotunplugable DIMMs
> > and also for specifying hotplugged DIMMs in migration case.
> > 
> > Tested guests:
> >  - RHEL 6x64
> >  - Windows 2012DCx64
> >  - Windows 2008DCx64
> >  - Windows 2008DCx32
> > 
> > Known limitations/bugs/TODOs:
> >  - only hot-add supported
> >  - max number of supported DIMM devices 255 (due to ACPI object name
> >    limit), could be increased creating several containers and putting
> >    DIMMs there. (exercise for future) 
> >  - failed hotplug action consumes 1 slot (device_add doesn't delete
> >    device properly if realize failed)
> >  - e820 table doesn't include DIMM devices added with -device /
> >    (or after reboot devices added with device_add)
> >  - Windows 2008 remembers DIMM configuration, so if DIMM with other
> >    start/size is added into the same slot, it refuses to use it insisting
> >    on old mapping.
> > 
> > Series is based on mst's PCI tree and requires following SeaBIOS patch:
> >   http://patchwork.ozlabs.org/patch/292614/
> >   on top of patches to load ACPI tables from QEMU
> >   working SeaBIOS tree for testing is available at:
> >     https://github.com/imammedo/seabios/commits/memhp-wip
> > 
> > QEMU git tree for testing is available at:
> >   https://github.com/imammedo/qemu/commits/memory-hotplug-v7
> > 
> > Example QEMU cmd line:
> >   qemu-system-x86_64 -enable-kvm -monitor unix:/tmp/mon,server,nowait \ 
> >      -m 4096,slots=4,maxmem=8G -L /custome_seabios guest.img
> > 
> > PS:
> >   Windows guest requires SRAT table for hotplug to work so add extra option:
> >    -numa node
> >   to QEMU command line.
> > 
> > 
> > Igor Mammedov (26):
> >   acpi: factor out common pm_update_sci() into acpi core
> >   rename pci_hotplug_fn to hotplug_fn and make it available for other
> >     devices
> >   pc: add 'etc/reserved-memory-end' fw_cfg interface for SeaBIOS
> >   vl: convert -m to qemu_opts_parse()
> >   qapi: add SIZE type parser to string_input_visitor
> >   get reference to /backend container via qemu_get_backend()
> >   add memdev backend infrastructure
> >   dimm: map DimmDevice into DimBus provided address space
> >   dimm: add busy slot check and slot auto-allocation
> >   dimm: add busy address check and address auto-allocation
> >   dimm: add hotplug callback to DimmBus
> >   acpi: memory hotplug ACPI hardware implementation
> >   acpi: initialize memory hotplug ACPI PIIX4 hardware
> >   acpi: piix4: add memory-hotplug-io-base property to piix4_pm
> >   acpi: ich9: allow guest to clear SCI rised by GPE
> >   acpi: initialize memory hotplug ACPI ICH9 hardware
> >   acpi: ich9: add memory-hotplug-io-base property to ich9_pm
> >   acpi: piix4/ich9: add optional vmstate field for MemHotplugState
> >     migration
> >   pc: piix: make PCII440FXState type public
> >   pc: add memory hotplug 440fx machine
> >   pc: add memory hotplug Q35 machine
> >   pc: ACPI BIOS: implement memory hotplug interface
> >   pc: ACPI BIOS: add ssdt-mem.hex.generated and update
> >     ssdt-misc.hex.generated
> >   pc: ACPI BIOS: use enum for defining memory affinity flags
> >   pc: ACPI BIOS: reserve SRAT entry for hotplug mem hole
> >   pc: ACPI BIOS: make GPE.3 handle memory hotplug event on PIIX and Q35
> >     machines
> > 
> > Vasilis Liaskovitis (1):
> >   dimm: implement dimm device abstraction
> > 
> >  backends/Makefile.objs             |    2 +
> >  backends/hostmem.c                 |  275 +++++++++++
> >  backends/hostmem_compat_ram.c      |   42 ++
> >  default-configs/i386-softmmu.mak   |    1 +
> >  default-configs/x86_64-softmmu.mak |    1 +
> >  docs/specs/acpi_mem_hotplug.txt    |   38 ++
> >  hmp-commands.hx                    |   13 +
> >  hw/Makefile.objs                   |    1 +
> >  hw/acpi/core.c                     |  189 ++++++++
> >  hw/acpi/ich9.c                     |   57 ++-
> >  hw/acpi/pcihp.c                    |    6 +-
> >  hw/acpi/piix4.c                    |   91 +++--
> >  hw/i386/Makefile.objs              |    3 +-
> >  hw/i386/acpi-build.c               |   91 ++++-
> >  hw/i386/acpi-dsdt.dsl              |    5 +-
> >  hw/i386/pc.c                       |   90 ++++-
> >  hw/i386/pc_piix.c                  |    7 +-
> >  hw/i386/pc_q35.c                   |    4 +
> >  hw/i386/q35-acpi-dsdt.dsl          |    5 +-
> >  hw/i386/ssdt-mem.dsl               |   75 +++
> >  hw/i386/ssdt-mem.hex.generated     |  197 ++++++++
> >  hw/i386/ssdt-misc.dsl              |  179 ++++++++
> >  hw/i386/ssdt-misc.hex.generated    |  881 +++++++++++++++++++++++++++++++++++-
> >  hw/mem/Makefile.objs               |    1 +
> >  hw/mem/dimm.c                      |  321 +++++++++++++
> >  hw/pci-host/piix.c                 |   36 +-
> >  hw/pci-host/q35.c                  |   19 +-
> >  hw/pci/pci.c                       |   12 +-
> >  hw/pci/pcie.c                      |    7 +-
> >  hw/pci/shpc.c                      |    9 +-
> >  include/hw/acpi/acpi.h             |   42 ++
> >  include/hw/acpi/ich9.h             |    6 +
> >  include/hw/acpi/pcihp.h            |    2 +-
> >  include/hw/acpi/piix4.h            |    2 +
> >  include/hw/i386/pc.h               |   33 ++-
> >  include/hw/mem/dimm.h              |   99 ++++
> >  include/hw/pci-host/piix.h         |   29 ++
> >  include/hw/pci-host/q35.h          |    1 +
> >  include/hw/pci/pci.h               |   11 +-
> >  include/hw/pci/pci_bus.h           |    2 +-
> >  include/hw/qdev-core.h             |    9 +
> >  include/sysemu/hostmem.h           |  102 +++++
> >  include/sysemu/sysemu.h            |    3 +
> >  monitor.c                          |    1 +
> >  qapi-schema.json                   |   18 +
> >  qapi/string-input-visitor.c        |   18 +
> >  qemu-options.hx                    |   16 +-
> >  qmp-commands.hx                    |   27 ++
> >  ui/console.c                       |    3 +-
> >  vl.c                               |   98 ++++-
> >  50 files changed, 3040 insertions(+), 140 deletions(-)
> >  create mode 100644 backends/hostmem.c
> >  create mode 100644 backends/hostmem_compat_ram.c
> >  create mode 100644 docs/specs/acpi_mem_hotplug.txt
> >  create mode 100644 hw/i386/ssdt-mem.dsl
> >  create mode 100644 hw/i386/ssdt-mem.hex.generated
> >  create mode 100644 hw/mem/Makefile.objs
> >  create mode 100644 hw/mem/dimm.c
> >  create mode 100644 include/hw/mem/dimm.h
> >  create mode 100644 include/hw/pci-host/piix.h
> >  create mode 100644 include/sysemu/hostmem.h

  reply	other threads:[~2013-11-21 13:39 UTC|newest]

Thread overview: 143+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-11-21  2:38 [Qemu-devel] [PATCH 00/27 RFC v7] ACPI memory hotplug Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 01/27] acpi: factor out common pm_update_sci() into acpi core Igor Mammedov
2013-12-05 12:37   ` Michael S. Tsirkin
2013-12-05 15:11     ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 02/27] rename pci_hotplug_fn to hotplug_fn and make it available for other devices Igor Mammedov
2013-11-25 12:49   ` Paolo Bonzini
2013-11-25 13:11     ` Paolo Bonzini
2013-11-25 15:57     ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 03/27] pc: add 'etc/reserved-memory-end' fw_cfg interface for SeaBIOS Igor Mammedov
2013-12-19 14:35   ` Michael S. Tsirkin
2013-12-20 12:48     ` Igor Mammedov
2013-12-22 11:20       ` Michael S. Tsirkin
2013-11-21  2:38 ` [Qemu-devel] [PATCH 04/27] vl: convert -m to qemu_opts_parse() Igor Mammedov
2013-11-21  6:01   ` Li Guang
2013-11-21 13:45     ` Igor Mammedov
2013-11-21 10:12   ` Markus Armbruster
2013-11-26 13:17     ` Igor Mammedov
2013-11-26 14:49       ` Markus Armbruster
2013-11-26 16:55         ` Igor Mammedov
2013-11-27 14:35           ` Markus Armbruster
2013-11-27 15:28             ` Igor Mammedov
2013-11-27 17:31               ` Markus Armbruster
2013-11-27  0:27         ` [Qemu-devel] [PATCH 04/28] vl: convert -m to QemuOpts Igor Mammedov
2013-11-27  0:27           ` [Qemu-devel] [PATCH 05/28] vl.c: extend -m option to support options for memory hotplug Igor Mammedov
2013-12-10  7:23           ` [Qemu-devel] [PATCH 04/28] vl: convert -m to QemuOpts Paolo Bonzini
2013-12-10 10:53             ` Igor Mammedov
2013-11-25 12:51   ` [Qemu-devel] [PATCH 04/27] vl: convert -m to qemu_opts_parse() Paolo Bonzini
2013-11-27  0:32     ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 05/27] qapi: add SIZE type parser to string_input_visitor Igor Mammedov
2013-11-21 10:15   ` Markus Armbruster
2013-11-25 15:36     ` Igor Mammedov
2013-11-25 16:04       ` Michael S. Tsirkin
2013-11-25 16:32         ` Paolo Bonzini
2013-11-25 16:43           ` Eric Blake
2013-11-25 17:01             ` Paolo Bonzini
2013-11-27 14:15             ` Markus Armbruster
2013-11-27 15:17               ` Paolo Bonzini
2013-11-27 17:02                 ` Markus Armbruster
2013-11-27 17:10                   ` Paolo Bonzini
2013-12-19 14:40             ` Michael S. Tsirkin
2013-12-19 15:14               ` Markus Armbruster
2013-12-19 15:32                 ` Michael S. Tsirkin
2013-12-19 15:31               ` Paolo Bonzini
2013-12-19 15:40                 ` Michael S. Tsirkin
2013-12-19 15:46                   ` Paolo Bonzini
2013-11-21  2:38 ` [Qemu-devel] [PATCH 06/27] get reference to /backend container via qemu_get_backend() Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 07/27] add memdev backend infrastructure Igor Mammedov
2013-11-25 12:54   ` Paolo Bonzini
2013-11-25 16:01     ` Igor Mammedov
2013-11-25 16:09       ` Paolo Bonzini
2013-11-27 14:37         ` Igor Mammedov
2013-11-27 15:21           ` Paolo Bonzini
2013-11-27 15:57             ` Igor Mammedov
2013-11-27 15:25   ` Eric Blake
2013-11-27 16:09     ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 08/27] dimm: implement dimm device abstraction Igor Mammedov
2013-11-25 12:57   ` Paolo Bonzini
2013-11-25 15:10     ` Igor Mammedov
2013-11-25 15:16       ` Paolo Bonzini
2013-11-21  2:38 ` [Qemu-devel] [PATCH 09/27] dimm: map DimmDevice into DimBus provided address space Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 10/27] dimm: add busy slot check and slot auto-allocation Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 11/27] dimm: add busy address check and address auto-allocation Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 12/27] dimm: add hotplug callback to DimmBus Igor Mammedov
2013-11-25 13:01   ` Paolo Bonzini
2013-11-25 14:40     ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 13/27] acpi: memory hotplug ACPI hardware implementation Igor Mammedov
2013-11-21  9:42   ` Michael S. Tsirkin
2013-11-21 14:21     ` Igor Mammedov
2013-11-21 14:38       ` Michael S. Tsirkin
2013-11-22 17:14         ` Igor Mammedov
2013-11-24 10:58           ` Michael S. Tsirkin
2013-11-25  7:27             ` Markus Armbruster
2013-11-25 13:45               ` Paolo Bonzini
2013-11-25 14:18                 ` Igor Mammedov
2013-11-25 14:31                   ` Paolo Bonzini
2013-11-25 14:57                     ` Igor Mammedov
2013-11-25 13:56             ` Igor Mammedov
2013-11-27 17:59   ` Eric Blake
2013-11-21  2:38 ` [Qemu-devel] [PATCH 14/27] acpi: initialize memory hotplug ACPI PIIX4 hardware Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 15/27] acpi: piix4: add memory-hotplug-io-base property to piix4_pm Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 16/27] acpi: ich9: allow guest to clear SCI rised by GPE Igor Mammedov
2013-11-21  7:14   ` Michael S. Tsirkin
2013-11-21  8:12     ` Hu Tao
2013-11-21  8:18       ` Li Guang
2013-11-21  8:29         ` Michael S. Tsirkin
2013-11-21  8:32           ` Li Guang
2013-11-21  9:43             ` Michael S. Tsirkin
2013-11-22  0:57               ` Li Guang
2013-11-25 11:13                 ` Igor Mammedov
2013-11-26  0:29                   ` Li Guang
2013-11-26 22:36                     ` Igor Mammedov
2013-11-27  0:15                       ` Li Guang
2013-11-27  0:57                         ` Igor Mammedov
2013-11-27  1:48                           ` Li Guang
2013-11-27  9:43                             ` Paolo Bonzini
2013-11-21 13:19             ` Igor Mammedov
2013-11-22  1:03               ` Li Guang
2013-11-21  8:26       ` Michael S. Tsirkin
2013-11-21  8:28         ` Hu Tao
2013-11-21 13:31           ` Igor Mammedov
2013-11-21 13:21         ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 17/27] acpi: initialize memory hotplug ACPI ICH9 hardware Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 18/27] acpi: ich9: add memory-hotplug-io-base property to ich9_pm Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 19/27] acpi: piix4/ich9: add optional vmstate field for MemHotplugState migration Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 20/27] pc: piix: make PCII440FXState type public Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 21/27] pc: add memory hotplug 440fx machine Igor Mammedov
2013-11-21  5:48   ` Li Guang
2013-11-21 14:13     ` Andreas Färber
2013-11-21 14:34       ` Igor Mammedov
2013-11-21 14:39         ` Michael S. Tsirkin
2013-11-21 16:09         ` Andreas Färber
2013-11-21 16:17           ` Michael S. Tsirkin
2013-11-25 10:41           ` Igor Mammedov
2013-11-25 17:00             ` Andreas Färber
2013-11-26 20:26               ` Igor Mammedov
2013-11-22 14:23   ` Gerd Hoffmann
2013-11-25 11:00     ` Igor Mammedov
2013-11-25 11:39       ` Gerd Hoffmann
2013-11-25 13:34         ` Igor Mammedov
2013-11-25 13:35         ` Paolo Bonzini
2013-11-25 14:24           ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 22/27] pc: add memory hotplug Q35 machine Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 23/27] pc: ACPI BIOS: implement memory hotplug interface Igor Mammedov
2013-11-21  9:37   ` Michael S. Tsirkin
2013-11-25 14:39     ` Igor Mammedov
2013-12-16 19:50       ` Michael S. Tsirkin
2013-12-16 21:42         ` Igor Mammedov
2013-11-25 13:42   ` Paolo Bonzini
2013-11-25 14:26     ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 24/27] pc: ACPI BIOS: add ssdt-mem.hex.generated and update ssdt-misc.hex.generated Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 25/27] pc: ACPI BIOS: use enum for defining memory affinity flags Igor Mammedov
2013-11-21  7:20   ` Michael S. Tsirkin
2013-11-25 10:11     ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 26/27] pc: ACPI BIOS: reserve SRAT entry for hotplug mem hole Igor Mammedov
2013-11-21  7:18   ` Michael S. Tsirkin
2013-11-25 10:11     ` Igor Mammedov
2013-11-21  2:38 ` [Qemu-devel] [PATCH 27/27] pc: ACPI BIOS: make GPE.3 handle memory hotplug event on PIIX and Q35 machines Igor Mammedov
2013-11-21  6:20 ` [Qemu-devel] [PATCH 00/27 RFC v7] ACPI memory hotplug Michael S. Tsirkin
2013-11-21 13:39   ` Igor Mammedov [this message]
2013-11-21 13:43     ` Michael S. Tsirkin
2013-11-21 14:37       ` Igor Mammedov
2013-11-21 14:45         ` Michael S. Tsirkin
2013-11-25 10:09           ` Igor Mammedov

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=20131121143910.066abec9@nial.usersys.redhat.com \
    --to=imammedo@redhat.com \
    --cc=afaerber@suse.de \
    --cc=aliguori@amazon.com \
    --cc=armbru@redhat.com \
    --cc=chegu_vinod@hp.com \
    --cc=hutao@cn.fujitsu.com \
    --cc=kraxel@redhat.com \
    --cc=lcapitulino@redhat.com \
    --cc=marcel.a@redhat.com \
    --cc=mdroth@linux.vnet.ibm.com \
    --cc=mjt@tls.msk.ru \
    --cc=mst@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=peter.maydell@linaro.org \
    --cc=qemu-devel@nongnu.org \
    --cc=quintela@redhat.com \
    --cc=stefanb@linux.vnet.ibm.com \
    --cc=stefanha@redhat.com \
    --cc=vasilis.liaskovitis@profitbricks.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).