sound fixes for 6.5-rc4
A collection of device-specific small fixes such as ASoC Realtek codec fixes for PM issues, ASoC nau8821 quirk additions, and usual HD- and USB-audio quirks. -----BEGIN PGP SIGNATURE----- iQJCBAABCAAsFiEEIXTw5fNLNI7mMiVaLtJE4w1nLE8FAmTDriAOHHRpd2FpQHN1 c2UuZGUACgkQLtJE4w1nLE9oew//d8mUKTQtOC7kY1lWm5IElO3xIP25vg4Ct3jU giBZoZOPmuw2idEUvGn2cE7WsbdyXytflZMkRZi4sf5nCnVf4cuwprtKyibnO1Ld hCPyVYDNOjv23mLBoNRJNiZPvC7+tU36eg9Li+wcxSk17recxfj8LoP4MoQ3qsiI kgpR++BwO5tKJnIjA9/vM/Ksj2OYRHLW6/XNki/o9Y8X1bREU6uNwgAeghrxyKXh tnpadV5cgiAC5rhlUcbnqaPWmDrwIXWzNHkrJ7XHf/8cEMrpKRBBhLcQRPFG15Kd ZNV8gCcrcthy0drRN8E01QFYvyqmuP5sVvN/4VZNrdOZBYKZWVwHFowlB5KOEnB0 /8pkjsFMSvGMLmsNJWWAYJFZ7BIp3b5Hghyvujl2FJhy2ClJkj4qZUA1jlo/uoT/ nj3VRp9RyMelYKZAVemfyLDIowPznmKPkp1nisXsWP21xydYYbdXV5FrY/lgQUtX GUf+N0spqAzcRbHc7FKDFqGc1zMJAln30nyICGlyiLdwHZn8ZXXmXwfH5jqUyqGL zXw8lVhfeyq6g74wMRbaaNFwdZqkco4+DV7cKzs/0kDwOu4rD5tia6vumZHS0C/O oqoi0PBXU2b235u5CyFVD/ZpYda2GlK23TXpDNZT7uihbMwAmjyIx0r2Xh3219UW MNLjW9A= =XrNX -----END PGP SIGNATURE----- Merge tag 'sound-6.5-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound Pull sound fixes from Takashi Iwai: "A collection of device-specific small fixes such as ASoC Realtek codec fixes for PM issues, ASoC nau8821 quirk additions, and usual HD- and USB-audio quirks" * tag 'sound-6.5-rc4' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: ALSA: hda/realtek: Support ASUS G713PV laptop ALSA: usb-audio: Update for native DSD support quirks ALSA: usb-audio: Add quirk for Microsoft Modern Wireless Headset ALSA: hda/relatek: Enable Mute LED on HP 250 G8 ASoC: atmel: Fix the 8K sample parameter in I2SC master ASoC: rt711-sdca: fix for JD event handling in ClockStop Mode0 ASoC: rt711: fix for JD event handling in ClockStop Mode0 ASoC: rt722-sdca: fix for JD event handling in ClockStop Mode0 ASoC: rt712-sdca: fix for JD event handling in ClockStop Mode0 ASoc: codecs: ES8316: Fix DMIC config ASoC: rt5682-sdw: fix for JD event handling in ClockStop Mode0 ASoC: wm8904: Fill the cache for WM8904_ADC_TEST_0 register ASoC: nau8821: Add DMI quirk mechanism for active-high jack-detect ASoC: da7219: Check for failure reading AAD IRQ events ASoC: da7219: Flush pending AAD IRQ when suspending ALSA: seq: remove redundant unsigned comparison to zero ASoC: fsl_spdif: Silence output on stop
This commit is contained in:
commit
6fb9f7f839
@ -298,8 +298,7 @@ static void update_group_attrs(struct seq_ump_client *client)
|
||||
}
|
||||
|
||||
list_for_each_entry(fb, &client->ump->block_list, list) {
|
||||
if (fb->info.first_group < 0 ||
|
||||
fb->info.first_group + fb->info.num_groups > SNDRV_UMP_MAX_GROUPS)
|
||||
if (fb->info.first_group + fb->info.num_groups > SNDRV_UMP_MAX_GROUPS)
|
||||
break;
|
||||
group = &client->groups[fb->info.first_group];
|
||||
for (i = 0; i < fb->info.num_groups; i++, group++) {
|
||||
|
@ -9541,6 +9541,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
||||
SND_PCI_QUIRK(0x103c, 0x880d, "HP EliteBook 830 G8 Notebook PC", ALC285_FIXUP_HP_GPIO_LED),
|
||||
SND_PCI_QUIRK(0x103c, 0x8811, "HP Spectre x360 15-eb1xxx", ALC285_FIXUP_HP_SPECTRE_X360_EB1),
|
||||
SND_PCI_QUIRK(0x103c, 0x8812, "HP Spectre x360 15-eb1xxx", ALC285_FIXUP_HP_SPECTRE_X360_EB1),
|
||||
SND_PCI_QUIRK(0x103c, 0x881d, "HP 250 G8 Notebook PC", ALC236_FIXUP_HP_MUTE_LED_COEFBIT2),
|
||||
SND_PCI_QUIRK(0x103c, 0x8846, "HP EliteBook 850 G8 Notebook PC", ALC285_FIXUP_HP_GPIO_LED),
|
||||
SND_PCI_QUIRK(0x103c, 0x8847, "HP EliteBook x360 830 G8 Notebook PC", ALC285_FIXUP_HP_GPIO_LED),
|
||||
SND_PCI_QUIRK(0x103c, 0x884b, "HP EliteBook 840 Aero G8 Notebook PC", ALC285_FIXUP_HP_GPIO_LED),
|
||||
@ -9671,6 +9672,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
||||
SND_PCI_QUIRK(0x1043, 0x1c9f, "ASUS G614JI", ALC285_FIXUP_ASUS_HEADSET_MIC),
|
||||
SND_PCI_QUIRK(0x1043, 0x1caf, "ASUS G634JYR/JZR", ALC285_FIXUP_ASUS_SPI_REAR_SPEAKERS),
|
||||
SND_PCI_QUIRK(0x1043, 0x1ccd, "ASUS X555UB", ALC256_FIXUP_ASUS_MIC),
|
||||
SND_PCI_QUIRK(0x1043, 0x1d1f, "ASUS ROG Strix G17 2023 (G713PV)", ALC287_FIXUP_CS35L41_I2C_2),
|
||||
SND_PCI_QUIRK(0x1043, 0x1d42, "ASUS Zephyrus G14 2022", ALC289_FIXUP_ASUS_GA401),
|
||||
SND_PCI_QUIRK(0x1043, 0x1d4e, "ASUS TM420", ALC256_FIXUP_ASUS_HPE),
|
||||
SND_PCI_QUIRK(0x1043, 0x1e02, "ASUS UX3402", ALC245_FIXUP_CS35L41_SPI_2),
|
||||
|
@ -163,11 +163,14 @@ struct atmel_i2s_gck_param {
|
||||
|
||||
#define I2S_MCK_12M288 12288000UL
|
||||
#define I2S_MCK_11M2896 11289600UL
|
||||
#define I2S_MCK_6M144 6144000UL
|
||||
|
||||
/* mck = (32 * (imckfs+1) / (imckdiv+1)) * fs */
|
||||
static const struct atmel_i2s_gck_param gck_params[] = {
|
||||
/* mck = 6.144Mhz */
|
||||
{ 8000, I2S_MCK_6M144, 1, 47}, /* mck = 768 fs */
|
||||
|
||||
/* mck = 12.288MHz */
|
||||
{ 8000, I2S_MCK_12M288, 0, 47}, /* mck = 1536 fs */
|
||||
{ 16000, I2S_MCK_12M288, 1, 47}, /* mck = 768 fs */
|
||||
{ 24000, I2S_MCK_12M288, 3, 63}, /* mck = 512 fs */
|
||||
{ 32000, I2S_MCK_12M288, 3, 47}, /* mck = 384 fs */
|
||||
|
@ -361,11 +361,15 @@ static irqreturn_t da7219_aad_irq_thread(int irq, void *data)
|
||||
struct da7219_priv *da7219 = snd_soc_component_get_drvdata(component);
|
||||
u8 events[DA7219_AAD_IRQ_REG_MAX];
|
||||
u8 statusa;
|
||||
int i, report = 0, mask = 0;
|
||||
int i, ret, report = 0, mask = 0;
|
||||
|
||||
/* Read current IRQ events */
|
||||
regmap_bulk_read(da7219->regmap, DA7219_ACCDET_IRQ_EVENT_A,
|
||||
ret = regmap_bulk_read(da7219->regmap, DA7219_ACCDET_IRQ_EVENT_A,
|
||||
events, DA7219_AAD_IRQ_REG_MAX);
|
||||
if (ret) {
|
||||
dev_warn_ratelimited(component->dev, "Failed to read IRQ events: %d\n", ret);
|
||||
return IRQ_NONE;
|
||||
}
|
||||
|
||||
if (!events[DA7219_AAD_IRQ_REG_A] && !events[DA7219_AAD_IRQ_REG_B])
|
||||
return IRQ_NONE;
|
||||
@ -944,6 +948,8 @@ void da7219_aad_suspend(struct snd_soc_component *component)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
synchronize_irq(da7219_aad->irq);
|
||||
}
|
||||
|
||||
void da7219_aad_resume(struct snd_soc_component *component)
|
||||
|
@ -153,7 +153,7 @@ static const char * const es8316_dmic_txt[] = {
|
||||
"dmic data at high level",
|
||||
"dmic data at low level",
|
||||
};
|
||||
static const unsigned int es8316_dmic_values[] = { 0, 1, 2 };
|
||||
static const unsigned int es8316_dmic_values[] = { 0, 2, 3 };
|
||||
static const struct soc_enum es8316_dmic_src_enum =
|
||||
SOC_VALUE_ENUM_SINGLE(ES8316_ADC_DMIC, 0, 3,
|
||||
ARRAY_SIZE(es8316_dmic_txt),
|
||||
|
@ -10,6 +10,7 @@
|
||||
#include <linux/acpi.h>
|
||||
#include <linux/clk.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/dmi.h>
|
||||
#include <linux/init.h>
|
||||
#include <linux/i2c.h>
|
||||
#include <linux/module.h>
|
||||
@ -25,6 +26,13 @@
|
||||
#include <sound/tlv.h>
|
||||
#include "nau8821.h"
|
||||
|
||||
#define NAU8821_JD_ACTIVE_HIGH BIT(0)
|
||||
|
||||
static int nau8821_quirk;
|
||||
static int quirk_override = -1;
|
||||
module_param_named(quirk, quirk_override, uint, 0444);
|
||||
MODULE_PARM_DESC(quirk, "Board-specific quirk override");
|
||||
|
||||
#define NAU_FREF_MAX 13500000
|
||||
#define NAU_FVCO_MAX 100000000
|
||||
#define NAU_FVCO_MIN 90000000
|
||||
@ -1792,6 +1800,33 @@ static int nau8821_setup_irq(struct nau8821 *nau8821)
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* Please keep this list alphabetically sorted */
|
||||
static const struct dmi_system_id nau8821_quirk_table[] = {
|
||||
{
|
||||
/* Positivo CW14Q01P-V2 */
|
||||
.matches = {
|
||||
DMI_MATCH(DMI_SYS_VENDOR, "Positivo Tecnologia SA"),
|
||||
DMI_MATCH(DMI_BOARD_NAME, "CW14Q01P-V2"),
|
||||
},
|
||||
.driver_data = (void *)(NAU8821_JD_ACTIVE_HIGH),
|
||||
},
|
||||
{}
|
||||
};
|
||||
|
||||
static void nau8821_check_quirks(void)
|
||||
{
|
||||
const struct dmi_system_id *dmi_id;
|
||||
|
||||
if (quirk_override != -1) {
|
||||
nau8821_quirk = quirk_override;
|
||||
return;
|
||||
}
|
||||
|
||||
dmi_id = dmi_first_match(nau8821_quirk_table);
|
||||
if (dmi_id)
|
||||
nau8821_quirk = (unsigned long)dmi_id->driver_data;
|
||||
}
|
||||
|
||||
static int nau8821_i2c_probe(struct i2c_client *i2c)
|
||||
{
|
||||
struct device *dev = &i2c->dev;
|
||||
@ -1812,6 +1847,12 @@ static int nau8821_i2c_probe(struct i2c_client *i2c)
|
||||
|
||||
nau8821->dev = dev;
|
||||
nau8821->irq = i2c->irq;
|
||||
|
||||
nau8821_check_quirks();
|
||||
|
||||
if (nau8821_quirk & NAU8821_JD_ACTIVE_HIGH)
|
||||
nau8821->jkdet_polarity = 0;
|
||||
|
||||
nau8821_print_device_properties(nau8821);
|
||||
|
||||
nau8821_reset_chip(nau8821->regmap);
|
||||
|
@ -750,8 +750,15 @@ static int __maybe_unused rt5682_dev_resume(struct device *dev)
|
||||
if (!rt5682->first_hw_init)
|
||||
return 0;
|
||||
|
||||
if (!slave->unattach_request)
|
||||
if (!slave->unattach_request) {
|
||||
if (rt5682->disable_irq == true) {
|
||||
mutex_lock(&rt5682->disable_irq_lock);
|
||||
sdw_write_no_pm(slave, SDW_SCP_INTMASK1, SDW_SCP_INT1_IMPL_DEF);
|
||||
rt5682->disable_irq = false;
|
||||
mutex_unlock(&rt5682->disable_irq_lock);
|
||||
}
|
||||
goto regmap_sync;
|
||||
}
|
||||
|
||||
time = wait_for_completion_timeout(&slave->initialization_complete,
|
||||
msecs_to_jiffies(RT5682_PROBE_TIMEOUT));
|
||||
|
@ -438,8 +438,16 @@ static int __maybe_unused rt711_sdca_dev_resume(struct device *dev)
|
||||
if (!rt711->first_hw_init)
|
||||
return 0;
|
||||
|
||||
if (!slave->unattach_request)
|
||||
if (!slave->unattach_request) {
|
||||
if (rt711->disable_irq == true) {
|
||||
mutex_lock(&rt711->disable_irq_lock);
|
||||
sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK1, SDW_SCP_SDCA_INTMASK_SDCA_0);
|
||||
sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK2, SDW_SCP_SDCA_INTMASK_SDCA_8);
|
||||
rt711->disable_irq = false;
|
||||
mutex_unlock(&rt711->disable_irq_lock);
|
||||
}
|
||||
goto regmap_sync;
|
||||
}
|
||||
|
||||
time = wait_for_completion_timeout(&slave->initialization_complete,
|
||||
msecs_to_jiffies(RT711_PROBE_TIMEOUT));
|
||||
|
@ -538,8 +538,15 @@ static int __maybe_unused rt711_dev_resume(struct device *dev)
|
||||
if (!rt711->first_hw_init)
|
||||
return 0;
|
||||
|
||||
if (!slave->unattach_request)
|
||||
if (!slave->unattach_request) {
|
||||
if (rt711->disable_irq == true) {
|
||||
mutex_lock(&rt711->disable_irq_lock);
|
||||
sdw_write_no_pm(slave, SDW_SCP_INTMASK1, SDW_SCP_INT1_IMPL_DEF);
|
||||
rt711->disable_irq = false;
|
||||
mutex_unlock(&rt711->disable_irq_lock);
|
||||
}
|
||||
goto regmap_sync;
|
||||
}
|
||||
|
||||
time = wait_for_completion_timeout(&slave->initialization_complete,
|
||||
msecs_to_jiffies(RT711_PROBE_TIMEOUT));
|
||||
|
@ -438,8 +438,16 @@ static int __maybe_unused rt712_sdca_dev_resume(struct device *dev)
|
||||
if (!rt712->first_hw_init)
|
||||
return 0;
|
||||
|
||||
if (!slave->unattach_request)
|
||||
if (!slave->unattach_request) {
|
||||
if (rt712->disable_irq == true) {
|
||||
mutex_lock(&rt712->disable_irq_lock);
|
||||
sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK1, SDW_SCP_SDCA_INTMASK_SDCA_0);
|
||||
sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK2, SDW_SCP_SDCA_INTMASK_SDCA_8);
|
||||
rt712->disable_irq = false;
|
||||
mutex_unlock(&rt712->disable_irq_lock);
|
||||
}
|
||||
goto regmap_sync;
|
||||
}
|
||||
|
||||
time = wait_for_completion_timeout(&slave->initialization_complete,
|
||||
msecs_to_jiffies(RT712_PROBE_TIMEOUT));
|
||||
|
@ -463,8 +463,16 @@ static int __maybe_unused rt722_sdca_dev_resume(struct device *dev)
|
||||
if (!rt722->first_hw_init)
|
||||
return 0;
|
||||
|
||||
if (!slave->unattach_request)
|
||||
if (!slave->unattach_request) {
|
||||
if (rt722->disable_irq == true) {
|
||||
mutex_lock(&rt722->disable_irq_lock);
|
||||
sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK1, SDW_SCP_SDCA_INTMASK_SDCA_6);
|
||||
sdw_write_no_pm(slave, SDW_SCP_SDCA_INTMASK2, SDW_SCP_SDCA_INTMASK_SDCA_8);
|
||||
rt722->disable_irq = false;
|
||||
mutex_unlock(&rt722->disable_irq_lock);
|
||||
}
|
||||
goto regmap_sync;
|
||||
}
|
||||
|
||||
time = wait_for_completion_timeout(&slave->initialization_complete,
|
||||
msecs_to_jiffies(RT722_PROBE_TIMEOUT));
|
||||
|
@ -2308,6 +2308,9 @@ static int wm8904_i2c_probe(struct i2c_client *i2c)
|
||||
regmap_update_bits(wm8904->regmap, WM8904_BIAS_CONTROL_0,
|
||||
WM8904_POBCTRL, 0);
|
||||
|
||||
/* Fill the cache for the ADC test register */
|
||||
regmap_read(wm8904->regmap, WM8904_ADC_TEST_0, &val);
|
||||
|
||||
/* Can leave the device powered off until we need it */
|
||||
regcache_cache_only(wm8904->regmap, true);
|
||||
regulator_bulk_disable(ARRAY_SIZE(wm8904->supplies), wm8904->supplies);
|
||||
|
@ -751,6 +751,8 @@ static int fsl_spdif_trigger(struct snd_pcm_substream *substream,
|
||||
case SNDRV_PCM_TRIGGER_PAUSE_PUSH:
|
||||
regmap_update_bits(regmap, REG_SPDIF_SCR, dmaen, 0);
|
||||
regmap_update_bits(regmap, REG_SPDIF_SIE, intr, 0);
|
||||
regmap_write(regmap, REG_SPDIF_STL, 0x0);
|
||||
regmap_write(regmap, REG_SPDIF_STR, 0x0);
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
|
@ -374,6 +374,15 @@ static const struct usbmix_name_map corsair_virtuoso_map[] = {
|
||||
{ 0 }
|
||||
};
|
||||
|
||||
/* Microsoft USB Link headset */
|
||||
/* a guess work: raw playback volume values are from 2 to 129 */
|
||||
static const struct usbmix_dB_map ms_usb_link_dB = { -3225, 0, true };
|
||||
static const struct usbmix_name_map ms_usb_link_map[] = {
|
||||
{ 9, NULL, .dB = &ms_usb_link_dB },
|
||||
{ 10, NULL }, /* Headset Capture volume; seems non-working, disabled */
|
||||
{ 0 } /* terminator */
|
||||
};
|
||||
|
||||
/* ASUS ROG Zenith II with Realtek ALC1220-VB */
|
||||
static const struct usbmix_name_map asus_zenith_ii_map[] = {
|
||||
{ 19, NULL, 12 }, /* FU, Input Gain Pad - broken response, disabled */
|
||||
@ -668,6 +677,11 @@ static const struct usbmix_ctl_map usbmix_ctl_maps[] = {
|
||||
.id = USB_ID(0x1395, 0x0025),
|
||||
.map = sennheiser_pc8_map,
|
||||
},
|
||||
{
|
||||
/* Microsoft USB Link headset */
|
||||
.id = USB_ID(0x045e, 0x083c),
|
||||
.map = ms_usb_link_map,
|
||||
},
|
||||
{ 0 } /* terminator */
|
||||
};
|
||||
|
||||
|
@ -1876,8 +1876,10 @@ u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip,
|
||||
|
||||
/* XMOS based USB DACs */
|
||||
switch (chip->usb_id) {
|
||||
case USB_ID(0x1511, 0x0037): /* AURALiC VEGA */
|
||||
case USB_ID(0x21ed, 0xd75a): /* Accuphase DAC-60 option card */
|
||||
case USB_ID(0x139f, 0x5504): /* Nagra DAC */
|
||||
case USB_ID(0x20b1, 0x3089): /* Mola-Mola DAC */
|
||||
case USB_ID(0x2522, 0x0007): /* LH Labs Geek Out 1V5 */
|
||||
case USB_ID(0x2522, 0x0009): /* LH Labs Geek Pulse X Inifinity 2V0 */
|
||||
case USB_ID(0x2522, 0x0012): /* LH Labs VI DAC Infinity */
|
||||
case USB_ID(0x2772, 0x0230): /* Pro-Ject Pre Box S2 Digital */
|
||||
if (fp->altsetting == 2)
|
||||
@ -1887,14 +1889,18 @@ u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip,
|
||||
case USB_ID(0x0d8c, 0x0316): /* Hegel HD12 DSD */
|
||||
case USB_ID(0x10cb, 0x0103): /* The Bit Opus #3; with fp->dsd_raw */
|
||||
case USB_ID(0x16d0, 0x06b2): /* NuPrime DAC-10 */
|
||||
case USB_ID(0x16d0, 0x09dd): /* Encore mDSD */
|
||||
case USB_ID(0x16d0, 0x06b4): /* NuPrime Audio HD-AVP/AVA */
|
||||
case USB_ID(0x16d0, 0x0733): /* Furutech ADL Stratos */
|
||||
case USB_ID(0x16d0, 0x09d8): /* NuPrime IDA-8 */
|
||||
case USB_ID(0x16d0, 0x09db): /* NuPrime Audio DAC-9 */
|
||||
case USB_ID(0x16d0, 0x09dd): /* Encore mDSD */
|
||||
case USB_ID(0x1db5, 0x0003): /* Bryston BDA3 */
|
||||
case USB_ID(0x20a0, 0x4143): /* WaveIO USB Audio 2.0 */
|
||||
case USB_ID(0x22e1, 0xca01): /* HDTA Serenade DSD */
|
||||
case USB_ID(0x249c, 0x9326): /* M2Tech Young MkIII */
|
||||
case USB_ID(0x2616, 0x0106): /* PS Audio NuWave DAC */
|
||||
case USB_ID(0x2622, 0x0041): /* Audiolab M-DAC+ */
|
||||
case USB_ID(0x278b, 0x5100): /* Rotel RC-1590 */
|
||||
case USB_ID(0x27f7, 0x3002): /* W4S DAC-2v2SE */
|
||||
case USB_ID(0x29a2, 0x0086): /* Mutec MC3+ USB */
|
||||
case USB_ID(0x6b42, 0x0042): /* MSB Technology */
|
||||
@ -1904,9 +1910,6 @@ u64 snd_usb_interface_dsd_format_quirks(struct snd_usb_audio *chip,
|
||||
|
||||
/* 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:
|
||||
@ -2013,6 +2016,9 @@ static const struct usb_audio_quirk_flags_table quirk_flags_table[] = {
|
||||
QUIRK_FLAG_IGNORE_CTL_ERROR),
|
||||
DEVICE_FLG(0x041e, 0x4080, /* Creative Live Cam VF0610 */
|
||||
QUIRK_FLAG_GET_SAMPLE_RATE),
|
||||
DEVICE_FLG(0x045e, 0x083c, /* MS USB Link headset */
|
||||
QUIRK_FLAG_GET_SAMPLE_RATE | QUIRK_FLAG_CTL_MSG_DELAY |
|
||||
QUIRK_FLAG_DISABLE_AUTOSUSPEND),
|
||||
DEVICE_FLG(0x046d, 0x084c, /* Logitech ConferenceCam Connect */
|
||||
QUIRK_FLAG_GET_SAMPLE_RATE | QUIRK_FLAG_CTL_MSG_DELAY_1M),
|
||||
DEVICE_FLG(0x046d, 0x0991, /* Logitech QuickCam Pro */
|
||||
@ -2048,6 +2054,9 @@ static const struct usb_audio_quirk_flags_table quirk_flags_table[] = {
|
||||
QUIRK_FLAG_IFACE_DELAY),
|
||||
DEVICE_FLG(0x0644, 0x805f, /* TEAC Model 12 */
|
||||
QUIRK_FLAG_FORCE_IFACE_RESET),
|
||||
DEVICE_FLG(0x0644, 0x806b, /* TEAC UD-701 */
|
||||
QUIRK_FLAG_ITF_USB_DSD_DAC | QUIRK_FLAG_CTL_MSG_DELAY |
|
||||
QUIRK_FLAG_IFACE_DELAY),
|
||||
DEVICE_FLG(0x06f8, 0xb000, /* Hercules DJ Console (Windows Edition) */
|
||||
QUIRK_FLAG_IGNORE_CTL_ERROR),
|
||||
DEVICE_FLG(0x06f8, 0xd002, /* Hercules DJ Console (Macintosh Edition) */
|
||||
@ -2086,6 +2095,8 @@ static const struct usb_audio_quirk_flags_table quirk_flags_table[] = {
|
||||
QUIRK_FLAG_ITF_USB_DSD_DAC | QUIRK_FLAG_CTL_MSG_DELAY),
|
||||
DEVICE_FLG(0x154e, 0x3006, /* Marantz SA-14S1 */
|
||||
QUIRK_FLAG_ITF_USB_DSD_DAC | QUIRK_FLAG_CTL_MSG_DELAY),
|
||||
DEVICE_FLG(0x154e, 0x300b, /* Marantz SA-KI RUBY / SA-12 */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
DEVICE_FLG(0x154e, 0x500e, /* Denon DN-X1600 */
|
||||
QUIRK_FLAG_IGNORE_CLOCK_SOURCE),
|
||||
DEVICE_FLG(0x1686, 0x00dd, /* Zoom R16/24 */
|
||||
@ -2130,6 +2141,10 @@ static const struct usb_audio_quirk_flags_table quirk_flags_table[] = {
|
||||
QUIRK_FLAG_SHARE_MEDIA_DEVICE | QUIRK_FLAG_ALIGN_TRANSFER),
|
||||
DEVICE_FLG(0x21b4, 0x0081, /* AudioQuest DragonFly */
|
||||
QUIRK_FLAG_GET_SAMPLE_RATE),
|
||||
DEVICE_FLG(0x21b4, 0x0230, /* Ayre QB-9 Twenty */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
DEVICE_FLG(0x21b4, 0x0232, /* Ayre QX-5 Twenty */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
DEVICE_FLG(0x2522, 0x0007, /* LH Labs Geek Out HD Audio 1V5 */
|
||||
QUIRK_FLAG_SET_IFACE_FIRST),
|
||||
DEVICE_FLG(0x2708, 0x0002, /* Audient iD14 */
|
||||
@ -2172,12 +2187,18 @@ static const struct usb_audio_quirk_flags_table quirk_flags_table[] = {
|
||||
QUIRK_FLAG_VALIDATE_RATES),
|
||||
VENDOR_FLG(0x1235, /* Focusrite Novation */
|
||||
QUIRK_FLAG_VALIDATE_RATES),
|
||||
VENDOR_FLG(0x1511, /* AURALiC */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x152a, /* Thesycon devices */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x18d1, /* iBasso devices */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x1de7, /* Phoenix Audio */
|
||||
QUIRK_FLAG_GET_SAMPLE_RATE),
|
||||
VENDOR_FLG(0x20b1, /* XMOS based devices */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x21ed, /* Accuphase Laboratory */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x22d9, /* Oppo */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x23ba, /* Playback Design */
|
||||
@ -2193,10 +2214,14 @@ static const struct usb_audio_quirk_flags_table quirk_flags_table[] = {
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x2ab6, /* T+A devices */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x2d87, /* Cayin device */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x3336, /* HEM devices */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x3353, /* Khadas devices */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x35f4, /* MSB Technology */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0x3842, /* EVGA */
|
||||
QUIRK_FLAG_DSD_RAW),
|
||||
VENDOR_FLG(0xc502, /* HiBy devices */
|
||||
|
Loading…
x
Reference in New Issue
Block a user