From 072c21e360c2eec829965e76c5a6b435252f69db Mon Sep 17 00:00:00 2001 From: =?utf8?q?=E9=82=B1=E5=BB=BA=E6=96=8C?= Date: Sat, 24 Mar 2012 20:51:57 +0800 Subject: [PATCH] rk30: fix i2s and pcm bug --- sound/soc/codecs/rt5631.c | 13 ++++++++----- sound/soc/rk29/rk29_pcm.c | 14 ++++++++++++++ sound/soc/rk29/rk29_rt5631.c | 6 ++++++ sound/soc/rk29/rk30_i2s.c | 2 +- 4 files changed, 29 insertions(+), 6 deletions(-) diff --git a/sound/soc/codecs/rt5631.c b/sound/soc/codecs/rt5631.c index b61c35ea5d5a..9948c2bb72ba 100755 --- a/sound/soc/codecs/rt5631.c +++ b/sound/soc/codecs/rt5631.c @@ -176,7 +176,7 @@ static struct rt5631_init_reg init_list[] = { //{RT5631_STEREO_DAC_VOL_1 , 0x004C}, {RT5631_ADC_REC_MIXER , 0xb0f0},//Record Mixer source from Mic1 by default {RT5631_ADC_CTRL_1 , 0x0006},//STEREO ADC CONTROL 1 - {RT5631_MIC_CTRL_2 , 0x6600},//0x8800},//0x5500}, //Mic1/Mic2 boost 40DB by default + {RT5631_MIC_CTRL_2 , 0x4400},//0x8800},//0x6600}, //Mic1/Mic2 boost 40DB by default {RT5631_PWR_MANAG_ADD1 , 0x93e0}, #if RT5631_ALC_ADC_FUNC_ENA @@ -1910,8 +1910,13 @@ static int rt5631_set_bias_level(struct snd_soc_codec *codec, break; case SND_SOC_BIAS_STANDBY: - rt5631_write_mask(codec, RT5631_PWR_MANAG_ADD2, 0, - PWR_MICBIAS1_VOL | PWR_MICBIAS2_VOL); + // rt5631_write_mask(codec, RT5631_PWR_MANAG_ADD2, 0, + // PWR_MICBIAS1_VOL | PWR_MICBIAS2_VOL); + printk("standby rt5631\n"); + rt5631_write(codec, RT5631_PWR_MANAG_ADD1, 0x0000); + rt5631_write(codec, RT5631_PWR_MANAG_ADD2, 0x0000); + rt5631_write(codec, RT5631_PWR_MANAG_ADD3, 0x0000); + rt5631_write(codec, RT5631_PWR_MANAG_ADD4, 0x0000); break; case SND_SOC_BIAS_OFF: @@ -1938,8 +1943,6 @@ static int rt5631_probe(struct snd_soc_codec *codec) struct rt5631_priv *rt5631 = snd_soc_codec_get_drvdata(codec); unsigned int val; int ret; - - DBG("%s..............\n", __func__); ret = snd_soc_codec_set_cache_io(codec, 8, 16, SND_SOC_I2C); if (ret != 0) { dev_err(codec->dev, "Failed to set cache I/O: %d\n", ret); diff --git a/sound/soc/rk29/rk29_pcm.c b/sound/soc/rk29/rk29_pcm.c index c015652d6a2d..8630a4ab5a0b 100755 --- a/sound/soc/rk29/rk29_pcm.c +++ b/sound/soc/rk29/rk29_pcm.c @@ -144,8 +144,22 @@ void rk29_audio_buffdone(void *dev_id, int size, return; if (!substream->runtime) return; + switch(result) + { + case RK29_RES_OK: + DBG("::%s----%d RK29_RES_OK\n",__FUNCTION__,__LINE__); + break; + case RK29_RES_ERR: + DBG("::%s----%d RK29_RES_ERR\n",__FUNCTION__,__LINE__); + break; + case RK29_RES_ABORT: + DBG("Enter::%s----%d RK29_RES_ABORT \n",__FUNCTION__,__LINE__); + return; + } prtd = substream->runtime->private_data; + if(!(prtd->state & ST_RUNNING)) + return; DBG("Enter::%s----%d, substream=%p, prtd=%p\n",__FUNCTION__,__LINE__, substream, prtd); if (substream){ snd_pcm_period_elapsed(substream); diff --git a/sound/soc/rk29/rk29_rt5631.c b/sound/soc/rk29/rk29_rt5631.c index c38fefe198c2..05e5c9af4412 100644 --- a/sound/soc/rk29/rk29_rt5631.c +++ b/sound/soc/rk29/rk29_rt5631.c @@ -195,7 +195,13 @@ static struct snd_soc_dai_link rk29_dai = { .stream_name = "RT5631 PCM", .codec_name = "RT5631.0-001a", .platform_name = "rockchip-audio", +#if defined(CONFIG_SND_RK29_SOC_I2S_8CH) .cpu_dai_name = "rk29_i2s.0", +#elif defined(CONFIG_SND_RK29_SOC_I2S_2CH) + .cpu_dai_name = "rk29_i2s.1", +#else + .cpu_dai_name = "rk29_i2s.2", +#endif .codec_dai_name = "RT5631 HiFi", .init = rk29_rt5631_init, .ops = &rk29_ops, diff --git a/sound/soc/rk29/rk30_i2s.c b/sound/soc/rk29/rk30_i2s.c index 0daeeae57230..348c3ce54d65 100755 --- a/sound/soc/rk29/rk30_i2s.c +++ b/sound/soc/rk29/rk30_i2s.c @@ -46,7 +46,7 @@ #define pheadi2s ((pI2S_REG)(i2s->regs)) -#define MAX_I2S 2 +#define MAX_I2S 3 struct rk29_i2s_info { struct device *dev; -- 2.34.1