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()
267 chip->usb_id == USB_ID(0x0b0e, 0x030c)) { in parse_audio_format_rates_v1()
269 if (fp->nr_rates != 1) in parse_audio_format_rates_v1()
279 * rates per altsetting but reports the full set each time.
280 * If we don't filter out the unsupported rates and attempt
284 * The list of supported rates per altsetting (set of available
290 switch (fp->altsetting) { in s1810c_valid_sample_rate()
307 * Many Focusrite devices supports a limited set of sampling rates per
309 * descriptor which has a non-standard bLength = 10.
320 iface = usb_ifnum_to_if(chip->dev, fp->iface); in focusrite_valid_sample_rate()
324 alts = &iface->altsetting[fp->altset_idx]; in focusrite_valid_sample_rate()
325 fmt = snd_usb_find_csint_desc(alts->extra, alts->extralen, in focusrite_valid_sample_rate()
341 fp->iface, fp->altsetting, max_rate); in focusrite_valid_sample_rate()
355 * get to know how many sample rates we have to expect.
356 * Then fp->rate_table can be allocated and filled.
360 const unsigned char *data) in parse_uac2_sample_rate_range() argument
365 int min = combine_quad(&data[2 + 12 * i]); in parse_uac2_sample_rate_range()
366 int max = combine_quad(&data[6 + 12 * i]); in parse_uac2_sample_rate_range()
367 int res = combine_quad(&data[10 + 12 * i]); in parse_uac2_sample_rate_range()
379 fp->rate_min = min; in parse_uac2_sample_rate_range()
380 fp->rate_max = max; in parse_uac2_sample_rate_range()
381 fp->rates = SNDRV_PCM_RATE_CONTINUOUS; in parse_uac2_sample_rate_range()
387 /* Filter out invalid rates on Presonus Studio 1810c */ in parse_uac2_sample_rate_range()
388 if (chip->usb_id == USB_ID(0x194f, 0x010c) && in parse_uac2_sample_rate_range()
392 /* Filter out invalid rates on Focusrite devices */ in parse_uac2_sample_rate_range()
393 if (USB_ID_VENDOR(chip->usb_id) == 0x1235 && in parse_uac2_sample_rate_range()
397 if (fp->rate_table) in parse_uac2_sample_rate_range()
398 fp->rate_table[nr_rates] = rate; in parse_uac2_sample_rate_range()
401 usb_audio_err(chip, "invalid uac2 rates\n"); in parse_uac2_sample_rate_range()
417 * clock rates.
422 switch (chip->usb_id) { in line6_parse_audio_format_rates_quirk()
426 case USB_ID(0x0e41, 0x4246): /* Line6 HX-Stomp */ in line6_parse_audio_format_rates_quirk()
427 case USB_ID(0x0e41, 0x4253): /* Line6 HX-Stomp XL */ in line6_parse_audio_format_rates_quirk()
437 return -ENODEV; in line6_parse_audio_format_rates_quirk()
444 struct usb_device *dev = chip->dev; in check_valid_altsetting_v2v3()
446 u64 data; in check_valid_altsetting_v2v3() local
450 if (snd_BUG_ON(altsetting >= 64 - 8)) in check_valid_altsetting_v2v3()
460 data = le64_to_cpu(raw_data); in check_valid_altsetting_v2v3()
462 if ((data & 0xff) * 8 < altsetting) in check_valid_altsetting_v2v3()
464 if (data & (1ULL << (altsetting + 8))) in check_valid_altsetting_v2v3()
478 struct usb_device *dev = chip->dev; in validate_sample_rate_table_v2v3()
489 if (!(chip->quirk_flags & QUIRK_FLAG_VALIDATE_RATES)) in validate_sample_rate_table_v2v3()
492 alts = snd_usb_get_host_interface(chip, fp->iface, fp->altsetting); in validate_sample_rate_table_v2v3()
496 if (fp->protocol == UAC_VERSION_3) { in validate_sample_rate_table_v2v3()
498 alts->extra, alts->extralen, NULL, UAC_AS_GENERAL); in validate_sample_rate_table_v2v3()
499 bmControls = le32_to_cpu(as->bmControls); in validate_sample_rate_table_v2v3()
502 alts->extra, alts->extralen, NULL, UAC_AS_GENERAL); in validate_sample_rate_table_v2v3()
503 bmControls = as->bmControls; in validate_sample_rate_table_v2v3()
510 table = kcalloc(fp->nr_rates, sizeof(*table), GFP_KERNEL); in validate_sample_rate_table_v2v3()
512 return -ENOMEM; in validate_sample_rate_table_v2v3()
515 usb_set_interface(dev, fp->iface, 0); in validate_sample_rate_table_v2v3()
518 for (i = 0; i < fp->nr_rates; i++) { in validate_sample_rate_table_v2v3()
520 fp->rate_table[i]); in validate_sample_rate_table_v2v3()
524 if (check_valid_altsetting_v2v3(chip, fp->iface, fp->altsetting)) in validate_sample_rate_table_v2v3()
525 table[nr_rates++] = fp->rate_table[i]; in validate_sample_rate_table_v2v3()
531 fp->iface, fp->altsetting); in validate_sample_rate_table_v2v3()
532 nr_rates = fp->nr_rates; /* continue as is */ in validate_sample_rate_table_v2v3()
535 if (fp->nr_rates == nr_rates) { in validate_sample_rate_table_v2v3()
540 kfree(fp->rate_table); in validate_sample_rate_table_v2v3()
541 fp->rate_table = table; in validate_sample_rate_table_v2v3()
542 fp->nr_rates = nr_rates; in validate_sample_rate_table_v2v3()
547 * parse the format descriptor and stores the possible sample rates
553 struct usb_device *dev = chip->dev; in parse_audio_format_rates_v2v3()
554 unsigned char tmp[2], *data; in parse_audio_format_rates_v2v3() local
559 dev_err(&dev->dev, in parse_audio_format_rates_v2v3()
565 /* get the number of sample rates first by only fetching 2 bytes */ in parse_audio_format_rates_v2v3()
575 if (ret_l6 == -ENODEV) { in parse_audio_format_rates_v2v3()
577 dev_err(&dev->dev, in parse_audio_format_rates_v2v3()
578 "%s(): unable to retrieve number of sample rates (clock %d)\n", in parse_audio_format_rates_v2v3()
583 dev_info(&dev->dev, in parse_audio_format_rates_v2v3()
584 "%s(): unable to retrieve number of sample rates: set it to a predefined value (clock %d).\n", in parse_audio_format_rates_v2v3()
594 data = kzalloc(data_size, GFP_KERNEL); in parse_audio_format_rates_v2v3()
595 if (!data) { in parse_audio_format_rates_v2v3()
596 ret = -ENOMEM; in parse_audio_format_rates_v2v3()
605 data, data_size); in parse_audio_format_rates_v2v3()
608 dev_err(&dev->dev, in parse_audio_format_rates_v2v3()
611 ret = -EINVAL; in parse_audio_format_rates_v2v3()
615 /* Call the triplet parser, and make sure fp->rate_table is NULL. in parse_audio_format_rates_v2v3()
616 * We just use the return value to know how many sample rates we in parse_audio_format_rates_v2v3()
618 kfree(fp->rate_table); in parse_audio_format_rates_v2v3()
619 fp->rate_table = NULL; in parse_audio_format_rates_v2v3()
620 fp->nr_rates = parse_uac2_sample_rate_range(chip, fp, nr_triplets, data); in parse_audio_format_rates_v2v3()
622 if (fp->nr_rates == 0) { in parse_audio_format_rates_v2v3()
628 fp->rate_table = kmalloc_array(fp->nr_rates, sizeof(int), GFP_KERNEL); in parse_audio_format_rates_v2v3()
629 if (!fp->rate_table) { in parse_audio_format_rates_v2v3()
630 ret = -ENOMEM; in parse_audio_format_rates_v2v3()
634 /* Call the triplet parser again, but this time, fp->rate_table is in parse_audio_format_rates_v2v3()
635 * allocated, so the rates will be stored */ in parse_audio_format_rates_v2v3()
636 parse_uac2_sample_rate_range(chip, fp, nr_triplets, data); in parse_audio_format_rates_v2v3()
645 kfree(data); in parse_audio_format_rates_v2v3()
661 switch (fp->protocol) { in parse_audio_format_i()
667 fmt_type = fmt->bFormatType; in parse_audio_format_i()
671 /* fp->fmt_type is already set in this case */ in parse_audio_format_i()
672 fmt_type = fp->fmt_type; in parse_audio_format_i()
682 switch (chip->usb_id) { in parse_audio_format_i()
684 case USB_ID(0x0763, 0x2003): /* M-Audio Audiophile USB */ in parse_audio_format_i()
685 if (chip->setup == 0x00 && in parse_audio_format_i()
686 fp->altsetting == 6) in parse_audio_format_i()
694 fp->formats = pcm_format_to_bits(pcm_format); in parse_audio_format_i()
696 fp->formats = parse_audio_format_i_type(chip, fp, format, _fmt); in parse_audio_format_i()
697 if (!fp->formats) in parse_audio_format_i()
698 return -EINVAL; in parse_audio_format_i()
701 /* gather possible sample rates */ in parse_audio_format_i()
702 /* audio class v1 reports possible sample rates as part of the in parse_audio_format_i()
706 switch (fp->protocol) { in parse_audio_format_i()
711 fp->channels = fmt->bNrChannels; in parse_audio_format_i()
717 /* fp->channels is already set in this case */ in parse_audio_format_i()
723 if (fp->channels < 1) { in parse_audio_format_i()
726 fp->iface, fp->altsetting, fp->channels); in parse_audio_format_i()
727 return -EINVAL; in parse_audio_format_i()
745 // fp->formats = SNDRV_PCM_FMTBIT_AC3; in parse_audio_format_ii()
746 fp->formats = SNDRV_PCM_FMTBIT_U8; /* temporary hack to receive byte streams */ in parse_audio_format_ii()
749 fp->formats = SNDRV_PCM_FMTBIT_MPEG; in parse_audio_format_ii()
754 fp->iface, fp->altsetting, format); in parse_audio_format_ii()
755 fp->formats = SNDRV_PCM_FMTBIT_MPEG; in parse_audio_format_ii()
759 fp->channels = 1; in parse_audio_format_ii()
761 switch (fp->protocol) { in parse_audio_format_ii()
765 brate = le16_to_cpu(fmt->wMaxBitRate); in parse_audio_format_ii()
766 framesize = le16_to_cpu(fmt->wSamplesPerFrame); in parse_audio_format_ii()
768 fp->frame_size = framesize; in parse_audio_format_ii()
769 ret = parse_audio_format_rates_v1(chip, fp, _fmt, 8); /* fmt[8..] sample rates */ in parse_audio_format_ii()
774 brate = le16_to_cpu(fmt->wMaxBitRate); in parse_audio_format_ii()
775 framesize = le16_to_cpu(fmt->wSamplesPerFrame); in parse_audio_format_ii()
777 fp->frame_size = framesize; in parse_audio_format_ii()
793 switch (fmt->bFormatType) { in snd_usb_parse_audio_format()
804 fp->iface, fp->altsetting, in snd_usb_parse_audio_format()
805 fmt->bFormatType); in snd_usb_parse_audio_format()
806 return -ENOTSUPP; in snd_usb_parse_audio_format()
808 fp->fmt_type = fmt->bFormatType; in snd_usb_parse_audio_format()
813 /* extigy apparently supports sample rates other than 48k in snd_usb_parse_audio_format()
816 if (chip->usb_id == USB_ID(0x041e, 0x3000) || in snd_usb_parse_audio_format()
817 chip->usb_id == USB_ID(0x041e, 0x3020) || in snd_usb_parse_audio_format()
818 chip->usb_id == USB_ID(0x041e, 0x3061)) { in snd_usb_parse_audio_format()
819 if (fmt->bFormatType == UAC_FORMAT_TYPE_I && in snd_usb_parse_audio_format()
820 fp->rates != SNDRV_PCM_RATE_48000 && in snd_usb_parse_audio_format()
821 fp->rates != SNDRV_PCM_RATE_96000) in snd_usb_parse_audio_format()
822 return -ENOTSUPP; in snd_usb_parse_audio_format()
833 u64 format = le64_to_cpu(as->bmFormats); in snd_usb_parse_audio_format_v3()
841 fp->fmt_type = UAC_FORMAT_TYPE_I; in snd_usb_parse_audio_format_v3()
843 fp->fmt_type = UAC_FORMAT_TYPE_III; in snd_usb_parse_audio_format_v3()