summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJuan Quintela <quintela@redhat.com>2009-08-20 19:42:29 +0200
committerAnthony Liguori <aliguori@us.ibm.com>2009-08-27 20:30:21 -0500
commitec245e2111ec59cd04e2510a183e43dee3fb85ce (patch)
tree7ee9a56dd6f0d3a80b480ecfd07750fd0236d741
parent695dcf71eb463c93c9b3418cffdf3be437dee14a (diff)
downloadhqemu-ec245e2111ec59cd04e2510a183e43dee3fb85ce.zip
hqemu-ec245e2111ec59cd04e2510a183e43dee3fb85ce.tar.gz
Add VMState support for structs
This patch adds support for saving one VMStateDescription from other VMStateDescription. Signed-off-by: Juan Quintela <quintela@redhat.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
-rw-r--r--hw/hw.h12
-rw-r--r--savevm.c15
2 files changed, 25 insertions, 2 deletions
diff --git a/hw/hw.h b/hw/hw.h
index a8534fa..2ee307e 100644
--- a/hw/hw.h
+++ b/hw/hw.h
@@ -283,6 +283,7 @@ enum VMStateFlags {
VMS_SINGLE = 0x001,
VMS_POINTER = 0x002,
VMS_ARRAY = 0x004,
+ VMS_STRUCT = 0x008,
};
typedef struct {
@@ -292,6 +293,7 @@ typedef struct {
int num;
const VMStateInfo *info;
enum VMStateFlags flags;
+ const VMStateDescription *vmsd;
int version_id;
} VMStateField;
@@ -349,6 +351,16 @@ extern const VMStateInfo vmstate_info_timer;
+ type_check_array(_type,typeof_field(_state, _field),_num) \
}
+#define VMSTATE_STRUCT(_field, _state, _version, _vmsd, _type) { \
+ .name = (stringify(_field)), \
+ .version_id = (_version), \
+ .vmsd = &(_vmsd), \
+ .size = sizeof(_type), \
+ .flags = VMS_STRUCT, \
+ .offset = offsetof(_state, _field) \
+ + type_check(_type,typeof_field(_state, _field)) \
+}
+
/* _f : field name
_n : num of elements
_s : struct state name
diff --git a/savevm.c b/savevm.c
index 7bcb783..71ec4ca 100644
--- a/savevm.c
+++ b/savevm.c
@@ -983,7 +983,13 @@ int vmstate_load_state(QEMUFile *f, const VMStateDescription *vmsd,
}
for (i = 0; i < n_elems; i++) {
void *addr = base_addr + field->size * i;
- ret = field->info->get(f, addr, field->size);
+
+ if (field->flags & VMS_STRUCT) {
+ ret = vmstate_load_state(f, field->vmsd, addr, version_id);
+ } else {
+ ret = field->info->get(f, addr, field->size);
+
+ }
if (ret < 0) {
return ret;
}
@@ -1011,7 +1017,12 @@ void vmstate_save_state(QEMUFile *f, const VMStateDescription *vmsd,
}
for (i = 0; i < n_elems; i++) {
const void *addr = base_addr + field->size * i;
- field->info->put(f, addr, field->size);
+
+ if (field->flags & VMS_STRUCT) {
+ vmstate_save_state(f, field->vmsd, addr);
+ } else {
+ field->info->put(f, addr, field->size);
+ }
}
field++;
}
OpenPOWER on IntegriCloud