devices.h 2.1 KB

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