Linux Audio

Check our new training course

In-person Linux kernel drivers training

Jun 16-20, 2025
Register
Loading...
v4.17
  1// SPDX-License-Identifier: GPL-2.0
  2/*
  3 * Device Tree file for Wiliboard WBD-222
  4 */
  5
  6/dts-v1/;
  7
  8#include "gemini.dtsi"
  9#include <dt-bindings/input/input.h>
 10
 11/ {
 12	model = "Wiliboard WBD-222";
 13	compatible = "wiliboard,wbd222", "cortina,gemini";
 14	#address-cells = <1>;
 15	#size-cells = <1>;
 16
 17	memory { /* 128 MB */
 18		device_type = "memory";
 19		reg = <0x00000000 0x8000000>;
 20	};
 21
 22	chosen {
 23		bootargs = "console=ttyS0,115200n8";
 24		stdout-path = &uart0;
 25	};
 26
 27	gpio_keys {
 28		compatible = "gpio-keys";
 29		#address-cells = <1>;
 30		#size-cells = <0>;
 31
 32		button@5 {
 33			debounce_interval = <50>;
 34			wakeup-source;
 35			linux,code = <KEY_SETUP>;
 36			label = "reset";
 37			/* Conflict with ICE */
 38			gpios = <&gpio0 5 GPIO_ACTIVE_LOW>;
 39		};
 40	};
 41
 42	leds {
 43		compatible = "gpio-leds";
 44
 45		led@1 {
 46			label = "wbd111:red:L3";
 47			/* Conflict with TVC and extended parallel flash */
 48			gpios = <&gpio0 1 GPIO_ACTIVE_HIGH>;
 49			default-state = "off";
 50		};
 51		led@2 {
 52			label = "wbd111:green:L4";
 53			/* Conflict with TVC and extended parallel flash */
 54			gpios = <&gpio0 2 GPIO_ACTIVE_HIGH>;
 55			default-state = "off";
 56		};
 57		led@3 {
 58			label = "wbd111:red:L4";
 59			/* Conflict with TVC and extended parallel flash */
 60			gpios = <&gpio0 3 GPIO_ACTIVE_HIGH>;
 61			default-state = "off";
 62		};
 63		led@5 {
 64			label = "wbd111:green:L3";
 65			/* Conflict with TVC and extended parallel flash */
 66			gpios = <&gpio0 5 GPIO_ACTIVE_HIGH>;
 67			default-state = "on";
 68			linux,default-trigger = "heartbeat";
 69		};
 70	};
 71
 72	mdio0: ethernet-phy {
 73		compatible = "virtual,mdio-gpio";
 74		gpios = <&gpio0 22 GPIO_ACTIVE_HIGH>, /* MDC */
 75			<&gpio0 21 GPIO_ACTIVE_HIGH>; /* MDIO */
 76		#address-cells = <1>;
 77		#size-cells = <0>;
 78
 79		phy0: ethernet-phy@1 {
 80			reg = <1>;
 81			device_type = "ethernet-phy";
 82		};
 83
 84		phy1: ethernet-phy@3 {
 85			reg = <3>;
 86			device_type = "ethernet-phy";
 87		};
 88	};
 89
 90	soc {
 91		flash@30000000 {
 92			status = "okay";
 93			/* 8MB of flash */
 94			reg = <0x30000000 0x00800000>;
 95
 96			partition@0 {
 97				label = "RedBoot";
 98				reg = <0x00000000 0x00020000>;
 99				read-only;
100			};
101			partition@20000 {
102				label = "kernel";
103				reg = <0x00020000 0x00100000>;
104			};
105			partition@120000 {
106				label = "rootfs";
107				reg = <0x00120000 0x006a0000>;
108			};
109			partition@7c0000 {
110				label = "VCTL";
111				reg = <0x007c0000 0x00010000>;
112				read-only;
113			};
114			partition@7d0000 {
115				label = "cfg";
116				reg = <0x007d0000 0x00010000>;
117				read-only;
118			};
119			partition@7e0000 {
120				label = "FIS";
121				reg = <0x007e0000 0x00010000>;
122				read-only;
123			};
124		};
125
126		syscon: syscon@40000000 {
127			pinctrl {
128				/*
129				 * gpio0agrp cover line 0-4
130				 * gpio0bgrp cover line 5
131				 */
132				gpio0_default_pins: pinctrl-gpio0 {
133					mux {
134						function = "gpio0";
135						groups = "gpio0agrp",
136						"gpio0bgrp";
137					};
138				};
139				pinctrl-gmii {
140					/* This platform use both the ethernet ports */
141					mux {
142						function = "gmii";
143						groups = "gmii_gmac0_grp", "gmii_gmac1_grp";
144					};
145				};
146			};
147		};
148
149		gpio0: gpio@4d000000 {
150			pinctrl-names = "default";
151			pinctrl-0 = <&gpio0_default_pins>;
152		};
153
154		pci@50000000 {
155			status = "okay";
156			interrupt-map-mask = <0xf800 0 0 7>;
157			interrupt-map =
158				<0x4800 0 0 1 &pci_intc 0>, /* Slot 9 */
159				<0x4800 0 0 2 &pci_intc 1>,
160				<0x4800 0 0 3 &pci_intc 2>,
161				<0x4800 0 0 4 &pci_intc 3>,
162				<0x5000 0 0 1 &pci_intc 1>, /* Slot 10 */
163				<0x5000 0 0 2 &pci_intc 2>,
164				<0x5000 0 0 3 &pci_intc 3>,
165				<0x5000 0 0 4 &pci_intc 0>,
166				<0x5800 0 0 1 &pci_intc 2>, /* Slot 11 */
167				<0x5800 0 0 2 &pci_intc 3>,
168				<0x5800 0 0 3 &pci_intc 0>,
169				<0x5800 0 0 4 &pci_intc 1>,
170				<0x6000 0 0 1 &pci_intc 3>, /* Slot 12 */
171				<0x6000 0 0 2 &pci_intc 0>,
172				<0x6000 0 0 3 &pci_intc 1>,
173				<0x6000 0 0 4 &pci_intc 2>;
174		};
175
176		ethernet@60000000 {
177			status = "okay";
178
179			ethernet-port@0 {
180				phy-mode = "rgmii";
181				phy-handle = <&phy0>;
182			};
183			ethernet-port@1 {
184				phy-mode = "rgmii";
185				phy-handle = <&phy1>;
186			};
 
 
 
 
 
 
 
 
187		};
188	};
189};
v5.4
  1// SPDX-License-Identifier: GPL-2.0
  2/*
  3 * Device Tree file for Wiliboard WBD-222
  4 */
  5
  6/dts-v1/;
  7
  8#include "gemini.dtsi"
  9#include <dt-bindings/input/input.h>
 10
 11/ {
 12	model = "Wiliboard WBD-222";
 13	compatible = "wiliboard,wbd222", "cortina,gemini";
 14	#address-cells = <1>;
 15	#size-cells = <1>;
 16
 17	memory@0 { /* 128 MB */
 18		device_type = "memory";
 19		reg = <0x00000000 0x8000000>;
 20	};
 21
 22	chosen {
 23		bootargs = "console=ttyS0,115200n8";
 24		stdout-path = &uart0;
 25	};
 26
 27	gpio_keys {
 28		compatible = "gpio-keys";
 
 
 29
 30		button-setup {
 31			debounce-interval = <100>;
 32			wakeup-source;
 33			linux,code = <KEY_SETUP>;
 34			label = "reset";
 35			/* Conflict with ICE */
 36			gpios = <&gpio0 5 GPIO_ACTIVE_LOW>;
 37		};
 38	};
 39
 40	leds {
 41		compatible = "gpio-leds";
 42
 43		led-red-l3 {
 44			label = "wbd111:red:L3";
 45			/* Conflict with TVC and extended parallel flash */
 46			gpios = <&gpio0 1 GPIO_ACTIVE_HIGH>;
 47			default-state = "off";
 48		};
 49		led-green-l4 {
 50			label = "wbd111:green:L4";
 51			/* Conflict with TVC and extended parallel flash */
 52			gpios = <&gpio0 2 GPIO_ACTIVE_HIGH>;
 53			default-state = "off";
 54		};
 55		led-red-l4 {
 56			label = "wbd111:red:L4";
 57			/* Conflict with TVC and extended parallel flash */
 58			gpios = <&gpio0 3 GPIO_ACTIVE_HIGH>;
 59			default-state = "off";
 60		};
 61		led-green-l3 {
 62			label = "wbd111:green:L3";
 63			/* Conflict with TVC and extended parallel flash */
 64			gpios = <&gpio0 5 GPIO_ACTIVE_HIGH>;
 65			default-state = "on";
 66			linux,default-trigger = "heartbeat";
 67		};
 68	};
 69
 70	mdio0: ethernet-phy {
 71		compatible = "virtual,mdio-gpio";
 72		gpios = <&gpio0 22 GPIO_ACTIVE_HIGH>, /* MDC */
 73			<&gpio0 21 GPIO_ACTIVE_HIGH>; /* MDIO */
 74		#address-cells = <1>;
 75		#size-cells = <0>;
 76
 77		phy0: ethernet-phy@1 {
 78			reg = <1>;
 79			device_type = "ethernet-phy";
 80		};
 81
 82		phy1: ethernet-phy@3 {
 83			reg = <3>;
 84			device_type = "ethernet-phy";
 85		};
 86	};
 87
 88	soc {
 89		flash@30000000 {
 90			status = "okay";
 91			/* 8MB of flash */
 92			reg = <0x30000000 0x00800000>;
 93
 94			partition@0 {
 95				label = "RedBoot";
 96				reg = <0x00000000 0x00020000>;
 97				read-only;
 98			};
 99			partition@20000 {
100				label = "kernel";
101				reg = <0x00020000 0x00100000>;
102			};
103			partition@120000 {
104				label = "rootfs";
105				reg = <0x00120000 0x006a0000>;
106			};
107			partition@7c0000 {
108				label = "VCTL";
109				reg = <0x007c0000 0x00010000>;
110				read-only;
111			};
112			partition@7d0000 {
113				label = "cfg";
114				reg = <0x007d0000 0x00010000>;
115				read-only;
116			};
117			partition@7e0000 {
118				label = "FIS";
119				reg = <0x007e0000 0x00010000>;
120				read-only;
121			};
122		};
123
124		syscon: syscon@40000000 {
125			pinctrl {
126				/*
127				 * gpio0agrp cover line 0-4
128				 * gpio0bgrp cover line 5
129				 */
130				gpio0_default_pins: pinctrl-gpio0 {
131					mux {
132						function = "gpio0";
133						groups = "gpio0agrp",
134						"gpio0bgrp";
135					};
136				};
137				pinctrl-gmii {
138					/* This platform use both the ethernet ports */
139					mux {
140						function = "gmii";
141						groups = "gmii_gmac0_grp", "gmii_gmac1_grp";
142					};
143				};
144			};
145		};
146
147		gpio0: gpio@4d000000 {
148			pinctrl-names = "default";
149			pinctrl-0 = <&gpio0_default_pins>;
150		};
151
152		pci@50000000 {
153			status = "okay";
154			interrupt-map-mask = <0xf800 0 0 7>;
155			interrupt-map =
156				<0x4800 0 0 1 &pci_intc 0>, /* Slot 9 */
157				<0x4800 0 0 2 &pci_intc 1>,
158				<0x4800 0 0 3 &pci_intc 2>,
159				<0x4800 0 0 4 &pci_intc 3>,
160				<0x5000 0 0 1 &pci_intc 1>, /* Slot 10 */
161				<0x5000 0 0 2 &pci_intc 2>,
162				<0x5000 0 0 3 &pci_intc 3>,
163				<0x5000 0 0 4 &pci_intc 0>,
164				<0x5800 0 0 1 &pci_intc 2>, /* Slot 11 */
165				<0x5800 0 0 2 &pci_intc 3>,
166				<0x5800 0 0 3 &pci_intc 0>,
167				<0x5800 0 0 4 &pci_intc 1>,
168				<0x6000 0 0 1 &pci_intc 3>, /* Slot 12 */
169				<0x6000 0 0 2 &pci_intc 0>,
170				<0x6000 0 0 3 &pci_intc 1>,
171				<0x6000 0 0 4 &pci_intc 2>;
172		};
173
174		ethernet@60000000 {
175			status = "okay";
176
177			ethernet-port@0 {
178				phy-mode = "rgmii";
179				phy-handle = <&phy0>;
180			};
181			ethernet-port@1 {
182				phy-mode = "rgmii";
183				phy-handle = <&phy1>;
184			};
185		};
186
187		usb@68000000 {
188			status = "okay";
189		};
190
191		usb@69000000 {
192			status = "okay";
193		};
194	};
195};