diff options
author | Axel Lin <axel.lin@gmail.com> | 2011-10-11 08:20:53 -0400 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2011-10-12 06:21:12 -0400 |
commit | b91470bb374ed7db0448696ec85a3ed4785da2ee (patch) | |
tree | e9ecd8f5c7377fd9791afc7ba6561fadc9ff9972 /sound/soc/codecs/ak4642.c | |
parent | b90d2f908465c800388714180217620c4a5b2fe4 (diff) |
ASoC: ak4642: convert to soc-cache
Signed-off-by: Axel Lin <axel.lin@gmail.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Diffstat (limited to 'sound/soc/codecs/ak4642.c')
-rw-r--r-- | sound/soc/codecs/ak4642.c | 82 |
1 files changed, 12 insertions, 70 deletions
diff --git a/sound/soc/codecs/ak4642.c b/sound/soc/codecs/ak4642.c index 65f46047b1cb..5e25191891e0 100644 --- a/sound/soc/codecs/ak4642.c +++ b/sound/soc/codecs/ak4642.c | |||
@@ -156,7 +156,6 @@ static const struct snd_kcontrol_new ak4642_snd_controls[] = { | |||
156 | struct ak4642_priv { | 156 | struct ak4642_priv { |
157 | unsigned int sysclk; | 157 | unsigned int sysclk; |
158 | enum snd_soc_control_type control_type; | 158 | enum snd_soc_control_type control_type; |
159 | void *control_data; | ||
160 | }; | 159 | }; |
161 | 160 | ||
162 | /* | 161 | /* |
@@ -175,64 +174,6 @@ static const u16 ak4642_reg[AK4642_CACHEREGNUM] = { | |||
175 | 0x0000, | 174 | 0x0000, |
176 | }; | 175 | }; |
177 | 176 | ||
178 | /* | ||
179 | * read ak4642 register cache | ||
180 | */ | ||
181 | static inline unsigned int ak4642_read_reg_cache(struct snd_soc_codec *codec, | ||
182 | unsigned int reg) | ||
183 | { | ||
184 | u16 *cache = codec->reg_cache; | ||
185 | if (reg >= AK4642_CACHEREGNUM) | ||
186 | return -1; | ||
187 | return cache[reg]; | ||
188 | } | ||
189 | |||
190 | /* | ||
191 | * write ak4642 register cache | ||
192 | */ | ||
193 | static inline void ak4642_write_reg_cache(struct snd_soc_codec *codec, | ||
194 | u16 reg, unsigned int value) | ||
195 | { | ||
196 | u16 *cache = codec->reg_cache; | ||
197 | if (reg >= AK4642_CACHEREGNUM) | ||
198 | return; | ||
199 | |||
200 | cache[reg] = value; | ||
201 | } | ||
202 | |||
203 | /* | ||
204 | * write to the AK4642 register space | ||
205 | */ | ||
206 | static int ak4642_write(struct snd_soc_codec *codec, unsigned int reg, | ||
207 | unsigned int value) | ||
208 | { | ||
209 | u8 data[2]; | ||
210 | |||
211 | /* data is | ||
212 | * D15..D8 AK4642 register offset | ||
213 | * D7...D0 register data | ||
214 | */ | ||
215 | data[0] = reg & 0xff; | ||
216 | data[1] = value & 0xff; | ||
217 | |||
218 | if (codec->hw_write(codec->control_data, data, 2) == 2) { | ||
219 | ak4642_write_reg_cache(codec, reg, value); | ||
220 | return 0; | ||
221 | } else | ||
222 | return -EIO; | ||
223 | } | ||
224 | |||
225 | static int ak4642_sync(struct snd_soc_codec *codec) | ||
226 | { | ||
227 | u16 *cache = codec->reg_cache; | ||
228 | int i, r = 0; | ||
229 | |||
230 | for (i = 0; i < AK4642_CACHEREGNUM; i++) | ||
231 | r |= ak4642_write(codec, i, cache[i]); | ||
232 | |||
233 | return r; | ||
234 | }; | ||
235 | |||
236 | static int ak4642_dai_startup(struct snd_pcm_substream *substream, | 177 | static int ak4642_dai_startup(struct snd_pcm_substream *substream, |
237 | struct snd_soc_dai *dai) | 178 | struct snd_soc_dai *dai) |
238 | { | 179 | { |
@@ -252,8 +193,8 @@ static int ak4642_dai_startup(struct snd_pcm_substream *substream, | |||
252 | */ | 193 | */ |
253 | snd_soc_update_bits(codec, MD_CTL4, DACH, DACH); | 194 | snd_soc_update_bits(codec, MD_CTL4, DACH, DACH); |
254 | snd_soc_update_bits(codec, MD_CTL3, BST1, BST1); | 195 | snd_soc_update_bits(codec, MD_CTL3, BST1, BST1); |
255 | ak4642_write(codec, L_IVC, 0x91); /* volume */ | 196 | snd_soc_write(codec, L_IVC, 0x91); /* volume */ |
256 | ak4642_write(codec, R_IVC, 0x91); /* volume */ | 197 | snd_soc_write(codec, R_IVC, 0x91); /* volume */ |
257 | snd_soc_update_bits(codec, PW_MGMT1, PMVCM | PMMIN | PMDAC, | 198 | snd_soc_update_bits(codec, PW_MGMT1, PMVCM | PMMIN | PMDAC, |
258 | PMVCM | PMMIN | PMDAC); | 199 | PMVCM | PMMIN | PMDAC); |
259 | snd_soc_update_bits(codec, PW_MGMT2, PMHP_MASK, PMHP); | 200 | snd_soc_update_bits(codec, PW_MGMT2, PMHP_MASK, PMHP); |
@@ -272,9 +213,9 @@ static int ak4642_dai_startup(struct snd_pcm_substream *substream, | |||
272 | * This operation came from example code of | 213 | * This operation came from example code of |
273 | * "ASAHI KASEI AK4642" (japanese) manual p94. | 214 | * "ASAHI KASEI AK4642" (japanese) manual p94. |
274 | */ | 215 | */ |
275 | ak4642_write(codec, SG_SL1, PMMP | MGAIN0); | 216 | snd_soc_write(codec, SG_SL1, PMMP | MGAIN0); |
276 | ak4642_write(codec, TIMER, ZTM(0x3) | WTM(0x3)); | 217 | snd_soc_write(codec, TIMER, ZTM(0x3) | WTM(0x3)); |
277 | ak4642_write(codec, ALC_CTL1, ALC | LMTH0); | 218 | snd_soc_write(codec, ALC_CTL1, ALC | LMTH0); |
278 | snd_soc_update_bits(codec, PW_MGMT1, PMVCM | PMADL, | 219 | snd_soc_update_bits(codec, PW_MGMT1, PMVCM | PMADL, |
279 | PMVCM | PMADL); | 220 | PMVCM | PMADL); |
280 | snd_soc_update_bits(codec, PW_MGMT3, PMADR, PMADR); | 221 | snd_soc_update_bits(codec, PW_MGMT3, PMADR, PMADR); |
@@ -462,7 +403,7 @@ static struct snd_soc_dai_driver ak4642_dai = { | |||
462 | 403 | ||
463 | static int ak4642_resume(struct snd_soc_codec *codec) | 404 | static int ak4642_resume(struct snd_soc_codec *codec) |
464 | { | 405 | { |
465 | ak4642_sync(codec); | 406 | snd_soc_cache_sync(codec); |
466 | return 0; | 407 | return 0; |
467 | } | 408 | } |
468 | 409 | ||
@@ -470,11 +411,15 @@ static int ak4642_resume(struct snd_soc_codec *codec) | |||
470 | static int ak4642_probe(struct snd_soc_codec *codec) | 411 | static int ak4642_probe(struct snd_soc_codec *codec) |
471 | { | 412 | { |
472 | struct ak4642_priv *ak4642 = snd_soc_codec_get_drvdata(codec); | 413 | struct ak4642_priv *ak4642 = snd_soc_codec_get_drvdata(codec); |
414 | int ret; | ||
473 | 415 | ||
474 | dev_info(codec->dev, "AK4642 Audio Codec %s", AK4642_VERSION); | 416 | dev_info(codec->dev, "AK4642 Audio Codec %s", AK4642_VERSION); |
475 | 417 | ||
476 | codec->hw_write = (hw_write_t)i2c_master_send; | 418 | ret = snd_soc_codec_set_cache_io(codec, 8, 8, ak4642->control_type); |
477 | codec->control_data = ak4642->control_data; | 419 | if (ret < 0) { |
420 | dev_err(codec->dev, "Failed to set cache I/O: %d\n", ret); | ||
421 | return ret; | ||
422 | } | ||
478 | 423 | ||
479 | snd_soc_add_controls(codec, ak4642_snd_controls, | 424 | snd_soc_add_controls(codec, ak4642_snd_controls, |
480 | ARRAY_SIZE(ak4642_snd_controls)); | 425 | ARRAY_SIZE(ak4642_snd_controls)); |
@@ -485,8 +430,6 @@ static int ak4642_probe(struct snd_soc_codec *codec) | |||
485 | static struct snd_soc_codec_driver soc_codec_dev_ak4642 = { | 430 | static struct snd_soc_codec_driver soc_codec_dev_ak4642 = { |
486 | .probe = ak4642_probe, | 431 | .probe = ak4642_probe, |
487 | .resume = ak4642_resume, | 432 | .resume = ak4642_resume, |
488 | .read = ak4642_read_reg_cache, | ||
489 | .write = ak4642_write, | ||
490 | .reg_cache_size = ARRAY_SIZE(ak4642_reg), | 433 | .reg_cache_size = ARRAY_SIZE(ak4642_reg), |
491 | .reg_word_size = sizeof(u8), | 434 | .reg_word_size = sizeof(u8), |
492 | .reg_cache_default = ak4642_reg, | 435 | .reg_cache_default = ak4642_reg, |
@@ -504,7 +447,6 @@ static __devinit int ak4642_i2c_probe(struct i2c_client *i2c, | |||
504 | return -ENOMEM; | 447 | return -ENOMEM; |
505 | 448 | ||
506 | i2c_set_clientdata(i2c, ak4642); | 449 | i2c_set_clientdata(i2c, ak4642); |
507 | ak4642->control_data = i2c; | ||
508 | ak4642->control_type = SND_SOC_I2C; | 450 | ak4642->control_type = SND_SOC_I2C; |
509 | 451 | ||
510 | ret = snd_soc_register_codec(&i2c->dev, | 452 | ret = snd_soc_register_codec(&i2c->dev, |