~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/sound/usb/line6/driver.h

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /sound/usb/line6/driver.h (Version linux-6.12-rc7) and /sound/usb/line6/driver.h (Version linux-5.17.15)


  1 /* SPDX-License-Identifier: GPL-2.0-only */         1 /* SPDX-License-Identifier: GPL-2.0-only */
  2 /*                                                  2 /*
  3  * Line 6 Linux USB driver                          3  * Line 6 Linux USB driver
  4  *                                                  4  *
  5  * Copyright (C) 2004-2010 Markus Grabner (lin !!   5  * Copyright (C) 2004-2010 Markus Grabner (grabner@icg.tugraz.at)
  6  */                                                 6  */
  7                                                     7 
  8 #ifndef DRIVER_H                                    8 #ifndef DRIVER_H
  9 #define DRIVER_H                                    9 #define DRIVER_H
 10                                                    10 
 11 #include <linux/usb.h>                             11 #include <linux/usb.h>
 12 #include <linux/mutex.h>                           12 #include <linux/mutex.h>
 13 #include <linux/kfifo.h>                           13 #include <linux/kfifo.h>
 14 #include <sound/core.h>                            14 #include <sound/core.h>
 15                                                    15 
 16 #include "midi.h"                                  16 #include "midi.h"
 17                                                    17 
 18 /* USB 1.1 speed configuration */                  18 /* USB 1.1 speed configuration */
 19 #define USB_LOW_INTERVALS_PER_SECOND 1000          19 #define USB_LOW_INTERVALS_PER_SECOND 1000
 20 #define USB_LOW_ISO_BUFFERS 2                      20 #define USB_LOW_ISO_BUFFERS 2
 21                                                    21 
 22 /* USB 2.0+ speed configuration */                 22 /* USB 2.0+ speed configuration */
 23 #define USB_HIGH_INTERVALS_PER_SECOND 8000         23 #define USB_HIGH_INTERVALS_PER_SECOND 8000
 24 #define USB_HIGH_ISO_BUFFERS 16                    24 #define USB_HIGH_ISO_BUFFERS 16
 25                                                    25 
 26 /* Fallback USB interval and max packet size v     26 /* Fallback USB interval and max packet size values */
 27 #define LINE6_FALLBACK_INTERVAL 10                 27 #define LINE6_FALLBACK_INTERVAL 10
 28 #define LINE6_FALLBACK_MAXPACKETSIZE 16            28 #define LINE6_FALLBACK_MAXPACKETSIZE 16
 29                                                    29 
 30 #define LINE6_TIMEOUT 1000                         30 #define LINE6_TIMEOUT 1000
 31 #define LINE6_BUFSIZE_LISTEN 64                    31 #define LINE6_BUFSIZE_LISTEN 64
 32 #define LINE6_MIDI_MESSAGE_MAXLEN 256              32 #define LINE6_MIDI_MESSAGE_MAXLEN 256
 33                                                    33 
 34 #define LINE6_RAW_MESSAGES_MAXCOUNT_ORDER 7        34 #define LINE6_RAW_MESSAGES_MAXCOUNT_ORDER 7
 35 /* 4k packets are common, BUFSIZE * MAXCOUNT s     35 /* 4k packets are common, BUFSIZE * MAXCOUNT should be bigger... */
 36 #define LINE6_RAW_MESSAGES_MAXCOUNT (1 << LINE     36 #define LINE6_RAW_MESSAGES_MAXCOUNT (1 << LINE6_RAW_MESSAGES_MAXCOUNT_ORDER)
 37                                                    37 
 38                                                    38 
 39 #if LINE6_BUFSIZE_LISTEN > 65535                   39 #if LINE6_BUFSIZE_LISTEN > 65535
 40 #error "Use dynamic fifo instead"                  40 #error "Use dynamic fifo instead"
 41 #endif                                             41 #endif
 42                                                    42 
 43 /*                                                 43 /*
 44         Line 6 MIDI control commands               44         Line 6 MIDI control commands
 45 */                                                 45 */
 46 #define LINE6_PARAM_CHANGE   0xb0                  46 #define LINE6_PARAM_CHANGE   0xb0
 47 #define LINE6_PROGRAM_CHANGE 0xc0                  47 #define LINE6_PROGRAM_CHANGE 0xc0
 48 #define LINE6_SYSEX_BEGIN    0xf0                  48 #define LINE6_SYSEX_BEGIN    0xf0
 49 #define LINE6_SYSEX_END      0xf7                  49 #define LINE6_SYSEX_END      0xf7
 50 #define LINE6_RESET          0xff                  50 #define LINE6_RESET          0xff
 51                                                    51 
 52 /*                                                 52 /*
 53         MIDI channel for messages initiated by     53         MIDI channel for messages initiated by the host
 54         (and eventually echoed back by the dev     54         (and eventually echoed back by the device)
 55 */                                                 55 */
 56 #define LINE6_CHANNEL_HOST   0x00                  56 #define LINE6_CHANNEL_HOST   0x00
 57                                                    57 
 58 /*                                                 58 /*
 59         MIDI channel for messages initiated by     59         MIDI channel for messages initiated by the device
 60 */                                                 60 */
 61 #define LINE6_CHANNEL_DEVICE 0x02                  61 #define LINE6_CHANNEL_DEVICE 0x02
 62                                                    62 
 63 #define LINE6_CHANNEL_UNKNOWN 5 /* don't know      63 #define LINE6_CHANNEL_UNKNOWN 5 /* don't know yet what this is good for */
 64                                                    64 
 65 #define LINE6_CHANNEL_MASK 0x0f                    65 #define LINE6_CHANNEL_MASK 0x0f
 66                                                    66 
 67 extern const unsigned char line6_midi_id[3];       67 extern const unsigned char line6_midi_id[3];
 68                                                    68 
 69 #define SYSEX_DATA_OFS (sizeof(line6_midi_id)      69 #define SYSEX_DATA_OFS (sizeof(line6_midi_id) + 3)
 70 #define SYSEX_EXTRA_SIZE (sizeof(line6_midi_id     70 #define SYSEX_EXTRA_SIZE (sizeof(line6_midi_id) + 4)
 71                                                    71 
 72 /*                                                 72 /*
 73          Common properties of Line 6 devices.      73          Common properties of Line 6 devices.
 74 */                                                 74 */
 75 struct line6_properties {                          75 struct line6_properties {
 76         /* Card id string (maximum 16 characte     76         /* Card id string (maximum 16 characters).
 77          * This can be used to address the dev     77          * This can be used to address the device in ALSA programs as
 78          * "default:CARD=<id>"                     78          * "default:CARD=<id>"
 79          */                                        79          */
 80         const char *id;                            80         const char *id;
 81                                                    81 
 82         /* Card short name (maximum 32 charact     82         /* Card short name (maximum 32 characters) */
 83         const char *name;                          83         const char *name;
 84                                                    84 
 85         /* Bit vector defining this device's c     85         /* Bit vector defining this device's capabilities in line6usb driver */
 86         int capabilities;                          86         int capabilities;
 87                                                    87 
 88         int altsetting;                            88         int altsetting;
 89                                                    89 
 90         unsigned int ctrl_if;                      90         unsigned int ctrl_if;
 91         unsigned int ep_ctrl_r;                    91         unsigned int ep_ctrl_r;
 92         unsigned int ep_ctrl_w;                    92         unsigned int ep_ctrl_w;
 93         unsigned int ep_audio_r;                   93         unsigned int ep_audio_r;
 94         unsigned int ep_audio_w;                   94         unsigned int ep_audio_w;
 95 };                                                 95 };
 96                                                    96 
 97 /* Capability bits */                              97 /* Capability bits */
 98 enum {                                             98 enum {
 99         /* device supports settings parameter      99         /* device supports settings parameter via USB */
100         LINE6_CAP_CONTROL =     1 << 0,           100         LINE6_CAP_CONTROL =     1 << 0,
101         /* device supports PCM input/output vi    101         /* device supports PCM input/output via USB */
102         LINE6_CAP_PCM =         1 << 1,           102         LINE6_CAP_PCM =         1 << 1,
103         /* device supports hardware monitoring    103         /* device supports hardware monitoring */
104         LINE6_CAP_HWMON =       1 << 2,           104         LINE6_CAP_HWMON =       1 << 2,
105         /* device requires output data when in    105         /* device requires output data when input is read */
106         LINE6_CAP_IN_NEEDS_OUT = 1 << 3,          106         LINE6_CAP_IN_NEEDS_OUT = 1 << 3,
107         /* device uses raw MIDI via USB (data     107         /* device uses raw MIDI via USB (data endpoints) */
108         LINE6_CAP_CONTROL_MIDI = 1 << 4,          108         LINE6_CAP_CONTROL_MIDI = 1 << 4,
109         /* device provides low-level informati    109         /* device provides low-level information */
110         LINE6_CAP_CONTROL_INFO = 1 << 5,          110         LINE6_CAP_CONTROL_INFO = 1 << 5,
111         /* device provides hardware monitoring    111         /* device provides hardware monitoring volume control */
112         LINE6_CAP_HWMON_CTL =   1 << 6,           112         LINE6_CAP_HWMON_CTL =   1 << 6,
113 };                                                113 };
114                                                   114 
115 /*                                                115 /*
116          Common data shared by all Line 6 devi    116          Common data shared by all Line 6 devices.
117          Corresponds to a pair of USB endpoint    117          Corresponds to a pair of USB endpoints.
118 */                                                118 */
119 struct usb_line6 {                                119 struct usb_line6 {
120         /* USB device */                          120         /* USB device */
121         struct usb_device *usbdev;                121         struct usb_device *usbdev;
122                                                   122 
123         /* Properties */                          123         /* Properties */
124         const struct line6_properties *propert    124         const struct line6_properties *properties;
125                                                   125 
126         /* Interval for data USB packets */       126         /* Interval for data USB packets */
127         int interval;                             127         int interval;
128         /* ...for isochronous transfers framin    128         /* ...for isochronous transfers framing */
129         int intervals_per_second;                 129         int intervals_per_second;
130                                                   130 
131         /* Number of isochronous URBs used for    131         /* Number of isochronous URBs used for frame transfers */
132         int iso_buffers;                          132         int iso_buffers;
133                                                   133 
134         /* Maximum size of data USB packet */     134         /* Maximum size of data USB packet */
135         int max_packet_size;                      135         int max_packet_size;
136                                                   136 
137         /* Device representing the USB interfa    137         /* Device representing the USB interface */
138         struct device *ifcdev;                    138         struct device *ifcdev;
139                                                   139 
140         /* Line 6 sound card data structure.      140         /* Line 6 sound card data structure.
141          * Each device has at least MIDI or PC    141          * Each device has at least MIDI or PCM.
142          */                                       142          */
143         struct snd_card *card;                    143         struct snd_card *card;
144                                                   144 
145         /* Line 6 PCM device data structure */    145         /* Line 6 PCM device data structure */
146         struct snd_line6_pcm *line6pcm;           146         struct snd_line6_pcm *line6pcm;
147                                                   147 
148         /* Line 6 MIDI device data structure *    148         /* Line 6 MIDI device data structure */
149         struct snd_line6_midi *line6midi;         149         struct snd_line6_midi *line6midi;
150                                                   150 
151         /* URB for listening to POD data endpo    151         /* URB for listening to POD data endpoint */
152         struct urb *urb_listen;                   152         struct urb *urb_listen;
153                                                   153 
154         /* Buffer for incoming data from POD d    154         /* Buffer for incoming data from POD data endpoint */
155         unsigned char *buffer_listen;             155         unsigned char *buffer_listen;
156                                                   156 
157         /* Buffer for message to be processed,    157         /* Buffer for message to be processed, generated from MIDI layer */
158         unsigned char *buffer_message;            158         unsigned char *buffer_message;
159                                                   159 
160         /* Length of message to be processed,     160         /* Length of message to be processed, generated from MIDI layer  */
161         int message_length;                       161         int message_length;
162                                                   162 
163         /* Circular buffer for non-MIDI contro    163         /* Circular buffer for non-MIDI control messages */
164         struct {                                  164         struct {
165                 struct mutex read_lock;           165                 struct mutex read_lock;
166                 wait_queue_head_t wait_queue;     166                 wait_queue_head_t wait_queue;
167                 unsigned int active:1;            167                 unsigned int active:1;
168                 unsigned int nonblock:1;          168                 unsigned int nonblock:1;
169                 STRUCT_KFIFO_REC_2(LINE6_BUFSI    169                 STRUCT_KFIFO_REC_2(LINE6_BUFSIZE_LISTEN * LINE6_RAW_MESSAGES_MAXCOUNT)
170                         fifo;                     170                         fifo;
171         } messages;                               171         } messages;
172                                                   172 
173         /* Work for delayed PCM startup */        173         /* Work for delayed PCM startup */
174         struct delayed_work startup_work;         174         struct delayed_work startup_work;
175                                                   175 
176         /* If MIDI is supported, buffer_messag    176         /* If MIDI is supported, buffer_message contains the pre-processed data;
177          * otherwise the data is only in urb_l    177          * otherwise the data is only in urb_listen (buffer_incoming).
178          */                                       178          */
179         void (*process_message)(struct usb_lin    179         void (*process_message)(struct usb_line6 *);
180         void (*disconnect)(struct usb_line6 *l    180         void (*disconnect)(struct usb_line6 *line6);
181         void (*startup)(struct usb_line6 *line    181         void (*startup)(struct usb_line6 *line6);
182 };                                                182 };
183                                                   183 
184 extern char *line6_alloc_sysex_buffer(struct u    184 extern char *line6_alloc_sysex_buffer(struct usb_line6 *line6, int code1,
185                                       int code    185                                       int code2, int size);
186 extern int line6_read_data(struct usb_line6 *l    186 extern int line6_read_data(struct usb_line6 *line6, unsigned address,
187                            void *data, unsigne    187                            void *data, unsigned datalen);
188 extern int line6_read_serial_number(struct usb    188 extern int line6_read_serial_number(struct usb_line6 *line6,
189                                     u32 *seria    189                                     u32 *serial_number);
190 extern int line6_send_raw_message(struct usb_l    190 extern int line6_send_raw_message(struct usb_line6 *line6,
191                                         const     191                                         const char *buffer, int size);
192 extern int line6_send_raw_message_async(struct    192 extern int line6_send_raw_message_async(struct usb_line6 *line6,
193                                         const     193                                         const char *buffer, int size);
194 extern int line6_send_sysex_message(struct usb    194 extern int line6_send_sysex_message(struct usb_line6 *line6,
195                                     const char    195                                     const char *buffer, int size);
                                                   >> 196 extern ssize_t line6_set_raw(struct device *dev, struct device_attribute *attr,
                                                   >> 197                              const char *buf, size_t count);
196 extern int line6_version_request_async(struct     198 extern int line6_version_request_async(struct usb_line6 *line6);
197 extern int line6_write_data(struct usb_line6 *    199 extern int line6_write_data(struct usb_line6 *line6, unsigned address,
198                             void *data, unsign    200                             void *data, unsigned datalen);
199                                                   201 
200 int line6_probe(struct usb_interface *interfac    202 int line6_probe(struct usb_interface *interface,
201                 const struct usb_device_id *id    203                 const struct usb_device_id *id,
202                 const char *driver_name,          204                 const char *driver_name,
203                 const struct line6_properties     205                 const struct line6_properties *properties,
204                 int (*private_init)(struct usb    206                 int (*private_init)(struct usb_line6 *, const struct usb_device_id *id),
205                 size_t data_size);                207                 size_t data_size);
206                                                   208 
207 void line6_disconnect(struct usb_interface *in    209 void line6_disconnect(struct usb_interface *interface);
208                                                   210 
209 #ifdef CONFIG_PM                                  211 #ifdef CONFIG_PM
210 int line6_suspend(struct usb_interface *interf    212 int line6_suspend(struct usb_interface *interface, pm_message_t message);
211 int line6_resume(struct usb_interface *interfa    213 int line6_resume(struct usb_interface *interface);
212 #endif                                            214 #endif
213                                                   215 
214 #endif                                            216 #endif
215                                                   217 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php