Merge branch 'topic/fixes' into for-linus
Signed-off-by: Takashi Iwai <tiwai@suse.de>
This commit is contained in:
@@ -347,17 +347,20 @@ static int get_ctl_value_v2(struct usb_mixer_elem_info *cval, int request,
|
||||
int validx, int *value_ret)
|
||||
{
|
||||
struct snd_usb_audio *chip = cval->head.mixer->chip;
|
||||
unsigned char buf[4 + 3 * sizeof(__u32)]; /* enough space for one range */
|
||||
/* enough space for one range */
|
||||
unsigned char buf[sizeof(__u16) + 3 * sizeof(__u32)];
|
||||
unsigned char *val;
|
||||
int idx = 0, ret, size;
|
||||
int idx = 0, ret, val_size, size;
|
||||
__u8 bRequest;
|
||||
|
||||
val_size = uac2_ctl_value_size(cval->val_type);
|
||||
|
||||
if (request == UAC_GET_CUR) {
|
||||
bRequest = UAC2_CS_CUR;
|
||||
size = uac2_ctl_value_size(cval->val_type);
|
||||
size = val_size;
|
||||
} else {
|
||||
bRequest = UAC2_CS_RANGE;
|
||||
size = sizeof(buf);
|
||||
size = sizeof(__u16) + 3 * val_size;
|
||||
}
|
||||
|
||||
memset(buf, 0, sizeof(buf));
|
||||
@@ -390,16 +393,17 @@ error:
|
||||
val = buf + sizeof(__u16);
|
||||
break;
|
||||
case UAC_GET_MAX:
|
||||
val = buf + sizeof(__u16) * 2;
|
||||
val = buf + sizeof(__u16) + val_size;
|
||||
break;
|
||||
case UAC_GET_RES:
|
||||
val = buf + sizeof(__u16) * 3;
|
||||
val = buf + sizeof(__u16) + val_size * 2;
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
*value_ret = convert_signed_value(cval, snd_usb_combine_bytes(val, sizeof(__u16)));
|
||||
*value_ret = convert_signed_value(cval,
|
||||
snd_usb_combine_bytes(val, val_size));
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
@@ -352,6 +352,15 @@ static int set_sync_ep_implicit_fb_quirk(struct snd_usb_substream *subs,
|
||||
ep = 0x86;
|
||||
iface = usb_ifnum_to_if(dev, 2);
|
||||
|
||||
if (!iface || iface->num_altsetting == 0)
|
||||
return -EINVAL;
|
||||
|
||||
alts = &iface->altsetting[1];
|
||||
goto add_sync_ep;
|
||||
case USB_ID(0x1397, 0x0002):
|
||||
ep = 0x81;
|
||||
iface = usb_ifnum_to_if(dev, 1);
|
||||
|
||||
if (!iface || iface->num_altsetting == 0)
|
||||
return -EINVAL;
|
||||
|
||||
|
@@ -1363,8 +1363,11 @@ u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip,
|
||||
return SNDRV_PCM_FMTBIT_DSD_U32_BE;
|
||||
break;
|
||||
|
||||
/* Amanero Combo384 USB interface with native DSD support */
|
||||
case USB_ID(0x16d0, 0x071a):
|
||||
/* Amanero Combo384 USB based DACs with native DSD support */
|
||||
case USB_ID(0x16d0, 0x071a): /* Amanero - Combo384 */
|
||||
case USB_ID(0x2ab6, 0x0004): /* T+A DAC8DSD-V2.0, MP1000E-V2.0, MP2000R-V2.0, MP2500R-V2.0, MP3100HV-V2.0 */
|
||||
case USB_ID(0x2ab6, 0x0005): /* T+A USB HD Audio 1 */
|
||||
case USB_ID(0x2ab6, 0x0006): /* T+A USB HD Audio 2 */
|
||||
if (fp->altsetting == 2) {
|
||||
switch (le16_to_cpu(chip->dev->descriptor.bcdDevice)) {
|
||||
case 0x199:
|
||||
|
مرجع در شماره جدید
Block a user