Statistics
| Branch: | Revision:

root / hw / pc.h @ e1460e47

History | View | Annotate | Download (5.1 kB)

1
#ifndef HW_PC_H
2
#define HW_PC_H
3

    
4
#include "qemu-common.h"
5
#include "ioport.h"
6
#include "isa.h"
7
#include "fdc.h"
8
#include "mc146818rtc.h"
9

    
10
/* PC-style peripherals (also used by other machines).  */
11

    
12
/* serial.c */
13

    
14
SerialState *serial_init(int base, qemu_irq irq, int baudbase,
15
                         CharDriverState *chr);
16
SerialState *serial_mm_init (target_phys_addr_t base, int it_shift,
17
                             qemu_irq irq, int baudbase,
18
                             CharDriverState *chr, int ioregister,
19
                             int be);
20
SerialState *serial_isa_init(int index, CharDriverState *chr);
21
void serial_set_frequency(SerialState *s, uint32_t frequency);
22

    
23
/* parallel.c */
24

    
25
typedef struct ParallelState ParallelState;
26
ParallelState *parallel_init(int index, CharDriverState *chr);
27
ParallelState *parallel_mm_init(target_phys_addr_t base, int it_shift, qemu_irq irq, CharDriverState *chr);
28

    
29
/* i8259.c */
30

    
31
typedef struct PicState2 PicState2;
32
extern PicState2 *isa_pic;
33
void pic_set_irq(int irq, int level);
34
void pic_set_irq_new(void *opaque, int irq, int level);
35
qemu_irq *i8259_init(qemu_irq parent_irq);
36
int pic_read_irq(PicState2 *s);
37
void pic_update_irq(PicState2 *s);
38
uint32_t pic_intack_read(PicState2 *s);
39
void pic_info(Monitor *mon);
40
void irq_info(Monitor *mon);
41

    
42
/* ISA */
43
typedef struct isa_irq_state {
44
    qemu_irq *i8259;
45
    qemu_irq *ioapic;
46
} IsaIrqState;
47

    
48
void isa_irq_handler(void *opaque, int n, int level);
49

    
50
/* i8254.c */
51

    
52
#define PIT_FREQ 1193182
53

    
54
typedef struct PITState PITState;
55

    
56
PITState *pit_init(int base, qemu_irq irq);
57
void pit_set_gate(PITState *pit, int channel, int val);
58
int pit_get_gate(PITState *pit, int channel);
59
int pit_get_initial_count(PITState *pit, int channel);
60
int pit_get_mode(PITState *pit, int channel);
61
int pit_get_out(PITState *pit, int channel, int64_t current_time);
62

    
63
void hpet_pit_disable(void);
64
void hpet_pit_enable(void);
65

    
66
/* vmport.c */
67
void vmport_init(void);
68
void vmport_register(unsigned char command, IOPortReadFunc *func, void *opaque);
69

    
70
/* vmmouse.c */
71
void *vmmouse_init(void *m);
72

    
73
/* pckbd.c */
74

    
75
void i8042_init(qemu_irq kbd_irq, qemu_irq mouse_irq, uint32_t io_base);
76
void i8042_mm_init(qemu_irq kbd_irq, qemu_irq mouse_irq,
77
                   target_phys_addr_t base, ram_addr_t size,
78
                   target_phys_addr_t mask);
79

    
80
/* pc.c */
81
extern int fd_bootchk;
82

    
83
void pc_register_ferr_irq(qemu_irq irq);
84
void pc_cmos_set_s3_resume(void *opaque, int irq, int level);
85
void pc_acpi_smi_interrupt(void *opaque, int irq, int level);
86

    
87
void pc_cpus_init(const char *cpu_model);
88
void pc_memory_init(ram_addr_t ram_size,
89
                    const char *kernel_filename,
90
                    const char *kernel_cmdline,
91
                    const char *initrd_filename,
92
                    ram_addr_t *below_4g_mem_size_p,
93
                    ram_addr_t *above_4g_mem_size_p);
94
qemu_irq *pc_allocate_cpu_irq(void);
95
void pc_vga_init(PCIBus *pci_bus);
96
void pc_basic_device_init(qemu_irq *isa_irq,
97
                          FDCtrl **floppy_controller,
98
                          RTCState **rtc_state);
99
void pc_init_ne2k_isa(NICInfo *nd);
100
#ifdef HAS_AUDIO
101
void pc_audio_init (PCIBus *pci_bus, qemu_irq *pic);
102
#endif
103
void pc_cmos_init(ram_addr_t ram_size, ram_addr_t above_4g_mem_size,
104
                  const char *boot_device, DriveInfo **hd_table,
105
                  FDCtrl *floppy_controller, RTCState *s);
106
void pc_pci_device_init(PCIBus *pci_bus);
107

    
108
void ioport_set_a20(int enable);
109
int ioport_get_a20(void);
110

    
111
typedef void (*cpu_set_smm_t)(int smm, void *arg);
112
void cpu_smm_register(cpu_set_smm_t callback, void *arg);
113

    
114
/* acpi.c */
115
extern int acpi_enabled;
116
extern char *acpi_tables;
117
extern size_t acpi_tables_len;
118

    
119
void acpi_bios_init(void);
120
int acpi_table_add(const char *table_desc);
121

    
122
/* acpi_piix.c */
123

    
124
i2c_bus *piix4_pm_init(PCIBus *bus, int devfn, uint32_t smb_io_base,
125
                       qemu_irq sci_irq, qemu_irq cmos_s3, qemu_irq smi_irq,
126
                       int kvm_enabled);
127
void piix4_smbus_register_device(SMBusDevice *dev, uint8_t addr);
128
void piix4_acpi_system_hot_add_init(PCIBus *bus);
129

    
130
/* hpet.c */
131
extern int no_hpet;
132

    
133
/* pcspk.c */
134
void pcspk_init(PITState *);
135
int pcspk_audio_init(qemu_irq *pic);
136

    
137
/* piix_pci.c */
138
struct PCII440FXState;
139
typedef struct PCII440FXState PCII440FXState;
140

    
141
PCIBus *i440fx_init(PCII440FXState **pi440fx_state, int *piix_devfn, qemu_irq *pic, int ram_size);
142
void i440fx_init_memory_mappings(PCII440FXState *d);
143

    
144
/* piix4.c */
145
extern PCIDevice *piix4_dev;
146
int piix4_init(PCIBus *bus, int devfn);
147

    
148
/* vga.c */
149
enum vga_retrace_method {
150
    VGA_RETRACE_DUMB,
151
    VGA_RETRACE_PRECISE
152
};
153

    
154
extern enum vga_retrace_method vga_retrace_method;
155

    
156
int isa_vga_init(void);
157
int pci_vga_init(PCIBus *bus,
158
                 unsigned long vga_bios_offset, int vga_bios_size);
159
int isa_vga_mm_init(target_phys_addr_t vram_base,
160
                    target_phys_addr_t ctrl_base, int it_shift);
161

    
162
/* cirrus_vga.c */
163
void pci_cirrus_vga_init(PCIBus *bus);
164
void isa_cirrus_vga_init(void);
165

    
166
/* ne2000.c */
167

    
168
void isa_ne2000_init(int base, int irq, NICInfo *nd);
169

    
170
/* e820 types */
171
#define E820_RAM        1
172
#define E820_RESERVED   2
173
#define E820_ACPI       3
174
#define E820_NVS        4
175
#define E820_UNUSABLE   5
176

    
177
int e820_add_entry(uint64_t, uint64_t, uint32_t);
178

    
179
#endif