mirror of
https://github.com/torvalds/linux.git
synced 2024-12-30 06:41:43 +00:00
media: rcar-vin: Unconditionally unregister notifier on remove
If the VIN device is part of a group of VIN devices (all Gen3 boards) there is no reason to only unregister the group notifier if the VIN that registers the notifier is removed. The VIN that registers the notifier is always the last VIN device to be bound, so keeping the notifier around after any VIN is unbound creates an unbalanced state where no VIN in the group is operational. Fix this by unconditionally unregistering the notifier when any VIN device is unbound. Unregistering the notifier will lead to unbound() being called and all video devices exposed by any VIN instance to be removed. The lock was only needed to protect the check which VIN registers the notifier and is no longer needed. Signed-off-by: Niklas Söderlund <niklas.soderlund+renesas@ragnatech.se> Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
This commit is contained in:
parent
780d815dcc
commit
f18d6a4cb0
@ -1370,12 +1370,8 @@ static int rcar_vin_remove(struct platform_device *pdev)
|
||||
v4l2_async_notifier_cleanup(&vin->notifier);
|
||||
|
||||
if (vin->info->use_mc) {
|
||||
mutex_lock(&vin->group->lock);
|
||||
if (&vin->v4l2_dev == vin->group->notifier.v4l2_dev) {
|
||||
v4l2_async_notifier_unregister(&vin->group->notifier);
|
||||
v4l2_async_notifier_cleanup(&vin->group->notifier);
|
||||
}
|
||||
mutex_unlock(&vin->group->lock);
|
||||
v4l2_async_notifier_unregister(&vin->group->notifier);
|
||||
v4l2_async_notifier_cleanup(&vin->group->notifier);
|
||||
rvin_group_put(vin);
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user