1 /* 2 * RX CPU 3 * 4 * Copyright (c) 2019 Yoshinori Sato 5 * 6 * This program is free software; you can redistribute it and/or modify it 7 * under the terms and conditions of the GNU General Public License, 8 * version 2 or later, as published by the Free Software Foundation. 9 * 10 * This program is distributed in the hope it will be useful, but WITHOUT 11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 13 * more details. 14 * 15 * You should have received a copy of the GNU General Public License along with 16 * this program. If not, see <http://www.gnu.org/licenses/>. 17 */ 18 19 #ifndef RX_CPU_QOM_H 20 #define RX_CPU_QOM_H 21 22 #include "hw/core/cpu.h" 23 #include "qom/object.h" 24 25 #define TYPE_RX_CPU "rx-cpu" 26 27 #define TYPE_RX62N_CPU RX_CPU_TYPE_NAME("rx62n") 28 29 typedef struct RXCPU RXCPU; 30 typedef struct RXCPUClass RXCPUClass; 31 DECLARE_OBJ_CHECKERS(RXCPU, RXCPUClass, 32 RX_CPU, TYPE_RX_CPU) 33 34 /* 35 * RXCPUClass: 36 * @parent_realize: The parent class' realize handler. 37 * @parent_reset: The parent class' reset handler. 38 * 39 * A RX CPU model. 40 */ 41 struct RXCPUClass { 42 /*< private >*/ 43 CPUClass parent_class; 44 /*< public >*/ 45 46 DeviceRealize parent_realize; 47 DeviceReset parent_reset; 48 }; 49 50 #define CPUArchState struct CPURXState 51 52 #endif 53