162306a36Sopenharmony_ci// SPDX-License-Identifier: (GPL-2.0 OR MIT)
262306a36Sopenharmony_ci
362306a36Sopenharmony_ci/*
462306a36Sopenharmony_ci * Device tree file for ZII's SSMB SPU3 board
562306a36Sopenharmony_ci *
662306a36Sopenharmony_ci * SSMB - SPU3 Switch Management Board
762306a36Sopenharmony_ci * SPU - Seat Power Unit
862306a36Sopenharmony_ci *
962306a36Sopenharmony_ci * Copyright (C) 2015, 2016 Zodiac Inflight Innovations
1062306a36Sopenharmony_ci *
1162306a36Sopenharmony_ci * Based on an original 'vf610-twr.dts' which is Copyright 2015,
1262306a36Sopenharmony_ci * Freescale Semiconductor, Inc.
1362306a36Sopenharmony_ci */
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ci/dts-v1/;
1662306a36Sopenharmony_ci#include "vf610.dtsi"
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci/ {
1962306a36Sopenharmony_ci	model = "ZII VF610 SSMB SPU3 Board";
2062306a36Sopenharmony_ci	compatible = "zii,vf610spu3", "zii,vf610dev", "fsl,vf610";
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci	chosen {
2362306a36Sopenharmony_ci		stdout-path = &uart0;
2462306a36Sopenharmony_ci	};
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci	memory@80000000 {
2762306a36Sopenharmony_ci		device_type = "memory";
2862306a36Sopenharmony_ci		reg = <0x80000000 0x20000000>;
2962306a36Sopenharmony_ci	};
3062306a36Sopenharmony_ci
3162306a36Sopenharmony_ci	gpio-leds {
3262306a36Sopenharmony_ci		compatible = "gpio-leds";
3362306a36Sopenharmony_ci		pinctrl-0 = <&pinctrl_leds_debug>;
3462306a36Sopenharmony_ci		pinctrl-names = "default";
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci		led-debug {
3762306a36Sopenharmony_ci			label = "zii:green:debug1";
3862306a36Sopenharmony_ci			gpios = <&gpio2 18 GPIO_ACTIVE_HIGH>;
3962306a36Sopenharmony_ci			linux,default-trigger = "heartbeat";
4062306a36Sopenharmony_ci		};
4162306a36Sopenharmony_ci	};
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci	reg_vcc_3v3_mcu: regulator {
4462306a36Sopenharmony_ci		compatible = "regulator-fixed";
4562306a36Sopenharmony_ci		regulator-name = "vcc_3v3_mcu";
4662306a36Sopenharmony_ci		regulator-min-microvolt = <3300000>;
4762306a36Sopenharmony_ci		regulator-max-microvolt = <3300000>;
4862306a36Sopenharmony_ci	};
4962306a36Sopenharmony_ci
5062306a36Sopenharmony_ci	supply-voltage-monitor {
5162306a36Sopenharmony_ci		compatible = "iio-hwmon";
5262306a36Sopenharmony_ci		io-channels = <&adc0 8>, /* 12V_MAIN */
5362306a36Sopenharmony_ci			      <&adc0 9>, /* +3.3V    */
5462306a36Sopenharmony_ci			      <&adc1 8>, /* VCC_1V5  */
5562306a36Sopenharmony_ci			      <&adc1 9>; /* VCC_1V2  */
5662306a36Sopenharmony_ci	};
5762306a36Sopenharmony_ci};
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ci&adc0 {
6062306a36Sopenharmony_ci	vref-supply = <&reg_vcc_3v3_mcu>;
6162306a36Sopenharmony_ci	status = "okay";
6262306a36Sopenharmony_ci};
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci&adc1 {
6562306a36Sopenharmony_ci	vref-supply = <&reg_vcc_3v3_mcu>;
6662306a36Sopenharmony_ci	status = "okay";
6762306a36Sopenharmony_ci};
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ci&dspi1 {
7062306a36Sopenharmony_ci	bus-num = <1>;
7162306a36Sopenharmony_ci	pinctrl-names = "default";
7262306a36Sopenharmony_ci	pinctrl-0 = <&pinctrl_dspi1>;
7362306a36Sopenharmony_ci	/*
7462306a36Sopenharmony_ci	 * Some SPU3s come with SPI-NOR chip DNPed, so we leave this
7562306a36Sopenharmony_ci	 * node disabled by default and rely on bootloader to enable
7662306a36Sopenharmony_ci	 * it when appropriate.
7762306a36Sopenharmony_ci	 */
7862306a36Sopenharmony_ci	status = "disabled";
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci	flash@0 {
8162306a36Sopenharmony_ci		#address-cells = <1>;
8262306a36Sopenharmony_ci		#size-cells = <1>;
8362306a36Sopenharmony_ci		compatible = "m25p128", "jedec,spi-nor";
8462306a36Sopenharmony_ci		reg = <0>;
8562306a36Sopenharmony_ci		spi-max-frequency = <50000000>;
8662306a36Sopenharmony_ci
8762306a36Sopenharmony_ci		partition@0 {
8862306a36Sopenharmony_ci			label = "m25p128-0";
8962306a36Sopenharmony_ci			reg = <0x0 0x01000000>;
9062306a36Sopenharmony_ci		};
9162306a36Sopenharmony_ci	};
9262306a36Sopenharmony_ci};
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ci&edma0 {
9562306a36Sopenharmony_ci	status = "okay";
9662306a36Sopenharmony_ci};
9762306a36Sopenharmony_ci
9862306a36Sopenharmony_ci&edma1 {
9962306a36Sopenharmony_ci	status = "okay";
10062306a36Sopenharmony_ci};
10162306a36Sopenharmony_ci
10262306a36Sopenharmony_ci&esdhc0 {
10362306a36Sopenharmony_ci	pinctrl-names = "default";
10462306a36Sopenharmony_ci	pinctrl-0 = <&pinctrl_esdhc0>;
10562306a36Sopenharmony_ci	bus-width = <8>;
10662306a36Sopenharmony_ci	non-removable;
10762306a36Sopenharmony_ci	no-1-8-v;
10862306a36Sopenharmony_ci	keep-power-in-suspend;
10962306a36Sopenharmony_ci	no-sdio;
11062306a36Sopenharmony_ci	no-sd;
11162306a36Sopenharmony_ci	status = "okay";
11262306a36Sopenharmony_ci};
11362306a36Sopenharmony_ci
11462306a36Sopenharmony_ci&esdhc1 {
11562306a36Sopenharmony_ci	pinctrl-names = "default";
11662306a36Sopenharmony_ci	pinctrl-0 = <&pinctrl_esdhc1>;
11762306a36Sopenharmony_ci	bus-width = <4>;
11862306a36Sopenharmony_ci	no-sdio;
11962306a36Sopenharmony_ci	status = "okay";
12062306a36Sopenharmony_ci};
12162306a36Sopenharmony_ci
12262306a36Sopenharmony_ci&fec1 {
12362306a36Sopenharmony_ci	phy-mode = "rmii";
12462306a36Sopenharmony_ci	pinctrl-names = "default";
12562306a36Sopenharmony_ci	pinctrl-0 = <&pinctrl_fec1>;
12662306a36Sopenharmony_ci	status = "okay";
12762306a36Sopenharmony_ci
12862306a36Sopenharmony_ci	fixed-link {
12962306a36Sopenharmony_ci		speed = <100>;
13062306a36Sopenharmony_ci		full-duplex;
13162306a36Sopenharmony_ci	};
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci	mdio1: mdio {
13462306a36Sopenharmony_ci		#address-cells = <1>;
13562306a36Sopenharmony_ci		#size-cells = <0>;
13662306a36Sopenharmony_ci		clock-frequency = <12500000>;
13762306a36Sopenharmony_ci		suppress-preamble;
13862306a36Sopenharmony_ci		status = "okay";
13962306a36Sopenharmony_ci
14062306a36Sopenharmony_ci		switch0: switch0@0 {
14162306a36Sopenharmony_ci			compatible = "marvell,mv88e6190";
14262306a36Sopenharmony_ci			pinctrl-0 = <&pinctrl_gpio_switch0>;
14362306a36Sopenharmony_ci			pinctrl-names = "default";
14462306a36Sopenharmony_ci			reg = <0>;
14562306a36Sopenharmony_ci			eeprom-length = <65536>;
14662306a36Sopenharmony_ci			interrupt-parent = <&gpio3>;
14762306a36Sopenharmony_ci			interrupts = <2 IRQ_TYPE_LEVEL_LOW>;
14862306a36Sopenharmony_ci			interrupt-controller;
14962306a36Sopenharmony_ci			#interrupt-cells = <2>;
15062306a36Sopenharmony_ci
15162306a36Sopenharmony_ci			ports {
15262306a36Sopenharmony_ci				#address-cells = <1>;
15362306a36Sopenharmony_ci				#size-cells = <0>;
15462306a36Sopenharmony_ci
15562306a36Sopenharmony_ci				port@0 {
15662306a36Sopenharmony_ci					reg = <0>;
15762306a36Sopenharmony_ci					phy-mode = "rmii";
15862306a36Sopenharmony_ci					ethernet = <&fec1>;
15962306a36Sopenharmony_ci
16062306a36Sopenharmony_ci					fixed-link {
16162306a36Sopenharmony_ci						speed = <100>;
16262306a36Sopenharmony_ci						full-duplex;
16362306a36Sopenharmony_ci					};
16462306a36Sopenharmony_ci				};
16562306a36Sopenharmony_ci
16662306a36Sopenharmony_ci				port@1 {
16762306a36Sopenharmony_ci					reg = <1>;
16862306a36Sopenharmony_ci					label = "eth_cu_1000_1";
16962306a36Sopenharmony_ci				};
17062306a36Sopenharmony_ci
17162306a36Sopenharmony_ci				port@2 {
17262306a36Sopenharmony_ci					reg = <2>;
17362306a36Sopenharmony_ci					label = "eth_cu_1000_2";
17462306a36Sopenharmony_ci				};
17562306a36Sopenharmony_ci
17662306a36Sopenharmony_ci				port@3 {
17762306a36Sopenharmony_ci					reg = <3>;
17862306a36Sopenharmony_ci					label = "eth_cu_1000_3";
17962306a36Sopenharmony_ci				};
18062306a36Sopenharmony_ci
18162306a36Sopenharmony_ci				port@4 {
18262306a36Sopenharmony_ci					reg = <4>;
18362306a36Sopenharmony_ci					label = "eth_cu_1000_4";
18462306a36Sopenharmony_ci				};
18562306a36Sopenharmony_ci
18662306a36Sopenharmony_ci				port@5 {
18762306a36Sopenharmony_ci					reg = <5>;
18862306a36Sopenharmony_ci					label = "eth_cu_1000_5";
18962306a36Sopenharmony_ci				};
19062306a36Sopenharmony_ci
19162306a36Sopenharmony_ci				port@6 {
19262306a36Sopenharmony_ci					reg = <6>;
19362306a36Sopenharmony_ci					label = "eth_cu_1000_6";
19462306a36Sopenharmony_ci				};
19562306a36Sopenharmony_ci			};
19662306a36Sopenharmony_ci		};
19762306a36Sopenharmony_ci	};
19862306a36Sopenharmony_ci};
19962306a36Sopenharmony_ci
20062306a36Sopenharmony_ci&i2c0 {
20162306a36Sopenharmony_ci	clock-frequency = <100000>;
20262306a36Sopenharmony_ci	pinctrl-names = "default";
20362306a36Sopenharmony_ci	pinctrl-0 = <&pinctrl_i2c0>;
20462306a36Sopenharmony_ci	status = "okay";
20562306a36Sopenharmony_ci
20662306a36Sopenharmony_ci	gpio6: io-expander@22 {
20762306a36Sopenharmony_ci		compatible = "nxp,pca9554";
20862306a36Sopenharmony_ci		reg = <0x22>;
20962306a36Sopenharmony_ci		gpio-controller;
21062306a36Sopenharmony_ci		#gpio-cells = <2>;
21162306a36Sopenharmony_ci	};
21262306a36Sopenharmony_ci
21362306a36Sopenharmony_ci	lm75@48 {
21462306a36Sopenharmony_ci		compatible = "national,lm75";
21562306a36Sopenharmony_ci		reg = <0x48>;
21662306a36Sopenharmony_ci	};
21762306a36Sopenharmony_ci
21862306a36Sopenharmony_ci	eeprom@50 {
21962306a36Sopenharmony_ci		compatible = "atmel,24c04";
22062306a36Sopenharmony_ci		reg = <0x50>;
22162306a36Sopenharmony_ci		label = "nameplate";
22262306a36Sopenharmony_ci	};
22362306a36Sopenharmony_ci
22462306a36Sopenharmony_ci	eeprom@52 {
22562306a36Sopenharmony_ci		compatible = "atmel,24c04";
22662306a36Sopenharmony_ci		reg = <0x52>;
22762306a36Sopenharmony_ci	};
22862306a36Sopenharmony_ci};
22962306a36Sopenharmony_ci
23062306a36Sopenharmony_ci&i2c1 {
23162306a36Sopenharmony_ci	clock-frequency = <100000>;
23262306a36Sopenharmony_ci	pinctrl-names = "default";
23362306a36Sopenharmony_ci	pinctrl-0 = <&pinctrl_i2c1>;
23462306a36Sopenharmony_ci	status = "okay";
23562306a36Sopenharmony_ci
23662306a36Sopenharmony_ci	watchdog@38 {
23762306a36Sopenharmony_ci		compatible = "zii,rave-wdt";
23862306a36Sopenharmony_ci		reg = <0x38>;
23962306a36Sopenharmony_ci	};
24062306a36Sopenharmony_ci};
24162306a36Sopenharmony_ci
24262306a36Sopenharmony_ci&snvsrtc {
24362306a36Sopenharmony_ci	status = "disabled";
24462306a36Sopenharmony_ci};
24562306a36Sopenharmony_ci
24662306a36Sopenharmony_ci&uart0 {
24762306a36Sopenharmony_ci	pinctrl-names = "default";
24862306a36Sopenharmony_ci	pinctrl-0 = <&pinctrl_uart0>;
24962306a36Sopenharmony_ci	status = "okay";
25062306a36Sopenharmony_ci};
25162306a36Sopenharmony_ci
25262306a36Sopenharmony_ci&uart1 {
25362306a36Sopenharmony_ci	pinctrl-names = "default";
25462306a36Sopenharmony_ci	pinctrl-0 = <&pinctrl_uart1>;
25562306a36Sopenharmony_ci	status = "okay";
25662306a36Sopenharmony_ci
25762306a36Sopenharmony_ci	mcu {
25862306a36Sopenharmony_ci		compatible = "zii,rave-sp-rdu2";
25962306a36Sopenharmony_ci		current-speed = <1000000>;
26062306a36Sopenharmony_ci		#address-cells = <1>;
26162306a36Sopenharmony_ci		#size-cells = <1>;
26262306a36Sopenharmony_ci
26362306a36Sopenharmony_ci		watchdog {
26462306a36Sopenharmony_ci			compatible = "zii,rave-sp-watchdog";
26562306a36Sopenharmony_ci		};
26662306a36Sopenharmony_ci
26762306a36Sopenharmony_ci		eeprom@a3 {
26862306a36Sopenharmony_ci			compatible = "zii,rave-sp-eeprom";
26962306a36Sopenharmony_ci			reg = <0xa3 0x4000>;
27062306a36Sopenharmony_ci			#address-cells = <1>;
27162306a36Sopenharmony_ci			#size-cells = <1>;
27262306a36Sopenharmony_ci			zii,eeprom-name = "main-eeprom";
27362306a36Sopenharmony_ci		};
27462306a36Sopenharmony_ci	};
27562306a36Sopenharmony_ci};
27662306a36Sopenharmony_ci
27762306a36Sopenharmony_ci&wdoga5 {
27862306a36Sopenharmony_ci	status = "disabled";
27962306a36Sopenharmony_ci};
28062306a36Sopenharmony_ci
28162306a36Sopenharmony_ci&iomuxc {
28262306a36Sopenharmony_ci	pinctrl_dspi1: dspi1grp {
28362306a36Sopenharmony_ci		fsl,pins = <
28462306a36Sopenharmony_ci			VF610_PAD_PTD5__DSPI1_CS0		0x1182
28562306a36Sopenharmony_ci			VF610_PAD_PTD4__DSPI1_CS1		0x1182
28662306a36Sopenharmony_ci			VF610_PAD_PTC6__DSPI1_SIN		0x1181
28762306a36Sopenharmony_ci			VF610_PAD_PTC7__DSPI1_SOUT		0x1182
28862306a36Sopenharmony_ci			VF610_PAD_PTC8__DSPI1_SCK		0x1182
28962306a36Sopenharmony_ci		>;
29062306a36Sopenharmony_ci	};
29162306a36Sopenharmony_ci
29262306a36Sopenharmony_ci	pinctrl_esdhc0: esdhc0grp {
29362306a36Sopenharmony_ci		fsl,pins = <
29462306a36Sopenharmony_ci			VF610_PAD_PTC0__ESDHC0_CLK		0x31ef
29562306a36Sopenharmony_ci			VF610_PAD_PTC1__ESDHC0_CMD		0x31ef
29662306a36Sopenharmony_ci			VF610_PAD_PTC2__ESDHC0_DAT0		0x31ef
29762306a36Sopenharmony_ci			VF610_PAD_PTC3__ESDHC0_DAT1		0x31ef
29862306a36Sopenharmony_ci			VF610_PAD_PTC4__ESDHC0_DAT2		0x31ef
29962306a36Sopenharmony_ci			VF610_PAD_PTC5__ESDHC0_DAT3		0x31ef
30062306a36Sopenharmony_ci			VF610_PAD_PTD23__ESDHC0_DAT4		0x31ef
30162306a36Sopenharmony_ci			VF610_PAD_PTD22__ESDHC0_DAT5		0x31ef
30262306a36Sopenharmony_ci			VF610_PAD_PTD21__ESDHC0_DAT6		0x31ef
30362306a36Sopenharmony_ci			VF610_PAD_PTD20__ESDHC0_DAT7		0x31ef
30462306a36Sopenharmony_ci		>;
30562306a36Sopenharmony_ci	};
30662306a36Sopenharmony_ci
30762306a36Sopenharmony_ci	pinctrl_esdhc1: esdhc1grp {
30862306a36Sopenharmony_ci		fsl,pins = <
30962306a36Sopenharmony_ci			VF610_PAD_PTA24__ESDHC1_CLK		0x31ef
31062306a36Sopenharmony_ci			VF610_PAD_PTA25__ESDHC1_CMD		0x31ef
31162306a36Sopenharmony_ci			VF610_PAD_PTA26__ESDHC1_DAT0		0x31ef
31262306a36Sopenharmony_ci			VF610_PAD_PTA27__ESDHC1_DAT1		0x31ef
31362306a36Sopenharmony_ci			VF610_PAD_PTA28__ESDHC1_DATA2		0x31ef
31462306a36Sopenharmony_ci			VF610_PAD_PTA29__ESDHC1_DAT3		0x31ef
31562306a36Sopenharmony_ci		>;
31662306a36Sopenharmony_ci	};
31762306a36Sopenharmony_ci
31862306a36Sopenharmony_ci	pinctrl_fec1: fec1grp {
31962306a36Sopenharmony_ci		fsl,pins = <
32062306a36Sopenharmony_ci			VF610_PAD_PTA6__RMII_CLKIN		0x30d1
32162306a36Sopenharmony_ci			VF610_PAD_PTC9__ENET_RMII1_MDC		0x30d2
32262306a36Sopenharmony_ci			VF610_PAD_PTC10__ENET_RMII1_MDIO	0x30d3
32362306a36Sopenharmony_ci			VF610_PAD_PTC11__ENET_RMII1_CRS		0x30d1
32462306a36Sopenharmony_ci			VF610_PAD_PTC12__ENET_RMII1_RXD1	0x30d1
32562306a36Sopenharmony_ci			VF610_PAD_PTC13__ENET_RMII1_RXD0	0x30d1
32662306a36Sopenharmony_ci			VF610_PAD_PTC14__ENET_RMII1_RXER	0x30d1
32762306a36Sopenharmony_ci			VF610_PAD_PTC15__ENET_RMII1_TXD1	0x30d2
32862306a36Sopenharmony_ci			VF610_PAD_PTC16__ENET_RMII1_TXD0	0x30d2
32962306a36Sopenharmony_ci			VF610_PAD_PTC17__ENET_RMII1_TXEN	0x30d2
33062306a36Sopenharmony_ci		>;
33162306a36Sopenharmony_ci	};
33262306a36Sopenharmony_ci
33362306a36Sopenharmony_ci	pinctrl_gpio_switch0: pinctrl-gpio-switch0 {
33462306a36Sopenharmony_ci		fsl,pins = <
33562306a36Sopenharmony_ci			VF610_PAD_PTB28__GPIO_98		0x219d
33662306a36Sopenharmony_ci		>;
33762306a36Sopenharmony_ci	};
33862306a36Sopenharmony_ci
33962306a36Sopenharmony_ci	pinctrl_i2c0: i2c0grp {
34062306a36Sopenharmony_ci		fsl,pins = <
34162306a36Sopenharmony_ci			VF610_PAD_PTB14__I2C0_SCL		0x37ff
34262306a36Sopenharmony_ci			VF610_PAD_PTB15__I2C0_SDA		0x37ff
34362306a36Sopenharmony_ci		>;
34462306a36Sopenharmony_ci	};
34562306a36Sopenharmony_ci
34662306a36Sopenharmony_ci	pinctrl_i2c1: i2c1grp {
34762306a36Sopenharmony_ci		fsl,pins = <
34862306a36Sopenharmony_ci			VF610_PAD_PTB16__I2C1_SCL		0x37ff
34962306a36Sopenharmony_ci			VF610_PAD_PTB17__I2C1_SDA		0x37ff
35062306a36Sopenharmony_ci		>;
35162306a36Sopenharmony_ci	};
35262306a36Sopenharmony_ci
35362306a36Sopenharmony_ci	pinctrl_leds_debug: pinctrl-leds-debug {
35462306a36Sopenharmony_ci		fsl,pins = <
35562306a36Sopenharmony_ci			VF610_PAD_PTD3__GPIO_82			0x31c2
35662306a36Sopenharmony_ci		>;
35762306a36Sopenharmony_ci	};
35862306a36Sopenharmony_ci
35962306a36Sopenharmony_ci	pinctrl_uart0: uart0grp {
36062306a36Sopenharmony_ci		fsl,pins = <
36162306a36Sopenharmony_ci			VF610_PAD_PTB10__UART0_TX		0x21a2
36262306a36Sopenharmony_ci			VF610_PAD_PTB11__UART0_RX		0x21a1
36362306a36Sopenharmony_ci		>;
36462306a36Sopenharmony_ci	};
36562306a36Sopenharmony_ci
36662306a36Sopenharmony_ci	pinctrl_uart1: uart1grp {
36762306a36Sopenharmony_ci		fsl,pins = <
36862306a36Sopenharmony_ci			VF610_PAD_PTB23__UART1_TX		0x21a2
36962306a36Sopenharmony_ci			VF610_PAD_PTB24__UART1_RX		0x21a1
37062306a36Sopenharmony_ci		>;
37162306a36Sopenharmony_ci	};
37262306a36Sopenharmony_ci};
373