1b2441318SGreg Kroah-Hartman /* SPDX-License-Identifier: GPL-2.0 */ 21da177e4SLinus Torvalds /* 31da177e4SLinus Torvalds * 41da177e4SLinus Torvalds * Includes for cdc-acm.c 51da177e4SLinus Torvalds * 61da177e4SLinus Torvalds * Mainly take from usbnet's cdc-ether part 71da177e4SLinus Torvalds * 81da177e4SLinus Torvalds */ 91da177e4SLinus Torvalds 101da177e4SLinus Torvalds /* 111da177e4SLinus Torvalds * Major and minor numbers. 121da177e4SLinus Torvalds */ 131da177e4SLinus Torvalds 141da177e4SLinus Torvalds #define ACM_TTY_MAJOR 166 1565c35dd5SJohan Hovold #define ACM_TTY_MINORS 256 161da177e4SLinus Torvalds 17*91fac074SJohan Hovold #define ACM_MINOR_INVALID ACM_TTY_MINORS 18*91fac074SJohan Hovold 191da177e4SLinus Torvalds /* 201da177e4SLinus Torvalds * Requests. 211da177e4SLinus Torvalds */ 221da177e4SLinus Torvalds 231da177e4SLinus Torvalds #define USB_RT_ACM (USB_TYPE_CLASS | USB_RECIP_INTERFACE) 241da177e4SLinus Torvalds 251da177e4SLinus Torvalds /* 261da177e4SLinus Torvalds * Internal driver structures. 271da177e4SLinus Torvalds */ 281da177e4SLinus Torvalds 29884b600fSOliver Neukum /* 3025985edcSLucas De Marchi * The only reason to have several buffers is to accommodate assumptions 31884b600fSOliver Neukum * in line disciplines. They ask for empty space amount, receive our URB size, 32884b600fSOliver Neukum * and proceed to issue several 1-character writes, assuming they will fit. 33884b600fSOliver Neukum * The very first write takes a complete URB. Fortunately, this only happens 3486478944SOliver Neukum * when processing onlcr, so we only need 2 buffers. These values must be 3586478944SOliver Neukum * powers of 2. 36884b600fSOliver Neukum */ 37e4cf3aa8SDavid Engraf #define ACM_NW 16 3886478944SOliver Neukum #define ACM_NR 16 3961a87adfSDavid Kubicek 40884b600fSOliver Neukum struct acm_wb { 4137329036SOliver Neukum u8 *buf; 42884b600fSOliver Neukum dma_addr_t dmah; 4337329036SOliver Neukum unsigned int len; 44e4cf3aa8SDavid Engraf struct urb *urb; 45e4cf3aa8SDavid Engraf struct acm *instance; 4637329036SOliver Neukum bool use; 47884b600fSOliver Neukum }; 48884b600fSOliver Neukum 4961a87adfSDavid Kubicek struct acm_rb { 5061a87adfSDavid Kubicek int size; 5161a87adfSDavid Kubicek unsigned char *base; 5261a87adfSDavid Kubicek dma_addr_t dma; 53088c64f8SJohan Hovold int index; 5461a87adfSDavid Kubicek struct acm *instance; 5561a87adfSDavid Kubicek }; 5661a87adfSDavid Kubicek 571da177e4SLinus Torvalds struct acm { 581da177e4SLinus Torvalds struct usb_device *dev; /* the corresponding usb device */ 591da177e4SLinus Torvalds struct usb_interface *control; /* control interface */ 601da177e4SLinus Torvalds struct usb_interface *data; /* data interface */ 6174bccc9bSLadislav Michl unsigned in, out; /* i/o pipes */ 62739e0285SAlan Cox struct tty_port port; /* our tty port data */ 63e4cf3aa8SDavid Engraf struct urb *ctrlurb; /* urbs */ 6461a87adfSDavid Kubicek u8 *ctrl_buffer; /* buffers of urbs */ 6561a87adfSDavid Kubicek dma_addr_t ctrl_dma; /* dma handles of buffers */ 66c4cabd28SOliver Neukum u8 *country_codes; /* country codes from device */ 67c4cabd28SOliver Neukum unsigned int country_code_size; /* size of this buffer */ 68c4cabd28SOliver Neukum unsigned int country_rel_date; /* release date of version */ 6986478944SOliver Neukum struct acm_wb wb[ACM_NW]; 70088c64f8SJohan Hovold unsigned long read_urbs_free; 71088c64f8SJohan Hovold struct urb *read_urbs[ACM_NR]; 72088c64f8SJohan Hovold struct acm_rb read_buffers[ACM_NR]; 7386478944SOliver Neukum int rx_buflimit; 7461a87adfSDavid Kubicek spinlock_t read_lock; 75ea258352STobias Herzog u8 *notification_buffer; /* to reassemble fragmented notifications */ 76ea258352STobias Herzog unsigned int nb_index; 77ea258352STobias Herzog unsigned int nb_size; 7811ea859dSOliver Neukum int transmitting; 79884b600fSOliver Neukum spinlock_t write_lock; 801365baf7SOliver Neukum struct mutex mutex; 817fb57a01SHavard Skinnemoen bool disconnected; 821aba579fSLadislav Michl unsigned long flags; 831aba579fSLadislav Michl # define EVENT_TTY_WAKEUP 0 841aba579fSLadislav Michl # define EVENT_RX_STALL 1 850f02321eSJohan Hovold # define ACM_THROTTLED 2 86a4e7279cSOliver Neukum # define ACM_ERROR_DELAY 3 87a4e7279cSOliver Neukum unsigned long urbs_in_error_delay; /* these need to be restarted after a delay */ 881da177e4SLinus Torvalds struct usb_cdc_line_coding line; /* bits, stop, parity */ 8938203b83SJerome Brunet struct delayed_work dwork; /* work queue entry for various purposes */ 901da177e4SLinus Torvalds unsigned int ctrlin; /* input control lines (DCD, DSR, RI, break, overruns) */ 911da177e4SLinus Torvalds unsigned int ctrlout; /* output control lines (DTR, RTS) */ 925a6a62bdSOliver Neukum struct async_icount iocount; /* counters for control line changes */ 935a6a62bdSOliver Neukum struct async_icount oldcount; /* for comparison of counter */ 945a6a62bdSOliver Neukum wait_queue_head_t wioctl; /* for ioctl */ 951da177e4SLinus Torvalds unsigned int writesize; /* max packet size for the output bulk endpoint */ 961da177e4SLinus Torvalds unsigned int readsize,ctrlsize; /* buffer sizes for freeing */ 971da177e4SLinus Torvalds unsigned int minor; /* acm minor number */ 981da177e4SLinus Torvalds unsigned char clocal; /* termios CLOCAL */ 991da177e4SLinus Torvalds unsigned int ctrl_caps; /* control capabilities from the class specific header */ 1001365baf7SOliver Neukum unsigned int susp_count; /* number of suspended interfaces */ 101fa4dc364SRandy Dunlap unsigned int combined_interfaces:1; /* control and data collapsed */ 102cf7fdd57SOliver Neukum u8 bInterval; 103140cb81aSJohan Hovold struct usb_anchor delayed; /* writes queued for a device about to be woken */ 1042a8cdfdeSJohan Hovold unsigned long quirks; 1051da177e4SLinus Torvalds }; 1061da177e4SLinus Torvalds 1071da177e4SLinus Torvalds /* constants describing various quirks and errors */ 108d1b78100SOliver Neukum #define NO_UNION_NORMAL BIT(0) 109d1b78100SOliver Neukum #define SINGLE_RX_URB BIT(1) 110d1b78100SOliver Neukum #define NO_CAP_LINE BIT(2) 111bf1c6744SJohan Hovold #define IGNORE_DEVICE BIT(3) 112bf1c6744SJohan Hovold #define QUIRK_CONTROL_LINE_STATE BIT(4) 113bf1c6744SJohan Hovold #define CLEAR_HALT_CONDITIONS BIT(5) 114bf1c6744SJohan Hovold #define SEND_ZERO_PACKET BIT(6) 115bf1c6744SJohan Hovold #define DISABLE_ECHO BIT(7) 116