[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH v3 30/32] nvdimm: support DSM_CMD_SET_NAMESPACE_LABE
From: |
Xiao Guangrong |
Subject: |
[Qemu-devel] [PATCH v3 30/32] nvdimm: support DSM_CMD_SET_NAMESPACE_LABEL_DATA |
Date: |
Sun, 11 Oct 2015 11:53:02 +0800 |
Function 6 is used to set Namespace Label Data
Signed-off-by: Xiao Guangrong <address@hidden>
---
hw/mem/nvdimm/acpi.c | 36 ++++++++++++++++++++++++++++++++++++
1 file changed, 36 insertions(+)
diff --git a/hw/mem/nvdimm/acpi.c b/hw/mem/nvdimm/acpi.c
index e0a37cb..6f05b37 100644
--- a/hw/mem/nvdimm/acpi.c
+++ b/hw/mem/nvdimm/acpi.c
@@ -424,6 +424,11 @@ struct cmd_out_get_label_data {
} QEMU_PACKED;
typedef struct cmd_out_get_label_data cmd_out_get_label_data;
+struct cmd_out_set_label_data {
+ uint32_t status;
+};
+typedef struct cmd_out_set_label_data cmd_out_set_label_data;
+
struct dsm_out {
/* the size of buffer filled by QEMU. */
uint16_t len;
@@ -433,6 +438,7 @@ struct dsm_out {
cmd_out_implemented cmd_implemented;
cmd_out_label_size cmd_label_size;
cmd_out_get_label_data cmd_get_label_data;
+ cmd_out_set_label_data cmd_set_label_data;
};
} QEMU_PACKED;
typedef struct dsm_out dsm_out;
@@ -534,6 +540,33 @@ exit:
return status;
}
+static uint32_t
+dsm_cmd_set_label_data(NVDIMMDevice *nvdimm, dsm_in *in, dsm_out *out)
+{
+ cmd_in_set_label_data *cmd_in = &in->cmd_set_label_data;
+ uint32_t length, offset, status;
+
+ length = cmd_in->length;
+ offset = cmd_in->offset;
+ le32_to_cpus(&length);
+ le32_to_cpus(&offset);
+
+ nvdebug("Write Label Data: offset %#x length %#x.\n", offset, length);
+ if (nvdimm->label_size < length + offset) {
+ nvdebug("position %#x is beyond config data (len = %#lx).\n",
+ length + offset, nvdimm->label_size);
+ out->len = sizeof(out->status);
+ status = DSM_STATUS_INVALID_PARAS;
+ goto exit;
+ }
+
+ status = DSM_STATUS_SUCCESS;
+ memcpy(nvdimm->label_data + offset, cmd_in->in_buf, length);
+ out->len = sizeof(status);
+exit:
+ return status;
+}
+
static void dsm_write_nvdimm(MemoryRegion *dsm_ram_mr, uint32_t handle,
uint32_t function, dsm_in *in, dsm_out *out)
{
@@ -559,6 +592,9 @@ static void dsm_write_nvdimm(MemoryRegion *dsm_ram_mr,
uint32_t handle,
case DSM_CMD_GET_NAMESPACE_LABEL_DATA:
status = dsm_cmd_get_label_data(nvdimm, in, out);
break;
+ case DSM_CMD_SET_NAMESPACE_LABEL_DATA:
+ status = dsm_cmd_set_label_data(nvdimm, in, out);
+ break;
default:
out->len = sizeof(out->status);
status = DSM_STATUS_NOT_SUPPORTED;
--
1.8.3.1
- Re: [Qemu-devel] [PATCH v3 27/32] nvdimm: support DSM_CMD_IMPLEMENTED function, (continued)
Re: [Qemu-devel] [PATCH v3 27/32] nvdimm: support DSM_CMD_IMPLEMENTED function, Stefan Hajnoczi, 2015/10/14
Re: [Qemu-devel] [PATCH v3 27/32] nvdimm: support DSM_CMD_IMPLEMENTED function, Stefan Hajnoczi, 2015/10/15
Re: [Qemu-devel] [PATCH v3 27/32] nvdimm: support DSM_CMD_IMPLEMENTED function, Xiao Guangrong, 2015/10/15
[Qemu-devel] [PATCH v3 30/32] nvdimm: support DSM_CMD_SET_NAMESPACE_LABEL_DATA,
Xiao Guangrong <=
[Qemu-devel] [PATCH v3 31/32] nvdimm: allow using whole backend memory as pmem, Xiao Guangrong, 2015/10/10
[Qemu-devel] [PATCH v3 01/32] acpi: add aml_derefof, Xiao Guangrong, 2015/10/10
[Qemu-devel] [PATCH v3 02/32] acpi: add aml_sizeof, Xiao Guangrong, 2015/10/10
[Qemu-devel] [PATCH v3 17/32] dimm: abstract dimm device from pc-dimm, Xiao Guangrong, 2015/10/10
[Qemu-devel] [PATCH v3 18/32] dimm: get mapped memory region from DIMMDeviceClass->get_memory_region, Xiao Guangrong, 2015/10/10
[Qemu-devel] [PATCH v3 13/32] pc-dimm: make pc_existing_dimms_capacity static and rename it, Xiao Guangrong, 2015/10/10
[Qemu-devel] [PATCH v3 15/32] stubs: rename qmp_pc_dimm_device_list.c, Xiao Guangrong, 2015/10/10
[Qemu-devel] [PATCH v3 21/32] nvdimm: implement NVDIMM device abstract, Xiao Guangrong, 2015/10/10