[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PULL 1/5] pl330: fix vmstate description
From: |
Peter Maydell |
Subject: |
[Qemu-devel] [PULL 1/5] pl330: fix vmstate description |
Date: |
Fri, 26 Jul 2019 16:19:48 +0100 |
From: Damien Hedde <address@hidden>
Fix the pl330 main and queue vmstate description.
There were missing POINTER flags causing crashes during
incoming migration because:
+ PL330State chan field is a pointer to an array
+ PL330Queue queue field is a pointer to an array
Also bump corresponding vmsd version numbers.
Signed-off-by: Damien Hedde <address@hidden>
Reviewed-by: Philippe Mathieu-Daude <address@hidden>
Acked-by: Dr. David Alan Gilbert <address@hidden>
Message-id: address@hidden
Signed-off-by: Peter Maydell <address@hidden>
---
hw/dma/pl330.c | 17 +++++++++--------
1 file changed, 9 insertions(+), 8 deletions(-)
diff --git a/hw/dma/pl330.c b/hw/dma/pl330.c
index 58df965a468..a56a3e77713 100644
--- a/hw/dma/pl330.c
+++ b/hw/dma/pl330.c
@@ -218,11 +218,12 @@ typedef struct PL330Queue {
static const VMStateDescription vmstate_pl330_queue = {
.name = "pl330_queue",
- .version_id = 1,
- .minimum_version_id = 1,
+ .version_id = 2,
+ .minimum_version_id = 2,
.fields = (VMStateField[]) {
- VMSTATE_STRUCT_VARRAY_UINT32(queue, PL330Queue, queue_size, 1,
- vmstate_pl330_queue_entry, PL330QueueEntry),
+ VMSTATE_STRUCT_VARRAY_POINTER_UINT32(queue, PL330Queue, queue_size,
+ vmstate_pl330_queue_entry,
+ PL330QueueEntry),
VMSTATE_END_OF_LIST()
}
};
@@ -278,12 +279,12 @@ struct PL330State {
static const VMStateDescription vmstate_pl330 = {
.name = "pl330",
- .version_id = 1,
- .minimum_version_id = 1,
+ .version_id = 2,
+ .minimum_version_id = 2,
.fields = (VMStateField[]) {
VMSTATE_STRUCT(manager, PL330State, 0, vmstate_pl330_chan, PL330Chan),
- VMSTATE_STRUCT_VARRAY_UINT32(chan, PL330State, num_chnls, 0,
- vmstate_pl330_chan, PL330Chan),
+ VMSTATE_STRUCT_VARRAY_POINTER_UINT32(chan, PL330State, num_chnls,
+ vmstate_pl330_chan, PL330Chan),
VMSTATE_VBUFFER_UINT32(lo_seqn, PL330State, 1, NULL, num_chnls),
VMSTATE_VBUFFER_UINT32(hi_seqn, PL330State, 1, NULL, num_chnls),
VMSTATE_STRUCT(fifo, PL330State, 0, vmstate_pl330_fifo, PL330Fifo),
--
2.20.1
- [Qemu-devel] [PULL 0/5] target-arm queue, Peter Maydell, 2019/07/22
- [Qemu-devel] [PULL 1/5] target/arm: Add missing break statement for Hypervisor Trap Exception, Peter Maydell, 2019/07/22
- [Qemu-devel] [PULL 2/5] hw/arm/fsl-imx6ul.c: Remove dead SMP-related code, Peter Maydell, 2019/07/22
- [Qemu-devel] [PULL 3/5] target/arm: Limit ID register assertions to TCG, Peter Maydell, 2019/07/22
- [Qemu-devel] [PULL 5/5] contrib/elf2dmp: Build download.o with CURL_CFLAGS, Peter Maydell, 2019/07/22
- [Qemu-devel] [PULL 4/5] configure: Clarify URL to source downloads, Peter Maydell, 2019/07/22
- Re: [Qemu-devel] [PULL 0/5] target-arm queue, Peter Maydell, 2019/07/22
- [Qemu-devel] [PULL 0/5] target-arm queue, Peter Maydell, 2019/07/26
- [Qemu-devel] [PULL 1/5] pl330: fix vmstate description,
Peter Maydell <=
- [Qemu-devel] [PULL 2/5] stellaris_input: Fix vmstate description of buttons field, Peter Maydell, 2019/07/26
- [Qemu-devel] [PULL 3/5] vmstate.h: Type check VMSTATE_STRUCT_VARRAY macros, Peter Maydell, 2019/07/26
- [Qemu-devel] [PULL 4/5] hw/arm/boot: Rename elf_{low, high}_addr to image_{low, high}_addr, Peter Maydell, 2019/07/26
- [Qemu-devel] [PULL 5/5] hw/arm/boot: Further improve initrd positioning code, Peter Maydell, 2019/07/26
- Re: [Qemu-devel] [PULL 0/5] target-arm queue, Peter Maydell, 2019/07/26