пн, 27 жовт. 2025 р. о 18:30 Hans Verkuil <[email protected]> пише: > > On 27/10/2025 17:26, Svyatoslav Ryhel wrote: > > пн, 27 жовт. 2025 р. о 18:08 Hans Verkuil <[email protected]> пише: > >> > >> Hi Svyatoslav, > >> > >> On 22/10/2025 16:20, Svyatoslav Ryhel wrote: > >>> Add support for MIPI CSI device found in Tegra20 and Tegra30 SoC along > >>> with a set of changes required for that. > >> > >> Other than patch 06/23 that looked iffy (although the original code was > >> iffy as > >> already), for which I posted a review, this series looks almost ready. > > > > 06/23 addresses issue I have encountered while testing with mt9m114 I > > will add detailed explanation later in the 06/23 commit discussion. > > > >> > >> Should the clk patches be merged together with the media patches? Or can > >> those > >> go in via the clk subsystem? If it is the latter, then I'll need an > >> Acked-by from the > >> clk subsystem maintainer. > >> > > > > I suppose this should be discussed between staging and clk subsystem > > maintainers I am fine with any conclusion. > > > >> Regarding the bindings: all except 21/23 are Acked. > > > > Maybe you did not notice, but 21/23 has reviewed-by from Rob Herring. > > Ah yes, Rob replied. Good. > > > > >> > >> I have one question regarding testing: in the past I tested this driver > >> with a > >> Jetson TX1 devkit and a camera sensor. One of the main reasons this driver > >> is still > >> in staging is that I never got that to work reliably: after 10-30 minutes > >> it would > >> lose sync and streaming would stop. > >> > >> Unfortunately I never had the time to dig deeper into that. > >> > >> So have you tested this with a camera sensor? And if so, does it stream > >> reliably? > >> I.e. just let it stream for 24 hours and see if that works. > >> > >> If it is reliable for you, then I think this driver should be moved to > >> drivers/media. > > > > Streaming works but I did not tested for such prolonged periods of > > time. Scope of this patchset is bringing CSI support for > > Tegra20/Tegra30, extended testing and move to media can be done in > > followup. > > I'd really appreciate it if you can do a duration test. Perhaps start > streaming on > Friday and let it run for the weekend?
With all do respect this will not happen any time soon. > Regards, > > Hans > > > > >> > >> Regards, > >> > >> Hans > >> > >>> > >>> --- > >>> Changes in v2: > >>> - vi_sensor gated through csus > >>> - TEGRA30_CLK_CLK_MAX moved to clk-tegra30 > >>> - adjusted commit titles and messages > >>> - clk_register_clkdev dropped from pad clock registration > >>> - removed tegra30-vi/vip and used tegra20 fallback > >>> - added separate csi schema for tegra20-csi and tegra30-csi > >>> - fixet number of VI channels > >>> - adjusted tegra_vi_out naming > >>> - fixed yuv_input_format to main_input_format > >>> - MIPI calibration refsctored for Tegra114+ and added support for > >>> pre-Tegra114 to use CSI as a MIPI calibration device > >>> - switched ENOMEM to EBUSY > >>> - added check into tegra_channel_get_remote_csi_subdev > >>> - moved avdd-dsi-csi-supply into CSI > >>> - next_fs_sp_idx > next_fs_sp_value > >>> - removed host1x_syncpt_incr from framecounted syncpoint > >>> - csi subdev request moved before frame cycle > >>> > >>> Changes in v3: > >>> - tegra20 and tegra30 csi schema merged > >>> - removed unneeded properties and requirements from schema > >>> - improved vendor specific properties description > >>> - added tegra20 csus parent mux > >>> - improved commit descriptions > >>> - redesigned MIPI-calibration to expose less SoC related data into header > >>> - commit "staging: media: tegra-video: csi: add support for SoCs with > >>> integrated > >>> MIPI calibration" dropped as unneeded > >>> - improved tegra_channel_get_remote_device_subdev logic > >>> - avdd-dsi-csi-supply moved from vi to csi for p2597 and p3450-0000 > >>> - software syncpoint counters switched to direct reading > >>> - adjusted planar formats offset calculation > >>> > >>> Changes in v4: > >>> - removed ifdefs from tegra_mipi_driver > >>> - document Tegra132 MIPI calibration device > >>> - switched to use BIT macro in tegra114-mipi > >>> - pinctrl changes moved to a separate patch > >>> - ERESTARTSYS workaround preserved for now > >>> - tegra_mipi_add_provider replaced with devm_tegra_mipi_add_provider > >>> - reworked bytesperline and sizeimage calculaion > >>> > >>> Changes in v5: > >>> - dropped patch 1/24 of v4 since it was picked to pinctrl tree > >>> - added reasoning for tegra132 comaptible into commit desctiption > >>> - moved clocks into common section in tegra20-csi schema > >>> - added note regarding ERESTARTSYS > >>> --- > >>> > >>> Svyatoslav Ryhel (23): > >>> clk: tegra: set CSUS as vi_sensor's gate for Tegra20, Tegra30 and > >>> Tegra114 > >>> dt-bindings: clock: tegra30: Add IDs for CSI pad clocks > >>> clk: tegra30: add CSI pad clock gates > >>> dt-bindings: display: tegra: document Tegra30 VI and VIP > >>> staging: media: tegra-video: expand VI and VIP support to Tegra30 > >>> staging: media: tegra-video: vi: adjust get_selection op check > >>> staging: media: tegra-video: vi: add flip controls only if no source > >>> controls are provided > >>> staging: media: tegra-video: csi: move CSI helpers to header > >>> gpu: host1x: convert MIPI to use operation function pointers > >>> dt-bindings: display: tegra: document Tegra132 MIPI calibration device > >>> staging: media: tegra-video: vi: improve logic of source requesting > >>> staging: media: tegra-video: csi: move avdd-dsi-csi-supply from VI to > >>> CSI > >>> arm64: tegra: move avdd-dsi-csi-supply into CSI node > >>> staging: media: tegra-video: tegra20: set correct maximum width and > >>> height > >>> staging: media: tegra-video: tegra20: add support for second output of > >>> VI > >>> staging: media: tegra-video: tegra20: adjust format align calculations > >>> staging: media: tegra-video: tegra20: set VI HW revision > >>> staging: media: tegra-video: tegra20: increase maximum VI clock > >>> frequency > >>> staging: media: tegra-video: tegra20: expand format support with > >>> RAW8/10 and YUV422/YUV420p 1X16 > >>> staging: media: tegra-video: tegra20: adjust luma buffer stride > >>> dt-bindings: display: tegra: document Tegra20 and Tegra30 CSI > >>> ARM: tegra: add CSI nodes for Tegra20 and Tegra30 > >>> staging: media: tegra-video: add CSI support for Tegra20 and Tegra30 > >>> > >>> .../display/tegra/nvidia,tegra114-mipi.yaml | 1 + > >>> .../display/tegra/nvidia,tegra20-csi.yaml | 138 +++ > >>> .../display/tegra/nvidia,tegra20-vi.yaml | 19 +- > >>> .../display/tegra/nvidia,tegra20-vip.yaml | 9 +- > >>> arch/arm/boot/dts/nvidia/tegra20.dtsi | 19 +- > >>> arch/arm/boot/dts/nvidia/tegra30.dtsi | 24 +- > >>> .../arm64/boot/dts/nvidia/tegra210-p2597.dtsi | 4 +- > >>> .../boot/dts/nvidia/tegra210-p3450-0000.dts | 4 +- > >>> drivers/clk/tegra/clk-tegra114.c | 7 +- > >>> drivers/clk/tegra/clk-tegra20.c | 20 +- > >>> drivers/clk/tegra/clk-tegra30.c | 21 +- > >>> drivers/gpu/drm/tegra/dsi.c | 1 + > >>> drivers/gpu/host1x/Makefile | 1 + > >>> drivers/gpu/host1x/mipi.c | 525 ++--------- > >>> drivers/gpu/host1x/tegra114-mipi.c | 483 +++++++++++ > >>> drivers/staging/media/tegra-video/Makefile | 1 + > >>> drivers/staging/media/tegra-video/csi.c | 70 +- > >>> drivers/staging/media/tegra-video/csi.h | 16 + > >>> drivers/staging/media/tegra-video/tegra20.c | 820 +++++++++++++++--- > >>> drivers/staging/media/tegra-video/vi.c | 56 +- > >>> drivers/staging/media/tegra-video/vi.h | 6 +- > >>> drivers/staging/media/tegra-video/video.c | 8 +- > >>> drivers/staging/media/tegra-video/vip.c | 4 +- > >>> include/dt-bindings/clock/tegra30-car.h | 3 +- > >>> include/linux/host1x.h | 10 - > >>> include/linux/tegra-mipi-cal.h | 57 ++ > >>> 26 files changed, 1657 insertions(+), 670 deletions(-) > >>> create mode 100644 > >>> Documentation/devicetree/bindings/display/tegra/nvidia,tegra20-csi.yaml > >>> create mode 100644 drivers/gpu/host1x/tegra114-mipi.c > >>> create mode 100644 include/linux/tegra-mipi-cal.h > >>> > >> >
