From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.lore.kernel.org (Postfix) with ESMTPS id 3F3B4C433F5 for ; Mon, 21 Feb 2022 07:18:56 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20210309; h=Sender: Content-Transfer-Encoding:Content-Type:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:References: Message-ID:Subject:Cc:To:From:Date:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=wQviLaTsHhGSp0p9MczJm9X2ziZQnKcEtMYR95rUjPg=; b=Aw1aqrI+p1mx3G DdSI06/Y9j3hP31beMTy8BbgqwgfTfV4tnYsskkd8GcTNm+5QqSmbH0ZrXil0QCReVFxrzQsmzaa7 KdyrW2dAmBk//HULl9Ij3jsqKLzbbrOenlmGASSRYoZZTlyjf41E/AmGhC8MJlCR33qULL8nItNCa w7/B0xd1vavPMUgHd/8hjL/BYZ88AAOm0ebx3OR/gVeQStJBgWNCbZaZEIqE7DF/8QaEMkAAekwSz hijyWrDKf+N76YFzFcIaOyrAgJfIeKDhpwEfjtW5iG81wXLYfZgbtqc+HmLpSDpSYZAK8dD7OsZh+ tPucBublh95PPPnlnPpw==; Received: from localhost ([::1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.94.2 #2 (Red Hat Linux)) id 1nM2wv-003xMj-CD; Mon, 21 Feb 2022 07:17:34 +0000 Received: from perceval.ideasonboard.com ([213.167.242.64]) by bombadil.infradead.org with esmtps (Exim 4.94.2 #2 (Red Hat Linux)) id 1nM2wq-003xKt-PA; Mon, 21 Feb 2022 07:17:30 +0000 Received: from pendragon.ideasonboard.com (62-78-145-57.bb.dnainternet.fi [62.78.145.57]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id 8ACCF482; Mon, 21 Feb 2022 08:17:26 +0100 (CET) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1645427847; bh=aSB52NNA4H92Oslixgeyy510diwPvOcyJd91kINF57c=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=JlSHLBrDXvdSWLwOBbH7z38SPLDPRbp/mPG/gBe+ulwi/xzqbFc6bDYXOLadUDJB4 5FYBuMgNCjUG3MPq0DvymghRTRKOwZgbbLqRyHPtFxQPq2TmC88wqbpyucwMD5IzwT oPzdhyvDd0La3qg9C2OeUUUAc1FNifOLgVy/6wuM= Date: Mon, 21 Feb 2022 09:17:16 +0200 From: Laurent Pinchart To: Jean-Michel Hautbois Cc: dave.stevenson@raspberrypi.com, devicetree@vger.kernel.org, kernel-list@raspberrypi.com, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-media@vger.kernel.org, linux-rpi-kernel@lists.infradead.org, lukasz@jany.st, mchehab@kernel.org, naush@raspberrypi.com, robh@kernel.org, tomi.valkeinen@ideasonboard.com, bcm-kernel-feedback-list@broadcom.com, stefan.wahren@i2se.com Subject: Re: [PATCH v5 09/11] media: imx219: Introduce the set_routing operation Message-ID: References: <20220208155027.891055-1-jeanmichel.hautbois@ideasonboard.com> <20220208155027.891055-10-jeanmichel.hautbois@ideasonboard.com> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: <20220208155027.891055-10-jeanmichel.hautbois@ideasonboard.com> X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20220220_231729_015542_2591B2CD X-CRM114-Status: GOOD ( 24.54 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.34 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hi Jean-Michel, Thank you for the patch. On Tue, Feb 08, 2022 at 04:50:25PM +0100, Jean-Michel Hautbois wrote: > As we want to use multiplexed streams API, we need to be able to set the > pad routing. Introduce the set_routing operation. > > As this operation is required for a multiplexed able sensor, add the > V4L2_SUBDEV_FL_MULTIPLEXED flag. > > Signed-off-by: Jean-Michel Hautbois > --- > drivers/media/i2c/imx219.c | 82 ++++++++++++++++++++++++++++++++++++-- > 1 file changed, 79 insertions(+), 3 deletions(-) > > diff --git a/drivers/media/i2c/imx219.c b/drivers/media/i2c/imx219.c > index abcaee15c4a0..35b61fad8e35 100644 > --- a/drivers/media/i2c/imx219.c > +++ b/drivers/media/i2c/imx219.c > @@ -118,6 +118,10 @@ > #define IMX219_PIXEL_ARRAY_WIDTH 3280U > #define IMX219_PIXEL_ARRAY_HEIGHT 2464U > > +/* Embedded metadata stream structure */ > +#define IMX219_EMBEDDED_LINE_WIDTH 16384 > +#define IMX219_NUM_EMBEDDED_LINES 1 > + > struct imx219_reg { > u16 address; > u8 val; > @@ -784,15 +788,85 @@ static void imx219_init_formats(struct v4l2_subdev_state *state) > format->height = supported_modes[0].height; > format->field = V4L2_FIELD_NONE; > format->colorspace = V4L2_COLORSPACE_RAW; > + > + if (state->routing.routes[1].flags & V4L2_SUBDEV_ROUTE_FL_ACTIVE) { There's no guarantee the routing table will have 2 entries. > + format = v4l2_state_get_stream_format(state, 0, 1); > + format->code = MEDIA_BUS_FMT_METADATA_8; > + format->width = IMX219_EMBEDDED_LINE_WIDTH; > + format->height = 1; > + format->field = V4L2_FIELD_NONE; > + format->colorspace = V4L2_COLORSPACE_DEFAULT; > + } > } > > -static int imx219_init_cfg(struct v4l2_subdev *sd, > - struct v4l2_subdev_state *state) > +static int __imx219_set_routing(struct v4l2_subdev *sd, > + struct v4l2_subdev_state *state) > { > + struct v4l2_subdev_route routes[] = { > + { > + .source_pad = 0, > + .source_stream = 0, > + .flags = V4L2_SUBDEV_ROUTE_FL_IMMUTABLE | > + V4L2_SUBDEV_ROUTE_FL_SOURCE | > + V4L2_SUBDEV_ROUTE_FL_ACTIVE, > + }, > + { }, { > + .source_pad = 0, > + .source_stream = 1, > + .flags = V4L2_SUBDEV_ROUTE_FL_SOURCE | > + V4L2_SUBDEV_ROUTE_FL_ACTIVE, > + } > + }; That doesn't look right. You're hardcoding the routes, disregarding completely what userspace wants to program. This default configuration must move to .init_cfg(). > + > + struct v4l2_subdev_krouting routing = { > + .num_routes = ARRAY_SIZE(routes), > + .routes = routes, > + }; > + > + int ret; > + > + ret = v4l2_subdev_set_routing(sd, state, &routing); > + if (ret) > + return ret; > + > imx219_init_formats(state); > + > return 0; > } > > +static int imx219_set_routing(struct v4l2_subdev *sd, > + struct v4l2_subdev_state *state, > + enum v4l2_subdev_format_whence which, > + struct v4l2_subdev_krouting *routing) > +{ > + int ret; > + > + if (routing->num_routes == 0 || routing->num_routes > 2) > + return -EINVAL; > + > + v4l2_subdev_lock_state(state); Note for the future: v11 of the V4L2 streams series will handle locking in the code, so you'll have to drop this (same in .init_cfg()). > + > + ret = __imx219_set_routing(sd, state); > + > + v4l2_subdev_unlock_state(state); > + > + return ret; > +} > + > +static int imx219_init_cfg(struct v4l2_subdev *sd, > + struct v4l2_subdev_state *state) > +{ > + int ret; > + > + v4l2_subdev_lock_state(state); > + > + ret = __imx219_set_routing(sd, state); > + > + v4l2_subdev_unlock_state(state); > + > + return ret; > +} > + > static int imx219_enum_mbus_code(struct v4l2_subdev *sd, > struct v4l2_subdev_state *sd_state, > struct v4l2_subdev_mbus_code_enum *code) > @@ -1251,6 +1325,7 @@ static const struct v4l2_subdev_pad_ops imx219_pad_ops = { > .get_fmt = imx219_get_pad_format, > .set_fmt = imx219_set_pad_format, > .get_selection = imx219_get_selection, > + .set_routing = imx219_set_routing, > .enum_frame_size = imx219_enum_frame_size, > }; > > @@ -1509,7 +1584,8 @@ static int imx219_probe(struct i2c_client *client) > > /* Initialize subdev */ > imx219->sd.flags |= V4L2_SUBDEV_FL_HAS_DEVNODE | > - V4L2_SUBDEV_FL_HAS_EVENTS; > + V4L2_SUBDEV_FL_HAS_EVENTS | > + V4L2_SUBDEV_FL_MULTIPLEXED; > imx219->sd.entity.function = MEDIA_ENT_F_CAM_SENSOR; > > /* Initialize source pad */ -- Regards, Laurent Pinchart _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel