1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20#ifndef QEMU_S390_CPU_QOM_H
21#define QEMU_S390_CPU_QOM_H
22
23#include "qom/cpu.h"
24#include "cpu.h"
25
26#define TYPE_S390_CPU "s390-cpu"
27
28#define S390_CPU_CLASS(klass) \
29 OBJECT_CLASS_CHECK(S390CPUClass, (klass), TYPE_S390_CPU)
30#define S390_CPU(obj) \
31 OBJECT_CHECK(S390CPU, (obj), TYPE_S390_CPU)
32#define S390_CPU_GET_CLASS(obj) \
33 OBJECT_GET_CLASS(S390CPUClass, (obj), TYPE_S390_CPU)
34
35
36
37
38
39
40
41
42
43
44
45typedef struct S390CPUClass {
46
47 CPUClass parent_class;
48
49
50 DeviceRealize parent_realize;
51 void (*parent_reset)(CPUState *cpu);
52 void (*load_normal)(CPUState *cpu);
53 void (*cpu_reset)(CPUState *cpu);
54 void (*initial_cpu_reset)(CPUState *cpu);
55} S390CPUClass;
56
57
58
59
60
61
62
63typedef struct S390CPU {
64
65 CPUState parent_obj;
66
67
68 CPUS390XState env;
69} S390CPU;
70
71static inline S390CPU *s390_env_get_cpu(CPUS390XState *env)
72{
73 return container_of(env, S390CPU, env);
74}
75
76#define ENV_GET_CPU(e) CPU(s390_env_get_cpu(e))
77
78#define ENV_OFFSET offsetof(S390CPU, env)
79
80#ifndef CONFIG_USER_ONLY
81extern const struct VMStateDescription vmstate_s390_cpu;
82#endif
83
84void s390_cpu_do_interrupt(CPUState *cpu);
85bool s390_cpu_exec_interrupt(CPUState *cpu, int int_req);
86void s390_cpu_dump_state(CPUState *cpu, FILE *f, fprintf_function cpu_fprintf,
87 int flags);
88int s390_cpu_write_elf64_note(WriteCoreDumpFunction f, CPUState *cs,
89 int cpuid, void *opaque);
90
91int s390_cpu_write_elf64_qemunote(WriteCoreDumpFunction f,
92 CPUState *cpu, void *opaque);
93hwaddr s390_cpu_get_phys_page_debug(CPUState *cpu, vaddr addr);
94hwaddr s390_cpu_get_phys_addr_debug(CPUState *cpu, vaddr addr);
95int s390_cpu_gdb_read_register(CPUState *cpu, uint8_t *buf, int reg);
96int s390_cpu_gdb_write_register(CPUState *cpu, uint8_t *buf, int reg);
97void s390_cpu_gdb_init(CPUState *cs);
98
99#endif
100