On Fri, Jun 16, 2017 at 6:19 PM, Sakari Ailus <sakari.ailus@xxxxxx> wrote: > On Fri, Jun 16, 2017 at 06:03:13PM +0900, Tomasz Figa wrote: >> On Fri, Jun 16, 2017 at 5:49 PM, Sakari Ailus <sakari.ailus@xxxxxx> wrote: >> > Hi Tomasz, >> > >> > On Fri, Jun 16, 2017 at 05:35:52PM +0900, Tomasz Figa wrote: >> >> On Fri, Jun 16, 2017 at 5:25 PM, Sakari Ailus <sakari.ailus@xxxxxx> wrote: >> >> > Hi Tomasz, >> >> > >> >> > On Fri, Jun 16, 2017 at 02:52:07PM +0900, Tomasz Figa wrote: >> >> >> On Tue, Jun 6, 2017 at 7:09 PM, Tomasz Figa <tfiga@xxxxxxxxxxxx> wrote: >> >> >> Actually, there is one more thing, which would become possible with >> >> >> switching to different queue types. If we have a device with queues >> >> >> like this: >> >> >> - video input, >> >> >> - video output, >> >> >> - parameters, >> >> >> - statistics, >> >> >> they could all be contained within one video node simply exposing 4 >> >> >> different queues. It would actually even allow an easy implementation >> >> > >> >> > The problem comes when you have multiple queues with the same type. I >> >> > actually once proposed that (albeit for a slightly different purposes: >> >> > streams) but the idea was rejected. It was decided to use separate video >> >> > nodes instead. >> >> > >> >> >> of mem2mem, given that for mem2mem devices opening a video node means >> >> >> creating a mem2mem context (while multiple video nodes would require >> >> >> some special synchronization to map contexts together, which doesn't >> >> >> exist as of today). >> >> > >> >> > V4L2 is very stream oriented and the mem2mem interface somewhat gets around >> >> > that. There are cases where at least partially changing per-frame >> >> > configuration is needed in streaming cases as well. The request API is >> >> > supposed to resolve these issues but it has become evident that the >> >> > implementation is far from trivial. >> >> > >> >> > I'd rather like to have a more generic solution than a number of >> >> > framework-lets that have their own semantics of the generic V4L2 IOCTLs that >> >> > only work with a particular kind of a device. Once there are new kind of >> >> > devices, we'd need to implement another framework-let to support them. >> >> > >> >> > Add a CSI-2 receiver to the ImgU device and we'll need again something very >> >> > different... >> >> >> >> I need to think if Request API alone is really capable of solving this >> >> problem, but if so, it would make sense indeed. >> > >> > What comes to this driver --- the request API could be beneficial, but the >> > driver does not strictly need it. If there were controls that would need to >> > be changed during streaming or if the device contained a CSI-2 receiver, >> > then it'd be more important to have the request API. >> >> There is one use case, though, which can't be achieved easily with >> current model - processing images for two cameras at the same time. >> One could theoretically do all the S_FMT/S_WHATNOT magic every frame, >> to process the cameras in a round robin fashion, but I'm not sure if >> this would work really well in practice. > > That's true --- having to wait for all the buffers before configuring the > formats would introduce some systematic delay which would decrease the total > throughput. I'm not sure how much that would be though. The number of IOCTLs > on each frame is big but then again IOCTLs are fast. The buffer memory isn't > affected in any case. Process scheduling will be required though. If we don't need to set any controls, we might be able to actually do this without waiting, because all the processing is based on vb2 queues and all parameters could be latched into buffers at queuing time. Still, I believe it would actually require doing everything from one process or some explicit userspace-based synchronization between processes, because queuing one frame means actually queuing to multiple queues, which is not atomic. Best regards, Tomasz