Statistics
| Branch: | Revision:

root / target-microblaze / cpu-qom.h @ 5b50e790

History | View | Annotate | Download (2.3 kB)

1 b77f98ca Andreas Färber
/*
2 b77f98ca Andreas Färber
 * QEMU MicroBlaze CPU
3 b77f98ca Andreas Färber
 *
4 b77f98ca Andreas Färber
 * Copyright (c) 2012 SUSE LINUX Products GmbH
5 b77f98ca Andreas Färber
 *
6 b77f98ca Andreas Färber
 * This library is free software; you can redistribute it and/or
7 b77f98ca Andreas Färber
 * modify it under the terms of the GNU Lesser General Public
8 b77f98ca Andreas Färber
 * License as published by the Free Software Foundation; either
9 b77f98ca Andreas Färber
 * version 2.1 of the License, or (at your option) any later version.
10 b77f98ca Andreas Färber
 *
11 b77f98ca Andreas Färber
 * This library is distributed in the hope that it will be useful,
12 b77f98ca Andreas Färber
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 b77f98ca Andreas Färber
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14 b77f98ca Andreas Färber
 * Lesser General Public License for more details.
15 b77f98ca Andreas Färber
 *
16 b77f98ca Andreas Färber
 * You should have received a copy of the GNU Lesser General Public
17 b77f98ca Andreas Färber
 * License along with this library; if not, see
18 b77f98ca Andreas Färber
 * <http://www.gnu.org/licenses/lgpl-2.1.html>
19 b77f98ca Andreas Färber
 */
20 b77f98ca Andreas Färber
#ifndef QEMU_MICROBLAZE_CPU_QOM_H
21 b77f98ca Andreas Färber
#define QEMU_MICROBLAZE_CPU_QOM_H
22 b77f98ca Andreas Färber
23 14cccb61 Paolo Bonzini
#include "qom/cpu.h"
24 b77f98ca Andreas Färber
25 b77f98ca Andreas Färber
#define TYPE_MICROBLAZE_CPU "microblaze-cpu"
26 b77f98ca Andreas Färber
27 b77f98ca Andreas Färber
#define MICROBLAZE_CPU_CLASS(klass) \
28 b77f98ca Andreas Färber
    OBJECT_CLASS_CHECK(MicroBlazeCPUClass, (klass), TYPE_MICROBLAZE_CPU)
29 b77f98ca Andreas Färber
#define MICROBLAZE_CPU(obj) \
30 b77f98ca Andreas Färber
    OBJECT_CHECK(MicroBlazeCPU, (obj), TYPE_MICROBLAZE_CPU)
31 b77f98ca Andreas Färber
#define MICROBLAZE_CPU_GET_CLASS(obj) \
32 b77f98ca Andreas Färber
    OBJECT_GET_CLASS(MicroBlazeCPUClass, (obj), TYPE_MICROBLAZE_CPU)
33 b77f98ca Andreas Färber
34 b77f98ca Andreas Färber
/**
35 b77f98ca Andreas Färber
 * MicroBlazeCPUClass:
36 746b03b2 Andreas Färber
 * @parent_realize: The parent class' realize handler.
37 b77f98ca Andreas Färber
 * @parent_reset: The parent class' reset handler.
38 b77f98ca Andreas Färber
 *
39 b77f98ca Andreas Färber
 * A MicroBlaze CPU model.
40 b77f98ca Andreas Färber
 */
41 b77f98ca Andreas Färber
typedef struct MicroBlazeCPUClass {
42 b77f98ca Andreas Färber
    /*< private >*/
43 b77f98ca Andreas Färber
    CPUClass parent_class;
44 b77f98ca Andreas Färber
    /*< public >*/
45 b77f98ca Andreas Färber
46 746b03b2 Andreas Färber
    DeviceRealize parent_realize;
47 b77f98ca Andreas Färber
    void (*parent_reset)(CPUState *cpu);
48 b77f98ca Andreas Färber
} MicroBlazeCPUClass;
49 b77f98ca Andreas Färber
50 b77f98ca Andreas Färber
/**
51 b77f98ca Andreas Färber
 * MicroBlazeCPU:
52 b77f98ca Andreas Färber
 * @env: #CPUMBState
53 b77f98ca Andreas Färber
 *
54 b77f98ca Andreas Färber
 * A MicroBlaze CPU.
55 b77f98ca Andreas Färber
 */
56 b77f98ca Andreas Färber
typedef struct MicroBlazeCPU {
57 b77f98ca Andreas Färber
    /*< private >*/
58 b77f98ca Andreas Färber
    CPUState parent_obj;
59 a1bff71c Edgar E. Iglesias
    uint32_t base_vectors;
60 b77f98ca Andreas Färber
    /*< public >*/
61 b77f98ca Andreas Färber
62 b77f98ca Andreas Färber
    CPUMBState env;
63 b77f98ca Andreas Färber
} MicroBlazeCPU;
64 b77f98ca Andreas Färber
65 b77f98ca Andreas Färber
static inline MicroBlazeCPU *mb_env_get_cpu(CPUMBState *env)
66 b77f98ca Andreas Färber
{
67 6e42be7c Andreas Färber
    return container_of(env, MicroBlazeCPU, env);
68 b77f98ca Andreas Färber
}
69 b77f98ca Andreas Färber
70 b77f98ca Andreas Färber
#define ENV_GET_CPU(e) CPU(mb_env_get_cpu(e))
71 b77f98ca Andreas Färber
72 fadf9825 Andreas Färber
#define ENV_OFFSET offsetof(MicroBlazeCPU, env)
73 b77f98ca Andreas Färber
74 97a8ea5a Andreas Färber
void mb_cpu_do_interrupt(CPUState *cs);
75 878096ee Andreas Färber
void mb_cpu_dump_state(CPUState *cpu, FILE *f, fprintf_function cpu_fprintf,
76 878096ee Andreas Färber
                       int flags);
77 00b941e5 Andreas Färber
hwaddr mb_cpu_get_phys_page_debug(CPUState *cpu, vaddr addr);
78 5b50e790 Andreas Färber
int mb_cpu_gdb_read_register(CPUState *cpu, uint8_t *buf, int reg);
79 5b50e790 Andreas Färber
int mb_cpu_gdb_write_register(CPUState *cpu, uint8_t *buf, int reg);
80 97a8ea5a Andreas Färber
81 b77f98ca Andreas Färber
#endif