diff options
author | Uwe Kleine-König <u.kleine-koenig@pengutronix.de> | 2022-09-12 15:20:40 +0200 |
---|---|---|
committer | Wolfram Sang <wsa@kernel.org> | 2022-09-16 20:37:50 +0100 |
commit | 085aacaa73163f4b8a89dec24ecb32cfacd34017 (patch) | |
tree | f77c33a36d78bd9ad79a6eb7d8797d96aa1f9410 /drivers/i2c | |
parent | 80e78fcce86de0288793a0ef0f6acf37656ee4cf (diff) | |
download | linux-stable-085aacaa73163f4b8a89dec24ecb32cfacd34017.tar.gz linux-stable-085aacaa73163f4b8a89dec24ecb32cfacd34017.tar.bz2 linux-stable-085aacaa73163f4b8a89dec24ecb32cfacd34017.zip |
i2c: imx: If pm_runtime_get_sync() returned 1 device access is possible
pm_runtime_get_sync() returning 1 also means the device is powered. So
resetting the chip registers in .remove() is possible and should be
done.
Reported-by: Dan Carpenter <dan.carpenter@oracle.com>
Fixes: d98bdd3a5b50 ("i2c: imx: Make sure to unregister adapter on remove()")
Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Acked-by: Oleksij Rempel <o.rempel@pengutronix.de>
Signed-off-by: Wolfram Sang <wsa@kernel.org>
Diffstat (limited to 'drivers/i2c')
-rw-r--r-- | drivers/i2c/busses/i2c-imx.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/i2c/busses/i2c-imx.c b/drivers/i2c/busses/i2c-imx.c index e47fa3465671..3082183bd66a 100644 --- a/drivers/i2c/busses/i2c-imx.c +++ b/drivers/i2c/busses/i2c-imx.c @@ -1583,7 +1583,7 @@ static int i2c_imx_remove(struct platform_device *pdev) if (i2c_imx->dma) i2c_imx_dma_free(i2c_imx); - if (ret == 0) { + if (ret >= 0) { /* setup chip registers to defaults */ imx_i2c_write_reg(0, i2c_imx, IMX_I2C_IADR); imx_i2c_write_reg(0, i2c_imx, IMX_I2C_IFDR); |