[PATCH v3 1/2] arm64: dts: mediatek: mt8395-genio-1200-evk: add support for TCPC port
Macpaul Lin
macpaul.lin at mediatek.com
Thu Oct 24 00:44:16 PDT 2024
On 10/23/24 20:00, AngeloGioacchino Del Regno wrote:
> Il 23/10/24 13:07, AngeloGioacchino Del Regno ha scritto:
>> Il 23/10/24 10:09, Macpaul Lin ha scritto:
>>> From: Fabien Parent <fparent at baylibre.com>
>>>
>>> Enable USB Type-C support on MediaTek MT8395 Genio 1200 EVK by adding
>>> configuration for TCPC Port, USB-C connector, and related settings.
>>>
>>> Configure dual role switch capability, set up PD (Power Delivery)
>>> profiles,
>>> and establish endpoints for SSUSB (SuperSpeed USB).
>>>
>>> Update pinctrl configurations for U3 P0 VBus default pins and set
>>> dr_mode
>>> to "otg" for OTG (On-The-Go) mode operation.
>>>
>>> Signed-off-by: Fabien Parent <fparent at baylibre.com>
>>> Signed-off-by: Yow-Shin Liou <yow-shin.liou at mediatek.com>
>>> Signed-off-by: Simon Sun <simon.sun at yunjingtech.com>
>>> Signed-off-by: Macpaul Lin <macpaul.lin at mediatek.com>
>>> ---
>>> .../dts/mediatek/mt8395-genio-1200-evk.dts | 54 +++++++++++++++++++
>>> 1 file changed, 54 insertions(+)
>>>
>>> Changes for v2:
>>> - Drop the no need '1/2' DT Schema update patch in the 1st version.
>>> - Fix intent for 'ports' node, it should under the 'connector' node.
>>> - Correct the index for 'port at 0' and 'port at 1' node.
>>>
>>> Changes for v3:
>>> - Correct the order between new added nodes.
>>>
>>> diff --git a/arch/arm64/boot/dts/mediatek/mt8395-genio-1200-evk.dts
>>> b/arch/arm64/ boot/dts/mediatek/mt8395-genio-1200-evk.dts
>>> index 5f16fb820580..83d520226302 100644
>>> --- a/arch/arm64/boot/dts/mediatek/mt8395-genio-1200-evk.dts
>>> +++ b/arch/arm64/boot/dts/mediatek/mt8395-genio-1200-evk.dts
>>> @@ -335,6 +335,43 @@ mt6360_ldo7: ldo7 {
>>> regulator-always-on;
>>> };
>>> };
>>> +
>>> + tcpc {
>>> + compatible = "mediatek,mt6360-tcpc";
>>> + interrupts-extended = <&pio 17 IRQ_TYPE_LEVEL_LOW>;
>>> + interrupt-names = "PD_IRQB";
>>> +
>>> + connector {
>>> + compatible = "usb-c-connector";
>>> + label = "USB-C";
>>> + data-role = "dual";
>>
>> op-sink-microwatt goes here
Okay, will fix it.
>>> + power-role = "dual";
>>> + try-power-role = "sink";
>>> + source-pdos = <PDO_FIXED(5000, 1000, \
>>> + PDO_FIXED_DUAL_ROLE | \
>>> + PDO_FIXED_DATA_SWAP)>;
>>
>> Please fix the indentation (and also you don't need the escaping)
Okay, it has been complained by checkpatch about this line is too long.
Will fix it in next version.
>> source-pdos = <PDO_FIXED(5000, 1000,
>> PDO_FIXED_DUAL_ROLE |
>> PDO_FIXED_DATA_SWAP)>;
>>
>>> + sink-pdos = <PDO_FIXED(5000, 2000, \
>>> + PDO_FIXED_DUAL_ROLE | \
>>> + PDO_FIXED_DATA_SWAP)>;
>>> + op-sink-microwatt = <10000000>;
>>> +
>>> + ports {
>>> + #address-cells = <1>;
>>> + #size-cells = <0>;
>>> +
>>> + port at 0 {
>>> + reg = <0>;
>>
>> Just to make sure that this is ok: are you sure that this port supports
>> SuperSpeed (physical connector too) and that it's not limited to
>> HighSpeed?
This port should be able to do both HighSpeed and SuperSpeed.
However our internal reference code set SuperSpeed at port at 0 and seems
just work for both high and supoer speeds.
See more detail discussion below.
>>
>> I have seen Rob's comment stating that ssusb_ep goes to port at 1, but I
>> think
>> that his comment came after reading "ss" in "ssusb": while the controller
>> does surely support SS, if the port does not, this should still go to
>> port at 0.
>>
>> P.S.: I didn't check the schematics - just please make sure it's
>> correct, and
>> that this actually works.
>>
> Sorry for the double email, but I've done some fast research on this as
> something
> came to mind right after sending this review.
>
> usb-connector.yaml says that the `ports` property models a data bus to
> the USB
> connector, and that a single connector can have multiple data buses, of
> course.
>
> The last statement doesn't come as a surprise, and actually makes me
> think about
> what MTU3 actually provides: a High Speed data bus, and a SuperSpeed
> data bus.
Ya. That's the question I was wondering, too.
Current DT bindings of MTU3 support only 1 port which is also a required
property. For the SSUSB0 port on MT8195, it indeed provides a High Speed
data bus, and a SuperSpeed data bus.
> Now, I see in MTU3 that only `port` is allowed and that only the HS part is
> is exposed... so to resolve this, you want to add a binding to connect the
> data bus of the MTU3 controller to the usb-c-connector, and obviously
> only then
> you should use it here.
>
> That should look like this:
>
> mediatek,mtu3.yaml:
> ports:
> $ref: /schemas/graph.yaml#/properties/ports
>
> properties:
> port at 0:
> $ref: /schemas/graph.yaml#/properties/port
> description: High Speed (HS) data bus.
>
> port at 1:
> $ref: /schemas/graph.yaml#/properties/port
> description: Super Speed (SS) data bus.
>
> some_devicetree.dts
> &ssusb0 {
> ports {
> port at 0 {
> reg = <0>;
>
> /* High Speed data bus */
> mtu3_hs0_ep: endpoint {
> /* connects to port at 0 (HS) of usb-c-connector */
> remote-endpoint = <&typec_con_hs>;
> }
> };
>
> port at 1 {
> reg = <1>;
>
> /* SuperSpeed data bus */
> mtu3_ss0_ep: endpoint {
> /* connects to port at 1 (SS) of usb-c-connector */
> remote-endpoint = <&typec_con_sss>;
> }
> };
> };
> };
Sure, but after adding that DT schema before the v3 patch has been send.
The dt_binding_check seems show 'port' is a required property for MTU3.
However I didn't found where it has been defined.
I think to add the 'ports' property in MTU3's DT Schema should be better.
> I don't have time to do any testing in this precise moment, so, if you want
> to go on and test - cool; otherwise, I can check that at a later time, but
> on Genio 700 EVK instead (which is the same thing for this specific
> topic anyway).
>
> Cheers,
> Angelo
>
>>> + };
>>> +
>>> + port at 1 {
>>> + reg = <1>;
>>> + mt6360_ssusb_ep: endpoint {
>>> + remote-endpoint = <&ssusb_ep>;
>>> + };
>>> + };
>>> + };
>>> + };
>>> + };
>>> };
>>> };
>>> @@ -770,6 +807,13 @@ pins-reset {
>>> };
>>> };
>>> + u3_p0_vbus: u3-p0-vbus-default-pins {
>>> + pins-cmd-dat {
>>
>> That's not a command nor data pin.
Oh! Will fix it.
>> pins-vbus {
>>
>>> + pinmux = <PINMUX_GPIO63__FUNC_VBUSVALID>;
>>> + input-enable;
>>> + };
>>> + };
>>> +
>>> uart0_pins: uart0-pins {
>>> pins {
>>> pinmux = <PINMUX_GPIO98__FUNC_UTXD0>,
>>> @@ -900,8 +944,18 @@ &ufsphy {
>>> };
>>> &ssusb0 {
>>> + dr_mode = "otg";
>>> + pinctrl-names = "default";
>>> + pinctrl-0 = <&u3_p0_vbus>;
>>
>> Is this port usb host by default? If it is:
>>
>> role-switch-default-mode = "host";
This port0 is exactly a dual-role port for genio-1200-evk.
It is usually used as gadget device port (like ADB) and
sometimes can do OTG function with xhci0.
>> Cheers,
>> Angelo
>>
>>> + usb-role-switch;
>>> vusb33-supply = <&mt6359_vusb_ldo_reg>;
>>> status = "okay";
>>> +
>>> + port {
>>> + ssusb_ep: endpoint {
>>> + remote-endpoint = <&mt6360_ssusb_ep>;
>>> + };
>>> + };
>>> };
>>> &ssusb2 {
>>
Thanks
Macpaul Lin
More information about the linux-arm-kernel
mailing list