Home | History | Annotate | Download | only in hw
      1 #ifndef QEMU_DEVICES_H
      2 #define QEMU_DEVICES_H
      3 
      4 /* Devices that have nowhere better to go.  */
      5 
      6 /* smc91c111.c */
      7 void smc91c111_init(NICInfo *, uint32_t, qemu_irq);
      8 
      9 /* lan9118.c */
     10 void lan9118_init(NICInfo *, uint32_t, qemu_irq);
     11 
     12 /* tsc210x.c */
     13 uWireSlave *tsc2102_init(qemu_irq pint);
     14 uWireSlave *tsc2301_init(qemu_irq penirq, qemu_irq kbirq, qemu_irq dav);
     15 I2SCodec *tsc210x_codec(uWireSlave *chip);
     16 uint32_t tsc210x_txrx(void *opaque, uint32_t value, int len);
     17 void tsc210x_set_transform(uWireSlave *chip,
     18                 MouseTransformInfo *info);
     19 void tsc210x_key_event(uWireSlave *chip, int key, int down);
     20 
     21 /* tsc2005.c */
     22 void *tsc2005_init(qemu_irq pintdav);
     23 uint32_t tsc2005_txrx(void *opaque, uint32_t value, int len);
     24 void tsc2005_set_transform(void *opaque, MouseTransformInfo *info);
     25 
     26 /* stellaris_input.c */
     27 void stellaris_gamepad_init(int n, qemu_irq *irq, const int *keycode);
     28 
     29 /* blizzard.c */
     30 void *s1d13745_init(qemu_irq gpio_int);
     31 void s1d13745_write(void *opaque, int dc, uint16_t value);
     32 void s1d13745_write_block(void *opaque, int dc,
     33                 void *buf, size_t len, int pitch);
     34 uint16_t s1d13745_read(void *opaque, int dc);
     35 
     36 /* cbus.c */
     37 typedef struct {
     38     qemu_irq clk;
     39     qemu_irq dat;
     40     qemu_irq sel;
     41 } CBus;
     42 CBus *cbus_init(qemu_irq dat_out);
     43 void cbus_attach(CBus *bus, void *slave_opaque);
     44 
     45 void *retu_init(qemu_irq irq, int vilma);
     46 void *tahvo_init(qemu_irq irq, int betty);
     47 
     48 void retu_key_event(void *retu, int state);
     49 
     50 /* tusb6010.c */
     51 typedef struct TUSBState TUSBState;
     52 TUSBState *tusb6010_init(qemu_irq intr);
     53 int tusb6010_sync_io(TUSBState *s);
     54 int tusb6010_async_io(TUSBState *s);
     55 void tusb6010_power(TUSBState *s, int on);
     56 
     57 /* tc6393xb.c */
     58 typedef struct TC6393xbState TC6393xbState;
     59 #define TC6393XB_RAM	0x110000 /* amount of ram for Video and USB */
     60 TC6393xbState *tc6393xb_init(uint32_t base, qemu_irq irq);
     61 void tc6393xb_gpio_out_set(TC6393xbState *s, int line,
     62                     qemu_irq handler);
     63 qemu_irq *tc6393xb_gpio_in_get(TC6393xbState *s);
     64 qemu_irq tc6393xb_l3v_get(TC6393xbState *s);
     65 
     66 /* sm501.c */
     67 void sm501_init(uint32_t base, uint32_t local_mem_bytes, qemu_irq irq,
     68                 CharDriverState *chr);
     69 
     70 #endif
     71