media: dvbdev: fix the logic when DVB_DYNAMIC_MINORS is not set
When CONFIG_DVB_DYNAMIC_MINORS, ret is not initialized, and a semaphore is left at the wrong state, in case of errors. Make the code simpler and avoid mistakes by having just one error check logic used weather DVB_DYNAMIC_MINORS is used or not. Reported-by: kernel test robot <lkp@intel.com> Reported-by: Dan Carpenter <dan.carpenter@linaro.org> Closes: https://lore.kernel.org/r/202410201717.ULWWdJv8-lkp@intel.com/ Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org> Link: https://lore.kernel.org/r/9e067488d8935b8cf00959764a1fa5de85d65725.1730926254.git.mchehab+huawei@kernel.org
This commit is contained in:
parent
96d8569563
commit
a4aebaf6e6
@ -530,6 +530,9 @@ int dvb_register_device(struct dvb_adapter *adap, struct dvb_device **pdvbdev,
|
|||||||
for (minor = 0; minor < MAX_DVB_MINORS; minor++)
|
for (minor = 0; minor < MAX_DVB_MINORS; minor++)
|
||||||
if (!dvb_minors[minor])
|
if (!dvb_minors[minor])
|
||||||
break;
|
break;
|
||||||
|
#else
|
||||||
|
minor = nums2minor(adap->num, type, id);
|
||||||
|
#endif
|
||||||
if (minor >= MAX_DVB_MINORS) {
|
if (minor >= MAX_DVB_MINORS) {
|
||||||
if (new_node) {
|
if (new_node) {
|
||||||
list_del(&new_node->list_head);
|
list_del(&new_node->list_head);
|
||||||
@ -543,17 +546,7 @@ int dvb_register_device(struct dvb_adapter *adap, struct dvb_device **pdvbdev,
|
|||||||
mutex_unlock(&dvbdev_register_lock);
|
mutex_unlock(&dvbdev_register_lock);
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
}
|
}
|
||||||
#else
|
|
||||||
minor = nums2minor(adap->num, type, id);
|
|
||||||
if (minor >= MAX_DVB_MINORS) {
|
|
||||||
dvb_media_device_free(dvbdev);
|
|
||||||
list_del(&dvbdev->list_head);
|
|
||||||
kfree(dvbdev);
|
|
||||||
*pdvbdev = NULL;
|
|
||||||
mutex_unlock(&dvbdev_register_lock);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
dvbdev->minor = minor;
|
dvbdev->minor = minor;
|
||||||
dvb_minors[minor] = dvb_device_get(dvbdev);
|
dvb_minors[minor] = dvb_device_get(dvbdev);
|
||||||
up_write(&minor_rwsem);
|
up_write(&minor_rwsem);
|
||||||
|
Loading…
Reference in New Issue
Block a user