]> git.proxmox.com Git - qemu.git/blame - hw/devices.h
Follow coding conventions
[qemu.git] / hw / devices.h
CommitLineData
87ecb68b
PB
1#ifndef QEMU_DEVICES_H
2#define QEMU_DEVICES_H
3
4/* Devices that have nowhere better to go. */
5
6/* smc91c111.c */
7void smc91c111_init(NICInfo *, uint32_t, qemu_irq);
8
9/* ssd0323.c */
10int ssd0323_xfer_ssi(void *opaque, int data);
3023f332 11void *ssd0323_init(qemu_irq *cmd_p);
87ecb68b
PB
12
13/* ads7846.c */
bc24a225 14typedef struct ADS7846State ADS7846State;
87ecb68b
PB
15uint32_t ads7846_read(void *opaque);
16void ads7846_write(void *opaque, uint32_t value);
bc24a225 17ADS7846State *ads7846_init(qemu_irq penirq);
87ecb68b 18
a5d7eb65 19/* tsc210x.c */
bc24a225
PB
20uWireSlave *tsc2102_init(qemu_irq pint, AudioState *audio);
21uWireSlave *tsc2301_init(qemu_irq penirq, qemu_irq kbirq,
a5d7eb65 22 qemu_irq dav, AudioState *audio);
bc24a225 23I2SCodec *tsc210x_codec(uWireSlave *chip);
e927bb00 24uint32_t tsc210x_txrx(void *opaque, uint32_t value, int len);
bc24a225
PB
25void tsc210x_set_transform(uWireSlave *chip,
26 MouseTransformInfo *info);
27void tsc210x_key_event(uWireSlave *chip, int key, int down);
a5d7eb65 28
e927bb00
AZ
29/* tsc2005.c */
30void *tsc2005_init(qemu_irq pintdav);
31uint32_t tsc2005_txrx(void *opaque, uint32_t value, int len);
bc24a225 32void tsc2005_set_transform(void *opaque, MouseTransformInfo *info);
e927bb00 33
cf0dbb21
PB
34/* stellaris_input.c */
35void stellaris_gamepad_init(int n, qemu_irq *irq, const int *keycode);
36
7e7c5e4c 37/* blizzard.c */
3023f332 38void *s1d13745_init(qemu_irq gpio_int);
7e7c5e4c
AZ
39void s1d13745_write(void *opaque, int dc, uint16_t value);
40void s1d13745_write_block(void *opaque, int dc,
41 void *buf, size_t len, int pitch);
42uint16_t s1d13745_read(void *opaque, int dc);
43
44/* cbus.c */
bc24a225 45typedef struct {
7e7c5e4c
AZ
46 qemu_irq clk;
47 qemu_irq dat;
48 qemu_irq sel;
bc24a225
PB
49} CBus;
50CBus *cbus_init(qemu_irq dat_out);
51void cbus_attach(CBus *bus, void *slave_opaque);
7e7c5e4c
AZ
52
53void *retu_init(qemu_irq irq, int vilma);
54void *tahvo_init(qemu_irq irq, int betty);
55
56void retu_key_event(void *retu, int state);
57
942ac052 58/* tusb6010.c */
bc24a225
PB
59typedef struct TUSBState TUSBState;
60TUSBState *tusb6010_init(qemu_irq intr);
61int tusb6010_sync_io(TUSBState *s);
62int tusb6010_async_io(TUSBState *s);
63void tusb6010_power(TUSBState *s, int on);
942ac052 64
88d2c950 65/* tc6393xb.c */
bc24a225 66typedef struct TC6393xbState TC6393xbState;
64b40bc5 67#define TC6393XB_RAM 0x110000 /* amount of ram for Video and USB */
bc24a225
PB
68TC6393xbState *tc6393xb_init(uint32_t base, qemu_irq irq);
69void tc6393xb_gpio_out_set(TC6393xbState *s, int line,
88d2c950 70 qemu_irq handler);
bc24a225
PB
71qemu_irq *tc6393xb_gpio_in_get(TC6393xbState *s);
72qemu_irq tc6393xb_l3v_get(TC6393xbState *s);
88d2c950 73
ffd39257 74/* sm501.c */
ac611340
AJ
75void sm501_init(uint32_t base, uint32_t local_mem_bytes, qemu_irq irq,
76 CharDriverState *chr);
77
78/* usb-ohci.c */
79void usb_ohci_init_sm501(uint32_t mmio_base, uint32_t localmem_base,
80 int num_ports, int devfn, qemu_irq irq);
87ecb68b 81#endif