Hi Prabhakar, On Thu, 21 Aug 2025 at 18:19, Prabhakar <prabhakar.csengg@xxxxxxxxx> wrote: > From: Lad Prabhakar <prabhakar.mahadev-lad.rj@xxxxxxxxxxxxxx> > > Enable USB2.0 support on RZ/T2H and RZ/N2H EVKs. > > Signed-off-by: Lad Prabhakar <prabhakar.mahadev-lad.rj@xxxxxxxxxxxxxx> Thanks for your patch! > --- a/arch/arm64/boot/dts/renesas/r9a09g077m44-rzt2h-evk.dts > +++ b/arch/arm64/boot/dts/renesas/r9a09g077m44-rzt2h-evk.dts > @@ -29,6 +29,28 @@ > */ > #define SD1_MICRO_SD 1 > > +/* > + * USB Pin Configuration: > + * > + * This board is equipped with three USB connectors: Type-A (CN80), Mini-B (CN79), > + * and Micro-AB (CN33). The RZ/T2H SoC has a single USB channel, so either the USB > + * host interface or the USB function interface can be used, but not both at the > + * same time. Please reflow the text to fit in 80 columns. The last sentence applies to the CN80 and CN79 connectors only, right? > + * > + * By default, the Type-A (CN80) and Mini-B (CN79) connectors are enabled. > + * Configure the switches as follows: > + * - P00_0 - P00_2 (control signals for USB power supply): SW1[5] = ON > + * - USB_VBUSIN (used for USB function): SW7[7] = OFF; SW7[8] = ON > + * - USB_VBUSEN (used for USB_HF_VBUSEN): SW7[9] = OFF; SW7[10] = ON > + * > + * To enable the Micro-AB (CN33) USB OTG connector, set the following macro to 1 > + * and configure the switches as follows: > + * - P00_0 - P00_2 (control signals for USB power supply): SW1[5] = ON > + * - USB_VBUSIN (used for USB OTG): SW7[7] = ON; SW7[8] = OFF > + * - USB_VBUSEN (used for USB_OTG_VBUSEN): SW7[9] = ON; SW7[10] = OFF > + */ > +#define USB_OTG 0 > + > #include "rzt2h-n2h-evk-common.dtsi" > > / { > @@ -145,4 +167,18 @@ i2c1_pins: i2c1-pins { > pinmux = <RZT2H_PORT_PINMUX(5, 0, 0x17)>, /* SDA */ > <RZT2H_PORT_PINMUX(4, 7, 0x17)>; /* SCL */ > }; > + > +#if USB_OTG > + usb-exicen-hog { > + gpio-hog; > + gpios = <RZT2H_GPIO(0, 2) GPIO_ACTIVE_HIGH>; > + output-high; > + line-name = "usb_exicen_a"; > + }; > +#endif > + > + usb_pins: usb-pins { > + pinmux = <RZT2H_PORT_PINMUX(0, 0, 0x13)>, /* VBUS */ s/VBUS/VBUSEN/? > + <RZT2H_PORT_PINMUX(0, 1, 0x13)>; /* OVRCUR */ > + }; > }; > diff --git a/arch/arm64/boot/dts/renesas/r9a09g087m44-rzn2h-evk.dts b/arch/arm64/boot/dts/renesas/r9a09g087m44-rzn2h-evk.dts > index 80f358fb2d74..b98b0f7c1128 100644 > --- a/arch/arm64/boot/dts/renesas/r9a09g087m44-rzn2h-evk.dts > +++ b/arch/arm64/boot/dts/renesas/r9a09g087m44-rzn2h-evk.dts > @@ -33,6 +33,33 @@ > */ > #define SD1_MICRO_SD 1 > > +/* > + * USB Pin Configuration: > + * > + * This board is equipped with three USB connectors: Type-A (CN7), Mini-B (CN8), > + * and Micro-AB (CN9). The RZ/N2H SoC has a single USB channel, so either the USB > + * host interface or the USB function interface can be used, but not both at the > + * same time. Please reflow the text to fit in 80 columns. The last sentence applies to the CN7 and CN8 connectors only, right? > + * > + * By default, the Type-A (CN7) and Mini-B (CN8) connectors are enabled. > + * Configure the switches as follows: > + * - P02_2 - P02_3 (control signals for USB power supply): DSW2[6] = OFF; s/DSW2[6]/DSW2[5]/? > + * - P02_2 (used for VBUSEN): DSW14[5] = OFF; DSW14[6] = ON > + * - P02_3 (used for USB_OVRCUR): DSW14[1] = OFF; DSW14[2] = ON > + * - USB_VBUSIN (used for VBUS of CN8 for function): DSW16[1] = OFF; DSW16[2] = ON > + * - USB_VBUSEN (used for USB_HF_VBUSEN): DSW16[3] = OFF; DSW16[4] = ON > + * > + * To enable the Micro-AB (CN9) USB OTG connector, set the following macro to 1 > + * and configure the switches as follows: > + * - P02_2 - P02_3 (control signals for USB power supply): DSW2[6] = OFF; s/DSW2[6]/DSW2[5]/? > + * - P02_2 (used for VBUSEN): DSW14[5] = OFF; DSW14[6] = ON > + * - P02_3 (used for USB_OVRCUR): DSW14[1] = OFF; DSW14[2] = ON > + * - USB_VBUSIN (used for VBUS of CN9 for OTG): DSW16[1] = ON; DSW16[2] = OFF > + * - USB_VBUSEN (used for USB_OTG_VBUSEN): DSW16[3] = ON; DSW16[4] = OFF > + * - USB_EXICEN (used for USB OTG EXICEN): DSW14[3] = OFF; DSW14[4] = ON Looks like you could use P00_0 - P00_2 instead of P02_2 - P02_3, like on the RZ/T2H EVK? But you don't want to do that because you want to use these pins for Ethernet? > + */ > +#define USB_OTG 0 > + > #include "rzt2h-n2h-evk-common.dtsi" > > /* > @@ -185,4 +212,18 @@ i2c1_pins: i2c1-pins { > pinmux = <RZT2H_PORT_PINMUX(3, 3, 0x17)>, > <RZT2H_PORT_PINMUX(3, 4, 0x17)>; > }; > + > +#if USB_OTG > + usb-exicen-hog { > + gpio-hog; > + gpios = <RZT2H_GPIO(2, 4) GPIO_ACTIVE_HIGH>; > + output-high; > + line-name = "usb_exicen_a"; > + }; > +#endif > + > + usb_pins: usb-pins { > + pinmux = <RZT2H_PORT_PINMUX(2, 2, 0x13)>, /* VBUS */ s/VBUS/VBUSEN/? > + <RZT2H_PORT_PINMUX(2, 3, 0x13)>; /* OVRCUR */ > + }; > }; The rest LGTM. Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- geert@xxxxxxxxxxxxxx In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds