Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp4950825iog; Wed, 22 Jun 2022 08:55:10 -0700 (PDT) X-Google-Smtp-Source: AGRyM1sRtMtrUmWfW15PjwcyGbhLfl8jcy5BZGdhDicr9PbhlbK7dh5KcLLHCvmBZL5H0OBgCO9k X-Received: by 2002:a17:907:9805:b0:711:dc46:e0fe with SMTP id ji5-20020a170907980500b00711dc46e0femr3643126ejc.179.1655913310142; Wed, 22 Jun 2022 08:55:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1655913310; cv=none; d=google.com; s=arc-20160816; b=YcGDwuYNTxdnPtikoND5aiAsFQD0HfuchGMUhO81fsaIygBbNla1z1ajulLdMOCP8u YoP7wVIiNJ8uG8WMCkz209gUTf3G1qwpCV7PKTjHrX1s5ng5u6ORBfnCvQEhOsl6kLrZ 7a1qhZ/esZ1zdoEnmsifayMm1QmZ53aKbs84Wt7bPNjls+6LO0baRqQ2HF+iEsXXPPGo EC+8NPo5FAmsAAynQ6uzo4ILo2qq0/QL/pgEP9v7GEOqtcoLnKMd7ET2lEOa1s0IPmBQ mZHlLKZrHa+KSAcxAtDoCgaRCN8krA0XKiPSxoI9vj8Dx+vSWWGueb45AM9VUhQ3ZWLb Qz+A== 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; bh=B3LQlccOnpjL15i0uBHmQn/MVouiG1E1SEUWNfyx5Uw=; b=IWPnPXrb7GEmxFYquAqk59JAgawYaFIs6wwDpg75UpiEk0dlL0qKjGlSK1o8VmuN2O xYs3bofFGGGnoh8RVh1t4cgmDB6WUV6N2iV4ScSotUeFhpUc3mWPKNPnyCtnSAibB+iE 2YUmBgDfH1lwZKfJ/z5fSbRg76DwNF1J+Ogq5g92+2AXaiVtxIYUWbQEPs4CcU9rSvEw QZ2AL3CNAhNLUnrLNv/gGRgxZ7xJjDPp0vDuNp3rObw1LaGlzvGX89fAY1ZYiLQ+0DyV 5n4UNQ/dvQsFkHSI8igl78IKY4wxmcLjpJQYSXPQwbyvC/qK4Tf9onVi1ZMxBmc69+0X MDNQ== ARC-Authentication-Results: i=1; mx.google.com; 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 ne23-20020a1709077b9700b006f3c9755f78si24630059ejc.671.2022.06.22.08.54.43; Wed, 22 Jun 2022 08:55:10 -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; 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 S1359470AbiFVPrD (ORCPT + 99 others); Wed, 22 Jun 2022 11:47:03 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46092 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1359452AbiFVPrB (ORCPT ); Wed, 22 Jun 2022 11:47:01 -0400 Received: from relay2-d.mail.gandi.net (relay2-d.mail.gandi.net [217.70.183.194]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A27463C4AE; Wed, 22 Jun 2022 08:46:59 -0700 (PDT) Received: (Authenticated sender: jacopo@jmondi.org) by mail.gandi.net (Postfix) with ESMTPSA id D7DAA40015; Wed, 22 Jun 2022 15:46:54 +0000 (UTC) Date: Wed, 22 Jun 2022 17:46:52 +0200 From: Jacopo Mondi To: Hans Verkuil Cc: Eugen.Hristev@microchip.com, linux-arm-kernel@lists.infradead.org, linux-media@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Claudiu.Beznea@microchip.com, Nicolas.Ferre@microchip.com Subject: Re: [PATCH v10 0/5] media: atmel: atmel-isc: implement media controller Message-ID: <20220622154652.o7be4tl64m4yrbxv@uno.localdomain> References: <20220503095127.48710-1-eugen.hristev@microchip.com> <1da61f9c-0605-dc9d-63a3-21c18fcb74c7@xs4all.nl> <20220622141439.v2ozrctikjxd67ue@uno.localdomain> <01b837f6-f8a2-1f59-45c1-f746b741f2db@xs4all.nl> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: <01b837f6-f8a2-1f59-45c1-f746b741f2db@xs4all.nl> X-Spam-Status: No, score=-2.6 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_LOW, RCVD_IN_MSPIKE_H3,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE,SPF_NONE, 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 Hans, On Wed, Jun 22, 2022 at 04:55:27PM +0200, Hans Verkuil wrote: > Hi Eugen, Jacopo, > > On 22/06/2022 16:14, Jacopo Mondi wrote: > > Hi Hans, Eugen > > > > On Wed, Jun 22, 2022 at 03:47:33PM +0200, Hans Verkuil wrote: > >> On 22/06/2022 14:42, Eugen.Hristev@microchip.com wrote: > >>> On 6/22/22 3:25 PM, Eugen Hristev - M18282 wrote: > >>>> On 6/22/22 2:53 PM, Hans Verkuil wrote: > >>>>> Hi Eugen, > >>>>> > >>>>> On 03/05/2022 11:51, Eugen Hristev wrote: > >>>>>> This series is a split from the series : > >>>>>> [PATCH v9 00/13] media: atmel: atmel-isc: implement media controller > >>>>>> and it includes the media controller part. > >>>>>> previous fixes were sent on a different patch series. > >>>>>> > >>>>>> As discussed on the ML, moving forward with having the media link validate at > >>>>>> start/stop streaming call. > >>>>>> I will test the patch : > >>>>>> [RFC PATCHv2] vb2: add support for (un)prepare_streaming queue ops > >>>>>> afterwards, but that patch requires moving my logic to the new vb2 callbacks. > >>>>> > >>>>> I'm looking at merging this series, but I would like to have the output of > >>>>> 'v4l2-compliance -m /dev/mediaX' to verify that the MC links etc. is all > >>>>> correct. > >>>> > >>>> Hello Hans, > >>>> > >>>> Please have a look at attached file . Unless you want me to add the > >>>> whole output to the e-mail ? > >>>> > >>>> I also added output of media-ctl -p for your convenience. > >>>> the subdev2 is a device and driver that is not upstream and has some > >>>> compliance issues, they are reported by the v4l2-compliance tool, but > >>>> they should not affect this series, it's a synopsys driver that was > >>>> rejected on mainline a few years ago, I took it for internal usage, but > >>>> it's not cleaned up nor worked a lot upon. > >>>> > >>>>> > >>>>> And one more question which may have been answered already in the past: > >>>>> > >>>>> Changing to the MC will break existing applications, doesn't it? Or did I > >>>>> miss something? > >>>>> > >>>> > >>>> The existing applications will have to configure the pipeline now. It > >>>> will no longer work by configuring just the top video node /dev/video0 . > >>>> They would have to use media-ctl for it, something similar with this set > >>>> of commands: > >>> > >>> To add on top of that, actually, the reality is that without the MC > >>> support in atmel-isc , some of our platforms do not work at all, because > >>> the csi2dc driver which is in the middle of the pipeline, is a MC > >>> driver. So it will not work without configuring it with MC anyway. It > >>> used to work in a very preliminary version of the csi2dc driver which I > >>> sent a few years ago, but that way of handling things was rejected. > >>> Hence I changed the csi2dc to being full-MC driver (requested for new > >>> drivers) and now I am completing the conversion for the whole pipeline. > >>> We are using this MC-centric approach in production for our products to > >>> be as close as possible to mainline, and backported it to our 5.15 > >>> internal releases, which people are using right now. > >> > >> I'm not all that keen on breaking userspace for those who do NOT use the > >> Atmel BSP. Basically some platforms are currently broken, and with this patch > >> series some other platforms are broken, but at least can be fixed by changing > >> userspace. > >> > >> How feasible is it to do something similar that TI did for the cal driver? > >> (drivers/media/platform/ti/cal) > >> > >> I.e., based on a module option the MC is enabled or disabled. And if a > >> csi2dc is present, then the MC API is always enabled. > >> > > > > I think I have suggested Eugen to move to MC when he > > started looking in libcamera, so sorry for the intrusion but I feel > > a bit bad for not rising the point earlier and get him to v10 > > > > I understand your point Hans, and when a vendor upstreaming code or a > > user requires to maintain compatibility, the burden of keeping more > > code in to handle the MC and non-MC cases is worth the complications. > > Eugen, can you provide a list of platforms that will break with this > change and which platforms are currently broken without this series? > > I'm trying to get a bit of a feel of the potential problems this change > will introduce. > > > > > But if even the vendor wants to move to MC to allow more use-cases I > > think we have to acknolege that if you're running mainline on an > > embedded system you could expect to adjust your setup between kernel > > updates. The idea to document the media-ctl commands required to setup > > the pipeline it's helpful, and might help in the interim period until > > the platform is not supported by libcamera. > > Well, I don't want Linus to start yelling at me for breaking userspace :-) > > We have broken userspace API (intentionally) in the past, but only with > good reasons. And sometimes a driver is used so rarely that it is not worth > the effort to try and keep compatible. > > As a developer I'd love to just forget about the old API, but as subsystem > maintainer I need good arguments. I understand and I think these are all valid concerns. Finding a balance between new features and legacy is not easy. > > Another option might be to take the TI cal approach, but have warnings that > it will be removed in, say, 2 years time. Or even make a copy of the driver > for the old platforms, and perhaps move that to staging to be removed eventually. > > The idea of a sudden breakage when going from kernel K to K+1 doesn't sit > well with me, if there was a transition period of 1-2 years then that would be > better. > If staging works for you that's probably the easiest option. Let's see what Eugen prefers! > Regards, > > Hans > > > > > That said, if Eugen wants to give the flag a try I won't > > oppose :) > > > > > >> Regards, > >> > >> Hans > >> > >>> > >>>> > >>>> media-ctl -d /dev/media0 --set-v4l2 '"imx219 > >>>> 1-0010":0[fmt:SRGGB10_1X10/1920x1080]' > >>>> media-ctl -d /dev/media0 --set-v4l2 > >>>> '"dw-csi.0":0[fmt:SRGGB10_1X10/1920x1080]' > >>>> media-ctl -d /dev/media0 --set-v4l2 '"csi2dc":0[fmt:SRGGB10_1X10/1920x1080]' > >>>> media-ctl -d /dev/media0 --set-v4l2 > >>>> '"atmel_isc_scaler":0[fmt:SRGGB10_1X10/1920x1080]' > >>>> > >>>> Thank you for taking care of this ! > >>>> > >>>> Eugen > >>>> > >>>>> Regards, > >>>>> > >>>>> Hans > >>>>> > >>>>>> > >>>>>> Full series history: > >>>>>> > >>>>>> Changes in v10: > >>>>>> -> split the series into this first fixes part. > >>>>>> -> moved IO_MC addition from first patch to the second patch on the driver changes > >>>>>> -> edited commit messages > >>>>>> -> DT nodes now disabled by default. > >>>>>> > >>>>>> Changes in v9: > >>>>>> -> kernel robot reported isc_link_validate is not static, changed to static. > >>>>>> > >>>>>> Changes in v8: > >>>>>> -> scaler: modified crop bounds to have the exact source size > >>>>>> > >>>>>> Changes in v7: > >>>>>> -> scaler: modified crop bounds to have maximum isc size > >>>>>> -> format propagation: did small changes as per Jacopo review > >>>>>> > >>>>>> > >>>>>> Changes in v6: > >>>>>> -> worked a bit on scaler, added try crop and other changes as per Jacopo review > >>>>>> -> worked on isc-base enum_fmt , reworked as per Jacopo review > >>>>>> > >>>>>> Changes in v5: > >>>>>> -> removed patch that removed the 'stop' variable as it was still required > >>>>>> -> added two new trivial patches > >>>>>> -> reworked some parts of the scaler and format propagation after discussions with Jacopo > >>>>>> > >>>>>> > >>>>>> Changes in v4: > >>>>>> -> as reviewed by Hans, added new patch to remove the 'stop' variable and reworked > >>>>>> one patch that was using it > >>>>>> -> as reviewed by Jacopo, reworked some parts of the media controller implementation > >>>>>> > >>>>>> > >>>>>> Changes in v3: > >>>>>> - change in bindings, small fixes in csi2dc driver and conversion to mc > >>>>>> for the isc-base. > >>>>>> - removed some MAINTAINERS patches and used patterns in MAINTAINERS > >>>>>> > >>>>>> Changes in v2: > >>>>>> - integrated many changes suggested by Jacopo in the review of the v1 series. > >>>>>> - add a few new patches > >>>>>> > >>>>>> Eugen Hristev (5): > >>>>>> media: atmel: atmel-isc: prepare for media controller support > >>>>>> media: atmel: atmel-isc: implement media controller > >>>>>> ARM: dts: at91: sama7g5: add nodes for video capture > >>>>>> ARM: configs: at91: sama7: add xisc and csi2dc > >>>>>> ARM: multi_v7_defconfig: add atmel video pipeline modules > >>>>>> > >>>>>> arch/arm/boot/dts/sama7g5.dtsi | 51 ++ > >>>>>> arch/arm/configs/multi_v7_defconfig | 3 + > >>>>>> arch/arm/configs/sama7_defconfig | 2 + > >>>>>> drivers/media/platform/atmel/Makefile | 2 +- > >>>>>> drivers/media/platform/atmel/atmel-isc-base.c | 485 +++++++++--------- > >>>>>> .../media/platform/atmel/atmel-isc-scaler.c | 267 ++++++++++ > >>>>>> drivers/media/platform/atmel/atmel-isc.h | 50 +- > >>>>>> .../media/platform/atmel/atmel-sama5d2-isc.c | 34 +- > >>>>>> .../media/platform/atmel/atmel-sama7g5-isc.c | 32 +- > >>>>>> 9 files changed, 685 insertions(+), 241 deletions(-) > >>>>>> create mode 100644 drivers/media/platform/atmel/atmel-isc-scaler.c > >>>>>> > >>>>> > >>>> > >>> > >> >