drivers: dio: fix possible memory leak in dio_init()
authorYang Yingliang <yangyingliang@huawei.com>
Wed, 9 Nov 2022 06:40:36 +0000 (14:40 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 9 Nov 2022 14:12:37 +0000 (15:12 +0100)
commite63e99397b2613d50a5f4f02ed07307e67a190f1
tree976a0665237db0a9a86706b095487a054b3d8ef5
parent30a0b95b1335e12efef89dd78518ed3e4a71a763
drivers: dio: fix possible memory leak in dio_init()

If device_register() returns error, the 'dev' and name needs be
freed. Add a release function, and then call put_device() in the
error path, so the name is freed in kobject_cleanup() and to the
'dev' is freed in release function.

Fixes: 2e4c77bea3d8 ("m68k: dio - Kill warn_unused_result warnings")
Fixes: 1fa5ae857bb1 ("driver core: get rid of struct device's bus_id string array")
Signed-off-by: Yang Yingliang <yangyingliang@huawei.com>
Link: https://lore.kernel.org/r/20221109064036.1835346-1-yangyingliang@huawei.com
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/dio/dio.c