Lines Matching +full:data +full:- +full:rates
1 // SPDX-License-Identifier: GPL-2.0-or-later
9 #include <linux/usb/audio-v2.h>
10 #include <linux/usb/audio-v3.h>
38 switch (fp->protocol) { in parse_audio_format_i_type()
45 fp->iface, fp->altsetting, format); in parse_audio_format_i_type()
48 sample_width = fmt->bBitResolution; in parse_audio_format_i_type()
49 sample_bytes = fmt->bSubframeSize; in parse_audio_format_i_type()
56 sample_width = fmt->bBitResolution; in parse_audio_format_i_type()
57 sample_bytes = fmt->bSubslotSize; in parse_audio_format_i_type()
62 fp->dsd_raw = true; in parse_audio_format_i_type()
73 sample_width = as->bBitResolution; in parse_audio_format_i_type()
74 sample_bytes = as->bSubslotSize; in parse_audio_format_i_type()
87 fp->fmt_bits = sample_width; in parse_audio_format_i_type()
93 fp->iface, fp->altsetting); in parse_audio_format_i_type()
97 if (((chip->usb_id == USB_ID(0x0582, 0x0016)) || in parse_audio_format_i_type()
98 /* Edirol SD-90 */ in parse_audio_format_i_type()
99 (chip->usb_id == USB_ID(0x0582, 0x000c))) && in parse_audio_format_i_type()
100 /* Roland SC-D70 */ in parse_audio_format_i_type()
105 fp->iface, fp->altsetting, in parse_audio_format_i_type()
131 fp->iface, fp->altsetting, in parse_audio_format_i_type()
139 if (chip->usb_id == USB_ID(0x04fa, 0x4201)) in parse_audio_format_i_type()
156 fp->iface, fp->altsetting, format); in parse_audio_format_i_type()
166 kfree(fp->rate_table); in set_fixed_rate()
167 fp->rate_table = kmalloc(sizeof(int), GFP_KERNEL); in set_fixed_rate()
168 if (!fp->rate_table) in set_fixed_rate()
169 return -ENOMEM; in set_fixed_rate()
170 fp->nr_rates = 1; in set_fixed_rate()
171 fp->rate_min = rate; in set_fixed_rate()
172 fp->rate_max = rate; in set_fixed_rate()
173 fp->rates = rate_bits; in set_fixed_rate()
174 fp->rate_table[0] = rate; in set_fixed_rate()
178 /* set up rate_min, rate_max and rates from the rate table */
184 fp->rate_min = INT_MAX; in set_rate_table_min_max()
185 fp->rate_max = 0; in set_rate_table_min_max()
186 fp->rates = 0; in set_rate_table_min_max()
187 for (i = 0; i < fp->nr_rates; i++) { in set_rate_table_min_max()
188 rate = fp->rate_table[i]; in set_rate_table_min_max()
189 fp->rate_min = min(fp->rate_min, rate); in set_rate_table_min_max()
190 fp->rate_max = max(fp->rate_max, rate); in set_rate_table_min_max()
191 fp->rates |= snd_pcm_rate_to_rate_bit(rate); in set_rate_table_min_max()
196 * parse the format descriptor and stores the possible sample rates
213 fp->iface, fp->altsetting); in parse_audio_format_rates_v1()
214 return -EINVAL; in parse_audio_format_rates_v1()
223 fp->rate_table = kmalloc_array(nr_rates, sizeof(int), in parse_audio_format_rates_v1()
225 if (fp->rate_table == NULL) in parse_audio_format_rates_v1()
226 return -ENOMEM; in parse_audio_format_rates_v1()
228 fp->nr_rates = 0; in parse_audio_format_rates_v1()
233 /* C-Media CM6501 mislabels its 96 kHz altsetting */ in parse_audio_format_rates_v1()
234 /* Terratec Aureon 7.1 USB C-Media 6206, too */ in parse_audio_format_rates_v1()
235 /* Ozone Z90 USB C-Media, too */ in parse_audio_format_rates_v1()
237 (chip->usb_id == USB_ID(0x0d8c, 0x0201) || in parse_audio_format_rates_v1()
238 chip->usb_id == USB_ID(0x0d8c, 0x0102) || in parse_audio_format_rates_v1()
239 chip->usb_id == USB_ID(0x0d8c, 0x0078) || in parse_audio_format_rates_v1()
240 chip->usb_id == USB_ID(0x0ccd, 0x00b1)) && in parse_audio_format_rates_v1()
241 fp->altsetting == 5 && fp->maxpacksize == 392) in parse_audio_format_rates_v1()
245 (chip->usb_id == USB_ID(0x041e, 0x4064) || in parse_audio_format_rates_v1()
246 chip->usb_id == USB_ID(0x041e, 0x4068))) in parse_audio_format_rates_v1()
249 fp->rate_table[fp->nr_rates++] = rate; in parse_audio_format_rates_v1()
251 if (!fp->nr_rates) { in parse_audio_format_rates_v1()
253 "%u:%d: All rates were zero\n", in parse_audio_format_rates_v1()
254 fp->iface, fp->altsetting); in parse_audio_format_rates_v1()
255 return -EINVAL; in parse_audio_format_rates_v1()
259 /* continuous rates */ in parse_audio_format_rates_v1()
260 fp->rates = SNDRV_PCM_RATE_CONTINUOUS; in parse_audio_format_rates_v1()
261 fp->rate_min = combine_triple(&fmt[offset + 1]); in parse_audio_format_rates_v1()
262 fp->rate_max = combine_triple(&fmt[offset + 4]); in parse_audio_format_rates_v1()
266 if (chip->usb_id == USB_ID(0x0b0e, 0x030b)) { in parse_audio_format_rates_v1()
268 if (fp->nr_rates != 1) in parse_audio_format_rates_v1()
278 * rates per altsetting but reports the full set each time.
279 * If we don't filter out the unsupported rates and attempt
283 * The list of supported rates per altsetting (set of available
289 switch (fp->altsetting) { in s1810c_valid_sample_rate()
306 * Many Focusrite devices supports a limited set of sampling rates per
308 * descriptor which has a non-standard bLength = 10.
319 iface = usb_ifnum_to_if(chip->dev, fp->iface); in focusrite_valid_sample_rate()
323 alts = &iface->altsetting[fp->altset_idx]; in focusrite_valid_sample_rate()
324 fmt = snd_usb_find_csint_desc(alts->extra, alts->extralen, in focusrite_valid_sample_rate()
340 fp->iface, fp->altsetting, max_rate); in focusrite_valid_sample_rate()
354 * get to know how many sample rates we have to expect.
355 * Then fp->rate_table can be allocated and filled.
359 const unsigned char *data) in parse_uac2_sample_rate_range() argument
364 int min = combine_quad(&data[2 + 12 * i]); in parse_uac2_sample_rate_range()
365 int max = combine_quad(&data[6 + 12 * i]); in parse_uac2_sample_rate_range()
366 int res = combine_quad(&data[10 + 12 * i]); in parse_uac2_sample_rate_range()
378 fp->rate_min = min; in parse_uac2_sample_rate_range()
379 fp->rate_max = max; in parse_uac2_sample_rate_range()
380 fp->rates = SNDRV_PCM_RATE_CONTINUOUS; in parse_uac2_sample_rate_range()
386 /* Filter out invalid rates on Presonus Studio 1810c */ in parse_uac2_sample_rate_range()
387 if (chip->usb_id == USB_ID(0x194f, 0x010c) && in parse_uac2_sample_rate_range()
391 /* Filter out invalid rates on Focusrite devices */ in parse_uac2_sample_rate_range()
392 if (USB_ID_VENDOR(chip->usb_id) == 0x1235 && in parse_uac2_sample_rate_range()
396 if (fp->rate_table) in parse_uac2_sample_rate_range()
397 fp->rate_table[nr_rates] = rate; in parse_uac2_sample_rate_range()
400 usb_audio_err(chip, "invalid uac2 rates\n"); in parse_uac2_sample_rate_range()
416 * clock rates.
421 switch (chip->usb_id) { in line6_parse_audio_format_rates_quirk()
425 case USB_ID(0x0e41, 0x4246): /* Line6 HX-Stomp */ in line6_parse_audio_format_rates_quirk()
426 case USB_ID(0x0e41, 0x4253): /* Line6 HX-Stomp XL */ in line6_parse_audio_format_rates_quirk()
436 return -ENODEV; in line6_parse_audio_format_rates_quirk()
443 struct usb_device *dev = chip->dev; in check_valid_altsetting_v2v3()
445 u64 data; in check_valid_altsetting_v2v3() local
449 if (snd_BUG_ON(altsetting >= 64 - 8)) in check_valid_altsetting_v2v3()
459 data = le64_to_cpu(raw_data); in check_valid_altsetting_v2v3()
461 if ((data & 0xff) * 8 < altsetting) in check_valid_altsetting_v2v3()
463 if (data & (1ULL << (altsetting + 8))) in check_valid_altsetting_v2v3()
477 struct usb_device *dev = chip->dev; in validate_sample_rate_table_v2v3()
488 if (!(chip->quirk_flags & QUIRK_FLAG_VALIDATE_RATES)) in validate_sample_rate_table_v2v3()
491 alts = snd_usb_get_host_interface(chip, fp->iface, fp->altsetting); in validate_sample_rate_table_v2v3()
495 if (fp->protocol == UAC_VERSION_3) { in validate_sample_rate_table_v2v3()
497 alts->extra, alts->extralen, NULL, UAC_AS_GENERAL); in validate_sample_rate_table_v2v3()
498 bmControls = le32_to_cpu(as->bmControls); in validate_sample_rate_table_v2v3()
501 alts->extra, alts->extralen, NULL, UAC_AS_GENERAL); in validate_sample_rate_table_v2v3()
502 bmControls = as->bmControls; in validate_sample_rate_table_v2v3()
509 table = kcalloc(fp->nr_rates, sizeof(*table), GFP_KERNEL); in validate_sample_rate_table_v2v3()
511 return -ENOMEM; in validate_sample_rate_table_v2v3()
514 usb_set_interface(dev, fp->iface, 0); in validate_sample_rate_table_v2v3()
517 for (i = 0; i < fp->nr_rates; i++) { in validate_sample_rate_table_v2v3()
519 fp->rate_table[i]); in validate_sample_rate_table_v2v3()
523 if (check_valid_altsetting_v2v3(chip, fp->iface, fp->altsetting)) in validate_sample_rate_table_v2v3()
524 table[nr_rates++] = fp->rate_table[i]; in validate_sample_rate_table_v2v3()
530 fp->iface, fp->altsetting); in validate_sample_rate_table_v2v3()
531 nr_rates = fp->nr_rates; /* continue as is */ in validate_sample_rate_table_v2v3()
534 if (fp->nr_rates == nr_rates) { in validate_sample_rate_table_v2v3()
539 kfree(fp->rate_table); in validate_sample_rate_table_v2v3()
540 fp->rate_table = table; in validate_sample_rate_table_v2v3()
541 fp->nr_rates = nr_rates; in validate_sample_rate_table_v2v3()
546 * parse the format descriptor and stores the possible sample rates
552 struct usb_device *dev = chip->dev; in parse_audio_format_rates_v2v3()
553 unsigned char tmp[2], *data; in parse_audio_format_rates_v2v3() local
558 dev_err(&dev->dev, in parse_audio_format_rates_v2v3()
564 /* get the number of sample rates first by only fetching 2 bytes */ in parse_audio_format_rates_v2v3()
574 if (ret_l6 == -ENODEV) { in parse_audio_format_rates_v2v3()
576 dev_err(&dev->dev, in parse_audio_format_rates_v2v3()
577 "%s(): unable to retrieve number of sample rates (clock %d)\n", in parse_audio_format_rates_v2v3()
582 dev_info(&dev->dev, in parse_audio_format_rates_v2v3()
583 "%s(): unable to retrieve number of sample rates: set it to a predefined value (clock %d).\n", in parse_audio_format_rates_v2v3()
593 data = kzalloc(data_size, GFP_KERNEL); in parse_audio_format_rates_v2v3()
594 if (!data) { in parse_audio_format_rates_v2v3()
595 ret = -ENOMEM; in parse_audio_format_rates_v2v3()
604 data, data_size); in parse_audio_format_rates_v2v3()
607 dev_err(&dev->dev, in parse_audio_format_rates_v2v3()
610 ret = -EINVAL; in parse_audio_format_rates_v2v3()
614 /* Call the triplet parser, and make sure fp->rate_table is NULL. in parse_audio_format_rates_v2v3()
615 * We just use the return value to know how many sample rates we in parse_audio_format_rates_v2v3()
617 kfree(fp->rate_table); in parse_audio_format_rates_v2v3()
618 fp->rate_table = NULL; in parse_audio_format_rates_v2v3()
619 fp->nr_rates = parse_uac2_sample_rate_range(chip, fp, nr_triplets, data); in parse_audio_format_rates_v2v3()
621 if (fp->nr_rates == 0) { in parse_audio_format_rates_v2v3()
627 fp->rate_table = kmalloc_array(fp->nr_rates, sizeof(int), GFP_KERNEL); in parse_audio_format_rates_v2v3()
628 if (!fp->rate_table) { in parse_audio_format_rates_v2v3()
629 ret = -ENOMEM; in parse_audio_format_rates_v2v3()
633 /* Call the triplet parser again, but this time, fp->rate_table is in parse_audio_format_rates_v2v3()
634 * allocated, so the rates will be stored */ in parse_audio_format_rates_v2v3()
635 parse_uac2_sample_rate_range(chip, fp, nr_triplets, data); in parse_audio_format_rates_v2v3()
644 kfree(data); in parse_audio_format_rates_v2v3()
660 switch (fp->protocol) { in parse_audio_format_i()
666 fmt_type = fmt->bFormatType; in parse_audio_format_i()
670 /* fp->fmt_type is already set in this case */ in parse_audio_format_i()
671 fmt_type = fp->fmt_type; in parse_audio_format_i()
681 switch (chip->usb_id) { in parse_audio_format_i()
683 case USB_ID(0x0763, 0x2003): /* M-Audio Audiophile USB */ in parse_audio_format_i()
684 if (chip->setup == 0x00 && in parse_audio_format_i()
685 fp->altsetting == 6) in parse_audio_format_i()
693 fp->formats = pcm_format_to_bits(pcm_format); in parse_audio_format_i()
695 fp->formats = parse_audio_format_i_type(chip, fp, format, _fmt); in parse_audio_format_i()
696 if (!fp->formats) in parse_audio_format_i()
697 return -EINVAL; in parse_audio_format_i()
700 /* gather possible sample rates */ in parse_audio_format_i()
701 /* audio class v1 reports possible sample rates as part of the in parse_audio_format_i()
705 switch (fp->protocol) { in parse_audio_format_i()
710 fp->channels = fmt->bNrChannels; in parse_audio_format_i()
716 /* fp->channels is already set in this case */ in parse_audio_format_i()
722 if (fp->channels < 1) { in parse_audio_format_i()
725 fp->iface, fp->altsetting, fp->channels); in parse_audio_format_i()
726 return -EINVAL; in parse_audio_format_i()
744 // fp->formats = SNDRV_PCM_FMTBIT_AC3; in parse_audio_format_ii()
745 fp->formats = SNDRV_PCM_FMTBIT_U8; /* temporary hack to receive byte streams */ in parse_audio_format_ii()
748 fp->formats = SNDRV_PCM_FMTBIT_MPEG; in parse_audio_format_ii()
753 fp->iface, fp->altsetting, format); in parse_audio_format_ii()
754 fp->formats = SNDRV_PCM_FMTBIT_MPEG; in parse_audio_format_ii()
758 fp->channels = 1; in parse_audio_format_ii()
760 switch (fp->protocol) { in parse_audio_format_ii()
764 brate = le16_to_cpu(fmt->wMaxBitRate); in parse_audio_format_ii()
765 framesize = le16_to_cpu(fmt->wSamplesPerFrame); in parse_audio_format_ii()
767 fp->frame_size = framesize; in parse_audio_format_ii()
768 ret = parse_audio_format_rates_v1(chip, fp, _fmt, 8); /* fmt[8..] sample rates */ in parse_audio_format_ii()
773 brate = le16_to_cpu(fmt->wMaxBitRate); in parse_audio_format_ii()
774 framesize = le16_to_cpu(fmt->wSamplesPerFrame); in parse_audio_format_ii()
776 fp->frame_size = framesize; in parse_audio_format_ii()
792 switch (fmt->bFormatType) { in snd_usb_parse_audio_format()
803 fp->iface, fp->altsetting, in snd_usb_parse_audio_format()
804 fmt->bFormatType); in snd_usb_parse_audio_format()
805 return -ENOTSUPP; in snd_usb_parse_audio_format()
807 fp->fmt_type = fmt->bFormatType; in snd_usb_parse_audio_format()
812 /* extigy apparently supports sample rates other than 48k in snd_usb_parse_audio_format()
815 if (chip->usb_id == USB_ID(0x041e, 0x3000) || in snd_usb_parse_audio_format()
816 chip->usb_id == USB_ID(0x041e, 0x3020) || in snd_usb_parse_audio_format()
817 chip->usb_id == USB_ID(0x041e, 0x3061)) { in snd_usb_parse_audio_format()
818 if (fmt->bFormatType == UAC_FORMAT_TYPE_I && in snd_usb_parse_audio_format()
819 fp->rates != SNDRV_PCM_RATE_48000 && in snd_usb_parse_audio_format()
820 fp->rates != SNDRV_PCM_RATE_96000) in snd_usb_parse_audio_format()
821 return -ENOTSUPP; in snd_usb_parse_audio_format()
832 u64 format = le64_to_cpu(as->bmFormats); in snd_usb_parse_audio_format_v3()
840 fp->fmt_type = UAC_FORMAT_TYPE_I; in snd_usb_parse_audio_format_v3()
842 fp->fmt_type = UAC_FORMAT_TYPE_III; in snd_usb_parse_audio_format_v3()