1b8d38bd5SDamien Hedde /*
2b8d38bd5SDamien Hedde * Clock migration structure
3b8d38bd5SDamien Hedde *
4b8d38bd5SDamien Hedde * Copyright GreenSocs 2019-2020
5b8d38bd5SDamien Hedde *
6b8d38bd5SDamien Hedde * Authors:
7b8d38bd5SDamien Hedde * Damien Hedde
8b8d38bd5SDamien Hedde *
9b8d38bd5SDamien Hedde * This work is licensed under the terms of the GNU GPL, version 2 or later.
10b8d38bd5SDamien Hedde * See the COPYING file in the top-level directory.
11b8d38bd5SDamien Hedde */
12b8d38bd5SDamien Hedde
13b8d38bd5SDamien Hedde #include "qemu/osdep.h"
14b8d38bd5SDamien Hedde #include "migration/vmstate.h"
15b8d38bd5SDamien Hedde #include "hw/clock.h"
16b8d38bd5SDamien Hedde
muldiv_needed(void * opaque)1799abcbc7SPeter Maydell static bool muldiv_needed(void *opaque)
1899abcbc7SPeter Maydell {
1999abcbc7SPeter Maydell Clock *clk = opaque;
2099abcbc7SPeter Maydell
2199abcbc7SPeter Maydell return clk->multiplier != 1 || clk->divider != 1;
2299abcbc7SPeter Maydell }
2399abcbc7SPeter Maydell
clock_pre_load(void * opaque)2499abcbc7SPeter Maydell static int clock_pre_load(void *opaque)
2599abcbc7SPeter Maydell {
2699abcbc7SPeter Maydell Clock *clk = opaque;
2799abcbc7SPeter Maydell /*
2899abcbc7SPeter Maydell * The initial out-of-reset settings of the Clock might have been
2999abcbc7SPeter Maydell * configured by the device to be different from what we set
3099abcbc7SPeter Maydell * in clock_initfn(), so we must here set the default values to
3199abcbc7SPeter Maydell * be used if they are not in the inbound migration state.
3299abcbc7SPeter Maydell */
3399abcbc7SPeter Maydell clk->multiplier = 1;
3499abcbc7SPeter Maydell clk->divider = 1;
3599abcbc7SPeter Maydell
3699abcbc7SPeter Maydell return 0;
3799abcbc7SPeter Maydell }
3899abcbc7SPeter Maydell
3999abcbc7SPeter Maydell const VMStateDescription vmstate_muldiv = {
4099abcbc7SPeter Maydell .name = "clock/muldiv",
4199abcbc7SPeter Maydell .version_id = 1,
4299abcbc7SPeter Maydell .minimum_version_id = 1,
4399abcbc7SPeter Maydell .needed = muldiv_needed,
44*f55f1a49SRichard Henderson .fields = (const VMStateField[]) {
4599abcbc7SPeter Maydell VMSTATE_UINT32(multiplier, Clock),
4699abcbc7SPeter Maydell VMSTATE_UINT32(divider, Clock),
47acbcd06eSDr. David Alan Gilbert VMSTATE_END_OF_LIST()
4899abcbc7SPeter Maydell },
4999abcbc7SPeter Maydell };
5099abcbc7SPeter Maydell
51b8d38bd5SDamien Hedde const VMStateDescription vmstate_clock = {
52b8d38bd5SDamien Hedde .name = "clock",
53b8d38bd5SDamien Hedde .version_id = 0,
54b8d38bd5SDamien Hedde .minimum_version_id = 0,
5599abcbc7SPeter Maydell .pre_load = clock_pre_load,
56*f55f1a49SRichard Henderson .fields = (const VMStateField[]) {
57b8d38bd5SDamien Hedde VMSTATE_UINT64(period, Clock),
58b8d38bd5SDamien Hedde VMSTATE_END_OF_LIST()
5999abcbc7SPeter Maydell },
60*f55f1a49SRichard Henderson .subsections = (const VMStateDescription * const []) {
6199abcbc7SPeter Maydell &vmstate_muldiv,
6299abcbc7SPeter Maydell NULL
6399abcbc7SPeter Maydell },
64b8d38bd5SDamien Hedde };
65