rtc: class: remove unnecessary device_get() in rtc_device_unregister
Technically the address of rtc->dev can never be NULL, so get_device() can never fail. Also caller of rtc_device_unregister() supposed to be the owner of the device and thus have a valid reference. Therefore call to get_device() is not needed here. Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com> Reviewed-by: Krzysztof Kozlowski <k.kozlowski@samsung.com> Signed-off-by: Alexandre Belloni <alexandre.belloni@free-electrons.com>
This commit is contained in:
parent
6706664d92
commit
c3b399a4b6
@ -266,20 +266,19 @@ EXPORT_SYMBOL_GPL(rtc_device_register);
|
|||||||
*/
|
*/
|
||||||
void rtc_device_unregister(struct rtc_device *rtc)
|
void rtc_device_unregister(struct rtc_device *rtc)
|
||||||
{
|
{
|
||||||
if (get_device(&rtc->dev) != NULL) {
|
|
||||||
mutex_lock(&rtc->ops_lock);
|
mutex_lock(&rtc->ops_lock);
|
||||||
/* remove innards of this RTC, then disable it, before
|
/*
|
||||||
|
* Remove innards of this RTC, then disable it, before
|
||||||
* letting any rtc_class_open() users access it again
|
* letting any rtc_class_open() users access it again
|
||||||
*/
|
*/
|
||||||
rtc_sysfs_del_device(rtc);
|
rtc_sysfs_del_device(rtc);
|
||||||
rtc_dev_del_device(rtc);
|
rtc_dev_del_device(rtc);
|
||||||
rtc_proc_del_device(rtc);
|
rtc_proc_del_device(rtc);
|
||||||
device_unregister(&rtc->dev);
|
device_del(&rtc->dev);
|
||||||
rtc->ops = NULL;
|
rtc->ops = NULL;
|
||||||
mutex_unlock(&rtc->ops_lock);
|
mutex_unlock(&rtc->ops_lock);
|
||||||
put_device(&rtc->dev);
|
put_device(&rtc->dev);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
EXPORT_SYMBOL_GPL(rtc_device_unregister);
|
EXPORT_SYMBOL_GPL(rtc_device_unregister);
|
||||||
|
|
||||||
static void devm_rtc_device_release(struct device *dev, void *res)
|
static void devm_rtc_device_release(struct device *dev, void *res)
|
||||||
|
Loading…
Reference in New Issue
Block a user