162306a36Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Copyright (C) 2020 Arm Ltd.
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * DT nodes common between Orange Pi Zero 2 and Orange Pi Zero 3.
662306a36Sopenharmony_ci * Excludes PMIC nodes and properties, since they are different between the two.
762306a36Sopenharmony_ci */
862306a36Sopenharmony_ci
962306a36Sopenharmony_ci#include "sun50i-h616.dtsi"
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#include <dt-bindings/gpio/gpio.h>
1262306a36Sopenharmony_ci#include <dt-bindings/interrupt-controller/arm-gic.h>
1362306a36Sopenharmony_ci#include <dt-bindings/leds/common.h>
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci/ {
1662306a36Sopenharmony_ci	aliases {
1762306a36Sopenharmony_ci		ethernet0 = &emac0;
1862306a36Sopenharmony_ci		serial0 = &uart0;
1962306a36Sopenharmony_ci	};
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_ci	chosen {
2262306a36Sopenharmony_ci		stdout-path = "serial0:115200n8";
2362306a36Sopenharmony_ci	};
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci	leds {
2662306a36Sopenharmony_ci		compatible = "gpio-leds";
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci		led-0 {
2962306a36Sopenharmony_ci			function = LED_FUNCTION_POWER;
3062306a36Sopenharmony_ci			color = <LED_COLOR_ID_RED>;
3162306a36Sopenharmony_ci			gpios = <&pio 2 12 GPIO_ACTIVE_HIGH>; /* PC12 */
3262306a36Sopenharmony_ci			default-state = "on";
3362306a36Sopenharmony_ci		};
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci		led-1 {
3662306a36Sopenharmony_ci			function = LED_FUNCTION_STATUS;
3762306a36Sopenharmony_ci			color = <LED_COLOR_ID_GREEN>;
3862306a36Sopenharmony_ci			gpios = <&pio 2 13 GPIO_ACTIVE_HIGH>; /* PC13 */
3962306a36Sopenharmony_ci		};
4062306a36Sopenharmony_ci	};
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci	reg_vcc5v: vcc5v {
4362306a36Sopenharmony_ci		/* board wide 5V supply directly from the USB-C socket */
4462306a36Sopenharmony_ci		compatible = "regulator-fixed";
4562306a36Sopenharmony_ci		regulator-name = "vcc-5v";
4662306a36Sopenharmony_ci		regulator-min-microvolt = <5000000>;
4762306a36Sopenharmony_ci		regulator-max-microvolt = <5000000>;
4862306a36Sopenharmony_ci		regulator-always-on;
4962306a36Sopenharmony_ci	};
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci	reg_usb1_vbus: regulator-usb1-vbus {
5262306a36Sopenharmony_ci		compatible = "regulator-fixed";
5362306a36Sopenharmony_ci		regulator-name = "usb1-vbus";
5462306a36Sopenharmony_ci		regulator-min-microvolt = <5000000>;
5562306a36Sopenharmony_ci		regulator-max-microvolt = <5000000>;
5662306a36Sopenharmony_ci		vin-supply = <&reg_vcc5v>;
5762306a36Sopenharmony_ci		enable-active-high;
5862306a36Sopenharmony_ci		gpio = <&pio 2 16 GPIO_ACTIVE_HIGH>; /* PC16 */
5962306a36Sopenharmony_ci	};
6062306a36Sopenharmony_ci};
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci&ehci1 {
6362306a36Sopenharmony_ci	status = "okay";
6462306a36Sopenharmony_ci};
6562306a36Sopenharmony_ci
6662306a36Sopenharmony_ci/* USB 2 & 3 are on headers only. */
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci&emac0 {
6962306a36Sopenharmony_ci	pinctrl-names = "default";
7062306a36Sopenharmony_ci	pinctrl-0 = <&ext_rgmii_pins>;
7162306a36Sopenharmony_ci	phy-handle = <&ext_rgmii_phy>;
7262306a36Sopenharmony_ci	status = "okay";
7362306a36Sopenharmony_ci};
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci&mdio0 {
7662306a36Sopenharmony_ci	ext_rgmii_phy: ethernet-phy@1 {
7762306a36Sopenharmony_ci		compatible = "ethernet-phy-ieee802.3-c22";
7862306a36Sopenharmony_ci		reg = <1>;
7962306a36Sopenharmony_ci	};
8062306a36Sopenharmony_ci};
8162306a36Sopenharmony_ci
8262306a36Sopenharmony_ci&mmc0 {
8362306a36Sopenharmony_ci	cd-gpios = <&pio 5 6 GPIO_ACTIVE_LOW>;	/* PF6 */
8462306a36Sopenharmony_ci	bus-width = <4>;
8562306a36Sopenharmony_ci	status = "okay";
8662306a36Sopenharmony_ci};
8762306a36Sopenharmony_ci
8862306a36Sopenharmony_ci&ohci1 {
8962306a36Sopenharmony_ci	status = "okay";
9062306a36Sopenharmony_ci};
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci&spi0  {
9362306a36Sopenharmony_ci	status = "okay";
9462306a36Sopenharmony_ci	pinctrl-names = "default";
9562306a36Sopenharmony_ci	pinctrl-0 = <&spi0_pins>, <&spi0_cs0_pin>;
9662306a36Sopenharmony_ci
9762306a36Sopenharmony_ci	flash@0 {
9862306a36Sopenharmony_ci		#address-cells = <1>;
9962306a36Sopenharmony_ci		#size-cells = <1>;
10062306a36Sopenharmony_ci		compatible = "jedec,spi-nor";
10162306a36Sopenharmony_ci		reg = <0>;
10262306a36Sopenharmony_ci		spi-max-frequency = <40000000>;
10362306a36Sopenharmony_ci	};
10462306a36Sopenharmony_ci};
10562306a36Sopenharmony_ci
10662306a36Sopenharmony_ci&uart0 {
10762306a36Sopenharmony_ci	pinctrl-names = "default";
10862306a36Sopenharmony_ci	pinctrl-0 = <&uart0_ph_pins>;
10962306a36Sopenharmony_ci	status = "okay";
11062306a36Sopenharmony_ci};
11162306a36Sopenharmony_ci
11262306a36Sopenharmony_ci&usbotg {
11362306a36Sopenharmony_ci	/*
11462306a36Sopenharmony_ci	 * PHY0 pins are connected to a USB-C socket, but a role switch
11562306a36Sopenharmony_ci	 * is not implemented: both CC pins are pulled to GND.
11662306a36Sopenharmony_ci	 * The VBUS pins power the device, so a fixed peripheral mode
11762306a36Sopenharmony_ci	 * is the best choice.
11862306a36Sopenharmony_ci	 * The board can be powered via GPIOs, in this case port0 *can*
11962306a36Sopenharmony_ci	 * act as a host (with a cable/adapter ignoring CC), as VBUS is
12062306a36Sopenharmony_ci	 * then provided by the GPIOs. Any user of this setup would
12162306a36Sopenharmony_ci	 * need to adjust the DT accordingly: dr_mode set to "host",
12262306a36Sopenharmony_ci	 * enabling OHCI0 and EHCI0.
12362306a36Sopenharmony_ci	 */
12462306a36Sopenharmony_ci	dr_mode = "peripheral";
12562306a36Sopenharmony_ci	status = "okay";
12662306a36Sopenharmony_ci};
12762306a36Sopenharmony_ci
12862306a36Sopenharmony_ci&usbphy {
12962306a36Sopenharmony_ci	usb1_vbus-supply = <&reg_usb1_vbus>;
13062306a36Sopenharmony_ci	status = "okay";
13162306a36Sopenharmony_ci};
132