From 36d5acc9be2e4176fbef7564ae3bbcd1db60c045 Mon Sep 17 00:00:00 2001 From: Manuel Lauss Date: Thu, 3 Jul 2008 09:33:10 +0200 Subject: [PATCH] --- yaml --- r: 99154 b: refs/heads/master c: 3f775987030cf7ff922765c18ddd0d311b4b46ef h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/sound/soc/codecs/ac97.c | 25 +++++++++++++++++++++++++ 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 30845f9a4574..67048f2cb89f 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 15e4c72f520d1db9adc38ba157547a7c1fca45b2 +refs/heads/master: 3f775987030cf7ff922765c18ddd0d311b4b46ef diff --git a/trunk/sound/soc/codecs/ac97.c b/trunk/sound/soc/codecs/ac97.c index 300d007f2339..e4516f3ce64c 100644 --- a/trunk/sound/soc/codecs/ac97.c +++ b/trunk/sound/soc/codecs/ac97.c @@ -144,9 +144,34 @@ static int ac97_soc_remove(struct platform_device *pdev) return 0; } +#ifdef CONFIG_PM +static int ac97_soc_suspend(struct platform_device *pdev, pm_message_t msg) +{ + struct snd_soc_device *socdev = platform_get_drvdata(pdev); + + snd_ac97_suspend(socdev->codec->ac97); + + return 0; +} + +static int ac97_soc_resume(struct platform_device *pdev) +{ + struct snd_soc_device *socdev = platform_get_drvdata(pdev); + + snd_ac97_resume(socdev->codec->ac97); + + return 0; +} +#else +#define ac97_soc_suspend NULL +#define ac97_soc_resume NULL +#endif + struct snd_soc_codec_device soc_codec_dev_ac97 = { .probe = ac97_soc_probe, .remove = ac97_soc_remove, + .suspend = ac97_soc_suspend, + .resume = ac97_soc_resume, }; EXPORT_SYMBOL_GPL(soc_codec_dev_ac97);