From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([2001:4830:134:3::10]:51984) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1WX0AA-0008Bl-OY for qemu-devel@nongnu.org; Sun, 06 Apr 2014 23:24:04 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1WX0A4-0000Dz-Hs for qemu-devel@nongnu.org; Sun, 06 Apr 2014 23:23:58 -0400 Received: from mx1.redhat.com ([209.132.183.28]:18389) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1WX0A4-0000Dv-Ae for qemu-devel@nongnu.org; Sun, 06 Apr 2014 23:23:52 -0400 Received: from int-mx02.intmail.prod.int.phx2.redhat.com (int-mx02.intmail.prod.int.phx2.redhat.com [10.5.11.12]) by mx1.redhat.com (8.14.4/8.14.4) with ESMTP id s373NpQ2025940 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-SHA bits=256 verify=OK) for ; Sun, 6 Apr 2014 23:23:51 -0400 From: Juan Quintela Date: Mon, 7 Apr 2014 05:21:40 +0200 Message-Id: <1396840915-10384-83-git-send-email-quintela@redhat.com> In-Reply-To: <1396840915-10384-1-git-send-email-quintela@redhat.com> References: <1396840915-10384-1-git-send-email-quintela@redhat.com> Subject: [Qemu-devel] [PATCH 82/97] vmstate: Test for VMSTATE_SYNTHETIC List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Signed-off-by: Juan Quintela --- tests/test-vmstate.c | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/tests/test-vmstate.c b/tests/test-vmstate.c index f51c887..b3d77a2 100644 --- a/tests/test-vmstate.c +++ b/tests/test-vmstate.c @@ -95,6 +95,29 @@ TestSimple obj_simple = { .f64 = float64_pi, }; +static int get_42_as_uint32(QEMUFile *f, void *pv, size_t size) +{ + uint64_t v; + v = qemu_get_be32(f); + if (v != 42) { + printf("We haven't received 42!!!!'"); + return -1; + } + return 0; +} + +static void put_42_as_uint32(QEMUFile *f, void *pv, size_t size) +{ + uint64_t v = 42; + qemu_put_be32(f, v); +} + +static const VMStateInfo vmstate_42_as_uint32 = { + .name = "42_as_uint32", + .get = get_42_as_uint32, + .put = put_42_as_uint32, +}; + /* Description of the values. If you add a primitive type you are expected to add a test here */ @@ -119,6 +142,7 @@ static const VMStateDescription vmstate_simple_primitive = { VMSTATE_INT64(i64_2, TestSimple), VMSTATE_FLOAT64(f64, TestSimple), VMSTATE_UNUSED(5), + VMSTATE_SYNTHETIC("synthetic", vmstate_42_as_uint32, sizeof(uint32)), VMSTATE_END_OF_LIST() } }; @@ -152,6 +176,7 @@ uint8_t wire_simple_primitive[] = { /* i64_2 */ 0xff, 0xff, 0xff, 0xff, 0xff, 0x47, 0x0b, 0x84, /* f64 */ 0x40, 0x09, 0x21, 0xfb, 0x54, 0x44, 0x2d, 0x18, /* unused */0x00, 0x00, 0x00, 0x00, 0x00, + /* synthe */0x00, 0x00, 0x00, 0x2a, QEMU_VM_EOF, /* just to ensure we won't get EOF reported prematurely */ }; -- 1.9.0