drivers/i2c/busses/i2c-qcom-geni.c | 24 +++++++++++------------- 1 file changed, 11 insertions(+), 13 deletions(-)
The driver carries custom system suspend/resume handling that manually
tracks a suspended state and conditionally calls
geni_i2c_runtime_suspend()
from the noirq suspend path, then adjusts runtime PM state by hand. This
duplicates PM core behavior and adds unnecessary complexity.
Drop the manual state tracking and switch to pm_runtime_force_suspend()
and pm_runtime_force_resume() for system sleep. These helpers already
perform the required checks, call the runtime PM callbacks when needed,
and keep runtime PM state transitions consistent.
Reviewed-by: Mukesh Kumar Savaliya <mukesh.savaliya@oss.qualcomm.com>
Signed-off-by: Praveen Talari <praveen.talari@oss.qualcomm.com>
---
drivers/i2c/busses/i2c-qcom-geni.c | 24 +++++++++++-------------
1 file changed, 11 insertions(+), 13 deletions(-)
diff --git a/drivers/i2c/busses/i2c-qcom-geni.c b/drivers/i2c/busses/i2c-qcom-geni.c
index a4acb78fafb6..ee04d542e055 100644
--- a/drivers/i2c/busses/i2c-qcom-geni.c
+++ b/drivers/i2c/busses/i2c-qcom-geni.c
@@ -110,7 +110,6 @@ struct geni_i2c_dev {
struct clk *core_clk;
u32 clk_freq_out;
const struct geni_i2c_clk_fld *clk_fld;
- int suspended;
void *dma_buf;
size_t xfer_len;
dma_addr_t dma_addr;
@@ -1129,7 +1128,6 @@ static int geni_i2c_probe(struct platform_device *pdev)
if (ret)
goto err_dma;
- gi2c->suspended = 1;
pm_runtime_set_suspended(gi2c->se.dev);
pm_runtime_set_autosuspend_delay(gi2c->se.dev, I2C_AUTO_SUSPEND_DELAY);
pm_runtime_use_autosuspend(gi2c->se.dev);
@@ -1186,9 +1184,6 @@ static int __maybe_unused geni_i2c_runtime_suspend(struct device *dev)
if (ret) {
enable_irq(gi2c->irq);
return ret;
-
- } else {
- gi2c->suspended = 1;
}
clk_disable_unprepare(gi2c->core_clk);
@@ -1214,7 +1209,6 @@ static int __maybe_unused geni_i2c_runtime_resume(struct device *dev)
goto out_clk_disable;
enable_irq(gi2c->irq);
- gi2c->suspended = 0;
return 0;
@@ -1229,21 +1223,25 @@ static int __maybe_unused geni_i2c_runtime_resume(struct device *dev)
static int __maybe_unused geni_i2c_suspend_noirq(struct device *dev)
{
struct geni_i2c_dev *gi2c = dev_get_drvdata(dev);
+ int ret;
i2c_mark_adapter_suspended(&gi2c->adap);
- if (!gi2c->suspended) {
- geni_i2c_runtime_suspend(dev);
- pm_runtime_disable(dev);
- pm_runtime_set_suspended(dev);
- pm_runtime_enable(dev);
- }
- return 0;
+ ret = pm_runtime_force_suspend(dev);
+ if (ret)
+ i2c_mark_adapter_resumed(&gi2c->adap);
+
+ return ret;
}
static int __maybe_unused geni_i2c_resume_noirq(struct device *dev)
{
struct geni_i2c_dev *gi2c = dev_get_drvdata(dev);
+ int ret;
+
+ ret = pm_runtime_force_resume(dev);
+ if (ret)
+ return ret;
i2c_mark_adapter_resumed(&gi2c->adap);
return 0;
---
base-commit: 1f5ffc672165ff851063a5fd044b727ab2517ae3
change-id: 20260520-use_pm_runtime_apis-47e99f247d2b
Best regards,
--
Praveen Talari <praveen.talari@oss.qualcomm.com>
© 2016 - 2026 Red Hat, Inc.