i2c: Fix a potential use after free
authorXu Wang <vulab@iscas.ac.cn>
Fri, 27 Dec 2019 09:34:32 +0000 (09:34 +0000)
committerWolfram Sang <wsa@kernel.org>
Thu, 16 Jun 2022 19:39:40 +0000 (21:39 +0200)
commite4c72c06c367758a14f227c847f9d623f1994ecf
treebea84d2a77eb97f4a861e6e9e3a31babdac91a02
parent4dc1372ffb82c5f08ada7b9cb75a04dcfe49cd96
i2c: Fix a potential use after free

Free the adap structure only after we are done using it.
This patch just moves the put_device() down a bit to avoid the
use after free.

Fixes: 611e12ea0f12 ("i2c: core: manage i2c bus device refcount in i2c_[get|put]_adapter")
Signed-off-by: Xu Wang <vulab@iscas.ac.cn>
[wsa: added comment to the code, added Fixes tag]
Signed-off-by: Wolfram Sang <wsa@kernel.org>
drivers/i2c/i2c-core-base.c