public inbox for linux-media@vger.kernel.org
 help / color / mirror / Atom feed
From: Jacopo Mondi <jacopo.mondi@ideasonboard.com>
To: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Cc: "Jacopo Mondi" <jacopo.mondi@ideasonboard.com>,
	"Sakari Ailus" <sakari.ailus@linux.intel.com>,
	linux-media@vger.kernel.org, hans@jjverkuil.nl,
	Prabhakar <prabhakar.csengg@gmail.com>,
	"Kate Hsuan" <hpa@redhat.com>,
	"Dave Stevenson" <dave.stevenson@raspberrypi.com>,
	"Tommaso Merciai" <tomm.merciai@gmail.com>,
	"Benjamin Mugnier" <benjamin.mugnier@foss.st.com>,
	"Sylvain Petinot" <sylvain.petinot@foss.st.com>,
	"Christophe JAILLET" <christophe.jaillet@wanadoo.fr>,
	"Julien Massot" <julien.massot@collabora.com>,
	"Naushir Patuck" <naush@raspberrypi.com>,
	"Yan, Dongcheng" <dongcheng.yan@intel.com>,
	"Cao, Bingbu" <bingbu.cao@intel.com>,
	"Qiu, Tian Shu" <tian.shu.qiu@intel.com>,
	"Stefan Klug" <stefan.klug@ideasonboard.com>,
	"Mirela Rabulea" <mirela.rabulea@nxp.com>,
	"André Apitzsch" <git@apitzsch.eu>,
	"Heimir Thor Sverrisson" <heimir.sverrisson@gmail.com>,
	"Kieran Bingham" <kieran.bingham@ideasonboard.com>,
	"Mehdi Djait" <mehdi.djait@linux.intel.com>,
	"Ricardo Ribalda Delgado" <ribalda@kernel.org>,
	"Hans de Goede" <hansg@kernel.org>,
	"Tomi Valkeinen" <tomi.valkeinen@ideasonboard.com>,
	"David Plowman" <david.plowman@raspberrypi.com>,
	"Yu, Ong Hock" <ong.hock.yu@intel.com>,
	"Ng, Khai Wen" <khai.wen.ng@intel.com>,
	"Jai Luthra" <jai.luthra@ideasonboard.com>,
	"Rishikesh Donadkar" <r-donadkar@ti.com>
Subject: Re: [PATCH v4 25/29] media: v4l2-subdev: Move subdev client capabilities into a new struct
Date: Thu, 23 Apr 2026 09:02:24 +0200	[thread overview]
Message-ID: <aenBi86NWAFj3N9V@zed> (raw)
In-Reply-To: <20260416173015.GQ1775831@killaraus.ideasonboard.com>

Hi Laurent

On Thu, Apr 16, 2026 at 08:30:15PM +0300, Laurent Pinchart wrote:
> On Mon, Apr 13, 2026 at 02:42:03PM +0200, Jacopo Mondi wrote:
> > On Mon, Apr 13, 2026 at 11:11:33AM +0300, Sakari Ailus wrote:
> > > On Fri, Apr 10, 2026 at 03:31:32PM +0200, Jacopo Mondi wrote:
> > > > On Wed, Apr 08, 2026 at 06:39:34PM +0300, Sakari Ailus wrote:
> > > > > Add struct v4l2_subdev_client_info to hold sub-device client capability
> > > > > bits that used to be stored in the client_caps field of struct
> > > > > v4l2_subdev_fh. The intent is to enable passing this struct to sub-device
> > > > > pad operation callbacks for capability information. The main reason why
> > > > > this is a new struct instead of a u64 field is that modifying the callback
> > > > > arguments requires touching almost every sub-device driver and that is
> > > > > desirable to avoid in the future, should more than the client capability bits
> > > > > need to be known to the callbacks.
> > > > >
> > > > > Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
> > > > > Reviewed-by: Mirela Rabulea <mirela.rabulea@nxp.com>
> > > > > ---
> > > > >  drivers/media/v4l2-core/v4l2-subdev.c |  8 ++++----
> > > > >  include/media/v4l2-subdev.h           | 12 ++++++++++--
> > > > >  2 files changed, 14 insertions(+), 6 deletions(-)
> > > > >
> > > > > diff --git a/drivers/media/v4l2-core/v4l2-subdev.c b/drivers/media/v4l2-core/v4l2-subdev.c
> > > > > index 40b28e070726..eaa408832c6b 100644
> > > > > --- a/drivers/media/v4l2-core/v4l2-subdev.c
> > > > > +++ b/drivers/media/v4l2-core/v4l2-subdev.c
> > > > > @@ -612,7 +612,7 @@ subdev_ioctl_get_state(struct v4l2_subdev *sd, struct v4l2_subdev_fh *subdev_fh,
> > > > >  	case VIDIOC_SUBDEV_S_FRAME_INTERVAL: {
> > > > >  		struct v4l2_subdev_frame_interval *fi = arg;
> > > > >
> > > > > -		if (!(subdev_fh->client_caps &
> > > > > +		if (!(subdev_fh->ci.client_caps &
> > > > >  		      V4L2_SUBDEV_CLIENT_CAP_INTERVAL_USES_WHICH))
> > > > >  			fi->which = V4L2_SUBDEV_FORMAT_ACTIVE;
> > > > >
> > > > > @@ -652,7 +652,7 @@ static long subdev_do_ioctl(struct file *file, unsigned int cmd, void *arg,
> > > > >  	struct v4l2_subdev_fh *subdev_fh = to_v4l2_subdev_fh(vfh);
> > > > >  	bool ro_subdev = test_bit(V4L2_FL_SUBDEV_RO_DEVNODE, &vdev->flags);
> > > > >  	bool streams_subdev = sd->flags & V4L2_SUBDEV_FL_STREAMS;
> > > > > -	bool client_supports_streams = subdev_fh->client_caps &
> > > > > +	bool client_supports_streams = subdev_fh->ci.client_caps &
> > > > >  				       V4L2_SUBDEV_CLIENT_CAP_STREAMS;
> > > > >  	int rval;
> > > > >
> > > > > @@ -1119,7 +1119,7 @@ static long subdev_do_ioctl(struct file *file, unsigned int cmd, void *arg,
> > > > >  	case VIDIOC_SUBDEV_G_CLIENT_CAP: {
> > > > >  		struct v4l2_subdev_client_capability *client_cap = arg;
> > > > >
> > > > > -		client_cap->capabilities = subdev_fh->client_caps;
> > > > > +		client_cap->capabilities = subdev_fh->ci.client_caps;
> > > > >
> > > > >  		return 0;
> > > > >  	}
> > > > > @@ -1139,7 +1139,7 @@ static long subdev_do_ioctl(struct file *file, unsigned int cmd, void *arg,
> > > > >  		client_cap->capabilities &= (V4L2_SUBDEV_CLIENT_CAP_STREAMS |
> > > > >  					     V4L2_SUBDEV_CLIENT_CAP_INTERVAL_USES_WHICH);
> > > > >
> > > > > -		subdev_fh->client_caps = client_cap->capabilities;
> > > > > +		subdev_fh->ci.client_caps = client_cap->capabilities;
> > > >
> > > > I'm sorry for being annoying, but the discussion on v2 ended with the
> > > > question on why we can't propagate the client caps to the drivers
> > > > using the subdev state.
> > > >
> > > > I understand we have the active state which is stored in the subdev
> > > > and not per-file handle. But ioctls are called on a file handle and it
> > > > seems trivial to me copy the caps from the subdev_fh to the active
> > > > state.
> > > >
> > > > It would result in a much smaller set of changes.
> > > >
> > > > What am I missing ?
> > >
> > > I thought the discussion ended with the conclusion that we can't do that as
> > > the sub-device active state isn't bound to a file handle. :-)
> >
> > Can you clarify why this can't happen in your opinion ?
> >
> > Yes, the active state is not bound to any fh, but all ioctls
> > operations are issued on an fh, so it's trivial to copy the caps flags
> > in the active state before passing it to drivers.
> >
> > If this is not preferred because it feels like an hack I understand
> > it, it actually is, but I would like to think in perspective here.
>
> Storing the client caps in the state would be a hack indeed. The state
> is meant to be an object that represents the state of the device.
>
> Using it to store caps of a client means we'll need to ensure at least
> that no two clients will ever use the same state at the same time (which
> only applies to the active state), and that a state will always be
> associated with a client when a subdev operation is called.
>
> To ensure the former, we need to lock the active state before setting
> the caps field in the state, and keep it locked to call the subdev
> operation is called.
>
> The current implementation of the subdev ioctl handling code complies
> with those requirements.
>
> For the latter, it largely depends on which operation we're talking
> about. This series only adds the v4l2_subdev_client_info pointer to four
> operations: .get_fmt(), .set_fmt(), .get_selection() and
> .set_selection(). There are very few state-aware drivers calling the
> format operations manually on a subdev managed by a different driver,
> and even less calling the selection operations, and I don't expect that
> list to grow.
>
> Storing the caps in the state would be doable today, but I'm concerned
> it will cause issues later and restrict us in our ability to use subdev
> states. It could however be argued that introducing the new
> v4l2_subdev_client_info argument could be delayed to that point in time.
>
> All this being said, the only usage of client caps in subdev drivers
> today is conversion of existing sensor drivers to the new raw camera
> sensor model without breaking userspace. We have decided to propagate
> the V4L2_SUBDEV_CLIENT_CAP_COMMON_RAW_SENSOR capability to drivers to
> handle this, because we didn't find a way to handle it in the subdev
> core, but maybe there's a better solution we overlooked ?


>
> By the way, I don't think passing the client info pointer to the
> .get_fmt() operation is needed.
>
> > We want contexts, I think that's clear.
> >
> > In the design I proposed the active state will be moved from the
> > subdev to the context (when available). A state lives in a context
> > which is bound to file handle. Getting the caps from a state is then a
> > matter of providing a helpers in the form of a chain of container_of.
> >
> > The active_state which lives in the subdev will be used as a "default"
> > state, to support userspace application which are not context-aware.
> >
> > Would it be so bad to populate a v4l2_subdev_fh * in the active state
> > stored in the subdev to indicate on which file handle an ioctl has
> > been called on and retrieve the caps from there, so that the same
> > (name tbd) v4l2_subdev_get_state_caps(struct v4l2_subdev_state *state)
> > could be used ?
>
> I think that will cause trouble. States can be accessed directly from a
> client context (e.g. when servicing a subdev ioctl), but also from other
> contexts (e.g. pipeline validation when starting streaming). In the
> latter case no operation requiring client caps should be called. If we
> store client caps in the state, I fear we'll start accessing them from
> places where they shouldn't be accessed, and it would become hard to
> untangle it later.

I think this is the key point: drivers can access the state from
context where we can't guarantee a client is available (if I'm not
mistaken .s_stream() is one of them).

At the moment we don't need client caps in any of those places, but I
wouldn't feel confortable betting on this in the long run.

>
> > Adding the caps argument to driver's ioctl handlers to me pollutes the
> > interface diminishing the value of the state-centric interface we are
> > trying to implement.
>
> It's still state-centric.
>

Fair, it still is, my point was that going through the state would
have given a cleaner interface.

I'm still not in-love with adding caps to the ioctl handlers as it
feels like they will only be used by drivers that will go through
the transition to the RAW camera model, but it will affect all the
other ones as well.

> --
> Regards,
>
> Laurent Pinchart
>

  reply	other threads:[~2026-04-23  7:02 UTC|newest]

Thread overview: 116+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-04-08 15:39 [PATCH v4 00/29] Metadata series preparation Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 01/29] media: imx219: Rename "PIXEL_ARRAY" as "VISIBLE" Sakari Ailus
2026-04-16 13:14   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 02/29] media: imx219: Fix maximum frame length in lines Sakari Ailus
2026-04-16 13:56   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 03/29] media: imx219: Set horizontal blanking on mode change Sakari Ailus
2026-04-10  7:27   ` Jacopo Mondi
2026-04-16 14:22     ` Laurent Pinchart
2026-04-16 14:38     ` Dave Stevenson
2026-04-08 15:39 ` [PATCH v4 04/29] media: imx219: Scale the vblank limits according to rate_factor Sakari Ailus
2026-04-10  8:28   ` Jacopo Mondi
2026-04-10  8:41     ` Sakari Ailus
2026-04-10  9:01       ` Jacopo Mondi
2026-04-20 21:08         ` Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 05/29] media: imx219: Fix vertical blanking and exposure for analogue binning Sakari Ailus
2026-04-10  8:42   ` Jacopo Mondi
2026-04-10  8:46     ` Sakari Ailus
2026-04-10  8:56       ` Jacopo Mondi
2026-04-10  9:04         ` Sakari Ailus
2026-04-10 13:38           ` Jacopo Mondi
2026-04-15 14:38     ` Jai Luthra
2026-04-20 21:02       ` Sakari Ailus
2026-04-15 17:15   ` Jai Luthra
2026-04-20 20:54     ` Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 06/29] media: imx219: Don't update exposure limits while setting format Sakari Ailus
2026-04-10  8:44   ` Jacopo Mondi
2026-04-10 10:14     ` Sakari Ailus
2026-04-10 10:29     ` Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 07/29] media: imx219: Rename "binning" as "bin_hv" in imx219_set_pad_format Sakari Ailus
2026-04-16 14:25   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 08/29] media: imx274: Remove redundant kernel-doc comments Sakari Ailus
2026-04-10  8:48   ` Jacopo Mondi
2026-04-10  8:54     ` Sakari Ailus
2026-04-10  9:02       ` Jacopo Mondi
2026-04-16 14:26   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 09/29] media: imx334: " Sakari Ailus
2026-04-10  9:02   ` Jacopo Mondi
2026-04-16 14:27   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 10/29] media: imx335: " Sakari Ailus
2026-04-10  9:02   ` Jacopo Mondi
2026-04-16 14:27   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 11/29] media: imx412: " Sakari Ailus
2026-04-10  9:03   ` Jacopo Mondi
2026-04-16 14:28   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 12/29] media: ov9282: " Sakari Ailus
2026-04-10  9:08   ` Jacopo Mondi
2026-04-16 14:28   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 13/29] media: tvp514x: " Sakari Ailus
2026-04-10  9:08   ` Jacopo Mondi
2026-04-16 14:28   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 14/29] media: Documentation: Improve LINK_FREQ documentation Sakari Ailus
2026-04-16 15:05   ` Laurent Pinchart
2026-04-21 14:42     ` Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 15/29] media: Documentation: Improve pixel rate calculation documentation Sakari Ailus
2026-04-16 16:20   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 16/29] media: v4l2-subdev: Refactor returning routes Sakari Ailus
2026-04-16 16:24   ` Laurent Pinchart
2026-04-21 14:50     ` Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 17/29] media: v4l2-subdev: Allow accessing routes with STREAMS client capability Sakari Ailus
2026-04-16 15:06   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 18/29] media: mc: Simplify link processing in __media_pipeline_start() Sakari Ailus
2026-04-10  9:26   ` Jacopo Mondi
2026-04-16 14:35   ` Laurent Pinchart
2026-04-21 10:24     ` Sakari Ailus
2026-04-21 11:18       ` Laurent Pinchart
2026-04-21 12:37         ` Sakari Ailus
2026-04-21 22:10           ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 19/29] media: mc: Separate single link validation into a new function Sakari Ailus
2026-04-10  9:29   ` Jacopo Mondi
2026-04-16 16:35   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 20/29] media: uapi: Bump the STREAMS bit a little Sakari Ailus
2026-04-10  9:31   ` Jacopo Mondi
2026-04-16 14:31     ` Laurent Pinchart
2026-04-21 10:27       ` Sakari Ailus
2026-04-21 11:18         ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 21/29] media: mc: Don't care about unsettable flags in MEDIA_IOC_LINK_SETUP Sakari Ailus
2026-04-10 10:31   ` Jacopo Mondi
2026-04-10 12:56     ` Sakari Ailus
2026-04-10 13:24       ` Jacopo Mondi
2026-04-16 15:59   ` Laurent Pinchart
2026-04-21 10:44     ` Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 22/29] media: mc: Add MEDIA_LNK_FL_VALIDATE_LATE Sakari Ailus
2026-04-10 10:41   ` Jacopo Mondi
2026-04-13  7:59     ` Sakari Ailus
2026-04-13  9:30       ` Jacopo Mondi
2026-04-16 16:29   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 23/29] media: Improve enable_streams and disable_streams documentation Sakari Ailus
2026-04-16 15:49   ` Laurent Pinchart
2026-04-21 15:35     ` Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 24/29] media: v4l2-subdev: Introduce v4l2_subdev_get_frame_desc() Sakari Ailus
2026-04-10 10:53   ` Jacopo Mondi
2026-04-13  8:07     ` Sakari Ailus
2026-04-16 16:16       ` Laurent Pinchart
2026-04-21 12:18         ` Sakari Ailus
2026-04-21 22:18           ` Laurent Pinchart
2026-04-22  8:26             ` Sakari Ailus
2026-04-22  9:02               ` Laurent Pinchart
2026-04-22 10:02                 ` Sakari Ailus
2026-04-22 10:47                   ` Laurent Pinchart
2026-04-22 10:48                     ` Sakari Ailus
2026-04-22 10:54                       ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 25/29] media: v4l2-subdev: Move subdev client capabilities into a new struct Sakari Ailus
2026-04-10 13:31   ` Jacopo Mondi
2026-04-13  8:11     ` Sakari Ailus
2026-04-13 12:42       ` Jacopo Mondi
2026-04-16 17:30         ` Laurent Pinchart
2026-04-23  7:02           ` Jacopo Mondi [this message]
2026-04-08 15:39 ` [PATCH v4 26/29] media: v4l2-subdev: Add struct v4l2_subdev_client_info pointer to pad ops Sakari Ailus
2026-04-16 17:32   ` Laurent Pinchart
2026-04-08 15:39 ` [PATCH v4 27/29] media: v4l2-subdev: Add v4l2_subdev_call_ci_active_state Sakari Ailus
2026-04-16 17:38   ` Laurent Pinchart
2026-04-21 16:04     ` Sakari Ailus
2026-04-21 16:12       ` Laurent Pinchart
2026-04-21 16:34         ` Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 28/29] media: v4l2-subdev: Perform client info changes to i2c drivers Sakari Ailus
2026-04-08 15:39 ` [PATCH v4 29/29] media: v4l2-subdev: Add struct v4l2_subdev_client_info argument to pad ops Sakari Ailus

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=aenBi86NWAFj3N9V@zed \
    --to=jacopo.mondi@ideasonboard.com \
    --cc=benjamin.mugnier@foss.st.com \
    --cc=bingbu.cao@intel.com \
    --cc=christophe.jaillet@wanadoo.fr \
    --cc=dave.stevenson@raspberrypi.com \
    --cc=david.plowman@raspberrypi.com \
    --cc=dongcheng.yan@intel.com \
    --cc=git@apitzsch.eu \
    --cc=hans@jjverkuil.nl \
    --cc=hansg@kernel.org \
    --cc=heimir.sverrisson@gmail.com \
    --cc=hpa@redhat.com \
    --cc=jai.luthra@ideasonboard.com \
    --cc=julien.massot@collabora.com \
    --cc=khai.wen.ng@intel.com \
    --cc=kieran.bingham@ideasonboard.com \
    --cc=laurent.pinchart@ideasonboard.com \
    --cc=linux-media@vger.kernel.org \
    --cc=mehdi.djait@linux.intel.com \
    --cc=mirela.rabulea@nxp.com \
    --cc=naush@raspberrypi.com \
    --cc=ong.hock.yu@intel.com \
    --cc=prabhakar.csengg@gmail.com \
    --cc=r-donadkar@ti.com \
    --cc=ribalda@kernel.org \
    --cc=sakari.ailus@linux.intel.com \
    --cc=stefan.klug@ideasonboard.com \
    --cc=sylvain.petinot@foss.st.com \
    --cc=tian.shu.qiu@intel.com \
    --cc=tomi.valkeinen@ideasonboard.com \
    --cc=tomm.merciai@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox