Function qemuMonitorJSONBuildCPUModelInfoToJSON
builds and returns JSON of form
{"model": {"name": "IvyBridge", "props": {}}}
from qemuMonitorCPUModelInfo.
Function qemuMonitorJSONBuildCPUModelInfoToJSON
returns virJsonValuePtr on success and NULL on failure.
---
src/qemu/qemu_monitor_json.c | 48 ++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 48 insertions(+)
diff --git a/src/qemu/qemu_monitor_json.c b/src/qemu/qemu_monitor_json.c
index 4368aaaa0..44c1b2f15 100644
--- a/src/qemu/qemu_monitor_json.c
+++ b/src/qemu/qemu_monitor_json.c
@@ -5337,6 +5337,54 @@ qemuMonitorJSONParseCPUModelProperty(const char *key,
return 0;
}
+/* model_json: {"model": {"name": "IvyBridge", "props": {}}}
+ */
+static virJSONValuePtr
+qemuMonitorJSONBuildCPUModelInfoToJSON(qemuMonitorCPUModelInfoPtr model)
+{
+ virJSONValuePtr cpu_props = NULL;
+ virJSONValuePtr model_json = NULL;
+ size_t i;
+
+ if (!(cpu_props = virJSONValueNewObject()))
+ goto cleanup;
+
+ for (i = 0; i < model->nprops; i++) {
+ qemuMonitorCPUPropertyPtr prop = model->props + i;
+
+ switch (prop->type) {
+ case QEMU_MONITOR_CPU_PROPERTY_BOOLEAN:
+ if (virJSONValueObjectAppendBoolean(cpu_props, prop->name, prop->value.boolean) < 0)
+ goto cleanup;
+ break;
+
+ case QEMU_MONITOR_CPU_PROPERTY_STRING:
+ if (virJSONValueObjectAppendString(cpu_props, prop->name, prop->value.string) < 0)
+ goto cleanup;
+ break;
+
+ case QEMU_MONITOR_CPU_PROPERTY_NUMBER:
+ if (virJSONValueObjectAppendNumberLong(cpu_props, prop->name, prop->value.number) < 0)
+ goto cleanup;
+ break;
+
+ case QEMU_MONITOR_CPU_PROPERTY_LAST:
+ default:
+ virReportEnumRangeError(qemuMonitorCPUPropertyPtr, prop->type);
+ goto cleanup;
+ }
+ }
+
+ if (virJSONValueObjectCreate(&model_json, "s:name", model->name,
+ "a:props", &cpu_props, NULL) < 0) {
+ virJSONValueFree(cpu_props);
+ goto cleanup;
+ }
+
+ cleanup:
+ return model_json;
+}
+
/* model_json: {"model": {"name": "IvyBridge", "props": {}}}
*/
static qemuMonitorCPUModelInfoPtr
--
2.14.1
--
libvir-list mailing list
libvir-list@redhat.com
https://www.redhat.com/mailman/listinfo/libvir-list
$SUBJ: qemu_monitor_json: Introduce qemuMonitorJSONBuildCPUModelInfoToJSON The corollary for qemuMonitorJSONBuildCPUModelInfoFromJSON is to build the JSON data from the qemuMonitorCPUModelInfoPtr. On 04/19/2018 12:06 AM, Chris Venteicher wrote: > Function qemuMonitorJSONBuildCPUModelInfoToJSON > builds and returns JSON of form > {"model": {"name": "IvyBridge", "props": {}}} > from qemuMonitorCPUModelInfo. > > Function qemuMonitorJSONBuildCPUModelInfoToJSON > returns virJsonValuePtr on success and NULL on failure. > --- > src/qemu/qemu_monitor_json.c | 48 ++++++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 48 insertions(+) > > diff --git a/src/qemu/qemu_monitor_json.c b/src/qemu/qemu_monitor_json.c > index 4368aaaa0..44c1b2f15 100644 > --- a/src/qemu/qemu_monitor_json.c > +++ b/src/qemu/qemu_monitor_json.c > @@ -5337,6 +5337,54 @@ qemuMonitorJSONParseCPUModelProperty(const char *key, > return 0; > } > Again 2 blank lines (at end too). > +/* model_json: {"model": {"name": "IvyBridge", "props": {}}} > + */ > +static virJSONValuePtr > +qemuMonitorJSONBuildCPUModelInfoToJSON(qemuMonitorCPUModelInfoPtr model) > +{ > + virJSONValuePtr cpu_props = NULL; > + virJSONValuePtr model_json = NULL; > + size_t i; > + > + if (!(cpu_props = virJSONValueNewObject())) > + goto cleanup; > + > + for (i = 0; i < model->nprops; i++) { > + qemuMonitorCPUPropertyPtr prop = model->props + i; or prop = model->props[i] - something I'm more used to seeing. > + > + switch (prop->type) { > + case QEMU_MONITOR_CPU_PROPERTY_BOOLEAN: > + if (virJSONValueObjectAppendBoolean(cpu_props, prop->name, prop->value.boolean) < 0) Long line - consider creating line break after prop->name Prefer to keep lines < 80 if possible unless it's just a character or two. > + goto cleanup; > + break; > + > + case QEMU_MONITOR_CPU_PROPERTY_STRING: > + if (virJSONValueObjectAppendString(cpu_props, prop->name, prop->value.string) < 0) > + goto cleanup; > + break; > + > + case QEMU_MONITOR_CPU_PROPERTY_NUMBER: > + if (virJSONValueObjectAppendNumberLong(cpu_props, prop->name, prop->value.number) < 0) > + goto cleanup; > + break; > + > + case QEMU_MONITOR_CPU_PROPERTY_LAST: > + default: > + virReportEnumRangeError(qemuMonitorCPUPropertyPtr, prop->type); > + goto cleanup; > + } > + } > + > + if (virJSONValueObjectCreate(&model_json, "s:name", model->name, > + "a:props", &cpu_props, NULL) < 0) { > + virJSONValueFree(cpu_props); > + goto cleanup; > + } I just know the above will cause Coverity to get all upset, but I think if you go with ignore_value(virJSONValueObjectCreate(&model_json, "s:name", model->name, "a:props", &cpu_props, NULL)); cleanup: virJSONValueFree(cpu_props); return model_json; Then things will be fine. In the long run since @model_json is the returned thing and it'd only be non NULL if virJSONValueObjectCreate succeeded and it woudl consume @cpu_props properly, thus we don't care about the return value because it's not changing what we do. But not having that @cpu_props Free makes coverity believe it's leaked even though it's passed by reference. John > + > + cleanup: > + return model_json; > +} > + > /* model_json: {"model": {"name": "IvyBridge", "props": {}}} > */ > static qemuMonitorCPUModelInfoPtr > -- libvir-list mailing list libvir-list@redhat.com https://www.redhat.com/mailman/listinfo/libvir-list
© 2016 - 2025 Red Hat, Inc.