Laurent, Em Sat, 13 Jun 2015 10:36:44 +0300 Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx> escreveu: > Hi Mauro, > > (CC'ing Sakari) > > Thank you for the patch. > > On Friday 12 June 2015 08:31:26 Mauro Carvalho Chehab wrote: > > Since when we start discussions about the usage Media Controller > > for complex hardware, one thing become clear: the way it is, MC > > fails to map anything more complex than a webcam. > > I strongly disagree with that. The MC API works fine (albeit with entity type > names that are incorrect) on complex embedded video capture devices that are > far from being just webcams. However, I agree that the API is broken outside > of the V4L realm. By assuming that all V4L devices have DMA engines, it means that MC is broken *inside* V4L realm too. The very first V4L devices didn't have DMA at all. Radio devices (with is V4L realm since the beginning too) don't have DMA, or when they have, this don't appear at the data flow at the V4L side. Also, calling a V4L data I/O engine as DEVNODE is broken by design. The devnode is something else that may or may not have data I/O. Ok, by coincidence, the V4L devices currently mapped via MC have the data I/O engine accessible via a devnode, but this was never be a requirement of the V4L2 API. It is also broken for ALSA, and it is partially broken for DVB. The only scenario where MC works properly, ATM, is just the video path of capture/output/m2m devices. So, no, it doesn't work for complex embedded media devices, where audio, tuners, radio, no-dma video, etc may be present. So, i'll rewrite (tomorrow morning) the above paragraph to: Since when we start discussions about the usage Media Controller for complex hardware, one thing become clear: the way it is, MC fails to map anything different than capture/output/m2m video-only streaming. in order to better express that. > > > The point is that MC has entities named as devnodes, but the only > > devnode used (before the DVB patches) is MEDIA_ENT_T_DEVNODE_V4L. > > Due to the way MC got implemented, however, this entity actually > > doesn't represent the devnode, but the hardware I/O engine that > > receives data via DMA. > > > > By coincidence, such DMA is associated with the V4L device node > > on webcam hardware, but this is not true even for other V4L2 > > devices. For example, on USB hardware, the DMA is done via the > > USB controller. The data passes though a in-kernel filter that > > strips off the URB headers. Other V4L2 devices like radio may not > > even have DMA. When it have, the DMA is done via ALSA, and not > > via the V4L devnode. > > > > In other words, MC is broken as a whole, but tagging it as BROKEN > > right now would do more harm than good. > > > > So, instead, let's mark, for now, the DVB part as broken and > > block all new changes to MC while we fix this mess, whith > > we hopefully will do for the next Kernel version. > > > > Requested-by: Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx> > > Signed-off-by: Hans Verkuil <hans.verkuil@xxxxxxxxx> > > Signed-off-by: Mauro Carvalho Chehab <mchehab@xxxxxxxxxxxxxxx> > > I'm fine with the change, but I'd rework the commit message a bit. > > Acked-by: Laurent Pinchart <laurent.pinchart@xxxxxxxxxxxxxxxx> > > > diff --git a/drivers/media/Kconfig b/drivers/media/Kconfig > > index 3ef0f90b128f..157099243d61 100644 > > --- a/drivers/media/Kconfig > > +++ b/drivers/media/Kconfig > > @@ -97,6 +97,7 @@ config MEDIA_CONTROLLER > > config MEDIA_CONTROLLER_DVB > > bool "Enable Media controller for DVB" > > depends on MEDIA_CONTROLLER > > + depends on BROKEN > > ---help--- > > Enable the media controller API support for DVB. > -- To unsubscribe from this list: send the line "unsubscribe linux-media" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html