summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorZhang Qilong <zhangqilong3@huawei.com>2020-10-16 17:05:36 +0800
committerHerbert Xu <herbert@gondor.apana.org.au>2020-10-30 17:35:02 +1100
commit383e8a823014532ffd81c787ef9009f1c2bd3b79 (patch)
tree31d3740a6d4e4e415c1a34d43dfdd454064f1785
parent1bc608b4655b8b1491fb100f4cf4f15ae64a8698 (diff)
downloadlinux-383e8a823014532ffd81c787ef9009f1c2bd3b79.tar.gz
linux-383e8a823014532ffd81c787ef9009f1c2bd3b79.tar.bz2
linux-383e8a823014532ffd81c787ef9009f1c2bd3b79.zip
crypto: omap-aes - fix the reference count leak of omap device
pm_runtime_get_sync() will increment pm usage counter even when it returns an error code. We should call put operation in error handling paths of omap_aes_hw_init. Signed-off-by: Zhang Qilong <zhangqilong3@huawei.com> Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
-rw-r--r--drivers/crypto/omap-aes.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/crypto/omap-aes.c b/drivers/crypto/omap-aes.c
index 4fd14d90cc40..70ea5784a024 100644
--- a/drivers/crypto/omap-aes.c
+++ b/drivers/crypto/omap-aes.c
@@ -105,6 +105,7 @@ static int omap_aes_hw_init(struct omap_aes_dev *dd)
err = pm_runtime_get_sync(dd->dev);
if (err < 0) {
+ pm_runtime_put_noidle(dd->dev);
dev_err(dd->dev, "failed to get sync: %d\n", err);
return err;
}