]>
Commit | Line | Data |
---|---|---|
29e4bcb2 AF |
1 | /* |
2 | * QEMU S/390 CPU | |
3 | * | |
4 | * Copyright (c) 2012 SUSE LINUX Products GmbH | |
5 | * | |
6 | * This library is free software; you can redistribute it and/or | |
7 | * modify it under the terms of the GNU Lesser General Public | |
8 | * License as published by the Free Software Foundation; either | |
9 | * version 2.1 of the License, or (at your option) any later version. | |
10 | * | |
11 | * This library is distributed in the hope that it will be useful, | |
12 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
14 | * Lesser General Public License for more details. | |
15 | * | |
16 | * You should have received a copy of the GNU Lesser General Public | |
17 | * License along with this library; if not, see | |
18 | * <http://www.gnu.org/licenses/lgpl-2.1.html> | |
19 | */ | |
20 | #ifndef QEMU_S390_CPU_QOM_H | |
21 | #define QEMU_S390_CPU_QOM_H | |
22 | ||
2e5b09fd | 23 | #include "hw/core/cpu.h" |
db1015e9 | 24 | #include "qom/object.h" |
29e4bcb2 | 25 | |
e555cbe7 | 26 | #define TYPE_S390_CPU "s390x-cpu" |
29e4bcb2 | 27 | |
db1015e9 EH |
28 | typedef struct S390CPU S390CPU; |
29 | typedef struct S390CPUClass S390CPUClass; | |
29e4bcb2 AF |
30 | #define S390_CPU_CLASS(klass) \ |
31 | OBJECT_CLASS_CHECK(S390CPUClass, (klass), TYPE_S390_CPU) | |
32 | #define S390_CPU(obj) \ | |
33 | OBJECT_CHECK(S390CPU, (obj), TYPE_S390_CPU) | |
34 | #define S390_CPU_GET_CLASS(obj) \ | |
35 | OBJECT_GET_CLASS(S390CPUClass, (obj), TYPE_S390_CPU) | |
36 | ||
ef2974cc DH |
37 | typedef struct S390CPUModel S390CPUModel; |
38 | typedef struct S390CPUDef S390CPUDef; | |
39 | ||
eac4f827 JF |
40 | typedef enum cpu_reset_type { |
41 | S390_CPU_RESET_NORMAL, | |
81b92223 | 42 | S390_CPU_RESET_INITIAL, |
eb8adcc3 | 43 | S390_CPU_RESET_CLEAR, |
eac4f827 JF |
44 | } cpu_reset_type; |
45 | ||
29e4bcb2 AF |
46 | /** |
47 | * S390CPUClass: | |
1f136632 | 48 | * @parent_realize: The parent class' realize handler. |
29e4bcb2 | 49 | * @parent_reset: The parent class' reset handler. |
29c6157c | 50 | * @load_normal: Performs a load normal. |
f5ae2a4f CB |
51 | * @cpu_reset: Performs a CPU reset. |
52 | * @initial_cpu_reset: Performs an initial CPU reset. | |
29e4bcb2 AF |
53 | * |
54 | * An S/390 CPU model. | |
55 | */ | |
db1015e9 | 56 | struct S390CPUClass { |
29e4bcb2 AF |
57 | /*< private >*/ |
58 | CPUClass parent_class; | |
59 | /*< public >*/ | |
6c064de1 | 60 | const S390CPUDef *cpu_def; |
41868f84 DH |
61 | bool kvm_required; |
62 | bool is_static; | |
63 | bool is_migration_safe; | |
64 | const char *desc; | |
29e4bcb2 | 65 | |
1f136632 | 66 | DeviceRealize parent_realize; |
781c67ca | 67 | DeviceReset parent_reset; |
29c6157c | 68 | void (*load_normal)(CPUState *cpu); |
eac4f827 | 69 | void (*reset)(CPUState *cpu, cpu_reset_type type); |
db1015e9 | 70 | }; |
29e4bcb2 | 71 | |
ef2974cc | 72 | typedef struct CPUS390XState CPUS390XState; |
97a8ea5a | 73 | |
29e4bcb2 | 74 | #endif |