Commit 248ac368 authored by Sylwester Nawrocki's avatar Sylwester Nawrocki Committed by Mauro Carvalho Chehab

[media] s5p-fimc: Fix fimc-lite entities deregistration

Clear the proper array when deregistering FIMC-LITE devices. Now
fimc[] array is erroneously accessed instead of fimc_lite[] and
fimc_md_unregister_entities() function call can result in an oops
from NULL pointer dereference, since fmd->fimc[] is cleared earlier.
This might happen in normal conditions when the driver's probing
is deferred and then retried.
Signed-off-by: default avatarSylwester Nawrocki <s.nawrocki@samsung.com>
Signed-off-by: default avatarKyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@redhat.com>
parent eb362092
...@@ -472,7 +472,7 @@ static void fimc_md_unregister_entities(struct fimc_md *fmd) ...@@ -472,7 +472,7 @@ static void fimc_md_unregister_entities(struct fimc_md *fmd)
if (fmd->fimc_lite[i] == NULL) if (fmd->fimc_lite[i] == NULL)
continue; continue;
v4l2_device_unregister_subdev(&fmd->fimc_lite[i]->subdev); v4l2_device_unregister_subdev(&fmd->fimc_lite[i]->subdev);
fmd->fimc[i]->pipeline_ops = NULL; fmd->fimc_lite[i]->pipeline_ops = NULL;
fmd->fimc_lite[i] = NULL; fmd->fimc_lite[i] = NULL;
} }
for (i = 0; i < CSIS_MAX_ENTITIES; i++) { for (i = 0; i < CSIS_MAX_ENTITIES; i++) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment