From: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>
To: "G.N. Zhou (OSS)" <guoniu.zhou@oss.nxp.com>,
Linus Walleij <linusw@kernel.org>
Cc: Mauro Carvalho Chehab <mchehab@kernel.org>,
Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>, Frank Li <frank.li@nxp.com>,
Vladimir Zapolskiy <vz@mleia.com>,
Bartosz Golaszewski <brgl@kernel.org>,
"linux-media@vger.kernel.org" <linux-media@vger.kernel.org>,
"devicetree@vger.kernel.org" <devicetree@vger.kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"imx@lists.linux.dev" <imx@lists.linux.dev>,
"linux-gpio@vger.kernel.org" <linux-gpio@vger.kernel.org>,
"G.N. Zhou" <guoniu.zhou@nxp.com>
Subject: Re: [PATCH v6 1/4] dt-bindings: media: ti,ds90ub953: Add support for remote GPIO data source
Date: Tue, 28 Apr 2026 09:54:36 +0300 [thread overview]
Message-ID: <3150bbb4-ff19-4c17-9431-35d33fa97223@ideasonboard.com> (raw)
In-Reply-To: <AS8PR04MB908082A6E403407A88D3978DFA372@AS8PR04MB9080.eurprd04.prod.outlook.com>
Hi,
On 28/04/2026 09:17, G.N. Zhou (OSS) wrote:
> Hi Linus,
>
>> -----Original Message-----
>> From: Linus Walleij <linusw@kernel.org>
>> Sent: Tuesday, April 28, 2026 4:50 AM
>> To: G.N. Zhou (OSS) <guoniu.zhou@oss.nxp.com>
>> Cc: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>; Mauro Carvalho
>> Chehab <mchehab@kernel.org>; Rob Herring <robh@kernel.org>; Krzysztof
>> Kozlowski <krzk+dt@kernel.org>; Conor Dooley <conor+dt@kernel.org>; Frank
>> Li <frank.li@nxp.com>; Vladimir Zapolskiy <vz@mleia.com>; Bartosz
>> Golaszewski <brgl@kernel.org>; linux-media@vger.kernel.org;
>> devicetree@vger.kernel.org; linux-kernel@vger.kernel.org; imx@lists.linux.dev;
>> linux-gpio@vger.kernel.org; G.N. Zhou <guoniu.zhou@nxp.com>
>> Subject: Re: [PATCH v6 1/4] dt-bindings: media: ti,ds90ub953: Add support for
>> remote GPIO data source
>>
>> On Mon, Apr 27, 2026 at 11:13 AM G.N. Zhou (OSS)
>> <guoniu.zhou@oss.nxp.com> wrote:
>>> [Me]
>>
>>>> I understand that the driver needs to deal with this in a
>>>> per-gpio-line basis though, have you considered:
>>>>
>>>> 1. Just hard-coding this into the driver based on the .compatible
>>>> string, if the remote GPIOs are always the same for this TI thing?
>>>>
>>>> 2. If it is just for one particular system, you *could* actually have
>>>> a table/mask inside the driver for this:
>>>> if (of_machine_is_compatible("my-funky-system")) which will
>>>> kick in only on that very machine,
>>>>
>>>> 3. If you really want to store the information in the media i2c
>>>> device node, add some custom property like this:
>>>> ti,remote-sources = <0x0000001f>;
>>>> where a bit is set to 1 for each GPIO which is remote.
>>>>
>>>> Putting flags on the GPIO lines themselves seems too complex and
>>>> system- specific.
>>>
>>> Thank you for the detailed feedback.
>>>
>>> After considering your suggestions, I think option 3 (custom device
>>> property) is the most appropriate approach for this case.
>>
>> Why is that the most appropriate?
>>
>> I think (1) is most appropriate, if the hardware with this compatible always
>> looks like this. You need to answer the question if this is a per-system flag for
>> the GPIO lines or something that is *always* applicable for a device with
>> compatible ti,ds90ub9NN-q1?
>>
>> If it for example always applies to ti,ds90ub971-q1, then make that compatible
>> decide how to handle indvidual line, just write code for it. That is case (1).
>>
>> If this setting depends on how the serializer is integrated and the remote
>> setting may apply to some systems with this device and not others, you have
>> options (2) and (3).
>>
>>> However, I initially implemented this using a custom device property
>>> (ti,gpio-data) in v1 [1], and Vladimir rejected that approach.
>>
>> Vladimir is saying that the driver code should handle this without any extra DT
>> properties. That can be done with approach
>> (1) and (2). But I don't know about that.
>>
>> I think the basic problem with the patch is that no-one (myself included) apart
>> from you understand what a remote serializer is, why it is remote and what
>> that means, how the mechanism between the components making up this
>> essentially works etc. I.e. a much longer and more detailed commit message
>> and binding explaining very cleary what this is and how it works and why the
>> special property is needed on some lines, and how it is a property of some
>> specific way of integrating this GPIO controller.
>>
>> If a custom property should be used ti,gpio-data is too generic, come up with a
>> property name that actually says what it is all about and which anyone would
>> understand. "gpio-data" is a bit "the thing that does the thing" and overly
>> generic term.
>
> Thank you for this feedback. Let me explain the hardware architecture and the
> reason I chose option (3).
>
> Hardware Architecture:
> SoC --- I2C --- DS90UB960 (Deserializer) ---+--- FPD-Link --- DS90UB953 (Ser) --- OX03C10 Camera
> +--- FPD-Link --- DS90UB953 (Ser) --- OX03C10 Camera
> +--- FPD-Link --- DS90UB953 (Ser) --- OX03C10 Camera
> +--- FPD-Link --- DS90UB953 (Ser) --- OX03C10 Camera
>
> Each DS90UB953 serializer has 4 GPIO pins. One of these GPIOs connects to the
> OX03C10 camera's FSIN (frame sync input) pin for multi-camera synchronization.
>
> The Problem - Remote vs Local GPIO Data Source:
> -----------------------------------------------
> The DS90UB953's GPIO pins can operate in two modes:
> 1. LOCAL mode: GPIO data comes from the I2C-controlled GPIO register
> - Standard GPIO expander behavior
> - Data written via I2C controls the pin state
>
> 2. REMOTE mode: GPIO data comes from the DS90UB960 deserializer
> - The DS90UB960 generates a frame sync signal internally
While not exactly part of this series, how do you handle UB960
configuration? I don't remember all the options, but if I'm not
mistaken, a GPIO can be generated internally (e.g. frame sync you
mention), but it can also come into UB960 via a pin (could also be used
for a frame sync). And there were some debug options that can be exposed
via the GPIOs.
I'm not asking to implement all those, but I think it's worth at least
going through them, to have an idea if whatever is done now could
possibly support the other features.
> - This signal is transmitted to the DS90UB953 via the FPD-Link back channel
> - The DS90UB953 routes this remote signal to the specified GPIO pin
> - The GPIO pin state is NOT controlled by I2C register writes
>
> For camera synchronization, we need REMOTE mode: the FSIN GPIO must receive
> the frame sync signal from the deserializer, not from local I2C writes.
>
> Regarding option1, the remote GPIO configuration can vary between different board
> designs using the same TI device, so hard-coding based on .compatible wouldn't be
> flexible enough.
>
> Regarding option 2, if I understand correctly, driver would require adding a new
> compatible string or mask entry for every different board configuration, which
> doesn't scale well.
I think option 3 is okay.
Although I (perhaps naively) think that the approach in this patch feels
nicest: the user just defines the GPIO the normal way in the dts, and
marks it with a REMOTE flag. But I think the REMOTE flag should be a
device specific flag. Are those allowed?
But now, after writing the above, I wonder... If we use the REMOTE flag,
that will be in the consumer side of the GPIO, i.e. in the sensor node.
A 'ti,remote-sources' (or whatever it would be named) property would be
in the provider, the serializer node. Which one is the correct place to
configure a thing like this? The REMOTE flag is not quite like the usual
flags in gpio.h, as the sensor works fine (wrt. the gpio) with or
without the REMOTE flag.
So maybe 'ti,remote-sources' in the serializer node is better, after
all, to configure where the serializer gets the GPIOs value...
As for doing this configuration at runtime, with no DT changes... In
theory that would be possible with custom V4L2 controls to both the
serializer and the deserializer. But I don't know how the user could
ever know how to configure it, without having detailed information about
the HW.
For example, let's say the board generates a frame sync signal (a pulse,
30 Hz), which is connected to deserializer's GPIO pin X. The deser needs
to be configured to take the signal from pin X, and forward it to
serializers 0,1,2,3. Then the serializer needs to be configured to use
the "remote" gpio X from the deser, and provide it from the serializer's
GPIO pin, going to the sensor.
Tomi
next prev parent reply other threads:[~2026-04-28 6:54 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-04-24 1:42 [PATCH v6 0/4] media: i2c: ds90ub953: Add back channel GPIO support Guoniu Zhou
2026-04-24 1:42 ` [PATCH v6 1/4] dt-bindings: media: ti,ds90ub953: Add support for remote GPIO data source Guoniu Zhou
2026-04-24 17:09 ` Conor Dooley
2026-04-27 8:12 ` G.N. Zhou (OSS)
2026-04-27 19:22 ` Conor Dooley
2026-04-26 8:36 ` Linus Walleij
2026-04-27 9:12 ` G.N. Zhou (OSS)
2026-04-27 20:50 ` Linus Walleij
2026-04-28 6:17 ` G.N. Zhou (OSS)
2026-04-28 6:54 ` Tomi Valkeinen [this message]
2026-04-29 18:59 ` Linus Walleij
2026-04-24 1:42 ` [PATCH v6 2/4] media: i2c: ds90ub953: Add back channel GPIO support Guoniu Zhou
2026-04-24 1:42 ` [PATCH v6 3/4] media: i2c: ds90ub953: use devm_mutex_init() to simplify code Guoniu Zhou
2026-04-24 8:14 ` Bartosz Golaszewski
2026-04-24 1:42 ` [PATCH v6 4/4] media: i2c: ds90ub953: use guard() " Guoniu Zhou
2026-04-24 8:15 ` Bartosz Golaszewski
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=3150bbb4-ff19-4c17-9431-35d33fa97223@ideasonboard.com \
--to=tomi.valkeinen@ideasonboard.com \
--cc=brgl@kernel.org \
--cc=conor+dt@kernel.org \
--cc=devicetree@vger.kernel.org \
--cc=frank.li@nxp.com \
--cc=guoniu.zhou@nxp.com \
--cc=guoniu.zhou@oss.nxp.com \
--cc=imx@lists.linux.dev \
--cc=krzk+dt@kernel.org \
--cc=linusw@kernel.org \
--cc=linux-gpio@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-media@vger.kernel.org \
--cc=mchehab@kernel.org \
--cc=robh@kernel.org \
--cc=vz@mleia.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox