1e67db06eSJia Liu /* 2e67db06eSJia Liu * OpenRISC Machine 3e67db06eSJia Liu * 4e67db06eSJia Liu * Copyright (c) 2011-2012 Jia Liu <proljc@gmail.com> 5e67db06eSJia Liu * 6e67db06eSJia Liu * This library is free software; you can redistribute it and/or 7e67db06eSJia Liu * modify it under the terms of the GNU Lesser General Public 8e67db06eSJia Liu * License as published by the Free Software Foundation; either 9e67db06eSJia Liu * version 2 of the License, or (at your option) any later version. 10e67db06eSJia Liu * 11e67db06eSJia Liu * This library is distributed in the hope that it will be useful, 12e67db06eSJia Liu * but WITHOUT ANY WARRANTY; without even the implied warranty of 13e67db06eSJia Liu * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 14e67db06eSJia Liu * Lesser General Public License for more details. 15e67db06eSJia Liu * 16e67db06eSJia Liu * You should have received a copy of the GNU Lesser General Public 17e67db06eSJia Liu * License along with this library; if not, see <http://www.gnu.org/licenses/>. 18e67db06eSJia Liu */ 19e67db06eSJia Liu 20ed2decc6SPeter Maydell #include "qemu/osdep.h" 21e67db06eSJia Liu #include "hw/hw.h" 22e67db06eSJia Liu #include "hw/boards.h" 23e67db06eSJia Liu 24da697214SAndreas Färber static const VMStateDescription vmstate_env = { 25da697214SAndreas Färber .name = "env", 26da697214SAndreas Färber .version_id = 1, 27da697214SAndreas Färber .minimum_version_id = 1, 28e67db06eSJia Liu .fields = (VMStateField[]) { 29e67db06eSJia Liu VMSTATE_UINT32_ARRAY(gpr, CPUOpenRISCState, 32), 30e67db06eSJia Liu VMSTATE_UINT32(sr, CPUOpenRISCState), 31e67db06eSJia Liu VMSTATE_UINT32(epcr, CPUOpenRISCState), 32e67db06eSJia Liu VMSTATE_UINT32(eear, CPUOpenRISCState), 33e67db06eSJia Liu VMSTATE_UINT32(esr, CPUOpenRISCState), 34e67db06eSJia Liu VMSTATE_UINT32(fpcsr, CPUOpenRISCState), 35e67db06eSJia Liu VMSTATE_UINT32(pc, CPUOpenRISCState), 36e67db06eSJia Liu VMSTATE_UINT32(npc, CPUOpenRISCState), 37e67db06eSJia Liu VMSTATE_UINT32(ppc, CPUOpenRISCState), 38e67db06eSJia Liu VMSTATE_END_OF_LIST() 39e67db06eSJia Liu } 40e67db06eSJia Liu }; 41e67db06eSJia Liu 42da697214SAndreas Färber const VMStateDescription vmstate_openrisc_cpu = { 43da697214SAndreas Färber .name = "cpu", 44da697214SAndreas Färber .version_id = 1, 45da697214SAndreas Färber .minimum_version_id = 1, 46da697214SAndreas Färber .fields = (VMStateField[]) { 47da697214SAndreas Färber VMSTATE_CPU(), 48da697214SAndreas Färber VMSTATE_STRUCT(env, OpenRISCCPU, 1, vmstate_env, CPUOpenRISCState), 49da697214SAndreas Färber VMSTATE_END_OF_LIST() 50e67db06eSJia Liu } 51da697214SAndreas Färber }; 52