summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorScottPeterson <speterson@nvidia.com>2012-12-10 08:27:37 -0800
committerRohan Somvanshi <rsomvanshi@nvidia.com>2012-12-19 00:00:39 -0800
commit8c53a45e1d82657720211b121d5f1221911d6654 (patch)
tree639e25c703b15dc187cfb6dcb5a5eaed1799535e
parent8a177f4e46518a635c26512d84f3e27f6de2c0ce (diff)
tegra: kernel: voice call debug
Changed KB_ROW7 gpio to PULL_UP for better headset detection. Added vdd_sys_audio regulator for speaker amp Debugging voice call UL/DL loss during stress testing. Change-Id: Ib1930ff693306621aef269f0e0ff27aee2ab450f Signed-off-by: ScottPeterson <speterson@nvidia.com> Reviewed-on: http://git-master/r/171212
-rw-r--r--arch/arm/mach-tegra/board-pluto-pinmux-t11x.h7
-rw-r--r--arch/arm/mach-tegra/board-pluto-pinmux.c2
-rw-r--r--arch/arm/mach-tegra/board-pluto-power.c1
-rw-r--r--arch/arm/mach-tegra/board-pluto.h2
-rw-r--r--sound/soc/tegra/tegra30_dam.c8
-rw-r--r--sound/soc/tegra/tegra30_i2s.c36
-rw-r--r--sound/soc/tegra/tegra30_i2s.h2
-rw-r--r--sound/soc/tegra/tegra_cs42l73.c27
8 files changed, 66 insertions, 19 deletions
diff --git a/arch/arm/mach-tegra/board-pluto-pinmux-t11x.h b/arch/arm/mach-tegra/board-pluto-pinmux-t11x.h
index eedf7f71db8d..4c593223e184 100644
--- a/arch/arm/mach-tegra/board-pluto-pinmux-t11x.h
+++ b/arch/arm/mach-tegra/board-pluto-pinmux-t11x.h
@@ -49,7 +49,7 @@ static __initdata struct tegra_pingroup_config pluto_pinmux_common[] = {
DEFAULT_PINMUX(ULPI_DIR, ULPI, NORMAL, TRISTATE, INPUT),
DEFAULT_PINMUX(ULPI_NXT, ULPI, NORMAL, TRISTATE, INPUT),
DEFAULT_PINMUX(ULPI_STP, ULPI, NORMAL, NORMAL, OUTPUT),
- DEFAULT_PINMUX(KB_ROW7, KBC, PULL_DOWN, NORMAL, INPUT),
+ DEFAULT_PINMUX(KB_ROW7, KBC, PULL_UP, NORMAL, INPUT),
DEFAULT_PINMUX(GMI_A16, UARTD, NORMAL, NORMAL, OUTPUT),
DEFAULT_PINMUX(GMI_A17, UARTD, NORMAL, NORMAL, INPUT),
DEFAULT_PINMUX(GMI_A18, UARTD, NORMAL, NORMAL, INPUT),
@@ -213,6 +213,9 @@ static __initdata struct tegra_pingroup_config pluto_pinmux_common[] = {
I2C_PINMUX(DDC_SCL, I2C4, NORMAL, NORMAL, INPUT, DEFAULT, DEFAULT),
I2C_PINMUX(DDC_SDA, I2C4, NORMAL, NORMAL, INPUT, DEFAULT, DEFAULT),
+ /* USB pinmux */
+ DEFAULT_PINMUX(USB_VBUS_EN0, RSVD3, PULL_DOWN, NORMAL, OUTPUT),
+
/* nct */
DEFAULT_PINMUX(GPIO_X6_AUD, SPI6, PULL_UP, TRISTATE, INPUT),
@@ -286,5 +289,5 @@ static struct gpio_init_pin_info init_gpio_mode_pluto_common[] = {
GPIO_INIT_PIN_MODE(TEGRA_GPIO_PU6, true, 0),
GPIO_INIT_PIN_MODE(TEGRA_GPIO_PN7, true, 0),
GPIO_INIT_PIN_MODE(TEGRA_GPIO_PK5, false, 0),
- GPIO_INIT_PIN_MODE(TEGRA_GPIO_PN4, false, 0),
+ GPIO_INIT_PIN_MODE(TEGRA_GPIO_PN4, false, 1),
};
diff --git a/arch/arm/mach-tegra/board-pluto-pinmux.c b/arch/arm/mach-tegra/board-pluto-pinmux.c
index 07a05a51fe0d..7f4c41d1048b 100644
--- a/arch/arm/mach-tegra/board-pluto-pinmux.c
+++ b/arch/arm/mach-tegra/board-pluto-pinmux.c
@@ -227,7 +227,7 @@ static __initdata struct tegra_pingroup_config pluto_pinmux_set_nontristate[] =
DEFAULT_PINMUX(KB_ROW4, KBC, PULL_DOWN, NORMAL, INPUT),
DEFAULT_PINMUX(KB_ROW5, KBC, PULL_DOWN, NORMAL, OUTPUT),
DEFAULT_PINMUX(KB_ROW6, KBC, PULL_DOWN, NORMAL, OUTPUT),
- DEFAULT_PINMUX(KB_ROW7, KBC, PULL_DOWN, NORMAL, INPUT),
+ DEFAULT_PINMUX(KB_ROW7, KBC, PULL_UP, NORMAL, INPUT),
DEFAULT_PINMUX(KB_ROW8, KBC, PULL_DOWN, NORMAL, INPUT),
DEFAULT_PINMUX(CLK3_REQ, RSVD3, NORMAL, NORMAL, OUTPUT),
diff --git a/arch/arm/mach-tegra/board-pluto-power.c b/arch/arm/mach-tegra/board-pluto-power.c
index 065fd520b79d..a29fc813cfc8 100644
--- a/arch/arm/mach-tegra/board-pluto-power.c
+++ b/arch/arm/mach-tegra/board-pluto-power.c
@@ -373,6 +373,7 @@ static struct regulator_consumer_supply fixed_reg_en_battery_supply[] = {
REGULATOR_SUPPLY("vdd_sys_com", NULL),
REGULATOR_SUPPLY("vdd_sys_gps", NULL),
REGULATOR_SUPPLY("vdd_sys_bt", NULL),
+ REGULATOR_SUPPLY("vdd_sys_audio", NULL),
};
static struct regulator_consumer_supply fixed_reg_en_vdd_1v8_cam_supply[] = {
diff --git a/arch/arm/mach-tegra/board-pluto.h b/arch/arm/mach-tegra/board-pluto.h
index 7e5b9d00493a..7af8cbb1a838 100644
--- a/arch/arm/mach-tegra/board-pluto.h
+++ b/arch/arm/mach-tegra/board-pluto.h
@@ -32,7 +32,7 @@
/* Audio-related GPIOs */
#define TEGRA_GPIO_CDC_IRQ TEGRA_GPIO_PW3
#define TEGRA_GPIO_LDO1_EN TEGRA_GPIO_PV3
-#define TEGRA_GPIO_SPKR_EN -1
+#define TEGRA_GPIO_SPKR_EN TEGRA_GPIO_PN4
#define TEGRA_GPIO_HP_DET TEGRA_GPIO_PR7
#define TEGRA_GPIO_INT_MIC_EN -1
#define TEGRA_GPIO_EXT_MIC_EN -1
diff --git a/sound/soc/tegra/tegra30_dam.c b/sound/soc/tegra/tegra30_dam.c
index f4f2d69a0337..e2511edf219e 100644
--- a/sound/soc/tegra/tegra30_dam.c
+++ b/sound/soc/tegra/tegra30_dam.c
@@ -45,7 +45,6 @@ enum {
dam_ch_maxnum
} tegra30_dam_chtype;
-#ifdef CONFIG_ARCH_TEGRA_3x_SOC
struct tegra30_dam_src_step_table step_table[] = {
{ 8000, 44100, 80 },
{ 8000, 48000, 1 },
@@ -56,7 +55,6 @@ struct tegra30_dam_src_step_table step_table[] = {
{ 44100, 16000, 441 },
{ 48000, 16000, 0 },
};
-#endif
#ifndef CONFIG_ARCH_TEGRA_3x_SOC
int coefRam16To44[64] = {
@@ -317,11 +315,9 @@ static void tegra30_dam_set_output_samplerate(struct tegra30_dam_context *dam,
int fsout);
static void tegra30_dam_set_input_samplerate(struct tegra30_dam_context *dam,
int fsin);
-#ifdef CONFIG_ARCH_TEGRA_3x_SOC
static int tegra30_dam_set_step_reset(struct tegra30_dam_context *dam,
int insample, int outsample);
static void tegra30_dam_ch0_set_step(struct tegra30_dam_context *dam, int step);
-#endif
static inline void tegra30_dam_writel(struct tegra30_dam_context *dam,
u32 val, u32 reg)
@@ -549,9 +545,7 @@ void tegra30_dam_set_samplerate(int ifc, int chid, int samplerate)
case dam_ch_in0:
tegra30_dam_set_input_samplerate(dam, samplerate);
dam->ch_insamplerate[dam_ch_in0] = samplerate;
-#ifdef CONFIG_ARCH_TEGRA_3x_SOC
tegra30_dam_set_step_reset(dam, samplerate, dam->outsamplerate);
-#endif
break;
case dam_ch_in1:
if (samplerate != dam->outsamplerate)
@@ -622,7 +616,6 @@ void tegra30_dam_set_input_samplerate(struct tegra30_dam_context *dam, int fsin)
tegra30_dam_writel(dam, val, TEGRA30_DAM_CH0_CTRL);
}
-#ifdef CONFIG_ARCH_TEGRA_3x_SOC
int tegra30_dam_set_step_reset(struct tegra30_dam_context *dam,
int insample, int outsample)
{
@@ -649,7 +642,6 @@ void tegra30_dam_ch0_set_step(struct tegra30_dam_context *dam, int step)
val |= step << TEGRA30_DAM_CH0_CTRL_STEP_SHIFT;
tegra30_dam_writel(dam, val, TEGRA30_DAM_CH0_CTRL);
}
-#endif
int tegra30_dam_set_gain(int ifc, int chid, int gain)
{
diff --git a/sound/soc/tegra/tegra30_i2s.c b/sound/soc/tegra/tegra30_i2s.c
index cf11d9e861a8..ab8e220f6d25 100644
--- a/sound/soc/tegra/tegra30_i2s.c
+++ b/sound/soc/tegra/tegra30_i2s.c
@@ -1140,6 +1140,7 @@ int tegra30_make_voice_call_connections(struct codec_config *codec_info,
{
struct tegra30_i2s *codec_i2s;
struct tegra30_i2s *bb_i2s;
+ int reg;
codec_i2s = &i2scont[codec_info->i2s_id];
bb_i2s = &i2scont[bb_info->i2s_id];
@@ -1150,6 +1151,27 @@ int tegra30_make_voice_call_connections(struct codec_config *codec_info,
codec_i2s->capture_ref_count++;
bb_i2s->capture_ref_count++;
+ /* Make sure i2s is disabled during the configiration */
+ tegra30_i2s_enable_clocks(codec_i2s);
+ reg = codec_i2s->reg_ctrl;
+ reg &= ~TEGRA30_I2S_CTRL_TX_FLOWCTL_EN;
+ reg &= ~TEGRA30_I2S_CTRL_XFER_EN_TX;
+ reg &= ~TEGRA30_I2S_CTRL_XFER_EN_RX;
+ tegra30_i2s_write(codec_i2s, TEGRA30_I2S_CTRL,
+ codec_i2s->reg_ctrl);
+ tegra30_i2s_disable_clocks(codec_i2s);
+
+ tegra30_i2s_enable_clocks(bb_i2s);
+ reg = bb_i2s->reg_ctrl;
+ reg &= ~TEGRA30_I2S_CTRL_TX_FLOWCTL_EN;
+ reg &= ~TEGRA30_I2S_CTRL_XFER_EN_TX;
+ reg &= ~TEGRA30_I2S_CTRL_XFER_EN_RX;
+ tegra30_i2s_write(bb_i2s, TEGRA30_I2S_CTRL,
+ bb_i2s->reg_ctrl);
+ tegra30_i2s_disable_clocks(bb_i2s);
+
+ msleep(20);
+
/*Configure codec i2s*/
configure_baseband_i2s(codec_i2s, codec_info->is_i2smaster,
codec_info->is_format_dsp, codec_info->channels,
@@ -1171,6 +1193,16 @@ int tegra30_make_voice_call_connections(struct codec_config *codec_info,
tegra30_ahub_set_rx_cif_source(TEGRA30_AHUB_RXCIF_I2S0_RX0 +
codec_info->i2s_id, TEGRA30_AHUB_TXCIF_I2S0_TX0 +
bb_info->i2s_id);
+ if (!(codec_info->is_i2smaster && bb_info->is_i2smaster)) {
+ tegra30_i2s_write(codec_i2s, TEGRA30_I2S_FLOWCTL,
+ TEGRA30_I2S_FILTER_QUAD);
+ tegra30_i2s_write(bb_i2s, TEGRA30_I2S_FLOWCTL,
+ TEGRA30_I2S_FILTER_QUAD);
+ tegra30_i2s_write(codec_i2s, TEGRA30_I2S_TX_STEP, 4);
+ tegra30_i2s_write(bb_i2s, TEGRA30_I2S_TX_STEP, 4);
+ codec_i2s->reg_ctrl |= TEGRA30_I2S_CTRL_TX_FLOWCTL_EN;
+ bb_i2s->reg_ctrl |= TEGRA30_I2S_CTRL_TX_FLOWCTL_EN;
+ }
} else {
/*configure codec dam*/
@@ -1209,11 +1241,15 @@ int tegra30_make_voice_call_connections(struct codec_config *codec_info,
TEGRA30_DAM_CHIN0_SRC);
}
+ msleep(20);
+
codec_i2s->reg_ctrl |= TEGRA30_I2S_CTRL_XFER_EN_TX;
codec_i2s->reg_ctrl |= TEGRA30_I2S_CTRL_XFER_EN_RX;
tegra30_i2s_write(codec_i2s, TEGRA30_I2S_CTRL,
codec_i2s->reg_ctrl);
+ msleep(20);
+
bb_i2s->reg_ctrl |= TEGRA30_I2S_CTRL_XFER_EN_TX;
bb_i2s->reg_ctrl |= TEGRA30_I2S_CTRL_XFER_EN_RX;
tegra30_i2s_write(bb_i2s, TEGRA30_I2S_CTRL,
diff --git a/sound/soc/tegra/tegra30_i2s.h b/sound/soc/tegra/tegra30_i2s.h
index 10fadc86ab29..a0baaf7434aa 100644
--- a/sound/soc/tegra/tegra30_i2s.h
+++ b/sound/soc/tegra/tegra30_i2s.h
@@ -271,7 +271,7 @@ struct tegra30_i2s {
bool is_dam_used;
#ifdef CONFIG_PM
#ifdef CONFIG_ARCH_TEGRA_3x_SOC
- u32 reg_cache[(TEGRA30_I2S_CIF_TX_CTRL >> 2) + 1];
+ u32 reg_cache[(TEGRA30_I2S_LCOEF_2_4_2 >> 2) + 1];
#else
u32 reg_cache[(TEGRA30_I2S_SLOT_CTRL2 >> 2) + 1];
#endif
diff --git a/sound/soc/tegra/tegra_cs42l73.c b/sound/soc/tegra/tegra_cs42l73.c
index 2cd901ca6d89..e5e36b2fb2c6 100644
--- a/sound/soc/tegra/tegra_cs42l73.c
+++ b/sound/soc/tegra/tegra_cs42l73.c
@@ -91,6 +91,7 @@ struct tegra_cs42l73 {
struct regulator *dmic_reg;
struct regulator *dmic_1v8_reg;
struct regulator *hmic_reg;
+ struct regulator *spkr_reg;
enum snd_soc_bias_level bias_level;
struct snd_soc_card *pcard;
#ifdef CONFIG_SWITCH
@@ -936,12 +937,11 @@ static int tegra_cs42l73_event_int_mic(struct snd_soc_dapm_widget *w,
regulator_disable(machine->dmic_1v8_reg);
}
}
-
if (!(machine->gpio_requested & GPIO_INT_MIC_EN))
return 0;
gpio_set_value_cansleep(pdata->gpio_int_mic_en,
- SND_SOC_DAPM_EVENT_ON(event));
+ !!SND_SOC_DAPM_EVENT_ON(event));
return 0;
}
@@ -954,11 +954,18 @@ static int tegra_cs42l73_event_int_spk(struct snd_soc_dapm_widget *w,
struct tegra_cs42l73 *machine = snd_soc_card_get_drvdata(card);
struct tegra_asoc_platform_data *pdata = machine->pdata;
+ if (machine->spkr_reg) {
+ if (SND_SOC_DAPM_EVENT_ON(event))
+ regulator_enable(machine->spkr_reg);
+ else
+ regulator_disable(machine->spkr_reg);
+ }
+
if (!(machine->gpio_requested & GPIO_SPKR_EN))
return 0;
gpio_set_value_cansleep(pdata->gpio_spkr_en,
- SND_SOC_DAPM_EVENT_ON(event));
+ !!SND_SOC_DAPM_EVENT_ON(event));
return 0;
}
@@ -982,7 +989,7 @@ static int tegra_cs42l73_event_ext_mic(struct snd_soc_dapm_widget *w,
return 0;
gpio_set_value_cansleep(pdata->gpio_ext_mic_en,
- SND_SOC_DAPM_EVENT_ON(event));
+ !!SND_SOC_DAPM_EVENT_ON(event));
return 0;
}
@@ -998,6 +1005,8 @@ static const struct snd_soc_dapm_widget tegra_cs42l73_dapm_widgets[] = {
/* cs42l73 Audio Map */
static const struct snd_soc_dapm_route tegra_cs42l73_audio_map[] = {
{"Int Spk", NULL, "SPKOUT"},
+ {"Int Spk", NULL, "SPKLINEOUT"},
+ {"Int Spk", NULL, "EAROUT"},
{"MIC2", NULL, "Headset Mic"},
{"ADC Left", NULL, "Headset Mic"},
{"ADC Right", NULL, "Headset Mic"},
@@ -1072,7 +1081,6 @@ static int tegra_cs42l73_init(struct snd_soc_pcm_runtime *rtd)
gpio_direction_output(pdata->gpio_spkr_en, 0);
}
-
/* Add call mode switch control */
ret = snd_ctl_add(codec->card->snd_card,
snd_ctl_new1(&tegra_call_mode_control, machine));
@@ -1212,7 +1220,6 @@ static struct snd_soc_card snd_soc_tegra_cs42l73 = {
.resume_pre = tegra_cs42l73_resume_pre,
.set_bias_level = tegra_cs42l73_set_bias_level,
.set_bias_level_post = tegra_cs42l73_set_bias_level_post,
-
.controls = tegra_cs42l73_controls,
.num_controls = ARRAY_SIZE(tegra_cs42l73_controls),
.dapm_widgets = tegra_cs42l73_dapm_widgets,
@@ -1286,6 +1293,12 @@ static __devinit int tegra_cs42l73_driver_probe(struct platform_device *pdev)
machine->hmic_reg = 0;
}
+ machine->spkr_reg = regulator_get(&pdev->dev, "vdd_sys_audio");
+ if (IS_ERR(machine->spkr_reg)) {
+ dev_info(&pdev->dev, "No speaker regulator found\n");
+ machine->spkr_reg = 0;
+ }
+
#ifdef CONFIG_SWITCH
/* Addd h2w swith class support */
ret = switch_dev_register(&tegra_cs42l73_headset_switch);
@@ -1383,6 +1396,8 @@ static int __devexit tegra_cs42l73_driver_remove(struct platform_device *pdev)
regulator_put(machine->dmic_1v8_reg);
if (machine->hmic_reg)
regulator_put(machine->hmic_reg);
+ if (machine->spkr_reg)
+ regulator_put(machine->spkr_reg);
if (gpio_is_valid(pdata->gpio_ldo1_en)) {
gpio_set_value(pdata->gpio_ldo1_en, 0);