15d4e8cb4SGeert Uytterhoeven// SPDX-License-Identifier: GPL-2.0
25d4e8cb4SGeert Uytterhoeven/*
35d4e8cb4SGeert Uytterhoeven * Device Tree Source for the Ebisu board
45d4e8cb4SGeert Uytterhoeven *
55d4e8cb4SGeert Uytterhoeven * Copyright (C) 2018 Renesas Electronics Corp.
65d4e8cb4SGeert Uytterhoeven */
75d4e8cb4SGeert Uytterhoeven
85d4e8cb4SGeert Uytterhoeven#include <dt-bindings/gpio/gpio.h>
95d4e8cb4SGeert Uytterhoeven#include <dt-bindings/input/input.h>
105d4e8cb4SGeert Uytterhoeven
115d4e8cb4SGeert Uytterhoeven/ {
125d4e8cb4SGeert Uytterhoeven	model = "Renesas Ebisu board";
135d4e8cb4SGeert Uytterhoeven	compatible = "renesas,ebisu";
145d4e8cb4SGeert Uytterhoeven
155d4e8cb4SGeert Uytterhoeven	aliases {
165d4e8cb4SGeert Uytterhoeven		serial0 = &scif2;
175d4e8cb4SGeert Uytterhoeven		ethernet0 = &avb;
185d4e8cb4SGeert Uytterhoeven		mmc0 = &sdhi3;
195d4e8cb4SGeert Uytterhoeven		mmc1 = &sdhi0;
205d4e8cb4SGeert Uytterhoeven		mmc2 = &sdhi1;
215d4e8cb4SGeert Uytterhoeven	};
225d4e8cb4SGeert Uytterhoeven
235d4e8cb4SGeert Uytterhoeven	chosen {
245d4e8cb4SGeert Uytterhoeven		bootargs = "ignore_loglevel rw root=/dev/nfs ip=on";
255d4e8cb4SGeert Uytterhoeven		stdout-path = "serial0:115200n8";
265d4e8cb4SGeert Uytterhoeven	};
275d4e8cb4SGeert Uytterhoeven
285d4e8cb4SGeert Uytterhoeven	audio_clkout: audio-clkout {
295d4e8cb4SGeert Uytterhoeven		/*
305d4e8cb4SGeert Uytterhoeven		 * This is same as <&rcar_sound 0>
315d4e8cb4SGeert Uytterhoeven		 * but needed to avoid cs2000/rcar_sound probe dead-lock
325d4e8cb4SGeert Uytterhoeven		 */
335d4e8cb4SGeert Uytterhoeven		compatible = "fixed-clock";
345d4e8cb4SGeert Uytterhoeven		#clock-cells = <0>;
355d4e8cb4SGeert Uytterhoeven		clock-frequency = <11289600>;
365d4e8cb4SGeert Uytterhoeven	};
375d4e8cb4SGeert Uytterhoeven
385d4e8cb4SGeert Uytterhoeven	backlight: backlight {
395d4e8cb4SGeert Uytterhoeven		compatible = "pwm-backlight";
405d4e8cb4SGeert Uytterhoeven		pwms = <&pwm3 0 50000>;
415d4e8cb4SGeert Uytterhoeven
425d4e8cb4SGeert Uytterhoeven		brightness-levels = <512 511 505 494 473 440 392 327 241 133 0>;
435d4e8cb4SGeert Uytterhoeven		default-brightness-level = <10>;
445d4e8cb4SGeert Uytterhoeven
455d4e8cb4SGeert Uytterhoeven		power-supply = <&reg_12p0v>;
465d4e8cb4SGeert Uytterhoeven	};
475d4e8cb4SGeert Uytterhoeven
485d4e8cb4SGeert Uytterhoeven	cvbs-in {
495d4e8cb4SGeert Uytterhoeven		compatible = "composite-video-connector";
505d4e8cb4SGeert Uytterhoeven		label = "CVBS IN";
515d4e8cb4SGeert Uytterhoeven
525d4e8cb4SGeert Uytterhoeven		port {
535d4e8cb4SGeert Uytterhoeven			cvbs_con: endpoint {
545d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&adv7482_ain7>;
555d4e8cb4SGeert Uytterhoeven			};
565d4e8cb4SGeert Uytterhoeven		};
575d4e8cb4SGeert Uytterhoeven	};
585d4e8cb4SGeert Uytterhoeven
595d4e8cb4SGeert Uytterhoeven	hdmi-in {
605d4e8cb4SGeert Uytterhoeven		compatible = "hdmi-connector";
615d4e8cb4SGeert Uytterhoeven		label = "HDMI IN";
625d4e8cb4SGeert Uytterhoeven		type = "a";
635d4e8cb4SGeert Uytterhoeven
645d4e8cb4SGeert Uytterhoeven		port {
655d4e8cb4SGeert Uytterhoeven			hdmi_in_con: endpoint {
665d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&adv7482_hdmi>;
675d4e8cb4SGeert Uytterhoeven			};
685d4e8cb4SGeert Uytterhoeven		};
695d4e8cb4SGeert Uytterhoeven	};
705d4e8cb4SGeert Uytterhoeven
715d4e8cb4SGeert Uytterhoeven	hdmi-out {
725d4e8cb4SGeert Uytterhoeven		compatible = "hdmi-connector";
735d4e8cb4SGeert Uytterhoeven		type = "a";
745d4e8cb4SGeert Uytterhoeven
755d4e8cb4SGeert Uytterhoeven		port {
765d4e8cb4SGeert Uytterhoeven			hdmi_con_out: endpoint {
775d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&adv7511_out>;
785d4e8cb4SGeert Uytterhoeven			};
795d4e8cb4SGeert Uytterhoeven		};
805d4e8cb4SGeert Uytterhoeven	};
815d4e8cb4SGeert Uytterhoeven
825d4e8cb4SGeert Uytterhoeven	keys {
835d4e8cb4SGeert Uytterhoeven		compatible = "gpio-keys";
845d4e8cb4SGeert Uytterhoeven
855d4e8cb4SGeert Uytterhoeven		pinctrl-0 = <&keys_pins>;
865d4e8cb4SGeert Uytterhoeven		pinctrl-names = "default";
875d4e8cb4SGeert Uytterhoeven
885d4e8cb4SGeert Uytterhoeven		key-1 {
895d4e8cb4SGeert Uytterhoeven			gpios = <&gpio5 10 GPIO_ACTIVE_LOW>;
905d4e8cb4SGeert Uytterhoeven			linux,code = <KEY_1>;
915d4e8cb4SGeert Uytterhoeven			label = "SW4-1";
925d4e8cb4SGeert Uytterhoeven			wakeup-source;
935d4e8cb4SGeert Uytterhoeven			debounce-interval = <20>;
945d4e8cb4SGeert Uytterhoeven		};
955d4e8cb4SGeert Uytterhoeven		key-2 {
965d4e8cb4SGeert Uytterhoeven			gpios = <&gpio5 11 GPIO_ACTIVE_LOW>;
975d4e8cb4SGeert Uytterhoeven			linux,code = <KEY_2>;
985d4e8cb4SGeert Uytterhoeven			label = "SW4-2";
995d4e8cb4SGeert Uytterhoeven			wakeup-source;
1005d4e8cb4SGeert Uytterhoeven			debounce-interval = <20>;
1015d4e8cb4SGeert Uytterhoeven		};
1025d4e8cb4SGeert Uytterhoeven		key-3 {
1035d4e8cb4SGeert Uytterhoeven			gpios = <&gpio5 12 GPIO_ACTIVE_LOW>;
1045d4e8cb4SGeert Uytterhoeven			linux,code = <KEY_3>;
1055d4e8cb4SGeert Uytterhoeven			label = "SW4-3";
1065d4e8cb4SGeert Uytterhoeven			wakeup-source;
1075d4e8cb4SGeert Uytterhoeven			debounce-interval = <20>;
1085d4e8cb4SGeert Uytterhoeven		};
1095d4e8cb4SGeert Uytterhoeven		key-4 {
1105d4e8cb4SGeert Uytterhoeven			gpios = <&gpio5 13 GPIO_ACTIVE_LOW>;
1115d4e8cb4SGeert Uytterhoeven			linux,code = <KEY_4>;
1125d4e8cb4SGeert Uytterhoeven			label = "SW4-4";
1135d4e8cb4SGeert Uytterhoeven			wakeup-source;
1145d4e8cb4SGeert Uytterhoeven			debounce-interval = <20>;
1155d4e8cb4SGeert Uytterhoeven		};
1165d4e8cb4SGeert Uytterhoeven	};
1175d4e8cb4SGeert Uytterhoeven
1185d4e8cb4SGeert Uytterhoeven	lvds-decoder {
1195d4e8cb4SGeert Uytterhoeven		compatible = "thine,thc63lvd1024";
1205d4e8cb4SGeert Uytterhoeven		vcc-supply = <&reg_3p3v>;
1215d4e8cb4SGeert Uytterhoeven
1225d4e8cb4SGeert Uytterhoeven		ports {
1235d4e8cb4SGeert Uytterhoeven			#address-cells = <1>;
1245d4e8cb4SGeert Uytterhoeven			#size-cells = <0>;
1255d4e8cb4SGeert Uytterhoeven
1265d4e8cb4SGeert Uytterhoeven			port@0 {
1275d4e8cb4SGeert Uytterhoeven				reg = <0>;
1285d4e8cb4SGeert Uytterhoeven				thc63lvd1024_in: endpoint {
1295d4e8cb4SGeert Uytterhoeven					remote-endpoint = <&lvds0_out>;
1305d4e8cb4SGeert Uytterhoeven				};
1315d4e8cb4SGeert Uytterhoeven			};
1325d4e8cb4SGeert Uytterhoeven
1335d4e8cb4SGeert Uytterhoeven			port@2 {
1345d4e8cb4SGeert Uytterhoeven				reg = <2>;
1355d4e8cb4SGeert Uytterhoeven				thc63lvd1024_out: endpoint {
1365d4e8cb4SGeert Uytterhoeven					remote-endpoint = <&adv7511_in>;
1375d4e8cb4SGeert Uytterhoeven				};
1385d4e8cb4SGeert Uytterhoeven			};
1395d4e8cb4SGeert Uytterhoeven		};
1405d4e8cb4SGeert Uytterhoeven	};
1415d4e8cb4SGeert Uytterhoeven
1425d4e8cb4SGeert Uytterhoeven	memory@48000000 {
1435d4e8cb4SGeert Uytterhoeven		device_type = "memory";
1445d4e8cb4SGeert Uytterhoeven		/* first 128MB is reserved for secure area. */
1455d4e8cb4SGeert Uytterhoeven		reg = <0x0 0x48000000 0x0 0x38000000>;
1465d4e8cb4SGeert Uytterhoeven	};
1475d4e8cb4SGeert Uytterhoeven
1485d4e8cb4SGeert Uytterhoeven	reg_1p8v: regulator0 {
1495d4e8cb4SGeert Uytterhoeven		compatible = "regulator-fixed";
1505d4e8cb4SGeert Uytterhoeven		regulator-name = "fixed-1.8V";
1515d4e8cb4SGeert Uytterhoeven		regulator-min-microvolt = <1800000>;
1525d4e8cb4SGeert Uytterhoeven		regulator-max-microvolt = <1800000>;
1535d4e8cb4SGeert Uytterhoeven		regulator-boot-on;
1545d4e8cb4SGeert Uytterhoeven		regulator-always-on;
1555d4e8cb4SGeert Uytterhoeven	};
1565d4e8cb4SGeert Uytterhoeven
1575d4e8cb4SGeert Uytterhoeven	reg_3p3v: regulator1 {
1585d4e8cb4SGeert Uytterhoeven		compatible = "regulator-fixed";
1595d4e8cb4SGeert Uytterhoeven		regulator-name = "fixed-3.3V";
1605d4e8cb4SGeert Uytterhoeven		regulator-min-microvolt = <3300000>;
1615d4e8cb4SGeert Uytterhoeven		regulator-max-microvolt = <3300000>;
1625d4e8cb4SGeert Uytterhoeven		regulator-boot-on;
1635d4e8cb4SGeert Uytterhoeven		regulator-always-on;
1645d4e8cb4SGeert Uytterhoeven	};
1655d4e8cb4SGeert Uytterhoeven
1665d4e8cb4SGeert Uytterhoeven	reg_12p0v: regulator2 {
1675d4e8cb4SGeert Uytterhoeven		compatible = "regulator-fixed";
1685d4e8cb4SGeert Uytterhoeven		regulator-name = "D12.0V";
1695d4e8cb4SGeert Uytterhoeven		regulator-min-microvolt = <12000000>;
1705d4e8cb4SGeert Uytterhoeven		regulator-max-microvolt = <12000000>;
1715d4e8cb4SGeert Uytterhoeven		regulator-boot-on;
1725d4e8cb4SGeert Uytterhoeven		regulator-always-on;
1735d4e8cb4SGeert Uytterhoeven	};
1745d4e8cb4SGeert Uytterhoeven
1755d4e8cb4SGeert Uytterhoeven	rsnd_ak4613: sound {
1765d4e8cb4SGeert Uytterhoeven		compatible = "simple-audio-card";
1775d4e8cb4SGeert Uytterhoeven
1785d4e8cb4SGeert Uytterhoeven		simple-audio-card,name = "rsnd-ak4613";
1795d4e8cb4SGeert Uytterhoeven		simple-audio-card,format = "left_j";
1805d4e8cb4SGeert Uytterhoeven		simple-audio-card,bitclock-master = <&sndcpu>;
1815d4e8cb4SGeert Uytterhoeven		simple-audio-card,frame-master = <&sndcpu>;
1825d4e8cb4SGeert Uytterhoeven
1835d4e8cb4SGeert Uytterhoeven		sndcodec: simple-audio-card,codec {
1845d4e8cb4SGeert Uytterhoeven			sound-dai = <&ak4613>;
1855d4e8cb4SGeert Uytterhoeven		};
1865d4e8cb4SGeert Uytterhoeven
1875d4e8cb4SGeert Uytterhoeven		sndcpu: simple-audio-card,cpu {
1885d4e8cb4SGeert Uytterhoeven			sound-dai = <&rcar_sound>;
1895d4e8cb4SGeert Uytterhoeven		};
1905d4e8cb4SGeert Uytterhoeven	};
1915d4e8cb4SGeert Uytterhoeven
1925d4e8cb4SGeert Uytterhoeven	vbus0_usb2: regulator-vbus0-usb2 {
1935d4e8cb4SGeert Uytterhoeven		compatible = "regulator-fixed";
1945d4e8cb4SGeert Uytterhoeven
1955d4e8cb4SGeert Uytterhoeven		regulator-name = "USB20_VBUS_CN";
1965d4e8cb4SGeert Uytterhoeven		regulator-min-microvolt = <5000000>;
1975d4e8cb4SGeert Uytterhoeven		regulator-max-microvolt = <5000000>;
1985d4e8cb4SGeert Uytterhoeven
1995d4e8cb4SGeert Uytterhoeven		gpio = <&gpio6 4 GPIO_ACTIVE_HIGH>;
2005d4e8cb4SGeert Uytterhoeven		enable-active-high;
2015d4e8cb4SGeert Uytterhoeven	};
2025d4e8cb4SGeert Uytterhoeven
2035d4e8cb4SGeert Uytterhoeven	vcc_sdhi0: regulator-vcc-sdhi0 {
2045d4e8cb4SGeert Uytterhoeven		compatible = "regulator-fixed";
2055d4e8cb4SGeert Uytterhoeven
2065d4e8cb4SGeert Uytterhoeven		regulator-name = "SDHI0 Vcc";
2075d4e8cb4SGeert Uytterhoeven		regulator-min-microvolt = <3300000>;
2085d4e8cb4SGeert Uytterhoeven		regulator-max-microvolt = <3300000>;
2095d4e8cb4SGeert Uytterhoeven
2105d4e8cb4SGeert Uytterhoeven		gpio = <&gpio5 17 GPIO_ACTIVE_HIGH>;
2115d4e8cb4SGeert Uytterhoeven		enable-active-high;
2125d4e8cb4SGeert Uytterhoeven	};
2135d4e8cb4SGeert Uytterhoeven
2145d4e8cb4SGeert Uytterhoeven	vccq_sdhi0: regulator-vccq-sdhi0 {
2155d4e8cb4SGeert Uytterhoeven		compatible = "regulator-gpio";
2165d4e8cb4SGeert Uytterhoeven
2175d4e8cb4SGeert Uytterhoeven		regulator-name = "SDHI0 VccQ";
2185d4e8cb4SGeert Uytterhoeven		regulator-min-microvolt = <1800000>;
2195d4e8cb4SGeert Uytterhoeven		regulator-max-microvolt = <3300000>;
2205d4e8cb4SGeert Uytterhoeven
2215d4e8cb4SGeert Uytterhoeven		gpios = <&gpio5 18 GPIO_ACTIVE_HIGH>;
2225d4e8cb4SGeert Uytterhoeven		gpios-states = <1>;
2235d4e8cb4SGeert Uytterhoeven		states = <3300000 1>, <1800000 0>;
2245d4e8cb4SGeert Uytterhoeven	};
2255d4e8cb4SGeert Uytterhoeven
2265d4e8cb4SGeert Uytterhoeven	vcc_sdhi1: regulator-vcc-sdhi1 {
2275d4e8cb4SGeert Uytterhoeven		compatible = "regulator-fixed";
2285d4e8cb4SGeert Uytterhoeven
2295d4e8cb4SGeert Uytterhoeven		regulator-name = "SDHI1 Vcc";
2305d4e8cb4SGeert Uytterhoeven		regulator-min-microvolt = <3300000>;
2315d4e8cb4SGeert Uytterhoeven		regulator-max-microvolt = <3300000>;
2325d4e8cb4SGeert Uytterhoeven
2335d4e8cb4SGeert Uytterhoeven		gpio = <&gpio0 4 GPIO_ACTIVE_HIGH>;
2345d4e8cb4SGeert Uytterhoeven		enable-active-high;
2355d4e8cb4SGeert Uytterhoeven	};
2365d4e8cb4SGeert Uytterhoeven
2375d4e8cb4SGeert Uytterhoeven	vccq_sdhi1: regulator-vccq-sdhi1 {
2385d4e8cb4SGeert Uytterhoeven		compatible = "regulator-gpio";
2395d4e8cb4SGeert Uytterhoeven
2405d4e8cb4SGeert Uytterhoeven		regulator-name = "SDHI1 VccQ";
2415d4e8cb4SGeert Uytterhoeven		regulator-min-microvolt = <1800000>;
2425d4e8cb4SGeert Uytterhoeven		regulator-max-microvolt = <3300000>;
2435d4e8cb4SGeert Uytterhoeven
2445d4e8cb4SGeert Uytterhoeven		gpios = <&gpio3 15 GPIO_ACTIVE_HIGH>;
2455d4e8cb4SGeert Uytterhoeven		gpios-states = <1>;
2465d4e8cb4SGeert Uytterhoeven		states = <3300000 1>, <1800000 0>;
2475d4e8cb4SGeert Uytterhoeven	};
2485d4e8cb4SGeert Uytterhoeven
2495d4e8cb4SGeert Uytterhoeven	vga {
2505d4e8cb4SGeert Uytterhoeven		compatible = "vga-connector";
2515d4e8cb4SGeert Uytterhoeven
2525d4e8cb4SGeert Uytterhoeven		port {
2535d4e8cb4SGeert Uytterhoeven			vga_in: endpoint {
2545d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&adv7123_out>;
2555d4e8cb4SGeert Uytterhoeven			};
2565d4e8cb4SGeert Uytterhoeven		};
2575d4e8cb4SGeert Uytterhoeven	};
2585d4e8cb4SGeert Uytterhoeven
2595d4e8cb4SGeert Uytterhoeven	vga-encoder {
2605d4e8cb4SGeert Uytterhoeven		compatible = "adi,adv7123";
2615d4e8cb4SGeert Uytterhoeven
2625d4e8cb4SGeert Uytterhoeven		ports {
2635d4e8cb4SGeert Uytterhoeven			#address-cells = <1>;
2645d4e8cb4SGeert Uytterhoeven			#size-cells = <0>;
2655d4e8cb4SGeert Uytterhoeven
2665d4e8cb4SGeert Uytterhoeven			port@0 {
2675d4e8cb4SGeert Uytterhoeven				reg = <0>;
2685d4e8cb4SGeert Uytterhoeven				adv7123_in: endpoint {
2695d4e8cb4SGeert Uytterhoeven					remote-endpoint = <&du_out_rgb>;
2705d4e8cb4SGeert Uytterhoeven				};
2715d4e8cb4SGeert Uytterhoeven			};
2725d4e8cb4SGeert Uytterhoeven			port@1 {
2735d4e8cb4SGeert Uytterhoeven				reg = <1>;
2745d4e8cb4SGeert Uytterhoeven				adv7123_out: endpoint {
2755d4e8cb4SGeert Uytterhoeven					remote-endpoint = <&vga_in>;
2765d4e8cb4SGeert Uytterhoeven				};
2775d4e8cb4SGeert Uytterhoeven			};
2785d4e8cb4SGeert Uytterhoeven		};
2795d4e8cb4SGeert Uytterhoeven	};
2805d4e8cb4SGeert Uytterhoeven
2815d4e8cb4SGeert Uytterhoeven	x12_clk: x12 {
2825d4e8cb4SGeert Uytterhoeven		compatible = "fixed-clock";
2835d4e8cb4SGeert Uytterhoeven		#clock-cells = <0>;
2845d4e8cb4SGeert Uytterhoeven		clock-frequency = <24576000>;
2855d4e8cb4SGeert Uytterhoeven	};
2865d4e8cb4SGeert Uytterhoeven
2875d4e8cb4SGeert Uytterhoeven	x13_clk: x13 {
2885d4e8cb4SGeert Uytterhoeven		compatible = "fixed-clock";
2895d4e8cb4SGeert Uytterhoeven		#clock-cells = <0>;
2905d4e8cb4SGeert Uytterhoeven		clock-frequency = <74250000>;
2915d4e8cb4SGeert Uytterhoeven	};
2925d4e8cb4SGeert Uytterhoeven};
2935d4e8cb4SGeert Uytterhoeven
2945d4e8cb4SGeert Uytterhoeven&audio_clk_a {
2955d4e8cb4SGeert Uytterhoeven	clock-frequency = <22579200>;
2965d4e8cb4SGeert Uytterhoeven};
2975d4e8cb4SGeert Uytterhoeven
2985d4e8cb4SGeert Uytterhoeven&avb {
2995d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&avb_pins>;
3005d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
3015d4e8cb4SGeert Uytterhoeven	phy-handle = <&phy0>;
3025d4e8cb4SGeert Uytterhoeven	status = "okay";
3035d4e8cb4SGeert Uytterhoeven
3045d4e8cb4SGeert Uytterhoeven	phy0: ethernet-phy@0 {
305*722d55f3SGeert Uytterhoeven		compatible = "ethernet-phy-id0022.1622",
306*722d55f3SGeert Uytterhoeven			     "ethernet-phy-ieee802.3-c22";
3075d4e8cb4SGeert Uytterhoeven		rxc-skew-ps = <1500>;
3085d4e8cb4SGeert Uytterhoeven		reg = <0>;
3095d4e8cb4SGeert Uytterhoeven		interrupt-parent = <&gpio2>;
3105d4e8cb4SGeert Uytterhoeven		interrupts = <21 IRQ_TYPE_LEVEL_LOW>;
3115d4e8cb4SGeert Uytterhoeven		reset-gpios = <&gpio1 20 GPIO_ACTIVE_LOW>;
3125d4e8cb4SGeert Uytterhoeven		/*
3135d4e8cb4SGeert Uytterhoeven		 * TX clock internal delay mode is required for reliable
3145d4e8cb4SGeert Uytterhoeven		 * 1Gbps communication using the KSZ9031RNX phy present on
3155d4e8cb4SGeert Uytterhoeven		 * the Ebisu board, however, TX clock internal delay mode
3165d4e8cb4SGeert Uytterhoeven		 * isn't supported on R-Car E3(e).  Thus, limit speed to
3175d4e8cb4SGeert Uytterhoeven		 * 100Mbps for reliable communication.
3185d4e8cb4SGeert Uytterhoeven		 */
3195d4e8cb4SGeert Uytterhoeven		max-speed = <100>;
3205d4e8cb4SGeert Uytterhoeven	};
3215d4e8cb4SGeert Uytterhoeven};
3225d4e8cb4SGeert Uytterhoeven
3235d4e8cb4SGeert Uytterhoeven&canfd {
3245d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&canfd0_pins>;
3255d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
3265d4e8cb4SGeert Uytterhoeven	status = "okay";
3275d4e8cb4SGeert Uytterhoeven
3285d4e8cb4SGeert Uytterhoeven	channel0 {
3295d4e8cb4SGeert Uytterhoeven		status = "okay";
3305d4e8cb4SGeert Uytterhoeven	};
3315d4e8cb4SGeert Uytterhoeven};
3325d4e8cb4SGeert Uytterhoeven
3335d4e8cb4SGeert Uytterhoeven&csi40 {
3345d4e8cb4SGeert Uytterhoeven	status = "okay";
3355d4e8cb4SGeert Uytterhoeven
3365d4e8cb4SGeert Uytterhoeven	ports {
3375d4e8cb4SGeert Uytterhoeven		port@0 {
3385d4e8cb4SGeert Uytterhoeven			csi40_in: endpoint {
3395d4e8cb4SGeert Uytterhoeven				clock-lanes = <0>;
3405d4e8cb4SGeert Uytterhoeven				data-lanes = <1 2>;
3415d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&adv7482_txa>;
3425d4e8cb4SGeert Uytterhoeven			};
3435d4e8cb4SGeert Uytterhoeven		};
3445d4e8cb4SGeert Uytterhoeven	};
3455d4e8cb4SGeert Uytterhoeven};
3465d4e8cb4SGeert Uytterhoeven
3475d4e8cb4SGeert Uytterhoeven&du {
3485d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&du_pins>;
3495d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
3505d4e8cb4SGeert Uytterhoeven	status = "okay";
3515d4e8cb4SGeert Uytterhoeven
3525d4e8cb4SGeert Uytterhoeven	clocks = <&cpg CPG_MOD 724>,
3535d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 723>,
3545d4e8cb4SGeert Uytterhoeven		 <&x13_clk>;
3555d4e8cb4SGeert Uytterhoeven	clock-names = "du.0", "du.1", "dclkin.0";
3565d4e8cb4SGeert Uytterhoeven
3575d4e8cb4SGeert Uytterhoeven	ports {
3585d4e8cb4SGeert Uytterhoeven		port@0 {
3595d4e8cb4SGeert Uytterhoeven			endpoint {
3605d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&adv7123_in>;
3615d4e8cb4SGeert Uytterhoeven			};
3625d4e8cb4SGeert Uytterhoeven		};
3635d4e8cb4SGeert Uytterhoeven	};
3645d4e8cb4SGeert Uytterhoeven};
3655d4e8cb4SGeert Uytterhoeven
3665d4e8cb4SGeert Uytterhoeven&ehci0 {
3675d4e8cb4SGeert Uytterhoeven	dr_mode = "otg";
3685d4e8cb4SGeert Uytterhoeven	status = "okay";
3695d4e8cb4SGeert Uytterhoeven};
3705d4e8cb4SGeert Uytterhoeven
3715d4e8cb4SGeert Uytterhoeven&extal_clk {
3725d4e8cb4SGeert Uytterhoeven	clock-frequency = <48000000>;
3735d4e8cb4SGeert Uytterhoeven};
3745d4e8cb4SGeert Uytterhoeven
3755d4e8cb4SGeert Uytterhoeven&hsusb {
3765d4e8cb4SGeert Uytterhoeven	dr_mode = "otg";
3775d4e8cb4SGeert Uytterhoeven	status = "okay";
3785d4e8cb4SGeert Uytterhoeven};
3795d4e8cb4SGeert Uytterhoeven
3805d4e8cb4SGeert Uytterhoeven&i2c0 {
3815d4e8cb4SGeert Uytterhoeven	status = "okay";
3825d4e8cb4SGeert Uytterhoeven
3835d4e8cb4SGeert Uytterhoeven	io_expander: gpio@20 {
3845d4e8cb4SGeert Uytterhoeven		compatible = "onnn,pca9654";
3855d4e8cb4SGeert Uytterhoeven		reg = <0x20>;
3865d4e8cb4SGeert Uytterhoeven		gpio-controller;
3875d4e8cb4SGeert Uytterhoeven		#gpio-cells = <2>;
3885d4e8cb4SGeert Uytterhoeven		interrupt-parent = <&gpio2>;
3895d4e8cb4SGeert Uytterhoeven		interrupts = <22 IRQ_TYPE_LEVEL_LOW>;
3905d4e8cb4SGeert Uytterhoeven	};
3915d4e8cb4SGeert Uytterhoeven
3925d4e8cb4SGeert Uytterhoeven	hdmi-encoder@39 {
3935d4e8cb4SGeert Uytterhoeven		compatible = "adi,adv7511w";
3945d4e8cb4SGeert Uytterhoeven		reg = <0x39>;
3955d4e8cb4SGeert Uytterhoeven		interrupt-parent = <&gpio1>;
3965d4e8cb4SGeert Uytterhoeven		interrupts = <1 IRQ_TYPE_LEVEL_LOW>;
3975d4e8cb4SGeert Uytterhoeven
3985d4e8cb4SGeert Uytterhoeven		adi,input-depth = <8>;
3995d4e8cb4SGeert Uytterhoeven		adi,input-colorspace = "rgb";
4005d4e8cb4SGeert Uytterhoeven		adi,input-clock = "1x";
4015d4e8cb4SGeert Uytterhoeven
4025d4e8cb4SGeert Uytterhoeven		ports {
4035d4e8cb4SGeert Uytterhoeven			#address-cells = <1>;
4045d4e8cb4SGeert Uytterhoeven			#size-cells = <0>;
4055d4e8cb4SGeert Uytterhoeven
4065d4e8cb4SGeert Uytterhoeven			port@0 {
4075d4e8cb4SGeert Uytterhoeven				reg = <0>;
4085d4e8cb4SGeert Uytterhoeven				adv7511_in: endpoint {
4095d4e8cb4SGeert Uytterhoeven					remote-endpoint = <&thc63lvd1024_out>;
4105d4e8cb4SGeert Uytterhoeven				};
4115d4e8cb4SGeert Uytterhoeven			};
4125d4e8cb4SGeert Uytterhoeven
4135d4e8cb4SGeert Uytterhoeven			port@1 {
4145d4e8cb4SGeert Uytterhoeven				reg = <1>;
4155d4e8cb4SGeert Uytterhoeven				adv7511_out: endpoint {
4165d4e8cb4SGeert Uytterhoeven					remote-endpoint = <&hdmi_con_out>;
4175d4e8cb4SGeert Uytterhoeven				};
4185d4e8cb4SGeert Uytterhoeven			};
4195d4e8cb4SGeert Uytterhoeven		};
4205d4e8cb4SGeert Uytterhoeven	};
4215d4e8cb4SGeert Uytterhoeven
4225d4e8cb4SGeert Uytterhoeven	video-receiver@70 {
4235d4e8cb4SGeert Uytterhoeven		compatible = "adi,adv7482";
4245d4e8cb4SGeert Uytterhoeven		reg = <0x70>;
4255d4e8cb4SGeert Uytterhoeven
4265d4e8cb4SGeert Uytterhoeven		#address-cells = <1>;
4275d4e8cb4SGeert Uytterhoeven		#size-cells = <0>;
4285d4e8cb4SGeert Uytterhoeven
4295d4e8cb4SGeert Uytterhoeven		interrupt-parent = <&gpio0>;
4305d4e8cb4SGeert Uytterhoeven		interrupt-names = "intrq1", "intrq2";
4315d4e8cb4SGeert Uytterhoeven		interrupts = <7 IRQ_TYPE_LEVEL_LOW>,
4325d4e8cb4SGeert Uytterhoeven			     <17 IRQ_TYPE_LEVEL_LOW>;
4335d4e8cb4SGeert Uytterhoeven
4345d4e8cb4SGeert Uytterhoeven		port@7 {
4355d4e8cb4SGeert Uytterhoeven			reg = <7>;
4365d4e8cb4SGeert Uytterhoeven
4375d4e8cb4SGeert Uytterhoeven			adv7482_ain7: endpoint {
4385d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&cvbs_con>;
4395d4e8cb4SGeert Uytterhoeven			};
4405d4e8cb4SGeert Uytterhoeven		};
4415d4e8cb4SGeert Uytterhoeven
4425d4e8cb4SGeert Uytterhoeven		port@8 {
4435d4e8cb4SGeert Uytterhoeven			reg = <8>;
4445d4e8cb4SGeert Uytterhoeven
4455d4e8cb4SGeert Uytterhoeven			adv7482_hdmi: endpoint {
4465d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&hdmi_in_con>;
4475d4e8cb4SGeert Uytterhoeven			};
4485d4e8cb4SGeert Uytterhoeven		};
4495d4e8cb4SGeert Uytterhoeven
4505d4e8cb4SGeert Uytterhoeven		port@a {
4515d4e8cb4SGeert Uytterhoeven			reg = <10>;
4525d4e8cb4SGeert Uytterhoeven
4535d4e8cb4SGeert Uytterhoeven			adv7482_txa: endpoint {
4545d4e8cb4SGeert Uytterhoeven				clock-lanes = <0>;
4555d4e8cb4SGeert Uytterhoeven				data-lanes = <1 2>;
4565d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&csi40_in>;
4575d4e8cb4SGeert Uytterhoeven			};
4585d4e8cb4SGeert Uytterhoeven		};
4595d4e8cb4SGeert Uytterhoeven	};
4605d4e8cb4SGeert Uytterhoeven};
4615d4e8cb4SGeert Uytterhoeven
4625d4e8cb4SGeert Uytterhoeven&i2c3 {
4635d4e8cb4SGeert Uytterhoeven	status = "okay";
4645d4e8cb4SGeert Uytterhoeven
4655d4e8cb4SGeert Uytterhoeven	ak4613: codec@10 {
4665d4e8cb4SGeert Uytterhoeven		compatible = "asahi-kasei,ak4613";
4675d4e8cb4SGeert Uytterhoeven		#sound-dai-cells = <0>;
4685d4e8cb4SGeert Uytterhoeven		reg = <0x10>;
4695d4e8cb4SGeert Uytterhoeven		clocks = <&rcar_sound 3>;
4705d4e8cb4SGeert Uytterhoeven
4715d4e8cb4SGeert Uytterhoeven		asahi-kasei,in1-single-end;
4725d4e8cb4SGeert Uytterhoeven		asahi-kasei,in2-single-end;
4735d4e8cb4SGeert Uytterhoeven		asahi-kasei,out1-single-end;
4745d4e8cb4SGeert Uytterhoeven		asahi-kasei,out2-single-end;
4755d4e8cb4SGeert Uytterhoeven		asahi-kasei,out3-single-end;
4765d4e8cb4SGeert Uytterhoeven		asahi-kasei,out4-single-end;
4775d4e8cb4SGeert Uytterhoeven		asahi-kasei,out5-single-end;
4785d4e8cb4SGeert Uytterhoeven		asahi-kasei,out6-single-end;
4795d4e8cb4SGeert Uytterhoeven	};
4805d4e8cb4SGeert Uytterhoeven
4815d4e8cb4SGeert Uytterhoeven	cs2000: clk-multiplier@4f {
4825d4e8cb4SGeert Uytterhoeven		#clock-cells = <0>;
4835d4e8cb4SGeert Uytterhoeven		compatible = "cirrus,cs2000-cp";
4845d4e8cb4SGeert Uytterhoeven		reg = <0x4f>;
4855d4e8cb4SGeert Uytterhoeven		clocks = <&audio_clkout>, <&x12_clk>;
4865d4e8cb4SGeert Uytterhoeven		clock-names = "clk_in", "ref_clk";
4875d4e8cb4SGeert Uytterhoeven
4885d4e8cb4SGeert Uytterhoeven		assigned-clocks = <&cs2000>;
4895d4e8cb4SGeert Uytterhoeven		assigned-clock-rates = <24576000>; /* 1/1 divide */
4905d4e8cb4SGeert Uytterhoeven	};
4915d4e8cb4SGeert Uytterhoeven};
4925d4e8cb4SGeert Uytterhoeven
4935d4e8cb4SGeert Uytterhoeven&i2c_dvfs {
4945d4e8cb4SGeert Uytterhoeven	status = "okay";
4955d4e8cb4SGeert Uytterhoeven
4965d4e8cb4SGeert Uytterhoeven	clock-frequency = <400000>;
4975d4e8cb4SGeert Uytterhoeven
4985d4e8cb4SGeert Uytterhoeven	pmic: pmic@30 {
4995d4e8cb4SGeert Uytterhoeven		pinctrl-0 = <&irq0_pins>;
5005d4e8cb4SGeert Uytterhoeven		pinctrl-names = "default";
5015d4e8cb4SGeert Uytterhoeven
5025d4e8cb4SGeert Uytterhoeven		compatible = "rohm,bd9571mwv";
5035d4e8cb4SGeert Uytterhoeven		reg = <0x30>;
5045d4e8cb4SGeert Uytterhoeven		interrupt-parent = <&intc_ex>;
5055d4e8cb4SGeert Uytterhoeven		interrupts = <0 IRQ_TYPE_LEVEL_LOW>;
5065d4e8cb4SGeert Uytterhoeven		interrupt-controller;
5075d4e8cb4SGeert Uytterhoeven		#interrupt-cells = <2>;
5085d4e8cb4SGeert Uytterhoeven		gpio-controller;
5095d4e8cb4SGeert Uytterhoeven		#gpio-cells = <2>;
5105d4e8cb4SGeert Uytterhoeven		rohm,ddr-backup-power = <0x1>;
5115d4e8cb4SGeert Uytterhoeven		rohm,rstbmode-level;
5125d4e8cb4SGeert Uytterhoeven	};
5135d4e8cb4SGeert Uytterhoeven
5145d4e8cb4SGeert Uytterhoeven	eeprom@50 {
5155d4e8cb4SGeert Uytterhoeven		compatible = "rohm,br24t01", "atmel,24c01";
5165d4e8cb4SGeert Uytterhoeven		reg = <0x50>;
5175d4e8cb4SGeert Uytterhoeven		pagesize = <8>;
5185d4e8cb4SGeert Uytterhoeven	};
5195d4e8cb4SGeert Uytterhoeven};
5205d4e8cb4SGeert Uytterhoeven
5215d4e8cb4SGeert Uytterhoeven&lvds0 {
5225d4e8cb4SGeert Uytterhoeven	status = "okay";
5235d4e8cb4SGeert Uytterhoeven
5245d4e8cb4SGeert Uytterhoeven	clocks = <&cpg CPG_MOD 727>,
5255d4e8cb4SGeert Uytterhoeven		 <&x13_clk>,
5265d4e8cb4SGeert Uytterhoeven		 <&extal_clk>;
5275d4e8cb4SGeert Uytterhoeven	clock-names = "fck", "dclkin.0", "extal";
5285d4e8cb4SGeert Uytterhoeven
5295d4e8cb4SGeert Uytterhoeven	ports {
5305d4e8cb4SGeert Uytterhoeven		port@1 {
5315d4e8cb4SGeert Uytterhoeven			lvds0_out: endpoint {
5325d4e8cb4SGeert Uytterhoeven				remote-endpoint = <&thc63lvd1024_in>;
5335d4e8cb4SGeert Uytterhoeven			};
5345d4e8cb4SGeert Uytterhoeven		};
5355d4e8cb4SGeert Uytterhoeven	};
5365d4e8cb4SGeert Uytterhoeven};
5375d4e8cb4SGeert Uytterhoeven
5385d4e8cb4SGeert Uytterhoeven&lvds1 {
5395d4e8cb4SGeert Uytterhoeven	/*
5405d4e8cb4SGeert Uytterhoeven	 * Even though the LVDS1 output is not connected, the encoder must be
5415d4e8cb4SGeert Uytterhoeven	 * enabled to supply a pixel clock to the DU for the DPAD output when
5425d4e8cb4SGeert Uytterhoeven	 * LVDS0 is in use.
5435d4e8cb4SGeert Uytterhoeven	 */
5445d4e8cb4SGeert Uytterhoeven	status = "okay";
5455d4e8cb4SGeert Uytterhoeven
5465d4e8cb4SGeert Uytterhoeven	clocks = <&cpg CPG_MOD 727>,
5475d4e8cb4SGeert Uytterhoeven		 <&x13_clk>,
5485d4e8cb4SGeert Uytterhoeven		 <&extal_clk>;
5495d4e8cb4SGeert Uytterhoeven	clock-names = "fck", "dclkin.0", "extal";
5505d4e8cb4SGeert Uytterhoeven};
5515d4e8cb4SGeert Uytterhoeven
5525d4e8cb4SGeert Uytterhoeven&ohci0 {
5535d4e8cb4SGeert Uytterhoeven	dr_mode = "otg";
5545d4e8cb4SGeert Uytterhoeven	status = "okay";
5555d4e8cb4SGeert Uytterhoeven};
5565d4e8cb4SGeert Uytterhoeven
5575d4e8cb4SGeert Uytterhoeven&pcie_bus_clk {
5585d4e8cb4SGeert Uytterhoeven	clock-frequency = <100000000>;
5595d4e8cb4SGeert Uytterhoeven};
5605d4e8cb4SGeert Uytterhoeven
5615d4e8cb4SGeert Uytterhoeven&pciec0 {
5625d4e8cb4SGeert Uytterhoeven	status = "okay";
5635d4e8cb4SGeert Uytterhoeven};
5645d4e8cb4SGeert Uytterhoeven
5655d4e8cb4SGeert Uytterhoeven&pfc {
5665d4e8cb4SGeert Uytterhoeven	avb_pins: avb {
5675d4e8cb4SGeert Uytterhoeven		groups = "avb_link", "avb_mii";
5685d4e8cb4SGeert Uytterhoeven		function = "avb";
5695d4e8cb4SGeert Uytterhoeven	};
5705d4e8cb4SGeert Uytterhoeven
5715d4e8cb4SGeert Uytterhoeven	canfd0_pins: canfd0 {
5725d4e8cb4SGeert Uytterhoeven		groups = "canfd0_data";
5735d4e8cb4SGeert Uytterhoeven		function = "canfd0";
5745d4e8cb4SGeert Uytterhoeven	};
5755d4e8cb4SGeert Uytterhoeven
5765d4e8cb4SGeert Uytterhoeven	du_pins: du {
5775d4e8cb4SGeert Uytterhoeven		groups = "du_rgb888", "du_sync", "du_disp", "du_clk_out_0";
5785d4e8cb4SGeert Uytterhoeven		function = "du";
5795d4e8cb4SGeert Uytterhoeven	};
5805d4e8cb4SGeert Uytterhoeven
5815d4e8cb4SGeert Uytterhoeven	irq0_pins: irq0 {
5825d4e8cb4SGeert Uytterhoeven		groups = "intc_ex_irq0";
5835d4e8cb4SGeert Uytterhoeven		function = "intc_ex";
5845d4e8cb4SGeert Uytterhoeven	};
5855d4e8cb4SGeert Uytterhoeven
5865d4e8cb4SGeert Uytterhoeven	keys_pins: keys {
5875d4e8cb4SGeert Uytterhoeven		pins = "GP_5_10", "GP_5_11", "GP_5_12", "GP_5_13";
5885d4e8cb4SGeert Uytterhoeven		bias-pull-up;
5895d4e8cb4SGeert Uytterhoeven	};
5905d4e8cb4SGeert Uytterhoeven
5915d4e8cb4SGeert Uytterhoeven	pwm3_pins: pwm3 {
5925d4e8cb4SGeert Uytterhoeven		groups = "pwm3_b";
5935d4e8cb4SGeert Uytterhoeven		function = "pwm3";
5945d4e8cb4SGeert Uytterhoeven	};
5955d4e8cb4SGeert Uytterhoeven
5965d4e8cb4SGeert Uytterhoeven	pwm5_pins: pwm5 {
5975d4e8cb4SGeert Uytterhoeven		groups = "pwm5_a";
5985d4e8cb4SGeert Uytterhoeven		function = "pwm5";
5995d4e8cb4SGeert Uytterhoeven	};
6005d4e8cb4SGeert Uytterhoeven
6015d4e8cb4SGeert Uytterhoeven	scif2_pins: scif2 {
6025d4e8cb4SGeert Uytterhoeven		groups = "scif2_data_a";
6035d4e8cb4SGeert Uytterhoeven		function = "scif2";
6045d4e8cb4SGeert Uytterhoeven	};
6055d4e8cb4SGeert Uytterhoeven
6065d4e8cb4SGeert Uytterhoeven	sdhi0_pins: sd0 {
6075d4e8cb4SGeert Uytterhoeven		groups = "sdhi0_data4", "sdhi0_ctrl";
6085d4e8cb4SGeert Uytterhoeven		function = "sdhi0";
6095d4e8cb4SGeert Uytterhoeven		power-source = <3300>;
6105d4e8cb4SGeert Uytterhoeven	};
6115d4e8cb4SGeert Uytterhoeven
6125d4e8cb4SGeert Uytterhoeven	sdhi0_pins_uhs: sd0_uhs {
6135d4e8cb4SGeert Uytterhoeven		groups = "sdhi0_data4", "sdhi0_ctrl";
6145d4e8cb4SGeert Uytterhoeven		function = "sdhi0";
6155d4e8cb4SGeert Uytterhoeven		power-source = <1800>;
6165d4e8cb4SGeert Uytterhoeven	};
6175d4e8cb4SGeert Uytterhoeven
6185d4e8cb4SGeert Uytterhoeven	sdhi1_pins: sd1 {
6195d4e8cb4SGeert Uytterhoeven		groups = "sdhi1_data4", "sdhi1_ctrl";
6205d4e8cb4SGeert Uytterhoeven		function = "sdhi1";
6215d4e8cb4SGeert Uytterhoeven		power-source = <3300>;
6225d4e8cb4SGeert Uytterhoeven	};
6235d4e8cb4SGeert Uytterhoeven
6245d4e8cb4SGeert Uytterhoeven	sdhi1_pins_uhs: sd1_uhs {
6255d4e8cb4SGeert Uytterhoeven		groups = "sdhi1_data4", "sdhi1_ctrl";
6265d4e8cb4SGeert Uytterhoeven		function = "sdhi1";
6275d4e8cb4SGeert Uytterhoeven		power-source = <1800>;
6285d4e8cb4SGeert Uytterhoeven	};
6295d4e8cb4SGeert Uytterhoeven
6305d4e8cb4SGeert Uytterhoeven	sdhi3_pins: sd3 {
6315d4e8cb4SGeert Uytterhoeven		groups = "sdhi3_data8", "sdhi3_ctrl", "sdhi3_ds";
6325d4e8cb4SGeert Uytterhoeven		function = "sdhi3";
6335d4e8cb4SGeert Uytterhoeven		power-source = <1800>;
6345d4e8cb4SGeert Uytterhoeven	};
6355d4e8cb4SGeert Uytterhoeven
6365d4e8cb4SGeert Uytterhoeven	sound_clk_pins: sound_clk {
6375d4e8cb4SGeert Uytterhoeven		groups = "audio_clk_a", "audio_clk_b_a", "audio_clk_c_a",
6385d4e8cb4SGeert Uytterhoeven			 "audio_clkout_a", "audio_clkout1_a";
6395d4e8cb4SGeert Uytterhoeven		function = "audio_clk";
6405d4e8cb4SGeert Uytterhoeven	};
6415d4e8cb4SGeert Uytterhoeven
6425d4e8cb4SGeert Uytterhoeven	sound_pins: sound {
6435d4e8cb4SGeert Uytterhoeven		groups = "ssi01239_ctrl", "ssi0_data", "ssi1_data";
6445d4e8cb4SGeert Uytterhoeven		function = "ssi";
6455d4e8cb4SGeert Uytterhoeven	};
6465d4e8cb4SGeert Uytterhoeven
6475d4e8cb4SGeert Uytterhoeven	usb0_pins: usb {
6485d4e8cb4SGeert Uytterhoeven		groups = "usb0_b", "usb0_id";
6495d4e8cb4SGeert Uytterhoeven		function = "usb0";
6505d4e8cb4SGeert Uytterhoeven	};
6515d4e8cb4SGeert Uytterhoeven
6525d4e8cb4SGeert Uytterhoeven	usb30_pins: usb30 {
6535d4e8cb4SGeert Uytterhoeven		groups = "usb30";
6545d4e8cb4SGeert Uytterhoeven		function = "usb30";
6555d4e8cb4SGeert Uytterhoeven	};
6565d4e8cb4SGeert Uytterhoeven};
6575d4e8cb4SGeert Uytterhoeven
6585d4e8cb4SGeert Uytterhoeven&pwm3 {
6595d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&pwm3_pins>;
6605d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
6615d4e8cb4SGeert Uytterhoeven
6625d4e8cb4SGeert Uytterhoeven	status = "okay";
6635d4e8cb4SGeert Uytterhoeven};
6645d4e8cb4SGeert Uytterhoeven
6655d4e8cb4SGeert Uytterhoeven&pwm5 {
6665d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&pwm5_pins>;
6675d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
6685d4e8cb4SGeert Uytterhoeven
6695d4e8cb4SGeert Uytterhoeven	status = "okay";
6705d4e8cb4SGeert Uytterhoeven};
6715d4e8cb4SGeert Uytterhoeven
6725d4e8cb4SGeert Uytterhoeven&rcar_sound {
6735d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&sound_pins>, <&sound_clk_pins>;
6745d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
6755d4e8cb4SGeert Uytterhoeven
6765d4e8cb4SGeert Uytterhoeven	/* Single DAI */
6775d4e8cb4SGeert Uytterhoeven	#sound-dai-cells = <0>;
6785d4e8cb4SGeert Uytterhoeven
6795d4e8cb4SGeert Uytterhoeven	/* audio_clkout0/1/2/3 */
6805d4e8cb4SGeert Uytterhoeven	#clock-cells = <1>;
6815d4e8cb4SGeert Uytterhoeven	clock-frequency = <12288000 11289600>;
6825d4e8cb4SGeert Uytterhoeven
6835d4e8cb4SGeert Uytterhoeven	status = "okay";
6845d4e8cb4SGeert Uytterhoeven
6855d4e8cb4SGeert Uytterhoeven	/* update <audio_clk_b> to <cs2000> */
6865d4e8cb4SGeert Uytterhoeven	clocks = <&cpg CPG_MOD 1005>,
6875d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1006>, <&cpg CPG_MOD 1007>,
6885d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1008>, <&cpg CPG_MOD 1009>,
6895d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1010>, <&cpg CPG_MOD 1011>,
6905d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1012>, <&cpg CPG_MOD 1013>,
6915d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1014>, <&cpg CPG_MOD 1015>,
6925d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1022>, <&cpg CPG_MOD 1023>,
6935d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1024>, <&cpg CPG_MOD 1025>,
6945d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1026>, <&cpg CPG_MOD 1027>,
6955d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1028>, <&cpg CPG_MOD 1029>,
6965d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1030>, <&cpg CPG_MOD 1031>,
6975d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1020>, <&cpg CPG_MOD 1021>,
6985d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1020>, <&cpg CPG_MOD 1021>,
6995d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_MOD 1019>, <&cpg CPG_MOD 1018>,
7005d4e8cb4SGeert Uytterhoeven		 <&audio_clk_a>, <&cs2000>, <&audio_clk_c>,
7015d4e8cb4SGeert Uytterhoeven		 <&cpg CPG_CORE R8A77990_CLK_ZA2>;
7025d4e8cb4SGeert Uytterhoeven
7035d4e8cb4SGeert Uytterhoeven	rcar_sound,dai {
7045d4e8cb4SGeert Uytterhoeven		dai0 {
7055d4e8cb4SGeert Uytterhoeven			playback = <&ssi0>, <&src0>, <&dvc0>;
7065d4e8cb4SGeert Uytterhoeven			capture  = <&ssi1>, <&src1>, <&dvc1>;
7075d4e8cb4SGeert Uytterhoeven		};
7085d4e8cb4SGeert Uytterhoeven	};
7095d4e8cb4SGeert Uytterhoeven
7105d4e8cb4SGeert Uytterhoeven};
7115d4e8cb4SGeert Uytterhoeven
7125d4e8cb4SGeert Uytterhoeven&rwdt {
7135d4e8cb4SGeert Uytterhoeven	timeout-sec = <60>;
7145d4e8cb4SGeert Uytterhoeven	status = "okay";
7155d4e8cb4SGeert Uytterhoeven};
7165d4e8cb4SGeert Uytterhoeven
7175d4e8cb4SGeert Uytterhoeven&scif2 {
7185d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&scif2_pins>;
7195d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
7205d4e8cb4SGeert Uytterhoeven
7215d4e8cb4SGeert Uytterhoeven	status = "okay";
7225d4e8cb4SGeert Uytterhoeven};
7235d4e8cb4SGeert Uytterhoeven
7245d4e8cb4SGeert Uytterhoeven&sdhi0 {
7255d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&sdhi0_pins>;
7265d4e8cb4SGeert Uytterhoeven	pinctrl-1 = <&sdhi0_pins_uhs>;
7275d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default", "state_uhs";
7285d4e8cb4SGeert Uytterhoeven
7295d4e8cb4SGeert Uytterhoeven	vmmc-supply = <&vcc_sdhi0>;
7305d4e8cb4SGeert Uytterhoeven	vqmmc-supply = <&vccq_sdhi0>;
7315d4e8cb4SGeert Uytterhoeven	cd-gpios = <&gpio3 12 GPIO_ACTIVE_LOW>;
7325d4e8cb4SGeert Uytterhoeven	wp-gpios = <&gpio3 13 GPIO_ACTIVE_HIGH>;
7335d4e8cb4SGeert Uytterhoeven	bus-width = <4>;
7345d4e8cb4SGeert Uytterhoeven	sd-uhs-sdr50;
7355d4e8cb4SGeert Uytterhoeven	sd-uhs-sdr104;
7365d4e8cb4SGeert Uytterhoeven	status = "okay";
7375d4e8cb4SGeert Uytterhoeven};
7385d4e8cb4SGeert Uytterhoeven
7395d4e8cb4SGeert Uytterhoeven&sdhi1 {
7405d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&sdhi1_pins>;
7415d4e8cb4SGeert Uytterhoeven	pinctrl-1 = <&sdhi1_pins_uhs>;
7425d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default", "state_uhs";
7435d4e8cb4SGeert Uytterhoeven
7445d4e8cb4SGeert Uytterhoeven	vmmc-supply = <&vcc_sdhi1>;
7455d4e8cb4SGeert Uytterhoeven	vqmmc-supply = <&vccq_sdhi1>;
7465d4e8cb4SGeert Uytterhoeven	cd-gpios = <&gpio3 14 GPIO_ACTIVE_LOW>;
7475d4e8cb4SGeert Uytterhoeven	bus-width = <4>;
7485d4e8cb4SGeert Uytterhoeven	sd-uhs-sdr50;
7495d4e8cb4SGeert Uytterhoeven	sd-uhs-sdr104;
7505d4e8cb4SGeert Uytterhoeven	status = "okay";
7515d4e8cb4SGeert Uytterhoeven};
7525d4e8cb4SGeert Uytterhoeven
7535d4e8cb4SGeert Uytterhoeven&sdhi3 {
7545d4e8cb4SGeert Uytterhoeven	/* used for on-board 8bit eMMC */
7555d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&sdhi3_pins>;
7565d4e8cb4SGeert Uytterhoeven	pinctrl-1 = <&sdhi3_pins>;
7575d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default", "state_uhs";
7585d4e8cb4SGeert Uytterhoeven
7595d4e8cb4SGeert Uytterhoeven	vmmc-supply = <&reg_3p3v>;
7605d4e8cb4SGeert Uytterhoeven	vqmmc-supply = <&reg_1p8v>;
7615d4e8cb4SGeert Uytterhoeven	mmc-hs200-1_8v;
7625d4e8cb4SGeert Uytterhoeven	mmc-hs400-1_8v;
7635d4e8cb4SGeert Uytterhoeven	bus-width = <8>;
7645d4e8cb4SGeert Uytterhoeven	no-sd;
7655d4e8cb4SGeert Uytterhoeven	no-sdio;
7665d4e8cb4SGeert Uytterhoeven	non-removable;
7675d4e8cb4SGeert Uytterhoeven	full-pwr-cycle-in-suspend;
7685d4e8cb4SGeert Uytterhoeven	status = "okay";
7695d4e8cb4SGeert Uytterhoeven};
7705d4e8cb4SGeert Uytterhoeven
7715d4e8cb4SGeert Uytterhoeven&ssi1 {
7725d4e8cb4SGeert Uytterhoeven	shared-pin;
7735d4e8cb4SGeert Uytterhoeven};
7745d4e8cb4SGeert Uytterhoeven
7755d4e8cb4SGeert Uytterhoeven&usb2_phy0 {
7765d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&usb0_pins>;
7775d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
7785d4e8cb4SGeert Uytterhoeven
7795d4e8cb4SGeert Uytterhoeven	vbus-supply = <&vbus0_usb2>;
7805d4e8cb4SGeert Uytterhoeven	status = "okay";
7815d4e8cb4SGeert Uytterhoeven};
7825d4e8cb4SGeert Uytterhoeven
7835d4e8cb4SGeert Uytterhoeven&usb3_peri0 {
7845d4e8cb4SGeert Uytterhoeven	companion = <&xhci0>;
7855d4e8cb4SGeert Uytterhoeven	status = "okay";
7865d4e8cb4SGeert Uytterhoeven};
7875d4e8cb4SGeert Uytterhoeven
7885d4e8cb4SGeert Uytterhoeven&vin4 {
7895d4e8cb4SGeert Uytterhoeven	status = "okay";
7905d4e8cb4SGeert Uytterhoeven};
7915d4e8cb4SGeert Uytterhoeven
7925d4e8cb4SGeert Uytterhoeven&vin5 {
7935d4e8cb4SGeert Uytterhoeven	status = "okay";
7945d4e8cb4SGeert Uytterhoeven};
7955d4e8cb4SGeert Uytterhoeven
7965d4e8cb4SGeert Uytterhoeven&xhci0 {
7975d4e8cb4SGeert Uytterhoeven	pinctrl-0 = <&usb30_pins>;
7985d4e8cb4SGeert Uytterhoeven	pinctrl-names = "default";
7995d4e8cb4SGeert Uytterhoeven
8005d4e8cb4SGeert Uytterhoeven	status = "okay";
8015d4e8cb4SGeert Uytterhoeven};
802