diff options
| author | Mark Brown <broonie@linaro.org> | 2013-11-04 01:04:13 -0500 |
|---|---|---|
| committer | Mark Brown <broonie@linaro.org> | 2013-11-04 01:04:13 -0500 |
| commit | 14d907742c690b84681c02b37cd6f35cb96166d5 (patch) | |
| tree | 6596fbe5a1ad26de649ba7f3530f243a9cc8a5e5 | |
| parent | b199b0fcde29731710a571cb65460f53fd8e0927 (diff) | |
| parent | 166a34d27fcad1eeb0322cff23939a1910f8a77c (diff) | |
Merge remote-tracking branch 'asoc/topic/ab8500' into asoc-next
| -rw-r--r-- | sound/soc/codecs/ab8500-codec.c | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/sound/soc/codecs/ab8500-codec.c b/sound/soc/codecs/ab8500-codec.c index a0394a8f2257..21ae8d4fdbfb 100644 --- a/sound/soc/codecs/ab8500-codec.c +++ b/sound/soc/codecs/ab8500-codec.c | |||
| @@ -2300,17 +2300,17 @@ static int ab8500_codec_set_dai_tdm_slot(struct snd_soc_dai *dai, | |||
| 2300 | case 0: | 2300 | case 0: |
| 2301 | break; | 2301 | break; |
| 2302 | case 1: | 2302 | case 1: |
| 2303 | slot = find_first_bit((unsigned long *)&tx_mask, 32); | 2303 | slot = ffs(tx_mask); |
| 2304 | snd_soc_update_bits(codec, AB8500_DASLOTCONF1, mask, slot); | 2304 | snd_soc_update_bits(codec, AB8500_DASLOTCONF1, mask, slot); |
| 2305 | snd_soc_update_bits(codec, AB8500_DASLOTCONF3, mask, slot); | 2305 | snd_soc_update_bits(codec, AB8500_DASLOTCONF3, mask, slot); |
| 2306 | snd_soc_update_bits(codec, AB8500_DASLOTCONF2, mask, slot); | 2306 | snd_soc_update_bits(codec, AB8500_DASLOTCONF2, mask, slot); |
| 2307 | snd_soc_update_bits(codec, AB8500_DASLOTCONF4, mask, slot); | 2307 | snd_soc_update_bits(codec, AB8500_DASLOTCONF4, mask, slot); |
| 2308 | break; | 2308 | break; |
| 2309 | case 2: | 2309 | case 2: |
| 2310 | slot = find_first_bit((unsigned long *)&tx_mask, 32); | 2310 | slot = ffs(tx_mask); |
| 2311 | snd_soc_update_bits(codec, AB8500_DASLOTCONF1, mask, slot); | 2311 | snd_soc_update_bits(codec, AB8500_DASLOTCONF1, mask, slot); |
| 2312 | snd_soc_update_bits(codec, AB8500_DASLOTCONF3, mask, slot); | 2312 | snd_soc_update_bits(codec, AB8500_DASLOTCONF3, mask, slot); |
| 2313 | slot = find_next_bit((unsigned long *)&tx_mask, 32, slot + 1); | 2313 | slot = fls(tx_mask); |
| 2314 | snd_soc_update_bits(codec, AB8500_DASLOTCONF2, mask, slot); | 2314 | snd_soc_update_bits(codec, AB8500_DASLOTCONF2, mask, slot); |
| 2315 | snd_soc_update_bits(codec, AB8500_DASLOTCONF4, mask, slot); | 2315 | snd_soc_update_bits(codec, AB8500_DASLOTCONF4, mask, slot); |
| 2316 | break; | 2316 | break; |
| @@ -2341,18 +2341,18 @@ static int ab8500_codec_set_dai_tdm_slot(struct snd_soc_dai *dai, | |||
| 2341 | case 0: | 2341 | case 0: |
| 2342 | break; | 2342 | break; |
| 2343 | case 1: | 2343 | case 1: |
| 2344 | slot = find_first_bit((unsigned long *)&rx_mask, 32); | 2344 | slot = ffs(rx_mask); |
| 2345 | snd_soc_update_bits(codec, AB8500_ADSLOTSEL(slot), | 2345 | snd_soc_update_bits(codec, AB8500_ADSLOTSEL(slot), |
| 2346 | AB8500_MASK_SLOT(slot), | 2346 | AB8500_MASK_SLOT(slot), |
| 2347 | AB8500_ADSLOTSELX_AD_OUT_TO_SLOT(AB8500_AD_OUT3, slot)); | 2347 | AB8500_ADSLOTSELX_AD_OUT_TO_SLOT(AB8500_AD_OUT3, slot)); |
| 2348 | break; | 2348 | break; |
| 2349 | case 2: | 2349 | case 2: |
| 2350 | slot = find_first_bit((unsigned long *)&rx_mask, 32); | 2350 | slot = ffs(rx_mask); |
| 2351 | snd_soc_update_bits(codec, | 2351 | snd_soc_update_bits(codec, |
| 2352 | AB8500_ADSLOTSEL(slot), | 2352 | AB8500_ADSLOTSEL(slot), |
| 2353 | AB8500_MASK_SLOT(slot), | 2353 | AB8500_MASK_SLOT(slot), |
| 2354 | AB8500_ADSLOTSELX_AD_OUT_TO_SLOT(AB8500_AD_OUT3, slot)); | 2354 | AB8500_ADSLOTSELX_AD_OUT_TO_SLOT(AB8500_AD_OUT3, slot)); |
| 2355 | slot = find_next_bit((unsigned long *)&rx_mask, 32, slot + 1); | 2355 | slot = fls(rx_mask); |
| 2356 | snd_soc_update_bits(codec, | 2356 | snd_soc_update_bits(codec, |
| 2357 | AB8500_ADSLOTSEL(slot), | 2357 | AB8500_ADSLOTSEL(slot), |
| 2358 | AB8500_MASK_SLOT(slot), | 2358 | AB8500_MASK_SLOT(slot), |
| @@ -2575,6 +2575,8 @@ static int ab8500_codec_driver_probe(struct platform_device *pdev) | |||
| 2575 | /* Create driver private-data struct */ | 2575 | /* Create driver private-data struct */ |
| 2576 | drvdata = devm_kzalloc(&pdev->dev, sizeof(struct ab8500_codec_drvdata), | 2576 | drvdata = devm_kzalloc(&pdev->dev, sizeof(struct ab8500_codec_drvdata), |
| 2577 | GFP_KERNEL); | 2577 | GFP_KERNEL); |
| 2578 | if (!drvdata) | ||
| 2579 | return -ENOMEM; | ||
| 2578 | drvdata->sid_status = SID_UNCONFIGURED; | 2580 | drvdata->sid_status = SID_UNCONFIGURED; |
| 2579 | drvdata->anc_status = ANC_UNCONFIGURED; | 2581 | drvdata->anc_status = ANC_UNCONFIGURED; |
| 2580 | dev_set_drvdata(&pdev->dev, drvdata); | 2582 | dev_set_drvdata(&pdev->dev, drvdata); |
