On Wed, Jul 27, 2011 at 11:55:55PM -0300, Mauro Carvalho Chehab wrote: > Hi Sylwester, > > Em 27-07-2011 13:35, Sylwester Nawrocki escreveu: > > Hi Mauro, > > > > The following changes since commit f0a21151140da01c71de636f482f2eddec2840cc: > > > > Merge tag 'v3.0' into staging/for_v3.1 (2011-07-22 13:33:14 -0300) > > > > are available in the git repository at: > > > > git://git.infradead.org/users/kmpark/linux-2.6-samsung fimc-for-mauro > > > > Sylwester Nawrocki (28): > > s5p-fimc: Add support for runtime PM in the mem-to-mem driver > > s5p-fimc: Add media entity initialization > > s5p-fimc: Remove registration of video nodes from probe() > > s5p-fimc: Remove sclk_cam clock handling > > s5p-fimc: Limit number of available inputs to one > > s5p-fimc: Remove sensor management code from FIMC capture driver > > s5p-fimc: Remove v4l2_device from video capture and m2m driver > > s5p-fimc: Add the media device driver > > s5p-fimc: Conversion to use struct v4l2_fh > > s5p-fimc: Conversion to the control framework > > s5p-fimc: Add media operations in the capture entity driver > > s5p-fimc: Add PM helper function for streaming control > > s5p-fimc: Correct color format enumeration > > s5p-fimc: Convert to use media pipeline operations > > s5p-fimc: Add subdev for the FIMC processing block > > s5p-fimc: Add support for camera capture in JPEG format > > s5p-fimc: Add v4l2_device notification support for single frame capture > > s5p-fimc: Use consistent names for the buffer list functions > > s5p-fimc: Add runtime PM support in the camera capture driver > > s5p-fimc: Correct crop offset alignment on exynos4 > > s5p-fimc: Remove single-planar capability flags > > noon010pc30: Do not ignore errors in initial controls setup > > noon010pc30: Convert to the pad level ops > > noon010pc30: Clean up the s_power callback > > noon010pc30: Remove g_chip_ident operation handler > > s5p-csis: Handle all available power supplies > > s5p-csis: Rework of the system suspend/resume helpers > > s5p-csis: Enable v4l subdev device node > > From the last time you've submitted a similar set of patches: > > >> Why? The proper way to select an input is via S_INPUT. The driver > > may also > >> optionally allow changing it via the media device, but it should > > not be > >> a mandatory requirement, as the media device API is optional. > > > > The problem I'm trying to solve here is sharing the sensors and mipi-csi receivers between multiple FIMC H/W instances. Previously the driver supported attaching a sensor to only one selected FIMC at compile time. You could, for instance, specify all sensors as the selected FIMC's platform data and then use S_INPUT to choose between them. The sensor could not be used together with any other FIMC. But this is desired due to different capabilities of the FIMC IP instances. And now, instead of hardcoding a sensor assigment to particular video node, the sensors are bound to the media device. The media device driver takes the list of sensors and attaches them one by one to subsequent FIMC instances when it is initializing. Each sensor has a link to each FIMC but only one of them is active by default. That said an user application can use selected camera by opening corresponding video node. Which camera is at which node can be queried with G_INPUT. > > > > I could try to implement the previous S_INPUT behaviour, but IMHO this would lead to considerable and unnecessary driver code complication due to supporting overlapping APIs > > From this current pull request: > > From c6fb462c38be60a45d16a29a9e56c886ee0aa08c Mon Sep 17 00:00:00 2001 > From: Sylwester Nawrocki <s.nawrocki@xxxxxxxxxxx> > Date: Fri, 10 Jun 2011 20:36:51 +0200 > Subject: s5p-fimc: Conversion to the control framework > Cc: Linux Media Mailing List <linux-media@xxxxxxxxxxxxxxx> > > Make the driver inherit sensor controls when video node only API > compatibility mode is enabled. The control framework allows to > properly handle sensor controls through controls inheritance when > pipeline is re-configured at media device level. > > ... > - .vidioc_queryctrl = fimc_vidioc_queryctrl, > - .vidioc_g_ctrl = fimc_vidioc_g_ctrl, > - .vidioc_s_ctrl = fimc_cap_s_ctrl, > ... > > I'll need to take some time to review this patchset. So, it will likely > miss the bus for 3.1. > > While the code inside this patch looked ok, your comments scared me ;) > > In summary: The V4L2 API is not a legacy API that needs a "compatibility > mode". Removing controls like VIDIOC_S_INPUT, VIDIOC_*CTRL, etc in > favor of the media controller API is wrong. This specific patch itself seems > ok, but it is easy to loose the big picture on a series of 28 patches > with about 4000 lines changed. I remember this was discussed among with the last pull request on the patches. I don't remember seeing your reply in the thread after much discussion. Have you had time to read it? <URL:http://www.spinics.net/lists/linux-media/msg35504.html> In short, as far as I understand the reason why this driver doesn't support S_INPUT is exactly the same as with the OMAP 3 ISP driver. There is not enough information for the driver to perform what should be the effect of the user calling S_INPUT. If S_INPUT support is to be added (which I think is the right thing to do), it should be implemented in libv4l, not in the kernel. It involves essentially full pipeline configuration (as do things like S_FMT) which is typically very board dependent and doing that inside the driver would be quite cumbersome if not unfeasible. Someone could also claim this kind of functionality wouldn't belong to the kernel at all since most of it is policy decisions. Sincerely, -- Sakari Ailus sakari.ailus@xxxxxx -- 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