Merge tag 'amlogic-soc' of git://git.kernel.org/pub/scm/linux/kernel/git/khilman...
[linux-2.6-microblaze.git] / drivers / usb / gadget / function / f_uac2.c
1 // SPDX-License-Identifier: GPL-2.0+
2 /*
3  * f_uac2.c -- USB Audio Class 2.0 Function
4  *
5  * Copyright (C) 2011
6  *    Yadwinder Singh (yadi.brar01@gmail.com)
7  *    Jaswinder Singh (jaswinder.singh@linaro.org)
8  */
9
10 #include <linux/usb/audio.h>
11 #include <linux/usb/audio-v2.h>
12 #include <linux/module.h>
13
14 #include "u_audio.h"
15 #include "u_uac2.h"
16
17 /*
18  * The driver implements a simple UAC_2 topology.
19  * USB-OUT -> IT_1 -> OT_3 -> ALSA_Capture
20  * ALSA_Playback -> IT_2 -> OT_4 -> USB-IN
21  * Capture and Playback sampling rates are independently
22  *  controlled by two clock sources :
23  *    CLK_5 := c_srate, and CLK_6 := p_srate
24  */
25 #define USB_OUT_CLK_ID  (out_clk_src_desc.bClockID)
26 #define USB_IN_CLK_ID   (in_clk_src_desc.bClockID)
27
28 #define CONTROL_ABSENT  0
29 #define CONTROL_RDONLY  1
30 #define CONTROL_RDWR    3
31
32 #define CLK_FREQ_CTRL   0
33 #define CLK_VLD_CTRL    2
34
35 #define COPY_CTRL       0
36 #define CONN_CTRL       2
37 #define OVRLD_CTRL      4
38 #define CLSTR_CTRL      6
39 #define UNFLW_CTRL      8
40 #define OVFLW_CTRL      10
41
42 #define EPIN_EN(_opts) ((_opts)->p_chmask != 0)
43 #define EPOUT_EN(_opts) ((_opts)->c_chmask != 0)
44
45 struct f_uac2 {
46         struct g_audio g_audio;
47         u8 ac_intf, as_in_intf, as_out_intf;
48         u8 ac_alt, as_in_alt, as_out_alt;       /* needed for get_alt() */
49 };
50
51 static inline struct f_uac2 *func_to_uac2(struct usb_function *f)
52 {
53         return container_of(f, struct f_uac2, g_audio.func);
54 }
55
56 static inline
57 struct f_uac2_opts *g_audio_to_uac2_opts(struct g_audio *agdev)
58 {
59         return container_of(agdev->func.fi, struct f_uac2_opts, func_inst);
60 }
61
62 /* --------- USB Function Interface ------------- */
63
64 enum {
65         STR_ASSOC,
66         STR_IF_CTRL,
67         STR_CLKSRC_IN,
68         STR_CLKSRC_OUT,
69         STR_USB_IT,
70         STR_IO_IT,
71         STR_USB_OT,
72         STR_IO_OT,
73         STR_AS_OUT_ALT0,
74         STR_AS_OUT_ALT1,
75         STR_AS_IN_ALT0,
76         STR_AS_IN_ALT1,
77 };
78
79 static char clksrc_in[8];
80 static char clksrc_out[8];
81
82 static struct usb_string strings_fn[] = {
83         [STR_ASSOC].s = "Source/Sink",
84         [STR_IF_CTRL].s = "Topology Control",
85         [STR_CLKSRC_IN].s = clksrc_in,
86         [STR_CLKSRC_OUT].s = clksrc_out,
87         [STR_USB_IT].s = "USBH Out",
88         [STR_IO_IT].s = "USBD Out",
89         [STR_USB_OT].s = "USBH In",
90         [STR_IO_OT].s = "USBD In",
91         [STR_AS_OUT_ALT0].s = "Playback Inactive",
92         [STR_AS_OUT_ALT1].s = "Playback Active",
93         [STR_AS_IN_ALT0].s = "Capture Inactive",
94         [STR_AS_IN_ALT1].s = "Capture Active",
95         { },
96 };
97
98 static struct usb_gadget_strings str_fn = {
99         .language = 0x0409,     /* en-us */
100         .strings = strings_fn,
101 };
102
103 static struct usb_gadget_strings *fn_strings[] = {
104         &str_fn,
105         NULL,
106 };
107
108 static struct usb_interface_assoc_descriptor iad_desc = {
109         .bLength = sizeof iad_desc,
110         .bDescriptorType = USB_DT_INTERFACE_ASSOCIATION,
111
112         .bFirstInterface = 0,
113         .bInterfaceCount = 3,
114         .bFunctionClass = USB_CLASS_AUDIO,
115         .bFunctionSubClass = UAC2_FUNCTION_SUBCLASS_UNDEFINED,
116         .bFunctionProtocol = UAC_VERSION_2,
117 };
118
119 /* Audio Control Interface */
120 static struct usb_interface_descriptor std_ac_if_desc = {
121         .bLength = sizeof std_ac_if_desc,
122         .bDescriptorType = USB_DT_INTERFACE,
123
124         .bAlternateSetting = 0,
125         .bNumEndpoints = 0,
126         .bInterfaceClass = USB_CLASS_AUDIO,
127         .bInterfaceSubClass = USB_SUBCLASS_AUDIOCONTROL,
128         .bInterfaceProtocol = UAC_VERSION_2,
129 };
130
131 /* Clock source for IN traffic */
132 static struct uac_clock_source_descriptor in_clk_src_desc = {
133         .bLength = sizeof in_clk_src_desc,
134         .bDescriptorType = USB_DT_CS_INTERFACE,
135
136         .bDescriptorSubtype = UAC2_CLOCK_SOURCE,
137         /* .bClockID = DYNAMIC */
138         .bmAttributes = UAC_CLOCK_SOURCE_TYPE_INT_FIXED,
139         .bmControls = (CONTROL_RDONLY << CLK_FREQ_CTRL),
140         .bAssocTerminal = 0,
141 };
142
143 /* Clock source for OUT traffic */
144 static struct uac_clock_source_descriptor out_clk_src_desc = {
145         .bLength = sizeof out_clk_src_desc,
146         .bDescriptorType = USB_DT_CS_INTERFACE,
147
148         .bDescriptorSubtype = UAC2_CLOCK_SOURCE,
149         /* .bClockID = DYNAMIC */
150         .bmAttributes = UAC_CLOCK_SOURCE_TYPE_INT_FIXED,
151         .bmControls = (CONTROL_RDONLY << CLK_FREQ_CTRL),
152         .bAssocTerminal = 0,
153 };
154
155 /* Input Terminal for USB_OUT */
156 static struct uac2_input_terminal_descriptor usb_out_it_desc = {
157         .bLength = sizeof usb_out_it_desc,
158         .bDescriptorType = USB_DT_CS_INTERFACE,
159
160         .bDescriptorSubtype = UAC_INPUT_TERMINAL,
161         /* .bTerminalID = DYNAMIC */
162         .wTerminalType = cpu_to_le16(UAC_TERMINAL_STREAMING),
163         .bAssocTerminal = 0,
164         /* .bCSourceID = DYNAMIC */
165         .iChannelNames = 0,
166         .bmControls = cpu_to_le16(CONTROL_RDWR << COPY_CTRL),
167 };
168
169 /* Input Terminal for I/O-In */
170 static struct uac2_input_terminal_descriptor io_in_it_desc = {
171         .bLength = sizeof io_in_it_desc,
172         .bDescriptorType = USB_DT_CS_INTERFACE,
173
174         .bDescriptorSubtype = UAC_INPUT_TERMINAL,
175         /* .bTerminalID = DYNAMIC */
176         .wTerminalType = cpu_to_le16(UAC_INPUT_TERMINAL_UNDEFINED),
177         .bAssocTerminal = 0,
178         /* .bCSourceID = DYNAMIC */
179         .iChannelNames = 0,
180         .bmControls = cpu_to_le16(CONTROL_RDWR << COPY_CTRL),
181 };
182
183 /* Ouput Terminal for USB_IN */
184 static struct uac2_output_terminal_descriptor usb_in_ot_desc = {
185         .bLength = sizeof usb_in_ot_desc,
186         .bDescriptorType = USB_DT_CS_INTERFACE,
187
188         .bDescriptorSubtype = UAC_OUTPUT_TERMINAL,
189         /* .bTerminalID = DYNAMIC */
190         .wTerminalType = cpu_to_le16(UAC_TERMINAL_STREAMING),
191         .bAssocTerminal = 0,
192         /* .bSourceID = DYNAMIC */
193         /* .bCSourceID = DYNAMIC */
194         .bmControls = cpu_to_le16(CONTROL_RDWR << COPY_CTRL),
195 };
196
197 /* Ouput Terminal for I/O-Out */
198 static struct uac2_output_terminal_descriptor io_out_ot_desc = {
199         .bLength = sizeof io_out_ot_desc,
200         .bDescriptorType = USB_DT_CS_INTERFACE,
201
202         .bDescriptorSubtype = UAC_OUTPUT_TERMINAL,
203         /* .bTerminalID = DYNAMIC */
204         .wTerminalType = cpu_to_le16(UAC_OUTPUT_TERMINAL_UNDEFINED),
205         .bAssocTerminal = 0,
206         /* .bSourceID = DYNAMIC */
207         /* .bCSourceID = DYNAMIC */
208         .bmControls = cpu_to_le16(CONTROL_RDWR << COPY_CTRL),
209 };
210
211 static struct uac2_ac_header_descriptor ac_hdr_desc = {
212         .bLength = sizeof ac_hdr_desc,
213         .bDescriptorType = USB_DT_CS_INTERFACE,
214
215         .bDescriptorSubtype = UAC_MS_HEADER,
216         .bcdADC = cpu_to_le16(0x200),
217         .bCategory = UAC2_FUNCTION_IO_BOX,
218         /* .wTotalLength = DYNAMIC */
219         .bmControls = 0,
220 };
221
222 /* Audio Streaming OUT Interface - Alt0 */
223 static struct usb_interface_descriptor std_as_out_if0_desc = {
224         .bLength = sizeof std_as_out_if0_desc,
225         .bDescriptorType = USB_DT_INTERFACE,
226
227         .bAlternateSetting = 0,
228         .bNumEndpoints = 0,
229         .bInterfaceClass = USB_CLASS_AUDIO,
230         .bInterfaceSubClass = USB_SUBCLASS_AUDIOSTREAMING,
231         .bInterfaceProtocol = UAC_VERSION_2,
232 };
233
234 /* Audio Streaming OUT Interface - Alt1 */
235 static struct usb_interface_descriptor std_as_out_if1_desc = {
236         .bLength = sizeof std_as_out_if1_desc,
237         .bDescriptorType = USB_DT_INTERFACE,
238
239         .bAlternateSetting = 1,
240         .bNumEndpoints = 1,
241         .bInterfaceClass = USB_CLASS_AUDIO,
242         .bInterfaceSubClass = USB_SUBCLASS_AUDIOSTREAMING,
243         .bInterfaceProtocol = UAC_VERSION_2,
244 };
245
246 /* Audio Stream OUT Intface Desc */
247 static struct uac2_as_header_descriptor as_out_hdr_desc = {
248         .bLength = sizeof as_out_hdr_desc,
249         .bDescriptorType = USB_DT_CS_INTERFACE,
250
251         .bDescriptorSubtype = UAC_AS_GENERAL,
252         /* .bTerminalLink = DYNAMIC */
253         .bmControls = 0,
254         .bFormatType = UAC_FORMAT_TYPE_I,
255         .bmFormats = cpu_to_le32(UAC_FORMAT_TYPE_I_PCM),
256         .iChannelNames = 0,
257 };
258
259 /* Audio USB_OUT Format */
260 static struct uac2_format_type_i_descriptor as_out_fmt1_desc = {
261         .bLength = sizeof as_out_fmt1_desc,
262         .bDescriptorType = USB_DT_CS_INTERFACE,
263         .bDescriptorSubtype = UAC_FORMAT_TYPE,
264         .bFormatType = UAC_FORMAT_TYPE_I,
265 };
266
267 /* STD AS ISO OUT Endpoint */
268 static struct usb_endpoint_descriptor fs_epout_desc = {
269         .bLength = USB_DT_ENDPOINT_SIZE,
270         .bDescriptorType = USB_DT_ENDPOINT,
271
272         .bEndpointAddress = USB_DIR_OUT,
273         .bmAttributes = USB_ENDPOINT_XFER_ISOC | USB_ENDPOINT_SYNC_ASYNC,
274         /* .wMaxPacketSize = DYNAMIC */
275         .bInterval = 1,
276 };
277
278 static struct usb_endpoint_descriptor hs_epout_desc = {
279         .bLength = USB_DT_ENDPOINT_SIZE,
280         .bDescriptorType = USB_DT_ENDPOINT,
281
282         .bmAttributes = USB_ENDPOINT_XFER_ISOC | USB_ENDPOINT_SYNC_ASYNC,
283         /* .wMaxPacketSize = DYNAMIC */
284         .bInterval = 4,
285 };
286
287 /* CS AS ISO OUT Endpoint */
288 static struct uac2_iso_endpoint_descriptor as_iso_out_desc = {
289         .bLength = sizeof as_iso_out_desc,
290         .bDescriptorType = USB_DT_CS_ENDPOINT,
291
292         .bDescriptorSubtype = UAC_EP_GENERAL,
293         .bmAttributes = 0,
294         .bmControls = 0,
295         .bLockDelayUnits = 0,
296         .wLockDelay = 0,
297 };
298
299 /* Audio Streaming IN Interface - Alt0 */
300 static struct usb_interface_descriptor std_as_in_if0_desc = {
301         .bLength = sizeof std_as_in_if0_desc,
302         .bDescriptorType = USB_DT_INTERFACE,
303
304         .bAlternateSetting = 0,
305         .bNumEndpoints = 0,
306         .bInterfaceClass = USB_CLASS_AUDIO,
307         .bInterfaceSubClass = USB_SUBCLASS_AUDIOSTREAMING,
308         .bInterfaceProtocol = UAC_VERSION_2,
309 };
310
311 /* Audio Streaming IN Interface - Alt1 */
312 static struct usb_interface_descriptor std_as_in_if1_desc = {
313         .bLength = sizeof std_as_in_if1_desc,
314         .bDescriptorType = USB_DT_INTERFACE,
315
316         .bAlternateSetting = 1,
317         .bNumEndpoints = 1,
318         .bInterfaceClass = USB_CLASS_AUDIO,
319         .bInterfaceSubClass = USB_SUBCLASS_AUDIOSTREAMING,
320         .bInterfaceProtocol = UAC_VERSION_2,
321 };
322
323 /* Audio Stream IN Intface Desc */
324 static struct uac2_as_header_descriptor as_in_hdr_desc = {
325         .bLength = sizeof as_in_hdr_desc,
326         .bDescriptorType = USB_DT_CS_INTERFACE,
327
328         .bDescriptorSubtype = UAC_AS_GENERAL,
329         /* .bTerminalLink = DYNAMIC */
330         .bmControls = 0,
331         .bFormatType = UAC_FORMAT_TYPE_I,
332         .bmFormats = cpu_to_le32(UAC_FORMAT_TYPE_I_PCM),
333         .iChannelNames = 0,
334 };
335
336 /* Audio USB_IN Format */
337 static struct uac2_format_type_i_descriptor as_in_fmt1_desc = {
338         .bLength = sizeof as_in_fmt1_desc,
339         .bDescriptorType = USB_DT_CS_INTERFACE,
340         .bDescriptorSubtype = UAC_FORMAT_TYPE,
341         .bFormatType = UAC_FORMAT_TYPE_I,
342 };
343
344 /* STD AS ISO IN Endpoint */
345 static struct usb_endpoint_descriptor fs_epin_desc = {
346         .bLength = USB_DT_ENDPOINT_SIZE,
347         .bDescriptorType = USB_DT_ENDPOINT,
348
349         .bEndpointAddress = USB_DIR_IN,
350         .bmAttributes = USB_ENDPOINT_XFER_ISOC | USB_ENDPOINT_SYNC_ASYNC,
351         /* .wMaxPacketSize = DYNAMIC */
352         .bInterval = 1,
353 };
354
355 static struct usb_endpoint_descriptor hs_epin_desc = {
356         .bLength = USB_DT_ENDPOINT_SIZE,
357         .bDescriptorType = USB_DT_ENDPOINT,
358
359         .bmAttributes = USB_ENDPOINT_XFER_ISOC | USB_ENDPOINT_SYNC_ASYNC,
360         /* .wMaxPacketSize = DYNAMIC */
361         .bInterval = 4,
362 };
363
364 /* CS AS ISO IN Endpoint */
365 static struct uac2_iso_endpoint_descriptor as_iso_in_desc = {
366         .bLength = sizeof as_iso_in_desc,
367         .bDescriptorType = USB_DT_CS_ENDPOINT,
368
369         .bDescriptorSubtype = UAC_EP_GENERAL,
370         .bmAttributes = 0,
371         .bmControls = 0,
372         .bLockDelayUnits = 0,
373         .wLockDelay = 0,
374 };
375
376 static struct usb_descriptor_header *fs_audio_desc[] = {
377         (struct usb_descriptor_header *)&iad_desc,
378         (struct usb_descriptor_header *)&std_ac_if_desc,
379
380         (struct usb_descriptor_header *)&ac_hdr_desc,
381         (struct usb_descriptor_header *)&in_clk_src_desc,
382         (struct usb_descriptor_header *)&out_clk_src_desc,
383         (struct usb_descriptor_header *)&usb_out_it_desc,
384         (struct usb_descriptor_header *)&io_in_it_desc,
385         (struct usb_descriptor_header *)&usb_in_ot_desc,
386         (struct usb_descriptor_header *)&io_out_ot_desc,
387
388         (struct usb_descriptor_header *)&std_as_out_if0_desc,
389         (struct usb_descriptor_header *)&std_as_out_if1_desc,
390
391         (struct usb_descriptor_header *)&as_out_hdr_desc,
392         (struct usb_descriptor_header *)&as_out_fmt1_desc,
393         (struct usb_descriptor_header *)&fs_epout_desc,
394         (struct usb_descriptor_header *)&as_iso_out_desc,
395
396         (struct usb_descriptor_header *)&std_as_in_if0_desc,
397         (struct usb_descriptor_header *)&std_as_in_if1_desc,
398
399         (struct usb_descriptor_header *)&as_in_hdr_desc,
400         (struct usb_descriptor_header *)&as_in_fmt1_desc,
401         (struct usb_descriptor_header *)&fs_epin_desc,
402         (struct usb_descriptor_header *)&as_iso_in_desc,
403         NULL,
404 };
405
406 static struct usb_descriptor_header *hs_audio_desc[] = {
407         (struct usb_descriptor_header *)&iad_desc,
408         (struct usb_descriptor_header *)&std_ac_if_desc,
409
410         (struct usb_descriptor_header *)&ac_hdr_desc,
411         (struct usb_descriptor_header *)&in_clk_src_desc,
412         (struct usb_descriptor_header *)&out_clk_src_desc,
413         (struct usb_descriptor_header *)&usb_out_it_desc,
414         (struct usb_descriptor_header *)&io_in_it_desc,
415         (struct usb_descriptor_header *)&usb_in_ot_desc,
416         (struct usb_descriptor_header *)&io_out_ot_desc,
417
418         (struct usb_descriptor_header *)&std_as_out_if0_desc,
419         (struct usb_descriptor_header *)&std_as_out_if1_desc,
420
421         (struct usb_descriptor_header *)&as_out_hdr_desc,
422         (struct usb_descriptor_header *)&as_out_fmt1_desc,
423         (struct usb_descriptor_header *)&hs_epout_desc,
424         (struct usb_descriptor_header *)&as_iso_out_desc,
425
426         (struct usb_descriptor_header *)&std_as_in_if0_desc,
427         (struct usb_descriptor_header *)&std_as_in_if1_desc,
428
429         (struct usb_descriptor_header *)&as_in_hdr_desc,
430         (struct usb_descriptor_header *)&as_in_fmt1_desc,
431         (struct usb_descriptor_header *)&hs_epin_desc,
432         (struct usb_descriptor_header *)&as_iso_in_desc,
433         NULL,
434 };
435
436 struct cntrl_cur_lay3 {
437         __le32  dCUR;
438 };
439
440 struct cntrl_range_lay3 {
441         __le16  wNumSubRanges;
442         __le32  dMIN;
443         __le32  dMAX;
444         __le32  dRES;
445 } __packed;
446
447 static int set_ep_max_packet_size(const struct f_uac2_opts *uac2_opts,
448         struct usb_endpoint_descriptor *ep_desc,
449         enum usb_device_speed speed, bool is_playback)
450 {
451         int chmask, srate, ssize;
452         u16 max_size_bw, max_size_ep;
453         unsigned int factor;
454
455         switch (speed) {
456         case USB_SPEED_FULL:
457                 max_size_ep = 1023;
458                 factor = 1000;
459                 break;
460
461         case USB_SPEED_HIGH:
462                 max_size_ep = 1024;
463                 factor = 8000;
464                 break;
465
466         default:
467                 return -EINVAL;
468         }
469
470         if (is_playback) {
471                 chmask = uac2_opts->p_chmask;
472                 srate = uac2_opts->p_srate;
473                 ssize = uac2_opts->p_ssize;
474         } else {
475                 chmask = uac2_opts->c_chmask;
476                 srate = uac2_opts->c_srate;
477                 ssize = uac2_opts->c_ssize;
478         }
479
480         max_size_bw = num_channels(chmask) * ssize *
481                 DIV_ROUND_UP(srate, factor / (1 << (ep_desc->bInterval - 1)));
482         ep_desc->wMaxPacketSize = cpu_to_le16(min_t(u16, max_size_bw,
483                                                     max_size_ep));
484
485         return 0;
486 }
487
488 /* Use macro to overcome line length limitation */
489 #define USBDHDR(p) (struct usb_descriptor_header *)(p)
490
491 static void setup_descriptor(struct f_uac2_opts *opts)
492 {
493         /* patch descriptors */
494         int i = 1; /* ID's start with 1 */
495
496         if (EPOUT_EN(opts))
497                 usb_out_it_desc.bTerminalID = i++;
498         if (EPIN_EN(opts))
499                 io_in_it_desc.bTerminalID = i++;
500         if (EPOUT_EN(opts))
501                 io_out_ot_desc.bTerminalID = i++;
502         if (EPIN_EN(opts))
503                 usb_in_ot_desc.bTerminalID = i++;
504         if (EPOUT_EN(opts))
505                 out_clk_src_desc.bClockID = i++;
506         if (EPIN_EN(opts))
507                 in_clk_src_desc.bClockID = i++;
508
509         usb_out_it_desc.bCSourceID = out_clk_src_desc.bClockID;
510         usb_in_ot_desc.bSourceID = io_in_it_desc.bTerminalID;
511         usb_in_ot_desc.bCSourceID = in_clk_src_desc.bClockID;
512         io_in_it_desc.bCSourceID = in_clk_src_desc.bClockID;
513         io_out_ot_desc.bCSourceID = out_clk_src_desc.bClockID;
514         io_out_ot_desc.bSourceID = usb_out_it_desc.bTerminalID;
515         as_out_hdr_desc.bTerminalLink = usb_out_it_desc.bTerminalID;
516         as_in_hdr_desc.bTerminalLink = usb_in_ot_desc.bTerminalID;
517
518         iad_desc.bInterfaceCount = 1;
519         ac_hdr_desc.wTotalLength = cpu_to_le16(sizeof(ac_hdr_desc));
520
521         if (EPIN_EN(opts)) {
522                 u16 len = le16_to_cpu(ac_hdr_desc.wTotalLength);
523
524                 len += sizeof(in_clk_src_desc);
525                 len += sizeof(usb_in_ot_desc);
526                 len += sizeof(io_in_it_desc);
527                 ac_hdr_desc.wTotalLength = cpu_to_le16(len);
528                 iad_desc.bInterfaceCount++;
529         }
530         if (EPOUT_EN(opts)) {
531                 u16 len = le16_to_cpu(ac_hdr_desc.wTotalLength);
532
533                 len += sizeof(out_clk_src_desc);
534                 len += sizeof(usb_out_it_desc);
535                 len += sizeof(io_out_ot_desc);
536                 ac_hdr_desc.wTotalLength = cpu_to_le16(len);
537                 iad_desc.bInterfaceCount++;
538         }
539
540         i = 0;
541         fs_audio_desc[i++] = USBDHDR(&iad_desc);
542         fs_audio_desc[i++] = USBDHDR(&std_ac_if_desc);
543         fs_audio_desc[i++] = USBDHDR(&ac_hdr_desc);
544         if (EPIN_EN(opts))
545                 fs_audio_desc[i++] = USBDHDR(&in_clk_src_desc);
546         if (EPOUT_EN(opts)) {
547                 fs_audio_desc[i++] = USBDHDR(&out_clk_src_desc);
548                 fs_audio_desc[i++] = USBDHDR(&usb_out_it_desc);
549         }
550         if (EPIN_EN(opts)) {
551                 fs_audio_desc[i++] = USBDHDR(&io_in_it_desc);
552                 fs_audio_desc[i++] = USBDHDR(&usb_in_ot_desc);
553         }
554         if (EPOUT_EN(opts)) {
555                 fs_audio_desc[i++] = USBDHDR(&io_out_ot_desc);
556                 fs_audio_desc[i++] = USBDHDR(&std_as_out_if0_desc);
557                 fs_audio_desc[i++] = USBDHDR(&std_as_out_if1_desc);
558                 fs_audio_desc[i++] = USBDHDR(&as_out_hdr_desc);
559                 fs_audio_desc[i++] = USBDHDR(&as_out_fmt1_desc);
560                 fs_audio_desc[i++] = USBDHDR(&fs_epout_desc);
561                 fs_audio_desc[i++] = USBDHDR(&as_iso_out_desc);
562         }
563         if (EPIN_EN(opts)) {
564                 fs_audio_desc[i++] = USBDHDR(&std_as_in_if0_desc);
565                 fs_audio_desc[i++] = USBDHDR(&std_as_in_if1_desc);
566                 fs_audio_desc[i++] = USBDHDR(&as_in_hdr_desc);
567                 fs_audio_desc[i++] = USBDHDR(&as_in_fmt1_desc);
568                 fs_audio_desc[i++] = USBDHDR(&fs_epin_desc);
569                 fs_audio_desc[i++] = USBDHDR(&as_iso_in_desc);
570         }
571         fs_audio_desc[i] = NULL;
572
573         i = 0;
574         hs_audio_desc[i++] = USBDHDR(&iad_desc);
575         hs_audio_desc[i++] = USBDHDR(&std_ac_if_desc);
576         hs_audio_desc[i++] = USBDHDR(&ac_hdr_desc);
577         if (EPIN_EN(opts))
578                 hs_audio_desc[i++] = USBDHDR(&in_clk_src_desc);
579         if (EPOUT_EN(opts)) {
580                 hs_audio_desc[i++] = USBDHDR(&out_clk_src_desc);
581                 hs_audio_desc[i++] = USBDHDR(&usb_out_it_desc);
582         }
583         if (EPIN_EN(opts)) {
584                 hs_audio_desc[i++] = USBDHDR(&io_in_it_desc);
585                 hs_audio_desc[i++] = USBDHDR(&usb_in_ot_desc);
586         }
587         if (EPOUT_EN(opts)) {
588                 hs_audio_desc[i++] = USBDHDR(&io_out_ot_desc);
589                 hs_audio_desc[i++] = USBDHDR(&std_as_out_if0_desc);
590                 hs_audio_desc[i++] = USBDHDR(&std_as_out_if1_desc);
591                 hs_audio_desc[i++] = USBDHDR(&as_out_hdr_desc);
592                 hs_audio_desc[i++] = USBDHDR(&as_out_fmt1_desc);
593                 hs_audio_desc[i++] = USBDHDR(&hs_epout_desc);
594                 hs_audio_desc[i++] = USBDHDR(&as_iso_out_desc);
595         }
596         if (EPIN_EN(opts)) {
597                 hs_audio_desc[i++] = USBDHDR(&std_as_in_if0_desc);
598                 hs_audio_desc[i++] = USBDHDR(&std_as_in_if1_desc);
599                 hs_audio_desc[i++] = USBDHDR(&as_in_hdr_desc);
600                 hs_audio_desc[i++] = USBDHDR(&as_in_fmt1_desc);
601                 hs_audio_desc[i++] = USBDHDR(&hs_epin_desc);
602                 hs_audio_desc[i++] = USBDHDR(&as_iso_in_desc);
603         }
604         hs_audio_desc[i] = NULL;
605 }
606
607 static int
608 afunc_bind(struct usb_configuration *cfg, struct usb_function *fn)
609 {
610         struct f_uac2 *uac2 = func_to_uac2(fn);
611         struct g_audio *agdev = func_to_g_audio(fn);
612         struct usb_composite_dev *cdev = cfg->cdev;
613         struct usb_gadget *gadget = cdev->gadget;
614         struct device *dev = &gadget->dev;
615         struct f_uac2_opts *uac2_opts;
616         struct usb_string *us;
617         int ret;
618
619         uac2_opts = container_of(fn->fi, struct f_uac2_opts, func_inst);
620
621         us = usb_gstrings_attach(cdev, fn_strings, ARRAY_SIZE(strings_fn));
622         if (IS_ERR(us))
623                 return PTR_ERR(us);
624         iad_desc.iFunction = us[STR_ASSOC].id;
625         std_ac_if_desc.iInterface = us[STR_IF_CTRL].id;
626         in_clk_src_desc.iClockSource = us[STR_CLKSRC_IN].id;
627         out_clk_src_desc.iClockSource = us[STR_CLKSRC_OUT].id;
628         usb_out_it_desc.iTerminal = us[STR_USB_IT].id;
629         io_in_it_desc.iTerminal = us[STR_IO_IT].id;
630         usb_in_ot_desc.iTerminal = us[STR_USB_OT].id;
631         io_out_ot_desc.iTerminal = us[STR_IO_OT].id;
632         std_as_out_if0_desc.iInterface = us[STR_AS_OUT_ALT0].id;
633         std_as_out_if1_desc.iInterface = us[STR_AS_OUT_ALT1].id;
634         std_as_in_if0_desc.iInterface = us[STR_AS_IN_ALT0].id;
635         std_as_in_if1_desc.iInterface = us[STR_AS_IN_ALT1].id;
636
637
638         /* Initialize the configurable parameters */
639         usb_out_it_desc.bNrChannels = num_channels(uac2_opts->c_chmask);
640         usb_out_it_desc.bmChannelConfig = cpu_to_le32(uac2_opts->c_chmask);
641         io_in_it_desc.bNrChannels = num_channels(uac2_opts->p_chmask);
642         io_in_it_desc.bmChannelConfig = cpu_to_le32(uac2_opts->p_chmask);
643         as_out_hdr_desc.bNrChannels = num_channels(uac2_opts->c_chmask);
644         as_out_hdr_desc.bmChannelConfig = cpu_to_le32(uac2_opts->c_chmask);
645         as_in_hdr_desc.bNrChannels = num_channels(uac2_opts->p_chmask);
646         as_in_hdr_desc.bmChannelConfig = cpu_to_le32(uac2_opts->p_chmask);
647         as_out_fmt1_desc.bSubslotSize = uac2_opts->c_ssize;
648         as_out_fmt1_desc.bBitResolution = uac2_opts->c_ssize * 8;
649         as_in_fmt1_desc.bSubslotSize = uac2_opts->p_ssize;
650         as_in_fmt1_desc.bBitResolution = uac2_opts->p_ssize * 8;
651
652         snprintf(clksrc_in, sizeof(clksrc_in), "%uHz", uac2_opts->p_srate);
653         snprintf(clksrc_out, sizeof(clksrc_out), "%uHz", uac2_opts->c_srate);
654
655         ret = usb_interface_id(cfg, fn);
656         if (ret < 0) {
657                 dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
658                 return ret;
659         }
660         iad_desc.bFirstInterface = ret;
661
662         std_ac_if_desc.bInterfaceNumber = ret;
663         uac2->ac_intf = ret;
664         uac2->ac_alt = 0;
665
666         if (EPOUT_EN(uac2_opts)) {
667                 ret = usb_interface_id(cfg, fn);
668                 if (ret < 0) {
669                         dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
670                         return ret;
671                 }
672                 std_as_out_if0_desc.bInterfaceNumber = ret;
673                 std_as_out_if1_desc.bInterfaceNumber = ret;
674                 uac2->as_out_intf = ret;
675                 uac2->as_out_alt = 0;
676         }
677
678         if (EPIN_EN(uac2_opts)) {
679                 ret = usb_interface_id(cfg, fn);
680                 if (ret < 0) {
681                         dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
682                         return ret;
683                 }
684                 std_as_in_if0_desc.bInterfaceNumber = ret;
685                 std_as_in_if1_desc.bInterfaceNumber = ret;
686                 uac2->as_in_intf = ret;
687                 uac2->as_in_alt = 0;
688         }
689
690         /* Calculate wMaxPacketSize according to audio bandwidth */
691         ret = set_ep_max_packet_size(uac2_opts, &fs_epin_desc, USB_SPEED_FULL,
692                                      true);
693         if (ret < 0) {
694                 dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
695                 return ret;
696         }
697
698         ret = set_ep_max_packet_size(uac2_opts, &fs_epout_desc, USB_SPEED_FULL,
699                                      false);
700         if (ret < 0) {
701                 dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
702                 return ret;
703         }
704
705         ret = set_ep_max_packet_size(uac2_opts, &hs_epin_desc, USB_SPEED_HIGH,
706                                      true);
707         if (ret < 0) {
708                 dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
709                 return ret;
710         }
711
712         ret = set_ep_max_packet_size(uac2_opts, &hs_epout_desc, USB_SPEED_HIGH,
713                                      false);
714         if (ret < 0) {
715                 dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
716                 return ret;
717         }
718
719         if (EPOUT_EN(uac2_opts)) {
720                 agdev->out_ep = usb_ep_autoconfig(gadget, &fs_epout_desc);
721                 if (!agdev->out_ep) {
722                         dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
723                         return -ENODEV;
724                 }
725         }
726
727         if (EPIN_EN(uac2_opts)) {
728                 agdev->in_ep = usb_ep_autoconfig(gadget, &fs_epin_desc);
729                 if (!agdev->in_ep) {
730                         dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
731                         return -ENODEV;
732                 }
733         }
734
735         agdev->in_ep_maxpsize = max_t(u16,
736                                 le16_to_cpu(fs_epin_desc.wMaxPacketSize),
737                                 le16_to_cpu(hs_epin_desc.wMaxPacketSize));
738         agdev->out_ep_maxpsize = max_t(u16,
739                                 le16_to_cpu(fs_epout_desc.wMaxPacketSize),
740                                 le16_to_cpu(hs_epout_desc.wMaxPacketSize));
741
742         hs_epout_desc.bEndpointAddress = fs_epout_desc.bEndpointAddress;
743         hs_epin_desc.bEndpointAddress = fs_epin_desc.bEndpointAddress;
744
745         setup_descriptor(uac2_opts);
746
747         ret = usb_assign_descriptors(fn, fs_audio_desc, hs_audio_desc, NULL,
748                                      NULL);
749         if (ret)
750                 return ret;
751
752         agdev->gadget = gadget;
753
754         agdev->params.p_chmask = uac2_opts->p_chmask;
755         agdev->params.p_srate = uac2_opts->p_srate;
756         agdev->params.p_ssize = uac2_opts->p_ssize;
757         agdev->params.c_chmask = uac2_opts->c_chmask;
758         agdev->params.c_srate = uac2_opts->c_srate;
759         agdev->params.c_ssize = uac2_opts->c_ssize;
760         agdev->params.req_number = uac2_opts->req_number;
761         ret = g_audio_setup(agdev, "UAC2 PCM", "UAC2_Gadget");
762         if (ret)
763                 goto err_free_descs;
764         return 0;
765
766 err_free_descs:
767         usb_free_all_descriptors(fn);
768         agdev->gadget = NULL;
769         return ret;
770 }
771
772 static int
773 afunc_set_alt(struct usb_function *fn, unsigned intf, unsigned alt)
774 {
775         struct usb_composite_dev *cdev = fn->config->cdev;
776         struct f_uac2 *uac2 = func_to_uac2(fn);
777         struct usb_gadget *gadget = cdev->gadget;
778         struct device *dev = &gadget->dev;
779         int ret = 0;
780
781         /* No i/f has more than 2 alt settings */
782         if (alt > 1) {
783                 dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
784                 return -EINVAL;
785         }
786
787         if (intf == uac2->ac_intf) {
788                 /* Control I/f has only 1 AltSetting - 0 */
789                 if (alt) {
790                         dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
791                         return -EINVAL;
792                 }
793                 return 0;
794         }
795
796         if (intf == uac2->as_out_intf) {
797                 uac2->as_out_alt = alt;
798
799                 if (alt)
800                         ret = u_audio_start_capture(&uac2->g_audio);
801                 else
802                         u_audio_stop_capture(&uac2->g_audio);
803         } else if (intf == uac2->as_in_intf) {
804                 uac2->as_in_alt = alt;
805
806                 if (alt)
807                         ret = u_audio_start_playback(&uac2->g_audio);
808                 else
809                         u_audio_stop_playback(&uac2->g_audio);
810         } else {
811                 dev_err(dev, "%s:%d Error!\n", __func__, __LINE__);
812                 return -EINVAL;
813         }
814
815         return ret;
816 }
817
818 static int
819 afunc_get_alt(struct usb_function *fn, unsigned intf)
820 {
821         struct f_uac2 *uac2 = func_to_uac2(fn);
822         struct g_audio *agdev = func_to_g_audio(fn);
823
824         if (intf == uac2->ac_intf)
825                 return uac2->ac_alt;
826         else if (intf == uac2->as_out_intf)
827                 return uac2->as_out_alt;
828         else if (intf == uac2->as_in_intf)
829                 return uac2->as_in_alt;
830         else
831                 dev_err(&agdev->gadget->dev,
832                         "%s:%d Invalid Interface %d!\n",
833                         __func__, __LINE__, intf);
834
835         return -EINVAL;
836 }
837
838 static void
839 afunc_disable(struct usb_function *fn)
840 {
841         struct f_uac2 *uac2 = func_to_uac2(fn);
842
843         uac2->as_in_alt = 0;
844         uac2->as_out_alt = 0;
845         u_audio_stop_capture(&uac2->g_audio);
846         u_audio_stop_playback(&uac2->g_audio);
847 }
848
849 static int
850 in_rq_cur(struct usb_function *fn, const struct usb_ctrlrequest *cr)
851 {
852         struct usb_request *req = fn->config->cdev->req;
853         struct g_audio *agdev = func_to_g_audio(fn);
854         struct f_uac2_opts *opts;
855         u16 w_length = le16_to_cpu(cr->wLength);
856         u16 w_index = le16_to_cpu(cr->wIndex);
857         u16 w_value = le16_to_cpu(cr->wValue);
858         u8 entity_id = (w_index >> 8) & 0xff;
859         u8 control_selector = w_value >> 8;
860         int value = -EOPNOTSUPP;
861         int p_srate, c_srate;
862
863         opts = g_audio_to_uac2_opts(agdev);
864         p_srate = opts->p_srate;
865         c_srate = opts->c_srate;
866
867         if (control_selector == UAC2_CS_CONTROL_SAM_FREQ) {
868                 struct cntrl_cur_lay3 c;
869                 memset(&c, 0, sizeof(struct cntrl_cur_lay3));
870
871                 if (entity_id == USB_IN_CLK_ID)
872                         c.dCUR = cpu_to_le32(p_srate);
873                 else if (entity_id == USB_OUT_CLK_ID)
874                         c.dCUR = cpu_to_le32(c_srate);
875
876                 value = min_t(unsigned, w_length, sizeof c);
877                 memcpy(req->buf, &c, value);
878         } else if (control_selector == UAC2_CS_CONTROL_CLOCK_VALID) {
879                 *(u8 *)req->buf = 1;
880                 value = min_t(unsigned, w_length, 1);
881         } else {
882                 dev_err(&agdev->gadget->dev,
883                         "%s:%d control_selector=%d TODO!\n",
884                         __func__, __LINE__, control_selector);
885         }
886
887         return value;
888 }
889
890 static int
891 in_rq_range(struct usb_function *fn, const struct usb_ctrlrequest *cr)
892 {
893         struct usb_request *req = fn->config->cdev->req;
894         struct g_audio *agdev = func_to_g_audio(fn);
895         struct f_uac2_opts *opts;
896         u16 w_length = le16_to_cpu(cr->wLength);
897         u16 w_index = le16_to_cpu(cr->wIndex);
898         u16 w_value = le16_to_cpu(cr->wValue);
899         u8 entity_id = (w_index >> 8) & 0xff;
900         u8 control_selector = w_value >> 8;
901         struct cntrl_range_lay3 r;
902         int value = -EOPNOTSUPP;
903         int p_srate, c_srate;
904
905         opts = g_audio_to_uac2_opts(agdev);
906         p_srate = opts->p_srate;
907         c_srate = opts->c_srate;
908
909         if (control_selector == UAC2_CS_CONTROL_SAM_FREQ) {
910                 if (entity_id == USB_IN_CLK_ID)
911                         r.dMIN = cpu_to_le32(p_srate);
912                 else if (entity_id == USB_OUT_CLK_ID)
913                         r.dMIN = cpu_to_le32(c_srate);
914                 else
915                         return -EOPNOTSUPP;
916
917                 r.dMAX = r.dMIN;
918                 r.dRES = 0;
919                 r.wNumSubRanges = cpu_to_le16(1);
920
921                 value = min_t(unsigned, w_length, sizeof r);
922                 memcpy(req->buf, &r, value);
923         } else {
924                 dev_err(&agdev->gadget->dev,
925                         "%s:%d control_selector=%d TODO!\n",
926                         __func__, __LINE__, control_selector);
927         }
928
929         return value;
930 }
931
932 static int
933 ac_rq_in(struct usb_function *fn, const struct usb_ctrlrequest *cr)
934 {
935         if (cr->bRequest == UAC2_CS_CUR)
936                 return in_rq_cur(fn, cr);
937         else if (cr->bRequest == UAC2_CS_RANGE)
938                 return in_rq_range(fn, cr);
939         else
940                 return -EOPNOTSUPP;
941 }
942
943 static int
944 out_rq_cur(struct usb_function *fn, const struct usb_ctrlrequest *cr)
945 {
946         u16 w_length = le16_to_cpu(cr->wLength);
947         u16 w_value = le16_to_cpu(cr->wValue);
948         u8 control_selector = w_value >> 8;
949
950         if (control_selector == UAC2_CS_CONTROL_SAM_FREQ)
951                 return w_length;
952
953         return -EOPNOTSUPP;
954 }
955
956 static int
957 setup_rq_inf(struct usb_function *fn, const struct usb_ctrlrequest *cr)
958 {
959         struct f_uac2 *uac2 = func_to_uac2(fn);
960         struct g_audio *agdev = func_to_g_audio(fn);
961         u16 w_index = le16_to_cpu(cr->wIndex);
962         u8 intf = w_index & 0xff;
963
964         if (intf != uac2->ac_intf) {
965                 dev_err(&agdev->gadget->dev,
966                         "%s:%d Error!\n", __func__, __LINE__);
967                 return -EOPNOTSUPP;
968         }
969
970         if (cr->bRequestType & USB_DIR_IN)
971                 return ac_rq_in(fn, cr);
972         else if (cr->bRequest == UAC2_CS_CUR)
973                 return out_rq_cur(fn, cr);
974
975         return -EOPNOTSUPP;
976 }
977
978 static int
979 afunc_setup(struct usb_function *fn, const struct usb_ctrlrequest *cr)
980 {
981         struct usb_composite_dev *cdev = fn->config->cdev;
982         struct g_audio *agdev = func_to_g_audio(fn);
983         struct usb_request *req = cdev->req;
984         u16 w_length = le16_to_cpu(cr->wLength);
985         int value = -EOPNOTSUPP;
986
987         /* Only Class specific requests are supposed to reach here */
988         if ((cr->bRequestType & USB_TYPE_MASK) != USB_TYPE_CLASS)
989                 return -EOPNOTSUPP;
990
991         if ((cr->bRequestType & USB_RECIP_MASK) == USB_RECIP_INTERFACE)
992                 value = setup_rq_inf(fn, cr);
993         else
994                 dev_err(&agdev->gadget->dev, "%s:%d Error!\n",
995                                 __func__, __LINE__);
996
997         if (value >= 0) {
998                 req->length = value;
999                 req->zero = value < w_length;
1000                 value = usb_ep_queue(cdev->gadget->ep0, req, GFP_ATOMIC);
1001                 if (value < 0) {
1002                         dev_err(&agdev->gadget->dev,
1003                                 "%s:%d Error!\n", __func__, __LINE__);
1004                         req->status = 0;
1005                 }
1006         }
1007
1008         return value;
1009 }
1010
1011 static inline struct f_uac2_opts *to_f_uac2_opts(struct config_item *item)
1012 {
1013         return container_of(to_config_group(item), struct f_uac2_opts,
1014                             func_inst.group);
1015 }
1016
1017 static void f_uac2_attr_release(struct config_item *item)
1018 {
1019         struct f_uac2_opts *opts = to_f_uac2_opts(item);
1020
1021         usb_put_function_instance(&opts->func_inst);
1022 }
1023
1024 static struct configfs_item_operations f_uac2_item_ops = {
1025         .release        = f_uac2_attr_release,
1026 };
1027
1028 #define UAC2_ATTRIBUTE(name)                                            \
1029 static ssize_t f_uac2_opts_##name##_show(struct config_item *item,      \
1030                                          char *page)                    \
1031 {                                                                       \
1032         struct f_uac2_opts *opts = to_f_uac2_opts(item);                \
1033         int result;                                                     \
1034                                                                         \
1035         mutex_lock(&opts->lock);                                        \
1036         result = sprintf(page, "%u\n", opts->name);                     \
1037         mutex_unlock(&opts->lock);                                      \
1038                                                                         \
1039         return result;                                                  \
1040 }                                                                       \
1041                                                                         \
1042 static ssize_t f_uac2_opts_##name##_store(struct config_item *item,     \
1043                                           const char *page, size_t len) \
1044 {                                                                       \
1045         struct f_uac2_opts *opts = to_f_uac2_opts(item);                \
1046         int ret;                                                        \
1047         u32 num;                                                        \
1048                                                                         \
1049         mutex_lock(&opts->lock);                                        \
1050         if (opts->refcnt) {                                             \
1051                 ret = -EBUSY;                                           \
1052                 goto end;                                               \
1053         }                                                               \
1054                                                                         \
1055         ret = kstrtou32(page, 0, &num);                                 \
1056         if (ret)                                                        \
1057                 goto end;                                               \
1058                                                                         \
1059         opts->name = num;                                               \
1060         ret = len;                                                      \
1061                                                                         \
1062 end:                                                                    \
1063         mutex_unlock(&opts->lock);                                      \
1064         return ret;                                                     \
1065 }                                                                       \
1066                                                                         \
1067 CONFIGFS_ATTR(f_uac2_opts_, name)
1068
1069 UAC2_ATTRIBUTE(p_chmask);
1070 UAC2_ATTRIBUTE(p_srate);
1071 UAC2_ATTRIBUTE(p_ssize);
1072 UAC2_ATTRIBUTE(c_chmask);
1073 UAC2_ATTRIBUTE(c_srate);
1074 UAC2_ATTRIBUTE(c_ssize);
1075 UAC2_ATTRIBUTE(req_number);
1076
1077 static struct configfs_attribute *f_uac2_attrs[] = {
1078         &f_uac2_opts_attr_p_chmask,
1079         &f_uac2_opts_attr_p_srate,
1080         &f_uac2_opts_attr_p_ssize,
1081         &f_uac2_opts_attr_c_chmask,
1082         &f_uac2_opts_attr_c_srate,
1083         &f_uac2_opts_attr_c_ssize,
1084         &f_uac2_opts_attr_req_number,
1085         NULL,
1086 };
1087
1088 static const struct config_item_type f_uac2_func_type = {
1089         .ct_item_ops    = &f_uac2_item_ops,
1090         .ct_attrs       = f_uac2_attrs,
1091         .ct_owner       = THIS_MODULE,
1092 };
1093
1094 static void afunc_free_inst(struct usb_function_instance *f)
1095 {
1096         struct f_uac2_opts *opts;
1097
1098         opts = container_of(f, struct f_uac2_opts, func_inst);
1099         kfree(opts);
1100 }
1101
1102 static struct usb_function_instance *afunc_alloc_inst(void)
1103 {
1104         struct f_uac2_opts *opts;
1105
1106         opts = kzalloc(sizeof(*opts), GFP_KERNEL);
1107         if (!opts)
1108                 return ERR_PTR(-ENOMEM);
1109
1110         mutex_init(&opts->lock);
1111         opts->func_inst.free_func_inst = afunc_free_inst;
1112
1113         config_group_init_type_name(&opts->func_inst.group, "",
1114                                     &f_uac2_func_type);
1115
1116         opts->p_chmask = UAC2_DEF_PCHMASK;
1117         opts->p_srate = UAC2_DEF_PSRATE;
1118         opts->p_ssize = UAC2_DEF_PSSIZE;
1119         opts->c_chmask = UAC2_DEF_CCHMASK;
1120         opts->c_srate = UAC2_DEF_CSRATE;
1121         opts->c_ssize = UAC2_DEF_CSSIZE;
1122         opts->req_number = UAC2_DEF_REQ_NUM;
1123         return &opts->func_inst;
1124 }
1125
1126 static void afunc_free(struct usb_function *f)
1127 {
1128         struct g_audio *agdev;
1129         struct f_uac2_opts *opts;
1130
1131         agdev = func_to_g_audio(f);
1132         opts = container_of(f->fi, struct f_uac2_opts, func_inst);
1133         kfree(agdev);
1134         mutex_lock(&opts->lock);
1135         --opts->refcnt;
1136         mutex_unlock(&opts->lock);
1137 }
1138
1139 static void afunc_unbind(struct usb_configuration *c, struct usb_function *f)
1140 {
1141         struct g_audio *agdev = func_to_g_audio(f);
1142
1143         g_audio_cleanup(agdev);
1144         usb_free_all_descriptors(f);
1145
1146         agdev->gadget = NULL;
1147 }
1148
1149 static struct usb_function *afunc_alloc(struct usb_function_instance *fi)
1150 {
1151         struct f_uac2   *uac2;
1152         struct f_uac2_opts *opts;
1153
1154         uac2 = kzalloc(sizeof(*uac2), GFP_KERNEL);
1155         if (uac2 == NULL)
1156                 return ERR_PTR(-ENOMEM);
1157
1158         opts = container_of(fi, struct f_uac2_opts, func_inst);
1159         mutex_lock(&opts->lock);
1160         ++opts->refcnt;
1161         mutex_unlock(&opts->lock);
1162
1163         uac2->g_audio.func.name = "uac2_func";
1164         uac2->g_audio.func.bind = afunc_bind;
1165         uac2->g_audio.func.unbind = afunc_unbind;
1166         uac2->g_audio.func.set_alt = afunc_set_alt;
1167         uac2->g_audio.func.get_alt = afunc_get_alt;
1168         uac2->g_audio.func.disable = afunc_disable;
1169         uac2->g_audio.func.setup = afunc_setup;
1170         uac2->g_audio.func.free_func = afunc_free;
1171
1172         return &uac2->g_audio.func;
1173 }
1174
1175 DECLARE_USB_FUNCTION_INIT(uac2, afunc_alloc_inst, afunc_alloc);
1176 MODULE_LICENSE("GPL");
1177 MODULE_AUTHOR("Yadwinder Singh");
1178 MODULE_AUTHOR("Jaswinder Singh");