cdc-acm.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. /*
  2. *
  3. * Includes for cdc-acm.c
  4. *
  5. * Mainly take from usbnet's cdc-ether part
  6. *
  7. */
  8. /*
  9. * CMSPAR, some architectures can't have space and mark parity.
  10. */
  11. #ifndef CMSPAR
  12. #define CMSPAR 0
  13. #endif
  14. /*
  15. * Major and minor numbers.
  16. */
  17. #define ACM_TTY_MAJOR 166
  18. #define ACM_TTY_MINORS 32
  19. /*
  20. * Requests.
  21. */
  22. #define USB_RT_ACM (USB_TYPE_CLASS | USB_RECIP_INTERFACE)
  23. /*
  24. * Output control lines.
  25. */
  26. #define ACM_CTRL_DTR 0x01
  27. #define ACM_CTRL_RTS 0x02
  28. /*
  29. * Input control lines and line errors.
  30. */
  31. #define ACM_CTRL_DCD 0x01
  32. #define ACM_CTRL_DSR 0x02
  33. #define ACM_CTRL_BRK 0x04
  34. #define ACM_CTRL_RI 0x08
  35. #define ACM_CTRL_FRAMING 0x10
  36. #define ACM_CTRL_PARITY 0x20
  37. #define ACM_CTRL_OVERRUN 0x40
  38. /*
  39. * Internal driver structures.
  40. */
  41. /*
  42. * The only reason to have several buffers is to accommodate assumptions
  43. * in line disciplines. They ask for empty space amount, receive our URB size,
  44. * and proceed to issue several 1-character writes, assuming they will fit.
  45. * The very first write takes a complete URB. Fortunately, this only happens
  46. * when processing onlcr, so we only need 2 buffers. These values must be
  47. * powers of 2.
  48. */
  49. #define ACM_NW 16
  50. #define ACM_NR 16
  51. struct acm_wb {
  52. unsigned char *buf;
  53. dma_addr_t dmah;
  54. int len;
  55. int use;
  56. struct urb *urb;
  57. struct acm *instance;
  58. };
  59. struct acm_rb {
  60. int size;
  61. unsigned char *base;
  62. dma_addr_t dma;
  63. int index;
  64. struct acm *instance;
  65. };
  66. struct acm {
  67. struct usb_device *dev; /* the corresponding usb device */
  68. struct usb_interface *control; /* control interface */
  69. struct usb_interface *data; /* data interface */
  70. struct tty_port port; /* our tty port data */
  71. struct urb *ctrlurb; /* urbs */
  72. u8 *ctrl_buffer; /* buffers of urbs */
  73. dma_addr_t ctrl_dma; /* dma handles of buffers */
  74. u8 *country_codes; /* country codes from device */
  75. unsigned int country_code_size; /* size of this buffer */
  76. unsigned int country_rel_date; /* release date of version */
  77. struct acm_wb wb[ACM_NW];
  78. unsigned long read_urbs_free;
  79. struct urb *read_urbs[ACM_NR];
  80. struct acm_rb read_buffers[ACM_NR];
  81. int rx_buflimit;
  82. int rx_endpoint;
  83. spinlock_t read_lock;
  84. int write_used; /* number of non-empty write buffers */
  85. int transmitting;
  86. spinlock_t write_lock;
  87. struct mutex mutex;
  88. bool disconnected;
  89. struct usb_cdc_line_coding line; /* bits, stop, parity */
  90. struct work_struct work; /* work queue entry for line discipline waking up */
  91. unsigned int ctrlin; /* input control lines (DCD, DSR, RI, break, overruns) */
  92. unsigned int ctrlout; /* output control lines (DTR, RTS) */
  93. unsigned int writesize; /* max packet size for the output bulk endpoint */
  94. unsigned int readsize,ctrlsize; /* buffer sizes for freeing */
  95. unsigned int minor; /* acm minor number */
  96. unsigned char clocal; /* termios CLOCAL */
  97. unsigned int ctrl_caps; /* control capabilities from the class specific header */
  98. unsigned int susp_count; /* number of suspended interfaces */
  99. unsigned int combined_interfaces:1; /* control and data collapsed */
  100. unsigned int is_int_ep:1; /* interrupt endpoints contrary to spec used */
  101. unsigned int throttled:1; /* actually throttled */
  102. unsigned int throttle_req:1; /* throttle requested */
  103. u8 bInterval;
  104. struct usb_anchor delayed; /* writes queued for a device about to be woken */
  105. };
  106. #define CDC_DATA_INTERFACE_TYPE 0x0a
  107. /* constants describing various quirks and errors */
  108. #define NO_UNION_NORMAL 1
  109. #define SINGLE_RX_URB 2
  110. #define NO_CAP_LINE 4
  111. #define NOT_A_MODEM 8
  112. #define NO_DATA_INTERFACE 16