162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Device Tree Source for AMCC Arches (dual 460GT board)
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * (C) Copyright 2008 Applied Micro Circuits Corporation
662306a36Sopenharmony_ci * Victor Gallardo <vgallardo@amcc.com>
762306a36Sopenharmony_ci * Adam Graham <agraham@amcc.com>
862306a36Sopenharmony_ci *
962306a36Sopenharmony_ci * Based on the glacier.dts file
1062306a36Sopenharmony_ci *   Stefan Roese <sr@denx.de>
1162306a36Sopenharmony_ci *   Copyright 2008 DENX Software Engineering
1262306a36Sopenharmony_ci *
1362306a36Sopenharmony_ci * See file CREDITS for list of people who contributed to this
1462306a36Sopenharmony_ci * project.
1562306a36Sopenharmony_ci */
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci/dts-v1/;
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci/ {
2062306a36Sopenharmony_ci	#address-cells = <2>;
2162306a36Sopenharmony_ci	#size-cells = <1>;
2262306a36Sopenharmony_ci	model = "amcc,arches";
2362306a36Sopenharmony_ci	compatible = "amcc,arches";
2462306a36Sopenharmony_ci	dcr-parent = <&{/cpus/cpu@0}>;
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci	aliases {
2762306a36Sopenharmony_ci		ethernet0 = &EMAC0;
2862306a36Sopenharmony_ci		ethernet1 = &EMAC1;
2962306a36Sopenharmony_ci		ethernet2 = &EMAC2;
3062306a36Sopenharmony_ci		serial0 = &UART0;
3162306a36Sopenharmony_ci	};
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci	cpus {
3462306a36Sopenharmony_ci		#address-cells = <1>;
3562306a36Sopenharmony_ci		#size-cells = <0>;
3662306a36Sopenharmony_ci
3762306a36Sopenharmony_ci		cpu@0 {
3862306a36Sopenharmony_ci			device_type = "cpu";
3962306a36Sopenharmony_ci			model = "PowerPC,460GT";
4062306a36Sopenharmony_ci			reg = <0x00000000>;
4162306a36Sopenharmony_ci			clock-frequency = <0>; /* Filled in by U-Boot */
4262306a36Sopenharmony_ci			timebase-frequency = <0>; /* Filled in by U-Boot */
4362306a36Sopenharmony_ci			i-cache-line-size = <32>;
4462306a36Sopenharmony_ci			d-cache-line-size = <32>;
4562306a36Sopenharmony_ci			i-cache-size = <32768>;
4662306a36Sopenharmony_ci			d-cache-size = <32768>;
4762306a36Sopenharmony_ci			dcr-controller;
4862306a36Sopenharmony_ci			dcr-access-method = "native";
4962306a36Sopenharmony_ci			next-level-cache = <&L2C0>;
5062306a36Sopenharmony_ci		};
5162306a36Sopenharmony_ci	};
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci	memory {
5462306a36Sopenharmony_ci		device_type = "memory";
5562306a36Sopenharmony_ci		reg = <0x00000000 0x00000000 0x00000000>; /* Filled in by U-Boot */
5662306a36Sopenharmony_ci	};
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci	UIC0: interrupt-controller0 {
5962306a36Sopenharmony_ci		compatible = "ibm,uic-460gt","ibm,uic";
6062306a36Sopenharmony_ci		interrupt-controller;
6162306a36Sopenharmony_ci		cell-index = <0>;
6262306a36Sopenharmony_ci		dcr-reg = <0x0c0 0x009>;
6362306a36Sopenharmony_ci		#address-cells = <0>;
6462306a36Sopenharmony_ci		#size-cells = <0>;
6562306a36Sopenharmony_ci		#interrupt-cells = <2>;
6662306a36Sopenharmony_ci	};
6762306a36Sopenharmony_ci
6862306a36Sopenharmony_ci	UIC1: interrupt-controller1 {
6962306a36Sopenharmony_ci		compatible = "ibm,uic-460gt","ibm,uic";
7062306a36Sopenharmony_ci		interrupt-controller;
7162306a36Sopenharmony_ci		cell-index = <1>;
7262306a36Sopenharmony_ci		dcr-reg = <0x0d0 0x009>;
7362306a36Sopenharmony_ci		#address-cells = <0>;
7462306a36Sopenharmony_ci		#size-cells = <0>;
7562306a36Sopenharmony_ci		#interrupt-cells = <2>;
7662306a36Sopenharmony_ci		interrupts = <0x1e 0x4 0x1f 0x4>; /* cascade */
7762306a36Sopenharmony_ci		interrupt-parent = <&UIC0>;
7862306a36Sopenharmony_ci	};
7962306a36Sopenharmony_ci
8062306a36Sopenharmony_ci	UIC2: interrupt-controller2 {
8162306a36Sopenharmony_ci		compatible = "ibm,uic-460gt","ibm,uic";
8262306a36Sopenharmony_ci		interrupt-controller;
8362306a36Sopenharmony_ci		cell-index = <2>;
8462306a36Sopenharmony_ci		dcr-reg = <0x0e0 0x009>;
8562306a36Sopenharmony_ci		#address-cells = <0>;
8662306a36Sopenharmony_ci		#size-cells = <0>;
8762306a36Sopenharmony_ci		#interrupt-cells = <2>;
8862306a36Sopenharmony_ci		interrupts = <0xa 0x4 0xb 0x4>; /* cascade */
8962306a36Sopenharmony_ci		interrupt-parent = <&UIC0>;
9062306a36Sopenharmony_ci	};
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci	UIC3: interrupt-controller3 {
9362306a36Sopenharmony_ci		compatible = "ibm,uic-460gt","ibm,uic";
9462306a36Sopenharmony_ci		interrupt-controller;
9562306a36Sopenharmony_ci		cell-index = <3>;
9662306a36Sopenharmony_ci		dcr-reg = <0x0f0 0x009>;
9762306a36Sopenharmony_ci		#address-cells = <0>;
9862306a36Sopenharmony_ci		#size-cells = <0>;
9962306a36Sopenharmony_ci		#interrupt-cells = <2>;
10062306a36Sopenharmony_ci		interrupts = <0x10 0x4 0x11 0x4>; /* cascade */
10162306a36Sopenharmony_ci		interrupt-parent = <&UIC0>;
10262306a36Sopenharmony_ci	};
10362306a36Sopenharmony_ci
10462306a36Sopenharmony_ci	SDR0: sdr {
10562306a36Sopenharmony_ci		compatible = "ibm,sdr-460gt";
10662306a36Sopenharmony_ci		dcr-reg = <0x00e 0x002>;
10762306a36Sopenharmony_ci	};
10862306a36Sopenharmony_ci
10962306a36Sopenharmony_ci	CPR0: cpr {
11062306a36Sopenharmony_ci		compatible = "ibm,cpr-460gt";
11162306a36Sopenharmony_ci		dcr-reg = <0x00c 0x002>;
11262306a36Sopenharmony_ci	};
11362306a36Sopenharmony_ci
11462306a36Sopenharmony_ci	L2C0: l2c {
11562306a36Sopenharmony_ci		compatible = "ibm,l2-cache-460gt", "ibm,l2-cache";
11662306a36Sopenharmony_ci		dcr-reg = <0x020 0x008		/* Internal SRAM DCR's */
11762306a36Sopenharmony_ci			   0x030 0x008>;	/* L2 cache DCR's */
11862306a36Sopenharmony_ci		cache-line-size = <32>;		/* 32 bytes */
11962306a36Sopenharmony_ci		cache-size = <262144>;		/* L2, 256K */
12062306a36Sopenharmony_ci		interrupt-parent = <&UIC1>;
12162306a36Sopenharmony_ci		interrupts = <11 1>;
12262306a36Sopenharmony_ci	};
12362306a36Sopenharmony_ci
12462306a36Sopenharmony_ci	plb {
12562306a36Sopenharmony_ci		compatible = "ibm,plb-460gt", "ibm,plb4";
12662306a36Sopenharmony_ci		#address-cells = <2>;
12762306a36Sopenharmony_ci		#size-cells = <1>;
12862306a36Sopenharmony_ci		ranges;
12962306a36Sopenharmony_ci		clock-frequency = <0>; /* Filled in by U-Boot */
13062306a36Sopenharmony_ci
13162306a36Sopenharmony_ci		SDRAM0: sdram {
13262306a36Sopenharmony_ci			compatible = "ibm,sdram-460gt", "ibm,sdram-405gp";
13362306a36Sopenharmony_ci			dcr-reg = <0x010 0x002>;
13462306a36Sopenharmony_ci		};
13562306a36Sopenharmony_ci
13662306a36Sopenharmony_ci		CRYPTO: crypto@180000 {
13762306a36Sopenharmony_ci			compatible = "amcc,ppc460gt-crypto", "amcc,ppc4xx-crypto";
13862306a36Sopenharmony_ci			reg = <4 0x00180000 0x80400>;
13962306a36Sopenharmony_ci			interrupt-parent = <&UIC0>;
14062306a36Sopenharmony_ci			interrupts = <0x1d 0x4>;
14162306a36Sopenharmony_ci		};
14262306a36Sopenharmony_ci
14362306a36Sopenharmony_ci		MAL0: mcmal {
14462306a36Sopenharmony_ci			compatible = "ibm,mcmal-460gt", "ibm,mcmal2";
14562306a36Sopenharmony_ci			dcr-reg = <0x180 0x062>;
14662306a36Sopenharmony_ci			num-tx-chans = <3>;
14762306a36Sopenharmony_ci			num-rx-chans = <24>;
14862306a36Sopenharmony_ci			#address-cells = <0>;
14962306a36Sopenharmony_ci			#size-cells = <0>;
15062306a36Sopenharmony_ci			interrupt-parent = <&UIC2>;
15162306a36Sopenharmony_ci			interrupts = <	/*TXEOB*/ 0x6 0x4
15262306a36Sopenharmony_ci					/*RXEOB*/ 0x7 0x4
15362306a36Sopenharmony_ci					/*SERR*/  0x3 0x4
15462306a36Sopenharmony_ci					/*TXDE*/  0x4 0x4
15562306a36Sopenharmony_ci					/*RXDE*/  0x5 0x4>;
15662306a36Sopenharmony_ci			desc-base-addr-high = <0x8>;
15762306a36Sopenharmony_ci		};
15862306a36Sopenharmony_ci
15962306a36Sopenharmony_ci		POB0: opb {
16062306a36Sopenharmony_ci			compatible = "ibm,opb-460gt", "ibm,opb";
16162306a36Sopenharmony_ci			#address-cells = <1>;
16262306a36Sopenharmony_ci			#size-cells = <1>;
16362306a36Sopenharmony_ci			ranges = <0xb0000000 0x00000004 0xb0000000 0x50000000>;
16462306a36Sopenharmony_ci			clock-frequency = <0>; /* Filled in by U-Boot */
16562306a36Sopenharmony_ci
16662306a36Sopenharmony_ci			EBC0: ebc {
16762306a36Sopenharmony_ci				compatible = "ibm,ebc-460gt", "ibm,ebc";
16862306a36Sopenharmony_ci				dcr-reg = <0x012 0x002>;
16962306a36Sopenharmony_ci				#address-cells = <2>;
17062306a36Sopenharmony_ci				#size-cells = <1>;
17162306a36Sopenharmony_ci				clock-frequency = <0>; /* Filled in by U-Boot */
17262306a36Sopenharmony_ci				/* ranges property is supplied by U-Boot */
17362306a36Sopenharmony_ci				interrupts = <0x6 0x4>;
17462306a36Sopenharmony_ci				interrupt-parent = <&UIC1>;
17562306a36Sopenharmony_ci
17662306a36Sopenharmony_ci				nor_flash@0,0 {
17762306a36Sopenharmony_ci					compatible = "amd,s29gl256n", "cfi-flash";
17862306a36Sopenharmony_ci					bank-width = <2>;
17962306a36Sopenharmony_ci					reg = <0x00000000 0x00000000 0x02000000>;
18062306a36Sopenharmony_ci					#address-cells = <1>;
18162306a36Sopenharmony_ci					#size-cells = <1>;
18262306a36Sopenharmony_ci					partition@0 {
18362306a36Sopenharmony_ci						label = "kernel";
18462306a36Sopenharmony_ci						reg = <0x00000000 0x001e0000>;
18562306a36Sopenharmony_ci					};
18662306a36Sopenharmony_ci					partition@1e0000 {
18762306a36Sopenharmony_ci						label = "dtb";
18862306a36Sopenharmony_ci						reg = <0x001e0000 0x00020000>;
18962306a36Sopenharmony_ci					};
19062306a36Sopenharmony_ci					partition@200000 {
19162306a36Sopenharmony_ci						label = "root";
19262306a36Sopenharmony_ci						reg = <0x00200000 0x00200000>;
19362306a36Sopenharmony_ci					};
19462306a36Sopenharmony_ci					partition@400000 {
19562306a36Sopenharmony_ci						label = "user";
19662306a36Sopenharmony_ci						reg = <0x00400000 0x01b60000>;
19762306a36Sopenharmony_ci					};
19862306a36Sopenharmony_ci					partition@1f60000 {
19962306a36Sopenharmony_ci						label = "env";
20062306a36Sopenharmony_ci						reg = <0x01f60000 0x00040000>;
20162306a36Sopenharmony_ci					};
20262306a36Sopenharmony_ci					partition@1fa0000 {
20362306a36Sopenharmony_ci						label = "u-boot";
20462306a36Sopenharmony_ci						reg = <0x01fa0000 0x00060000>;
20562306a36Sopenharmony_ci					};
20662306a36Sopenharmony_ci				};
20762306a36Sopenharmony_ci			};
20862306a36Sopenharmony_ci
20962306a36Sopenharmony_ci			UART0: serial@ef600300 {
21062306a36Sopenharmony_ci				device_type = "serial";
21162306a36Sopenharmony_ci				compatible = "ns16550";
21262306a36Sopenharmony_ci				reg = <0xef600300 0x00000008>;
21362306a36Sopenharmony_ci				virtual-reg = <0xef600300>;
21462306a36Sopenharmony_ci				clock-frequency = <0>; /* Filled in by U-Boot */
21562306a36Sopenharmony_ci				current-speed = <0>; /* Filled in by U-Boot */
21662306a36Sopenharmony_ci				interrupt-parent = <&UIC1>;
21762306a36Sopenharmony_ci				interrupts = <0x1 0x4>;
21862306a36Sopenharmony_ci			};
21962306a36Sopenharmony_ci
22062306a36Sopenharmony_ci			IIC0: i2c@ef600700 {
22162306a36Sopenharmony_ci				compatible = "ibm,iic-460gt", "ibm,iic";
22262306a36Sopenharmony_ci				reg = <0xef600700 0x00000014>;
22362306a36Sopenharmony_ci				interrupt-parent = <&UIC0>;
22462306a36Sopenharmony_ci				interrupts = <0x2 0x4>;
22562306a36Sopenharmony_ci				#address-cells = <1>;
22662306a36Sopenharmony_ci				#size-cells = <0>;
22762306a36Sopenharmony_ci				sttm@4a {
22862306a36Sopenharmony_ci					compatible = "ad,ad7414";
22962306a36Sopenharmony_ci					reg = <0x4a>;
23062306a36Sopenharmony_ci					interrupt-parent = <&UIC1>;
23162306a36Sopenharmony_ci					interrupts = <0x0 0x8>;
23262306a36Sopenharmony_ci				};
23362306a36Sopenharmony_ci			};
23462306a36Sopenharmony_ci
23562306a36Sopenharmony_ci			IIC1: i2c@ef600800 {
23662306a36Sopenharmony_ci				compatible = "ibm,iic-460gt", "ibm,iic";
23762306a36Sopenharmony_ci				reg = <0xef600800 0x00000014>;
23862306a36Sopenharmony_ci				interrupt-parent = <&UIC0>;
23962306a36Sopenharmony_ci				interrupts = <0x3 0x4>;
24062306a36Sopenharmony_ci			};
24162306a36Sopenharmony_ci
24262306a36Sopenharmony_ci			TAH0: emac-tah@ef601350 {
24362306a36Sopenharmony_ci				compatible = "ibm,tah-460gt", "ibm,tah";
24462306a36Sopenharmony_ci				reg = <0xef601350 0x00000030>;
24562306a36Sopenharmony_ci			};
24662306a36Sopenharmony_ci
24762306a36Sopenharmony_ci			TAH1: emac-tah@ef601450 {
24862306a36Sopenharmony_ci				compatible = "ibm,tah-460gt", "ibm,tah";
24962306a36Sopenharmony_ci				reg = <0xef601450 0x00000030>;
25062306a36Sopenharmony_ci			};
25162306a36Sopenharmony_ci
25262306a36Sopenharmony_ci			EMAC0: ethernet@ef600e00 {
25362306a36Sopenharmony_ci				device_type = "network";
25462306a36Sopenharmony_ci				compatible = "ibm,emac-460gt", "ibm,emac4sync";
25562306a36Sopenharmony_ci				interrupt-parent = <&EMAC0>;
25662306a36Sopenharmony_ci				interrupts = <0x0 0x1>;
25762306a36Sopenharmony_ci				#interrupt-cells = <1>;
25862306a36Sopenharmony_ci				#address-cells = <0>;
25962306a36Sopenharmony_ci				#size-cells = <0>;
26062306a36Sopenharmony_ci				interrupt-map = </*Status*/ 0x0 &UIC2 0x10 0x4
26162306a36Sopenharmony_ci						 /*Wake*/   0x1 &UIC2 0x14 0x4>;
26262306a36Sopenharmony_ci				reg = <0xef600e00 0x000000c4>;
26362306a36Sopenharmony_ci				local-mac-address = [000000000000]; /* Filled in by U-Boot */
26462306a36Sopenharmony_ci				mal-device = <&MAL0>;
26562306a36Sopenharmony_ci				mal-tx-channel = <0>;
26662306a36Sopenharmony_ci				mal-rx-channel = <0>;
26762306a36Sopenharmony_ci				cell-index = <0>;
26862306a36Sopenharmony_ci				max-frame-size = <9000>;
26962306a36Sopenharmony_ci				rx-fifo-size = <4096>;
27062306a36Sopenharmony_ci				tx-fifo-size = <2048>;
27162306a36Sopenharmony_ci				rx-fifo-size-gige = <16384>;
27262306a36Sopenharmony_ci				phy-mode = "sgmii";
27362306a36Sopenharmony_ci				phy-map = <0xffffffff>;
27462306a36Sopenharmony_ci				gpcs-address = <0x0000000a>;
27562306a36Sopenharmony_ci				tah-device = <&TAH0>;
27662306a36Sopenharmony_ci				tah-channel = <0>;
27762306a36Sopenharmony_ci				has-inverted-stacr-oc;
27862306a36Sopenharmony_ci				has-new-stacr-staopc;
27962306a36Sopenharmony_ci			};
28062306a36Sopenharmony_ci
28162306a36Sopenharmony_ci			EMAC1: ethernet@ef600f00 {
28262306a36Sopenharmony_ci				device_type = "network";
28362306a36Sopenharmony_ci				compatible = "ibm,emac-460gt", "ibm,emac4sync";
28462306a36Sopenharmony_ci				interrupt-parent = <&EMAC1>;
28562306a36Sopenharmony_ci				interrupts = <0x0 0x1>;
28662306a36Sopenharmony_ci				#interrupt-cells = <1>;
28762306a36Sopenharmony_ci				#address-cells = <0>;
28862306a36Sopenharmony_ci				#size-cells = <0>;
28962306a36Sopenharmony_ci				interrupt-map = </*Status*/ 0x0 &UIC2 0x11 0x4
29062306a36Sopenharmony_ci						 /*Wake*/   0x1 &UIC2 0x15 0x4>;
29162306a36Sopenharmony_ci				reg = <0xef600f00 0x000000c4>;
29262306a36Sopenharmony_ci				local-mac-address = [000000000000]; /* Filled in by U-Boot */
29362306a36Sopenharmony_ci				mal-device = <&MAL0>;
29462306a36Sopenharmony_ci				mal-tx-channel = <1>;
29562306a36Sopenharmony_ci				mal-rx-channel = <8>;
29662306a36Sopenharmony_ci				cell-index = <1>;
29762306a36Sopenharmony_ci				max-frame-size = <9000>;
29862306a36Sopenharmony_ci				rx-fifo-size = <4096>;
29962306a36Sopenharmony_ci				tx-fifo-size = <2048>;
30062306a36Sopenharmony_ci				rx-fifo-size-gige = <16384>;
30162306a36Sopenharmony_ci				phy-mode = "sgmii";
30262306a36Sopenharmony_ci				phy-map = <0x00000000>;
30362306a36Sopenharmony_ci				gpcs-address = <0x0000000b>;
30462306a36Sopenharmony_ci				tah-device = <&TAH1>;
30562306a36Sopenharmony_ci				tah-channel = <1>;
30662306a36Sopenharmony_ci				has-inverted-stacr-oc;
30762306a36Sopenharmony_ci				has-new-stacr-staopc;
30862306a36Sopenharmony_ci				mdio-device = <&EMAC0>;
30962306a36Sopenharmony_ci			};
31062306a36Sopenharmony_ci
31162306a36Sopenharmony_ci			EMAC2: ethernet@ef601100 {
31262306a36Sopenharmony_ci				device_type = "network";
31362306a36Sopenharmony_ci				compatible = "ibm,emac-460gt", "ibm,emac4sync";
31462306a36Sopenharmony_ci				interrupt-parent = <&EMAC2>;
31562306a36Sopenharmony_ci				interrupts = <0x0 0x1>;
31662306a36Sopenharmony_ci				#interrupt-cells = <1>;
31762306a36Sopenharmony_ci				#address-cells = <0>;
31862306a36Sopenharmony_ci				#size-cells = <0>;
31962306a36Sopenharmony_ci				interrupt-map = </*Status*/ 0x0 &UIC2 0x12 0x4
32062306a36Sopenharmony_ci						 /*Wake*/   0x1 &UIC2 0x16 0x4>;
32162306a36Sopenharmony_ci				reg = <0xef601100 0x000000c4>;
32262306a36Sopenharmony_ci				local-mac-address = [000000000000]; /* Filled in by U-Boot */
32362306a36Sopenharmony_ci				mal-device = <&MAL0>;
32462306a36Sopenharmony_ci				mal-tx-channel = <2>;
32562306a36Sopenharmony_ci				mal-rx-channel = <16>;
32662306a36Sopenharmony_ci				cell-index = <2>;
32762306a36Sopenharmony_ci				max-frame-size = <9000>;
32862306a36Sopenharmony_ci				rx-fifo-size = <4096>;
32962306a36Sopenharmony_ci				tx-fifo-size = <2048>;
33062306a36Sopenharmony_ci				rx-fifo-size-gige = <16384>;
33162306a36Sopenharmony_ci				tx-fifo-size-gige = <16384>; /* emac2&3 only */
33262306a36Sopenharmony_ci				phy-mode = "sgmii";
33362306a36Sopenharmony_ci				phy-map = <0x00000001>;
33462306a36Sopenharmony_ci				gpcs-address = <0x0000000C>;
33562306a36Sopenharmony_ci				has-inverted-stacr-oc;
33662306a36Sopenharmony_ci				has-new-stacr-staopc;
33762306a36Sopenharmony_ci				mdio-device = <&EMAC0>;
33862306a36Sopenharmony_ci			};
33962306a36Sopenharmony_ci		};
34062306a36Sopenharmony_ci	};
34162306a36Sopenharmony_ci};
342