ASoC: cs35l45: Use modern pm_ops
authorRicardo Rivera-Matos <rriveram@opensource.cirrus.com>
Wed, 6 Dec 2023 16:03:16 +0000 (10:03 -0600)
committerMark Brown <broonie@kernel.org>
Wed, 6 Dec 2023 23:06:55 +0000 (23:06 +0000)
Make use of the recently introduced EXPORT_GPL_DEV_PM_OPS() macro, to
conditionally export the runtime/system PM functions.

Replace the old SET_{RUNTIME,SYSTEM_SLEEP,NOIRQ_SYSTEM_SLEEP}_PM_OPS()
helpers with their modern alternatives and get rid of the now
unnecessary '__maybe_unused' annotations on all PM functions.

Additionally, use the pm_ptr() macro to fix the following errors when
building with CONFIG_PM disabled:

Signed-off-by: Ricardo Rivera-Matos <rriveram@opensource.cirrus.com>
Acked-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Link: https://lore.kernel.org/r/20231206160318.1255034-2-rriveram@opensource.cirrus.com
Signed-off-by: Mark Brown <broonie@kernel.org>
sound/soc/codecs/cs35l45-i2c.c
sound/soc/codecs/cs35l45-spi.c
sound/soc/codecs/cs35l45.c

index 77e0f8750f3757f933f261918a1f105639ecc707..bc2af1ed0fe9bb478f392b94a186914052633c22 100644 (file)
@@ -62,7 +62,7 @@ static struct i2c_driver cs35l45_i2c_driver = {
        .driver = {
                .name           = "cs35l45",
                .of_match_table = cs35l45_of_match,
-               .pm             = &cs35l45_pm_ops,
+               .pm             = pm_ptr(&cs35l45_pm_ops),
        },
        .id_table       = cs35l45_id_i2c,
        .probe          = cs35l45_i2c_probe,
index 5efb77530cc33ed6e00189d8887aead25e954d81..39e203a5f060c6987ad55d6d8115eee4c507813a 100644 (file)
@@ -64,7 +64,7 @@ static struct spi_driver cs35l45_spi_driver = {
        .driver = {
                .name           = "cs35l45",
                .of_match_table = cs35l45_of_match,
-               .pm             = &cs35l45_pm_ops,
+               .pm             = pm_ptr(&cs35l45_pm_ops),
        },
        .id_table       = cs35l45_id_spi,
        .probe          = cs35l45_spi_probe,
index b68853e42fd1e35c88556e016c558e3fd7695ad4..4f4df166f5f016fe39fb4e305aa7318ef752ced9 100644 (file)
@@ -982,7 +982,7 @@ static int cs35l45_exit_hibernate(struct cs35l45_private *cs35l45)
        return -ETIMEDOUT;
 }
 
-static int __maybe_unused cs35l45_runtime_suspend(struct device *dev)
+static int cs35l45_runtime_suspend(struct device *dev)
 {
        struct cs35l45_private *cs35l45 = dev_get_drvdata(dev);
 
@@ -999,7 +999,7 @@ static int __maybe_unused cs35l45_runtime_suspend(struct device *dev)
        return 0;
 }
 
-static int __maybe_unused cs35l45_runtime_resume(struct device *dev)
+static int cs35l45_runtime_resume(struct device *dev)
 {
        struct cs35l45_private *cs35l45 = dev_get_drvdata(dev);
        int ret;
@@ -1466,10 +1466,9 @@ void cs35l45_remove(struct cs35l45_private *cs35l45)
 }
 EXPORT_SYMBOL_NS_GPL(cs35l45_remove, SND_SOC_CS35L45);
 
-const struct dev_pm_ops cs35l45_pm_ops = {
-       SET_RUNTIME_PM_OPS(cs35l45_runtime_suspend, cs35l45_runtime_resume, NULL)
+EXPORT_GPL_DEV_PM_OPS(cs35l45_pm_ops) = {
+       RUNTIME_PM_OPS(cs35l45_runtime_suspend, cs35l45_runtime_resume, NULL)
 };
-EXPORT_SYMBOL_NS_GPL(cs35l45_pm_ops, SND_SOC_CS35L45);
 
 MODULE_DESCRIPTION("ASoC CS35L45 driver");
 MODULE_AUTHOR("James Schulman, Cirrus Logic Inc, <james.schulman@cirrus.com>");