Commit 8ee67bb8 authored by Mark Brown's avatar Mark Brown

Merge remote-tracking branches 'asoc/topic/rt5645', 'asoc/topic/rt5651',...

Merge remote-tracking branches 'asoc/topic/rt5645', 'asoc/topic/rt5651', 'asoc/topic/rt5659' and 'asoc/topic/rt5660' into asoc-next
...@@ -18,9 +18,9 @@ Optional properties: ...@@ -18,9 +18,9 @@ Optional properties:
- realtek,jack-detect-source - realtek,jack-detect-source
u32. Valid values: u32. Valid values:
1: Use JD1_1 pin for jack-dectect 1: Use JD1_1 pin for jack-detect
2: Use JD1_2 pin for jack-dectect 2: Use JD1_2 pin for jack-detect
3: Use JD2 pin for jack-dectect 3: Use JD2 pin for jack-detect
- realtek,over-current-threshold-microamp - realtek,over-current-threshold-microamp
u32, micbias over-current detection threshold in µA, valid values are u32, micbias over-current detection threshold in µA, valid values are
......
/* SPDX-License-Identifier: GPL-2.0 */
#ifndef __DT_RT5651_H
#define __DT_RT5651_H
#define RT5651_JD_NULL 0
#define RT5651_JD1_1 1
#define RT5651_JD1_2 2
#define RT5651_JD2 3
#define RT5651_OVCD_SF_0P5 0
#define RT5651_OVCD_SF_0P75 1
#define RT5651_OVCD_SF_1P0 2
#define RT5651_OVCD_SF_1P5 3
#endif /* __DT_RT5651_H */
/*
* linux/sound/rt286.h -- Platform data for RT286
*
* Copyright 2013 Realtek Microelectronics
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 2 as
* published by the Free Software Foundation.
*/
#ifndef __LINUX_SND_RT5651_H
#define __LINUX_SND_RT5651_H
/*
* Note these MUST match the values from the DT binding:
* Documentation/devicetree/bindings/sound/rt5651.txt
*/
enum rt5651_jd_src {
RT5651_JD_NULL,
RT5651_JD1_1,
RT5651_JD1_2,
RT5651_JD2,
};
/*
* Note these MUST match the values from the DT binding:
* Documentation/devicetree/bindings/sound/rt5651.txt
*/
enum rt5651_ovcd_sf {
RT5651_OVCD_SF_0P5,
RT5651_OVCD_SF_0P75,
RT5651_OVCD_SF_1P0,
RT5651_OVCD_SF_1P5,
};
#endif
...@@ -30,6 +30,7 @@ enum rt5659_dmic2_data_pin { ...@@ -30,6 +30,7 @@ enum rt5659_dmic2_data_pin {
enum rt5659_jd_src { enum rt5659_jd_src {
RT5659_JD_NULL, RT5659_JD_NULL,
RT5659_JD3, RT5659_JD3,
RT5659_JD_HDA_HEADER,
}; };
struct rt5659_platform_data { struct rt5659_platform_data {
......
...@@ -71,9 +71,9 @@ static int cz_init(struct snd_soc_pcm_runtime *rtd) ...@@ -71,9 +71,9 @@ static int cz_init(struct snd_soc_pcm_runtime *rtd)
{ {
int ret; int ret;
struct snd_soc_card *card; struct snd_soc_card *card;
struct snd_soc_codec *codec; struct snd_soc_component *codec;
codec = rtd->codec; codec = rtd->codec_dai->component;
card = rtd->card; card = rtd->card;
ret = snd_soc_card_jack_new(card, "Headset Jack", ret = snd_soc_card_jack_new(card, "Headset Jack",
......
This diff is collapsed.
...@@ -2200,10 +2200,10 @@ enum { ...@@ -2200,10 +2200,10 @@ enum {
RT5645_AD_MONO_R_FILTER = (0x1 << 5), RT5645_AD_MONO_R_FILTER = (0x1 << 5),
}; };
int rt5645_sel_asrc_clk_src(struct snd_soc_codec *codec, int rt5645_sel_asrc_clk_src(struct snd_soc_component *component,
unsigned int filter_mask, unsigned int clk_src); unsigned int filter_mask, unsigned int clk_src);
int rt5645_set_jack_detect(struct snd_soc_codec *codec, int rt5645_set_jack_detect(struct snd_soc_component *component,
struct snd_soc_jack *hp_jack, struct snd_soc_jack *mic_jack, struct snd_soc_jack *hp_jack, struct snd_soc_jack *mic_jack,
struct snd_soc_jack *btn_jack); struct snd_soc_jack *btn_jack);
#endif /* __RT5645_H__ */ #endif /* __RT5645_H__ */
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
#ifndef __RT5651_H__ #ifndef __RT5651_H__
#define __RT5651_H__ #define __RT5651_H__
#include <sound/rt5651.h> #include <dt-bindings/sound/rt5651.h>
/* Info */ /* Info */
#define RT5651_RESET 0x00 #define RT5651_RESET 0x00
...@@ -2073,7 +2073,7 @@ struct rt5651_priv { ...@@ -2073,7 +2073,7 @@ struct rt5651_priv {
struct regmap *regmap; struct regmap *regmap;
struct snd_soc_jack *hp_jack; struct snd_soc_jack *hp_jack;
struct work_struct jack_detect_work; struct work_struct jack_detect_work;
enum rt5651_jd_src jd_src; unsigned int jd_src;
unsigned int ovcd_th; unsigned int ovcd_th;
unsigned int ovcd_sf; unsigned int ovcd_sf;
......
This diff is collapsed.
...@@ -1743,10 +1743,14 @@ ...@@ -1743,10 +1743,14 @@
#define RT5659_CKGEN_DAC2_SFT 4 #define RT5659_CKGEN_DAC2_SFT 4
/* Chopper and Clock control for ADC (0x013b)*/ /* Chopper and Clock control for ADC (0x013b)*/
#define RT5659_CKXEN_ADCC_MASK (0x1 << 13) #define RT5659_CKXEN_ADC1_MASK (0x1 << 13)
#define RT5659_CKXEN_ADCC_SFT 13 #define RT5659_CKXEN_ADC1_SFT 13
#define RT5659_CKGEN_ADCC_MASK (0x1 << 12) #define RT5659_CKGEN_ADC1_MASK (0x1 << 12)
#define RT5659_CKGEN_ADCC_SFT 12 #define RT5659_CKGEN_ADC1_SFT 12
#define RT5659_CKXEN_ADC2_MASK (0x1 << 5)
#define RT5659_CKXEN_ADC2_SFT 5
#define RT5659_CKGEN_ADC2_MASK (0x1 << 4)
#define RT5659_CKGEN_ADC2_SFT 4
/* Test Mode Control 1 (0x0145) */ /* Test Mode Control 1 (0x0145) */
#define RT5659_AD2DA_LB_MASK (0x1 << 9) #define RT5659_AD2DA_LB_MASK (0x1 << 9)
...@@ -1789,7 +1793,7 @@ struct rt5659_pll_code { ...@@ -1789,7 +1793,7 @@ struct rt5659_pll_code {
}; };
struct rt5659_priv { struct rt5659_priv {
struct snd_soc_codec *codec; struct snd_soc_component *component;
struct rt5659_platform_data pdata; struct rt5659_platform_data pdata;
struct regmap *regmap; struct regmap *regmap;
struct gpio_desc *gpiod_ldo1_en; struct gpio_desc *gpiod_ldo1_en;
...@@ -1810,10 +1814,11 @@ struct rt5659_priv { ...@@ -1810,10 +1814,11 @@ struct rt5659_priv {
int pll_out; int pll_out;
int jack_type; int jack_type;
bool hda_hp_plugged;
bool hda_mic_plugged;
}; };
int rt5659_set_jack_detect(struct snd_soc_codec *codec, int rt5659_set_jack_detect(struct snd_soc_component *component,
struct snd_soc_jack *hs_jack); struct snd_soc_jack *hs_jack);
#endif /* __RT5659_H__ */ #endif /* __RT5659_H__ */
This diff is collapsed.
...@@ -831,7 +831,7 @@ enum { ...@@ -831,7 +831,7 @@ enum {
}; };
struct rt5660_priv { struct rt5660_priv {
struct snd_soc_codec *codec; struct snd_soc_component *component;
struct rt5660_platform_data pdata; struct rt5660_platform_data pdata;
struct regmap *regmap; struct regmap *regmap;
struct clk *mclk; struct clk *mclk;
......
This diff is collapsed.
...@@ -1790,7 +1790,7 @@ struct rt5677_platform_data { ...@@ -1790,7 +1790,7 @@ struct rt5677_platform_data {
}; };
struct rt5677_priv { struct rt5677_priv {
struct snd_soc_codec *codec; struct snd_soc_component *component;
struct rt5677_platform_data pdata; struct rt5677_platform_data pdata;
struct regmap *regmap, *regmap_physical; struct regmap *regmap, *regmap_physical;
const struct firmware *fw1, *fw2; const struct firmware *fw1, *fw2;
...@@ -1816,7 +1816,7 @@ struct rt5677_priv { ...@@ -1816,7 +1816,7 @@ struct rt5677_priv {
bool is_vref_slow; bool is_vref_slow;
}; };
int rt5677_sel_asrc_clk_src(struct snd_soc_codec *codec, int rt5677_sel_asrc_clk_src(struct snd_soc_component *component,
unsigned int filter_mask, unsigned int clk_src); unsigned int filter_mask, unsigned int clk_src);
#endif /* __RT5677_H__ */ #endif /* __RT5677_H__ */
...@@ -34,7 +34,7 @@ ...@@ -34,7 +34,7 @@
struct bdw_rt5677_priv { struct bdw_rt5677_priv {
struct gpio_desc *gpio_hp_en; struct gpio_desc *gpio_hp_en;
struct snd_soc_codec *codec; struct snd_soc_component *component;
}; };
static int bdw_rt5677_event_hp(struct snd_soc_dapm_widget *w, static int bdw_rt5677_event_hp(struct snd_soc_dapm_widget *w,
...@@ -204,26 +204,26 @@ static int bdw_rt5677_init(struct snd_soc_pcm_runtime *rtd) ...@@ -204,26 +204,26 @@ static int bdw_rt5677_init(struct snd_soc_pcm_runtime *rtd)
{ {
struct bdw_rt5677_priv *bdw_rt5677 = struct bdw_rt5677_priv *bdw_rt5677 =
snd_soc_card_get_drvdata(rtd->card); snd_soc_card_get_drvdata(rtd->card);
struct snd_soc_codec *codec = rtd->codec; struct snd_soc_component *component = rtd->codec_dai->component;
struct snd_soc_dapm_context *dapm = snd_soc_codec_get_dapm(codec); struct snd_soc_dapm_context *dapm = snd_soc_component_get_dapm(component);
int ret; int ret;
ret = devm_acpi_dev_add_driver_gpios(codec->dev, bdw_rt5677_gpios); ret = devm_acpi_dev_add_driver_gpios(component->dev, bdw_rt5677_gpios);
if (ret) if (ret)
dev_warn(codec->dev, "Failed to add driver gpios\n"); dev_warn(component->dev, "Failed to add driver gpios\n");
/* Enable codec ASRC function for Stereo DAC/Stereo1 ADC/DMIC/I2S1. /* Enable codec ASRC function for Stereo DAC/Stereo1 ADC/DMIC/I2S1.
* The ASRC clock source is clk_i2s1_asrc. * The ASRC clock source is clk_i2s1_asrc.
*/ */
rt5677_sel_asrc_clk_src(codec, RT5677_DA_STEREO_FILTER | rt5677_sel_asrc_clk_src(component, RT5677_DA_STEREO_FILTER |
RT5677_AD_STEREO1_FILTER | RT5677_I2S1_SOURCE, RT5677_AD_STEREO1_FILTER | RT5677_I2S1_SOURCE,
RT5677_CLK_SEL_I2S1_ASRC); RT5677_CLK_SEL_I2S1_ASRC);
/* Request rt5677 GPIO for headphone amp control */ /* Request rt5677 GPIO for headphone amp control */
bdw_rt5677->gpio_hp_en = devm_gpiod_get(codec->dev, "headphone-enable", bdw_rt5677->gpio_hp_en = devm_gpiod_get(component->dev, "headphone-enable",
GPIOD_OUT_LOW); GPIOD_OUT_LOW);
if (IS_ERR(bdw_rt5677->gpio_hp_en)) { if (IS_ERR(bdw_rt5677->gpio_hp_en)) {
dev_err(codec->dev, "Can't find HP_AMP_SHDN_L gpio\n"); dev_err(component->dev, "Can't find HP_AMP_SHDN_L gpio\n");
return PTR_ERR(bdw_rt5677->gpio_hp_en); return PTR_ERR(bdw_rt5677->gpio_hp_en);
} }
...@@ -231,25 +231,25 @@ static int bdw_rt5677_init(struct snd_soc_pcm_runtime *rtd) ...@@ -231,25 +231,25 @@ static int bdw_rt5677_init(struct snd_soc_pcm_runtime *rtd)
if (!snd_soc_card_jack_new(rtd->card, "Headphone Jack", if (!snd_soc_card_jack_new(rtd->card, "Headphone Jack",
SND_JACK_HEADPHONE, &headphone_jack, SND_JACK_HEADPHONE, &headphone_jack,
&headphone_jack_pin, 1)) { &headphone_jack_pin, 1)) {
headphone_jack_gpio.gpiod_dev = codec->dev; headphone_jack_gpio.gpiod_dev = component->dev;
if (snd_soc_jack_add_gpios(&headphone_jack, 1, if (snd_soc_jack_add_gpios(&headphone_jack, 1,
&headphone_jack_gpio)) &headphone_jack_gpio))
dev_err(codec->dev, "Can't add headphone jack gpio\n"); dev_err(component->dev, "Can't add headphone jack gpio\n");
} else { } else {
dev_err(codec->dev, "Can't create headphone jack\n"); dev_err(component->dev, "Can't create headphone jack\n");
} }
/* Create and initialize mic jack */ /* Create and initialize mic jack */
if (!snd_soc_card_jack_new(rtd->card, "Mic Jack", if (!snd_soc_card_jack_new(rtd->card, "Mic Jack",
SND_JACK_MICROPHONE, &mic_jack, SND_JACK_MICROPHONE, &mic_jack,
&mic_jack_pin, 1)) { &mic_jack_pin, 1)) {
mic_jack_gpio.gpiod_dev = codec->dev; mic_jack_gpio.gpiod_dev = component->dev;
if (snd_soc_jack_add_gpios(&mic_jack, 1, &mic_jack_gpio)) if (snd_soc_jack_add_gpios(&mic_jack, 1, &mic_jack_gpio))
dev_err(codec->dev, "Can't add mic jack gpio\n"); dev_err(component->dev, "Can't add mic jack gpio\n");
} else { } else {
dev_err(codec->dev, "Can't create mic jack\n"); dev_err(component->dev, "Can't create mic jack\n");
} }
bdw_rt5677->codec = codec; bdw_rt5677->component = component;
snd_soc_dapm_force_enable_pin(dapm, "MICBIAS1"); snd_soc_dapm_force_enable_pin(dapm, "MICBIAS1");
return 0; return 0;
...@@ -302,8 +302,8 @@ static int bdw_rt5677_suspend_pre(struct snd_soc_card *card) ...@@ -302,8 +302,8 @@ static int bdw_rt5677_suspend_pre(struct snd_soc_card *card)
struct bdw_rt5677_priv *bdw_rt5677 = snd_soc_card_get_drvdata(card); struct bdw_rt5677_priv *bdw_rt5677 = snd_soc_card_get_drvdata(card);
struct snd_soc_dapm_context *dapm; struct snd_soc_dapm_context *dapm;
if (bdw_rt5677->codec) { if (bdw_rt5677->component) {
dapm = snd_soc_codec_get_dapm(bdw_rt5677->codec); dapm = snd_soc_component_get_dapm(bdw_rt5677->component);
snd_soc_dapm_disable_pin(dapm, "MICBIAS1"); snd_soc_dapm_disable_pin(dapm, "MICBIAS1");
} }
return 0; return 0;
...@@ -314,8 +314,8 @@ static int bdw_rt5677_resume_post(struct snd_soc_card *card) ...@@ -314,8 +314,8 @@ static int bdw_rt5677_resume_post(struct snd_soc_card *card)
struct bdw_rt5677_priv *bdw_rt5677 = snd_soc_card_get_drvdata(card); struct bdw_rt5677_priv *bdw_rt5677 = snd_soc_card_get_drvdata(card);
struct snd_soc_dapm_context *dapm; struct snd_soc_dapm_context *dapm;
if (bdw_rt5677->codec) { if (bdw_rt5677->component) {
dapm = snd_soc_codec_get_dapm(bdw_rt5677->codec); dapm = snd_soc_component_get_dapm(bdw_rt5677->component);
snd_soc_dapm_force_enable_pin(dapm, "MICBIAS1"); snd_soc_dapm_force_enable_pin(dapm, "MICBIAS1");
} }
return 0; return 0;
......
...@@ -252,14 +252,14 @@ static int cht_codec_init(struct snd_soc_pcm_runtime *runtime) ...@@ -252,14 +252,14 @@ static int cht_codec_init(struct snd_soc_pcm_runtime *runtime)
{ {
struct snd_soc_card *card = runtime->card; struct snd_soc_card *card = runtime->card;
struct cht_mc_private *ctx = snd_soc_card_get_drvdata(runtime->card); struct cht_mc_private *ctx = snd_soc_card_get_drvdata(runtime->card);
struct snd_soc_codec *codec = runtime->codec; struct snd_soc_component *component = runtime->codec_dai->component;
int jack_type; int jack_type;
int ret; int ret;
if ((cht_rt5645_quirk & CHT_RT5645_SSP2_AIF2) || if ((cht_rt5645_quirk & CHT_RT5645_SSP2_AIF2) ||
(cht_rt5645_quirk & CHT_RT5645_SSP0_AIF2)) { (cht_rt5645_quirk & CHT_RT5645_SSP0_AIF2)) {
/* Select clk_i2s2_asrc as ASRC clock source */ /* Select clk_i2s2_asrc as ASRC clock source */
rt5645_sel_asrc_clk_src(codec, rt5645_sel_asrc_clk_src(component,
RT5645_DA_STEREO_FILTER | RT5645_DA_STEREO_FILTER |
RT5645_DA_MONO_L_FILTER | RT5645_DA_MONO_L_FILTER |
RT5645_DA_MONO_R_FILTER | RT5645_DA_MONO_R_FILTER |
...@@ -267,7 +267,7 @@ static int cht_codec_init(struct snd_soc_pcm_runtime *runtime) ...@@ -267,7 +267,7 @@ static int cht_codec_init(struct snd_soc_pcm_runtime *runtime)
RT5645_CLK_SEL_I2S2_ASRC); RT5645_CLK_SEL_I2S2_ASRC);
} else { } else {
/* Select clk_i2s1_asrc as ASRC clock source */ /* Select clk_i2s1_asrc as ASRC clock source */
rt5645_sel_asrc_clk_src(codec, rt5645_sel_asrc_clk_src(component,
RT5645_DA_STEREO_FILTER | RT5645_DA_STEREO_FILTER |
RT5645_DA_MONO_L_FILTER | RT5645_DA_MONO_L_FILTER |
RT5645_DA_MONO_R_FILTER | RT5645_DA_MONO_R_FILTER |
...@@ -310,7 +310,7 @@ static int cht_codec_init(struct snd_soc_pcm_runtime *runtime) ...@@ -310,7 +310,7 @@ static int cht_codec_init(struct snd_soc_pcm_runtime *runtime)
return ret; return ret;
} }
rt5645_set_jack_detect(codec, &ctx->jack, &ctx->jack, &ctx->jack); rt5645_set_jack_detect(component, &ctx->jack, &ctx->jack, &ctx->jack);
/* /*
......
...@@ -82,10 +82,10 @@ static struct snd_soc_jack mt8173_rt5650_rt5514_jack; ...@@ -82,10 +82,10 @@ static struct snd_soc_jack mt8173_rt5650_rt5514_jack;
static int mt8173_rt5650_rt5514_init(struct snd_soc_pcm_runtime *runtime) static int mt8173_rt5650_rt5514_init(struct snd_soc_pcm_runtime *runtime)
{ {
struct snd_soc_card *card = runtime->card; struct snd_soc_card *card = runtime->card;
struct snd_soc_codec *codec = runtime->codec_dais[0]->codec; struct snd_soc_component *component = runtime->codec_dais[0]->component;
int ret; int ret;
rt5645_sel_asrc_clk_src(codec, rt5645_sel_asrc_clk_src(component,
RT5645_DA_STEREO_FILTER | RT5645_DA_STEREO_FILTER |
RT5645_AD_STEREO_FILTER, RT5645_AD_STEREO_FILTER,
RT5645_CLK_SEL_I2S1_ASRC); RT5645_CLK_SEL_I2S1_ASRC);
...@@ -101,7 +101,7 @@ static int mt8173_rt5650_rt5514_init(struct snd_soc_pcm_runtime *runtime) ...@@ -101,7 +101,7 @@ static int mt8173_rt5650_rt5514_init(struct snd_soc_pcm_runtime *runtime)
return ret; return ret;
} }
return rt5645_set_jack_detect(codec, return rt5645_set_jack_detect(component,
&mt8173_rt5650_rt5514_jack, &mt8173_rt5650_rt5514_jack,
&mt8173_rt5650_rt5514_jack, &mt8173_rt5650_rt5514_jack,
&mt8173_rt5650_rt5514_jack); &mt8173_rt5650_rt5514_jack);
......
...@@ -86,19 +86,19 @@ static struct snd_soc_jack mt8173_rt5650_rt5676_jack; ...@@ -86,19 +86,19 @@ static struct snd_soc_jack mt8173_rt5650_rt5676_jack;
static int mt8173_rt5650_rt5676_init(struct snd_soc_pcm_runtime *runtime) static int mt8173_rt5650_rt5676_init(struct snd_soc_pcm_runtime *runtime)
{ {
struct snd_soc_card *card = runtime->card; struct snd_soc_card *card = runtime->card;
struct snd_soc_codec *codec = runtime->codec_dais[0]->codec; struct snd_soc_component *component = runtime->codec_dais[0]->component;
struct snd_soc_codec *codec_sub = runtime->codec_dais[1]->codec; struct snd_soc_component *component_sub = runtime->codec_dais[1]->component;
int ret; int ret;
rt5645_sel_asrc_clk_src(codec, rt5645_sel_asrc_clk_src(component,
RT5645_DA_STEREO_FILTER | RT5645_DA_STEREO_FILTER |
RT5645_AD_STEREO_FILTER, RT5645_AD_STEREO_FILTER,
RT5645_CLK_SEL_I2S1_ASRC); RT5645_CLK_SEL_I2S1_ASRC);
rt5677_sel_asrc_clk_src(codec_sub, rt5677_sel_asrc_clk_src(component_sub,
RT5677_DA_STEREO_FILTER | RT5677_DA_STEREO_FILTER |
RT5677_AD_STEREO1_FILTER, RT5677_AD_STEREO1_FILTER,
RT5677_CLK_SEL_I2S1_ASRC); RT5677_CLK_SEL_I2S1_ASRC);
rt5677_sel_asrc_clk_src(codec_sub, rt5677_sel_asrc_clk_src(component_sub,
RT5677_AD_STEREO2_FILTER | RT5677_AD_STEREO2_FILTER |
RT5677_I2S2_SOURCE, RT5677_I2S2_SOURCE,
RT5677_CLK_SEL_I2S2_ASRC); RT5677_CLK_SEL_I2S2_ASRC);
...@@ -114,7 +114,7 @@ static int mt8173_rt5650_rt5676_init(struct snd_soc_pcm_runtime *runtime) ...@@ -114,7 +114,7 @@ static int mt8173_rt5650_rt5676_init(struct snd_soc_pcm_runtime *runtime)
return ret; return ret;
} }
return rt5645_set_jack_detect(codec, return rt5645_set_jack_detect(component,
&mt8173_rt5650_rt5676_jack, &mt8173_rt5650_rt5676_jack,
&mt8173_rt5650_rt5676_jack, &mt8173_rt5650_rt5676_jack,
&mt8173_rt5650_rt5676_jack); &mt8173_rt5650_rt5676_jack);
......
...@@ -112,26 +112,26 @@ static struct snd_soc_jack mt8173_rt5650_jack; ...@@ -112,26 +112,26 @@ static struct snd_soc_jack mt8173_rt5650_jack;
static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime) static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime)
{ {
struct snd_soc_card *card = runtime->card; struct snd_soc_card *card = runtime->card;
struct snd_soc_codec *codec = runtime->codec_dais[0]->codec; struct snd_soc_component *component = runtime->codec_dais[0]->component;
const char *codec_capture_dai = runtime->codec_dais[1]->name; const char *codec_capture_dai = runtime->codec_dais[1]->name;
int ret; int ret;
rt5645_sel_asrc_clk_src(codec, rt5645_sel_asrc_clk_src(component,
RT5645_DA_STEREO_FILTER, RT5645_DA_STEREO_FILTER,
RT5645_CLK_SEL_I2S1_ASRC); RT5645_CLK_SEL_I2S1_ASRC);
if (!strcmp(codec_capture_dai, "rt5645-aif1")) { if (!strcmp(codec_capture_dai, "rt5645-aif1")) {
rt5645_sel_asrc_clk_src(codec, rt5645_sel_asrc_clk_src(component,
RT5645_AD_STEREO_FILTER, RT5645_AD_STEREO_FILTER,
RT5645_CLK_SEL_I2S1_ASRC); RT5645_CLK_SEL_I2S1_ASRC);
} else if (!strcmp(codec_capture_dai, "rt5645-aif2")) { } else if (!strcmp(codec_capture_dai, "rt5645-aif2")) {
rt5645_sel_asrc_clk_src(codec, rt5645_sel_asrc_clk_src(component,
RT5645_AD_STEREO_FILTER, RT5645_AD_STEREO_FILTER,
RT5645_CLK_SEL_I2S2_ASRC); RT5645_CLK_SEL_I2S2_ASRC);
} else { } else {
dev_warn(card->dev, dev_warn(card->dev,
"Only one dai codec found in DTS, enabled rt5645 AD filter\n"); "Only one dai codec found in DTS, enabled rt5645 AD filter\n");
rt5645_sel_asrc_clk_src(codec, rt5645_sel_asrc_clk_src(component,
RT5645_AD_STEREO_FILTER, RT5645_AD_STEREO_FILTER,
RT5645_CLK_SEL_I2S1_ASRC); RT5645_CLK_SEL_I2S1_ASRC);
} }
...@@ -147,7 +147,7 @@ static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime) ...@@ -147,7 +147,7 @@ static int mt8173_rt5650_init(struct snd_soc_pcm_runtime *runtime)
return ret; return ret;
} }
return rt5645_set_jack_detect(codec, return rt5645_set_jack_detect(component,
&mt8173_rt5650_jack, &mt8173_rt5650_jack,
&mt8173_rt5650_jack, &mt8173_rt5650_jack,
&mt8173_rt5650_jack); &mt8173_rt5650_jack);
......
...@@ -29,16 +29,12 @@ ...@@ -29,16 +29,12 @@
#include <sound/pcm_params.h> #include <sound/pcm_params.h>
#include <sound/soc.h> #include <sound/soc.h>
#include "rockchip_i2s.h" #include "rockchip_i2s.h"
#include "../codecs/rt5645.h"
#define DRV_NAME "rockchip-snd-rt5645" #define DRV_NAME "rockchip-snd-rt5645"
static struct snd_soc_jack headset_jack; static struct snd_soc_jack headset_jack;
/* Jack detect via rt5645 driver. */
extern int rt5645_set_jack_detect(struct snd_soc_codec *codec,
struct snd_soc_jack *hp_jack, struct snd_soc_jack *mic_jack,
struct snd_soc_jack *btn_jack);
static const struct snd_soc_dapm_widget rk_dapm_widgets[] = { static const struct snd_soc_dapm_widget rk_dapm_widgets[] = {
SND_SOC_DAPM_HP("Headphones", NULL), SND_SOC_DAPM_HP("Headphones", NULL),
SND_SOC_DAPM_SPK("Speakers", NULL), SND_SOC_DAPM_SPK("Speakers", NULL),
...@@ -129,7 +125,7 @@ static int rk_init(struct snd_soc_pcm_runtime *runtime) ...@@ -129,7 +125,7 @@ static int rk_init(struct snd_soc_pcm_runtime *runtime)
return ret; return ret;
} }
return rt5645_set_jack_detect(runtime->codec, return rt5645_set_jack_detect(runtime->codec_dai->component,
&headset_jack, &headset_jack,
&headset_jack, &headset_jack,
&headset_jack); &headset_jack);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment