[PATCH] media: nxp: imx8-isi: Cleanup video device in error path

Dan Scally dan.scally at ideasonboard.com
Fri May 23 07:34:53 PDT 2025


Hi Laurent

On 22/05/2025 16:26, Laurent Pinchart wrote:
> Hi Dan,
>
> Thank you for the patch.
>
> On Thu, May 22, 2025 at 03:30:08PM +0100, Daniel Scally wrote:
>> mxc_isi_v4l2_init() registers video devices and v4l2 subdevices but
>> the video devices are not cleaned up in that function's error path
>> which means they're left hanging if it fails. Update the function
>> to clean them up properly.
>>
>> Signed-off-by: Daniel Scally <dan.scally at ideasonboard.com>
>> ---
>>   drivers/media/platform/nxp/imx8-isi/imx8-isi-core.c | 9 ++++++---
>>   1 file changed, 6 insertions(+), 3 deletions(-)
>>
>> diff --git a/drivers/media/platform/nxp/imx8-isi/imx8-isi-core.c b/drivers/media/platform/nxp/imx8-isi/imx8-isi-core.c
>> index 1e79b1211b603a71f0427e82a997787110f7e4ac..4a74b988217f504a03dfe330a7bac76cdecc933c 100644
>> --- a/drivers/media/platform/nxp/imx8-isi/imx8-isi-core.c
>> +++ b/drivers/media/platform/nxp/imx8-isi/imx8-isi-core.c
>> @@ -154,7 +154,7 @@ static int mxc_isi_v4l2_init(struct mxc_isi_dev *isi)
>>   		if (ret < 0) {
>>   			dev_err(isi->dev, "Failed to register pipe%u: %d\n", i,
>>   				ret);
>> -			goto err_v4l2;
>> +			goto err_cleanup_pipe;
>>   		}
>>   
>>   		ret = media_create_pad_link(&isi->crossbar.sd.entity,
>> @@ -164,14 +164,14 @@ static int mxc_isi_v4l2_init(struct mxc_isi_dev *isi)
>>   					    MEDIA_LNK_FL_IMMUTABLE |
>>   					    MEDIA_LNK_FL_ENABLED);
>>   		if (ret < 0)
>> -			goto err_v4l2;
>> +			goto err_cleanup_pipe;
>>   	}
>>   
>>   	/* Register the M2M device. */
>>   	ret = mxc_isi_m2m_register(isi, v4l2_dev);
>>   	if (ret < 0) {
>>   		dev_err(isi->dev, "Failed to register M2M device: %d\n", ret);
>> -		goto err_v4l2;
>> +		goto err_cleanup_pipe;
>>   	}
>>   
>>   	/* Initialize, fill and register the async notifier. */
>> @@ -212,6 +212,9 @@ static int mxc_isi_v4l2_init(struct mxc_isi_dev *isi)
>>   err_m2m:
>>   	mxc_isi_m2m_unregister(isi);
>>   	v4l2_async_nf_cleanup(&isi->notifier);
>> +err_cleanup_pipe:
>> +	for (i = 0; i < isi->pdata->num_channels; ++i)
>> +		mxc_isi_pipe_unregister(&isi->pipes[i]);
> mxc_isi_pipe_unregister() calls mxc_isi_video_unregister(), which locks
> the video->lock mutex. The mutex is initialized in
> mxc_isi_video_register(), so you will have an issue here when reaching
> this label from within the pipe registration loop for any non-registered
> pipe.
>
> One option to address this would be to return from
> mxc_isi_video_unregister() if video->pipe is NULL.


Ah - good spot, thanks

>>   err_v4l2:
>>   	v4l2_device_unregister(v4l2_dev);
>>   err_media:
>>
>> ---
>> base-commit: b64b134942c8cf4801ea288b3fd38b509aedec21
>> change-id: 20250522-djrscally-imx8-isi-fixes-fed2d7cffb1c



More information about the linux-arm-kernel mailing list