Re: [PATCH 01/13] media: v4l2-async: Clean v4l2_async_notifier_add_fwnode_remote_subdev semantics

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Thu, 2021-01-14 at 18:11 +0200, Sakari Ailus wrote:
> On Thu, Jan 14, 2021 at 11:46:11AM -0300, Ezequiel Garcia wrote:
> > On Thu, 2021-01-14 at 15:47 +0200, Sakari Ailus wrote:
> > > Hi Laurent, Ezequiel,
> > > 
> > > On Thu, Jan 14, 2021 at 03:59:10AM +0200, Laurent Pinchart wrote:
> > > > > diff --git a/drivers/media/platform/rockchip/rkisp1/rkisp1-dev.c b/drivers/media/platform/rockchip/rkisp1/rkisp1-dev.c
> > > > > index 68da1eed753d..235dcf0c4122 100644
> > > > > --- a/drivers/media/platform/rockchip/rkisp1/rkisp1-dev.c
> > > > > +++ b/drivers/media/platform/rockchip/rkisp1/rkisp1-dev.c
> > > > > @@ -252,6 +252,7 @@ static int rkisp1_subdev_notifier(struct rkisp1_device *rkisp1)
> > > > >                         .bus_type = V4L2_MBUS_CSI2_DPHY
> > > > >                 };
> > > > >                 struct rkisp1_sensor_async *rk_asd = NULL;
> > > > > +               struct v4l2_async_subdev *asd;
> > > > >                 struct fwnode_handle *ep;
> > > > >  
> > > > >                 ep = fwnode_graph_get_endpoint_by_id(dev_fwnode(rkisp1->dev),
> > > > > @@ -264,21 +265,16 @@ static int rkisp1_subdev_notifier(struct rkisp1_device *rkisp1)
> > > > >                 if (ret)
> > > > >                         goto err_parse;
> > > > >  
> > > > > -               rk_asd = kzalloc(sizeof(*rk_asd), GFP_KERNEL);
> > > > > -               if (!rk_asd) {
> > > > > -                       ret = -ENOMEM;
> > > > > +               asd = v4l2_async_notifier_add_fwnode_remote_subdev(ntf, ep,
> > > > > +                                                       sizeof(*rk_asd));
> > > > > +               if (IS_ERR(asd))
> > > 
> > > The problem with registering the sub-device already here is that the driver
> > > can proceed to use the information in the async sub-device object which is
> > > initialised below.
> > > 
> > 
> > Note that this interface is not really registering sub-devices.
> 
> Not directly, but this will happen as a by-product of registering the async
> sub-device and other functions that will be called. All this takes place
> synchronously, meaming that by the time this function returns, the
> character devices that are the user space interface have already been
> created.
> 

That's not the case, as I've explained before, v4l2_async_notifier_add_fwnode_remote_subdev
is _not_ about registering any actual v4l2 subdevice/char device.

It's just about adding the v4l2 async subdevice descriptor
to a given (unregistered) notifier.

Thanks,
Ezequiel




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux