ASoC: Export card PM callbacks for use in direct registered cards
Allow hookup of cards registered directly with the core to the PM operations by exporting the device power management operations to modules, also exporting the default PM operations since it is expected that most cards will end up using exactly the same setup. Note that the callbacks require that the driver data for the card be the snd_soc_card. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com> Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
This commit is contained in:
parent
e7361ec499
commit
6f8ab4ac29
|
@ -260,6 +260,9 @@ enum snd_soc_compress_type {
|
||||||
|
|
||||||
int snd_soc_register_card(struct snd_soc_card *card);
|
int snd_soc_register_card(struct snd_soc_card *card);
|
||||||
int snd_soc_unregister_card(struct snd_soc_card *card);
|
int snd_soc_unregister_card(struct snd_soc_card *card);
|
||||||
|
int snd_soc_suspend(struct device *dev);
|
||||||
|
int snd_soc_resume(struct device *dev);
|
||||||
|
int snd_soc_poweroff(struct device *dev);
|
||||||
int snd_soc_register_platform(struct device *dev,
|
int snd_soc_register_platform(struct device *dev,
|
||||||
struct snd_soc_platform_driver *platform_drv);
|
struct snd_soc_platform_driver *platform_drv);
|
||||||
void snd_soc_unregister_platform(struct device *dev);
|
void snd_soc_unregister_platform(struct device *dev);
|
||||||
|
@ -802,4 +805,6 @@ static inline void snd_soc_initialize_card_lists(struct snd_soc_card *card)
|
||||||
extern struct dentry *snd_soc_debugfs_root;
|
extern struct dentry *snd_soc_debugfs_root;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
extern const struct dev_pm_ops snd_soc_pm_ops;
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -965,12 +965,11 @@ static struct snd_pcm_ops soc_pcm_ops = {
|
||||||
.pointer = soc_pcm_pointer,
|
.pointer = soc_pcm_pointer,
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef CONFIG_PM
|
#ifdef CONFIG_PM_SLEEP
|
||||||
/* powers down audio subsystem for suspend */
|
/* powers down audio subsystem for suspend */
|
||||||
static int soc_suspend(struct device *dev)
|
int snd_soc_suspend(struct device *dev)
|
||||||
{
|
{
|
||||||
struct platform_device *pdev = to_platform_device(dev);
|
struct snd_soc_card *card = dev_get_drvdata(dev);
|
||||||
struct snd_soc_card *card = platform_get_drvdata(pdev);
|
|
||||||
struct snd_soc_codec *codec;
|
struct snd_soc_codec *codec;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
|
@ -1082,6 +1081,7 @@ static int soc_suspend(struct device *dev)
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(snd_soc_suspend);
|
||||||
|
|
||||||
/* deferred resume work, so resume can complete before we finished
|
/* deferred resume work, so resume can complete before we finished
|
||||||
* setting our codec back up, which can be very slow on I2C
|
* setting our codec back up, which can be very slow on I2C
|
||||||
|
@ -1187,10 +1187,9 @@ static void soc_resume_deferred(struct work_struct *work)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* powers up audio subsystem after a suspend */
|
/* powers up audio subsystem after a suspend */
|
||||||
static int soc_resume(struct device *dev)
|
int snd_soc_resume(struct device *dev)
|
||||||
{
|
{
|
||||||
struct platform_device *pdev = to_platform_device(dev);
|
struct snd_soc_card *card = dev_get_drvdata(dev);
|
||||||
struct snd_soc_card *card = platform_get_drvdata(pdev);
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* AC97 devices might have other drivers hanging off them so
|
/* AC97 devices might have other drivers hanging off them so
|
||||||
|
@ -1212,9 +1211,10 @@ static int soc_resume(struct device *dev)
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(snd_soc_resume);
|
||||||
#else
|
#else
|
||||||
#define soc_suspend NULL
|
#define snd_soc_suspend NULL
|
||||||
#define soc_resume NULL
|
#define snd_soc_resume NULL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
static struct snd_soc_dai_ops null_dai_ops = {
|
static struct snd_soc_dai_ops null_dai_ops = {
|
||||||
|
@ -1924,10 +1924,9 @@ static int soc_remove(struct platform_device *pdev)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int soc_poweroff(struct device *dev)
|
int snd_soc_poweroff(struct device *dev)
|
||||||
{
|
{
|
||||||
struct platform_device *pdev = to_platform_device(dev);
|
struct snd_soc_card *card = dev_get_drvdata(dev);
|
||||||
struct snd_soc_card *card = platform_get_drvdata(pdev);
|
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if (!card->instantiated)
|
if (!card->instantiated)
|
||||||
|
@ -1944,11 +1943,12 @@ static int soc_poweroff(struct device *dev)
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(snd_soc_poweroff);
|
||||||
|
|
||||||
static const struct dev_pm_ops soc_pm_ops = {
|
const struct dev_pm_ops snd_soc_pm_ops = {
|
||||||
.suspend = soc_suspend,
|
.suspend = snd_soc_suspend,
|
||||||
.resume = soc_resume,
|
.resume = snd_soc_resume,
|
||||||
.poweroff = soc_poweroff,
|
.poweroff = snd_soc_poweroff,
|
||||||
};
|
};
|
||||||
|
|
||||||
/* ASoC platform driver */
|
/* ASoC platform driver */
|
||||||
|
@ -1956,7 +1956,7 @@ static struct platform_driver soc_driver = {
|
||||||
.driver = {
|
.driver = {
|
||||||
.name = "soc-audio",
|
.name = "soc-audio",
|
||||||
.owner = THIS_MODULE,
|
.owner = THIS_MODULE,
|
||||||
.pm = &soc_pm_ops,
|
.pm = &snd_soc_pm_ops,
|
||||||
},
|
},
|
||||||
.probe = soc_probe,
|
.probe = soc_probe,
|
||||||
.remove = soc_remove,
|
.remove = soc_remove,
|
||||||
|
|
Loading…
Reference in New Issue