Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751504AbdH1KzO (ORCPT ); Mon, 28 Aug 2017 06:55:14 -0400 Received: from lb1-smtp-cloud7.xs4all.net ([194.109.24.24]:34365 "EHLO lb1-smtp-cloud7.xs4all.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751161AbdH1KzM (ORCPT ); Mon, 28 Aug 2017 06:55:12 -0400 Subject: Re: [PATCH v4 7/7] media: open.rst: add a notice about subdev-API on vdev-centric To: Mauro Carvalho Chehab References: <20170828073009.3762b293@vento.lan> Cc: Linux Doc Mailing List , Linux Media Mailing List , Mauro Carvalho Chehab , linux-kernel@vger.kernel.org, Jonathan Corbet , Hans Verkuil , Ramesh Shanmugasundaram From: Hans Verkuil Message-ID: <31b0ab20-3079-9c4a-e0f7-d9173b865db5@xs4all.nl> Date: Mon, 28 Aug 2017 12:55:09 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:45.0) Gecko/20100101 Thunderbird/45.7.1 MIME-Version: 1.0 In-Reply-To: <20170828073009.3762b293@vento.lan> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit X-CMAE-Envelope: MS4wfBJcFjveP2jIsg1AUMKbslYGI++zb9qVYecCemQsw1P3D5L6Ay2KR9fPMpHG6Eb765qJk8gsHpQZkxpoORUcUu/ykDxqAGnsg1qbg8jsdn3j3pDF+UrQ av75G91isTQ9AeFjZPNJMnfcD6g0hYrsy3ODX+ffG5WzeA19Din6iKTaMSWA08xEGu7u1EXJEhDw6NpRPIRDSGzMbKVbJHRalpFaAnKQJ5SaXwns78Bf8Wqz /dcj0tZDursB7JrL7mmj/mXNF8O6C5o6unOAQQEg3cFAXSDQk0sTi0PJJc+h9h+WqXqDZpMGI9Q5LERatEvS+JBqnlV89kpE+DHzxQO2dkAzB+I3tk3Ce1Ci cfVVFCXJr+8kXzt5TUC31p8BcyP7u0p67+7JtdMKkNEBZdXgJCHxO7OuyRekuT24PWHOJPNvw8lyelSsT/Qtc/I5+/RWsw== Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3707 Lines: 85 On 28/08/17 12:30, Mauro Carvalho Chehab wrote: > Em Mon, 28 Aug 2017 12:05:06 +0200 > Hans Verkuil escreveu: > >> On 26/08/17 13:53, Mauro Carvalho Chehab wrote: >>> The documentation doesn't mention if vdev-centric hardware >>> control would have subdev API or not. >>> >>> Add a notice about that, reflecting the current status, where >>> three drivers use it, in order to support some subdev-specific >>> controls. >> >> I posted a patch removing v4l-subdevX support for cobalt. It's only used >> within Cisco, so this is safe to do and won't break any userspace support. > > OK. > >> atmel-isc is another driver that creates subdev nodes. Like cobalt, this >> is unnecessary. There are no sensors that use private controls. > > The question is not if the driver has private controls. Private controls > can be V4L2 device node oriented. > > The real question is if userspace applications use subdevs or not in > order to set something specific to a subdev, on a pipeline where > multiple subdevs could use the same control. > > E. g. even on a simple case where the driver would have something like: > > sensor -> processing -> DMA > > both "sensor" and "processing" could provide the same control > (bright, contrast, gain, or whatever). Only by exposing such > control via subdev is possible to pinpoint what part of the > hardware pipeline would be affected when such control is changed. In theory, yes. In practice this does not happen for any of the V4L2-centric drivers. Including for the three drivers under discussion. > >> This driver is not referenced anywhere (dts or board file) in the kernel. >> It is highly unlikely anyone would use v4l-subdevX nodes when there is no >> need to do so. My suggestion is to add a kernel option for this driver >> to enable v4l-subdevX support, but set it to 'default n'. Perhaps with >> a note in the Kconfig description and a message in the kernel log that >> this will be removed in the future. >> >> The final driver is rcar_drif that uses this to set the "I2S Enable" >> private control of the max2175 driver. >> >> I remember that there was a long discussion over this control. I still >> think that there is no need to mark this private. > > The problem with I2S is that a device may have multiple places > where I2S could be used. I don't know how the rcar-drif driver uses > it, but there are several vdev-centric boards that use I2S for audio. > > On several of the devices I worked with, the I2S can be enabled, in > runtime, if the audio signal would be directed to some digital output, > or it can be disabled if the audio signal would be directed to some > analog output. Thankfully, on those devices, I2S can be indirectly > controlled via either an ALSA mixer or via VIDIOC A/V routing > ioctls. Also, there's just one I2S bus on them. > > However, on a device that have multiple I2S bus, userspace should > be able to control each of them individually, as some parts of the > pipeline may require it enabled while others may require it > disabled. So, I strongly believe that this should be a subdev > control on such hardware. > > That's said, I don't know how rcar_drif uses it. If it has just > one I2S bus and it is used only for audio, then VIDIOC A/V routing > ioctls and/or an ALSA mixer could replace it. If not, then > it should be kept as-is and the driver would need to add support > for MC, in order for applications to identify the right > sub-devices that are associated with the pipelines where I2S > will be controlled. Ramesh, do applications using rcar_drif + max2175 have to manually enable the i2s? Shouldn't this be part of the device tree description instead? Regards, Hans