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:
Niklas Söderlund 2020-08-13 23:06:01 +02:00 committed by Mauro Carvalho Chehab
parent 780d815dcc
commit f18d6a4cb0
1 changed files with 2 additions and 6 deletions

View File

@ -1370,12 +1370,8 @@ static int rcar_vin_remove(struct platform_device *pdev)
v4l2_async_notifier_cleanup(&vin->notifier); v4l2_async_notifier_cleanup(&vin->notifier);
if (vin->info->use_mc) { if (vin->info->use_mc) {
mutex_lock(&vin->group->lock); v4l2_async_notifier_unregister(&vin->group->notifier);
if (&vin->v4l2_dev == vin->group->notifier.v4l2_dev) { v4l2_async_notifier_cleanup(&vin->group->notifier);
v4l2_async_notifier_unregister(&vin->group->notifier);
v4l2_async_notifier_cleanup(&vin->group->notifier);
}
mutex_unlock(&vin->group->lock);
rvin_group_put(vin); rvin_group_put(vin);
} }