exec_close(): return -errno on errors (v2)
[qemu-kvm.git] / hw / devices.h
blob1a55c1e9053208cf6f0d6905aee7e4cb72a7e97c
1 #ifndef QEMU_DEVICES_H
2 #define QEMU_DEVICES_H
4 /* ??? Not all users of this file can include cpu-common.h. */
5 struct MemoryRegion;
7 /* Devices that have nowhere better to go. */
9 /* smc91c111.c */
10 void smc91c111_init(NICInfo *, uint32_t, qemu_irq);
12 /* lan9118.c */
13 void lan9118_init(NICInfo *, uint32_t, qemu_irq);
15 /* tsc210x.c */
16 uWireSlave *tsc2102_init(qemu_irq pint);
17 uWireSlave *tsc2301_init(qemu_irq penirq, qemu_irq kbirq, qemu_irq dav);
18 I2SCodec *tsc210x_codec(uWireSlave *chip);
19 uint32_t tsc210x_txrx(void *opaque, uint32_t value, int len);
20 void tsc210x_set_transform(uWireSlave *chip,
21 MouseTransformInfo *info);
22 void tsc210x_key_event(uWireSlave *chip, int key, int down);
24 /* tsc2005.c */
25 void *tsc2005_init(qemu_irq pintdav);
26 uint32_t tsc2005_txrx(void *opaque, uint32_t value, int len);
27 void tsc2005_set_transform(void *opaque, MouseTransformInfo *info);
29 /* stellaris_input.c */
30 void stellaris_gamepad_init(int n, qemu_irq *irq, const int *keycode);
32 /* blizzard.c */
33 void *s1d13745_init(qemu_irq gpio_int);
34 void s1d13745_write(void *opaque, int dc, uint16_t value);
35 void s1d13745_write_block(void *opaque, int dc,
36 void *buf, size_t len, int pitch);
37 uint16_t s1d13745_read(void *opaque, int dc);
39 /* cbus.c */
40 typedef struct {
41 qemu_irq clk;
42 qemu_irq dat;
43 qemu_irq sel;
44 } CBus;
45 CBus *cbus_init(qemu_irq dat_out);
46 void cbus_attach(CBus *bus, void *slave_opaque);
48 void *retu_init(qemu_irq irq, int vilma);
49 void *tahvo_init(qemu_irq irq, int betty);
51 void retu_key_event(void *retu, int state);
53 /* tc6393xb.c */
54 typedef struct TC6393xbState TC6393xbState;
55 #define TC6393XB_RAM 0x110000 /* amount of ram for Video and USB */
56 TC6393xbState *tc6393xb_init(struct MemoryRegion *sysmem,
57 uint32_t base, qemu_irq irq);
58 void tc6393xb_gpio_out_set(TC6393xbState *s, int line,
59 qemu_irq handler);
60 qemu_irq *tc6393xb_gpio_in_get(TC6393xbState *s);
61 qemu_irq tc6393xb_l3v_get(TC6393xbState *s);
63 /* sm501.c */
64 void sm501_init(struct MemoryRegion *address_space_mem, uint32_t base,
65 uint32_t local_mem_bytes, qemu_irq irq,
66 CharDriverState *chr);
68 #endif