Hi, On Mon, 2019-04-08 at 10:18 +0200, Paul Kocialkowski wrote: > Hi, > > Le dimanche 07 avril 2019 à 20:47 +0200, Jernej Skrabec a écrit : > > Currently, MEDIA_IOC_G_TOPOLOGY ioctl on cedrus fails due to incorrect > > initialization order. Fix that by moving video_register_device() before > > v4l2_m2m_register_media_controller() and while at it, fix error path. > > > > Reported-by: Jonas Karlman <jonas@xxxxxxxxx> > > Signed-off-by: Jernej Skrabec <jernej.skrabec@xxxxxxxx> > > Thanks for the fix, good catch! > > Acked-by: Paul Kocialkowski <paul.kocialkowski@xxxxxxxxxxx> Looks like this patch wasn't picked-up yet. Could we take it in? I think it would also deserve a: Fixes: 50e761516f2b ("media: platform: Add Cedrus VPU decoder driver") Cheers, Paul > > --- > > drivers/staging/media/sunxi/cedrus/cedrus.c | 24 ++++++++++----------- > > 1 file changed, 12 insertions(+), 12 deletions(-) > > > > diff --git a/drivers/staging/media/sunxi/cedrus/cedrus.c b/drivers/staging/media/sunxi/cedrus/cedrus.c > > index b98add3cdedd..d0429c0e6b6b 100644 > > --- a/drivers/staging/media/sunxi/cedrus/cedrus.c > > +++ b/drivers/staging/media/sunxi/cedrus/cedrus.c > > @@ -300,7 +300,7 @@ static int cedrus_probe(struct platform_device *pdev) > > "Failed to initialize V4L2 M2M device\n"); > > ret = PTR_ERR(dev->m2m_dev); > > > > - goto err_video; > > + goto err_v4l2; > > } > > > > dev->mdev.dev = &pdev->dev; > > @@ -310,23 +310,23 @@ static int cedrus_probe(struct platform_device *pdev) > > dev->mdev.ops = &cedrus_m2m_media_ops; > > dev->v4l2_dev.mdev = &dev->mdev; > > > > - ret = v4l2_m2m_register_media_controller(dev->m2m_dev, vfd, > > - MEDIA_ENT_F_PROC_VIDEO_DECODER); > > - if (ret) { > > - v4l2_err(&dev->v4l2_dev, > > - "Failed to initialize V4L2 M2M media controller\n"); > > - goto err_m2m; > > - } > > - > > ret = video_register_device(vfd, VFL_TYPE_GRABBER, 0); > > if (ret) { > > v4l2_err(&dev->v4l2_dev, "Failed to register video device\n"); > > - goto err_v4l2; > > + goto err_m2m; > > } > > > > v4l2_info(&dev->v4l2_dev, > > "Device registered as /dev/video%d\n", vfd->num); > > > > + ret = v4l2_m2m_register_media_controller(dev->m2m_dev, vfd, > > + MEDIA_ENT_F_PROC_VIDEO_DECODER); > > + if (ret) { > > + v4l2_err(&dev->v4l2_dev, > > + "Failed to initialize V4L2 M2M media controller\n"); > > + goto err_video; > > + } > > + > > ret = media_device_register(&dev->mdev); > > if (ret) { > > v4l2_err(&dev->v4l2_dev, "Failed to register media device\n"); > > @@ -339,10 +339,10 @@ static int cedrus_probe(struct platform_device *pdev) > > > > err_m2m_mc: > > v4l2_m2m_unregister_media_controller(dev->m2m_dev); > > -err_m2m: > > - v4l2_m2m_release(dev->m2m_dev); > > err_video: > > video_unregister_device(&dev->vfd); > > +err_m2m: > > + v4l2_m2m_release(dev->m2m_dev); > > err_v4l2: > > v4l2_device_unregister(&dev->v4l2_dev); > > -- Paul Kocialkowski, Bootlin Embedded Linux and kernel engineering https://bootlin.com