All of lore.kernel.org
 help / color / mirror / Atom feed
From: David Hildenbrand <david@redhat.com>
To: qemu-devel@nongnu.org
Cc: qemu-ppc@nongnu.org, Eduardo Habkost <ehabkost@redhat.com>,
	Igor Mammedov <imammedo@redhat.com>,
	"Michael S . Tsirkin" <mst@redhat.com>,
	Marcel Apfelbaum <marcel.apfelbaum@gmail.com>,
	Paolo Bonzini <pbonzini@redhat.com>,
	Richard Henderson <rth@twiddle.net>,
	Xiao Guangrong <xiaoguangrong.eric@gmail.com>,
	David Gibson <david@gibson.dropbear.id.au>,
	Alexander Graf <agraf@suse.de>,
	David Hildenbrand <david@redhat.com>
Subject: [Qemu-devel] [PATCH v3 10/13] nvdimm: convert nvdimm_mr into a pointer
Date: Fri, 15 Jun 2018 16:04:45 +0200	[thread overview]
Message-ID: <20180615140448.32234-11-david@redhat.com> (raw)
In-Reply-To: <20180615140448.32234-1-david@redhat.com>

This way we can easily check if the region has already been inititalized
without having to rely on the size of an uninitialized region being 0.

Signed-off-by: David Hildenbrand <david@redhat.com>
---
 hw/mem/nvdimm.c         | 9 +++++----
 include/hw/mem/nvdimm.h | 2 +-
 2 files changed, 6 insertions(+), 5 deletions(-)

diff --git a/hw/mem/nvdimm.c b/hw/mem/nvdimm.c
index 7260c9c6b1..db7d8c3050 100644
--- a/hw/mem/nvdimm.c
+++ b/hw/mem/nvdimm.c
@@ -43,7 +43,7 @@ static void nvdimm_set_label_size(Object *obj, Visitor *v, const char *name,
     Error *local_err = NULL;
     uint64_t value;
 
-    if (memory_region_size(&nvdimm->nvdimm_mr)) {
+    if (nvdimm->nvdimm_mr) {
         error_setg(&local_err, "cannot change property value");
         goto out;
     }
@@ -75,7 +75,7 @@ static MemoryRegion *nvdimm_get_memory_region(PCDIMMDevice *dimm, Error **errp)
 {
     NVDIMMDevice *nvdimm = NVDIMM(dimm);
 
-    return &nvdimm->nvdimm_mr;
+    return nvdimm->nvdimm_mr;
 }
 
 static void nvdimm_realize(PCDIMMDevice *dimm, Error **errp)
@@ -102,9 +102,10 @@ static void nvdimm_realize(PCDIMMDevice *dimm, Error **errp)
         return;
     }
 
-    memory_region_init_alias(&nvdimm->nvdimm_mr, OBJECT(dimm),
+    nvdimm->nvdimm_mr = g_new(MemoryRegion, 1);
+    memory_region_init_alias(nvdimm->nvdimm_mr, OBJECT(dimm),
                              "nvdimm-memory", mr, 0, pmem_size);
-    nvdimm->nvdimm_mr.align = align;
+    nvdimm->nvdimm_mr->align = align;
 }
 
 /*
diff --git a/include/hw/mem/nvdimm.h b/include/hw/mem/nvdimm.h
index 9340631cfc..c5c9b3c7f8 100644
--- a/include/hw/mem/nvdimm.h
+++ b/include/hw/mem/nvdimm.h
@@ -74,7 +74,7 @@ struct NVDIMMDevice {
      * it's the PMEM region in NVDIMM device, which is presented to
      * guest via ACPI NFIT and _FIT method if NVDIMM hotplug is supported.
      */
-    MemoryRegion nvdimm_mr;
+    MemoryRegion *nvdimm_mr;
 
     /*
      * The 'on' value results in the unarmed flag set in ACPI NFIT,
-- 
2.17.1

  parent reply	other threads:[~2018-06-15 14:05 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-06-15 14:04 [Qemu-devel] [PATCH v3 00/13] pc-dimm: next bunch of cleanups David Hildenbrand
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 01/13] pc-dimm: remove leftover "struct pc_dimms_capacity" David Hildenbrand
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 02/13] pc: rename pc_dimm_(plug|unplug|...)* into pc_memory_(plug|unplug|...)* David Hildenbrand
2018-06-18  0:39   ` David Gibson
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 03/13] pc-dimm: rename pc_dimm_memory_* to pc_dimm_* David Hildenbrand
2018-06-18  0:39   ` David Gibson
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 04/13] pc-dimm: remove pc_dimm_get_free_slot() from header David Hildenbrand
2018-06-18  0:41   ` David Gibson
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 05/13] pc: factor out pc specific dimm checks into pc_memory_pre_plug() David Hildenbrand
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 06/13] nvdimm: no need to overwrite get_vmstate_memory_region() David Hildenbrand
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 07/13] hostmem: drop error variable from host_memory_backend_get_memory() David Hildenbrand
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 08/13] pc-dimm: merge get_(vmstate_)memory_region() David Hildenbrand
2018-06-18  0:46   ` David Gibson
2018-06-18 11:47   ` Igor Mammedov
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 09/13] nvdimm: convert "unarmed" into a static property David Hildenbrand
2018-06-18  0:48   ` David Gibson
2018-06-15 14:04 ` David Hildenbrand [this message]
2018-06-18  0:49   ` [Qemu-devel] [PATCH v3 10/13] nvdimm: convert nvdimm_mr into a pointer David Gibson
2018-06-18 10:51     ` David Hildenbrand
2018-06-18 12:42   ` Igor Mammedov
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 11/13] nvdimm: allow setting the label-size to 0 David Hildenbrand
2018-06-16  2:05   ` Haozhong Zhang
2018-06-18 10:49     ` David Hildenbrand
2018-06-18 12:03   ` Igor Mammedov
2018-06-18 12:04     ` David Hildenbrand
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 12/13] nvdimm: make get_memory_region() perform checks and initialization David Hildenbrand
2018-06-18 12:43   ` Igor Mammedov
2018-06-15 14:04 ` [Qemu-devel] [PATCH v3 13/13] pc-dimm: get_memory_region() will not fail after realize David Hildenbrand
2018-06-18  0:52   ` David Gibson
2018-06-18 12:32 ` [Qemu-devel] [PATCH v3 00/13] pc-dimm: next bunch of cleanups David Hildenbrand

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=20180615140448.32234-11-david@redhat.com \
    --to=david@redhat.com \
    --cc=agraf@suse.de \
    --cc=david@gibson.dropbear.id.au \
    --cc=ehabkost@redhat.com \
    --cc=imammedo@redhat.com \
    --cc=marcel.apfelbaum@gmail.com \
    --cc=mst@redhat.com \
    --cc=pbonzini@redhat.com \
    --cc=qemu-devel@nongnu.org \
    --cc=qemu-ppc@nongnu.org \
    --cc=rth@twiddle.net \
    --cc=xiaoguangrong.eric@gmail.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 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.