[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 104/124] vmstate: Test for VMSTATE_POINTER
From: |
Juan Quintela |
Subject: |
[Qemu-devel] [PATCH 104/124] vmstate: Test for VMSTATE_POINTER |
Date: |
Mon, 21 Apr 2014 16:41:24 +0200 |
Signed-off-by: Juan Quintela <address@hidden>
---
tests/test-vmstate.c | 61 ++++++++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 61 insertions(+)
diff --git a/tests/test-vmstate.c b/tests/test-vmstate.c
index 79bdf9d..c284bfc 100644
--- a/tests/test-vmstate.c
+++ b/tests/test-vmstate.c
@@ -1057,6 +1057,66 @@ static void test_vbuffer_simple(void)
SUCCESS(memcmp(obj->buffer2, obj_vbuffer->buffer2, VMSTATE_ARRAY_SIZE));
}
+typedef struct TestPointer {
+ uint8_t *u8_1p;
+} TestPointer;
+
+static const VMStateDescription vmstate_pointer_simple = {
+ .name = "pointer/simple",
+ .version_id = 1,
+ .minimum_version_id = 1,
+ .minimum_version_id_old = 1,
+ .fields = (VMStateField[]) {
+ VMSTATE_POINTER(u8_1p, TestPointer, NULL, vmstate_info_uint8, uint8_t),
+ VMSTATE_END_OF_LIST()
+ }
+};
+
+uint8_t wire_pointer_simple[] = {
+ /* u8_1p */ 0x11,
+ QEMU_VM_EOF, /* just to ensure we won't get EOF reported prematurely */
+};
+
+static void obj_pointer_copy(void *arg1, void *arg2)
+{
+ TestPointer *target = arg1;
+ TestPointer *source = arg2;
+
+ *target->u8_1p = *source->u8_1p;
+}
+
+static TestPointer *create_pointer(void)
+{
+ TestPointer *obj = g_malloc0(sizeof(*obj));
+ obj->u8_1p = g_malloc0(sizeof(*obj->u8_1p));
+
+ return obj;
+}
+
+static void test_pointer_simple(void)
+{
+ TestPointer *obj, *obj_clone, *obj_pointer;
+
+ obj_pointer = create_pointer();
+ obj = create_pointer();
+ obj_clone = create_pointer();
+
+ *obj_pointer->u8_1p = 17;
+ *obj->u8_1p = 22;
+
+ save_vmstate(&vmstate_pointer_simple, obj_pointer);
+
+ compare_vmstate(wire_pointer_simple, sizeof(wire_pointer_simple));
+
+ SUCCESS(load_vmstate(&vmstate_pointer_simple, obj, obj_clone,
+ obj_pointer_copy, 1, wire_pointer_simple,
+ sizeof(wire_pointer_simple)));
+
+#define FIELD_EQUAL(name) g_assert_cmpint(*obj->name, ==, *obj_pointer->name)
+ FIELD_EQUAL(u8_1p);
+}
+#undef FIELD_EQUAL
+
typedef struct TestVersioned {
uint32_t a, b, c, e;
uint64_t d, f;
@@ -1296,6 +1356,7 @@ int main(int argc, char **argv)
g_test_add_func("/vmstate/buffer/simple", test_buffer_simple);
g_test_add_func("/vmstate/buffer/test", test_buffer_test);
g_test_add_func("/vmstate/vbuffer/simple", test_vbuffer_simple);
+ g_test_add_func("/vmstate/pointer/simple", test_pointer_simple);
g_test_run();
close(temp_fd);
--
1.9.0
- [Qemu-devel] [PATCH 094/124] vmstate: Use VMSTATE_UINT8_2DARRAY instead of VMSTATE_BUFFER_TEST, (continued)
- [Qemu-devel] [PATCH 094/124] vmstate: Use VMSTATE_UINT8_2DARRAY instead of VMSTATE_BUFFER_TEST, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 092/124] vmstate: Test for VMSTATE_BUFFER_START_MIDDLE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 095/124] vmstate: Test for VMSTATE_BUFFER_UNSAFE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 096/124] vmstate: Remove unused VMSTATE_SUB_VBUFFER, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 097/124] vmstate: Remove unused VMSTATE_PARTIAL_VBUFFER_UINT32, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 099/124] vmstate: Rename VMSTATE_PARTIAL_VBUFFER to VMSTATE_VBUFFER_INT32, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 098/124] vmstate: Test for VMSTATE_PARTIAL_VBUFFER, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 100/124] vmstate: Create VMS_VBUFFER_UINT32, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 101/124] vmstate: Rename VMS_VBUFFER to VMST_VBUFFER_INT32 for consintency, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 102/124] vmstate: Test for VMSTATE_VBUFFER_UINT32, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 104/124] vmstate: Test for VMSTATE_POINTER,
Juan Quintela <=
- [Qemu-devel] [PATCH 105/124] vmstate: Test for VMSTATE_POINTER_UNSAFE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 103/124] vmstate: VMSTATE_POINTER() used the wrong type to calculate the size, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 106/124] vmstate: Test for VMSTATE_BUFFER_UNSAFE_TEST, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 108/124] vmstate: Test for VMSTATE_ARRAY_INT32_UNSAFE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 109/124] vmstate: Test for VMSTATE_VARRAY, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 107/124] vmstate: Test for VMSTATE_BUFFER_POINTER_UNSAFE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 111/124] vmstate: Test for VMSTATE_VARRAY_UINT16_UNSAFE, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 113/124] vmstate: Test for VMSTATE_STRUCT{_TEST}, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 112/124] vmstate: Test for VMSTATE_VARRAY_INT32{_TEST}, Juan Quintela, 2014/04/21
- [Qemu-devel] [PATCH 117/124] vmstate: Test for VMSTATE_STRUCT_VARRAY_UINT8, Juan Quintela, 2014/04/21