[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-ppc] [PATCH v3 09/13] nvdimm: convert "unarmed" into a static
From: |
David Gibson |
Subject: |
Re: [Qemu-ppc] [PATCH v3 09/13] nvdimm: convert "unarmed" into a static property |
Date: |
Mon, 18 Jun 2018 10:48:18 +1000 |
User-agent: |
Mutt/1.10.0 (2018-05-17) |
On Fri, Jun 15, 2018 at 04:04:44PM +0200, David Hildenbrand wrote:
> We don't allow to modify it after realization. So we can simply turn
> it into a static property.
>
> Signed-off-by: David Hildenbrand <address@hidden>
Reviewed-by: David Gibson <address@hidden>
> ---
> hw/mem/nvdimm.c | 32 +++++++-------------------------
> 1 file changed, 7 insertions(+), 25 deletions(-)
>
> diff --git a/hw/mem/nvdimm.c b/hw/mem/nvdimm.c
> index df9716231f..7260c9c6b1 100644
> --- a/hw/mem/nvdimm.c
> +++ b/hw/mem/nvdimm.c
> @@ -64,36 +64,11 @@ out:
> error_propagate(errp, local_err);
> }
>
> -static bool nvdimm_get_unarmed(Object *obj, Error **errp)
> -{
> - NVDIMMDevice *nvdimm = NVDIMM(obj);
> -
> - return nvdimm->unarmed;
> -}
> -
> -static void nvdimm_set_unarmed(Object *obj, bool value, Error **errp)
> -{
> - NVDIMMDevice *nvdimm = NVDIMM(obj);
> - Error *local_err = NULL;
> -
> - if (memory_region_size(&nvdimm->nvdimm_mr)) {
> - error_setg(&local_err, "cannot change property value");
> - goto out;
> - }
> -
> - nvdimm->unarmed = value;
> -
> - out:
> - error_propagate(errp, local_err);
> -}
> -
> static void nvdimm_init(Object *obj)
> {
> object_property_add(obj, NVDIMM_LABEL_SIZE_PROP, "int",
> nvdimm_get_label_size, nvdimm_set_label_size, NULL,
> NULL, NULL);
> - object_property_add_bool(obj, NVDIMM_UNARMED_PROP,
> - nvdimm_get_unarmed, nvdimm_set_unarmed, NULL);
> }
>
> static MemoryRegion *nvdimm_get_memory_region(PCDIMMDevice *dimm, Error
> **errp)
> @@ -166,13 +141,20 @@ static void nvdimm_write_label_data(NVDIMMDevice
> *nvdimm, const void *buf,
> memory_region_set_dirty(mr, backend_offset, size);
> }
>
> +static Property nvdimm_properties[] = {
> + DEFINE_PROP_BOOL(NVDIMM_UNARMED_PROP, NVDIMMDevice, unarmed, false),
> + DEFINE_PROP_END_OF_LIST(),
> +};
> +
> static void nvdimm_class_init(ObjectClass *oc, void *data)
> {
> PCDIMMDeviceClass *ddc = PC_DIMM_CLASS(oc);
> NVDIMMClass *nvc = NVDIMM_CLASS(oc);
> + DeviceClass *dc = DEVICE_CLASS(oc);
>
> ddc->realize = nvdimm_realize;
> ddc->get_memory_region = nvdimm_get_memory_region;
> + dc->props = nvdimm_properties;
>
> nvc->read_label_data = nvdimm_read_label_data;
> nvc->write_label_data = nvdimm_write_label_data;
--
David Gibson | I'll have my music baroque, and my code
david AT gibson.dropbear.id.au | minimalist, thank you. NOT _the_ _other_
| _way_ _around_!
http://www.ozlabs.org/~dgibson
signature.asc
Description: PGP signature
- Re: [Qemu-ppc] [PATCH v3 10/13] nvdimm: convert nvdimm_mr into a pointer, (continued)
- [Qemu-ppc] [PATCH v3 11/13] nvdimm: allow setting the label-size to 0, David Hildenbrand, 2018/06/15
- [Qemu-ppc] [PATCH v3 12/13] nvdimm: make get_memory_region() perform checks and initialization, David Hildenbrand, 2018/06/15
- [Qemu-ppc] [PATCH v3 09/13] nvdimm: convert "unarmed" into a static property, David Hildenbrand, 2018/06/15
- Re: [Qemu-ppc] [PATCH v3 09/13] nvdimm: convert "unarmed" into a static property,
David Gibson <=
- [Qemu-ppc] [PATCH v3 13/13] pc-dimm: get_memory_region() will not fail after realize, David Hildenbrand, 2018/06/15
- Re: [Qemu-ppc] [PATCH v3 00/13] pc-dimm: next bunch of cleanups, David Hildenbrand, 2018/06/18