From: Ye Weihua Date: Thu, 8 Apr 2021 11:06:38 +0000 (+0800) Subject: i2c: imx: Fix PM reference leak in i2c_imx_reg_slave() X-Git-Tag: accepted/tizen/unified/20230118.172025~7326^2~22 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=c4b1fcc310e655fa8414696c38a84d36c00684c8;p=platform%2Fkernel%2Flinux-rpi.git i2c: imx: Fix PM reference leak in i2c_imx_reg_slave() pm_runtime_get_sync() will increment the PM reference count even on failure. Forgetting to put the reference again will result in a leak. Replace it with pm_runtime_resume_and_get() to keep the usage counter balanced. Reported-by: Hulk Robot Signed-off-by: Ye Weihua Signed-off-by: Wolfram Sang --- diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c index dc9c4b4..dc5ca71 100644 --- a/drivers/i2c/busses/i2c-imx.c +++ b/drivers/i2c/busses/i2c-imx.c @@ -801,7 +801,7 @@ static int i2c_imx_reg_slave(struct i2c_client *client) i2c_imx->last_slave_event = I2C_SLAVE_STOP; /* Resume */ - ret = pm_runtime_get_sync(i2c_imx->adapter.dev.parent); + ret = pm_runtime_resume_and_get(i2c_imx->adapter.dev.parent); if (ret < 0) { dev_err(&i2c_imx->adapter.dev, "failed to resume i2c controller"); return ret;