Re: Suggestion regarding x8 gang mode device tree changes

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




On 10/29/20 9:52 AM, Sakari Ailus wrote:
On Thu, Oct 29, 2020 at 09:49:57AM -0700, Sowjanya Komatineni wrote:
On 10/29/20 8:36 AM, Sowjanya Komatineni wrote:
On 10/29/20 7:50 AM, Sakari Ailus wrote:
Hi Sowjanya,

On Wed, Oct 28, 2020 at 06:48:59PM -0700, Sowjanya Komatineni wrote:
Hi Sakari,

Missed to add you to below patch series for HDMI2CSI bridge support

https://patchwork.kernel.org/project/linux-media/cover/1603768763-25590-1-git-send-email-skomatineni@xxxxxxxxxx/


Patch-10 of this series is for x8 capture from HDMI2CSI bridge.

Would like to get your suggestion on x8 gang/combined ports capture
implementation.
The majority of CSI-2 receiver devices support partitioning the
lanes among
different PHYs in various ways. They do support usually up to four
lanes,
but adding four more lanes is not a reason for making the API different.

So instead, you should implement this as a single port that simply has 8
lanes.

Thanks Sakari for your reply.

current v2 series treats as 8 lanes. You mean to not expose 2nd port in
device tree as VI/CSI side takes care of 2nd port as combined to treat
as 8 lane?
Correct.

Although you can have the second port connected if fewer lanes are assigned
to the first one.

How does it work for this device, are the lanes statically allocated to
ports, apart from the special 8 lane mode?

Tegra CSI each port supports max 4 lanes. For x8, 2 x4 ports together are programmed for simultaneous streaming during the same video/subdev stream ops.

Physically, CSI RX side 4 lanes goes to x4 port and other 4 lanes goes to another x4 port.

HDMI Bridge TX0 -> CSI RX0 (x4 port)

HDMI Bridge TX1 -> CSI RX1 (x4 port)

HDMI bridge side single image is split into 2 x4 ports and on RX side image from both ports are captured simultaneously with buffer offsets adjusted side-by-side to get combined image for same video buf of video device.

Both these 2 x4 ports together are used for streaming by Tegra VI and buffer offsets are adjusted side by side for these ports and for video device node stream, its single buffer which contains combined image from capture.

AS csi2 bus type supports max 4 data lanes with endpoint parse API.

Currently with x8 as single port, I am using bus-width with bus type as
parallel in device tree and when using x4 using data-lanes with csi2 bus
type and driver gets lanes based on either of this from DT.

Instead should we update endpoint parse API for max up to 8 lanes for
data-lanes?
Yes, please. Could you send a patch?

The standard AFAIK supports up to four lanes but as we know, hardware
sometimes has more than that.

Sure once Hans also agrees with this to have it as single x8 port (just like I have now in v2), will send v3 to update endpoint parse to allow upto max 8 data-lanes and will also update Tegra CSI driver accordingly to retrieve lanes using csi2 bus type.

Hans, Please confirm if you agree with this.




[Index of Archives]     [Linux Input]     [Video for Linux]     [Gstreamer Embedded]     [Mplayer Users]     [Linux USB Devel]     [Linux Audio Users]     [Linux Kernel]     [Linux SCSI]     [Yosemite Backpacking]

  Powered by Linux