162306a36Sopenharmony_ci/*
262306a36Sopenharmony_ci * Broadcom BCM470X / BCM5301X ARM platform code.
362306a36Sopenharmony_ci * DTS for Netgear R8000
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (C) 2015 Rafał Miłecki <zajec5@gmail.com>
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci * Permission to use, copy, modify, and/or distribute this software for any
862306a36Sopenharmony_ci * purpose with or without fee is hereby granted, provided that the above
962306a36Sopenharmony_ci * copyright notice and this permission notice appear in all copies.
1062306a36Sopenharmony_ci *
1162306a36Sopenharmony_ci * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
1262306a36Sopenharmony_ci * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
1362306a36Sopenharmony_ci * AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
1462306a36Sopenharmony_ci * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
1562306a36Sopenharmony_ci * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
1662306a36Sopenharmony_ci * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
1762306a36Sopenharmony_ci * PERFORMANCE OF THIS SOFTWARE.
1862306a36Sopenharmony_ci */
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ci/dts-v1/;
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ci#include "bcm4709.dtsi"
2362306a36Sopenharmony_ci#include "bcm5301x-nand-cs0-bch8.dtsi"
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci/ {
2662306a36Sopenharmony_ci	compatible = "netgear,r8000", "brcm,bcm4709", "brcm,bcm4708";
2762306a36Sopenharmony_ci	model = "Netgear R8000 (BCM4709)";
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_ci	chosen {
3062306a36Sopenharmony_ci		bootargs = "console=ttyS0,115200";
3162306a36Sopenharmony_ci	};
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci	memory@0 {
3462306a36Sopenharmony_ci		device_type = "memory";
3562306a36Sopenharmony_ci		reg = <0x00000000 0x08000000>,
3662306a36Sopenharmony_ci		      <0x88000000 0x08000000>;
3762306a36Sopenharmony_ci	};
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci	leds {
4062306a36Sopenharmony_ci		compatible = "gpio-leds";
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci		led-power-white {
4362306a36Sopenharmony_ci			label = "bcm53xx:white:power";
4462306a36Sopenharmony_ci			gpios = <&chipcommon 2 GPIO_ACTIVE_LOW>;
4562306a36Sopenharmony_ci			linux,default-trigger = "default-on";
4662306a36Sopenharmony_ci		};
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci		led-power-amber {
4962306a36Sopenharmony_ci			label = "bcm53xx:amber:power";
5062306a36Sopenharmony_ci			gpios = <&chipcommon 3 GPIO_ACTIVE_LOW>;
5162306a36Sopenharmony_ci		};
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci		led-wan-white {
5462306a36Sopenharmony_ci			label = "bcm53xx:white:wan";
5562306a36Sopenharmony_ci			gpios = <&chipcommon 8 GPIO_ACTIVE_LOW>;
5662306a36Sopenharmony_ci			linux,default-trigger = "default-on";
5762306a36Sopenharmony_ci		};
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_ci		led-wan-amber {
6062306a36Sopenharmony_ci			label = "bcm53xx:amber:wan";
6162306a36Sopenharmony_ci			gpios = <&chipcommon 9 GPIO_ACTIVE_HIGH>;
6262306a36Sopenharmony_ci		};
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_ci		led-5ghz-1 {
6562306a36Sopenharmony_ci			label = "bcm53xx:white:5ghz-1";
6662306a36Sopenharmony_ci			gpios = <&chipcommon 12 GPIO_ACTIVE_LOW>;
6762306a36Sopenharmony_ci		};
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ci		led-2ghz {
7062306a36Sopenharmony_ci			label = "bcm53xx:white:2ghz";
7162306a36Sopenharmony_ci			gpios = <&chipcommon 13 GPIO_ACTIVE_LOW>;
7262306a36Sopenharmony_ci		};
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_ci		led-wireless {
7562306a36Sopenharmony_ci			label = "bcm53xx:white:wireless";
7662306a36Sopenharmony_ci			gpios = <&chipcommon 14 GPIO_ACTIVE_HIGH>;
7762306a36Sopenharmony_ci		};
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_ci		led-wps {
8062306a36Sopenharmony_ci			label = "bcm53xx:white:wps";
8162306a36Sopenharmony_ci			gpios = <&chipcommon 15 GPIO_ACTIVE_HIGH>;
8262306a36Sopenharmony_ci		};
8362306a36Sopenharmony_ci
8462306a36Sopenharmony_ci		led-5ghz-2 {
8562306a36Sopenharmony_ci			label = "bcm53xx:white:5ghz-2";
8662306a36Sopenharmony_ci			gpios = <&chipcommon 16 GPIO_ACTIVE_LOW>;
8762306a36Sopenharmony_ci		};
8862306a36Sopenharmony_ci
8962306a36Sopenharmony_ci		led-usb3 {
9062306a36Sopenharmony_ci			label = "bcm53xx:white:usb3";
9162306a36Sopenharmony_ci			gpios = <&chipcommon 17 GPIO_ACTIVE_LOW>;
9262306a36Sopenharmony_ci		};
9362306a36Sopenharmony_ci
9462306a36Sopenharmony_ci		led-usb2 {
9562306a36Sopenharmony_ci			label = "bcm53xx:white:usb2";
9662306a36Sopenharmony_ci			gpios = <&chipcommon 18 GPIO_ACTIVE_LOW>;
9762306a36Sopenharmony_ci		};
9862306a36Sopenharmony_ci	};
9962306a36Sopenharmony_ci
10062306a36Sopenharmony_ci	gpio-keys {
10162306a36Sopenharmony_ci		compatible = "gpio-keys";
10262306a36Sopenharmony_ci
10362306a36Sopenharmony_ci		button-rfkill {
10462306a36Sopenharmony_ci			label = "WiFi";
10562306a36Sopenharmony_ci			linux,code = <KEY_RFKILL>;
10662306a36Sopenharmony_ci			gpios = <&chipcommon 4 GPIO_ACTIVE_LOW>;
10762306a36Sopenharmony_ci		};
10862306a36Sopenharmony_ci
10962306a36Sopenharmony_ci		button-wps {
11062306a36Sopenharmony_ci			label = "WPS";
11162306a36Sopenharmony_ci			linux,code = <KEY_WPS_BUTTON>;
11262306a36Sopenharmony_ci			gpios = <&chipcommon 5 GPIO_ACTIVE_LOW>;
11362306a36Sopenharmony_ci		};
11462306a36Sopenharmony_ci
11562306a36Sopenharmony_ci		button-restart {
11662306a36Sopenharmony_ci			label = "Reset";
11762306a36Sopenharmony_ci			linux,code = <KEY_RESTART>;
11862306a36Sopenharmony_ci			gpios = <&chipcommon 6 GPIO_ACTIVE_LOW>;
11962306a36Sopenharmony_ci		};
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci		button-brightness {
12262306a36Sopenharmony_ci			label = "Backlight";
12362306a36Sopenharmony_ci			linux,code = <KEY_BRIGHTNESS_ZERO>;
12462306a36Sopenharmony_ci			gpios = <&chipcommon 19 GPIO_ACTIVE_LOW>;
12562306a36Sopenharmony_ci		};
12662306a36Sopenharmony_ci	};
12762306a36Sopenharmony_ci};
12862306a36Sopenharmony_ci
12962306a36Sopenharmony_ci&pcie0 {
13062306a36Sopenharmony_ci	#address-cells = <3>;
13162306a36Sopenharmony_ci	#size-cells = <2>;
13262306a36Sopenharmony_ci
13362306a36Sopenharmony_ci	bridge@0,0,0 {
13462306a36Sopenharmony_ci		reg = <0x0000 0 0 0 0>;
13562306a36Sopenharmony_ci
13662306a36Sopenharmony_ci		#address-cells = <3>;
13762306a36Sopenharmony_ci		#size-cells = <2>;
13862306a36Sopenharmony_ci
13962306a36Sopenharmony_ci		wifi@0,1,0 {
14062306a36Sopenharmony_ci			compatible = "brcm,bcm4366-fmac", "brcm,bcm4329-fmac";
14162306a36Sopenharmony_ci			reg = <0x0000 0 0 0 0>;
14262306a36Sopenharmony_ci			ieee80211-freq-limit = <5735000 5835000>;
14362306a36Sopenharmony_ci			brcm,ccode-map = "JP-JP-78", "US-Q2-86";
14462306a36Sopenharmony_ci		};
14562306a36Sopenharmony_ci	};
14662306a36Sopenharmony_ci};
14762306a36Sopenharmony_ci
14862306a36Sopenharmony_ci&pcie1 {
14962306a36Sopenharmony_ci	#address-cells = <3>;
15062306a36Sopenharmony_ci	#size-cells = <2>;
15162306a36Sopenharmony_ci
15262306a36Sopenharmony_ci	bridge@1,0,0 {
15362306a36Sopenharmony_ci		reg = <0x0000 0 0 0 0>;
15462306a36Sopenharmony_ci
15562306a36Sopenharmony_ci		#address-cells = <3>;
15662306a36Sopenharmony_ci		#size-cells = <2>;
15762306a36Sopenharmony_ci
15862306a36Sopenharmony_ci		bridge@1,1,0 {
15962306a36Sopenharmony_ci			reg = <0x0000 0 0 0 0>;
16062306a36Sopenharmony_ci
16162306a36Sopenharmony_ci			#address-cells = <3>;
16262306a36Sopenharmony_ci			#size-cells = <2>;
16362306a36Sopenharmony_ci
16462306a36Sopenharmony_ci			bridge@1,0 {
16562306a36Sopenharmony_ci				reg = <0x800 0 0 0 0>;
16662306a36Sopenharmony_ci
16762306a36Sopenharmony_ci				#address-cells = <3>;
16862306a36Sopenharmony_ci				#size-cells = <2>;
16962306a36Sopenharmony_ci
17062306a36Sopenharmony_ci				wifi@0,0 {
17162306a36Sopenharmony_ci					compatible = "brcm,bcm4366-fmac", "brcm,bcm4329-fmac";
17262306a36Sopenharmony_ci					reg = <0x0000 0 0 0 0>;
17362306a36Sopenharmony_ci					brcm,ccode-map = "JP-JP-78", "US-Q2-86";
17462306a36Sopenharmony_ci				};
17562306a36Sopenharmony_ci			};
17662306a36Sopenharmony_ci
17762306a36Sopenharmony_ci			bridge@1,2,2 {
17862306a36Sopenharmony_ci				reg = <0x1000 0 0 0 0>;
17962306a36Sopenharmony_ci
18062306a36Sopenharmony_ci				#address-cells = <3>;
18162306a36Sopenharmony_ci				#size-cells = <2>;
18262306a36Sopenharmony_ci
18362306a36Sopenharmony_ci				wifi@1,4,0 {
18462306a36Sopenharmony_ci					compatible = "brcm,bcm4366-fmac", "brcm,bcm4329-fmac";
18562306a36Sopenharmony_ci					reg = <0x0000 0 0 0 0>;
18662306a36Sopenharmony_ci					ieee80211-freq-limit = <5170000 5730000>;
18762306a36Sopenharmony_ci					brcm,ccode-map = "JP-JP-78", "US-Q2-86";
18862306a36Sopenharmony_ci				};
18962306a36Sopenharmony_ci			};
19062306a36Sopenharmony_ci		};
19162306a36Sopenharmony_ci	};
19262306a36Sopenharmony_ci};
19362306a36Sopenharmony_ci
19462306a36Sopenharmony_ci&usb2 {
19562306a36Sopenharmony_ci	vcc-gpio = <&chipcommon 0 GPIO_ACTIVE_HIGH>;
19662306a36Sopenharmony_ci};
19762306a36Sopenharmony_ci
19862306a36Sopenharmony_ci&usb3 {
19962306a36Sopenharmony_ci	vcc-gpio = <&chipcommon 0 GPIO_ACTIVE_HIGH>;
20062306a36Sopenharmony_ci};
20162306a36Sopenharmony_ci
20262306a36Sopenharmony_ci&usb3_phy {
20362306a36Sopenharmony_ci	status = "okay";
20462306a36Sopenharmony_ci};
20562306a36Sopenharmony_ci
20662306a36Sopenharmony_ci&srab {
20762306a36Sopenharmony_ci	status = "okay";
20862306a36Sopenharmony_ci
20962306a36Sopenharmony_ci	ports {
21062306a36Sopenharmony_ci		port@0 {
21162306a36Sopenharmony_ci			label = "lan1";
21262306a36Sopenharmony_ci		};
21362306a36Sopenharmony_ci
21462306a36Sopenharmony_ci		port@1 {
21562306a36Sopenharmony_ci			label = "lan2";
21662306a36Sopenharmony_ci		};
21762306a36Sopenharmony_ci
21862306a36Sopenharmony_ci		port@2 {
21962306a36Sopenharmony_ci			label = "lan3";
22062306a36Sopenharmony_ci		};
22162306a36Sopenharmony_ci
22262306a36Sopenharmony_ci		port@3 {
22362306a36Sopenharmony_ci			label = "lan4";
22462306a36Sopenharmony_ci		};
22562306a36Sopenharmony_ci
22662306a36Sopenharmony_ci		port@4 {
22762306a36Sopenharmony_ci			label = "wan";
22862306a36Sopenharmony_ci		};
22962306a36Sopenharmony_ci
23062306a36Sopenharmony_ci		port@5 {
23162306a36Sopenharmony_ci			status = "disabled";
23262306a36Sopenharmony_ci		};
23362306a36Sopenharmony_ci
23462306a36Sopenharmony_ci		port@7 {
23562306a36Sopenharmony_ci			status = "disabled";
23662306a36Sopenharmony_ci		};
23762306a36Sopenharmony_ci
23862306a36Sopenharmony_ci		port@8 {
23962306a36Sopenharmony_ci			label = "cpu";
24062306a36Sopenharmony_ci		};
24162306a36Sopenharmony_ci	};
24262306a36Sopenharmony_ci};
243