diff mbox

Revert part of "ASoC: tegra: Convert to managed resources"

Message ID 20150818115645.GA3345@localhost (mailing list archive)
State Accepted
Commit 1d15f21dc8030c4511964819b89b50e39d5a7013
Headers show

Commit Message

Vaishali Thakkar Aug. 18, 2015, 11:56 a.m. UTC
Revert the problematic part of commit 470805eb9f31 ("ASoC: tegra:
Convert to managed resources"). Before this commit, PM cleanup was
performed after the component was unregistered. But returning
directly will skip PM cleanup. So, to be on safe side it is better
to use snd_soc_register_component instead of
devm_snd_soc_register_component.

Signed-off-by: Vaishali Thakkar <vthakkar1994@gmail.com>
---
 sound/soc/tegra/tegra20_spdif.c | 10 ++++++----
 1 file changed, 6 insertions(+), 4 deletions(-)

Comments

Mark Brown Aug. 18, 2015, 4:55 p.m. UTC | #1
On Tue, Aug 18, 2015 at 05:26:45PM +0530, Vaishali Thakkar wrote:

> Revert the problematic part of commit 470805eb9f31 ("ASoC: tegra:
> Convert to managed resources"). Before this commit, PM cleanup was

Please use subject lines matching the style for the subsystem on
patches.
Vaishali Thakkar Aug. 18, 2015, 5:01 p.m. UTC | #2
On 18 Aug 2015 22:25, "Mark Brown" <broonie@kernel.org> wrote:
>
> On Tue, Aug 18, 2015 at 05:26:45PM +0530, Vaishali Thakkar wrote:
>
> > Revert the problematic part of commit 470805eb9f31 ("ASoC: tegra:
> > Convert to managed resources"). Before this commit, PM cleanup was
>
> Please use subject lines matching the style for the subsystem on
> patches.

Oh, I am sorry.

I'll keep this in mind for next time. Thanks for making it suitable and
applying the patch.
Alexandre Courbot Aug. 31, 2015, 5:27 a.m. UTC | #3
On Tue, Aug 18, 2015 at 8:56 PM, Vaishali Thakkar
<vthakkar1994@gmail.com> wrote:
> Revert the problematic part of commit 470805eb9f31 ("ASoC: tegra:
> Convert to managed resources"). Before this commit, PM cleanup was
> performed after the component was unregistered. But returning
> directly will skip PM cleanup. So, to be on safe side it is better
> to use snd_soc_register_component instead of
> devm_snd_soc_register_component.
>
> Signed-off-by: Vaishali Thakkar <vthakkar1994@gmail.com>

I'm probably late for the party, but FWIW:

Reviewed-by: Alexandre Courbot <acourbot@nvidia.com>
diff mbox

Patch

diff --git a/sound/soc/tegra/tegra20_spdif.c b/sound/soc/tegra/tegra20_spdif.c
index a814da0..66237bc 100644
--- a/sound/soc/tegra/tegra20_spdif.c
+++ b/sound/soc/tegra/tegra20_spdif.c
@@ -329,9 +329,8 @@  static int tegra20_spdif_platform_probe(struct platform_device *pdev)
 			goto err_pm_disable;
 	}
 
-	ret = devm_snd_soc_register_component(&pdev->dev,
-					      &tegra20_spdif_component,
-					      &tegra20_spdif_dai, 1);
+	ret = snd_soc_register_component(&pdev->dev, &tegra20_spdif_component,
+					 &tegra20_spdif_dai, 1);
 	if (ret) {
 		dev_err(&pdev->dev, "Could not register DAI: %d\n", ret);
 		ret = -ENOMEM;
@@ -341,11 +340,13 @@  static int tegra20_spdif_platform_probe(struct platform_device *pdev)
 	ret = tegra_pcm_platform_register(&pdev->dev);
 	if (ret) {
 		dev_err(&pdev->dev, "Could not register PCM: %d\n", ret);
-		return ret;
+		goto err_unregister_component;
 	}
 
 	return 0;
 
+err_unregister_component:
+	snd_soc_unregister_component(&pdev->dev);
 err_suspend:
 	if (!pm_runtime_status_suspended(&pdev->dev))
 		tegra20_spdif_runtime_suspend(&pdev->dev);
@@ -364,6 +365,7 @@  static int tegra20_spdif_platform_remove(struct platform_device *pdev)
 		tegra20_spdif_runtime_suspend(&pdev->dev);
 
 	tegra_pcm_platform_unregister(&pdev->dev);
+	snd_soc_unregister_component(&pdev->dev);
 
 	return 0;
 }