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 1 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 static const int SYSEX_DATA_OFS = sizeof(line6_midi_id) + 3; 70 #define SYSEX_EXTRA_SIZE (sizeof(line6_midi_id !! 70 static const int 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 << 112 LINE6_CAP_HWMON_CTL = 1 << 6, << 113 }; 111 }; 114 112 115 /* 113 /* 116 Common data shared by all Line 6 devi 114 Common data shared by all Line 6 devices. 117 Corresponds to a pair of USB endpoint 115 Corresponds to a pair of USB endpoints. 118 */ 116 */ 119 struct usb_line6 { 117 struct usb_line6 { 120 /* USB device */ 118 /* USB device */ 121 struct usb_device *usbdev; 119 struct usb_device *usbdev; 122 120 123 /* Properties */ 121 /* Properties */ 124 const struct line6_properties *propert 122 const struct line6_properties *properties; 125 123 126 /* Interval for data USB packets */ 124 /* Interval for data USB packets */ 127 int interval; 125 int interval; 128 /* ...for isochronous transfers framin 126 /* ...for isochronous transfers framing */ 129 int intervals_per_second; 127 int intervals_per_second; 130 128 131 /* Number of isochronous URBs used for 129 /* Number of isochronous URBs used for frame transfers */ 132 int iso_buffers; 130 int iso_buffers; 133 131 134 /* Maximum size of data USB packet */ 132 /* Maximum size of data USB packet */ 135 int max_packet_size; 133 int max_packet_size; 136 134 137 /* Device representing the USB interfa 135 /* Device representing the USB interface */ 138 struct device *ifcdev; 136 struct device *ifcdev; 139 137 140 /* Line 6 sound card data structure. 138 /* Line 6 sound card data structure. 141 * Each device has at least MIDI or PC 139 * Each device has at least MIDI or PCM. 142 */ 140 */ 143 struct snd_card *card; 141 struct snd_card *card; 144 142 145 /* Line 6 PCM device data structure */ 143 /* Line 6 PCM device data structure */ 146 struct snd_line6_pcm *line6pcm; 144 struct snd_line6_pcm *line6pcm; 147 145 148 /* Line 6 MIDI device data structure * 146 /* Line 6 MIDI device data structure */ 149 struct snd_line6_midi *line6midi; 147 struct snd_line6_midi *line6midi; 150 148 151 /* URB for listening to POD data endpo 149 /* URB for listening to POD data endpoint */ 152 struct urb *urb_listen; 150 struct urb *urb_listen; 153 151 154 /* Buffer for incoming data from POD d 152 /* Buffer for incoming data from POD data endpoint */ 155 unsigned char *buffer_listen; 153 unsigned char *buffer_listen; 156 154 157 /* Buffer for message to be processed, 155 /* Buffer for message to be processed, generated from MIDI layer */ 158 unsigned char *buffer_message; 156 unsigned char *buffer_message; 159 157 160 /* Length of message to be processed, 158 /* Length of message to be processed, generated from MIDI layer */ 161 int message_length; 159 int message_length; 162 160 163 /* Circular buffer for non-MIDI contro 161 /* Circular buffer for non-MIDI control messages */ 164 struct { 162 struct { 165 struct mutex read_lock; 163 struct mutex read_lock; 166 wait_queue_head_t wait_queue; 164 wait_queue_head_t wait_queue; 167 unsigned int active:1; 165 unsigned int active:1; 168 unsigned int nonblock:1; << 169 STRUCT_KFIFO_REC_2(LINE6_BUFSI 166 STRUCT_KFIFO_REC_2(LINE6_BUFSIZE_LISTEN * LINE6_RAW_MESSAGES_MAXCOUNT) 170 fifo; 167 fifo; 171 } messages; 168 } messages; 172 169 173 /* Work for delayed PCM startup */ 170 /* Work for delayed PCM startup */ 174 struct delayed_work startup_work; 171 struct delayed_work startup_work; 175 172 176 /* If MIDI is supported, buffer_messag 173 /* If MIDI is supported, buffer_message contains the pre-processed data; 177 * otherwise the data is only in urb_l 174 * otherwise the data is only in urb_listen (buffer_incoming). 178 */ 175 */ 179 void (*process_message)(struct usb_lin 176 void (*process_message)(struct usb_line6 *); 180 void (*disconnect)(struct usb_line6 *l 177 void (*disconnect)(struct usb_line6 *line6); 181 void (*startup)(struct usb_line6 *line 178 void (*startup)(struct usb_line6 *line6); 182 }; 179 }; 183 180 184 extern char *line6_alloc_sysex_buffer(struct u 181 extern char *line6_alloc_sysex_buffer(struct usb_line6 *line6, int code1, 185 int code 182 int code2, int size); 186 extern int line6_read_data(struct usb_line6 *l 183 extern int line6_read_data(struct usb_line6 *line6, unsigned address, 187 void *data, unsigne 184 void *data, unsigned datalen); 188 extern int line6_read_serial_number(struct usb 185 extern int line6_read_serial_number(struct usb_line6 *line6, 189 u32 *seria 186 u32 *serial_number); 190 extern int line6_send_raw_message(struct usb_l << 191 const << 192 extern int line6_send_raw_message_async(struct 187 extern int line6_send_raw_message_async(struct usb_line6 *line6, 193 const 188 const char *buffer, int size); 194 extern int line6_send_sysex_message(struct usb 189 extern int line6_send_sysex_message(struct usb_line6 *line6, 195 const char 190 const char *buffer, int size); >> 191 extern ssize_t line6_set_raw(struct device *dev, struct device_attribute *attr, >> 192 const char *buf, size_t count); 196 extern int line6_version_request_async(struct 193 extern int line6_version_request_async(struct usb_line6 *line6); 197 extern int line6_write_data(struct usb_line6 * 194 extern int line6_write_data(struct usb_line6 *line6, unsigned address, 198 void *data, unsign 195 void *data, unsigned datalen); 199 196 200 int line6_probe(struct usb_interface *interfac 197 int line6_probe(struct usb_interface *interface, 201 const struct usb_device_id *id 198 const struct usb_device_id *id, 202 const char *driver_name, 199 const char *driver_name, 203 const struct line6_properties 200 const struct line6_properties *properties, 204 int (*private_init)(struct usb 201 int (*private_init)(struct usb_line6 *, const struct usb_device_id *id), 205 size_t data_size); 202 size_t data_size); 206 203 207 void line6_disconnect(struct usb_interface *in 204 void line6_disconnect(struct usb_interface *interface); 208 205 209 #ifdef CONFIG_PM 206 #ifdef CONFIG_PM 210 int line6_suspend(struct usb_interface *interf 207 int line6_suspend(struct usb_interface *interface, pm_message_t message); 211 int line6_resume(struct usb_interface *interfa 208 int line6_resume(struct usb_interface *interface); 212 #endif 209 #endif 213 210 214 #endif 211 #endif 215 212
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.