mirror of
https://github.com/torvalds/linux.git
synced 2025-01-01 15:51:46 +00:00
Merge branch 'for-linus' into for-next
This commit is contained in:
commit
f4209f692e
@ -124,7 +124,7 @@ static int snd_emu10k1_pcm_channel_alloc(struct snd_emu10k1_pcm * epcm, int voic
|
||||
epcm->voices[0]->epcm = epcm;
|
||||
if (voices > 1) {
|
||||
for (i = 1; i < voices; i++) {
|
||||
epcm->voices[i] = &epcm->emu->voices[epcm->voices[0]->number + i];
|
||||
epcm->voices[i] = &epcm->emu->voices[(epcm->voices[0]->number + i) % NUM_G];
|
||||
epcm->voices[i]->epcm = epcm;
|
||||
}
|
||||
}
|
||||
|
@ -157,10 +157,10 @@ static int hda_codec_driver_remove(struct device *dev)
|
||||
return codec->bus->core.ext_ops->hdev_detach(&codec->core);
|
||||
}
|
||||
|
||||
refcount_dec(&codec->pcm_ref);
|
||||
snd_hda_codec_disconnect_pcms(codec);
|
||||
snd_hda_jack_tbl_disconnect(codec);
|
||||
wait_event(codec->remove_sleep, !refcount_read(&codec->pcm_ref));
|
||||
if (!refcount_dec_and_test(&codec->pcm_ref))
|
||||
wait_event(codec->remove_sleep, !refcount_read(&codec->pcm_ref));
|
||||
snd_power_sync_ref(codec->bus->card);
|
||||
|
||||
if (codec->patch_ops.free)
|
||||
|
@ -2543,6 +2543,8 @@ static const struct pci_device_id azx_ids[] = {
|
||||
/* 5 Series/3400 */
|
||||
{ PCI_DEVICE(0x8086, 0x3b56),
|
||||
.driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH_NOPM },
|
||||
{ PCI_DEVICE(0x8086, 0x3b57),
|
||||
.driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH_NOPM },
|
||||
/* Poulsbo */
|
||||
{ PCI_DEVICE(0x8086, 0x811b),
|
||||
.driver_data = AZX_DRIVER_SCH | AZX_DCAPS_INTEL_PCH_BASE },
|
||||
|
@ -3984,6 +3984,7 @@ static int tegra_hdmi_init(struct hda_codec *codec)
|
||||
|
||||
generic_hdmi_init_per_pins(codec);
|
||||
|
||||
codec->depop_delay = 10;
|
||||
codec->patch_ops.build_pcms = tegra_hdmi_build_pcms;
|
||||
spec->chmap.ops.chmap_cea_alloc_validate_get_type =
|
||||
nvhdmi_chmap_cea_alloc_validate_get_type;
|
||||
|
@ -9569,6 +9569,7 @@ static const struct snd_pci_quirk alc269_fixup_tbl[] = {
|
||||
SND_PCI_QUIRK(0x17aa, 0x9e54, "LENOVO NB", ALC269_FIXUP_LENOVO_EAPD),
|
||||
SND_PCI_QUIRK(0x1849, 0x1233, "ASRock NUC Box 1100", ALC233_FIXUP_NO_AUDIO_JACK),
|
||||
SND_PCI_QUIRK(0x19e5, 0x3204, "Huawei MACH-WX9", ALC256_FIXUP_HUAWEI_MACH_WX9_PINS),
|
||||
SND_PCI_QUIRK(0x19e5, 0x320f, "Huawei WRT-WX9 ", ALC256_FIXUP_ASUS_MIC_NO_PRESENCE),
|
||||
SND_PCI_QUIRK(0x1b35, 0x1235, "CZC B20", ALC269_FIXUP_CZC_B20),
|
||||
SND_PCI_QUIRK(0x1b35, 0x1236, "CZC TMI", ALC269_FIXUP_CZC_TMI),
|
||||
SND_PCI_QUIRK(0x1b35, 0x1237, "CZC L101", ALC269_FIXUP_CZC_L101),
|
||||
|
@ -196,7 +196,7 @@ struct mchp_spdiftx_dev {
|
||||
struct clk *pclk;
|
||||
struct clk *gclk;
|
||||
unsigned int fmt;
|
||||
int gclk_enabled:1;
|
||||
unsigned int gclk_enabled:1;
|
||||
};
|
||||
|
||||
static inline int mchp_spdiftx_is_running(struct mchp_spdiftx_dev *dev)
|
||||
|
@ -1617,7 +1617,6 @@ static irqreturn_t cs42l42_irq_thread(int irq, void *data)
|
||||
unsigned int current_plug_status;
|
||||
unsigned int current_button_status;
|
||||
unsigned int i;
|
||||
int report = 0;
|
||||
|
||||
mutex_lock(&cs42l42->irq_lock);
|
||||
if (cs42l42->suspended) {
|
||||
@ -1711,13 +1710,15 @@ static irqreturn_t cs42l42_irq_thread(int irq, void *data)
|
||||
|
||||
if (current_button_status & CS42L42_M_DETECT_TF_MASK) {
|
||||
dev_dbg(cs42l42->dev, "Button released\n");
|
||||
report = 0;
|
||||
snd_soc_jack_report(cs42l42->jack, 0,
|
||||
SND_JACK_BTN_0 | SND_JACK_BTN_1 |
|
||||
SND_JACK_BTN_2 | SND_JACK_BTN_3);
|
||||
} else if (current_button_status & CS42L42_M_DETECT_FT_MASK) {
|
||||
report = cs42l42_handle_button_press(cs42l42);
|
||||
|
||||
snd_soc_jack_report(cs42l42->jack,
|
||||
cs42l42_handle_button_press(cs42l42),
|
||||
SND_JACK_BTN_0 | SND_JACK_BTN_1 |
|
||||
SND_JACK_BTN_2 | SND_JACK_BTN_3);
|
||||
}
|
||||
snd_soc_jack_report(cs42l42->jack, report, SND_JACK_BTN_0 | SND_JACK_BTN_1 |
|
||||
SND_JACK_BTN_2 | SND_JACK_BTN_3);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -357,17 +357,32 @@ static const struct snd_soc_dapm_route nau8540_dapm_routes[] = {
|
||||
{"AIFTX", NULL, "Digital CH4 Mux"},
|
||||
};
|
||||
|
||||
static int nau8540_clock_check(struct nau8540 *nau8540, int rate, int osr)
|
||||
static const struct nau8540_osr_attr *
|
||||
nau8540_get_osr(struct nau8540 *nau8540)
|
||||
{
|
||||
unsigned int osr;
|
||||
|
||||
regmap_read(nau8540->regmap, NAU8540_REG_ADC_SAMPLE_RATE, &osr);
|
||||
osr &= NAU8540_ADC_OSR_MASK;
|
||||
if (osr >= ARRAY_SIZE(osr_adc_sel))
|
||||
return NULL;
|
||||
return &osr_adc_sel[osr];
|
||||
}
|
||||
|
||||
static int nau8540_dai_startup(struct snd_pcm_substream *substream,
|
||||
struct snd_soc_dai *dai)
|
||||
{
|
||||
struct snd_soc_component *component = dai->component;
|
||||
struct nau8540 *nau8540 = snd_soc_component_get_drvdata(component);
|
||||
const struct nau8540_osr_attr *osr;
|
||||
|
||||
osr = nau8540_get_osr(nau8540);
|
||||
if (!osr || !osr->osr)
|
||||
return -EINVAL;
|
||||
|
||||
if (rate * osr > CLK_ADC_MAX) {
|
||||
dev_err(nau8540->dev, "exceed the maximum frequency of CLK_ADC\n");
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
return snd_pcm_hw_constraint_minmax(substream->runtime,
|
||||
SNDRV_PCM_HW_PARAM_RATE,
|
||||
0, CLK_ADC_MAX / osr->osr);
|
||||
}
|
||||
|
||||
static int nau8540_hw_params(struct snd_pcm_substream *substream,
|
||||
@ -375,7 +390,8 @@ static int nau8540_hw_params(struct snd_pcm_substream *substream,
|
||||
{
|
||||
struct snd_soc_component *component = dai->component;
|
||||
struct nau8540 *nau8540 = snd_soc_component_get_drvdata(component);
|
||||
unsigned int val_len = 0, osr;
|
||||
unsigned int val_len = 0;
|
||||
const struct nau8540_osr_attr *osr;
|
||||
|
||||
/* CLK_ADC = OSR * FS
|
||||
* ADC clock frequency is defined as Over Sampling Rate (OSR)
|
||||
@ -383,13 +399,14 @@ static int nau8540_hw_params(struct snd_pcm_substream *substream,
|
||||
* values must be selected such that the maximum frequency is less
|
||||
* than 6.144 MHz.
|
||||
*/
|
||||
regmap_read(nau8540->regmap, NAU8540_REG_ADC_SAMPLE_RATE, &osr);
|
||||
osr &= NAU8540_ADC_OSR_MASK;
|
||||
if (nau8540_clock_check(nau8540, params_rate(params), osr))
|
||||
osr = nau8540_get_osr(nau8540);
|
||||
if (!osr || !osr->osr)
|
||||
return -EINVAL;
|
||||
if (params_rate(params) * osr->osr > CLK_ADC_MAX)
|
||||
return -EINVAL;
|
||||
regmap_update_bits(nau8540->regmap, NAU8540_REG_CLOCK_SRC,
|
||||
NAU8540_CLK_ADC_SRC_MASK,
|
||||
osr_adc_sel[osr].clk_src << NAU8540_CLK_ADC_SRC_SFT);
|
||||
osr->clk_src << NAU8540_CLK_ADC_SRC_SFT);
|
||||
|
||||
switch (params_width(params)) {
|
||||
case 16:
|
||||
@ -515,6 +532,7 @@ static int nau8540_set_tdm_slot(struct snd_soc_dai *dai,
|
||||
|
||||
|
||||
static const struct snd_soc_dai_ops nau8540_dai_ops = {
|
||||
.startup = nau8540_dai_startup,
|
||||
.hw_params = nau8540_hw_params,
|
||||
.set_fmt = nau8540_set_fmt,
|
||||
.set_tdm_slot = nau8540_set_tdm_slot,
|
||||
|
@ -670,28 +670,40 @@ static const struct snd_soc_dapm_route nau8821_dapm_routes[] = {
|
||||
{"HPOR", NULL, "Class G"},
|
||||
};
|
||||
|
||||
static int nau8821_clock_check(struct nau8821 *nau8821,
|
||||
int stream, int rate, int osr)
|
||||
static const struct nau8821_osr_attr *
|
||||
nau8821_get_osr(struct nau8821 *nau8821, int stream)
|
||||
{
|
||||
int osrate = 0;
|
||||
unsigned int osr;
|
||||
|
||||
if (stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
||||
regmap_read(nau8821->regmap, NAU8821_R2C_DAC_CTRL1, &osr);
|
||||
osr &= NAU8821_DAC_OVERSAMPLE_MASK;
|
||||
if (osr >= ARRAY_SIZE(osr_dac_sel))
|
||||
return -EINVAL;
|
||||
osrate = osr_dac_sel[osr].osr;
|
||||
return NULL;
|
||||
return &osr_dac_sel[osr];
|
||||
} else {
|
||||
regmap_read(nau8821->regmap, NAU8821_R2B_ADC_RATE, &osr);
|
||||
osr &= NAU8821_ADC_SYNC_DOWN_MASK;
|
||||
if (osr >= ARRAY_SIZE(osr_adc_sel))
|
||||
return -EINVAL;
|
||||
osrate = osr_adc_sel[osr].osr;
|
||||
return NULL;
|
||||
return &osr_adc_sel[osr];
|
||||
}
|
||||
}
|
||||
|
||||
if (!osrate || rate * osrate > CLK_DA_AD_MAX) {
|
||||
dev_err(nau8821->dev,
|
||||
"exceed the maximum frequency of CLK_ADC or CLK_DAC");
|
||||
static int nau8821_dai_startup(struct snd_pcm_substream *substream,
|
||||
struct snd_soc_dai *dai)
|
||||
{
|
||||
struct snd_soc_component *component = dai->component;
|
||||
struct nau8821 *nau8821 = snd_soc_component_get_drvdata(component);
|
||||
const struct nau8821_osr_attr *osr;
|
||||
|
||||
osr = nau8821_get_osr(nau8821, substream->stream);
|
||||
if (!osr || !osr->osr)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
return snd_pcm_hw_constraint_minmax(substream->runtime,
|
||||
SNDRV_PCM_HW_PARAM_RATE,
|
||||
0, CLK_DA_AD_MAX / osr->osr);
|
||||
}
|
||||
|
||||
static int nau8821_hw_params(struct snd_pcm_substream *substream,
|
||||
@ -699,7 +711,8 @@ static int nau8821_hw_params(struct snd_pcm_substream *substream,
|
||||
{
|
||||
struct snd_soc_component *component = dai->component;
|
||||
struct nau8821 *nau8821 = snd_soc_component_get_drvdata(component);
|
||||
unsigned int val_len = 0, osr, ctrl_val, bclk_fs, clk_div;
|
||||
unsigned int val_len = 0, ctrl_val, bclk_fs, clk_div;
|
||||
const struct nau8821_osr_attr *osr;
|
||||
|
||||
nau8821->fs = params_rate(params);
|
||||
/* CLK_DAC or CLK_ADC = OSR * FS
|
||||
@ -708,27 +721,19 @@ static int nau8821_hw_params(struct snd_pcm_substream *substream,
|
||||
* values must be selected such that the maximum frequency is less
|
||||
* than 6.144 MHz.
|
||||
*/
|
||||
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
||||
regmap_read(nau8821->regmap, NAU8821_R2C_DAC_CTRL1, &osr);
|
||||
osr &= NAU8821_DAC_OVERSAMPLE_MASK;
|
||||
if (nau8821_clock_check(nau8821, substream->stream,
|
||||
nau8821->fs, osr)) {
|
||||
return -EINVAL;
|
||||
}
|
||||
osr = nau8821_get_osr(nau8821, substream->stream);
|
||||
if (!osr || !osr->osr)
|
||||
return -EINVAL;
|
||||
if (nau8821->fs * osr->osr > CLK_DA_AD_MAX)
|
||||
return -EINVAL;
|
||||
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
|
||||
regmap_update_bits(nau8821->regmap, NAU8821_R03_CLK_DIVIDER,
|
||||
NAU8821_CLK_DAC_SRC_MASK,
|
||||
osr_dac_sel[osr].clk_src << NAU8821_CLK_DAC_SRC_SFT);
|
||||
} else {
|
||||
regmap_read(nau8821->regmap, NAU8821_R2B_ADC_RATE, &osr);
|
||||
osr &= NAU8821_ADC_SYNC_DOWN_MASK;
|
||||
if (nau8821_clock_check(nau8821, substream->stream,
|
||||
nau8821->fs, osr)) {
|
||||
return -EINVAL;
|
||||
}
|
||||
osr->clk_src << NAU8821_CLK_DAC_SRC_SFT);
|
||||
else
|
||||
regmap_update_bits(nau8821->regmap, NAU8821_R03_CLK_DIVIDER,
|
||||
NAU8821_CLK_ADC_SRC_MASK,
|
||||
osr_adc_sel[osr].clk_src << NAU8821_CLK_ADC_SRC_SFT);
|
||||
}
|
||||
osr->clk_src << NAU8821_CLK_ADC_SRC_SFT);
|
||||
|
||||
/* make BCLK and LRC divde configuration if the codec as master. */
|
||||
regmap_read(nau8821->regmap, NAU8821_R1D_I2S_PCM_CTRL2, &ctrl_val);
|
||||
@ -843,6 +848,7 @@ static int nau8821_digital_mute(struct snd_soc_dai *dai, int mute,
|
||||
}
|
||||
|
||||
static const struct snd_soc_dai_ops nau8821_dai_ops = {
|
||||
.startup = nau8821_dai_startup,
|
||||
.hw_params = nau8821_hw_params,
|
||||
.set_fmt = nau8821_set_dai_fmt,
|
||||
.mute_stream = nau8821_digital_mute,
|
||||
|
@ -1014,27 +1014,42 @@ static irqreturn_t nau8824_interrupt(int irq, void *data)
|
||||
return IRQ_HANDLED;
|
||||
}
|
||||
|
||||
static int nau8824_clock_check(struct nau8824 *nau8824,
|
||||
int stream, int rate, int osr)
|
||||
static const struct nau8824_osr_attr *
|
||||
nau8824_get_osr(struct nau8824 *nau8824, int stream)
|
||||
{
|
||||
int osrate;
|
||||
unsigned int osr;
|
||||
|
||||
if (stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
||||
regmap_read(nau8824->regmap,
|
||||
NAU8824_REG_DAC_FILTER_CTRL_1, &osr);
|
||||
osr &= NAU8824_DAC_OVERSAMPLE_MASK;
|
||||
if (osr >= ARRAY_SIZE(osr_dac_sel))
|
||||
return -EINVAL;
|
||||
osrate = osr_dac_sel[osr].osr;
|
||||
return NULL;
|
||||
return &osr_dac_sel[osr];
|
||||
} else {
|
||||
regmap_read(nau8824->regmap,
|
||||
NAU8824_REG_ADC_FILTER_CTRL, &osr);
|
||||
osr &= NAU8824_ADC_SYNC_DOWN_MASK;
|
||||
if (osr >= ARRAY_SIZE(osr_adc_sel))
|
||||
return -EINVAL;
|
||||
osrate = osr_adc_sel[osr].osr;
|
||||
return NULL;
|
||||
return &osr_adc_sel[osr];
|
||||
}
|
||||
}
|
||||
|
||||
if (!osrate || rate * osr > CLK_DA_AD_MAX) {
|
||||
dev_err(nau8824->dev, "exceed the maximum frequency of CLK_ADC or CLK_DAC\n");
|
||||
static int nau8824_dai_startup(struct snd_pcm_substream *substream,
|
||||
struct snd_soc_dai *dai)
|
||||
{
|
||||
struct snd_soc_component *component = dai->component;
|
||||
struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
|
||||
const struct nau8824_osr_attr *osr;
|
||||
|
||||
osr = nau8824_get_osr(nau8824, substream->stream);
|
||||
if (!osr || !osr->osr)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
return snd_pcm_hw_constraint_minmax(substream->runtime,
|
||||
SNDRV_PCM_HW_PARAM_RATE,
|
||||
0, CLK_DA_AD_MAX / osr->osr);
|
||||
}
|
||||
|
||||
static int nau8824_hw_params(struct snd_pcm_substream *substream,
|
||||
@ -1042,7 +1057,9 @@ static int nau8824_hw_params(struct snd_pcm_substream *substream,
|
||||
{
|
||||
struct snd_soc_component *component = dai->component;
|
||||
struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
|
||||
unsigned int val_len = 0, osr, ctrl_val, bclk_fs, bclk_div;
|
||||
unsigned int val_len = 0, ctrl_val, bclk_fs, bclk_div;
|
||||
const struct nau8824_osr_attr *osr;
|
||||
int err = -EINVAL;
|
||||
|
||||
nau8824_sema_acquire(nau8824, HZ);
|
||||
|
||||
@ -1053,27 +1070,19 @@ static int nau8824_hw_params(struct snd_pcm_substream *substream,
|
||||
* than 6.144 MHz.
|
||||
*/
|
||||
nau8824->fs = params_rate(params);
|
||||
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
||||
regmap_read(nau8824->regmap,
|
||||
NAU8824_REG_DAC_FILTER_CTRL_1, &osr);
|
||||
osr &= NAU8824_DAC_OVERSAMPLE_MASK;
|
||||
if (nau8824_clock_check(nau8824, substream->stream,
|
||||
nau8824->fs, osr))
|
||||
return -EINVAL;
|
||||
osr = nau8824_get_osr(nau8824, substream->stream);
|
||||
if (!osr || !osr->osr)
|
||||
goto error;
|
||||
if (nau8824->fs * osr->osr > CLK_DA_AD_MAX)
|
||||
goto error;
|
||||
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
|
||||
regmap_update_bits(nau8824->regmap, NAU8824_REG_CLK_DIVIDER,
|
||||
NAU8824_CLK_DAC_SRC_MASK,
|
||||
osr_dac_sel[osr].clk_src << NAU8824_CLK_DAC_SRC_SFT);
|
||||
} else {
|
||||
regmap_read(nau8824->regmap,
|
||||
NAU8824_REG_ADC_FILTER_CTRL, &osr);
|
||||
osr &= NAU8824_ADC_SYNC_DOWN_MASK;
|
||||
if (nau8824_clock_check(nau8824, substream->stream,
|
||||
nau8824->fs, osr))
|
||||
return -EINVAL;
|
||||
osr->clk_src << NAU8824_CLK_DAC_SRC_SFT);
|
||||
else
|
||||
regmap_update_bits(nau8824->regmap, NAU8824_REG_CLK_DIVIDER,
|
||||
NAU8824_CLK_ADC_SRC_MASK,
|
||||
osr_adc_sel[osr].clk_src << NAU8824_CLK_ADC_SRC_SFT);
|
||||
}
|
||||
osr->clk_src << NAU8824_CLK_ADC_SRC_SFT);
|
||||
|
||||
/* make BCLK and LRC divde configuration if the codec as master. */
|
||||
regmap_read(nau8824->regmap,
|
||||
@ -1090,7 +1099,7 @@ static int nau8824_hw_params(struct snd_pcm_substream *substream,
|
||||
else if (bclk_fs <= 256)
|
||||
bclk_div = 0;
|
||||
else
|
||||
return -EINVAL;
|
||||
goto error;
|
||||
regmap_update_bits(nau8824->regmap,
|
||||
NAU8824_REG_PORT0_I2S_PCM_CTRL_2,
|
||||
NAU8824_I2S_LRC_DIV_MASK | NAU8824_I2S_BLK_DIV_MASK,
|
||||
@ -1111,15 +1120,17 @@ static int nau8824_hw_params(struct snd_pcm_substream *substream,
|
||||
val_len |= NAU8824_I2S_DL_32;
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
goto error;
|
||||
}
|
||||
|
||||
regmap_update_bits(nau8824->regmap, NAU8824_REG_PORT0_I2S_PCM_CTRL_1,
|
||||
NAU8824_I2S_DL_MASK, val_len);
|
||||
err = 0;
|
||||
|
||||
error:
|
||||
nau8824_sema_release(nau8824);
|
||||
|
||||
return 0;
|
||||
return err;
|
||||
}
|
||||
|
||||
static int nau8824_set_fmt(struct snd_soc_dai *dai, unsigned int fmt)
|
||||
@ -1128,8 +1139,6 @@ static int nau8824_set_fmt(struct snd_soc_dai *dai, unsigned int fmt)
|
||||
struct nau8824 *nau8824 = snd_soc_component_get_drvdata(component);
|
||||
unsigned int ctrl1_val = 0, ctrl2_val = 0;
|
||||
|
||||
nau8824_sema_acquire(nau8824, HZ);
|
||||
|
||||
switch (fmt & SND_SOC_DAIFMT_MASTER_MASK) {
|
||||
case SND_SOC_DAIFMT_CBM_CFM:
|
||||
ctrl2_val |= NAU8824_I2S_MS_MASTER;
|
||||
@ -1171,6 +1180,8 @@ static int nau8824_set_fmt(struct snd_soc_dai *dai, unsigned int fmt)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
nau8824_sema_acquire(nau8824, HZ);
|
||||
|
||||
regmap_update_bits(nau8824->regmap, NAU8824_REG_PORT0_I2S_PCM_CTRL_1,
|
||||
NAU8824_I2S_DF_MASK | NAU8824_I2S_BP_MASK |
|
||||
NAU8824_I2S_PCMB_EN, ctrl1_val);
|
||||
@ -1547,6 +1558,7 @@ static const struct snd_soc_component_driver nau8824_component_driver = {
|
||||
};
|
||||
|
||||
static const struct snd_soc_dai_ops nau8824_dai_ops = {
|
||||
.startup = nau8824_dai_startup,
|
||||
.hw_params = nau8824_hw_params,
|
||||
.set_fmt = nau8824_set_fmt,
|
||||
.set_tdm_slot = nau8824_set_tdm_slot,
|
||||
|
@ -1247,27 +1247,42 @@ static const struct snd_soc_dapm_route nau8825_dapm_routes[] = {
|
||||
{"HPOR", NULL, "Class G"},
|
||||
};
|
||||
|
||||
static int nau8825_clock_check(struct nau8825 *nau8825,
|
||||
int stream, int rate, int osr)
|
||||
static const struct nau8825_osr_attr *
|
||||
nau8825_get_osr(struct nau8825 *nau8825, int stream)
|
||||
{
|
||||
int osrate;
|
||||
unsigned int osr;
|
||||
|
||||
if (stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
||||
regmap_read(nau8825->regmap,
|
||||
NAU8825_REG_DAC_CTRL1, &osr);
|
||||
osr &= NAU8825_DAC_OVERSAMPLE_MASK;
|
||||
if (osr >= ARRAY_SIZE(osr_dac_sel))
|
||||
return -EINVAL;
|
||||
osrate = osr_dac_sel[osr].osr;
|
||||
return NULL;
|
||||
return &osr_dac_sel[osr];
|
||||
} else {
|
||||
regmap_read(nau8825->regmap,
|
||||
NAU8825_REG_ADC_RATE, &osr);
|
||||
osr &= NAU8825_ADC_SYNC_DOWN_MASK;
|
||||
if (osr >= ARRAY_SIZE(osr_adc_sel))
|
||||
return -EINVAL;
|
||||
osrate = osr_adc_sel[osr].osr;
|
||||
return NULL;
|
||||
return &osr_adc_sel[osr];
|
||||
}
|
||||
}
|
||||
|
||||
if (!osrate || rate * osr > CLK_DA_AD_MAX) {
|
||||
dev_err(nau8825->dev, "exceed the maximum frequency of CLK_ADC or CLK_DAC\n");
|
||||
static int nau8825_dai_startup(struct snd_pcm_substream *substream,
|
||||
struct snd_soc_dai *dai)
|
||||
{
|
||||
struct snd_soc_component *component = dai->component;
|
||||
struct nau8825 *nau8825 = snd_soc_component_get_drvdata(component);
|
||||
const struct nau8825_osr_attr *osr;
|
||||
|
||||
osr = nau8825_get_osr(nau8825, substream->stream);
|
||||
if (!osr || !osr->osr)
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
return snd_pcm_hw_constraint_minmax(substream->runtime,
|
||||
SNDRV_PCM_HW_PARAM_RATE,
|
||||
0, CLK_DA_AD_MAX / osr->osr);
|
||||
}
|
||||
|
||||
static int nau8825_hw_params(struct snd_pcm_substream *substream,
|
||||
@ -1276,7 +1291,9 @@ static int nau8825_hw_params(struct snd_pcm_substream *substream,
|
||||
{
|
||||
struct snd_soc_component *component = dai->component;
|
||||
struct nau8825 *nau8825 = snd_soc_component_get_drvdata(component);
|
||||
unsigned int val_len = 0, osr, ctrl_val, bclk_fs, bclk_div;
|
||||
unsigned int val_len = 0, ctrl_val, bclk_fs, bclk_div;
|
||||
const struct nau8825_osr_attr *osr;
|
||||
int err = -EINVAL;
|
||||
|
||||
nau8825_sema_acquire(nau8825, 3 * HZ);
|
||||
|
||||
@ -1286,29 +1303,19 @@ static int nau8825_hw_params(struct snd_pcm_substream *substream,
|
||||
* values must be selected such that the maximum frequency is less
|
||||
* than 6.144 MHz.
|
||||
*/
|
||||
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK) {
|
||||
regmap_read(nau8825->regmap, NAU8825_REG_DAC_CTRL1, &osr);
|
||||
osr &= NAU8825_DAC_OVERSAMPLE_MASK;
|
||||
if (nau8825_clock_check(nau8825, substream->stream,
|
||||
params_rate(params), osr)) {
|
||||
nau8825_sema_release(nau8825);
|
||||
return -EINVAL;
|
||||
}
|
||||
osr = nau8825_get_osr(nau8825, substream->stream);
|
||||
if (!osr || !osr->osr)
|
||||
goto error;
|
||||
if (params_rate(params) * osr->osr > CLK_DA_AD_MAX)
|
||||
goto error;
|
||||
if (substream->stream == SNDRV_PCM_STREAM_PLAYBACK)
|
||||
regmap_update_bits(nau8825->regmap, NAU8825_REG_CLK_DIVIDER,
|
||||
NAU8825_CLK_DAC_SRC_MASK,
|
||||
osr_dac_sel[osr].clk_src << NAU8825_CLK_DAC_SRC_SFT);
|
||||
} else {
|
||||
regmap_read(nau8825->regmap, NAU8825_REG_ADC_RATE, &osr);
|
||||
osr &= NAU8825_ADC_SYNC_DOWN_MASK;
|
||||
if (nau8825_clock_check(nau8825, substream->stream,
|
||||
params_rate(params), osr)) {
|
||||
nau8825_sema_release(nau8825);
|
||||
return -EINVAL;
|
||||
}
|
||||
osr->clk_src << NAU8825_CLK_DAC_SRC_SFT);
|
||||
else
|
||||
regmap_update_bits(nau8825->regmap, NAU8825_REG_CLK_DIVIDER,
|
||||
NAU8825_CLK_ADC_SRC_MASK,
|
||||
osr_adc_sel[osr].clk_src << NAU8825_CLK_ADC_SRC_SFT);
|
||||
}
|
||||
osr->clk_src << NAU8825_CLK_ADC_SRC_SFT);
|
||||
|
||||
/* make BCLK and LRC divde configuration if the codec as master. */
|
||||
regmap_read(nau8825->regmap, NAU8825_REG_I2S_PCM_CTRL2, &ctrl_val);
|
||||
@ -1321,10 +1328,8 @@ static int nau8825_hw_params(struct snd_pcm_substream *substream,
|
||||
bclk_div = 1;
|
||||
else if (bclk_fs <= 128)
|
||||
bclk_div = 0;
|
||||
else {
|
||||
nau8825_sema_release(nau8825);
|
||||
return -EINVAL;
|
||||
}
|
||||
else
|
||||
goto error;
|
||||
regmap_update_bits(nau8825->regmap, NAU8825_REG_I2S_PCM_CTRL2,
|
||||
NAU8825_I2S_LRC_DIV_MASK | NAU8825_I2S_BLK_DIV_MASK,
|
||||
((bclk_div + 1) << NAU8825_I2S_LRC_DIV_SFT) | bclk_div);
|
||||
@ -1344,17 +1349,18 @@ static int nau8825_hw_params(struct snd_pcm_substream *substream,
|
||||
val_len |= NAU8825_I2S_DL_32;
|
||||
break;
|
||||
default:
|
||||
nau8825_sema_release(nau8825);
|
||||
return -EINVAL;
|
||||
goto error;
|
||||
}
|
||||
|
||||
regmap_update_bits(nau8825->regmap, NAU8825_REG_I2S_PCM_CTRL1,
|
||||
NAU8825_I2S_DL_MASK, val_len);
|
||||
err = 0;
|
||||
|
||||
error:
|
||||
/* Release the semaphore. */
|
||||
nau8825_sema_release(nau8825);
|
||||
|
||||
return 0;
|
||||
return err;
|
||||
}
|
||||
|
||||
static int nau8825_set_dai_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt)
|
||||
@ -1420,6 +1426,7 @@ static int nau8825_set_dai_fmt(struct snd_soc_dai *codec_dai, unsigned int fmt)
|
||||
}
|
||||
|
||||
static const struct snd_soc_dai_ops nau8825_dai_ops = {
|
||||
.startup = nau8825_dai_startup,
|
||||
.hw_params = nau8825_hw_params,
|
||||
.set_fmt = nau8825_set_dai_fmt,
|
||||
};
|
||||
|
@ -234,18 +234,26 @@ static int fsl_aud2htx_probe(struct platform_device *pdev)
|
||||
|
||||
regcache_cache_only(aud2htx->regmap, true);
|
||||
|
||||
/*
|
||||
* Register platform component before registering cpu dai for there
|
||||
* is not defer probe for platform component in snd_soc_add_pcm_runtime().
|
||||
*/
|
||||
ret = devm_snd_dmaengine_pcm_register(&pdev->dev, NULL, 0);
|
||||
if (ret) {
|
||||
dev_err(&pdev->dev, "failed to pcm register\n");
|
||||
pm_runtime_disable(&pdev->dev);
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = devm_snd_soc_register_component(&pdev->dev,
|
||||
&fsl_aud2htx_component,
|
||||
&fsl_aud2htx_dai, 1);
|
||||
if (ret) {
|
||||
dev_err(&pdev->dev, "failed to register ASoC DAI\n");
|
||||
pm_runtime_disable(&pdev->dev);
|
||||
return ret;
|
||||
}
|
||||
|
||||
ret = imx_pcm_dma_init(pdev);
|
||||
if (ret)
|
||||
dev_err(&pdev->dev, "failed to init imx pcm dma: %d\n", ret);
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
|
@ -122,7 +122,7 @@ static int fsl_mqs_set_dai_fmt(struct snd_soc_dai *dai, unsigned int fmt)
|
||||
}
|
||||
|
||||
switch (fmt & SND_SOC_DAIFMT_CLOCK_PROVIDER_MASK) {
|
||||
case SND_SOC_DAIFMT_BP_FP:
|
||||
case SND_SOC_DAIFMT_CBC_CFC:
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
|
@ -1306,7 +1306,7 @@ static int fsl_sai_probe(struct platform_device *pdev)
|
||||
sai->mclk_clk[i] = devm_clk_get(dev, tmp);
|
||||
if (IS_ERR(sai->mclk_clk[i])) {
|
||||
dev_err(dev, "failed to get mclk%d clock: %ld\n",
|
||||
i + 1, PTR_ERR(sai->mclk_clk[i]));
|
||||
i, PTR_ERR(sai->mclk_clk[i]));
|
||||
sai->mclk_clk[i] = NULL;
|
||||
}
|
||||
}
|
||||
|
@ -271,9 +271,6 @@ static int mtk_adda_ul_event(struct snd_soc_dapm_widget *w,
|
||||
/* should delayed 1/fs(smallest is 8k) = 125us before afe off */
|
||||
usleep_range(125, 135);
|
||||
mt8186_afe_gpio_request(afe->dev, false, MT8186_DAI_ADDA, 1);
|
||||
|
||||
/* reset dmic */
|
||||
afe_priv->mtkaif_dmic = 0;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
|
@ -270,6 +270,7 @@ static int sm8250_platform_probe(struct platform_device *pdev)
|
||||
if (!card)
|
||||
return -ENOMEM;
|
||||
|
||||
card->owner = THIS_MODULE;
|
||||
/* Allocate the private data */
|
||||
data = devm_kzalloc(dev, sizeof(*data), GFP_KERNEL);
|
||||
if (!data)
|
||||
|
@ -196,6 +196,7 @@ config SND_SOC_SOF_DEBUG_ENABLE_FIRMWARE_TRACE
|
||||
|
||||
config SND_SOC_SOF_DEBUG_IPC_FLOOD_TEST
|
||||
tristate "SOF enable IPC flood test"
|
||||
depends on SND_SOC_SOF
|
||||
select SND_SOC_SOF_CLIENT
|
||||
help
|
||||
This option enables a separate client device for IPC flood test
|
||||
@ -214,6 +215,7 @@ config SND_SOC_SOF_DEBUG_IPC_FLOOD_TEST_NUM
|
||||
|
||||
config SND_SOC_SOF_DEBUG_IPC_MSG_INJECTOR
|
||||
tristate "SOF enable IPC message injector"
|
||||
depends on SND_SOC_SOF
|
||||
select SND_SOC_SOF_CLIENT
|
||||
help
|
||||
This option enables the IPC message injector which can be used to send
|
||||
|
@ -771,7 +771,7 @@ static int sof_ipc4_widget_setup_comp_src(struct snd_sof_widget *swidget)
|
||||
goto err;
|
||||
|
||||
ret = sof_update_ipc_object(scomp, src, SOF_SRC_TOKENS, swidget->tuples,
|
||||
swidget->num_tuples, sizeof(src), 1);
|
||||
swidget->num_tuples, sizeof(*src), 1);
|
||||
if (ret) {
|
||||
dev_err(scomp->dev, "Parsing SRC tokens failed\n");
|
||||
goto err;
|
||||
@ -1251,7 +1251,7 @@ sof_ipc4_prepare_copier_module(struct snd_sof_widget *swidget,
|
||||
if (blob->alh_cfg.count > 1) {
|
||||
int group_id;
|
||||
|
||||
group_id = ida_alloc_max(&alh_group_ida, ALH_MULTI_GTW_COUNT,
|
||||
group_id = ida_alloc_max(&alh_group_ida, ALH_MULTI_GTW_COUNT - 1,
|
||||
GFP_KERNEL);
|
||||
|
||||
if (group_id < 0)
|
||||
|
@ -925,6 +925,8 @@ void snd_usb_endpoint_close(struct snd_usb_audio *chip,
|
||||
endpoint_set_interface(chip, ep, false);
|
||||
|
||||
if (!--ep->opened) {
|
||||
if (ep->clock_ref && !atomic_read(&ep->clock_ref->locked))
|
||||
ep->clock_ref->rate = 0;
|
||||
ep->iface = 0;
|
||||
ep->altsetting = 0;
|
||||
ep->cur_audiofmt = NULL;
|
||||
|
Loading…
Reference in New Issue
Block a user