diff options
author | Takashi Iwai <tiwai@suse.de> | 2018-02-12 03:35:43 -0500 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2018-02-12 03:36:26 -0500 |
commit | 1dcb1859dd6752131b85c78fb3e440bd1d2cf361 (patch) | |
tree | ac1df8f420a9c8f6bbb0c0071645622adf901af5 | |
parent | 7928b2cbe55b2a410a0f5c1f154610059c57b1b2 (diff) | |
parent | 7c74866baef1827e18f8269aec85030063520bd4 (diff) |
Merge branch 'topic/fixes' into for-linus
Signed-off-by: Takashi Iwai <tiwai@suse.de>
-rw-r--r-- | include/sound/ac97/regs.h | 2 | ||||
-rw-r--r-- | sound/ac97/Kconfig | 1 | ||||
-rw-r--r-- | sound/pci/hda/patch_realtek.c | 53 | ||||
-rw-r--r-- | sound/usb/mixer.c | 18 | ||||
-rw-r--r-- | sound/usb/pcm.c | 9 | ||||
-rw-r--r-- | sound/usb/quirks.c | 7 |
6 files changed, 79 insertions, 11 deletions
diff --git a/include/sound/ac97/regs.h b/include/sound/ac97/regs.h index 4bb86d379bd5..9a4fa0c3264a 100644 --- a/include/sound/ac97/regs.h +++ b/include/sound/ac97/regs.h | |||
@@ -31,7 +31,7 @@ | |||
31 | #define AC97_HEADPHONE 0x04 /* Headphone Volume (optional) */ | 31 | #define AC97_HEADPHONE 0x04 /* Headphone Volume (optional) */ |
32 | #define AC97_MASTER_MONO 0x06 /* Master Volume Mono (optional) */ | 32 | #define AC97_MASTER_MONO 0x06 /* Master Volume Mono (optional) */ |
33 | #define AC97_MASTER_TONE 0x08 /* Master Tone (Bass & Treble) (optional) */ | 33 | #define AC97_MASTER_TONE 0x08 /* Master Tone (Bass & Treble) (optional) */ |
34 | #define AC97_PC_BEEP 0x0a /* PC Beep Volume (optinal) */ | 34 | #define AC97_PC_BEEP 0x0a /* PC Beep Volume (optional) */ |
35 | #define AC97_PHONE 0x0c /* Phone Volume (optional) */ | 35 | #define AC97_PHONE 0x0c /* Phone Volume (optional) */ |
36 | #define AC97_MIC 0x0e /* MIC Volume */ | 36 | #define AC97_MIC 0x0e /* MIC Volume */ |
37 | #define AC97_LINE 0x10 /* Line In Volume */ | 37 | #define AC97_LINE 0x10 /* Line In Volume */ |
diff --git a/sound/ac97/Kconfig b/sound/ac97/Kconfig index f8a64e15e5bf..baa5f8ef89d2 100644 --- a/sound/ac97/Kconfig +++ b/sound/ac97/Kconfig | |||
@@ -5,7 +5,6 @@ | |||
5 | 5 | ||
6 | config AC97_BUS_NEW | 6 | config AC97_BUS_NEW |
7 | tristate | 7 | tristate |
8 | select AC97 | ||
9 | help | 8 | help |
10 | This is the new AC97 bus type, successor of AC97_BUS. The ported | 9 | This is the new AC97 bus type, successor of AC97_BUS. The ported |
11 | drivers which benefit from the AC97 automatic probing should "select" | 10 | drivers which benefit from the AC97 automatic probing should "select" |
diff --git a/sound/pci/hda/patch_realtek.c b/sound/pci/hda/patch_realtek.c index 23475888192b..32938ca8e5e3 100644 --- a/sound/pci/hda/patch_realtek.c +++ b/sound/pci/hda/patch_realtek.c | |||
@@ -4972,6 +4972,28 @@ static void alc_fixup_tpt440_dock(struct hda_codec *codec, | |||
4972 | } | 4972 | } |
4973 | } | 4973 | } |
4974 | 4974 | ||
4975 | static void alc_fixup_tpt470_dock(struct hda_codec *codec, | ||
4976 | const struct hda_fixup *fix, int action) | ||
4977 | { | ||
4978 | static const struct hda_pintbl pincfgs[] = { | ||
4979 | { 0x17, 0x21211010 }, /* dock headphone */ | ||
4980 | { 0x19, 0x21a11010 }, /* dock mic */ | ||
4981 | { } | ||
4982 | }; | ||
4983 | struct alc_spec *spec = codec->spec; | ||
4984 | |||
4985 | if (action == HDA_FIXUP_ACT_PRE_PROBE) { | ||
4986 | spec->parse_flags = HDA_PINCFG_NO_HP_FIXUP; | ||
4987 | /* Enable DOCK device */ | ||
4988 | snd_hda_codec_write(codec, 0x17, 0, | ||
4989 | AC_VERB_SET_CONFIG_DEFAULT_BYTES_3, 0); | ||
4990 | /* Enable DOCK device */ | ||
4991 | snd_hda_codec_write(codec, 0x19, 0, | ||
4992 | AC_VERB_SET_CONFIG_DEFAULT_BYTES_3, 0); | ||
4993 | snd_hda_apply_pincfgs(codec, pincfgs); | ||
4994 | } | ||
4995 | } | ||
4996 | |||
4975 | static void alc_shutup_dell_xps13(struct hda_codec *codec) | 4997 | static void alc_shutup_dell_xps13(struct hda_codec *codec) |
4976 | { | 4998 | { |
4977 | struct alc_spec *spec = codec->spec; | 4999 | struct alc_spec *spec = codec->spec; |
@@ -5446,6 +5468,7 @@ enum { | |||
5446 | ALC700_FIXUP_INTEL_REFERENCE, | 5468 | ALC700_FIXUP_INTEL_REFERENCE, |
5447 | ALC274_FIXUP_DELL_BIND_DACS, | 5469 | ALC274_FIXUP_DELL_BIND_DACS, |
5448 | ALC274_FIXUP_DELL_AIO_LINEOUT_VERB, | 5470 | ALC274_FIXUP_DELL_AIO_LINEOUT_VERB, |
5471 | ALC298_FIXUP_TPT470_DOCK, | ||
5449 | }; | 5472 | }; |
5450 | 5473 | ||
5451 | static const struct hda_fixup alc269_fixups[] = { | 5474 | static const struct hda_fixup alc269_fixups[] = { |
@@ -6271,6 +6294,12 @@ static const struct hda_fixup alc269_fixups[] = { | |||
6271 | .chained = true, | 6294 | .chained = true, |
6272 | .chain_id = ALC274_FIXUP_DELL_BIND_DACS | 6295 | .chain_id = ALC274_FIXUP_DELL_BIND_DACS |
6273 | }, | 6296 | }, |
6297 | [ALC298_FIXUP_TPT470_DOCK] = { | ||
6298 | .type = HDA_FIXUP_FUNC, | ||
6299 | .v.func = alc_fixup_tpt470_dock, | ||
6300 | .chained = true, | ||
6301 | .chain_id = ALC293_FIXUP_LENOVO_SPK_NOISE | ||
6302 | }, | ||
6274 | }; | 6303 | }; |
6275 | 6304 | ||
6276 | static const struct snd_pci_quirk alc269_fixup_tbl[] = { | 6305 | static const struct snd_pci_quirk alc269_fixup_tbl[] = { |
@@ -6321,6 +6350,8 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = { | |||
6321 | SND_PCI_QUIRK(0x1028, 0x075d, "Dell AIO", ALC298_FIXUP_SPK_VOLUME), | 6350 | SND_PCI_QUIRK(0x1028, 0x075d, "Dell AIO", ALC298_FIXUP_SPK_VOLUME), |
6322 | SND_PCI_QUIRK(0x1028, 0x0798, "Dell Inspiron 17 7000 Gaming", ALC256_FIXUP_DELL_INSPIRON_7559_SUBWOOFER), | 6351 | SND_PCI_QUIRK(0x1028, 0x0798, "Dell Inspiron 17 7000 Gaming", ALC256_FIXUP_DELL_INSPIRON_7559_SUBWOOFER), |
6323 | SND_PCI_QUIRK(0x1028, 0x082a, "Dell XPS 13 9360", ALC256_FIXUP_DELL_XPS_13_HEADPHONE_NOISE), | 6352 | SND_PCI_QUIRK(0x1028, 0x082a, "Dell XPS 13 9360", ALC256_FIXUP_DELL_XPS_13_HEADPHONE_NOISE), |
6353 | SND_PCI_QUIRK(0x1028, 0x084b, "Dell", ALC274_FIXUP_DELL_AIO_LINEOUT_VERB), | ||
6354 | SND_PCI_QUIRK(0x1028, 0x084e, "Dell", ALC274_FIXUP_DELL_AIO_LINEOUT_VERB), | ||
6324 | SND_PCI_QUIRK(0x1028, 0x164a, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), | 6355 | SND_PCI_QUIRK(0x1028, 0x164a, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), |
6325 | SND_PCI_QUIRK(0x1028, 0x164b, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), | 6356 | SND_PCI_QUIRK(0x1028, 0x164b, "Dell", ALC293_FIXUP_DELL1_MIC_NO_PRESENCE), |
6326 | SND_PCI_QUIRK(0x103c, 0x1586, "HP", ALC269_FIXUP_HP_MUTE_LED_MIC2), | 6357 | SND_PCI_QUIRK(0x103c, 0x1586, "HP", ALC269_FIXUP_HP_MUTE_LED_MIC2), |
@@ -6450,8 +6481,16 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = { | |||
6450 | SND_PCI_QUIRK(0x17aa, 0x2218, "Thinkpad X1 Carbon 2nd", ALC292_FIXUP_TPT440_DOCK), | 6481 | SND_PCI_QUIRK(0x17aa, 0x2218, "Thinkpad X1 Carbon 2nd", ALC292_FIXUP_TPT440_DOCK), |
6451 | SND_PCI_QUIRK(0x17aa, 0x2223, "ThinkPad T550", ALC292_FIXUP_TPT440_DOCK), | 6482 | SND_PCI_QUIRK(0x17aa, 0x2223, "ThinkPad T550", ALC292_FIXUP_TPT440_DOCK), |
6452 | SND_PCI_QUIRK(0x17aa, 0x2226, "ThinkPad X250", ALC292_FIXUP_TPT440_DOCK), | 6483 | SND_PCI_QUIRK(0x17aa, 0x2226, "ThinkPad X250", ALC292_FIXUP_TPT440_DOCK), |
6484 | SND_PCI_QUIRK(0x17aa, 0x222d, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6485 | SND_PCI_QUIRK(0x17aa, 0x222e, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6453 | SND_PCI_QUIRK(0x17aa, 0x2231, "Thinkpad T560", ALC292_FIXUP_TPT460), | 6486 | SND_PCI_QUIRK(0x17aa, 0x2231, "Thinkpad T560", ALC292_FIXUP_TPT460), |
6454 | SND_PCI_QUIRK(0x17aa, 0x2233, "Thinkpad", ALC292_FIXUP_TPT460), | 6487 | SND_PCI_QUIRK(0x17aa, 0x2233, "Thinkpad", ALC292_FIXUP_TPT460), |
6488 | SND_PCI_QUIRK(0x17aa, 0x2245, "Thinkpad T470", ALC298_FIXUP_TPT470_DOCK), | ||
6489 | SND_PCI_QUIRK(0x17aa, 0x2246, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6490 | SND_PCI_QUIRK(0x17aa, 0x2247, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6491 | SND_PCI_QUIRK(0x17aa, 0x224b, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6492 | SND_PCI_QUIRK(0x17aa, 0x224c, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6493 | SND_PCI_QUIRK(0x17aa, 0x224d, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6455 | SND_PCI_QUIRK(0x17aa, 0x30bb, "ThinkCentre AIO", ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY), | 6494 | SND_PCI_QUIRK(0x17aa, 0x30bb, "ThinkCentre AIO", ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY), |
6456 | SND_PCI_QUIRK(0x17aa, 0x30e2, "ThinkCentre AIO", ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY), | 6495 | SND_PCI_QUIRK(0x17aa, 0x30e2, "ThinkCentre AIO", ALC233_FIXUP_LENOVO_LINE2_MIC_HOTKEY), |
6457 | SND_PCI_QUIRK(0x17aa, 0x310c, "ThinkCentre Station", ALC294_FIXUP_LENOVO_MIC_LOCATION), | 6496 | SND_PCI_QUIRK(0x17aa, 0x310c, "ThinkCentre Station", ALC294_FIXUP_LENOVO_MIC_LOCATION), |
@@ -6472,7 +6511,12 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = { | |||
6472 | SND_PCI_QUIRK(0x17aa, 0x5050, "Thinkpad T560p", ALC292_FIXUP_TPT460), | 6511 | SND_PCI_QUIRK(0x17aa, 0x5050, "Thinkpad T560p", ALC292_FIXUP_TPT460), |
6473 | SND_PCI_QUIRK(0x17aa, 0x5051, "Thinkpad L460", ALC292_FIXUP_TPT460), | 6512 | SND_PCI_QUIRK(0x17aa, 0x5051, "Thinkpad L460", ALC292_FIXUP_TPT460), |
6474 | SND_PCI_QUIRK(0x17aa, 0x5053, "Thinkpad T460", ALC292_FIXUP_TPT460), | 6513 | SND_PCI_QUIRK(0x17aa, 0x5053, "Thinkpad T460", ALC292_FIXUP_TPT460), |
6514 | SND_PCI_QUIRK(0x17aa, 0x505d, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6515 | SND_PCI_QUIRK(0x17aa, 0x505f, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6516 | SND_PCI_QUIRK(0x17aa, 0x5062, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6475 | SND_PCI_QUIRK(0x17aa, 0x5109, "Thinkpad", ALC269_FIXUP_LIMIT_INT_MIC_BOOST), | 6517 | SND_PCI_QUIRK(0x17aa, 0x5109, "Thinkpad", ALC269_FIXUP_LIMIT_INT_MIC_BOOST), |
6518 | SND_PCI_QUIRK(0x17aa, 0x511e, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6519 | SND_PCI_QUIRK(0x17aa, 0x511f, "Thinkpad", ALC298_FIXUP_TPT470_DOCK), | ||
6476 | SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_FIXUP_PCM_44K), | 6520 | SND_PCI_QUIRK(0x17aa, 0x3bf8, "Quanta FL1", ALC269_FIXUP_PCM_44K), |
6477 | SND_PCI_QUIRK(0x17aa, 0x9e54, "LENOVO NB", ALC269_FIXUP_LENOVO_EAPD), | 6521 | SND_PCI_QUIRK(0x17aa, 0x9e54, "LENOVO NB", ALC269_FIXUP_LENOVO_EAPD), |
6478 | SND_PCI_QUIRK(0x1b7d, 0xa831, "Ordissimo EVE2 ", ALC269VB_FIXUP_ORDISSIMO_EVE2), /* Also known as Malata PC-B1303 */ | 6522 | SND_PCI_QUIRK(0x1b7d, 0xa831, "Ordissimo EVE2 ", ALC269VB_FIXUP_ORDISSIMO_EVE2), /* Also known as Malata PC-B1303 */ |
@@ -6735,6 +6779,11 @@ static const struct snd_hda_pin_quirk alc269_pin_fixup_tbl[] = { | |||
6735 | {0x14, 0x90170110}, | 6779 | {0x14, 0x90170110}, |
6736 | {0x21, 0x02211020}), | 6780 | {0x21, 0x02211020}), |
6737 | SND_HDA_PIN_QUIRK(0x10ec0256, 0x1028, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE, | 6781 | SND_HDA_PIN_QUIRK(0x10ec0256, 0x1028, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE, |
6782 | {0x12, 0x90a60130}, | ||
6783 | {0x14, 0x90170110}, | ||
6784 | {0x14, 0x01011020}, | ||
6785 | {0x21, 0x0221101f}), | ||
6786 | SND_HDA_PIN_QUIRK(0x10ec0256, 0x1028, "Dell", ALC255_FIXUP_DELL1_MIC_NO_PRESENCE, | ||
6738 | ALC256_STANDARD_PINS), | 6787 | ALC256_STANDARD_PINS), |
6739 | SND_HDA_PIN_QUIRK(0x10ec0256, 0x1043, "ASUS", ALC256_FIXUP_ASUS_MIC, | 6788 | SND_HDA_PIN_QUIRK(0x10ec0256, 0x1043, "ASUS", ALC256_FIXUP_ASUS_MIC, |
6740 | {0x14, 0x90170110}, | 6789 | {0x14, 0x90170110}, |
@@ -6803,6 +6852,10 @@ static const struct snd_hda_pin_quirk alc269_pin_fixup_tbl[] = { | |||
6803 | {0x12, 0x90a60120}, | 6852 | {0x12, 0x90a60120}, |
6804 | {0x14, 0x90170110}, | 6853 | {0x14, 0x90170110}, |
6805 | {0x21, 0x0321101f}), | 6854 | {0x21, 0x0321101f}), |
6855 | SND_HDA_PIN_QUIRK(0x10ec0289, 0x1028, "Dell", ALC225_FIXUP_DELL1_MIC_NO_PRESENCE, | ||
6856 | {0x12, 0xb7a60130}, | ||
6857 | {0x14, 0x90170110}, | ||
6858 | {0x21, 0x04211020}), | ||
6806 | SND_HDA_PIN_QUIRK(0x10ec0290, 0x103c, "HP", ALC269_FIXUP_HP_MUTE_LED_MIC1, | 6859 | SND_HDA_PIN_QUIRK(0x10ec0290, 0x103c, "HP", ALC269_FIXUP_HP_MUTE_LED_MIC1, |
6807 | ALC290_STANDARD_PINS, | 6860 | ALC290_STANDARD_PINS, |
6808 | {0x15, 0x04211040}, | 6861 | {0x15, 0x04211040}, |
diff --git a/sound/usb/mixer.c b/sound/usb/mixer.c index 9afb8ab524c7..06b22624ab7a 100644 --- a/sound/usb/mixer.c +++ b/sound/usb/mixer.c | |||
@@ -347,17 +347,20 @@ static int get_ctl_value_v2(struct usb_mixer_elem_info *cval, int request, | |||
347 | int validx, int *value_ret) | 347 | int validx, int *value_ret) |
348 | { | 348 | { |
349 | struct snd_usb_audio *chip = cval->head.mixer->chip; | 349 | struct snd_usb_audio *chip = cval->head.mixer->chip; |
350 | unsigned char buf[4 + 3 * sizeof(__u32)]; /* enough space for one range */ | 350 | /* enough space for one range */ |
351 | unsigned char buf[sizeof(__u16) + 3 * sizeof(__u32)]; | ||
351 | unsigned char *val; | 352 | unsigned char *val; |
352 | int idx = 0, ret, size; | 353 | int idx = 0, ret, val_size, size; |
353 | __u8 bRequest; | 354 | __u8 bRequest; |
354 | 355 | ||
356 | val_size = uac2_ctl_value_size(cval->val_type); | ||
357 | |||
355 | if (request == UAC_GET_CUR) { | 358 | if (request == UAC_GET_CUR) { |
356 | bRequest = UAC2_CS_CUR; | 359 | bRequest = UAC2_CS_CUR; |
357 | size = uac2_ctl_value_size(cval->val_type); | 360 | size = val_size; |
358 | } else { | 361 | } else { |
359 | bRequest = UAC2_CS_RANGE; | 362 | bRequest = UAC2_CS_RANGE; |
360 | size = sizeof(buf); | 363 | size = sizeof(__u16) + 3 * val_size; |
361 | } | 364 | } |
362 | 365 | ||
363 | memset(buf, 0, sizeof(buf)); | 366 | memset(buf, 0, sizeof(buf)); |
@@ -390,16 +393,17 @@ error: | |||
390 | val = buf + sizeof(__u16); | 393 | val = buf + sizeof(__u16); |
391 | break; | 394 | break; |
392 | case UAC_GET_MAX: | 395 | case UAC_GET_MAX: |
393 | val = buf + sizeof(__u16) * 2; | 396 | val = buf + sizeof(__u16) + val_size; |
394 | break; | 397 | break; |
395 | case UAC_GET_RES: | 398 | case UAC_GET_RES: |
396 | val = buf + sizeof(__u16) * 3; | 399 | val = buf + sizeof(__u16) + val_size * 2; |
397 | break; | 400 | break; |
398 | default: | 401 | default: |
399 | return -EINVAL; | 402 | return -EINVAL; |
400 | } | 403 | } |
401 | 404 | ||
402 | *value_ret = convert_signed_value(cval, snd_usb_combine_bytes(val, sizeof(__u16))); | 405 | *value_ret = convert_signed_value(cval, |
406 | snd_usb_combine_bytes(val, val_size)); | ||
403 | 407 | ||
404 | return 0; | 408 | return 0; |
405 | } | 409 | } |
diff --git a/sound/usb/pcm.c b/sound/usb/pcm.c index b9c9a19f9588..3cbfae6604f9 100644 --- a/sound/usb/pcm.c +++ b/sound/usb/pcm.c | |||
@@ -357,6 +357,15 @@ static int set_sync_ep_implicit_fb_quirk(struct snd_usb_substream *subs, | |||
357 | 357 | ||
358 | alts = &iface->altsetting[1]; | 358 | alts = &iface->altsetting[1]; |
359 | goto add_sync_ep; | 359 | goto add_sync_ep; |
360 | case USB_ID(0x1397, 0x0002): | ||
361 | ep = 0x81; | ||
362 | iface = usb_ifnum_to_if(dev, 1); | ||
363 | |||
364 | if (!iface || iface->num_altsetting == 0) | ||
365 | return -EINVAL; | ||
366 | |||
367 | alts = &iface->altsetting[1]; | ||
368 | goto add_sync_ep; | ||
360 | 369 | ||
361 | } | 370 | } |
362 | if (attr == USB_ENDPOINT_SYNC_ASYNC && | 371 | if (attr == USB_ENDPOINT_SYNC_ASYNC && |
diff --git a/sound/usb/quirks.c b/sound/usb/quirks.c index a66ef5777887..ea8f3de92fa4 100644 --- a/sound/usb/quirks.c +++ b/sound/usb/quirks.c | |||
@@ -1363,8 +1363,11 @@ u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip, | |||
1363 | return SNDRV_PCM_FMTBIT_DSD_U32_BE; | 1363 | return SNDRV_PCM_FMTBIT_DSD_U32_BE; |
1364 | break; | 1364 | break; |
1365 | 1365 | ||
1366 | /* Amanero Combo384 USB interface with native DSD support */ | 1366 | /* Amanero Combo384 USB based DACs with native DSD support */ |
1367 | case USB_ID(0x16d0, 0x071a): | 1367 | case USB_ID(0x16d0, 0x071a): /* Amanero - Combo384 */ |
1368 | case USB_ID(0x2ab6, 0x0004): /* T+A DAC8DSD-V2.0, MP1000E-V2.0, MP2000R-V2.0, MP2500R-V2.0, MP3100HV-V2.0 */ | ||
1369 | case USB_ID(0x2ab6, 0x0005): /* T+A USB HD Audio 1 */ | ||
1370 | case USB_ID(0x2ab6, 0x0006): /* T+A USB HD Audio 2 */ | ||
1368 | if (fp->altsetting == 2) { | 1371 | if (fp->altsetting == 2) { |
1369 | switch (le16_to_cpu(chip->dev->descriptor.bcdDevice)) { | 1372 | switch (le16_to_cpu(chip->dev->descriptor.bcdDevice)) { |
1370 | case 0x199: | 1373 | case 0x199: |