migration: Use normal VMStateDescriptions for Subsections

We create optional sections with this patch.  But we already have
optional subsections.  Instead of having two mechanism that do the
same, we can just generalize it.

For subsections we just change:

- Add a needed function to VMStateDescription
- Remove VMStateSubsection (after removal of the needed function
  it is just a VMStateDescription)
- Adjust the whole tree, moving the needed function to the corresponding
  VMStateDescription

Signed-off-by: Juan Quintela <quintela@redhat.com>
This commit is contained in:
Juan Quintela 2014-09-23 14:09:54 +02:00
parent 0163a2e025
commit 5cd8cadae8
32 changed files with 266 additions and 402 deletions

11
cpus.c
View File

@ -480,6 +480,7 @@ static const VMStateDescription icount_vmstate_timers = {
.name = "timer/icount", .name = "timer/icount",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = icount_state_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT64(qemu_icount_bias, TimersState), VMSTATE_INT64(qemu_icount_bias, TimersState),
VMSTATE_INT64(qemu_icount, TimersState), VMSTATE_INT64(qemu_icount, TimersState),
@ -497,13 +498,9 @@ static const VMStateDescription vmstate_timers = {
VMSTATE_INT64_V(cpu_clock_offset, TimersState, 2), VMSTATE_INT64_V(cpu_clock_offset, TimersState, 2),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &icount_vmstate_timers,
.vmsd = &icount_vmstate_timers, NULL
.needed = icount_state_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -257,6 +257,7 @@ const VMStateDescription vmstate_ide_drive_pio_state = {
.minimum_version_id = 1, .minimum_version_id = 1,
.pre_save = ide_drive_pio_pre_save, .pre_save = ide_drive_pio_pre_save,
.post_load = ide_drive_pio_post_load, .post_load = ide_drive_pio_post_load,
.needed = ide_drive_pio_state_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(req_nb_sectors, IDEState), VMSTATE_INT32(req_nb_sectors, IDEState),
VMSTATE_VARRAY_INT32(io_buffer, IDEState, io_buffer_total_len, 1, VMSTATE_VARRAY_INT32(io_buffer, IDEState, io_buffer_total_len, 1,
@ -279,13 +280,9 @@ const VMStateDescription vmstate_ide_drive = {
.... several fields .... .... several fields ....
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_ide_drive_pio_state,
.vmsd = &vmstate_ide_drive_pio_state, NULL
.needed = ide_drive_pio_state_needed,
}, {
/* empty */
}
} }
}; };

11
exec.c
View File

@ -454,6 +454,7 @@ static const VMStateDescription vmstate_cpu_common_exception_index = {
.name = "cpu_common/exception_index", .name = "cpu_common/exception_index",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = cpu_common_exception_index_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(exception_index, CPUState), VMSTATE_INT32(exception_index, CPUState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -471,13 +472,9 @@ const VMStateDescription vmstate_cpu_common = {
VMSTATE_UINT32(interrupt_request, CPUState), VMSTATE_UINT32(interrupt_request, CPUState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_cpu_common_exception_index,
.vmsd = &vmstate_cpu_common_exception_index, NULL
.needed = cpu_common_exception_index_needed,
} , {
/* empty */
}
} }
}; };

View File

@ -152,6 +152,7 @@ static const VMStateDescription vmstate_memhp_state = {
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.minimum_version_id_old = 1, .minimum_version_id_old = 1,
.needed = vmstate_test_use_memhp,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_MEMORY_HOTPLUG(acpi_memory_hotplug, ICH9LPCPMRegs), VMSTATE_MEMORY_HOTPLUG(acpi_memory_hotplug, ICH9LPCPMRegs),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -175,12 +176,9 @@ const VMStateDescription vmstate_ich9_pm = {
VMSTATE_UINT32(smi_sts, ICH9LPCPMRegs), VMSTATE_UINT32(smi_sts, ICH9LPCPMRegs),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_memhp_state,
.vmsd = &vmstate_memhp_state, NULL
.needed = vmstate_test_use_memhp,
},
VMSTATE_END_OF_LIST()
} }
}; };

View File

@ -260,6 +260,7 @@ static const VMStateDescription vmstate_memhp_state = {
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.minimum_version_id_old = 1, .minimum_version_id_old = 1,
.needed = vmstate_test_use_memhp,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_MEMORY_HOTPLUG(acpi_memory_hotplug, PIIX4PMState), VMSTATE_MEMORY_HOTPLUG(acpi_memory_hotplug, PIIX4PMState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -298,12 +299,9 @@ static const VMStateDescription vmstate_acpi = {
vmstate_test_use_acpi_pci_hotplug), vmstate_test_use_acpi_pci_hotplug),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_memhp_state,
.vmsd = &vmstate_memhp_state, NULL
.needed = vmstate_test_use_memhp,
},
VMSTATE_END_OF_LIST()
} }
}; };

View File

@ -699,6 +699,7 @@ static const VMStateDescription vmstate_fdrive_media_changed = {
.name = "fdrive/media_changed", .name = "fdrive/media_changed",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fdrive_media_changed_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(media_changed, FDrive), VMSTATE_UINT8(media_changed, FDrive),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -716,6 +717,7 @@ static const VMStateDescription vmstate_fdrive_media_rate = {
.name = "fdrive/media_rate", .name = "fdrive/media_rate",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fdrive_media_rate_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(media_rate, FDrive), VMSTATE_UINT8(media_rate, FDrive),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -733,6 +735,7 @@ static const VMStateDescription vmstate_fdrive_perpendicular = {
.name = "fdrive/perpendicular", .name = "fdrive/perpendicular",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fdrive_perpendicular_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(perpendicular, FDrive), VMSTATE_UINT8(perpendicular, FDrive),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -756,19 +759,11 @@ static const VMStateDescription vmstate_fdrive = {
VMSTATE_UINT8(sect, FDrive), VMSTATE_UINT8(sect, FDrive),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_fdrive_media_changed,
.vmsd = &vmstate_fdrive_media_changed, &vmstate_fdrive_media_rate,
.needed = &fdrive_media_changed_needed, &vmstate_fdrive_perpendicular,
} , { NULL
.vmsd = &vmstate_fdrive_media_rate,
.needed = &fdrive_media_rate_needed,
} , {
.vmsd = &vmstate_fdrive_perpendicular,
.needed = &fdrive_perpendicular_needed,
} , {
/* empty */
}
} }
}; };
@ -833,6 +828,7 @@ static const VMStateDescription vmstate_fdc_reset_sensei = {
.name = "fdc/reset_sensei", .name = "fdc/reset_sensei",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fdc_reset_sensei_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(reset_sensei, FDCtrl), VMSTATE_INT32(reset_sensei, FDCtrl),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -850,6 +846,7 @@ static const VMStateDescription vmstate_fdc_result_timer = {
.name = "fdc/result_timer", .name = "fdc/result_timer",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fdc_result_timer_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_TIMER_PTR(result_timer, FDCtrl), VMSTATE_TIMER_PTR(result_timer, FDCtrl),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -867,6 +864,7 @@ static const VMStateDescription vmstate_fdc_phase = {
.name = "fdc/phase", .name = "fdc/phase",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fdc_phase_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(phase, FDCtrl), VMSTATE_UINT8(phase, FDCtrl),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -911,19 +909,11 @@ static const VMStateDescription vmstate_fdc = {
vmstate_fdrive, FDrive), vmstate_fdrive, FDrive),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_fdc_reset_sensei,
.vmsd = &vmstate_fdc_reset_sensei, &vmstate_fdc_result_timer,
.needed = fdc_reset_sensei_needed, &vmstate_fdc_phase,
} , { NULL
.vmsd = &vmstate_fdc_result_timer,
.needed = fdc_result_timer_needed,
} , {
.vmsd = &vmstate_fdc_phase,
.needed = fdc_phase_needed,
} , {
/* empty */
}
} }
}; };

View File

@ -662,6 +662,7 @@ static const VMStateDescription vmstate_serial_thr_ipending = {
.name = "serial/thr_ipending", .name = "serial/thr_ipending",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = serial_thr_ipending_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(thr_ipending, SerialState), VMSTATE_INT32(thr_ipending, SerialState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -678,6 +679,7 @@ static const VMStateDescription vmstate_serial_tsr = {
.name = "serial/tsr", .name = "serial/tsr",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = serial_tsr_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(tsr_retry, SerialState), VMSTATE_INT32(tsr_retry, SerialState),
VMSTATE_UINT8(thr, SerialState), VMSTATE_UINT8(thr, SerialState),
@ -697,6 +699,7 @@ static const VMStateDescription vmstate_serial_recv_fifo = {
.name = "serial/recv_fifo", .name = "serial/recv_fifo",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = serial_recv_fifo_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_STRUCT(recv_fifo, SerialState, 1, vmstate_fifo8, Fifo8), VMSTATE_STRUCT(recv_fifo, SerialState, 1, vmstate_fifo8, Fifo8),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -713,6 +716,7 @@ static const VMStateDescription vmstate_serial_xmit_fifo = {
.name = "serial/xmit_fifo", .name = "serial/xmit_fifo",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = serial_xmit_fifo_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_STRUCT(xmit_fifo, SerialState, 1, vmstate_fifo8, Fifo8), VMSTATE_STRUCT(xmit_fifo, SerialState, 1, vmstate_fifo8, Fifo8),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -729,6 +733,7 @@ static const VMStateDescription vmstate_serial_fifo_timeout_timer = {
.name = "serial/fifo_timeout_timer", .name = "serial/fifo_timeout_timer",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = serial_fifo_timeout_timer_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_TIMER_PTR(fifo_timeout_timer, SerialState), VMSTATE_TIMER_PTR(fifo_timeout_timer, SerialState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -745,6 +750,7 @@ static const VMStateDescription vmstate_serial_timeout_ipending = {
.name = "serial/timeout_ipending", .name = "serial/timeout_ipending",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = serial_timeout_ipending_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(timeout_ipending, SerialState), VMSTATE_INT32(timeout_ipending, SerialState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -760,6 +766,7 @@ static bool serial_poll_needed(void *opaque)
static const VMStateDescription vmstate_serial_poll = { static const VMStateDescription vmstate_serial_poll = {
.name = "serial/poll", .name = "serial/poll",
.version_id = 1, .version_id = 1,
.needed = serial_poll_needed,
.minimum_version_id = 1, .minimum_version_id = 1,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(poll_msl, SerialState), VMSTATE_INT32(poll_msl, SerialState),
@ -788,31 +795,15 @@ const VMStateDescription vmstate_serial = {
VMSTATE_UINT8_V(fcr_vmstate, SerialState, 3), VMSTATE_UINT8_V(fcr_vmstate, SerialState, 3),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_serial_thr_ipending,
.vmsd = &vmstate_serial_thr_ipending, &vmstate_serial_tsr,
.needed = &serial_thr_ipending_needed, &vmstate_serial_recv_fifo,
} , { &vmstate_serial_xmit_fifo,
.vmsd = &vmstate_serial_tsr, &vmstate_serial_fifo_timeout_timer,
.needed = &serial_tsr_needed, &vmstate_serial_timeout_ipending,
} , { &vmstate_serial_poll,
.vmsd = &vmstate_serial_recv_fifo, NULL
.needed = &serial_recv_fifo_needed,
} , {
.vmsd = &vmstate_serial_xmit_fifo,
.needed = &serial_xmit_fifo_needed,
} , {
.vmsd = &vmstate_serial_fifo_timeout_timer,
.needed = &serial_fifo_timeout_timer_needed,
} , {
.vmsd = &vmstate_serial_timeout_ipending,
.needed = &serial_timeout_ipending_needed,
} , {
.vmsd = &vmstate_serial_poll,
.needed = &serial_poll_needed,
} , {
/* empty */
}
} }
}; };

View File

@ -2220,6 +2220,7 @@ static VMStateDescription qxl_vmstate_monitors_config = {
.name = "qxl/monitors-config", .name = "qxl/monitors-config",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = qxl_monitors_config_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(guest_monitors_config, PCIQXLDevice), VMSTATE_UINT64(guest_monitors_config, PCIQXLDevice),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -2253,13 +2254,9 @@ static VMStateDescription qxl_vmstate = {
VMSTATE_UINT64(guest_cursor, PCIQXLDevice), VMSTATE_UINT64(guest_cursor, PCIQXLDevice),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &qxl_vmstate_monitors_config,
.vmsd = &qxl_vmstate_monitors_config, NULL
.needed = qxl_monitors_config_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -2035,6 +2035,7 @@ static const VMStateDescription vmstate_vga_endian = {
.name = "vga.endian", .name = "vga.endian",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = vga_endian_state_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_BOOL(big_endian_fb, VGACommonState), VMSTATE_BOOL(big_endian_fb, VGACommonState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -2078,13 +2079,9 @@ const VMStateDescription vmstate_vga_common = {
VMSTATE_UINT32(vbe_bank_mask, VGACommonState), VMSTATE_UINT32(vbe_bank_mask, VGACommonState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_vga_endian,
.vmsd = &vmstate_vga_endian, NULL
.needed = vga_endian_state_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -2561,6 +2561,7 @@ static const VMStateDescription vmstate_ide_atapi_gesn_state = {
.name ="ide_drive/atapi/gesn_state", .name ="ide_drive/atapi/gesn_state",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = ide_atapi_gesn_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_BOOL(events.new_media, IDEState), VMSTATE_BOOL(events.new_media, IDEState),
VMSTATE_BOOL(events.eject_request, IDEState), VMSTATE_BOOL(events.eject_request, IDEState),
@ -2572,6 +2573,7 @@ static const VMStateDescription vmstate_ide_tray_state = {
.name = "ide_drive/tray_state", .name = "ide_drive/tray_state",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = ide_tray_state_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_BOOL(tray_open, IDEState), VMSTATE_BOOL(tray_open, IDEState),
VMSTATE_BOOL(tray_locked, IDEState), VMSTATE_BOOL(tray_locked, IDEState),
@ -2585,6 +2587,7 @@ static const VMStateDescription vmstate_ide_drive_pio_state = {
.minimum_version_id = 1, .minimum_version_id = 1,
.pre_save = ide_drive_pio_pre_save, .pre_save = ide_drive_pio_pre_save,
.post_load = ide_drive_pio_post_load, .post_load = ide_drive_pio_post_load,
.needed = ide_drive_pio_state_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(req_nb_sectors, IDEState), VMSTATE_INT32(req_nb_sectors, IDEState),
VMSTATE_VARRAY_INT32(io_buffer, IDEState, io_buffer_total_len, 1, VMSTATE_VARRAY_INT32(io_buffer, IDEState, io_buffer_total_len, 1,
@ -2626,19 +2629,11 @@ const VMStateDescription vmstate_ide_drive = {
VMSTATE_UINT8_V(cdrom_changed, IDEState, 3), VMSTATE_UINT8_V(cdrom_changed, IDEState, 3),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_ide_drive_pio_state,
.vmsd = &vmstate_ide_drive_pio_state, &vmstate_ide_tray_state,
.needed = ide_drive_pio_state_needed, &vmstate_ide_atapi_gesn_state,
}, { NULL
.vmsd = &vmstate_ide_tray_state,
.needed = ide_tray_state_needed,
}, {
.vmsd = &vmstate_ide_atapi_gesn_state,
.needed = ide_atapi_gesn_needed,
}, {
/* empty */
}
} }
}; };
@ -2646,6 +2641,7 @@ static const VMStateDescription vmstate_ide_error_status = {
.name ="ide_bus/error", .name ="ide_bus/error",
.version_id = 2, .version_id = 2,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = ide_error_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(error_status, IDEBus), VMSTATE_INT32(error_status, IDEBus),
VMSTATE_INT64_V(retry_sector_num, IDEBus, 2), VMSTATE_INT64_V(retry_sector_num, IDEBus, 2),
@ -2664,13 +2660,9 @@ const VMStateDescription vmstate_ide_bus = {
VMSTATE_UINT8(unit, IDEBus), VMSTATE_UINT8(unit, IDEBus),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_ide_error_status,
.vmsd = &vmstate_ide_error_status, NULL
.needed = ide_error_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -350,6 +350,7 @@ static const VMStateDescription vmstate_bmdma_current = {
.name = "ide bmdma_current", .name = "ide bmdma_current",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = ide_bmdma_current_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT32(cur_addr, BMDMAState), VMSTATE_UINT32(cur_addr, BMDMAState),
VMSTATE_UINT32(cur_prd_last, BMDMAState), VMSTATE_UINT32(cur_prd_last, BMDMAState),
@ -363,6 +364,7 @@ static const VMStateDescription vmstate_bmdma_status = {
.name ="ide bmdma/status", .name ="ide bmdma/status",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = ide_bmdma_status_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(status, BMDMAState), VMSTATE_UINT8(status, BMDMAState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -383,16 +385,10 @@ static const VMStateDescription vmstate_bmdma = {
VMSTATE_UINT8(migration_retry_unit, BMDMAState), VMSTATE_UINT8(migration_retry_unit, BMDMAState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_bmdma_current,
.vmsd = &vmstate_bmdma_current, &vmstate_bmdma_status,
.needed = ide_bmdma_current_needed, NULL
}, {
.vmsd = &vmstate_bmdma_status,
.needed = ide_bmdma_status_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -391,23 +391,24 @@ static int kbd_outport_post_load(void *opaque, int version_id)
return 0; return 0;
} }
static const VMStateDescription vmstate_kbd_outport = {
.name = "pckbd_outport",
.version_id = 1,
.minimum_version_id = 1,
.post_load = kbd_outport_post_load,
.fields = (VMStateField[]) {
VMSTATE_UINT8(outport, KBDState),
VMSTATE_END_OF_LIST()
}
};
static bool kbd_outport_needed(void *opaque) static bool kbd_outport_needed(void *opaque)
{ {
KBDState *s = opaque; KBDState *s = opaque;
return s->outport != kbd_outport_default(s); return s->outport != kbd_outport_default(s);
} }
static const VMStateDescription vmstate_kbd_outport = {
.name = "pckbd_outport",
.version_id = 1,
.minimum_version_id = 1,
.post_load = kbd_outport_post_load,
.needed = kbd_outport_needed,
.fields = (VMStateField[]) {
VMSTATE_UINT8(outport, KBDState),
VMSTATE_END_OF_LIST()
}
};
static int kbd_post_load(void *opaque, int version_id) static int kbd_post_load(void *opaque, int version_id)
{ {
KBDState *s = opaque; KBDState *s = opaque;
@ -430,12 +431,9 @@ static const VMStateDescription vmstate_kbd = {
VMSTATE_UINT8(pending, KBDState), VMSTATE_UINT8(pending, KBDState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_kbd_outport,
.vmsd = &vmstate_kbd_outport, NULL
.needed = kbd_outport_needed,
},
VMSTATE_END_OF_LIST()
} }
}; };

View File

@ -677,6 +677,7 @@ static const VMStateDescription vmstate_ps2_keyboard_ledstate = {
.version_id = 3, .version_id = 3,
.minimum_version_id = 2, .minimum_version_id = 2,
.post_load = ps2_kbd_ledstate_post_load, .post_load = ps2_kbd_ledstate_post_load,
.needed = ps2_keyboard_ledstate_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(ledstate, PS2KbdState), VMSTATE_INT32(ledstate, PS2KbdState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -717,13 +718,9 @@ static const VMStateDescription vmstate_ps2_keyboard = {
VMSTATE_INT32_V(scancode_set, PS2KbdState,3), VMSTATE_INT32_V(scancode_set, PS2KbdState,3),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_ps2_keyboard_ledstate,
.vmsd = &vmstate_ps2_keyboard_ledstate, NULL
.needed = ps2_keyboard_ledstate_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -369,6 +369,7 @@ static const VMStateDescription vmstate_apic_common_sipi = {
.name = "apic_sipi", .name = "apic_sipi",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = apic_common_sipi_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32(sipi_vector, APICCommonState), VMSTATE_INT32(sipi_vector, APICCommonState),
VMSTATE_INT32(wait_for_sipi, APICCommonState), VMSTATE_INT32(wait_for_sipi, APICCommonState),
@ -408,12 +409,9 @@ static const VMStateDescription vmstate_apic_common = {
APICCommonState), /* open-coded timer state */ APICCommonState), /* open-coded timer state */
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_apic_common_sipi,
.vmsd = &vmstate_apic_common_sipi, NULL
.needed = apic_common_sipi_needed,
},
VMSTATE_END_OF_LIST()
} }
}; };

View File

@ -650,6 +650,7 @@ static const VMStateDescription vmstate_ich9_rst_cnt = {
.name = "ICH9LPC/rst_cnt", .name = "ICH9LPC/rst_cnt",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = ich9_rst_cnt_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(rst_cnt, ICH9LPCState), VMSTATE_UINT8(rst_cnt, ICH9LPCState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -669,12 +670,9 @@ static const VMStateDescription vmstate_ich9_lpc = {
VMSTATE_UINT32(sci_level, ICH9LPCState), VMSTATE_UINT32(sci_level, ICH9LPCState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_ich9_rst_cnt,
.vmsd = &vmstate_ich9_rst_cnt, NULL
.needed = ich9_rst_cnt_needed
},
{ 0 }
} }
}; };

View File

@ -1370,6 +1370,7 @@ static const VMStateDescription vmstate_e1000_mit_state = {
.name = "e1000/mit_state", .name = "e1000/mit_state",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = e1000_mit_state_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT32(mac_reg[RDTR], E1000State), VMSTATE_UINT32(mac_reg[RDTR], E1000State),
VMSTATE_UINT32(mac_reg[RADV], E1000State), VMSTATE_UINT32(mac_reg[RADV], E1000State),
@ -1457,13 +1458,9 @@ static const VMStateDescription vmstate_e1000 = {
VMSTATE_UINT32_SUB_ARRAY(mac_reg, E1000State, VFTA, 128), VMSTATE_UINT32_SUB_ARRAY(mac_reg, E1000State, VFTA, 128),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_e1000_mit_state,
.vmsd = &vmstate_e1000_mit_state, NULL
.needed = e1000_mit_state_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -3240,6 +3240,7 @@ static const VMStateDescription vmstate_rtl8139_hotplug_ready ={
.name = "rtl8139/hotplug_ready", .name = "rtl8139/hotplug_ready",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = rtl8139_hotplug_ready_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
} }
@ -3335,13 +3336,9 @@ static const VMStateDescription vmstate_rtl8139 = {
VMSTATE_UINT32_V(cplus_enabled, RTL8139State, 4), VMSTATE_UINT32_V(cplus_enabled, RTL8139State, 4),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_rtl8139_hotplug_ready,
.vmsd = &vmstate_rtl8139_hotplug_ready, NULL
.needed = rtl8139_hotplug_ready_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -2226,6 +2226,7 @@ static const VMStateDescription vmxstate_vmxnet3_mcast_list = {
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.pre_load = vmxnet3_mcast_list_pre_load, .pre_load = vmxnet3_mcast_list_pre_load,
.needed = vmxnet3_mc_list_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_VBUFFER_UINT32(mcast_list, VMXNET3State, 0, NULL, 0, VMSTATE_VBUFFER_UINT32(mcast_list, VMXNET3State, 0, NULL, 0,
mcast_list_buff_size), mcast_list_buff_size),
@ -2470,14 +2471,9 @@ static const VMStateDescription vmstate_vmxnet3 = {
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmxstate_vmxnet3_mcast_list,
.vmsd = &vmxstate_vmxnet3_mcast_list, NULL
.needed = vmxnet3_mc_list_needed
},
{
/* empty element. */
}
} }
}; };

View File

@ -582,6 +582,7 @@ static const VMStateDescription vmstate_piix3_rcr = {
.name = "PIIX3/rcr", .name = "PIIX3/rcr",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = piix3_rcr_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(rcr, PIIX3State), VMSTATE_UINT8(rcr, PIIX3State),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -600,12 +601,9 @@ static const VMStateDescription vmstate_piix3 = {
PIIX_NUM_PIRQS, 3), PIIX_NUM_PIRQS, 3),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_piix3_rcr,
.vmsd = &vmstate_piix3_rcr, NULL
.needed = piix3_rcr_needed,
},
{ 0 }
} }
}; };

View File

@ -1968,6 +1968,7 @@ static const VMStateDescription vmstate_scsi_sense_state = {
.name = "SCSIDevice/sense", .name = "SCSIDevice/sense",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = scsi_sense_state_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8_SUB_ARRAY(sense, SCSIDevice, VMSTATE_UINT8_SUB_ARRAY(sense, SCSIDevice,
SCSI_SENSE_BUF_SIZE_OLD, SCSI_SENSE_BUF_SIZE_OLD,
@ -1998,13 +1999,9 @@ const VMStateDescription vmstate_scsi_device = {
}, },
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_scsi_sense_state,
.vmsd = &vmstate_scsi_sense_state, NULL
.needed = scsi_sense_state_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -283,6 +283,7 @@ static const VMStateDescription vmstate_hpet_rtc_irq_level = {
.name = "hpet/rtc_irq_level", .name = "hpet/rtc_irq_level",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = hpet_rtc_irq_level_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(rtc_irq_level, HPETState), VMSTATE_UINT8(rtc_irq_level, HPETState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -322,13 +323,9 @@ static const VMStateDescription vmstate_hpet = {
vmstate_hpet_timer, HPETTimer), vmstate_hpet_timer, HPETTimer),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_hpet_rtc_irq_level,
.vmsd = &vmstate_hpet_rtc_irq_level, NULL
.needed = hpet_rtc_irq_level_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -733,22 +733,23 @@ static int rtc_post_load(void *opaque, int version_id)
return 0; return 0;
} }
static const VMStateDescription vmstate_rtc_irq_reinject_on_ack_count = {
.name = "mc146818rtc/irq_reinject_on_ack_count",
.version_id = 1,
.minimum_version_id = 1,
.fields = (VMStateField[]) {
VMSTATE_UINT16(irq_reinject_on_ack_count, RTCState),
VMSTATE_END_OF_LIST()
}
};
static bool rtc_irq_reinject_on_ack_count_needed(void *opaque) static bool rtc_irq_reinject_on_ack_count_needed(void *opaque)
{ {
RTCState *s = (RTCState *)opaque; RTCState *s = (RTCState *)opaque;
return s->irq_reinject_on_ack_count != 0; return s->irq_reinject_on_ack_count != 0;
} }
static const VMStateDescription vmstate_rtc_irq_reinject_on_ack_count = {
.name = "mc146818rtc/irq_reinject_on_ack_count",
.version_id = 1,
.minimum_version_id = 1,
.needed = rtc_irq_reinject_on_ack_count_needed,
.fields = (VMStateField[]) {
VMSTATE_UINT16(irq_reinject_on_ack_count, RTCState),
VMSTATE_END_OF_LIST()
}
};
static const VMStateDescription vmstate_rtc = { static const VMStateDescription vmstate_rtc = {
.name = "mc146818rtc", .name = "mc146818rtc",
.version_id = 3, .version_id = 3,
@ -770,13 +771,9 @@ static const VMStateDescription vmstate_rtc = {
VMSTATE_UINT64_V(next_alarm_time, RTCState, 3), VMSTATE_UINT64_V(next_alarm_time, RTCState, 3),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_rtc_irq_reinject_on_ack_count,
.vmsd = &vmstate_rtc_irq_reinject_on_ack_count, NULL
.needed = rtc_irq_reinject_on_ack_count_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -2034,6 +2034,7 @@ static const VMStateDescription vmstate_ohci_eof_timer = {
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.pre_load = ohci_eof_timer_pre_load, .pre_load = ohci_eof_timer_pre_load,
.needed = ohci_eof_timer_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_TIMER_PTR(eof_timer, OHCIState), VMSTATE_TIMER_PTR(eof_timer, OHCIState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -2081,13 +2082,9 @@ static const VMStateDescription vmstate_ohci_state = {
VMSTATE_BOOL(async_complete, OHCIState), VMSTATE_BOOL(async_complete, OHCIState),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_ohci_eof_timer,
.vmsd = &vmstate_ohci_eof_timer, NULL
.needed = ohci_eof_timer_needed,
} , {
/* empty */
}
} }
}; };

View File

@ -2257,16 +2257,6 @@ static const VMStateInfo usbredir_ep_bufpq_vmstate_info = {
/* For endp_data migration */ /* For endp_data migration */
static const VMStateDescription usbredir_bulk_receiving_vmstate = {
.name = "usb-redir-ep/bulk-receiving",
.version_id = 1,
.minimum_version_id = 1,
.fields = (VMStateField[]) {
VMSTATE_UINT8(bulk_receiving_started, struct endp_data),
VMSTATE_END_OF_LIST()
}
};
static bool usbredir_bulk_receiving_needed(void *priv) static bool usbredir_bulk_receiving_needed(void *priv)
{ {
struct endp_data *endp = priv; struct endp_data *endp = priv;
@ -2274,12 +2264,13 @@ static bool usbredir_bulk_receiving_needed(void *priv)
return endp->bulk_receiving_started; return endp->bulk_receiving_started;
} }
static const VMStateDescription usbredir_stream_vmstate = { static const VMStateDescription usbredir_bulk_receiving_vmstate = {
.name = "usb-redir-ep/stream-state", .name = "usb-redir-ep/bulk-receiving",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = usbredir_bulk_receiving_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT32(max_streams, struct endp_data), VMSTATE_UINT8(bulk_receiving_started, struct endp_data),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
} }
}; };
@ -2291,6 +2282,17 @@ static bool usbredir_stream_needed(void *priv)
return endp->max_streams; return endp->max_streams;
} }
static const VMStateDescription usbredir_stream_vmstate = {
.name = "usb-redir-ep/stream-state",
.version_id = 1,
.minimum_version_id = 1,
.needed = usbredir_stream_needed,
.fields = (VMStateField[]) {
VMSTATE_UINT32(max_streams, struct endp_data),
VMSTATE_END_OF_LIST()
}
};
static const VMStateDescription usbredir_ep_vmstate = { static const VMStateDescription usbredir_ep_vmstate = {
.name = "usb-redir-ep", .name = "usb-redir-ep",
.version_id = 1, .version_id = 1,
@ -2318,16 +2320,10 @@ static const VMStateDescription usbredir_ep_vmstate = {
VMSTATE_INT32(bufpq_target_size, struct endp_data), VMSTATE_INT32(bufpq_target_size, struct endp_data),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &usbredir_bulk_receiving_vmstate,
.vmsd = &usbredir_bulk_receiving_vmstate, &usbredir_stream_vmstate,
.needed = usbredir_bulk_receiving_needed, NULL
}, {
.vmsd = &usbredir_stream_vmstate,
.needed = usbredir_stream_needed,
}, {
/* empty */
}
} }
}; };

View File

@ -1053,6 +1053,7 @@ static const VMStateDescription vmstate_virtio_device_endian = {
.name = "virtio/device_endian", .name = "virtio/device_endian",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = &virtio_device_endian_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT8(device_endian, VirtIODevice), VMSTATE_UINT8(device_endian, VirtIODevice),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -1063,6 +1064,7 @@ static const VMStateDescription vmstate_virtio_64bit_features = {
.name = "virtio/64bit_features", .name = "virtio/64bit_features",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = &virtio_64bit_features_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(guest_features, VirtIODevice), VMSTATE_UINT64(guest_features, VirtIODevice),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -1077,16 +1079,10 @@ static const VMStateDescription vmstate_virtio = {
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_virtio_device_endian,
.vmsd = &vmstate_virtio_device_endian, &vmstate_virtio_64bit_features,
.needed = &virtio_device_endian_needed NULL
},
{
.vmsd = &vmstate_virtio_64bit_features,
.needed = &virtio_64bit_features_needed
},
{ 0 }
} }
}; };

View File

@ -120,11 +120,6 @@ typedef struct {
bool (*field_exists)(void *opaque, int version_id); bool (*field_exists)(void *opaque, int version_id);
} VMStateField; } VMStateField;
typedef struct VMStateSubsection {
const VMStateDescription *vmsd;
bool (*needed)(void *opaque);
} VMStateSubsection;
struct VMStateDescription { struct VMStateDescription {
const char *name; const char *name;
int unmigratable; int unmigratable;
@ -135,8 +130,9 @@ struct VMStateDescription {
int (*pre_load)(void *opaque); int (*pre_load)(void *opaque);
int (*post_load)(void *opaque, int version_id); int (*post_load)(void *opaque, int version_id);
void (*pre_save)(void *opaque); void (*pre_save)(void *opaque);
bool (*needed)(void *opaque);
VMStateField *fields; VMStateField *fields;
const VMStateSubsection *subsections; const VMStateDescription **subsections;
}; };
extern const VMStateDescription vmstate_dummy; extern const VMStateDescription vmstate_dummy;

View File

@ -272,11 +272,11 @@ static void dump_vmstate_vmsf(FILE *out_file, const VMStateField *field,
} }
static void dump_vmstate_vmss(FILE *out_file, static void dump_vmstate_vmss(FILE *out_file,
const VMStateSubsection *subsection, const VMStateDescription **subsection,
int indent) int indent)
{ {
if (subsection->vmsd != NULL) { if (*subsection != NULL) {
dump_vmstate_vmsd(out_file, subsection->vmsd, indent, true); dump_vmstate_vmsd(out_file, *subsection, indent, true);
} }
} }
@ -317,12 +317,12 @@ static void dump_vmstate_vmsd(FILE *out_file,
fprintf(out_file, "\n%*s]", indent, ""); fprintf(out_file, "\n%*s]", indent, "");
} }
if (vmsd->subsections != NULL) { if (vmsd->subsections != NULL) {
const VMStateSubsection *subsection = vmsd->subsections; const VMStateDescription **subsection = vmsd->subsections;
bool first; bool first;
fprintf(out_file, ",\n%*s\"Subsections\": [\n", indent, ""); fprintf(out_file, ",\n%*s\"Subsections\": [\n", indent, "");
first = true; first = true;
while (subsection->vmsd != NULL) { while (*subsection != NULL) {
if (!first) { if (!first) {
fprintf(out_file, ",\n"); fprintf(out_file, ",\n");
} }

View File

@ -341,11 +341,11 @@ void vmstate_save_state(QEMUFile *f, const VMStateDescription *vmsd,
} }
static const VMStateDescription * static const VMStateDescription *
vmstate_get_subsection(const VMStateSubsection *sub, char *idstr) vmstate_get_subsection(const VMStateDescription **sub, char *idstr)
{ {
while (sub && sub->needed) { while (sub && *sub && (*sub)->needed) {
if (strcmp(idstr, sub->vmsd->name) == 0) { if (strcmp(idstr, (*sub)->name) == 0) {
return sub->vmsd; return *sub;
} }
sub++; sub++;
} }
@ -405,12 +405,12 @@ static int vmstate_subsection_load(QEMUFile *f, const VMStateDescription *vmsd,
static void vmstate_subsection_save(QEMUFile *f, const VMStateDescription *vmsd, static void vmstate_subsection_save(QEMUFile *f, const VMStateDescription *vmsd,
void *opaque, QJSON *vmdesc) void *opaque, QJSON *vmdesc)
{ {
const VMStateSubsection *sub = vmsd->subsections; const VMStateDescription **sub = vmsd->subsections;
bool subsection_found = false; bool subsection_found = false;
while (sub && sub->needed) { while (sub && *sub && (*sub)->needed) {
if (sub->needed(opaque)) { if ((*sub)->needed(opaque)) {
const VMStateDescription *vmsd = sub->vmsd; const VMStateDescription *vmsd = *sub;
uint8_t len; uint8_t len;
if (vmdesc) { if (vmdesc) {

View File

@ -40,6 +40,7 @@ static const VMStateDescription vmstate_vfp = {
.name = "cpu/vfp", .name = "cpu/vfp",
.version_id = 3, .version_id = 3,
.minimum_version_id = 3, .minimum_version_id = 3,
.needed = vfp_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_FLOAT64_ARRAY(env.vfp.regs, ARMCPU, 64), VMSTATE_FLOAT64_ARRAY(env.vfp.regs, ARMCPU, 64),
/* The xregs array is a little awkward because element 1 (FPSCR) /* The xregs array is a little awkward because element 1 (FPSCR)
@ -72,6 +73,7 @@ static const VMStateDescription vmstate_iwmmxt = {
.name = "cpu/iwmmxt", .name = "cpu/iwmmxt",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = iwmmxt_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64_ARRAY(env.iwmmxt.regs, ARMCPU, 16), VMSTATE_UINT64_ARRAY(env.iwmmxt.regs, ARMCPU, 16),
VMSTATE_UINT32_ARRAY(env.iwmmxt.cregs, ARMCPU, 16), VMSTATE_UINT32_ARRAY(env.iwmmxt.cregs, ARMCPU, 16),
@ -91,6 +93,7 @@ static const VMStateDescription vmstate_m = {
.name = "cpu/m", .name = "cpu/m",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = m_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT32(env.v7m.other_sp, ARMCPU), VMSTATE_UINT32(env.v7m.other_sp, ARMCPU),
VMSTATE_UINT32(env.v7m.vecbase, ARMCPU), VMSTATE_UINT32(env.v7m.vecbase, ARMCPU),
@ -114,6 +117,7 @@ static const VMStateDescription vmstate_thumb2ee = {
.name = "cpu/thumb2ee", .name = "cpu/thumb2ee",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = thumb2ee_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT32(env.teecr, ARMCPU), VMSTATE_UINT32(env.teecr, ARMCPU),
VMSTATE_UINT32(env.teehbr, ARMCPU), VMSTATE_UINT32(env.teehbr, ARMCPU),
@ -282,21 +286,11 @@ const VMStateDescription vmstate_arm_cpu = {
VMSTATE_BOOL(powered_off, ARMCPU), VMSTATE_BOOL(powered_off, ARMCPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_vfp,
.vmsd = &vmstate_vfp, &vmstate_iwmmxt,
.needed = vfp_needed, &vmstate_m,
} , { &vmstate_thumb2ee,
.vmsd = &vmstate_iwmmxt, NULL
.needed = iwmmxt_needed,
} , {
.vmsd = &vmstate_m,
.needed = m_needed,
} , {
.vmsd = &vmstate_thumb2ee,
.needed = thumb2ee_needed,
} , {
/* empty */
}
} }
}; };

View File

@ -403,6 +403,7 @@ static const VMStateDescription vmstate_steal_time_msr = {
.name = "cpu/steal_time_msr", .name = "cpu/steal_time_msr",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = steal_time_msr_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.steal_time_msr, X86CPU), VMSTATE_UINT64(env.steal_time_msr, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -413,6 +414,7 @@ static const VMStateDescription vmstate_async_pf_msr = {
.name = "cpu/async_pf_msr", .name = "cpu/async_pf_msr",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = async_pf_msr_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.async_pf_en_msr, X86CPU), VMSTATE_UINT64(env.async_pf_en_msr, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -423,6 +425,7 @@ static const VMStateDescription vmstate_pv_eoi_msr = {
.name = "cpu/async_pv_eoi_msr", .name = "cpu/async_pv_eoi_msr",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = pv_eoi_msr_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.pv_eoi_en_msr, X86CPU), VMSTATE_UINT64(env.pv_eoi_en_msr, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -441,6 +444,7 @@ static const VMStateDescription vmstate_fpop_ip_dp = {
.name = "cpu/fpop_ip_dp", .name = "cpu/fpop_ip_dp",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fpop_ip_dp_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT16(env.fpop, X86CPU), VMSTATE_UINT16(env.fpop, X86CPU),
VMSTATE_UINT64(env.fpip, X86CPU), VMSTATE_UINT64(env.fpip, X86CPU),
@ -461,6 +465,7 @@ static const VMStateDescription vmstate_msr_tsc_adjust = {
.name = "cpu/msr_tsc_adjust", .name = "cpu/msr_tsc_adjust",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = tsc_adjust_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.tsc_adjust, X86CPU), VMSTATE_UINT64(env.tsc_adjust, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -479,6 +484,7 @@ static const VMStateDescription vmstate_msr_tscdeadline = {
.name = "cpu/msr_tscdeadline", .name = "cpu/msr_tscdeadline",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = tscdeadline_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.tsc_deadline, X86CPU), VMSTATE_UINT64(env.tsc_deadline, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -505,6 +511,7 @@ static const VMStateDescription vmstate_msr_ia32_misc_enable = {
.name = "cpu/msr_ia32_misc_enable", .name = "cpu/msr_ia32_misc_enable",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = misc_enable_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.msr_ia32_misc_enable, X86CPU), VMSTATE_UINT64(env.msr_ia32_misc_enable, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -515,6 +522,7 @@ static const VMStateDescription vmstate_msr_ia32_feature_control = {
.name = "cpu/msr_ia32_feature_control", .name = "cpu/msr_ia32_feature_control",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = feature_control_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.msr_ia32_feature_control, X86CPU), VMSTATE_UINT64(env.msr_ia32_feature_control, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -549,6 +557,7 @@ static const VMStateDescription vmstate_msr_architectural_pmu = {
.name = "cpu/msr_architectural_pmu", .name = "cpu/msr_architectural_pmu",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = pmu_enable_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.msr_fixed_ctr_ctrl, X86CPU), VMSTATE_UINT64(env.msr_fixed_ctr_ctrl, X86CPU),
VMSTATE_UINT64(env.msr_global_ctrl, X86CPU), VMSTATE_UINT64(env.msr_global_ctrl, X86CPU),
@ -584,6 +593,7 @@ static const VMStateDescription vmstate_mpx = {
.name = "cpu/mpx", .name = "cpu/mpx",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = mpx_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_BND_REGS(env.bnd_regs, X86CPU, 4), VMSTATE_BND_REGS(env.bnd_regs, X86CPU, 4),
VMSTATE_UINT64(env.bndcs_regs.cfgu, X86CPU), VMSTATE_UINT64(env.bndcs_regs.cfgu, X86CPU),
@ -605,6 +615,7 @@ static const VMStateDescription vmstate_msr_hypercall_hypercall = {
.name = "cpu/msr_hyperv_hypercall", .name = "cpu/msr_hyperv_hypercall",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = hyperv_hypercall_enable_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.msr_hv_guest_os_id, X86CPU), VMSTATE_UINT64(env.msr_hv_guest_os_id, X86CPU),
VMSTATE_UINT64(env.msr_hv_hypercall, X86CPU), VMSTATE_UINT64(env.msr_hv_hypercall, X86CPU),
@ -624,6 +635,7 @@ static const VMStateDescription vmstate_msr_hyperv_vapic = {
.name = "cpu/msr_hyperv_vapic", .name = "cpu/msr_hyperv_vapic",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = hyperv_vapic_enable_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.msr_hv_vapic, X86CPU), VMSTATE_UINT64(env.msr_hv_vapic, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -642,6 +654,7 @@ static const VMStateDescription vmstate_msr_hyperv_time = {
.name = "cpu/msr_hyperv_time", .name = "cpu/msr_hyperv_time",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = hyperv_time_enable_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.msr_hv_tsc, X86CPU), VMSTATE_UINT64(env.msr_hv_tsc, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -683,6 +696,7 @@ static const VMStateDescription vmstate_avx512 = {
.name = "cpu/avx512", .name = "cpu/avx512",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = avx512_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64_ARRAY(env.opmask_regs, X86CPU, NB_OPMASK_REGS), VMSTATE_UINT64_ARRAY(env.opmask_regs, X86CPU, NB_OPMASK_REGS),
VMSTATE_ZMMH_REGS_VARS(env.xmm_regs, X86CPU, 0), VMSTATE_ZMMH_REGS_VARS(env.xmm_regs, X86CPU, 0),
@ -705,6 +719,7 @@ static const VMStateDescription vmstate_xss = {
.name = "cpu/xss", .name = "cpu/xss",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = xss_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.xss, X86CPU), VMSTATE_UINT64(env.xss, X86CPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -813,54 +828,22 @@ VMStateDescription vmstate_x86_cpu = {
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
/* The above list is not sorted /wrt version numbers, watch out! */ /* The above list is not sorted /wrt version numbers, watch out! */
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_async_pf_msr,
.vmsd = &vmstate_async_pf_msr, &vmstate_pv_eoi_msr,
.needed = async_pf_msr_needed, &vmstate_steal_time_msr,
} , { &vmstate_fpop_ip_dp,
.vmsd = &vmstate_pv_eoi_msr, &vmstate_msr_tsc_adjust,
.needed = pv_eoi_msr_needed, &vmstate_msr_tscdeadline,
} , { &vmstate_msr_ia32_misc_enable,
.vmsd = &vmstate_steal_time_msr, &vmstate_msr_ia32_feature_control,
.needed = steal_time_msr_needed, &vmstate_msr_architectural_pmu,
} , { &vmstate_mpx,
.vmsd = &vmstate_fpop_ip_dp, &vmstate_msr_hypercall_hypercall,
.needed = fpop_ip_dp_needed, &vmstate_msr_hyperv_vapic,
}, { &vmstate_msr_hyperv_time,
.vmsd = &vmstate_msr_tsc_adjust, &vmstate_avx512,
.needed = tsc_adjust_needed, &vmstate_xss,
}, { NULL
.vmsd = &vmstate_msr_tscdeadline,
.needed = tscdeadline_needed,
}, {
.vmsd = &vmstate_msr_ia32_misc_enable,
.needed = misc_enable_needed,
}, {
.vmsd = &vmstate_msr_ia32_feature_control,
.needed = feature_control_needed,
}, {
.vmsd = &vmstate_msr_architectural_pmu,
.needed = pmu_enable_needed,
} , {
.vmsd = &vmstate_mpx,
.needed = mpx_needed,
}, {
.vmsd = &vmstate_msr_hypercall_hypercall,
.needed = hyperv_hypercall_enable_needed,
}, {
.vmsd = &vmstate_msr_hyperv_vapic,
.needed = hyperv_vapic_enable_needed,
}, {
.vmsd = &vmstate_msr_hyperv_time,
.needed = hyperv_time_enable_needed,
}, {
.vmsd = &vmstate_avx512,
.needed = avx512_needed,
}, {
.vmsd = &vmstate_xss,
.needed = xss_needed,
} , {
/* empty */
}
} }
}; };

View File

@ -213,6 +213,7 @@ static const VMStateDescription vmstate_fpu = {
.name = "cpu/fpu", .name = "cpu/fpu",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fpu_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_FLOAT64_ARRAY(env.fpr, PowerPCCPU, 32), VMSTATE_FLOAT64_ARRAY(env.fpr, PowerPCCPU, 32),
VMSTATE_UINTTL(env.fpscr, PowerPCCPU), VMSTATE_UINTTL(env.fpscr, PowerPCCPU),
@ -231,6 +232,7 @@ static const VMStateDescription vmstate_altivec = {
.name = "cpu/altivec", .name = "cpu/altivec",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = altivec_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_AVR_ARRAY(env.avr, PowerPCCPU, 32), VMSTATE_AVR_ARRAY(env.avr, PowerPCCPU, 32),
VMSTATE_UINT32(env.vscr, PowerPCCPU), VMSTATE_UINT32(env.vscr, PowerPCCPU),
@ -249,6 +251,7 @@ static const VMStateDescription vmstate_vsx = {
.name = "cpu/vsx", .name = "cpu/vsx",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = vsx_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64_ARRAY(env.vsr, PowerPCCPU, 32), VMSTATE_UINT64_ARRAY(env.vsr, PowerPCCPU, 32),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -269,6 +272,7 @@ static const VMStateDescription vmstate_tm = {
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.minimum_version_id_old = 1, .minimum_version_id_old = 1,
.needed = tm_needed,
.fields = (VMStateField []) { .fields = (VMStateField []) {
VMSTATE_UINTTL_ARRAY(env.tm_gpr, PowerPCCPU, 32), VMSTATE_UINTTL_ARRAY(env.tm_gpr, PowerPCCPU, 32),
VMSTATE_AVR_ARRAY(env.tm_vsr, PowerPCCPU, 64), VMSTATE_AVR_ARRAY(env.tm_vsr, PowerPCCPU, 64),
@ -302,6 +306,7 @@ static const VMStateDescription vmstate_sr = {
.name = "cpu/sr", .name = "cpu/sr",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = sr_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINTTL_ARRAY(env.sr, PowerPCCPU, 32), VMSTATE_UINTTL_ARRAY(env.sr, PowerPCCPU, 32),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -351,6 +356,7 @@ static const VMStateDescription vmstate_slb = {
.name = "cpu/slb", .name = "cpu/slb",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = slb_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32_EQUAL(env.slb_nr, PowerPCCPU), VMSTATE_INT32_EQUAL(env.slb_nr, PowerPCCPU),
VMSTATE_SLB_ARRAY(env.slb, PowerPCCPU, MAX_SLB_ENTRIES), VMSTATE_SLB_ARRAY(env.slb, PowerPCCPU, MAX_SLB_ENTRIES),
@ -383,6 +389,7 @@ static const VMStateDescription vmstate_tlb6xx = {
.name = "cpu/tlb6xx", .name = "cpu/tlb6xx",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = tlb6xx_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32_EQUAL(env.nb_tlb, PowerPCCPU), VMSTATE_INT32_EQUAL(env.nb_tlb, PowerPCCPU),
VMSTATE_STRUCT_VARRAY_POINTER_INT32(env.tlb.tlb6, PowerPCCPU, VMSTATE_STRUCT_VARRAY_POINTER_INT32(env.tlb.tlb6, PowerPCCPU,
@ -429,6 +436,7 @@ static const VMStateDescription vmstate_pbr403 = {
.name = "cpu/pbr403", .name = "cpu/pbr403",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = pbr403_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINTTL_ARRAY(env.pb, PowerPCCPU, 4), VMSTATE_UINTTL_ARRAY(env.pb, PowerPCCPU, 4),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
@ -439,6 +447,7 @@ static const VMStateDescription vmstate_tlbemb = {
.name = "cpu/tlb6xx", .name = "cpu/tlb6xx",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = tlbemb_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32_EQUAL(env.nb_tlb, PowerPCCPU), VMSTATE_INT32_EQUAL(env.nb_tlb, PowerPCCPU),
VMSTATE_STRUCT_VARRAY_POINTER_INT32(env.tlb.tlbe, PowerPCCPU, VMSTATE_STRUCT_VARRAY_POINTER_INT32(env.tlb.tlbe, PowerPCCPU,
@ -448,13 +457,9 @@ static const VMStateDescription vmstate_tlbemb = {
/* 403 protection registers */ /* 403 protection registers */
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_pbr403,
.vmsd = &vmstate_pbr403, NULL
.needed = pbr403_needed,
} , {
/* empty */
}
} }
}; };
@ -483,6 +488,7 @@ static const VMStateDescription vmstate_tlbmas = {
.name = "cpu/tlbmas", .name = "cpu/tlbmas",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = tlbmas_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_INT32_EQUAL(env.nb_tlb, PowerPCCPU), VMSTATE_INT32_EQUAL(env.nb_tlb, PowerPCCPU),
VMSTATE_STRUCT_VARRAY_POINTER_INT32(env.tlb.tlbm, PowerPCCPU, VMSTATE_STRUCT_VARRAY_POINTER_INT32(env.tlb.tlbm, PowerPCCPU,
@ -533,38 +539,18 @@ const VMStateDescription vmstate_ppc_cpu = {
VMSTATE_UINT32_EQUAL(env.nb_BATs, PowerPCCPU), VMSTATE_UINT32_EQUAL(env.nb_BATs, PowerPCCPU),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection []) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_fpu,
.vmsd = &vmstate_fpu, &vmstate_altivec,
.needed = fpu_needed, &vmstate_vsx,
} , { &vmstate_sr,
.vmsd = &vmstate_altivec,
.needed = altivec_needed,
} , {
.vmsd = &vmstate_vsx,
.needed = vsx_needed,
} , {
.vmsd = &vmstate_sr,
.needed = sr_needed,
} , {
#ifdef TARGET_PPC64 #ifdef TARGET_PPC64
.vmsd = &vmstate_tm, &vmstate_tm,
.needed = tm_needed, &vmstate_slb,
} , {
.vmsd = &vmstate_slb,
.needed = slb_needed,
} , {
#endif /* TARGET_PPC64 */ #endif /* TARGET_PPC64 */
.vmsd = &vmstate_tlb6xx, &vmstate_tlb6xx,
.needed = tlb6xx_needed, &vmstate_tlbemb,
} , { &vmstate_tlbmas,
.vmsd = &vmstate_tlbemb, NULL
.needed = tlbemb_needed,
} , {
.vmsd = &vmstate_tlbmas,
.needed = tlbmas_needed,
} , {
/* empty */
}
} }
}; };

View File

@ -42,10 +42,17 @@ static void cpu_pre_save(void *opaque)
} }
} }
static inline bool fpu_needed(void *opaque)
{
/* This looks odd, but we might want to NOT transfer fprs in the future */
return true;
}
const VMStateDescription vmstate_fpu = { const VMStateDescription vmstate_fpu = {
.name = "cpu/fpu", .name = "cpu/fpu",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = fpu_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
VMSTATE_UINT64(env.vregs[0][0].ll, S390CPU), VMSTATE_UINT64(env.vregs[0][0].ll, S390CPU),
VMSTATE_UINT64(env.vregs[1][0].ll, S390CPU), VMSTATE_UINT64(env.vregs[1][0].ll, S390CPU),
@ -68,16 +75,11 @@ const VMStateDescription vmstate_fpu = {
} }
}; };
static inline bool fpu_needed(void *opaque)
{
/* This looks odd, but we might want to NOT transfer fprs in the future */
return true;
}
const VMStateDescription vmstate_vregs = { const VMStateDescription vmstate_vregs = {
.name = "cpu/vregs", .name = "cpu/vregs",
.version_id = 1, .version_id = 1,
.minimum_version_id = 1, .minimum_version_id = 1,
.needed = vregs_needed,
.fields = (VMStateField[]) { .fields = (VMStateField[]) {
/* vregs[0][0] -> vregs[15][0] and fregs are overlays */ /* vregs[0][0] -> vregs[15][0] and fregs are overlays */
VMSTATE_UINT64(env.vregs[16][0].ll, S390CPU), VMSTATE_UINT64(env.vregs[16][0].ll, S390CPU),
@ -159,16 +161,10 @@ const VMStateDescription vmstate_s390_cpu = {
VMSTATE_VBUFFER_UINT32(irqstate, S390CPU, 4, NULL, 0, VMSTATE_VBUFFER_UINT32(irqstate, S390CPU, 4, NULL, 0,
irqstate_saved_size), irqstate_saved_size),
VMSTATE_END_OF_LIST() VMSTATE_END_OF_LIST()
}, },
.subsections = (VMStateSubsection[]) { .subsections = (const VMStateDescription*[]) {
{ &vmstate_fpu,
.vmsd = &vmstate_fpu, &vmstate_vregs,
.needed = fpu_needed, NULL
} , {
.vmsd = &vmstate_vregs,
.needed = vregs_needed,
} , {
/* empty */
}
}, },
}; };