1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3 * f_midi2.c -- USB MIDI 2.0 class function driver
4 */
5
6 #include <linux/device.h>
7 #include <linux/kernel.h>
8 #include <linux/module.h>
9 #include <linux/slab.h>
10
11 #include <sound/core.h>
12 #include <sound/control.h>
13 #include <sound/ump.h>
14 #include <sound/ump_msg.h>
15 #include <sound/ump_convert.h>
16
17 #include <linux/usb/ch9.h>
18 #include <linux/usb/func_utils.h>
19 #include <linux/usb/gadget.h>
20 #include <linux/usb/audio.h>
21 #include <linux/usb/midi-v2.h>
22
23 #include "u_midi2.h"
24
25 struct f_midi2;
26 struct f_midi2_ep;
27 struct f_midi2_usb_ep;
28
29 /* Context for each USB request */
30 struct f_midi2_req_ctx {
31 struct f_midi2_usb_ep *usb_ep; /* belonging USB EP */
32 unsigned int index; /* array index: 0-31 */
33 struct usb_request *req; /* assigned request */
34 };
35
36 /* Resources for a USB Endpoint */
37 struct f_midi2_usb_ep {
38 struct f_midi2 *card; /* belonging card */
39 struct f_midi2_ep *ep; /* belonging UMP EP (optional) */
40 struct usb_ep *usb_ep; /* assigned USB EP */
41 void (*complete)(struct usb_ep *usb_ep, struct usb_request *req);
42 unsigned long free_reqs; /* bitmap for unused requests */
43 unsigned int num_reqs; /* number of allocated requests */
44 struct f_midi2_req_ctx *reqs; /* request context array */
45 };
46
47 /* Resources for UMP Function Block (and USB Group Terminal Block) */
48 struct f_midi2_block {
49 struct f_midi2_block_info info; /* FB info, copied from configfs */
50 struct snd_ump_block *fb; /* assigned FB */
51 unsigned int gtb_id; /* assigned GTB id */
52 unsigned int string_id; /* assigned string id */
53 };
54
55 /* Temporary buffer for altset 0 MIDI 1.0 handling */
56 struct f_midi2_midi1_port {
57 unsigned int pending; /* pending bytes on the input buffer */
58 u8 buf[32]; /* raw MIDI 1.0 byte input */
59 u8 state; /* running status */
60 u8 data[2]; /* rendered USB MIDI 1.0 packet data */
61 };
62
63 /* MIDI 1.0 message states */
64 enum {
65 STATE_INITIAL = 0, /* pseudo state */
66 STATE_1PARAM,
67 STATE_2PARAM_1,
68 STATE_2PARAM_2,
69 STATE_SYSEX_0,
70 STATE_SYSEX_1,
71 STATE_SYSEX_2,
72 STATE_REAL_TIME,
73 STATE_FINISHED, /* pseudo state */
74 };
75
76 /* Resources for UMP Endpoint */
77 struct f_midi2_ep {
78 struct snd_ump_endpoint *ump; /* assigned UMP EP */
79 struct f_midi2 *card; /* belonging MIDI 2.0 device */
80
81 struct f_midi2_ep_info info; /* UMP EP info, copied from configfs */
82 unsigned int num_blks; /* number of FBs */
83 struct f_midi2_block blks[SNDRV_UMP_MAX_BLOCKS]; /* UMP FBs */
84
85 struct f_midi2_usb_ep ep_in; /* USB MIDI EP-in */
86 struct f_midi2_usb_ep ep_out; /* USB MIDI EP-out */
87
88 u8 in_group_to_cable[SNDRV_UMP_MAX_GROUPS]; /* map to cable; 1-based! */
89 };
90
91 /* indices for USB strings */
92 enum {
93 STR_IFACE = 0,
94 STR_GTB1 = 1,
95 };
96
97 /* 1-based GTB id to string id */
98 #define gtb_to_str_id(id) (STR_GTB1 + (id) - 1)
99
100 /* mapping from MIDI 1.0 cable to UMP group */
101 struct midi1_cable_mapping {
102 struct f_midi2_ep *ep;
103 unsigned char block;
104 unsigned char group;
105 };
106
107 /* operation mode */
108 enum {
109 MIDI_OP_MODE_UNSET, /* no altset set yet */
110 MIDI_OP_MODE_MIDI1, /* MIDI 1.0 (altset 0) is used */
111 MIDI_OP_MODE_MIDI2, /* MIDI 2.0 (altset 1) is used */
112 };
113
114 /* Resources for MIDI 2.0 Device */
115 struct f_midi2 {
116 struct usb_function func;
117 struct usb_gadget *gadget;
118 struct snd_card *card;
119
120 /* MIDI 1.0 in/out USB EPs */
121 struct f_midi2_usb_ep midi1_ep_in;
122 struct f_midi2_usb_ep midi1_ep_out;
123
124 /* number of MIDI 1.0 I/O cables */
125 unsigned int num_midi1_in;
126 unsigned int num_midi1_out;
127
128 /* conversion for MIDI 1.0 EP-in */
129 struct f_midi2_midi1_port midi1_port[MAX_CABLES];
130 /* conversion for MIDI 1.0 EP-out */
131 struct ump_cvt_to_ump midi1_ump_cvt;
132 /* mapping between cables and UMP groups */
133 struct midi1_cable_mapping in_cable_mapping[MAX_CABLES];
134 struct midi1_cable_mapping out_cable_mapping[MAX_CABLES];
135
136 int midi_if; /* USB MIDI interface number */
137 int operation_mode; /* current operation mode */
138
139 spinlock_t queue_lock;
140
141 struct f_midi2_card_info info; /* card info, copied from configfs */
142
143 unsigned int num_eps;
144 struct f_midi2_ep midi2_eps[MAX_UMP_EPS];
145
146 unsigned int total_blocks; /* total number of blocks of all EPs */
147 struct usb_string *string_defs;
148 struct usb_string *strings;
149 };
150
151 #define func_to_midi2(f) container_of(f, struct f_midi2, func)
152
153 /* convert from MIDI protocol number (1 or 2) to SNDRV_UMP_EP_INFO_PROTO_* */
154 #define to_ump_protocol(v) (((v) & 3) << 8)
155
156 /* get EP name string */
ump_ep_name(const struct f_midi2_ep * ep)157 static const char *ump_ep_name(const struct f_midi2_ep *ep)
158 {
159 return ep->info.ep_name ? ep->info.ep_name : "MIDI 2.0 Gadget";
160 }
161
162 /* get EP product ID string */
ump_product_id(const struct f_midi2_ep * ep)163 static const char *ump_product_id(const struct f_midi2_ep *ep)
164 {
165 return ep->info.product_id ? ep->info.product_id : "Unique Product ID";
166 }
167
168 /* get FB name string */
ump_fb_name(const struct f_midi2_block_info * info)169 static const char *ump_fb_name(const struct f_midi2_block_info *info)
170 {
171 return info->name ? info->name : "MIDI 2.0 Gadget I/O";
172 }
173
174 /*
175 * USB Descriptor Definitions
176 */
177 /* GTB header descriptor */
178 static struct usb_ms20_gr_trm_block_header_descriptor gtb_header_desc = {
179 .bLength = sizeof(gtb_header_desc),
180 .bDescriptorType = USB_DT_CS_GR_TRM_BLOCK,
181 .bDescriptorSubtype = USB_MS_GR_TRM_BLOCK_HEADER,
182 .wTotalLength = __cpu_to_le16(0x12), // to be filled
183 };
184
185 /* GTB descriptor template: most items are replaced dynamically */
186 static struct usb_ms20_gr_trm_block_descriptor gtb_desc = {
187 .bLength = sizeof(gtb_desc),
188 .bDescriptorType = USB_DT_CS_GR_TRM_BLOCK,
189 .bDescriptorSubtype = USB_MS_GR_TRM_BLOCK,
190 .bGrpTrmBlkID = 0x01,
191 .bGrpTrmBlkType = USB_MS_GR_TRM_BLOCK_TYPE_BIDIRECTIONAL,
192 .nGroupTrm = 0x00,
193 .nNumGroupTrm = 1,
194 .iBlockItem = 0,
195 .bMIDIProtocol = USB_MS_MIDI_PROTO_1_0_64,
196 .wMaxInputBandwidth = 0,
197 .wMaxOutputBandwidth = 0,
198 };
199
200 DECLARE_USB_MIDI_OUT_JACK_DESCRIPTOR(1);
201 DECLARE_USB_MS_ENDPOINT_DESCRIPTOR(16);
202 DECLARE_UAC_AC_HEADER_DESCRIPTOR(1);
203 DECLARE_USB_MS20_ENDPOINT_DESCRIPTOR(32);
204
205 #define EP_MAX_PACKET_INT 8
206
207 /* Audio Control Interface */
208 static struct usb_interface_descriptor midi2_audio_if_desc = {
209 .bLength = USB_DT_INTERFACE_SIZE,
210 .bDescriptorType = USB_DT_INTERFACE,
211 .bInterfaceNumber = 0, // to be filled
212 .bNumEndpoints = 0,
213 .bInterfaceClass = USB_CLASS_AUDIO,
214 .bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL,
215 .bInterfaceProtocol = 0,
216 .iInterface = 0,
217 };
218
219 static struct uac1_ac_header_descriptor_1 midi2_audio_class_desc = {
220 .bLength = 0x09,
221 .bDescriptorType = USB_DT_CS_INTERFACE,
222 .bDescriptorSubtype = 0x01,
223 .bcdADC = __cpu_to_le16(0x0100),
224 .wTotalLength = __cpu_to_le16(0x0009),
225 .bInCollection = 0x01,
226 .baInterfaceNr = { 0x01 }, // to be filled
227 };
228
229 /* MIDI 1.0 Streaming Interface (altset 0) */
230 static struct usb_interface_descriptor midi2_midi1_if_desc = {
231 .bLength = USB_DT_INTERFACE_SIZE,
232 .bDescriptorType = USB_DT_INTERFACE,
233 .bInterfaceNumber = 0, // to be filled
234 .bAlternateSetting = 0,
235 .bNumEndpoints = 2, // to be filled
236 .bInterfaceClass = USB_CLASS_AUDIO,
237 .bInterfaceSubClass = USB_SUBCLASS_MIDISTREAMING,
238 .bInterfaceProtocol = 0,
239 .iInterface = 0, // to be filled
240 };
241
242 static struct usb_ms_header_descriptor midi2_midi1_class_desc = {
243 .bLength = 0x07,
244 .bDescriptorType = USB_DT_CS_INTERFACE,
245 .bDescriptorSubtype = USB_MS_HEADER,
246 .bcdMSC = __cpu_to_le16(0x0100),
247 .wTotalLength = __cpu_to_le16(0x41), // to be calculated
248 };
249
250 /* MIDI 1.0 EP OUT */
251 static struct usb_endpoint_descriptor midi2_midi1_ep_out_desc = {
252 .bLength = USB_DT_ENDPOINT_AUDIO_SIZE,
253 .bDescriptorType = USB_DT_ENDPOINT,
254 .bEndpointAddress = USB_DIR_OUT | 0, // set up dynamically
255 .bmAttributes = USB_ENDPOINT_XFER_BULK,
256 };
257
258 static struct usb_ss_ep_comp_descriptor midi2_midi1_ep_out_ss_comp_desc = {
259 .bLength = sizeof(midi2_midi1_ep_out_ss_comp_desc),
260 .bDescriptorType = USB_DT_SS_ENDPOINT_COMP,
261 };
262
263 static struct usb_ms_endpoint_descriptor_16 midi2_midi1_ep_out_class_desc = {
264 .bLength = 0x05, // to be filled
265 .bDescriptorType = USB_DT_CS_ENDPOINT,
266 .bDescriptorSubtype = USB_MS_GENERAL,
267 .bNumEmbMIDIJack = 1,
268 .baAssocJackID = { 0x01 },
269 };
270
271 /* MIDI 1.0 EP IN */
272 static struct usb_endpoint_descriptor midi2_midi1_ep_in_desc = {
273 .bLength = USB_DT_ENDPOINT_AUDIO_SIZE,
274 .bDescriptorType = USB_DT_ENDPOINT,
275 .bEndpointAddress = USB_DIR_IN | 0, // set up dynamically
276 .bmAttributes = USB_ENDPOINT_XFER_BULK,
277 };
278
279 static struct usb_ss_ep_comp_descriptor midi2_midi1_ep_in_ss_comp_desc = {
280 .bLength = sizeof(midi2_midi1_ep_in_ss_comp_desc),
281 .bDescriptorType = USB_DT_SS_ENDPOINT_COMP,
282 };
283
284 static struct usb_ms_endpoint_descriptor_16 midi2_midi1_ep_in_class_desc = {
285 .bLength = 0x05, // to be filled
286 .bDescriptorType = USB_DT_CS_ENDPOINT,
287 .bDescriptorSubtype = USB_MS_GENERAL,
288 .bNumEmbMIDIJack = 1,
289 .baAssocJackID = { 0x03 },
290 };
291
292 /* MIDI 2.0 Streaming Interface (altset 1) */
293 static struct usb_interface_descriptor midi2_midi2_if_desc = {
294 .bLength = USB_DT_INTERFACE_SIZE,
295 .bDescriptorType = USB_DT_INTERFACE,
296 .bInterfaceNumber = 0, // to be filled
297 .bAlternateSetting = 1,
298 .bNumEndpoints = 2, // to be filled
299 .bInterfaceClass = USB_CLASS_AUDIO,
300 .bInterfaceSubClass = USB_SUBCLASS_MIDISTREAMING,
301 .bInterfaceProtocol = 0,
302 .iInterface = 0, // to be filled
303 };
304
305 static struct usb_ms_header_descriptor midi2_midi2_class_desc = {
306 .bLength = 0x07,
307 .bDescriptorType = USB_DT_CS_INTERFACE,
308 .bDescriptorSubtype = USB_MS_HEADER,
309 .bcdMSC = __cpu_to_le16(0x0200),
310 .wTotalLength = __cpu_to_le16(0x07),
311 };
312
313 /* MIDI 2.0 EP OUT */
314 static struct usb_endpoint_descriptor midi2_midi2_ep_out_desc[MAX_UMP_EPS];
315
316 static struct usb_ss_ep_comp_descriptor midi2_midi2_ep_out_ss_comp_desc = {
317 .bLength = sizeof(midi2_midi1_ep_out_ss_comp_desc),
318 .bDescriptorType = USB_DT_SS_ENDPOINT_COMP,
319 };
320
321 static struct usb_ms20_endpoint_descriptor_32 midi2_midi2_ep_out_class_desc[MAX_UMP_EPS];
322
323 /* MIDI 2.0 EP IN */
324 static struct usb_endpoint_descriptor midi2_midi2_ep_in_desc[MAX_UMP_EPS];
325
326 static struct usb_ss_ep_comp_descriptor midi2_midi2_ep_in_ss_comp_desc = {
327 .bLength = sizeof(midi2_midi2_ep_in_ss_comp_desc),
328 .bDescriptorType = USB_DT_SS_ENDPOINT_COMP,
329 };
330
331 static struct usb_ms20_endpoint_descriptor_32 midi2_midi2_ep_in_class_desc[MAX_UMP_EPS];
332
333 /* Arrays of descriptors to be created */
334 static void *midi2_audio_descs[] = {
335 &midi2_audio_if_desc,
336 &midi2_audio_class_desc,
337 NULL
338 };
339
340 static void *midi2_midi1_descs[] = {
341 &midi2_midi1_if_desc,
342 &midi2_midi1_class_desc,
343 NULL
344 };
345
346 static void *midi2_midi1_ep_out_descs[] = {
347 &midi2_midi1_ep_out_desc,
348 &midi2_midi1_ep_out_class_desc,
349 NULL
350 };
351
352 static void *midi2_midi1_ep_in_descs[] = {
353 &midi2_midi1_ep_in_desc,
354 &midi2_midi1_ep_in_class_desc,
355 NULL
356 };
357
358 static void *midi2_midi1_ep_out_ss_descs[] = {
359 &midi2_midi1_ep_out_desc,
360 &midi2_midi1_ep_out_ss_comp_desc,
361 &midi2_midi1_ep_out_class_desc,
362 NULL
363 };
364
365 static void *midi2_midi1_ep_in_ss_descs[] = {
366 &midi2_midi1_ep_in_desc,
367 &midi2_midi1_ep_in_ss_comp_desc,
368 &midi2_midi1_ep_in_class_desc,
369 NULL
370 };
371
372 static void *midi2_midi2_descs[] = {
373 &midi2_midi2_if_desc,
374 &midi2_midi2_class_desc,
375 NULL
376 };
377
378 /*
379 * USB request handling
380 */
381
382 /* get an empty request for the given EP */
get_empty_request(struct f_midi2_usb_ep * usb_ep)383 static struct usb_request *get_empty_request(struct f_midi2_usb_ep *usb_ep)
384 {
385 struct usb_request *req = NULL;
386 unsigned long flags;
387 int index;
388
389 spin_lock_irqsave(&usb_ep->card->queue_lock, flags);
390 if (!usb_ep->free_reqs)
391 goto unlock;
392 index = find_first_bit(&usb_ep->free_reqs, usb_ep->num_reqs);
393 if (index >= usb_ep->num_reqs)
394 goto unlock;
395 req = usb_ep->reqs[index].req;
396 if (!req)
397 goto unlock;
398 clear_bit(index, &usb_ep->free_reqs);
399 req->length = 0;
400 unlock:
401 spin_unlock_irqrestore(&usb_ep->card->queue_lock, flags);
402 return req;
403 }
404
405 /* put the empty request back */
put_empty_request(struct usb_request * req)406 static void put_empty_request(struct usb_request *req)
407 {
408 struct f_midi2_req_ctx *ctx = req->context;
409 unsigned long flags;
410
411 spin_lock_irqsave(&ctx->usb_ep->card->queue_lock, flags);
412 set_bit(ctx->index, &ctx->usb_ep->free_reqs);
413 spin_unlock_irqrestore(&ctx->usb_ep->card->queue_lock, flags);
414 }
415
416 /*
417 * UMP v1.1 Stream message handling
418 */
419
420 /* queue a request to UMP EP; request is either queued or freed after this */
queue_request_ep_raw(struct usb_request * req)421 static int queue_request_ep_raw(struct usb_request *req)
422 {
423 struct f_midi2_req_ctx *ctx = req->context;
424 int err;
425
426 req->complete = ctx->usb_ep->complete;
427 err = usb_ep_queue(ctx->usb_ep->usb_ep, req, GFP_ATOMIC);
428 if (err) {
429 put_empty_request(req);
430 return err;
431 }
432 return 0;
433 }
434
435 /* queue a request with endianness conversion */
queue_request_ep_in(struct usb_request * req)436 static int queue_request_ep_in(struct usb_request *req)
437 {
438 /* UMP packets have to be converted to little-endian */
439 cpu_to_le32_array((u32 *)req->buf, req->length >> 2);
440 return queue_request_ep_raw(req);
441 }
442
443 /* reply a UMP packet via EP-in */
reply_ep_in(struct f_midi2_ep * ep,const void * buf,int len)444 static int reply_ep_in(struct f_midi2_ep *ep, const void *buf, int len)
445 {
446 struct f_midi2_usb_ep *usb_ep = &ep->ep_in;
447 struct usb_request *req;
448
449 req = get_empty_request(usb_ep);
450 if (!req)
451 return -ENOSPC;
452
453 req->length = len;
454 memcpy(req->buf, buf, len);
455 return queue_request_ep_in(req);
456 }
457
458 /* reply a UMP stream EP info */
reply_ump_stream_ep_info(struct f_midi2_ep * ep)459 static void reply_ump_stream_ep_info(struct f_midi2_ep *ep)
460 {
461 struct snd_ump_stream_msg_ep_info rep = {
462 .type = UMP_MSG_TYPE_STREAM,
463 .status = UMP_STREAM_MSG_STATUS_EP_INFO,
464 .ump_version_major = 0x01,
465 .ump_version_minor = 0x01,
466 .num_function_blocks = ep->num_blks,
467 .static_function_block = !!ep->card->info.static_block,
468 .protocol = (UMP_STREAM_MSG_EP_INFO_CAP_MIDI1 |
469 UMP_STREAM_MSG_EP_INFO_CAP_MIDI2) >> 8,
470 };
471
472 reply_ep_in(ep, &rep, sizeof(rep));
473 }
474
475 /* reply a UMP EP device info */
reply_ump_stream_ep_device(struct f_midi2_ep * ep)476 static void reply_ump_stream_ep_device(struct f_midi2_ep *ep)
477 {
478 struct snd_ump_stream_msg_device_info rep = {
479 .type = UMP_MSG_TYPE_STREAM,
480 .status = UMP_STREAM_MSG_STATUS_DEVICE_INFO,
481 .manufacture_id = ep->info.manufacturer,
482 .family_lsb = ep->info.family & 0xff,
483 .family_msb = (ep->info.family >> 8) & 0xff,
484 .model_lsb = ep->info.model & 0xff,
485 .model_msb = (ep->info.model >> 8) & 0xff,
486 .sw_revision = ep->info.sw_revision,
487 };
488
489 reply_ep_in(ep, &rep, sizeof(rep));
490 }
491
492 #define UMP_STREAM_PKT_BYTES 16 /* UMP stream packet size = 16 bytes*/
493 #define UMP_STREAM_EP_STR_OFF 2 /* offset of name string for EP info */
494 #define UMP_STREAM_FB_STR_OFF 3 /* offset of name string for FB info */
495
496 /* Helper to replay a string */
reply_ump_stream_string(struct f_midi2_ep * ep,const u8 * name,unsigned int type,unsigned int extra,unsigned int start_ofs)497 static void reply_ump_stream_string(struct f_midi2_ep *ep, const u8 *name,
498 unsigned int type, unsigned int extra,
499 unsigned int start_ofs)
500 {
501 struct f_midi2_usb_ep *usb_ep = &ep->ep_in;
502 struct f_midi2 *midi2 = ep->card;
503 struct usb_request *req;
504 unsigned int pos;
505 u32 *buf;
506
507 if (!*name)
508 return;
509 req = get_empty_request(usb_ep);
510 if (!req)
511 return;
512
513 buf = (u32 *)req->buf;
514 pos = start_ofs;
515 for (;;) {
516 if (pos == start_ofs) {
517 memset(buf, 0, UMP_STREAM_PKT_BYTES);
518 buf[0] = ump_stream_compose(type, 0) | extra;
519 }
520 buf[pos / 4] |= *name++ << ((3 - (pos % 4)) * 8);
521 if (!*name) {
522 if (req->length)
523 buf[0] |= UMP_STREAM_MSG_FORMAT_END << 26;
524 req->length += UMP_STREAM_PKT_BYTES;
525 break;
526 }
527 if (++pos == UMP_STREAM_PKT_BYTES) {
528 if (!req->length)
529 buf[0] |= UMP_STREAM_MSG_FORMAT_START << 26;
530 else
531 buf[0] |= UMP_STREAM_MSG_FORMAT_CONTINUE << 26;
532 req->length += UMP_STREAM_PKT_BYTES;
533 if (midi2->info.req_buf_size - req->length < UMP_STREAM_PKT_BYTES)
534 break;
535 buf += 4;
536 pos = start_ofs;
537 }
538 }
539
540 if (req->length)
541 queue_request_ep_in(req);
542 else
543 put_empty_request(req);
544 }
545
546 /* Reply a UMP EP name string */
reply_ump_stream_ep_name(struct f_midi2_ep * ep)547 static void reply_ump_stream_ep_name(struct f_midi2_ep *ep)
548 {
549 reply_ump_stream_string(ep, ump_ep_name(ep),
550 UMP_STREAM_MSG_STATUS_EP_NAME, 0,
551 UMP_STREAM_EP_STR_OFF);
552 }
553
554 /* Reply a UMP EP product ID string */
reply_ump_stream_ep_pid(struct f_midi2_ep * ep)555 static void reply_ump_stream_ep_pid(struct f_midi2_ep *ep)
556 {
557 reply_ump_stream_string(ep, ump_product_id(ep),
558 UMP_STREAM_MSG_STATUS_PRODUCT_ID, 0,
559 UMP_STREAM_EP_STR_OFF);
560 }
561
562 /* Reply a UMP EP stream config */
reply_ump_stream_ep_config(struct f_midi2_ep * ep)563 static void reply_ump_stream_ep_config(struct f_midi2_ep *ep)
564 {
565 struct snd_ump_stream_msg_stream_cfg rep = {
566 .type = UMP_MSG_TYPE_STREAM,
567 .status = UMP_STREAM_MSG_STATUS_STREAM_CFG,
568 };
569
570 if (ep->info.protocol == 2)
571 rep.protocol = UMP_STREAM_MSG_EP_INFO_CAP_MIDI2 >> 8;
572 else
573 rep.protocol = UMP_STREAM_MSG_EP_INFO_CAP_MIDI1 >> 8;
574
575 reply_ep_in(ep, &rep, sizeof(rep));
576 }
577
578 /* Reply a UMP FB info */
reply_ump_stream_fb_info(struct f_midi2_ep * ep,int blk)579 static void reply_ump_stream_fb_info(struct f_midi2_ep *ep, int blk)
580 {
581 struct f_midi2_block_info *b = &ep->blks[blk].info;
582 struct snd_ump_stream_msg_fb_info rep = {
583 .type = UMP_MSG_TYPE_STREAM,
584 .status = UMP_STREAM_MSG_STATUS_FB_INFO,
585 .active = !!b->active,
586 .function_block_id = blk,
587 .ui_hint = b->ui_hint,
588 .midi_10 = b->is_midi1,
589 .direction = b->direction,
590 .first_group = b->first_group,
591 .num_groups = b->num_groups,
592 .midi_ci_version = b->midi_ci_version,
593 .sysex8_streams = b->sysex8_streams,
594 };
595
596 reply_ep_in(ep, &rep, sizeof(rep));
597 }
598
599 /* Reply a FB name string */
reply_ump_stream_fb_name(struct f_midi2_ep * ep,unsigned int blk)600 static void reply_ump_stream_fb_name(struct f_midi2_ep *ep, unsigned int blk)
601 {
602 reply_ump_stream_string(ep, ump_fb_name(&ep->blks[blk].info),
603 UMP_STREAM_MSG_STATUS_FB_NAME, blk << 8,
604 UMP_STREAM_FB_STR_OFF);
605 }
606
607 /* Process a UMP Stream message */
process_ump_stream_msg(struct f_midi2_ep * ep,const u32 * data)608 static void process_ump_stream_msg(struct f_midi2_ep *ep, const u32 *data)
609 {
610 struct f_midi2 *midi2 = ep->card;
611 unsigned int format, status, blk;
612
613 format = ump_stream_message_format(*data);
614 status = ump_stream_message_status(*data);
615 switch (status) {
616 case UMP_STREAM_MSG_STATUS_EP_DISCOVERY:
617 if (format)
618 return; // invalid
619 if (data[1] & UMP_STREAM_MSG_REQUEST_EP_INFO)
620 reply_ump_stream_ep_info(ep);
621 if (data[1] & UMP_STREAM_MSG_REQUEST_DEVICE_INFO)
622 reply_ump_stream_ep_device(ep);
623 if (data[1] & UMP_STREAM_MSG_REQUEST_EP_NAME)
624 reply_ump_stream_ep_name(ep);
625 if (data[1] & UMP_STREAM_MSG_REQUEST_PRODUCT_ID)
626 reply_ump_stream_ep_pid(ep);
627 if (data[1] & UMP_STREAM_MSG_REQUEST_STREAM_CFG)
628 reply_ump_stream_ep_config(ep);
629 return;
630 case UMP_STREAM_MSG_STATUS_STREAM_CFG_REQUEST:
631 if (*data & UMP_STREAM_MSG_EP_INFO_CAP_MIDI2) {
632 ep->info.protocol = 2;
633 DBG(midi2, "Switching Protocol to MIDI2\n");
634 } else {
635 ep->info.protocol = 1;
636 DBG(midi2, "Switching Protocol to MIDI1\n");
637 }
638 snd_ump_switch_protocol(ep->ump, to_ump_protocol(ep->info.protocol));
639 reply_ump_stream_ep_config(ep);
640 return;
641 case UMP_STREAM_MSG_STATUS_FB_DISCOVERY:
642 if (format)
643 return; // invalid
644 blk = (*data >> 8) & 0xff;
645 if (blk == 0xff) {
646 /* inquiry for all blocks */
647 for (blk = 0; blk < ep->num_blks; blk++) {
648 if (*data & UMP_STREAM_MSG_REQUEST_FB_INFO)
649 reply_ump_stream_fb_info(ep, blk);
650 if (*data & UMP_STREAM_MSG_REQUEST_FB_NAME)
651 reply_ump_stream_fb_name(ep, blk);
652 }
653 } else if (blk < ep->num_blks) {
654 /* only the specified block */
655 if (*data & UMP_STREAM_MSG_REQUEST_FB_INFO)
656 reply_ump_stream_fb_info(ep, blk);
657 if (*data & UMP_STREAM_MSG_REQUEST_FB_NAME)
658 reply_ump_stream_fb_name(ep, blk);
659 }
660 return;
661 }
662 }
663
664 /* Process UMP messages included in a USB request */
process_ump(struct f_midi2_ep * ep,const struct usb_request * req)665 static void process_ump(struct f_midi2_ep *ep, const struct usb_request *req)
666 {
667 const u32 *data = (u32 *)req->buf;
668 int len = req->actual >> 2;
669 const u32 *in_buf = ep->ump->input_buf;
670
671 for (; len > 0; len--, data++) {
672 if (snd_ump_receive_ump_val(ep->ump, *data) <= 0)
673 continue;
674 if (ump_message_type(*in_buf) == UMP_MSG_TYPE_STREAM)
675 process_ump_stream_msg(ep, in_buf);
676 }
677 }
678
679 /*
680 * MIDI 2.0 UMP USB request handling
681 */
682
683 /* complete handler for UMP EP-out requests */
f_midi2_ep_out_complete(struct usb_ep * usb_ep,struct usb_request * req)684 static void f_midi2_ep_out_complete(struct usb_ep *usb_ep,
685 struct usb_request *req)
686 {
687 struct f_midi2_req_ctx *ctx = req->context;
688 struct f_midi2_ep *ep = ctx->usb_ep->ep;
689 struct f_midi2 *midi2 = ep->card;
690 int status = req->status;
691
692 if (status) {
693 DBG(midi2, "%s complete error %d: %d/%d\n",
694 usb_ep->name, status, req->actual, req->length);
695 goto error;
696 }
697
698 /* convert to UMP packet in native endianness */
699 le32_to_cpu_array((u32 *)req->buf, req->actual >> 2);
700
701 if (midi2->info.process_ump)
702 process_ump(ep, req);
703
704 snd_ump_receive(ep->ump, req->buf, req->actual & ~3);
705
706 if (midi2->operation_mode != MIDI_OP_MODE_MIDI2)
707 goto error;
708
709 if (queue_request_ep_raw(req))
710 goto error;
711 return;
712
713 error:
714 put_empty_request(req);
715 }
716
717 /* Transmit UMP packets received from user-space to the gadget */
process_ump_transmit(struct f_midi2_ep * ep)718 static void process_ump_transmit(struct f_midi2_ep *ep)
719 {
720 struct f_midi2_usb_ep *usb_ep = &ep->ep_in;
721 struct f_midi2 *midi2 = ep->card;
722 struct usb_request *req;
723 int len;
724
725 if (!usb_ep->usb_ep->enabled)
726 return;
727
728 for (;;) {
729 req = get_empty_request(usb_ep);
730 if (!req)
731 break;
732 len = snd_ump_transmit(ep->ump, (u32 *)req->buf,
733 midi2->info.req_buf_size);
734 if (len <= 0) {
735 put_empty_request(req);
736 break;
737 }
738
739 req->length = len;
740 if (queue_request_ep_in(req) < 0)
741 break;
742 }
743 }
744
745 /* Complete handler for UMP EP-in requests */
f_midi2_ep_in_complete(struct usb_ep * usb_ep,struct usb_request * req)746 static void f_midi2_ep_in_complete(struct usb_ep *usb_ep,
747 struct usb_request *req)
748 {
749 struct f_midi2_req_ctx *ctx = req->context;
750 struct f_midi2_ep *ep = ctx->usb_ep->ep;
751 struct f_midi2 *midi2 = ep->card;
752 int status = req->status;
753
754 put_empty_request(req);
755
756 if (status) {
757 DBG(midi2, "%s complete error %d: %d/%d\n",
758 usb_ep->name, status, req->actual, req->length);
759 return;
760 }
761
762 process_ump_transmit(ep);
763 }
764
765 /*
766 * MIDI1 (altset 0) USB request handling
767 */
768
769 /* process one MIDI byte -- copied from f_midi.c
770 *
771 * fill the packet or request if needed
772 * returns true if the request became empty (queued)
773 */
process_midi1_byte(struct f_midi2 * midi2,u8 cable,u8 b,struct usb_request ** req_p)774 static bool process_midi1_byte(struct f_midi2 *midi2, u8 cable, u8 b,
775 struct usb_request **req_p)
776 {
777 struct f_midi2_midi1_port *port = &midi2->midi1_port[cable];
778 u8 p[4] = { cable << 4, 0, 0, 0 };
779 int next_state = STATE_INITIAL;
780 struct usb_request *req = *req_p;
781
782 switch (b) {
783 case 0xf8 ... 0xff:
784 /* System Real-Time Messages */
785 p[0] |= 0x0f;
786 p[1] = b;
787 next_state = port->state;
788 port->state = STATE_REAL_TIME;
789 break;
790
791 case 0xf7:
792 /* End of SysEx */
793 switch (port->state) {
794 case STATE_SYSEX_0:
795 p[0] |= 0x05;
796 p[1] = 0xf7;
797 next_state = STATE_FINISHED;
798 break;
799 case STATE_SYSEX_1:
800 p[0] |= 0x06;
801 p[1] = port->data[0];
802 p[2] = 0xf7;
803 next_state = STATE_FINISHED;
804 break;
805 case STATE_SYSEX_2:
806 p[0] |= 0x07;
807 p[1] = port->data[0];
808 p[2] = port->data[1];
809 p[3] = 0xf7;
810 next_state = STATE_FINISHED;
811 break;
812 default:
813 /* Ignore byte */
814 next_state = port->state;
815 port->state = STATE_INITIAL;
816 }
817 break;
818
819 case 0xf0 ... 0xf6:
820 /* System Common Messages */
821 port->data[0] = port->data[1] = 0;
822 port->state = STATE_INITIAL;
823 switch (b) {
824 case 0xf0:
825 port->data[0] = b;
826 port->data[1] = 0;
827 next_state = STATE_SYSEX_1;
828 break;
829 case 0xf1:
830 case 0xf3:
831 port->data[0] = b;
832 next_state = STATE_1PARAM;
833 break;
834 case 0xf2:
835 port->data[0] = b;
836 next_state = STATE_2PARAM_1;
837 break;
838 case 0xf4:
839 case 0xf5:
840 next_state = STATE_INITIAL;
841 break;
842 case 0xf6:
843 p[0] |= 0x05;
844 p[1] = 0xf6;
845 next_state = STATE_FINISHED;
846 break;
847 }
848 break;
849
850 case 0x80 ... 0xef:
851 /*
852 * Channel Voice Messages, Channel Mode Messages
853 * and Control Change Messages.
854 */
855 port->data[0] = b;
856 port->data[1] = 0;
857 port->state = STATE_INITIAL;
858 if (b >= 0xc0 && b <= 0xdf)
859 next_state = STATE_1PARAM;
860 else
861 next_state = STATE_2PARAM_1;
862 break;
863
864 case 0x00 ... 0x7f:
865 /* Message parameters */
866 switch (port->state) {
867 case STATE_1PARAM:
868 if (port->data[0] < 0xf0)
869 p[0] |= port->data[0] >> 4;
870 else
871 p[0] |= 0x02;
872
873 p[1] = port->data[0];
874 p[2] = b;
875 /* This is to allow Running State Messages */
876 next_state = STATE_1PARAM;
877 break;
878 case STATE_2PARAM_1:
879 port->data[1] = b;
880 next_state = STATE_2PARAM_2;
881 break;
882 case STATE_2PARAM_2:
883 if (port->data[0] < 0xf0)
884 p[0] |= port->data[0] >> 4;
885 else
886 p[0] |= 0x03;
887
888 p[1] = port->data[0];
889 p[2] = port->data[1];
890 p[3] = b;
891 /* This is to allow Running State Messages */
892 next_state = STATE_2PARAM_1;
893 break;
894 case STATE_SYSEX_0:
895 port->data[0] = b;
896 next_state = STATE_SYSEX_1;
897 break;
898 case STATE_SYSEX_1:
899 port->data[1] = b;
900 next_state = STATE_SYSEX_2;
901 break;
902 case STATE_SYSEX_2:
903 p[0] |= 0x04;
904 p[1] = port->data[0];
905 p[2] = port->data[1];
906 p[3] = b;
907 next_state = STATE_SYSEX_0;
908 break;
909 }
910 break;
911 }
912
913 /* States where we have to write into the USB request */
914 if (next_state == STATE_FINISHED ||
915 port->state == STATE_SYSEX_2 ||
916 port->state == STATE_1PARAM ||
917 port->state == STATE_2PARAM_2 ||
918 port->state == STATE_REAL_TIME) {
919 memcpy(req->buf + req->length, p, sizeof(p));
920 req->length += sizeof(p);
921
922 if (next_state == STATE_FINISHED) {
923 next_state = STATE_INITIAL;
924 port->data[0] = port->data[1] = 0;
925 }
926
927 if (midi2->info.req_buf_size - req->length <= 4) {
928 queue_request_ep_raw(req);
929 *req_p = NULL;
930 return true;
931 }
932 }
933
934 port->state = next_state;
935 return false;
936 }
937
938 /* process all pending MIDI bytes in the internal buffer;
939 * returns true if the request gets empty
940 * returns false if all have been processed
941 */
process_midi1_pending_buf(struct f_midi2 * midi2,struct usb_request ** req_p)942 static bool process_midi1_pending_buf(struct f_midi2 *midi2,
943 struct usb_request **req_p)
944 {
945 unsigned int cable, c;
946
947 for (cable = 0; cable < midi2->num_midi1_in; cable++) {
948 struct f_midi2_midi1_port *port = &midi2->midi1_port[cable];
949
950 if (!port->pending)
951 continue;
952 for (c = 0; c < port->pending; c++) {
953 if (process_midi1_byte(midi2, cable, port->buf[c],
954 req_p)) {
955 port->pending -= c;
956 if (port->pending)
957 memmove(port->buf, port->buf + c,
958 port->pending);
959 return true;
960 }
961 }
962 port->pending = 0;
963 }
964
965 return false;
966 }
967
968 /* fill the MIDI bytes onto the temporary buffer
969 */
fill_midi1_pending_buf(struct f_midi2 * midi2,u8 cable,u8 * buf,unsigned int size)970 static void fill_midi1_pending_buf(struct f_midi2 *midi2, u8 cable, u8 *buf,
971 unsigned int size)
972 {
973 struct f_midi2_midi1_port *port = &midi2->midi1_port[cable];
974
975 if (port->pending + size > sizeof(port->buf))
976 return;
977 memcpy(port->buf + port->pending, buf, size);
978 port->pending += size;
979 }
980
981 /* try to process data given from the associated UMP stream */
process_midi1_transmit(struct f_midi2 * midi2)982 static void process_midi1_transmit(struct f_midi2 *midi2)
983 {
984 struct f_midi2_usb_ep *usb_ep = &midi2->midi1_ep_in;
985 struct f_midi2_ep *ep = &midi2->midi2_eps[0];
986 struct usb_request *req = NULL;
987 /* 12 is the largest outcome (4 MIDI1 cmds) for a single UMP packet */
988 unsigned char outbuf[12];
989 unsigned char group, cable;
990 int len, size;
991 u32 ump;
992
993 if (!usb_ep->usb_ep || !usb_ep->usb_ep->enabled)
994 return;
995
996 for (;;) {
997 if (!req) {
998 req = get_empty_request(usb_ep);
999 if (!req)
1000 break;
1001 }
1002
1003 if (process_midi1_pending_buf(midi2, &req))
1004 continue;
1005
1006 len = snd_ump_transmit(ep->ump, &ump, 4);
1007 if (len <= 0)
1008 break;
1009 if (snd_ump_receive_ump_val(ep->ump, ump) <= 0)
1010 continue;
1011 size = snd_ump_convert_from_ump(ep->ump->input_buf, outbuf,
1012 &group);
1013 if (size <= 0)
1014 continue;
1015 cable = ep->in_group_to_cable[group];
1016 if (!cable)
1017 continue;
1018 cable--; /* to 0-base */
1019 fill_midi1_pending_buf(midi2, cable, outbuf, size);
1020 }
1021
1022 if (req) {
1023 if (req->length)
1024 queue_request_ep_raw(req);
1025 else
1026 put_empty_request(req);
1027 }
1028 }
1029
1030 /* complete handler for MIDI1 EP-in requests */
f_midi2_midi1_ep_in_complete(struct usb_ep * usb_ep,struct usb_request * req)1031 static void f_midi2_midi1_ep_in_complete(struct usb_ep *usb_ep,
1032 struct usb_request *req)
1033 {
1034 struct f_midi2_req_ctx *ctx = req->context;
1035 struct f_midi2 *midi2 = ctx->usb_ep->card;
1036 int status = req->status;
1037
1038 put_empty_request(req);
1039
1040 if (status) {
1041 DBG(midi2, "%s complete error %d: %d/%d\n",
1042 usb_ep->name, status, req->actual, req->length);
1043 return;
1044 }
1045
1046 process_midi1_transmit(midi2);
1047 }
1048
1049 /* complete handler for MIDI1 EP-out requests */
f_midi2_midi1_ep_out_complete(struct usb_ep * usb_ep,struct usb_request * req)1050 static void f_midi2_midi1_ep_out_complete(struct usb_ep *usb_ep,
1051 struct usb_request *req)
1052 {
1053 struct f_midi2_req_ctx *ctx = req->context;
1054 struct f_midi2 *midi2 = ctx->usb_ep->card;
1055 struct f_midi2_ep *ep;
1056 struct ump_cvt_to_ump *cvt = &midi2->midi1_ump_cvt;
1057 static const u8 midi1_packet_bytes[16] = {
1058 0, 0, 2, 3, 3, 1, 2, 3, 3, 3, 3, 3, 2, 2, 3, 1
1059 };
1060 unsigned int group, cable, bytes, c, len;
1061 int status = req->status;
1062 const u8 *buf = req->buf;
1063
1064 if (status) {
1065 DBG(midi2, "%s complete error %d: %d/%d\n",
1066 usb_ep->name, status, req->actual, req->length);
1067 goto error;
1068 }
1069
1070 len = req->actual >> 2;
1071 for (; len; len--, buf += 4) {
1072 cable = *buf >> 4;
1073 ep = midi2->out_cable_mapping[cable].ep;
1074 if (!ep)
1075 continue;
1076 group = midi2->out_cable_mapping[cable].group;
1077 bytes = midi1_packet_bytes[*buf & 0x0f];
1078 for (c = 0; c < bytes; c++) {
1079 snd_ump_convert_to_ump(cvt, group,
1080 to_ump_protocol(ep->info.protocol),
1081 buf[c + 1]);
1082 if (cvt->ump_bytes) {
1083 snd_ump_receive(ep->ump, cvt->ump,
1084 cvt->ump_bytes);
1085 cvt->ump_bytes = 0;
1086 }
1087 }
1088 }
1089
1090 if (midi2->operation_mode != MIDI_OP_MODE_MIDI1)
1091 goto error;
1092
1093 if (queue_request_ep_raw(req))
1094 goto error;
1095 return;
1096
1097 error:
1098 put_empty_request(req);
1099 }
1100
1101 /*
1102 * Common EP handling helpers
1103 */
1104
1105 /* Start MIDI EP */
f_midi2_start_ep(struct f_midi2_usb_ep * usb_ep,struct usb_function * fn)1106 static int f_midi2_start_ep(struct f_midi2_usb_ep *usb_ep,
1107 struct usb_function *fn)
1108 {
1109 int err;
1110
1111 if (!usb_ep->usb_ep)
1112 return 0;
1113
1114 usb_ep_disable(usb_ep->usb_ep);
1115 err = config_ep_by_speed(usb_ep->card->gadget, fn, usb_ep->usb_ep);
1116 if (err)
1117 return err;
1118 return usb_ep_enable(usb_ep->usb_ep);
1119 }
1120
1121 /* Drop pending requests */
f_midi2_drop_reqs(struct f_midi2_usb_ep * usb_ep)1122 static void f_midi2_drop_reqs(struct f_midi2_usb_ep *usb_ep)
1123 {
1124 int i;
1125
1126 if (!usb_ep->usb_ep || !usb_ep->num_reqs)
1127 return;
1128
1129 for (i = 0; i < usb_ep->num_reqs; i++) {
1130 if (!test_bit(i, &usb_ep->free_reqs) && usb_ep->reqs[i].req) {
1131 usb_ep_dequeue(usb_ep->usb_ep, usb_ep->reqs[i].req);
1132 set_bit(i, &usb_ep->free_reqs);
1133 }
1134 }
1135 }
1136
1137 /* Allocate requests for the given EP */
f_midi2_alloc_ep_reqs(struct f_midi2_usb_ep * usb_ep)1138 static int f_midi2_alloc_ep_reqs(struct f_midi2_usb_ep *usb_ep)
1139 {
1140 struct f_midi2 *midi2 = usb_ep->card;
1141 int i;
1142
1143 if (!usb_ep->usb_ep)
1144 return 0;
1145 if (!usb_ep->reqs)
1146 return -EINVAL;
1147
1148 for (i = 0; i < midi2->info.num_reqs; i++) {
1149 if (usb_ep->reqs[i].req)
1150 continue;
1151 usb_ep->reqs[i].req = alloc_ep_req(usb_ep->usb_ep,
1152 midi2->info.req_buf_size);
1153 if (!usb_ep->reqs[i].req)
1154 return -ENOMEM;
1155 usb_ep->reqs[i].req->context = &usb_ep->reqs[i];
1156 }
1157 return 0;
1158 }
1159
1160 /* Free allocated requests */
f_midi2_free_ep_reqs(struct f_midi2_usb_ep * usb_ep)1161 static void f_midi2_free_ep_reqs(struct f_midi2_usb_ep *usb_ep)
1162 {
1163 struct f_midi2 *midi2 = usb_ep->card;
1164 int i;
1165
1166 for (i = 0; i < midi2->info.num_reqs; i++) {
1167 if (!usb_ep->reqs[i].req)
1168 continue;
1169 free_ep_req(usb_ep->usb_ep, usb_ep->reqs[i].req);
1170 usb_ep->reqs[i].req = NULL;
1171 }
1172 }
1173
1174 /* Initialize EP */
f_midi2_init_ep(struct f_midi2 * midi2,struct f_midi2_ep * ep,struct f_midi2_usb_ep * usb_ep,void * desc,void (* complete)(struct usb_ep * usb_ep,struct usb_request * req))1175 static int f_midi2_init_ep(struct f_midi2 *midi2, struct f_midi2_ep *ep,
1176 struct f_midi2_usb_ep *usb_ep,
1177 void *desc,
1178 void (*complete)(struct usb_ep *usb_ep,
1179 struct usb_request *req))
1180 {
1181 int i;
1182
1183 usb_ep->card = midi2;
1184 usb_ep->ep = ep;
1185 usb_ep->usb_ep = usb_ep_autoconfig(midi2->gadget, desc);
1186 if (!usb_ep->usb_ep)
1187 return -ENODEV;
1188 usb_ep->complete = complete;
1189
1190 usb_ep->reqs = kzalloc_objs(*usb_ep->reqs, midi2->info.num_reqs);
1191 if (!usb_ep->reqs)
1192 return -ENOMEM;
1193 for (i = 0; i < midi2->info.num_reqs; i++) {
1194 usb_ep->reqs[i].index = i;
1195 usb_ep->reqs[i].usb_ep = usb_ep;
1196 set_bit(i, &usb_ep->free_reqs);
1197 usb_ep->num_reqs++;
1198 }
1199
1200 return 0;
1201 }
1202
1203 /* Free EP */
f_midi2_free_ep(struct f_midi2_usb_ep * usb_ep)1204 static void f_midi2_free_ep(struct f_midi2_usb_ep *usb_ep)
1205 {
1206 f_midi2_drop_reqs(usb_ep);
1207
1208 f_midi2_free_ep_reqs(usb_ep);
1209
1210 kfree(usb_ep->reqs);
1211 usb_ep->num_reqs = 0;
1212 usb_ep->free_reqs = 0;
1213 usb_ep->reqs = NULL;
1214 }
1215
1216 /* Queue requests for EP-out at start */
f_midi2_queue_out_reqs(struct f_midi2_usb_ep * usb_ep)1217 static void f_midi2_queue_out_reqs(struct f_midi2_usb_ep *usb_ep)
1218 {
1219 int i, err;
1220
1221 if (!usb_ep->usb_ep)
1222 return;
1223
1224 for (i = 0; i < usb_ep->num_reqs; i++) {
1225 if (!test_bit(i, &usb_ep->free_reqs) || !usb_ep->reqs[i].req)
1226 continue;
1227 usb_ep->reqs[i].req->complete = usb_ep->complete;
1228 err = usb_ep_queue(usb_ep->usb_ep, usb_ep->reqs[i].req,
1229 GFP_ATOMIC);
1230 if (!err)
1231 clear_bit(i, &usb_ep->free_reqs);
1232 }
1233 }
1234
1235 /*
1236 * Gadget Function callbacks
1237 */
1238
1239 /* stop both IN and OUT EPs */
f_midi2_stop_eps(struct f_midi2_usb_ep * ep_in,struct f_midi2_usb_ep * ep_out)1240 static void f_midi2_stop_eps(struct f_midi2_usb_ep *ep_in,
1241 struct f_midi2_usb_ep *ep_out)
1242 {
1243 f_midi2_drop_reqs(ep_in);
1244 f_midi2_drop_reqs(ep_out);
1245 f_midi2_free_ep_reqs(ep_in);
1246 f_midi2_free_ep_reqs(ep_out);
1247 }
1248
1249 /* start/queue both IN and OUT EPs */
f_midi2_start_eps(struct f_midi2_usb_ep * ep_in,struct f_midi2_usb_ep * ep_out,struct usb_function * fn)1250 static int f_midi2_start_eps(struct f_midi2_usb_ep *ep_in,
1251 struct f_midi2_usb_ep *ep_out,
1252 struct usb_function *fn)
1253 {
1254 int err;
1255
1256 err = f_midi2_start_ep(ep_in, fn);
1257 if (err)
1258 return err;
1259 err = f_midi2_start_ep(ep_out, fn);
1260 if (err)
1261 return err;
1262
1263 err = f_midi2_alloc_ep_reqs(ep_in);
1264 if (err)
1265 return err;
1266 err = f_midi2_alloc_ep_reqs(ep_out);
1267 if (err)
1268 return err;
1269
1270 f_midi2_queue_out_reqs(ep_out);
1271 return 0;
1272 }
1273
1274 /* gadget function set_alt callback */
f_midi2_set_alt(struct usb_function * fn,unsigned int intf,unsigned int alt)1275 static int f_midi2_set_alt(struct usb_function *fn, unsigned int intf,
1276 unsigned int alt)
1277 {
1278 struct f_midi2 *midi2 = func_to_midi2(fn);
1279 struct f_midi2_ep *ep;
1280 int i, op_mode, err;
1281
1282 if (intf != midi2->midi_if || alt > 1)
1283 return 0;
1284
1285 if (alt == 0)
1286 op_mode = MIDI_OP_MODE_MIDI1;
1287 else
1288 op_mode = MIDI_OP_MODE_MIDI2;
1289
1290 if (midi2->operation_mode == op_mode)
1291 return 0;
1292
1293 midi2->operation_mode = op_mode;
1294
1295 if (op_mode != MIDI_OP_MODE_MIDI1)
1296 f_midi2_stop_eps(&midi2->midi1_ep_in, &midi2->midi1_ep_out);
1297
1298 if (op_mode != MIDI_OP_MODE_MIDI2) {
1299 for (i = 0; i < midi2->num_eps; i++) {
1300 ep = &midi2->midi2_eps[i];
1301 f_midi2_stop_eps(&ep->ep_in, &ep->ep_out);
1302 }
1303 }
1304
1305 if (op_mode == MIDI_OP_MODE_MIDI1)
1306 return f_midi2_start_eps(&midi2->midi1_ep_in,
1307 &midi2->midi1_ep_out, fn);
1308
1309 if (op_mode == MIDI_OP_MODE_MIDI2) {
1310 for (i = 0; i < midi2->num_eps; i++) {
1311 ep = &midi2->midi2_eps[i];
1312
1313 err = f_midi2_start_eps(&ep->ep_in, &ep->ep_out, fn);
1314 if (err)
1315 return err;
1316 }
1317 }
1318
1319 return 0;
1320 }
1321
1322 /* gadget function get_alt callback */
f_midi2_get_alt(struct usb_function * fn,unsigned int intf)1323 static int f_midi2_get_alt(struct usb_function *fn, unsigned int intf)
1324 {
1325 struct f_midi2 *midi2 = func_to_midi2(fn);
1326
1327 if (intf == midi2->midi_if &&
1328 midi2->operation_mode == MIDI_OP_MODE_MIDI2)
1329 return 1;
1330 return 0;
1331 }
1332
1333 /* convert UMP direction to USB MIDI 2.0 direction */
ump_to_usb_dir(unsigned int ump_dir)1334 static unsigned int ump_to_usb_dir(unsigned int ump_dir)
1335 {
1336 switch (ump_dir) {
1337 case SNDRV_UMP_DIR_INPUT:
1338 return USB_MS_GR_TRM_BLOCK_TYPE_INPUT_ONLY;
1339 case SNDRV_UMP_DIR_OUTPUT:
1340 return USB_MS_GR_TRM_BLOCK_TYPE_OUTPUT_ONLY;
1341 default:
1342 return USB_MS_GR_TRM_BLOCK_TYPE_BIDIRECTIONAL;
1343 }
1344 }
1345
1346 /* assign GTB descriptors (for the given request) */
assign_block_descriptors(struct f_midi2 * midi2,struct usb_request * req,int max_len)1347 static void assign_block_descriptors(struct f_midi2 *midi2,
1348 struct usb_request *req,
1349 int max_len)
1350 {
1351 struct usb_ms20_gr_trm_block_header_descriptor header;
1352 struct usb_ms20_gr_trm_block_descriptor *desc;
1353 struct f_midi2_block_info *b;
1354 struct f_midi2_ep *ep;
1355 int i, blk, len;
1356 char *data;
1357
1358 len = sizeof(gtb_header_desc) + sizeof(gtb_desc) * midi2->total_blocks;
1359 if (WARN_ON(len > midi2->info.req_buf_size))
1360 return;
1361
1362 header = gtb_header_desc;
1363 header.wTotalLength = cpu_to_le16(len);
1364 if (max_len < len) {
1365 len = min_t(int, len, sizeof(header));
1366 memcpy(req->buf, &header, len);
1367 req->length = len;
1368 req->zero = len < max_len;
1369 return;
1370 }
1371
1372 memcpy(req->buf, &header, sizeof(header));
1373 data = req->buf + sizeof(header);
1374 for (i = 0; i < midi2->num_eps; i++) {
1375 ep = &midi2->midi2_eps[i];
1376 for (blk = 0; blk < ep->num_blks; blk++) {
1377 b = &ep->blks[blk].info;
1378 desc = (struct usb_ms20_gr_trm_block_descriptor *)data;
1379
1380 *desc = gtb_desc;
1381 desc->bGrpTrmBlkID = ep->blks[blk].gtb_id;
1382 desc->bGrpTrmBlkType = ump_to_usb_dir(b->direction);
1383 desc->nGroupTrm = b->first_group;
1384 desc->nNumGroupTrm = b->num_groups;
1385 desc->iBlockItem = ep->blks[blk].string_id;
1386
1387 if (ep->info.protocol == 2)
1388 desc->bMIDIProtocol = USB_MS_MIDI_PROTO_2_0;
1389 else
1390 desc->bMIDIProtocol = USB_MS_MIDI_PROTO_1_0_128;
1391
1392 if (b->is_midi1 == 2) {
1393 desc->wMaxInputBandwidth = cpu_to_le16(1);
1394 desc->wMaxOutputBandwidth = cpu_to_le16(1);
1395 }
1396
1397 data += sizeof(*desc);
1398 }
1399 }
1400
1401 req->length = len;
1402 req->zero = len < max_len;
1403 }
1404
1405 /* gadget function setup callback: handle GTB requests */
f_midi2_setup(struct usb_function * fn,const struct usb_ctrlrequest * ctrl)1406 static int f_midi2_setup(struct usb_function *fn,
1407 const struct usb_ctrlrequest *ctrl)
1408 {
1409 struct f_midi2 *midi2 = func_to_midi2(fn);
1410 struct usb_composite_dev *cdev = fn->config->cdev;
1411 struct usb_request *req = cdev->req;
1412 u16 value, length;
1413
1414 if ((ctrl->bRequestType & USB_TYPE_MASK) != USB_TYPE_STANDARD ||
1415 ctrl->bRequest != USB_REQ_GET_DESCRIPTOR)
1416 return -EOPNOTSUPP;
1417
1418 value = le16_to_cpu(ctrl->wValue);
1419 length = le16_to_cpu(ctrl->wLength);
1420
1421 if ((value >> 8) != USB_DT_CS_GR_TRM_BLOCK)
1422 return -EOPNOTSUPP;
1423
1424 /* handle only altset 1 */
1425 if ((value & 0xff) != 1)
1426 return -EOPNOTSUPP;
1427
1428 assign_block_descriptors(midi2, req, length);
1429 return usb_ep_queue(cdev->gadget->ep0, req, GFP_ATOMIC);
1430 }
1431
1432 /* gadget function disable callback */
f_midi2_disable(struct usb_function * fn)1433 static void f_midi2_disable(struct usb_function *fn)
1434 {
1435 struct f_midi2 *midi2 = func_to_midi2(fn);
1436
1437 midi2->operation_mode = MIDI_OP_MODE_UNSET;
1438 }
1439
1440 /*
1441 * ALSA UMP ops: most of them are NOPs, only trigger for write is needed
1442 */
f_midi2_ump_open(struct snd_ump_endpoint * ump,int dir)1443 static int f_midi2_ump_open(struct snd_ump_endpoint *ump, int dir)
1444 {
1445 return 0;
1446 }
1447
f_midi2_ump_close(struct snd_ump_endpoint * ump,int dir)1448 static void f_midi2_ump_close(struct snd_ump_endpoint *ump, int dir)
1449 {
1450 }
1451
f_midi2_ump_trigger(struct snd_ump_endpoint * ump,int dir,int up)1452 static void f_midi2_ump_trigger(struct snd_ump_endpoint *ump, int dir, int up)
1453 {
1454 struct f_midi2_ep *ep = ump->private_data;
1455 struct f_midi2 *midi2 = ep->card;
1456
1457 if (up && dir == SNDRV_RAWMIDI_STREAM_OUTPUT) {
1458 switch (midi2->operation_mode) {
1459 case MIDI_OP_MODE_MIDI1:
1460 process_midi1_transmit(midi2);
1461 break;
1462 case MIDI_OP_MODE_MIDI2:
1463 process_ump_transmit(ep);
1464 break;
1465 }
1466 }
1467 }
1468
f_midi2_ump_drain(struct snd_ump_endpoint * ump,int dir)1469 static void f_midi2_ump_drain(struct snd_ump_endpoint *ump, int dir)
1470 {
1471 }
1472
1473 static const struct snd_ump_ops f_midi2_ump_ops = {
1474 .open = f_midi2_ump_open,
1475 .close = f_midi2_ump_close,
1476 .trigger = f_midi2_ump_trigger,
1477 .drain = f_midi2_ump_drain,
1478 };
1479
1480 /*
1481 * "Operation Mode" control element
1482 */
f_midi2_operation_mode_info(struct snd_kcontrol * kcontrol,struct snd_ctl_elem_info * uinfo)1483 static int f_midi2_operation_mode_info(struct snd_kcontrol *kcontrol,
1484 struct snd_ctl_elem_info *uinfo)
1485 {
1486 uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
1487 uinfo->count = 1;
1488 uinfo->value.integer.min = MIDI_OP_MODE_UNSET;
1489 uinfo->value.integer.max = MIDI_OP_MODE_MIDI2;
1490 return 0;
1491 }
1492
f_midi2_operation_mode_get(struct snd_kcontrol * kcontrol,struct snd_ctl_elem_value * ucontrol)1493 static int f_midi2_operation_mode_get(struct snd_kcontrol *kcontrol,
1494 struct snd_ctl_elem_value *ucontrol)
1495 {
1496 struct f_midi2 *midi2 = snd_kcontrol_chip(kcontrol);
1497
1498 ucontrol->value.integer.value[0] = midi2->operation_mode;
1499 return 0;
1500 }
1501
1502 static const struct snd_kcontrol_new operation_mode_ctl = {
1503 .iface = SNDRV_CTL_ELEM_IFACE_RAWMIDI,
1504 .name = "Operation Mode",
1505 .access = SNDRV_CTL_ELEM_ACCESS_READ | SNDRV_CTL_ELEM_ACCESS_VOLATILE,
1506 .info = f_midi2_operation_mode_info,
1507 .get = f_midi2_operation_mode_get,
1508 };
1509
1510 /*
1511 * ALSA UMP instance creation / deletion
1512 */
f_midi2_free_card(struct f_midi2 * midi2)1513 static void f_midi2_free_card(struct f_midi2 *midi2)
1514 {
1515 if (midi2->card) {
1516 snd_card_free_when_closed(midi2->card);
1517 midi2->card = NULL;
1518 }
1519 }
1520
1521 /* use a reverse direction for the gadget host */
reverse_dir(int dir)1522 static int reverse_dir(int dir)
1523 {
1524 if (!dir || dir == SNDRV_UMP_DIR_BIDIRECTION)
1525 return dir;
1526 return (dir == SNDRV_UMP_DIR_OUTPUT) ?
1527 SNDRV_UMP_DIR_INPUT : SNDRV_UMP_DIR_OUTPUT;
1528 }
1529
f_midi2_create_card(struct f_midi2 * midi2)1530 static int f_midi2_create_card(struct f_midi2 *midi2)
1531 {
1532 struct snd_card *card;
1533 struct snd_ump_endpoint *ump;
1534 struct f_midi2_ep *ep;
1535 int i, id, blk, err;
1536 __be32 sw;
1537
1538 err = snd_card_new(&midi2->gadget->dev, -1, NULL, THIS_MODULE, 0,
1539 &card);
1540 if (err < 0)
1541 return err;
1542 midi2->card = card;
1543
1544 strcpy(card->driver, "f_midi2");
1545 strcpy(card->shortname, "MIDI 2.0 Gadget");
1546 strcpy(card->longname, "MIDI 2.0 Gadget");
1547
1548 id = 0;
1549 for (i = 0; i < midi2->num_eps; i++) {
1550 ep = &midi2->midi2_eps[i];
1551 err = snd_ump_endpoint_new(card, "MIDI 2.0 Gadget", id,
1552 1, 1, &ump);
1553 if (err < 0)
1554 goto error;
1555 id++;
1556
1557 ep->ump = ump;
1558 ump->no_process_stream = true;
1559 ump->private_data = ep;
1560 ump->ops = &f_midi2_ump_ops;
1561 if (midi2->info.static_block)
1562 ump->info.flags |= SNDRV_UMP_EP_INFO_STATIC_BLOCKS;
1563 ump->info.protocol_caps = (ep->info.protocol_caps & 3) << 8;
1564 ump->info.protocol = to_ump_protocol(ep->info.protocol);
1565 ump->info.version = 0x0101;
1566 ump->info.family_id = ep->info.family;
1567 ump->info.model_id = ep->info.model;
1568 ump->info.manufacturer_id = ep->info.manufacturer & 0xffffff;
1569 sw = cpu_to_be32(ep->info.sw_revision);
1570 memcpy(ump->info.sw_revision, &sw, 4);
1571
1572 strscpy(ump->info.name, ump_ep_name(ep),
1573 sizeof(ump->info.name));
1574 strscpy(ump->info.product_id, ump_product_id(ep),
1575 sizeof(ump->info.product_id));
1576 strscpy(ump->core.name, ump->info.name, sizeof(ump->core.name));
1577
1578 for (blk = 0; blk < ep->num_blks; blk++) {
1579 const struct f_midi2_block_info *b = &ep->blks[blk].info;
1580 struct snd_ump_block *fb;
1581
1582 err = snd_ump_block_new(ump, blk,
1583 reverse_dir(b->direction),
1584 b->first_group, b->num_groups,
1585 &ep->blks[blk].fb);
1586 if (err < 0)
1587 goto error;
1588 fb = ep->blks[blk].fb;
1589 fb->info.active = !!b->active;
1590 fb->info.midi_ci_version = b->midi_ci_version;
1591 fb->info.ui_hint = reverse_dir(b->ui_hint);
1592 fb->info.sysex8_streams = b->sysex8_streams;
1593 if (b->is_midi1 < 2)
1594 fb->info.flags |= b->is_midi1;
1595 else
1596 fb->info.flags |= SNDRV_UMP_BLOCK_IS_MIDI1 |
1597 SNDRV_UMP_BLOCK_IS_LOWSPEED;
1598 strscpy(fb->info.name, ump_fb_name(b),
1599 sizeof(fb->info.name));
1600 }
1601 snd_ump_update_group_attrs(ump);
1602 }
1603
1604 for (i = 0; i < midi2->num_eps; i++) {
1605 err = snd_ump_attach_legacy_rawmidi(midi2->midi2_eps[i].ump,
1606 "Legacy MIDI", id);
1607 if (err < 0)
1608 goto error;
1609 id++;
1610 }
1611
1612 err = snd_ctl_add(card, snd_ctl_new1(&operation_mode_ctl, midi2));
1613 if (err < 0)
1614 goto error;
1615
1616 err = snd_card_register(card);
1617 if (err < 0)
1618 goto error;
1619
1620 return 0;
1621
1622 error:
1623 f_midi2_free_card(midi2);
1624 return err;
1625 }
1626
1627 /*
1628 * Creation of USB descriptors
1629 */
1630 struct f_midi2_usb_config {
1631 struct usb_descriptor_header **list;
1632 unsigned int size;
1633 unsigned int alloc;
1634
1635 /* MIDI 1.0 jacks */
1636 unsigned char jack_in, jack_out, jack_id;
1637 struct usb_midi_in_jack_descriptor jack_ins[MAX_CABLES];
1638 struct usb_midi_out_jack_descriptor_1 jack_outs[MAX_CABLES];
1639 };
1640
append_config(struct f_midi2_usb_config * config,void * d)1641 static int append_config(struct f_midi2_usb_config *config, void *d)
1642 {
1643 unsigned int size;
1644 void *buf;
1645
1646 if (config->size + 2 >= config->alloc) {
1647 size = config->size + 16;
1648 buf = krealloc(config->list, size * sizeof(void *), GFP_KERNEL);
1649 if (!buf)
1650 return -ENOMEM;
1651 config->list = buf;
1652 config->alloc = size;
1653 }
1654
1655 config->list[config->size] = d;
1656 config->size++;
1657 config->list[config->size] = NULL;
1658 return 0;
1659 }
1660
append_configs(struct f_midi2_usb_config * config,void ** d)1661 static int append_configs(struct f_midi2_usb_config *config, void **d)
1662 {
1663 int err;
1664
1665 for (; *d; d++) {
1666 err = append_config(config, *d);
1667 if (err)
1668 return err;
1669 }
1670 return 0;
1671 }
1672
append_midi1_in_jack(struct f_midi2 * midi2,struct f_midi2_usb_config * config,struct midi1_cable_mapping * map,unsigned int type)1673 static int append_midi1_in_jack(struct f_midi2 *midi2,
1674 struct f_midi2_usb_config *config,
1675 struct midi1_cable_mapping *map,
1676 unsigned int type)
1677 {
1678 struct usb_midi_in_jack_descriptor *jack =
1679 &config->jack_ins[config->jack_in++];
1680 int id = ++config->jack_id;
1681 int err;
1682
1683 jack->bLength = 0x06;
1684 jack->bDescriptorType = USB_DT_CS_INTERFACE;
1685 jack->bDescriptorSubtype = USB_MS_MIDI_IN_JACK;
1686 jack->bJackType = type;
1687 jack->bJackID = id;
1688 /* use the corresponding block name as jack name */
1689 if (map->ep)
1690 jack->iJack = map->ep->blks[map->block].string_id;
1691
1692 err = append_config(config, jack);
1693 if (err < 0)
1694 return err;
1695 return id;
1696 }
1697
append_midi1_out_jack(struct f_midi2 * midi2,struct f_midi2_usb_config * config,struct midi1_cable_mapping * map,unsigned int type,unsigned int source)1698 static int append_midi1_out_jack(struct f_midi2 *midi2,
1699 struct f_midi2_usb_config *config,
1700 struct midi1_cable_mapping *map,
1701 unsigned int type, unsigned int source)
1702 {
1703 struct usb_midi_out_jack_descriptor_1 *jack =
1704 &config->jack_outs[config->jack_out++];
1705 int id = ++config->jack_id;
1706 int err;
1707
1708 jack->bLength = 0x09;
1709 jack->bDescriptorType = USB_DT_CS_INTERFACE;
1710 jack->bDescriptorSubtype = USB_MS_MIDI_OUT_JACK;
1711 jack->bJackType = type;
1712 jack->bJackID = id;
1713 jack->bNrInputPins = 1;
1714 jack->pins[0].baSourceID = source;
1715 jack->pins[0].baSourcePin = 0x01;
1716 /* use the corresponding block name as jack name */
1717 if (map->ep)
1718 jack->iJack = map->ep->blks[map->block].string_id;
1719
1720 err = append_config(config, jack);
1721 if (err < 0)
1722 return err;
1723 return id;
1724 }
1725
f_midi2_create_usb_configs(struct f_midi2 * midi2,struct f_midi2_usb_config * config,int speed)1726 static int f_midi2_create_usb_configs(struct f_midi2 *midi2,
1727 struct f_midi2_usb_config *config,
1728 int speed)
1729 {
1730 void **midi1_in_eps, **midi1_out_eps;
1731 int i, jack, total;
1732 int err;
1733
1734 switch (speed) {
1735 default:
1736 case USB_SPEED_HIGH:
1737 midi2_midi1_ep_out_desc.wMaxPacketSize = cpu_to_le16(512);
1738 midi2_midi1_ep_in_desc.wMaxPacketSize = cpu_to_le16(512);
1739 for (i = 0; i < midi2->num_eps; i++) {
1740 midi2_midi2_ep_out_desc[i].wMaxPacketSize =
1741 cpu_to_le16(512);
1742 midi2_midi2_ep_in_desc[i].wMaxPacketSize =
1743 cpu_to_le16(512);
1744 }
1745 fallthrough;
1746 case USB_SPEED_FULL:
1747 midi1_in_eps = midi2_midi1_ep_in_descs;
1748 midi1_out_eps = midi2_midi1_ep_out_descs;
1749 break;
1750 case USB_SPEED_SUPER:
1751 midi2_midi1_ep_out_desc.wMaxPacketSize = cpu_to_le16(1024);
1752 midi2_midi1_ep_in_desc.wMaxPacketSize = cpu_to_le16(1024);
1753 for (i = 0; i < midi2->num_eps; i++) {
1754 midi2_midi2_ep_out_desc[i].wMaxPacketSize =
1755 cpu_to_le16(1024);
1756 midi2_midi2_ep_in_desc[i].wMaxPacketSize =
1757 cpu_to_le16(1024);
1758 }
1759 midi1_in_eps = midi2_midi1_ep_in_ss_descs;
1760 midi1_out_eps = midi2_midi1_ep_out_ss_descs;
1761 break;
1762 }
1763
1764 err = append_configs(config, midi2_audio_descs);
1765 if (err < 0)
1766 return err;
1767
1768 if (midi2->num_midi1_in && midi2->num_midi1_out)
1769 midi2_midi1_if_desc.bNumEndpoints = 2;
1770 else
1771 midi2_midi1_if_desc.bNumEndpoints = 1;
1772
1773 err = append_configs(config, midi2_midi1_descs);
1774 if (err < 0)
1775 return err;
1776
1777 total = USB_DT_MS_HEADER_SIZE;
1778 if (midi2->num_midi1_out) {
1779 midi2_midi1_ep_out_class_desc.bLength =
1780 USB_DT_MS_ENDPOINT_SIZE(midi2->num_midi1_out);
1781 total += midi2_midi1_ep_out_class_desc.bLength;
1782 midi2_midi1_ep_out_class_desc.bNumEmbMIDIJack =
1783 midi2->num_midi1_out;
1784 total += midi2->num_midi1_out *
1785 (USB_DT_MIDI_IN_SIZE + USB_DT_MIDI_OUT_SIZE(1));
1786 for (i = 0; i < midi2->num_midi1_out; i++) {
1787 jack = append_midi1_in_jack(midi2, config,
1788 &midi2->in_cable_mapping[i],
1789 USB_MS_EMBEDDED);
1790 if (jack < 0)
1791 return jack;
1792 midi2_midi1_ep_out_class_desc.baAssocJackID[i] = jack;
1793 jack = append_midi1_out_jack(midi2, config,
1794 &midi2->in_cable_mapping[i],
1795 USB_MS_EXTERNAL, jack);
1796 if (jack < 0)
1797 return jack;
1798 }
1799 }
1800
1801 if (midi2->num_midi1_in) {
1802 midi2_midi1_ep_in_class_desc.bLength =
1803 USB_DT_MS_ENDPOINT_SIZE(midi2->num_midi1_in);
1804 total += midi2_midi1_ep_in_class_desc.bLength;
1805 midi2_midi1_ep_in_class_desc.bNumEmbMIDIJack =
1806 midi2->num_midi1_in;
1807 total += midi2->num_midi1_in *
1808 (USB_DT_MIDI_IN_SIZE + USB_DT_MIDI_OUT_SIZE(1));
1809 for (i = 0; i < midi2->num_midi1_in; i++) {
1810 jack = append_midi1_in_jack(midi2, config,
1811 &midi2->out_cable_mapping[i],
1812 USB_MS_EXTERNAL);
1813 if (jack < 0)
1814 return jack;
1815 jack = append_midi1_out_jack(midi2, config,
1816 &midi2->out_cable_mapping[i],
1817 USB_MS_EMBEDDED, jack);
1818 if (jack < 0)
1819 return jack;
1820 midi2_midi1_ep_in_class_desc.baAssocJackID[i] = jack;
1821 }
1822 }
1823
1824 midi2_midi1_class_desc.wTotalLength = cpu_to_le16(total);
1825
1826 if (midi2->num_midi1_out) {
1827 err = append_configs(config, midi1_out_eps);
1828 if (err < 0)
1829 return err;
1830 }
1831 if (midi2->num_midi1_in) {
1832 err = append_configs(config, midi1_in_eps);
1833 if (err < 0)
1834 return err;
1835 }
1836
1837 err = append_configs(config, midi2_midi2_descs);
1838 if (err < 0)
1839 return err;
1840
1841 for (i = 0; i < midi2->num_eps; i++) {
1842 err = append_config(config, &midi2_midi2_ep_out_desc[i]);
1843 if (err < 0)
1844 return err;
1845 if (speed == USB_SPEED_SUPER || speed == USB_SPEED_SUPER_PLUS) {
1846 err = append_config(config, &midi2_midi2_ep_out_ss_comp_desc);
1847 if (err < 0)
1848 return err;
1849 }
1850 err = append_config(config, &midi2_midi2_ep_out_class_desc[i]);
1851 if (err < 0)
1852 return err;
1853 err = append_config(config, &midi2_midi2_ep_in_desc[i]);
1854 if (err < 0)
1855 return err;
1856 if (speed == USB_SPEED_SUPER || speed == USB_SPEED_SUPER_PLUS) {
1857 err = append_config(config, &midi2_midi2_ep_in_ss_comp_desc);
1858 if (err < 0)
1859 return err;
1860 }
1861 err = append_config(config, &midi2_midi2_ep_in_class_desc[i]);
1862 if (err < 0)
1863 return err;
1864 }
1865
1866 return 0;
1867 }
1868
f_midi2_free_usb_configs(struct f_midi2_usb_config * config)1869 static void f_midi2_free_usb_configs(struct f_midi2_usb_config *config)
1870 {
1871 kfree(config->list);
1872 memset(config, 0, sizeof(*config));
1873 }
1874
1875 /* as we use the static descriptors for simplicity, serialize bind call */
1876 static DEFINE_MUTEX(f_midi2_desc_mutex);
1877
1878 /* fill MIDI2 EP class-specific descriptor */
fill_midi2_class_desc(struct f_midi2_ep * ep,struct usb_ms20_endpoint_descriptor_32 * cdesc)1879 static void fill_midi2_class_desc(struct f_midi2_ep *ep,
1880 struct usb_ms20_endpoint_descriptor_32 *cdesc)
1881 {
1882 int blk;
1883
1884 cdesc->bLength = USB_DT_MS20_ENDPOINT_SIZE(ep->num_blks);
1885 cdesc->bDescriptorType = USB_DT_CS_ENDPOINT;
1886 cdesc->bDescriptorSubtype = USB_MS_GENERAL_2_0;
1887 cdesc->bNumGrpTrmBlock = ep->num_blks;
1888 for (blk = 0; blk < ep->num_blks; blk++)
1889 cdesc->baAssoGrpTrmBlkID[blk] = ep->blks[blk].gtb_id;
1890 }
1891
1892 /* initialize MIDI2 EP-in */
f_midi2_init_midi2_ep_in(struct f_midi2 * midi2,int index)1893 static int f_midi2_init_midi2_ep_in(struct f_midi2 *midi2, int index)
1894 {
1895 struct f_midi2_ep *ep = &midi2->midi2_eps[index];
1896 struct usb_endpoint_descriptor *desc = &midi2_midi2_ep_in_desc[index];
1897
1898 desc->bLength = USB_DT_ENDPOINT_SIZE;
1899 desc->bDescriptorType = USB_DT_ENDPOINT;
1900 desc->bEndpointAddress = USB_DIR_IN;
1901 desc->bmAttributes = USB_ENDPOINT_XFER_INT;
1902 desc->wMaxPacketSize = cpu_to_le16(EP_MAX_PACKET_INT);
1903 desc->bInterval = 1;
1904
1905 fill_midi2_class_desc(ep, &midi2_midi2_ep_in_class_desc[index]);
1906
1907 return f_midi2_init_ep(midi2, ep, &ep->ep_in, desc,
1908 f_midi2_ep_in_complete);
1909 }
1910
1911 /* initialize MIDI2 EP-out */
f_midi2_init_midi2_ep_out(struct f_midi2 * midi2,int index)1912 static int f_midi2_init_midi2_ep_out(struct f_midi2 *midi2, int index)
1913 {
1914 struct f_midi2_ep *ep = &midi2->midi2_eps[index];
1915 struct usb_endpoint_descriptor *desc = &midi2_midi2_ep_out_desc[index];
1916
1917 desc->bLength = USB_DT_ENDPOINT_SIZE;
1918 desc->bDescriptorType = USB_DT_ENDPOINT;
1919 desc->bEndpointAddress = USB_DIR_OUT;
1920 desc->bmAttributes = USB_ENDPOINT_XFER_BULK;
1921
1922 fill_midi2_class_desc(ep, &midi2_midi2_ep_out_class_desc[index]);
1923
1924 return f_midi2_init_ep(midi2, ep, &ep->ep_out, desc,
1925 f_midi2_ep_out_complete);
1926 }
1927
1928 /* gadget function bind callback */
f_midi2_bind(struct usb_configuration * c,struct usb_function * f)1929 static int f_midi2_bind(struct usb_configuration *c, struct usb_function *f)
1930 {
1931 struct usb_composite_dev *cdev = c->cdev;
1932 struct f_midi2 *midi2 = func_to_midi2(f);
1933 struct f_midi2_ep *ep;
1934 struct f_midi2_usb_config config = {};
1935 struct usb_gadget_strings string_fn = {
1936 .language = 0x0409, /* en-us */
1937 .strings = midi2->string_defs,
1938 };
1939 struct usb_gadget_strings *strings[] = {
1940 &string_fn,
1941 NULL,
1942 };
1943 int i, blk, status;
1944
1945 midi2->gadget = cdev->gadget;
1946 midi2->operation_mode = MIDI_OP_MODE_UNSET;
1947
1948 status = f_midi2_create_card(midi2);
1949 if (status < 0)
1950 goto fail_register;
1951
1952 /* maybe allocate device-global string ID */
1953 midi2->strings = usb_gstrings_attach(c->cdev, strings,
1954 midi2->total_blocks + 1);
1955 if (IS_ERR(midi2->strings)) {
1956 status = PTR_ERR(midi2->strings);
1957 goto fail_string;
1958 }
1959
1960 mutex_lock(&f_midi2_desc_mutex);
1961 midi2_midi1_if_desc.iInterface = midi2->strings[STR_IFACE].id;
1962 midi2_midi2_if_desc.iInterface = midi2->strings[STR_IFACE].id;
1963 for (i = 0; i < midi2->num_eps; i++) {
1964 ep = &midi2->midi2_eps[i];
1965 for (blk = 0; blk < ep->num_blks; blk++)
1966 ep->blks[blk].string_id =
1967 midi2->strings[gtb_to_str_id(ep->blks[blk].gtb_id)].id;
1968 }
1969
1970 midi2_midi2_if_desc.bNumEndpoints = midi2->num_eps * 2;
1971
1972 /* audio interface */
1973 status = usb_interface_id(c, f);
1974 if (status < 0)
1975 goto fail;
1976 midi2_audio_if_desc.bInterfaceNumber = status;
1977
1978 /* MIDI streaming */
1979 status = usb_interface_id(c, f);
1980 if (status < 0)
1981 goto fail;
1982 midi2->midi_if = status;
1983 midi2_midi1_if_desc.bInterfaceNumber = status;
1984 midi2_midi2_if_desc.bInterfaceNumber = status;
1985 midi2_audio_class_desc.baInterfaceNr[0] = status;
1986
1987 /* allocate instance-specific endpoints */
1988 if (midi2->midi2_eps[0].blks[0].info.direction != SNDRV_UMP_DIR_OUTPUT) {
1989 status = f_midi2_init_ep(midi2, NULL, &midi2->midi1_ep_in,
1990 &midi2_midi1_ep_in_desc,
1991 f_midi2_midi1_ep_in_complete);
1992 if (status)
1993 goto fail;
1994 }
1995
1996 if (midi2->midi2_eps[0].blks[0].info.direction != SNDRV_UMP_DIR_INPUT) {
1997 status = f_midi2_init_ep(midi2, NULL, &midi2->midi1_ep_out,
1998 &midi2_midi1_ep_out_desc,
1999 f_midi2_midi1_ep_out_complete);
2000 if (status)
2001 goto fail;
2002 }
2003
2004 for (i = 0; i < midi2->num_eps; i++) {
2005 status = f_midi2_init_midi2_ep_in(midi2, i);
2006 if (status)
2007 goto fail;
2008 status = f_midi2_init_midi2_ep_out(midi2, i);
2009 if (status)
2010 goto fail;
2011 }
2012
2013 status = f_midi2_create_usb_configs(midi2, &config, USB_SPEED_FULL);
2014 if (status < 0)
2015 goto fail;
2016 f->fs_descriptors = usb_copy_descriptors(config.list);
2017 if (!f->fs_descriptors) {
2018 status = -ENOMEM;
2019 goto fail;
2020 }
2021 f_midi2_free_usb_configs(&config);
2022
2023 status = f_midi2_create_usb_configs(midi2, &config, USB_SPEED_HIGH);
2024 if (status < 0)
2025 goto fail;
2026 f->hs_descriptors = usb_copy_descriptors(config.list);
2027 if (!f->hs_descriptors) {
2028 status = -ENOMEM;
2029 goto fail;
2030 }
2031 f_midi2_free_usb_configs(&config);
2032
2033 status = f_midi2_create_usb_configs(midi2, &config, USB_SPEED_SUPER);
2034 if (status < 0)
2035 goto fail;
2036 f->ss_descriptors = usb_copy_descriptors(config.list);
2037 if (!f->ss_descriptors) {
2038 status = -ENOMEM;
2039 goto fail;
2040 }
2041 f_midi2_free_usb_configs(&config);
2042
2043 mutex_unlock(&f_midi2_desc_mutex);
2044 return 0;
2045
2046 fail:
2047 f_midi2_free_usb_configs(&config);
2048 mutex_unlock(&f_midi2_desc_mutex);
2049 usb_free_all_descriptors(f);
2050 fail_string:
2051 f_midi2_free_card(midi2);
2052 fail_register:
2053 ERROR(midi2, "%s: can't bind, err %d\n", f->name, status);
2054 return status;
2055 }
2056
2057 /* gadget function unbind callback */
f_midi2_unbind(struct usb_configuration * c,struct usb_function * f)2058 static void f_midi2_unbind(struct usb_configuration *c, struct usb_function *f)
2059 {
2060 struct f_midi2 *midi2 = func_to_midi2(f);
2061 int i;
2062
2063 f_midi2_free_card(midi2);
2064
2065 f_midi2_free_ep(&midi2->midi1_ep_in);
2066 f_midi2_free_ep(&midi2->midi1_ep_out);
2067 for (i = 0; i < midi2->num_eps; i++) {
2068 f_midi2_free_ep(&midi2->midi2_eps[i].ep_in);
2069 f_midi2_free_ep(&midi2->midi2_eps[i].ep_out);
2070 }
2071
2072 usb_free_all_descriptors(f);
2073 }
2074
2075 /*
2076 * ConfigFS interface
2077 */
2078
2079 /* type conversion helpers */
to_f_midi2_opts(struct config_item * item)2080 static inline struct f_midi2_opts *to_f_midi2_opts(struct config_item *item)
2081 {
2082 return container_of(to_config_group(item), struct f_midi2_opts,
2083 func_inst.group);
2084 }
2085
2086 static inline struct f_midi2_ep_opts *
to_f_midi2_ep_opts(struct config_item * item)2087 to_f_midi2_ep_opts(struct config_item *item)
2088 {
2089 return container_of(to_config_group(item), struct f_midi2_ep_opts,
2090 group);
2091 }
2092
2093 static inline struct f_midi2_block_opts *
to_f_midi2_block_opts(struct config_item * item)2094 to_f_midi2_block_opts(struct config_item *item)
2095 {
2096 return container_of(to_config_group(item), struct f_midi2_block_opts,
2097 group);
2098 }
2099
2100 /* trim the string to be usable for EP and FB name strings */
make_name_string(char * s)2101 static void make_name_string(char *s)
2102 {
2103 char *p;
2104
2105 p = strchr(s, '\n');
2106 if (p)
2107 *p = 0;
2108
2109 p = s + strlen(s);
2110 for (; p > s && isspace(*p); p--)
2111 *p = 0;
2112 }
2113
2114 /* configfs helpers: generic show/store for unisnged int */
f_midi2_opts_uint_show(struct f_midi2_opts * opts,u32 val,const char * format,char * page)2115 static ssize_t f_midi2_opts_uint_show(struct f_midi2_opts *opts,
2116 u32 val, const char *format, char *page)
2117 {
2118 int result;
2119
2120 mutex_lock(&opts->lock);
2121 result = sprintf(page, format, val);
2122 mutex_unlock(&opts->lock);
2123 return result;
2124 }
2125
f_midi2_opts_uint_store(struct f_midi2_opts * opts,u32 * valp,u32 minval,u32 maxval,const char * page,size_t len)2126 static ssize_t f_midi2_opts_uint_store(struct f_midi2_opts *opts,
2127 u32 *valp, u32 minval, u32 maxval,
2128 const char *page, size_t len)
2129 {
2130 int ret;
2131 u32 val;
2132
2133 mutex_lock(&opts->lock);
2134 if (opts->refcnt) {
2135 ret = -EBUSY;
2136 goto end;
2137 }
2138
2139 ret = kstrtou32(page, 0, &val);
2140 if (ret)
2141 goto end;
2142 if (val < minval || val > maxval) {
2143 ret = -EINVAL;
2144 goto end;
2145 }
2146
2147 *valp = val;
2148 ret = len;
2149
2150 end:
2151 mutex_unlock(&opts->lock);
2152 return ret;
2153 }
2154
2155 /* generic store for bool */
f_midi2_opts_bool_store(struct f_midi2_opts * opts,bool * valp,const char * page,size_t len)2156 static ssize_t f_midi2_opts_bool_store(struct f_midi2_opts *opts,
2157 bool *valp, const char *page, size_t len)
2158 {
2159 int ret;
2160 bool val;
2161
2162 mutex_lock(&opts->lock);
2163 if (opts->refcnt) {
2164 ret = -EBUSY;
2165 goto end;
2166 }
2167
2168 ret = kstrtobool(page, &val);
2169 if (ret)
2170 goto end;
2171 *valp = val;
2172 ret = len;
2173
2174 end:
2175 mutex_unlock(&opts->lock);
2176 return ret;
2177 }
2178
2179 /* generic show/store for string */
f_midi2_opts_str_show(struct f_midi2_opts * opts,const char * str,char * page)2180 static ssize_t f_midi2_opts_str_show(struct f_midi2_opts *opts,
2181 const char *str, char *page)
2182 {
2183 int result = 0;
2184
2185 mutex_lock(&opts->lock);
2186 if (str)
2187 result = scnprintf(page, PAGE_SIZE, "%s\n", str);
2188 mutex_unlock(&opts->lock);
2189 return result;
2190 }
2191
f_midi2_opts_str_store(struct f_midi2_opts * opts,const char ** strp,size_t maxlen,const char * page,size_t len)2192 static ssize_t f_midi2_opts_str_store(struct f_midi2_opts *opts,
2193 const char **strp, size_t maxlen,
2194 const char *page, size_t len)
2195 {
2196 char *c;
2197 int ret;
2198
2199 mutex_lock(&opts->lock);
2200 if (opts->refcnt) {
2201 ret = -EBUSY;
2202 goto end;
2203 }
2204
2205 c = kstrndup(page, min(len, maxlen), GFP_KERNEL);
2206 if (!c) {
2207 ret = -ENOMEM;
2208 goto end;
2209 }
2210
2211 kfree(*strp);
2212 make_name_string(c);
2213 *strp = c;
2214 ret = len;
2215
2216 end:
2217 mutex_unlock(&opts->lock);
2218 return ret;
2219 }
2220
2221 /*
2222 * Definitions for UMP Block config
2223 */
2224
2225 /* define an uint option for block */
2226 #define F_MIDI2_BLOCK_OPT(name, format, minval, maxval) \
2227 static ssize_t f_midi2_block_opts_##name##_show(struct config_item *item,\
2228 char *page) \
2229 { \
2230 struct f_midi2_block_opts *opts = to_f_midi2_block_opts(item); \
2231 return f_midi2_opts_uint_show(opts->ep->opts, opts->info.name, \
2232 format "\n", page); \
2233 } \
2234 \
2235 static ssize_t f_midi2_block_opts_##name##_store(struct config_item *item,\
2236 const char *page, size_t len) \
2237 { \
2238 struct f_midi2_block_opts *opts = to_f_midi2_block_opts(item); \
2239 return f_midi2_opts_uint_store(opts->ep->opts, &opts->info.name,\
2240 minval, maxval, page, len); \
2241 } \
2242 \
2243 CONFIGFS_ATTR(f_midi2_block_opts_, name)
2244
2245 /* define a boolean option for block */
2246 #define F_MIDI2_BLOCK_BOOL_OPT(name) \
2247 static ssize_t f_midi2_block_opts_##name##_show(struct config_item *item,\
2248 char *page) \
2249 { \
2250 struct f_midi2_block_opts *opts = to_f_midi2_block_opts(item); \
2251 return f_midi2_opts_uint_show(opts->ep->opts, opts->info.name, \
2252 "%u\n", page); \
2253 } \
2254 \
2255 static ssize_t f_midi2_block_opts_##name##_store(struct config_item *item,\
2256 const char *page, size_t len) \
2257 { \
2258 struct f_midi2_block_opts *opts = to_f_midi2_block_opts(item); \
2259 return f_midi2_opts_bool_store(opts->ep->opts, &opts->info.name,\
2260 page, len); \
2261 } \
2262 \
2263 CONFIGFS_ATTR(f_midi2_block_opts_, name)
2264
2265 F_MIDI2_BLOCK_OPT(direction, "0x%x", 1, 3);
2266 F_MIDI2_BLOCK_OPT(first_group, "0x%x", 0, 15);
2267 F_MIDI2_BLOCK_OPT(num_groups, "0x%x", 1, 16);
2268 F_MIDI2_BLOCK_OPT(midi1_first_group, "0x%x", 0, 15);
2269 F_MIDI2_BLOCK_OPT(midi1_num_groups, "0x%x", 0, 16);
2270 F_MIDI2_BLOCK_OPT(ui_hint, "0x%x", 0, 3);
2271 F_MIDI2_BLOCK_OPT(midi_ci_version, "%u", 0, 1);
2272 F_MIDI2_BLOCK_OPT(sysex8_streams, "%u", 0, 255);
2273 F_MIDI2_BLOCK_OPT(is_midi1, "%u", 0, 2);
2274 F_MIDI2_BLOCK_BOOL_OPT(active);
2275
f_midi2_block_opts_name_show(struct config_item * item,char * page)2276 static ssize_t f_midi2_block_opts_name_show(struct config_item *item,
2277 char *page)
2278 {
2279 struct f_midi2_block_opts *opts = to_f_midi2_block_opts(item);
2280
2281 return f_midi2_opts_str_show(opts->ep->opts, opts->info.name, page);
2282 }
2283
f_midi2_block_opts_name_store(struct config_item * item,const char * page,size_t len)2284 static ssize_t f_midi2_block_opts_name_store(struct config_item *item,
2285 const char *page, size_t len)
2286 {
2287 struct f_midi2_block_opts *opts = to_f_midi2_block_opts(item);
2288
2289 return f_midi2_opts_str_store(opts->ep->opts, &opts->info.name, 128,
2290 page, len);
2291 }
2292
2293 CONFIGFS_ATTR(f_midi2_block_opts_, name);
2294
2295 static struct configfs_attribute *f_midi2_block_attrs[] = {
2296 &f_midi2_block_opts_attr_direction,
2297 &f_midi2_block_opts_attr_first_group,
2298 &f_midi2_block_opts_attr_num_groups,
2299 &f_midi2_block_opts_attr_midi1_first_group,
2300 &f_midi2_block_opts_attr_midi1_num_groups,
2301 &f_midi2_block_opts_attr_ui_hint,
2302 &f_midi2_block_opts_attr_midi_ci_version,
2303 &f_midi2_block_opts_attr_sysex8_streams,
2304 &f_midi2_block_opts_attr_is_midi1,
2305 &f_midi2_block_opts_attr_active,
2306 &f_midi2_block_opts_attr_name,
2307 NULL,
2308 };
2309
f_midi2_block_opts_release(struct config_item * item)2310 static void f_midi2_block_opts_release(struct config_item *item)
2311 {
2312 struct f_midi2_block_opts *opts = to_f_midi2_block_opts(item);
2313
2314 kfree(opts->info.name);
2315 kfree(opts);
2316 }
2317
2318 static const struct configfs_item_operations f_midi2_block_item_ops = {
2319 .release = f_midi2_block_opts_release,
2320 };
2321
2322 static const struct config_item_type f_midi2_block_type = {
2323 .ct_item_ops = &f_midi2_block_item_ops,
2324 .ct_attrs = f_midi2_block_attrs,
2325 .ct_owner = THIS_MODULE,
2326 };
2327
2328 /* create a f_midi2_block_opts instance for the given block number */
f_midi2_block_opts_create(struct f_midi2_ep_opts * ep_opts,unsigned int blk,struct f_midi2_block_opts ** block_p)2329 static int f_midi2_block_opts_create(struct f_midi2_ep_opts *ep_opts,
2330 unsigned int blk,
2331 struct f_midi2_block_opts **block_p)
2332 {
2333 struct f_midi2_block_opts *block_opts;
2334 int ret = 0;
2335
2336 mutex_lock(&ep_opts->opts->lock);
2337 if (ep_opts->opts->refcnt || ep_opts->blks[blk]) {
2338 ret = -EBUSY;
2339 goto out;
2340 }
2341
2342 block_opts = kzalloc_obj(*block_opts);
2343 if (!block_opts) {
2344 ret = -ENOMEM;
2345 goto out;
2346 }
2347
2348 block_opts->ep = ep_opts;
2349 block_opts->id = blk;
2350
2351 /* set up the default values */
2352 block_opts->info.direction = SNDRV_UMP_DIR_BIDIRECTION;
2353 block_opts->info.first_group = 0;
2354 block_opts->info.num_groups = 1;
2355 block_opts->info.ui_hint = SNDRV_UMP_BLOCK_UI_HINT_BOTH;
2356 block_opts->info.active = 1;
2357
2358 ep_opts->blks[blk] = block_opts;
2359 *block_p = block_opts;
2360
2361 out:
2362 mutex_unlock(&ep_opts->opts->lock);
2363 return ret;
2364 }
2365
2366 /* make_group callback for a block */
2367 static struct config_group *
f_midi2_opts_block_make(struct config_group * group,const char * name)2368 f_midi2_opts_block_make(struct config_group *group, const char *name)
2369 {
2370 struct f_midi2_ep_opts *ep_opts;
2371 struct f_midi2_block_opts *block_opts;
2372 unsigned int blk;
2373 int ret;
2374
2375 if (strncmp(name, "block.", 6))
2376 return ERR_PTR(-EINVAL);
2377 ret = kstrtouint(name + 6, 10, &blk);
2378 if (ret)
2379 return ERR_PTR(ret);
2380
2381 ep_opts = to_f_midi2_ep_opts(&group->cg_item);
2382
2383 if (blk >= SNDRV_UMP_MAX_BLOCKS)
2384 return ERR_PTR(-EINVAL);
2385 if (ep_opts->blks[blk])
2386 return ERR_PTR(-EBUSY);
2387 ret = f_midi2_block_opts_create(ep_opts, blk, &block_opts);
2388 if (ret)
2389 return ERR_PTR(ret);
2390
2391 config_group_init_type_name(&block_opts->group, name,
2392 &f_midi2_block_type);
2393 return &block_opts->group;
2394 }
2395
2396 /* drop_item callback for a block */
2397 static void
f_midi2_opts_block_drop(struct config_group * group,struct config_item * item)2398 f_midi2_opts_block_drop(struct config_group *group, struct config_item *item)
2399 {
2400 struct f_midi2_block_opts *block_opts = to_f_midi2_block_opts(item);
2401
2402 mutex_lock(&block_opts->ep->opts->lock);
2403 block_opts->ep->blks[block_opts->id] = NULL;
2404 mutex_unlock(&block_opts->ep->opts->lock);
2405 config_item_put(item);
2406 }
2407
2408 /*
2409 * Definitions for UMP Endpoint config
2410 */
2411
2412 /* define an uint option for EP */
2413 #define F_MIDI2_EP_OPT(name, format, minval, maxval) \
2414 static ssize_t f_midi2_ep_opts_##name##_show(struct config_item *item, \
2415 char *page) \
2416 { \
2417 struct f_midi2_ep_opts *opts = to_f_midi2_ep_opts(item); \
2418 return f_midi2_opts_uint_show(opts->opts, opts->info.name, \
2419 format "\n", page); \
2420 } \
2421 \
2422 static ssize_t f_midi2_ep_opts_##name##_store(struct config_item *item, \
2423 const char *page, size_t len)\
2424 { \
2425 struct f_midi2_ep_opts *opts = to_f_midi2_ep_opts(item); \
2426 return f_midi2_opts_uint_store(opts->opts, &opts->info.name, \
2427 minval, maxval, page, len); \
2428 } \
2429 \
2430 CONFIGFS_ATTR(f_midi2_ep_opts_, name)
2431
2432 /* define a string option for EP */
2433 #define F_MIDI2_EP_STR_OPT(name, maxlen) \
2434 static ssize_t f_midi2_ep_opts_##name##_show(struct config_item *item, \
2435 char *page) \
2436 { \
2437 struct f_midi2_ep_opts *opts = to_f_midi2_ep_opts(item); \
2438 return f_midi2_opts_str_show(opts->opts, opts->info.name, page);\
2439 } \
2440 \
2441 static ssize_t f_midi2_ep_opts_##name##_store(struct config_item *item, \
2442 const char *page, size_t len) \
2443 { \
2444 struct f_midi2_ep_opts *opts = to_f_midi2_ep_opts(item); \
2445 return f_midi2_opts_str_store(opts->opts, &opts->info.name, maxlen,\
2446 page, len); \
2447 } \
2448 \
2449 CONFIGFS_ATTR(f_midi2_ep_opts_, name)
2450
2451 F_MIDI2_EP_OPT(protocol, "0x%x", 1, 2);
2452 F_MIDI2_EP_OPT(protocol_caps, "0x%x", 1, 3);
2453 F_MIDI2_EP_OPT(manufacturer, "0x%x", 0, 0xffffff);
2454 F_MIDI2_EP_OPT(family, "0x%x", 0, 0xffff);
2455 F_MIDI2_EP_OPT(model, "0x%x", 0, 0xffff);
2456 F_MIDI2_EP_OPT(sw_revision, "0x%x", 0, 0xffffffff);
2457 F_MIDI2_EP_STR_OPT(ep_name, 128);
2458 F_MIDI2_EP_STR_OPT(product_id, 128);
2459
2460 static struct configfs_attribute *f_midi2_ep_attrs[] = {
2461 &f_midi2_ep_opts_attr_protocol,
2462 &f_midi2_ep_opts_attr_protocol_caps,
2463 &f_midi2_ep_opts_attr_ep_name,
2464 &f_midi2_ep_opts_attr_product_id,
2465 &f_midi2_ep_opts_attr_manufacturer,
2466 &f_midi2_ep_opts_attr_family,
2467 &f_midi2_ep_opts_attr_model,
2468 &f_midi2_ep_opts_attr_sw_revision,
2469 NULL,
2470 };
2471
f_midi2_ep_opts_release(struct config_item * item)2472 static void f_midi2_ep_opts_release(struct config_item *item)
2473 {
2474 struct f_midi2_ep_opts *opts = to_f_midi2_ep_opts(item);
2475
2476 kfree(opts->info.ep_name);
2477 kfree(opts->info.product_id);
2478 kfree(opts);
2479 }
2480
2481 static const struct configfs_item_operations f_midi2_ep_item_ops = {
2482 .release = f_midi2_ep_opts_release,
2483 };
2484
2485 static const struct configfs_group_operations f_midi2_ep_group_ops = {
2486 .make_group = f_midi2_opts_block_make,
2487 .drop_item = f_midi2_opts_block_drop,
2488 };
2489
2490 static const struct config_item_type f_midi2_ep_type = {
2491 .ct_item_ops = &f_midi2_ep_item_ops,
2492 .ct_group_ops = &f_midi2_ep_group_ops,
2493 .ct_attrs = f_midi2_ep_attrs,
2494 .ct_owner = THIS_MODULE,
2495 };
2496
2497 /* create a f_midi2_ep_opts instance */
f_midi2_ep_opts_create(struct f_midi2_opts * opts,unsigned int index,struct f_midi2_ep_opts ** ep_p)2498 static int f_midi2_ep_opts_create(struct f_midi2_opts *opts,
2499 unsigned int index,
2500 struct f_midi2_ep_opts **ep_p)
2501 {
2502 struct f_midi2_ep_opts *ep_opts;
2503
2504 ep_opts = kzalloc_obj(*ep_opts);
2505 if (!ep_opts)
2506 return -ENOMEM;
2507
2508 ep_opts->opts = opts;
2509 ep_opts->index = index;
2510
2511 /* set up the default values */
2512 ep_opts->info.protocol = 2;
2513 ep_opts->info.protocol_caps = 3;
2514
2515 opts->eps[index] = ep_opts;
2516 *ep_p = ep_opts;
2517 return 0;
2518 }
2519
2520 /* make_group callback for an EP */
2521 static struct config_group *
f_midi2_opts_ep_make(struct config_group * group,const char * name)2522 f_midi2_opts_ep_make(struct config_group *group, const char *name)
2523 {
2524 struct f_midi2_opts *opts;
2525 struct f_midi2_ep_opts *ep_opts;
2526 unsigned int index;
2527 int ret;
2528
2529 if (strncmp(name, "ep.", 3))
2530 return ERR_PTR(-EINVAL);
2531 ret = kstrtouint(name + 3, 10, &index);
2532 if (ret)
2533 return ERR_PTR(ret);
2534
2535 opts = to_f_midi2_opts(&group->cg_item);
2536 if (index >= MAX_UMP_EPS)
2537 return ERR_PTR(-EINVAL);
2538 if (opts->eps[index])
2539 return ERR_PTR(-EBUSY);
2540 ret = f_midi2_ep_opts_create(opts, index, &ep_opts);
2541 if (ret)
2542 return ERR_PTR(ret);
2543
2544 config_group_init_type_name(&ep_opts->group, name, &f_midi2_ep_type);
2545 return &ep_opts->group;
2546 }
2547
2548 /* drop_item callback for an EP */
2549 static void
f_midi2_opts_ep_drop(struct config_group * group,struct config_item * item)2550 f_midi2_opts_ep_drop(struct config_group *group, struct config_item *item)
2551 {
2552 struct f_midi2_ep_opts *ep_opts = to_f_midi2_ep_opts(item);
2553
2554 mutex_lock(&ep_opts->opts->lock);
2555 ep_opts->opts->eps[ep_opts->index] = NULL;
2556 mutex_unlock(&ep_opts->opts->lock);
2557 config_item_put(item);
2558 }
2559
2560 /*
2561 * Definitions for card config
2562 */
2563
2564 /* define a bool option for card */
2565 #define F_MIDI2_BOOL_OPT(name) \
2566 static ssize_t f_midi2_opts_##name##_show(struct config_item *item, \
2567 char *page) \
2568 { \
2569 struct f_midi2_opts *opts = to_f_midi2_opts(item); \
2570 return f_midi2_opts_uint_show(opts, opts->info.name, \
2571 "%u\n", page); \
2572 } \
2573 \
2574 static ssize_t f_midi2_opts_##name##_store(struct config_item *item, \
2575 const char *page, size_t len) \
2576 { \
2577 struct f_midi2_opts *opts = to_f_midi2_opts(item); \
2578 return f_midi2_opts_bool_store(opts, &opts->info.name, \
2579 page, len); \
2580 } \
2581 \
2582 CONFIGFS_ATTR(f_midi2_opts_, name)
2583
2584 F_MIDI2_BOOL_OPT(process_ump);
2585 F_MIDI2_BOOL_OPT(static_block);
2586
f_midi2_opts_iface_name_show(struct config_item * item,char * page)2587 static ssize_t f_midi2_opts_iface_name_show(struct config_item *item,
2588 char *page)
2589 {
2590 struct f_midi2_opts *opts = to_f_midi2_opts(item);
2591
2592 return f_midi2_opts_str_show(opts, opts->info.iface_name, page);
2593 }
2594
f_midi2_opts_iface_name_store(struct config_item * item,const char * page,size_t len)2595 static ssize_t f_midi2_opts_iface_name_store(struct config_item *item,
2596 const char *page, size_t len)
2597 {
2598 struct f_midi2_opts *opts = to_f_midi2_opts(item);
2599
2600 return f_midi2_opts_str_store(opts, &opts->info.iface_name, 128,
2601 page, len);
2602 }
2603
2604 CONFIGFS_ATTR(f_midi2_opts_, iface_name);
2605
2606 static struct configfs_attribute *f_midi2_attrs[] = {
2607 &f_midi2_opts_attr_process_ump,
2608 &f_midi2_opts_attr_static_block,
2609 &f_midi2_opts_attr_iface_name,
2610 NULL
2611 };
2612
f_midi2_opts_release(struct config_item * item)2613 static void f_midi2_opts_release(struct config_item *item)
2614 {
2615 struct f_midi2_opts *opts = to_f_midi2_opts(item);
2616
2617 usb_put_function_instance(&opts->func_inst);
2618 }
2619
2620 static const struct configfs_item_operations f_midi2_item_ops = {
2621 .release = f_midi2_opts_release,
2622 };
2623
2624 static const struct configfs_group_operations f_midi2_group_ops = {
2625 .make_group = f_midi2_opts_ep_make,
2626 .drop_item = f_midi2_opts_ep_drop,
2627 };
2628
2629 static const struct config_item_type f_midi2_func_type = {
2630 .ct_item_ops = &f_midi2_item_ops,
2631 .ct_group_ops = &f_midi2_group_ops,
2632 .ct_attrs = f_midi2_attrs,
2633 .ct_owner = THIS_MODULE,
2634 };
2635
f_midi2_free_inst(struct usb_function_instance * f)2636 static void f_midi2_free_inst(struct usb_function_instance *f)
2637 {
2638 struct f_midi2_opts *opts;
2639
2640 opts = container_of(f, struct f_midi2_opts, func_inst);
2641
2642 kfree(opts->info.iface_name);
2643 kfree(opts);
2644 }
2645
2646 /* gadget alloc_inst */
f_midi2_alloc_inst(void)2647 static struct usb_function_instance *f_midi2_alloc_inst(void)
2648 {
2649 struct f_midi2_opts *opts;
2650 struct f_midi2_ep_opts *ep_opts;
2651 struct f_midi2_block_opts *block_opts;
2652 int ret;
2653
2654 opts = kzalloc_obj(*opts);
2655 if (!opts)
2656 return ERR_PTR(-ENOMEM);
2657
2658 mutex_init(&opts->lock);
2659 opts->func_inst.free_func_inst = f_midi2_free_inst;
2660 opts->info.process_ump = true;
2661 opts->info.static_block = true;
2662 opts->info.num_reqs = 32;
2663 opts->info.req_buf_size = 512;
2664
2665 /* create the default ep */
2666 ret = f_midi2_ep_opts_create(opts, 0, &ep_opts);
2667 if (ret) {
2668 kfree(opts);
2669 return ERR_PTR(ret);
2670 }
2671
2672 /* create the default block */
2673 ret = f_midi2_block_opts_create(ep_opts, 0, &block_opts);
2674 if (ret) {
2675 kfree(ep_opts);
2676 kfree(opts);
2677 return ERR_PTR(ret);
2678 }
2679
2680 /* set up the default MIDI1 (that is mandatory) */
2681 block_opts->info.midi1_num_groups = 1;
2682
2683 config_group_init_type_name(&opts->func_inst.group, "",
2684 &f_midi2_func_type);
2685
2686 config_group_init_type_name(&ep_opts->group, "ep.0",
2687 &f_midi2_ep_type);
2688 configfs_add_default_group(&ep_opts->group, &opts->func_inst.group);
2689
2690 config_group_init_type_name(&block_opts->group, "block.0",
2691 &f_midi2_block_type);
2692 configfs_add_default_group(&block_opts->group, &ep_opts->group);
2693
2694 return &opts->func_inst;
2695 }
2696
do_f_midi2_free(struct f_midi2 * midi2,struct f_midi2_opts * opts)2697 static void do_f_midi2_free(struct f_midi2 *midi2, struct f_midi2_opts *opts)
2698 {
2699 mutex_lock(&opts->lock);
2700 --opts->refcnt;
2701 mutex_unlock(&opts->lock);
2702 kfree(midi2->string_defs);
2703 kfree(midi2);
2704 }
2705
f_midi2_free(struct usb_function * f)2706 static void f_midi2_free(struct usb_function *f)
2707 {
2708 do_f_midi2_free(func_to_midi2(f),
2709 container_of(f->fi, struct f_midi2_opts, func_inst));
2710 }
2711
2712 /* verify the parameters set up via configfs;
2713 * return the number of EPs or a negative error
2714 */
verify_parameters(struct f_midi2_opts * opts)2715 static int verify_parameters(struct f_midi2_opts *opts)
2716 {
2717 int i, j, num_eps, num_blks;
2718 struct f_midi2_ep_info *ep;
2719 struct f_midi2_block_info *bp;
2720
2721 for (num_eps = 0; num_eps < MAX_UMP_EPS && opts->eps[num_eps];
2722 num_eps++)
2723 ;
2724 if (!num_eps) {
2725 pr_err("f_midi2: No EP is defined\n");
2726 return -EINVAL;
2727 }
2728
2729 num_blks = 0;
2730 for (i = 0; i < num_eps; i++) {
2731 ep = &opts->eps[i]->info;
2732 if (!(ep->protocol_caps & ep->protocol)) {
2733 pr_err("f_midi2: Invalid protocol 0x%x (caps 0x%x) for EP %d\n",
2734 ep->protocol, ep->protocol_caps, i);
2735 return -EINVAL;
2736 }
2737
2738 for (j = 0; j < SNDRV_UMP_MAX_BLOCKS && opts->eps[i]->blks[j];
2739 j++, num_blks++) {
2740 bp = &opts->eps[i]->blks[j]->info;
2741 if (bp->first_group + bp->num_groups > SNDRV_UMP_MAX_GROUPS) {
2742 pr_err("f_midi2: Invalid group definitions for block %d:%d\n",
2743 i, j);
2744 return -EINVAL;
2745 }
2746
2747 if (bp->midi1_num_groups) {
2748 if (bp->midi1_first_group < bp->first_group ||
2749 bp->midi1_first_group + bp->midi1_num_groups >
2750 bp->first_group + bp->num_groups) {
2751 pr_err("f_midi2: Invalid MIDI1 group definitions for block %d:%d\n",
2752 i, j);
2753 return -EINVAL;
2754 }
2755 }
2756 }
2757 }
2758 if (!num_blks) {
2759 pr_err("f_midi2: No block is defined\n");
2760 return -EINVAL;
2761 }
2762
2763 return num_eps;
2764 }
2765
2766 /* fill mapping between MIDI 1.0 cable and UMP EP/group */
fill_midi1_cable_mapping(struct f_midi2 * midi2,struct f_midi2_ep * ep,int blk)2767 static void fill_midi1_cable_mapping(struct f_midi2 *midi2,
2768 struct f_midi2_ep *ep,
2769 int blk)
2770 {
2771 const struct f_midi2_block_info *binfo = &ep->blks[blk].info;
2772 struct midi1_cable_mapping *map;
2773 int i, group;
2774
2775 if (!binfo->midi1_num_groups)
2776 return;
2777 if (binfo->direction != SNDRV_UMP_DIR_OUTPUT) {
2778 group = binfo->midi1_first_group;
2779 map = midi2->in_cable_mapping + midi2->num_midi1_in;
2780 for (i = 0; i < binfo->midi1_num_groups; i++, group++, map++) {
2781 if (midi2->num_midi1_in >= MAX_CABLES)
2782 break;
2783 map->ep = ep;
2784 map->block = blk;
2785 map->group = group;
2786 midi2->num_midi1_in++;
2787 /* store 1-based cable number */
2788 ep->in_group_to_cable[group] = midi2->num_midi1_in;
2789 }
2790 }
2791
2792 if (binfo->direction != SNDRV_UMP_DIR_INPUT) {
2793 group = binfo->midi1_first_group;
2794 map = midi2->out_cable_mapping + midi2->num_midi1_out;
2795 for (i = 0; i < binfo->midi1_num_groups; i++, group++, map++) {
2796 if (midi2->num_midi1_out >= MAX_CABLES)
2797 break;
2798 map->ep = ep;
2799 map->block = blk;
2800 map->group = group;
2801 midi2->num_midi1_out++;
2802 }
2803 }
2804 }
2805
2806 /* gadget alloc callback */
f_midi2_alloc(struct usb_function_instance * fi)2807 static struct usb_function *f_midi2_alloc(struct usb_function_instance *fi)
2808 {
2809 struct f_midi2 *midi2;
2810 struct f_midi2_opts *opts;
2811 struct f_midi2_ep *ep;
2812 struct f_midi2_block *bp;
2813 int i, num_eps, blk;
2814
2815 midi2 = kzalloc_obj(*midi2);
2816 if (!midi2)
2817 return ERR_PTR(-ENOMEM);
2818
2819 opts = container_of(fi, struct f_midi2_opts, func_inst);
2820 mutex_lock(&opts->lock);
2821 num_eps = verify_parameters(opts);
2822 if (num_eps < 0) {
2823 mutex_unlock(&opts->lock);
2824 kfree(midi2);
2825 return ERR_PTR(num_eps);
2826 }
2827 ++opts->refcnt;
2828 mutex_unlock(&opts->lock);
2829
2830 spin_lock_init(&midi2->queue_lock);
2831
2832 midi2->func.name = "midi2_func";
2833 midi2->func.bind = f_midi2_bind;
2834 midi2->func.unbind = f_midi2_unbind;
2835 midi2->func.get_alt = f_midi2_get_alt;
2836 midi2->func.set_alt = f_midi2_set_alt;
2837 midi2->func.setup = f_midi2_setup;
2838 midi2->func.disable = f_midi2_disable;
2839 midi2->func.free_func = f_midi2_free;
2840
2841 midi2->info = opts->info;
2842 midi2->num_eps = num_eps;
2843
2844 for (i = 0; i < num_eps; i++) {
2845 ep = &midi2->midi2_eps[i];
2846 ep->info = opts->eps[i]->info;
2847 ep->card = midi2;
2848 for (blk = 0; blk < SNDRV_UMP_MAX_BLOCKS &&
2849 opts->eps[i]->blks[blk]; blk++) {
2850 bp = &ep->blks[blk];
2851 ep->num_blks++;
2852 bp->info = opts->eps[i]->blks[blk]->info;
2853 bp->gtb_id = ++midi2->total_blocks;
2854 }
2855 }
2856
2857 midi2->string_defs = kzalloc_objs(*midi2->string_defs,
2858 midi2->total_blocks + 1);
2859 if (!midi2->string_defs) {
2860 do_f_midi2_free(midi2, opts);
2861 return ERR_PTR(-ENOMEM);
2862 }
2863
2864 if (opts->info.iface_name && *opts->info.iface_name)
2865 midi2->string_defs[STR_IFACE].s = opts->info.iface_name;
2866 else
2867 midi2->string_defs[STR_IFACE].s = ump_ep_name(&midi2->midi2_eps[0]);
2868
2869 for (i = 0; i < midi2->num_eps; i++) {
2870 ep = &midi2->midi2_eps[i];
2871 for (blk = 0; blk < ep->num_blks; blk++) {
2872 bp = &ep->blks[blk];
2873 midi2->string_defs[gtb_to_str_id(bp->gtb_id)].s =
2874 ump_fb_name(&bp->info);
2875
2876 fill_midi1_cable_mapping(midi2, ep, blk);
2877 }
2878 }
2879
2880 if (!midi2->num_midi1_in && !midi2->num_midi1_out) {
2881 pr_err("f_midi2: MIDI1 definition is missing\n");
2882 do_f_midi2_free(midi2, opts);
2883 return ERR_PTR(-EINVAL);
2884 }
2885
2886 return &midi2->func;
2887 }
2888
2889 DECLARE_USB_FUNCTION_INIT(midi2, f_midi2_alloc_inst, f_midi2_alloc);
2890
2891 MODULE_DESCRIPTION("USB MIDI 2.0 class function driver");
2892 MODULE_LICENSE("GPL");
2893