diff options
Diffstat (limited to 'sound/soc/codecs/wm8753.c')
-rw-r--r-- | sound/soc/codecs/wm8753.c | 49 |
1 files changed, 16 insertions, 33 deletions
diff --git a/sound/soc/codecs/wm8753.c b/sound/soc/codecs/wm8753.c index 87caae59e939..79b02ae125c5 100644 --- a/sound/soc/codecs/wm8753.c +++ b/sound/soc/codecs/wm8753.c | |||
@@ -45,7 +45,6 @@ | |||
45 | #include <sound/pcm.h> | 45 | #include <sound/pcm.h> |
46 | #include <sound/pcm_params.h> | 46 | #include <sound/pcm_params.h> |
47 | #include <sound/soc.h> | 47 | #include <sound/soc.h> |
48 | #include <sound/soc-dapm.h> | ||
49 | #include <sound/initval.h> | 48 | #include <sound/initval.h> |
50 | #include <sound/tlv.h> | 49 | #include <sound/tlv.h> |
51 | #include <asm/div64.h> | 50 | #include <asm/div64.h> |
@@ -623,10 +622,11 @@ static const struct snd_soc_dapm_route audio_map[] = { | |||
623 | 622 | ||
624 | static int wm8753_add_widgets(struct snd_soc_codec *codec) | 623 | static int wm8753_add_widgets(struct snd_soc_codec *codec) |
625 | { | 624 | { |
626 | snd_soc_dapm_new_controls(codec, wm8753_dapm_widgets, | 625 | struct snd_soc_dapm_context *dapm = &codec->dapm; |
627 | ARRAY_SIZE(wm8753_dapm_widgets)); | ||
628 | 626 | ||
629 | snd_soc_dapm_add_routes(codec, audio_map, ARRAY_SIZE(audio_map)); | 627 | snd_soc_dapm_new_controls(dapm, wm8753_dapm_widgets, |
628 | ARRAY_SIZE(wm8753_dapm_widgets)); | ||
629 | snd_soc_dapm_add_routes(dapm, audio_map, ARRAY_SIZE(audio_map)); | ||
630 | 630 | ||
631 | return 0; | 631 | return 0; |
632 | } | 632 | } |
@@ -1245,7 +1245,7 @@ static int wm8753_set_bias_level(struct snd_soc_codec *codec, | |||
1245 | snd_soc_write(codec, WM8753_PWR1, 0x0001); | 1245 | snd_soc_write(codec, WM8753_PWR1, 0x0001); |
1246 | break; | 1246 | break; |
1247 | } | 1247 | } |
1248 | codec->bias_level = level; | 1248 | codec->dapm.bias_level = level; |
1249 | return 0; | 1249 | return 0; |
1250 | } | 1250 | } |
1251 | 1251 | ||
@@ -1435,9 +1435,11 @@ static void wm8753_set_dai_mode(struct snd_soc_codec *codec, | |||
1435 | 1435 | ||
1436 | static void wm8753_work(struct work_struct *work) | 1436 | static void wm8753_work(struct work_struct *work) |
1437 | { | 1437 | { |
1438 | struct snd_soc_codec *codec = | 1438 | struct snd_soc_dapm_context *dapm = |
1439 | container_of(work, struct snd_soc_codec, delayed_work.work); | 1439 | container_of(work, struct snd_soc_dapm_context, |
1440 | wm8753_set_bias_level(codec, codec->bias_level); | 1440 | delayed_work.work); |
1441 | struct snd_soc_codec *codec = dapm->codec; | ||
1442 | wm8753_set_bias_level(codec, dapm->bias_level); | ||
1441 | } | 1443 | } |
1442 | 1444 | ||
1443 | static int wm8753_suspend(struct snd_soc_codec *codec, pm_message_t state) | 1445 | static int wm8753_suspend(struct snd_soc_codec *codec, pm_message_t state) |
@@ -1466,41 +1468,22 @@ static int wm8753_resume(struct snd_soc_codec *codec) | |||
1466 | wm8753_set_bias_level(codec, SND_SOC_BIAS_STANDBY); | 1468 | wm8753_set_bias_level(codec, SND_SOC_BIAS_STANDBY); |
1467 | 1469 | ||
1468 | /* charge wm8753 caps */ | 1470 | /* charge wm8753 caps */ |
1469 | if (codec->suspend_bias_level == SND_SOC_BIAS_ON) { | 1471 | if (codec->dapm.suspend_bias_level == SND_SOC_BIAS_ON) { |
1470 | wm8753_set_bias_level(codec, SND_SOC_BIAS_PREPARE); | 1472 | wm8753_set_bias_level(codec, SND_SOC_BIAS_PREPARE); |
1471 | codec->bias_level = SND_SOC_BIAS_ON; | 1473 | codec->dapm.bias_level = SND_SOC_BIAS_ON; |
1472 | schedule_delayed_work(&codec->delayed_work, | 1474 | schedule_delayed_work(&codec->dapm.delayed_work, |
1473 | msecs_to_jiffies(caps_charge)); | 1475 | msecs_to_jiffies(caps_charge)); |
1474 | } | 1476 | } |
1475 | 1477 | ||
1476 | return 0; | 1478 | return 0; |
1477 | } | 1479 | } |
1478 | 1480 | ||
1479 | /* | ||
1480 | * This function forces any delayed work to be queued and run. | ||
1481 | */ | ||
1482 | static int run_delayed_work(struct delayed_work *dwork) | ||
1483 | { | ||
1484 | int ret; | ||
1485 | |||
1486 | /* cancel any work waiting to be queued. */ | ||
1487 | ret = cancel_delayed_work(dwork); | ||
1488 | |||
1489 | /* if there was any work waiting then we run it now and | ||
1490 | * wait for it's completion */ | ||
1491 | if (ret) { | ||
1492 | schedule_delayed_work(dwork, 0); | ||
1493 | flush_scheduled_work(); | ||
1494 | } | ||
1495 | return ret; | ||
1496 | } | ||
1497 | |||
1498 | static int wm8753_probe(struct snd_soc_codec *codec) | 1481 | static int wm8753_probe(struct snd_soc_codec *codec) |
1499 | { | 1482 | { |
1500 | struct wm8753_priv *wm8753 = snd_soc_codec_get_drvdata(codec); | 1483 | struct wm8753_priv *wm8753 = snd_soc_codec_get_drvdata(codec); |
1501 | int ret; | 1484 | int ret; |
1502 | 1485 | ||
1503 | INIT_DELAYED_WORK(&codec->delayed_work, wm8753_work); | 1486 | INIT_DELAYED_WORK(&codec->dapm.delayed_work, wm8753_work); |
1504 | 1487 | ||
1505 | ret = snd_soc_codec_set_cache_io(codec, 7, 9, wm8753->control_type); | 1488 | ret = snd_soc_codec_set_cache_io(codec, 7, 9, wm8753->control_type); |
1506 | if (ret < 0) { | 1489 | if (ret < 0) { |
@@ -1519,7 +1502,7 @@ static int wm8753_probe(struct snd_soc_codec *codec) | |||
1519 | 1502 | ||
1520 | /* charge output caps */ | 1503 | /* charge output caps */ |
1521 | wm8753_set_bias_level(codec, SND_SOC_BIAS_PREPARE); | 1504 | wm8753_set_bias_level(codec, SND_SOC_BIAS_PREPARE); |
1522 | schedule_delayed_work(&codec->delayed_work, | 1505 | schedule_delayed_work(&codec->dapm.delayed_work, |
1523 | msecs_to_jiffies(caps_charge)); | 1506 | msecs_to_jiffies(caps_charge)); |
1524 | 1507 | ||
1525 | /* set the update bits */ | 1508 | /* set the update bits */ |
@@ -1544,7 +1527,7 @@ static int wm8753_probe(struct snd_soc_codec *codec) | |||
1544 | /* power down chip */ | 1527 | /* power down chip */ |
1545 | static int wm8753_remove(struct snd_soc_codec *codec) | 1528 | static int wm8753_remove(struct snd_soc_codec *codec) |
1546 | { | 1529 | { |
1547 | run_delayed_work(&codec->delayed_work); | 1530 | flush_delayed_work_sync(&codec->dapm.delayed_work); |
1548 | wm8753_set_bias_level(codec, SND_SOC_BIAS_OFF); | 1531 | wm8753_set_bias_level(codec, SND_SOC_BIAS_OFF); |
1549 | 1532 | ||
1550 | return 0; | 1533 | return 0; |