Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp25310302rwd; Sun, 2 Jul 2023 14:58:09 -0700 (PDT) X-Google-Smtp-Source: APBJJlEdRCrb3GOl7UuAbp1FqRXEnlNf+ow8qEpnOsRzPTkCdKlEICa5tti//RvTzdfy/cep2QcC X-Received: by 2002:a05:6a00:17a5:b0:661:4a00:1ea5 with SMTP id s37-20020a056a0017a500b006614a001ea5mr10640396pfg.20.1688335089128; Sun, 02 Jul 2023 14:58:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1688335089; cv=none; d=google.com; s=arc-20160816; b=Tk/1kecZGBhiPvp49k4V1i5kAT91zf/J2KX4fK3wXR5Q84bcOTvLpdCXQCy3h3giuH VdMds0mP3u32Ebsqrsmt9bO5UhGrthZIoJlXA+LdvrljBjTL6w1WBKOuXrZ4K6gMvqmx qtjypucUfakfJUHbEoq/e5Xnc6MeDPYMC0kqbiR5MM5rIR/ujjVwRgSi3MF6DVaFwUIk kCCfAEph17C4EzVTn1IXL4BKyLR4VRVX/ilkzGG3NpHqU5T2msPgbWGFabJ7bw81xcix afiaTfX3LR/njSGRFgYOEYpJ1j7NXr+6qkqno+RJ2duHFtMRtIIqyhNqAOcxT0mvRVzb mNfw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=kerZ8dPkaXjTU3qoFga/gaD85O5eDMhDYxTYNoDAUZE=; fh=RuUtcKcrDtS3voG3gBFolEZSQgPPr0LpN/+9y+J+doA=; b=gxoICxAwjg9scLZNQmskxewOFtE4rf7TMecE1FhOinoByqNunj1MiDV6PLglfEAJzQ S7mu9P2HTGRSoFvY0Uj5NpIjgD/pJN3cP10HhKLgkTAvHX2S/67o5SKEDcQEHep3LCAV SXq+iNzhvLD6aw48nucbDU/OR3gzA1J/dVQ2+jCAOkkdbyLAioM1GKkjCtUvRUcVAFAg VOrdhdmq/FMyjNifil73SphvNile/W12g+E2MZtq7xmdNOSfP15WvUzpapS4uA/wZncs xsIwc7subpFpjJRjQ48u/YVpcfS19l6HPjfhcH8aYtQpUjseB5g0e8Fwfkk73jDZdQSo frKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=m5JNQ+O3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id k15-20020a056a00134f00b0067dd87a586esi11658306pfu.377.2023.07.02.14.57.57; Sun, 02 Jul 2023 14:58:09 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass (test mode) header.i=@ideasonboard.com header.s=mail header.b=m5JNQ+O3; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229884AbjGBVrP (ORCPT + 99 others); Sun, 2 Jul 2023 17:47:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49960 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229504AbjGBVrO (ORCPT ); Sun, 2 Jul 2023 17:47:14 -0400 Received: from perceval.ideasonboard.com (perceval.ideasonboard.com [IPv6:2001:4b98:dc2:55:216:3eff:fef7:d647]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 277AC199; Sun, 2 Jul 2023 14:47:13 -0700 (PDT) Received: from pendragon.ideasonboard.com (85-160-45-219.reb.o2.cz [85.160.45.219]) by perceval.ideasonboard.com (Postfix) with ESMTPSA id A96FA289; Sun, 2 Jul 2023 23:46:27 +0200 (CEST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=ideasonboard.com; s=mail; t=1688334387; bh=2nksf4efD2NZkbTahTVPuxUB0K/S72v96EXQ0ST6jd0=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=m5JNQ+O3rT9X0NI1iRu0kalDvtpQeg92MUwoAHp1O0LBvT2ur/Si+N0kJq1Ot40zW KqfJ9UPbfa22dr8KoclKyoGh+SlR8uFJnGPTxFz3+4mUpX0ISvhy+k5S9xoxaBe99w WTmwTCqxzFCcHgq5elfEz+STlCiZNfbxkfiCiWs0= Date: Mon, 3 Jul 2023 00:47:11 +0300 From: Laurent Pinchart To: Sakari Ailus Cc: Jean-Michel Hautbois , 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 04/11] media: bcm2835-unicam: Add support for CCP2/CSI2 camera interface Message-ID: <20230702214711.GC16995@pendragon.ideasonboard.com> References: <20220208155027.891055-1-jeanmichel.hautbois@ideasonboard.com> <20220208155027.891055-5-jeanmichel.hautbois@ideasonboard.com> <20230702152356.GA16995@pendragon.ideasonboard.com> <20230702214505.GB16995@pendragon.ideasonboard.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <20230702214505.GB16995@pendragon.ideasonboard.com> X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Sakari, On Mon, Jul 03, 2023 at 12:45:07AM +0300, Laurent Pinchart wrote: > On Sun, Jul 02, 2023 at 06:18:21PM +0000, Sakari Ailus wrote: > > On Sun, Jul 02, 2023 at 06:23:56PM +0300, Laurent Pinchart wrote: > > > On Fri, Feb 25, 2022 at 11:29:18AM +0200, Sakari Ailus wrote: > > > > On Tue, Feb 08, 2022 at 04:50:20PM +0100, Jean-Michel Hautbois wrote: > > > > > Add driver for the Unicam camera receiver block on BCM283x processors. > > > > > It is represented as two video device nodes: unicam-image and > > > > > unicam-embedded which are connected to an internal subdev (named > > > > > unicam-subdev) in order to manage streams routing. > > > > > > > > > > Signed-off-by: Dave Stevenson > > > > > Signed-off-by: Naushir Patuck > > > > > Signed-off-by: Jean-Michel Hautbois > > > > > > > > > > --- > > > > > v4: > > > > > - Add the vendor prefox for DT name > > > > > - Use the reg-names in DT parsing > > > > > - Remove MAINTAINERS entry > > > > > > > > > > v3 main changes: > > > > > - Change code organization > > > > > - Remove unused variables > > > > > - Correct the fmt_meta functions > > > > > - Rewrite the start/stop streaming > > > > > - You can now start the image node alone, but not the metadata one > > > > > - The buffers are allocated per-node > > > > > - only the required stream is started, if the route exists and is > > > > > enabled > > > > > - Prefix the macros with UNICAM_ to not have too generic names > > > > > - Drop colorspace support > > > > > -> This is causing issues in the try-fmt v4l2-compliance test > > > > > test VIDIOC_G_FMT: OK > > > > > fail: v4l2-test-formats.cpp(363): colorspace >= 0xff > > > > > fail: v4l2-test-formats.cpp(465): testColorspace(!node->is_io_mc, pix.pixelformat, pix.colorspace, pix.ycbcr_enc, pix.quantization) > > > > > test VIDIOC_TRY_FMT: FAIL > > > > > fail: v4l2-test-formats.cpp(363): colorspace >= 0xff > > > > > fail: v4l2-test-formats.cpp(465): testColorspace(!node->is_io_mc, pix.pixelformat, pix.colorspace, pix.ycbcr_enc, pix.quantization) > > > > > test VIDIOC_S_FMT: FAIL > > > > > > > > > > v2: Remove the unicam_{info,debug,error} macros and use > > > > > dev_dbg/dev_err instead. > > > > > --- > > > > > drivers/media/platform/Kconfig | 1 + > > > > > drivers/media/platform/Makefile | 2 + > > > > > drivers/media/platform/bcm2835/Kconfig | 21 + > > > > > drivers/media/platform/bcm2835/Makefile | 3 + > > > > > .../platform/bcm2835/bcm2835-unicam-regs.h | 253 ++ > > > > > .../media/platform/bcm2835/bcm2835-unicam.c | 2570 +++++++++++++++++ > > > > > 6 files changed, 2850 insertions(+) > > > > > create mode 100644 drivers/media/platform/bcm2835/Kconfig > > > > > create mode 100644 drivers/media/platform/bcm2835/Makefile > > > > > create mode 100644 drivers/media/platform/bcm2835/bcm2835-unicam-regs.h > > > > > create mode 100644 drivers/media/platform/bcm2835/bcm2835-unicam.c > > > > > > [snip] > > > > > > > > diff --git a/drivers/media/platform/bcm2835/bcm2835-unicam-regs.h b/drivers/media/platform/bcm2835/bcm2835-unicam-regs.h > > > > > new file mode 100644 > > > > > index 000000000000..b8d297076a02 > > > > > --- /dev/null > > > > > +++ b/drivers/media/platform/bcm2835/bcm2835-unicam-regs.h > > > > > > [snip] > > > > > > > > +static int unicam_connect_of_subdevs(struct unicam_device *unicam) > > > > > +{ > > > > > + struct v4l2_fwnode_endpoint ep = { }; > > > > > + struct fwnode_handle *ep_handle; > > > > > + struct v4l2_async_subdev *asd; > > > > > + unsigned int lane; > > > > > + int ret = -EINVAL; > > > > > + > > > > > + if (of_property_read_u32(unicam->dev->of_node, "brcm,num-data-lanes", > > > > > + &unicam->max_data_lanes) < 0) { > > > > > > > > As you're already using fwnode API below, you could use > > > > device_property_read_u32() here. > > > > > > > > You can then replace of_device.h by mod_devicetable.h. Up to you. > > > > > > > > > + dev_err(unicam->dev, "DT property %s not set\n", > > > > > + "brcm,num-data-lanes"); > > > > > + return -EINVAL; > > > > > + } > > > > > + > > > > > + /* Get the local endpoint and remote device. */ > > > > > + ep_handle = fwnode_graph_get_endpoint_by_id(dev_fwnode(unicam->dev), > > > > > + 0, 0, > > > > > + FWNODE_GRAPH_ENDPOINT_NEXT); > > > > > + if (!ep_handle) { > > > > > + dev_err(unicam->dev, "No endpoint\n"); > > > > > + return -ENODEV; > > > > > + } > > > > > + > > > > > + /* Parse the local endpoint and validate its configuration. */ > > > > > + if (v4l2_fwnode_endpoint_alloc_parse(ep_handle, &ep)) { > > > > > > > > As you don't need link-frequencies property parsing, you should use > > > > v4l2_fwnode_endpoint_parse(). That avoids having to call > > > > v4l2_fwnode_endpoint_free(). > > > > > > > > > + dev_err(unicam->dev, "could not parse endpoint\n"); > > > > > + goto cleanup_exit; > > > > > + } > > > > > + > > > > > + dev_dbg(unicam->dev, "parsed local endpoint, bus_type %u\n", > > > > > + ep.bus_type); > > > > > + > > > > > + unicam->bus_type = ep.bus_type; > > > > > + > > > > > + switch (ep.bus_type) { > > > > > + case V4L2_MBUS_CSI2_DPHY: > > > > > + switch (ep.bus.mipi_csi2.num_data_lanes) { > > > > > + case 1: > > > > > + case 2: > > > > > + case 4: > > > > > + break; > > > > > + > > > > > + default: > > > > > + dev_err(unicam->dev, "%u data lanes not supported\n", > > > > > + ep.bus.mipi_csi2.num_data_lanes); > > > > > + goto cleanup_exit; > > > > > + } > > > > > + > > > > > + for (lane = 0; lane < ep.bus.mipi_csi2.num_data_lanes; lane++) { > > > > > + if (ep.bus.mipi_csi2.data_lanes[lane] != lane + 1) { > > > > > + dev_err(unicam->dev, "data lanes reordering not supported\n"); > > > > > + goto cleanup_exit; > > > > > + } > > > > > + } > > > > > + > > > > > + if (ep.bus.mipi_csi2.num_data_lanes > unicam->max_data_lanes) { > > > > > + dev_err(unicam->dev, "endpoint requires %u data lanes when %u are supported\n", > > > > > + ep.bus.mipi_csi2.num_data_lanes, > > > > > + unicam->max_data_lanes); > > > > > + } > > > > > + > > > > > + unicam->active_data_lanes = ep.bus.mipi_csi2.num_data_lanes; > > > > > + unicam->bus_flags = ep.bus.mipi_csi2.flags; > > > > > + > > > > > + break; > > > > > + > > > > > + case V4L2_MBUS_CCP2: > > > > > + if (ep.bus.mipi_csi1.clock_lane != 0 || > > > > > + ep.bus.mipi_csi1.data_lane != 1) { > > > > > + dev_err(unicam->dev, "unsupported lanes configuration\n"); > > > > > > > > If the hardware doesn't support lane remapping for CCP2, then that should > > > > be reflected in DT bindings, i.e. data-lanes isn't relevant. There's no > > > > need to check that here. > > > > > > Should the above check for CSI-2 be dropped as well then ? > > > > Same for CSI-2, too: if there's nothing to configure there (lane remapping) > > there's no need to validate that part of the DT either. > > OK, I'll drop that. Actually, I'm wondering if it would make sense to tell the parsing functions whether lane reordering is supported or not. The checks could then be moved to the framework. What do you think ? > > > > > + goto cleanup_exit; > > > > > + } > > > > > + > > > > > + unicam->max_data_lanes = 1; > > > > > + unicam->active_data_lanes = 1; > > > > > + unicam->bus_flags = ep.bus.mipi_csi1.strobe; > > > > > + break; > > > > > + > > > > > + default: > > > > > + /* Unsupported bus type */ > > > > > + dev_err(unicam->dev, "unsupported bus type %u\n", > > > > > + ep.bus_type); > > > > > + goto cleanup_exit; > > > > > + } > > > > > + > > > > > + dev_dbg(unicam->dev, "%s bus, %u data lanes, flags=0x%08x\n", > > > > > + unicam->bus_type == V4L2_MBUS_CSI2_DPHY ? "CSI-2" : "CCP2", > > > > > + unicam->active_data_lanes, unicam->bus_flags); > > > > > > > > V4l2-fwnode already prints this information I believe. > > > > > > True. It does so with pr_debug() though, it would be nice to use > > > dev_dbg(). That's a candidate for a separate fix of course. > > > > The reason for using pr_debug() is that the device isn't used by the fwnode > > framework. Would you add that just for debug prints? Note that the device > > nodes themselves are already being printed so it adds little to the > > usefulness of the messages. > > I'll send patches, we can discuss their usefulness there. -- Regards, Laurent Pinchart