1#ifndef QEMU_DEVICES_H
2#define QEMU_DEVICES_H
3
4
5
6#include "hw/hw.h"
7
8
9void smc91c111_init(NICInfo *, uint32_t, qemu_irq);
10
11
12void lan9118_init(NICInfo *, uint32_t, qemu_irq);
13
14
15uWireSlave *tsc2102_init(qemu_irq pint);
16uWireSlave *tsc2301_init(qemu_irq penirq, qemu_irq kbirq, qemu_irq dav);
17I2SCodec *tsc210x_codec(uWireSlave *chip);
18uint32_t tsc210x_txrx(void *opaque, uint32_t value, int len);
19void tsc210x_set_transform(uWireSlave *chip,
20 MouseTransformInfo *info);
21void tsc210x_key_event(uWireSlave *chip, int key, int down);
22
23
24void *tsc2005_init(qemu_irq pintdav);
25uint32_t tsc2005_txrx(void *opaque, uint32_t value, int len);
26void tsc2005_set_transform(void *opaque, MouseTransformInfo *info);
27
28
29void stellaris_gamepad_init(int n, qemu_irq *irq, const int *keycode);
30
31
32void *s1d13745_init(qemu_irq gpio_int);
33void s1d13745_write(void *opaque, int dc, uint16_t value);
34void s1d13745_write_block(void *opaque, int dc,
35 void *buf, size_t len, int pitch);
36uint16_t s1d13745_read(void *opaque, int dc);
37
38
39typedef struct {
40 qemu_irq clk;
41 qemu_irq dat;
42 qemu_irq sel;
43} CBus;
44CBus *cbus_init(qemu_irq dat_out);
45void cbus_attach(CBus *bus, void *slave_opaque);
46
47void *retu_init(qemu_irq irq, int vilma);
48void *tahvo_init(qemu_irq irq, int betty);
49
50void retu_key_event(void *retu, int state);
51
52
53typedef struct TC6393xbState TC6393xbState;
54#define TC6393XB_RAM 0x110000
55TC6393xbState *tc6393xb_init(struct MemoryRegion *sysmem,
56 uint32_t base, qemu_irq irq);
57void tc6393xb_gpio_out_set(TC6393xbState *s, int line,
58 qemu_irq handler);
59qemu_irq *tc6393xb_gpio_in_get(TC6393xbState *s);
60qemu_irq tc6393xb_l3v_get(TC6393xbState *s);
61
62#endif
63