From: "Michael S. Tsirkin" <mst@redhat.com>
To: Andrey Korolyov <andrey@xdel.ru>
Cc: Igor Mammedov <imammedo@redhat.com>,
"qemu-devel@nongnu.org" <qemu-devel@nongnu.org>,
Paolo Bonzini <pbonzini@redhat.com>
Subject: Re: [Qemu-devel] [PATCH 08/11] pc: align DIMM's address/size by backend's alignment value
Date: Mon, 3 Nov 2014 20:01:16 +0200 [thread overview]
Message-ID: <20141103180116.GA7208@redhat.com> (raw)
In-Reply-To: <CABYiri9wXKj_G7+Y0nJK0Si=YvGPAyweUNapx50ptWB8iAP+CA@mail.gmail.com>
On Mon, Nov 03, 2014 at 09:48:20PM +0400, Andrey Korolyov wrote:
> On Fri, Oct 31, 2014 at 7:38 PM, Igor Mammedov <imammedo@redhat.com> wrote:
> > Performance wise it's better to align GVA by the backend's
> > page size.
> >
> > Also do not allow to create DIMM device with suboptimal
> > size (i.e. not aligned to backends page size) to aviod
> > memory loss.
> >
> > Do above only for 2.2 and newer machine types to avoid
> > breaking working configs with 2.1 machine type.
> >
> > Signed-off-by: Igor Mammedov <imammedo@redhat.com>
> > ---
> > hw/i386/pc.c | 15 +++++++++++++++
> > hw/i386/pc_piix.c | 3 +++
> > hw/i386/pc_q35.c | 3 +++
> > include/hw/i386/pc.h | 4 ++++
> > 4 files changed, 25 insertions(+)
> >
> > diff --git a/hw/i386/pc.c b/hw/i386/pc.c
> > index 1460074..ed50344 100644
> > --- a/hw/i386/pc.c
> > +++ b/hw/i386/pc.c
> > @@ -1605,6 +1605,10 @@ static void pc_dimm_plug(HotplugHandler *hotplug_dev,
> > goto out;
> > }
> >
> > + if (memory_region_get_alignment(mr) && pcms->enforce_aligned_dimm) {
> > + align = memory_region_get_alignment(mr);
> > + }
> > +
> > addr = pc_dimm_get_free_addr(pcms->hotplug_memory_base,
> > memory_region_size(&pcms->hotplug_memory),
> > !addr ? NULL : &addr, align,
> > @@ -1727,6 +1731,13 @@ static void pc_machine_set_max_ram_below_4g(Object *obj, Visitor *v,
> > pcms->max_ram_below_4g = value;
> > }
> >
> > +static bool pc_machine_get_aligned_dimm(Object *obj, Error **errp)
> > +{
> > + PCMachineState *pcms = PC_MACHINE(obj);
> > +
> > + return pcms->enforce_aligned_dimm;
> > +}
> > +
> > static void pc_machine_initfn(Object *obj)
> > {
> > PCMachineState *pcms = PC_MACHINE(obj);
> > @@ -1739,6 +1750,10 @@ static void pc_machine_initfn(Object *obj)
> > pc_machine_get_max_ram_below_4g,
> > pc_machine_set_max_ram_below_4g,
> > NULL, NULL, NULL);
> > + pcms->enforce_aligned_dimm = true;
> > + object_property_add_bool(obj, PC_MACHINE_ENFORCE_ALINED_DIMM,
> > + pc_machine_get_aligned_dimm,
> > + NULL, NULL);
> > }
> >
> > static void pc_machine_class_init(ObjectClass *oc, void *data)
> > diff --git a/hw/i386/pc_piix.c b/hw/i386/pc_piix.c
> > index 162b77e..4adcd9b 100644
> > --- a/hw/i386/pc_piix.c
> > +++ b/hw/i386/pc_piix.c
> > @@ -304,6 +304,9 @@ static void pc_init_pci(MachineState *machine)
> >
> > static void pc_compat_2_1(MachineState *machine)
> > {
> > + PCMachineState *pcms = PC_MACHINE(machine);
> > +
> > + pcms->enforce_aligned_dimm = false;
> > }
> >
> > static void pc_compat_2_0(MachineState *machine)
> > diff --git a/hw/i386/pc_q35.c b/hw/i386/pc_q35.c
> > index 0490980..cf4953e 100644
> > --- a/hw/i386/pc_q35.c
> > +++ b/hw/i386/pc_q35.c
> > @@ -282,6 +282,9 @@ static void pc_q35_init(MachineState *machine)
> >
> > static void pc_compat_2_1(MachineState *machine)
> > {
> > + PCMachineState *pcms = PC_MACHINE(machine);
> > +
> > + pcms->enforce_aligned_dimm = false;
> > }
> >
> > static void pc_compat_2_0(MachineState *machine)
> > diff --git a/include/hw/i386/pc.h b/include/hw/i386/pc.h
> > index c4ee520..a4e2a39 100644
> > --- a/include/hw/i386/pc.h
> > +++ b/include/hw/i386/pc.h
> > @@ -23,6 +23,8 @@
> > * address space begins.
> > * @hotplug_memory: hotplug memory addess space container
> > * @acpi_dev: link to ACPI PM device that performs ACPI hotplug handling
> > + * @enforce_aligned_dimm: check that DIMM's address/size is aligned by
> > + * backend's alignment value if provided
> > */
> > struct PCMachineState {
> > /*< private >*/
> > @@ -35,11 +37,13 @@ struct PCMachineState {
> > HotplugHandler *acpi_dev;
> >
> > uint64_t max_ram_below_4g;
> > + bool enforce_aligned_dimm;
> > };
> >
> > #define PC_MACHINE_ACPI_DEVICE_PROP "acpi-device"
> > #define PC_MACHINE_MEMHP_REGION_SIZE "hotplug-memory-region-size"
> > #define PC_MACHINE_MAX_RAM_BELOW_4G "max-ram-below-4g"
> > +#define PC_MACHINE_ENFORCE_ALINED_DIMM "enforce-aligned-dimm"
> >
> > /**
> > * PCMachineClass:
> > --
> > 1.8.3.1
> >
> >
>
>
> Spell: ALINED.
Igor as I've merged this tentatively, pls send fixup on top, with
fixup! prefix.
Thanks!
next prev parent reply other threads:[~2014-11-03 18:01 UTC|newest]
Thread overview: 31+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-10-31 16:38 [Qemu-devel] [PATCH 00/11] pc: kvm: memory hotplug fixes Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 01/11] pc: kvm: check if KVM has free memory slots to avoid abort() Igor Mammedov
2014-11-03 11:52 ` Paolo Bonzini
2014-11-04 14:51 ` Marcel Apfelbaum
2014-11-04 16:06 ` [Qemu-devel] [PATCH v2 " Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 02/11] kvm: provide API to query amount of memory slots supported by KVM Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 03/11] pc: check if KVM has enough memory slots for DIMM devices Igor Mammedov
2014-11-03 11:51 ` Paolo Bonzini
2014-11-03 17:00 ` Igor Mammedov
2014-11-03 17:32 ` Paolo Bonzini
2014-11-03 19:11 ` Igor Mammedov
2014-11-04 8:45 ` Paolo Bonzini
2014-11-04 15:39 ` Igor Mammedov
2014-11-04 15:42 ` Paolo Bonzini
2014-11-04 16:14 ` Igor Mammedov
2014-11-07 16:37 ` Paolo Bonzini
2014-10-31 16:38 ` [Qemu-devel] [PATCH 04/11] pc: make pc_dimm_plug() more readble Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 05/11] pc: limit DIMM address and size to page aligned values Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 06/11] memory: expose alignment used for allocating RAM as MemoryRegion API Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 07/11] pc: add pc_init_pci_2_1() and pc_compat_2_1() Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 08/11] pc: align DIMM's address/size by backend's alignment value Igor Mammedov
2014-11-03 17:48 ` Andrey Korolyov
2014-11-03 18:01 ` Michael S. Tsirkin [this message]
2014-11-03 19:30 ` [Qemu-devel] [PATCH 8/11] fixup! " Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 09/11] pc: pc-dimm: use backend alignment during address auto allocation Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 10/11] pc: explicitly check maxmem limit when adding DIMM Igor Mammedov
2014-11-06 14:16 ` [Qemu-devel] [PATCH 10/11] fixup! " Igor Mammedov
2014-10-31 16:38 ` [Qemu-devel] [PATCH 11/11] pc: count in 1Gb hugepage alignment when sizing hotplug-memory container Igor Mammedov
2014-11-04 16:10 ` [Qemu-devel] [PATCH v2 " Igor Mammedov
2014-11-02 10:36 ` [Qemu-devel] [PATCH 00/11] pc: kvm: memory hotplug fixes Michael S. Tsirkin
2014-11-03 11:52 ` Paolo Bonzini
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=20141103180116.GA7208@redhat.com \
--to=mst@redhat.com \
--cc=andrey@xdel.ru \
--cc=imammedo@redhat.com \
--cc=pbonzini@redhat.com \
--cc=qemu-devel@nongnu.org \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.