18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * TQM5200 board Device Tree Source
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright (C) 2007 Semihalf
68c2ecf20Sopenharmony_ci * Marian Balakowicz <m8@semihalf.com>
78c2ecf20Sopenharmony_ci */
88c2ecf20Sopenharmony_ci
98c2ecf20Sopenharmony_ci/dts-v1/;
108c2ecf20Sopenharmony_ci
118c2ecf20Sopenharmony_ci/ {
128c2ecf20Sopenharmony_ci	model = "tqc,tqm5200";
138c2ecf20Sopenharmony_ci	compatible = "tqc,tqm5200";
148c2ecf20Sopenharmony_ci	#address-cells = <1>;
158c2ecf20Sopenharmony_ci	#size-cells = <1>;
168c2ecf20Sopenharmony_ci	interrupt-parent = <&mpc5200_pic>;
178c2ecf20Sopenharmony_ci
188c2ecf20Sopenharmony_ci	cpus {
198c2ecf20Sopenharmony_ci		#address-cells = <1>;
208c2ecf20Sopenharmony_ci		#size-cells = <0>;
218c2ecf20Sopenharmony_ci
228c2ecf20Sopenharmony_ci		PowerPC,5200@0 {
238c2ecf20Sopenharmony_ci			device_type = "cpu";
248c2ecf20Sopenharmony_ci			reg = <0>;
258c2ecf20Sopenharmony_ci			d-cache-line-size = <32>;
268c2ecf20Sopenharmony_ci			i-cache-line-size = <32>;
278c2ecf20Sopenharmony_ci			d-cache-size = <0x4000>;	// L1, 16K
288c2ecf20Sopenharmony_ci			i-cache-size = <0x4000>;	// L1, 16K
298c2ecf20Sopenharmony_ci			timebase-frequency = <0>;	// from bootloader
308c2ecf20Sopenharmony_ci			bus-frequency = <0>;		// from bootloader
318c2ecf20Sopenharmony_ci			clock-frequency = <0>;		// from bootloader
328c2ecf20Sopenharmony_ci		};
338c2ecf20Sopenharmony_ci	};
348c2ecf20Sopenharmony_ci
358c2ecf20Sopenharmony_ci	memory@0 {
368c2ecf20Sopenharmony_ci		device_type = "memory";
378c2ecf20Sopenharmony_ci		reg = <0x00000000 0x04000000>;	// 64MB
388c2ecf20Sopenharmony_ci	};
398c2ecf20Sopenharmony_ci
408c2ecf20Sopenharmony_ci	soc5200@f0000000 {
418c2ecf20Sopenharmony_ci		#address-cells = <1>;
428c2ecf20Sopenharmony_ci		#size-cells = <1>;
438c2ecf20Sopenharmony_ci		compatible = "fsl,mpc5200-immr";
448c2ecf20Sopenharmony_ci		ranges = <0 0xf0000000 0x0000c000>;
458c2ecf20Sopenharmony_ci		reg = <0xf0000000 0x00000100>;
468c2ecf20Sopenharmony_ci		bus-frequency = <0>;		// from bootloader
478c2ecf20Sopenharmony_ci		system-frequency = <0>;		// from bootloader
488c2ecf20Sopenharmony_ci
498c2ecf20Sopenharmony_ci		cdm@200 {
508c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-cdm";
518c2ecf20Sopenharmony_ci			reg = <0x200 0x38>;
528c2ecf20Sopenharmony_ci		};
538c2ecf20Sopenharmony_ci
548c2ecf20Sopenharmony_ci		mpc5200_pic: interrupt-controller@500 {
558c2ecf20Sopenharmony_ci			// 5200 interrupts are encoded into two levels;
568c2ecf20Sopenharmony_ci			interrupt-controller;
578c2ecf20Sopenharmony_ci			#interrupt-cells = <3>;
588c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-pic";
598c2ecf20Sopenharmony_ci			reg = <0x500 0x80>;
608c2ecf20Sopenharmony_ci		};
618c2ecf20Sopenharmony_ci
628c2ecf20Sopenharmony_ci		timer@600 {	// General Purpose Timer
638c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-gpt";
648c2ecf20Sopenharmony_ci			reg = <0x600 0x10>;
658c2ecf20Sopenharmony_ci			interrupts = <1 9 0>;
668c2ecf20Sopenharmony_ci			fsl,has-wdt;
678c2ecf20Sopenharmony_ci		};
688c2ecf20Sopenharmony_ci
698c2ecf20Sopenharmony_ci		can@900 {
708c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-mscan";
718c2ecf20Sopenharmony_ci			interrupts = <2 17 0>;
728c2ecf20Sopenharmony_ci			reg = <0x900 0x80>;
738c2ecf20Sopenharmony_ci		};
748c2ecf20Sopenharmony_ci
758c2ecf20Sopenharmony_ci		can@980 {
768c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-mscan";
778c2ecf20Sopenharmony_ci			interrupts = <2 18 0>;
788c2ecf20Sopenharmony_ci			reg = <0x980 0x80>;
798c2ecf20Sopenharmony_ci		};
808c2ecf20Sopenharmony_ci
818c2ecf20Sopenharmony_ci		gpio_simple: gpio@b00 {
828c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-gpio";
838c2ecf20Sopenharmony_ci			reg = <0xb00 0x40>;
848c2ecf20Sopenharmony_ci			interrupts = <1 7 0>;
858c2ecf20Sopenharmony_ci			gpio-controller;
868c2ecf20Sopenharmony_ci			#gpio-cells = <2>;
878c2ecf20Sopenharmony_ci		};
888c2ecf20Sopenharmony_ci
898c2ecf20Sopenharmony_ci		usb@1000 {
908c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-ohci","ohci-be";
918c2ecf20Sopenharmony_ci			reg = <0x1000 0xff>;
928c2ecf20Sopenharmony_ci			interrupts = <2 6 0>;
938c2ecf20Sopenharmony_ci		};
948c2ecf20Sopenharmony_ci
958c2ecf20Sopenharmony_ci		dma-controller@1200 {
968c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-bestcomm";
978c2ecf20Sopenharmony_ci			reg = <0x1200 0x80>;
988c2ecf20Sopenharmony_ci			interrupts = <3 0 0  3 1 0  3 2 0  3 3 0
998c2ecf20Sopenharmony_ci			              3 4 0  3 5 0  3 6 0  3 7 0
1008c2ecf20Sopenharmony_ci			              3 8 0  3 9 0  3 10 0  3 11 0
1018c2ecf20Sopenharmony_ci			              3 12 0  3 13 0  3 14 0  3 15 0>;
1028c2ecf20Sopenharmony_ci		};
1038c2ecf20Sopenharmony_ci
1048c2ecf20Sopenharmony_ci		xlb@1f00 {
1058c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-xlb";
1068c2ecf20Sopenharmony_ci			reg = <0x1f00 0x100>;
1078c2ecf20Sopenharmony_ci		};
1088c2ecf20Sopenharmony_ci
1098c2ecf20Sopenharmony_ci		serial@2000 {		// PSC1
1108c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-psc-uart";
1118c2ecf20Sopenharmony_ci			reg = <0x2000 0x100>;
1128c2ecf20Sopenharmony_ci			interrupts = <2 1 0>;
1138c2ecf20Sopenharmony_ci		};
1148c2ecf20Sopenharmony_ci
1158c2ecf20Sopenharmony_ci		serial@2200 {		// PSC2
1168c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-psc-uart";
1178c2ecf20Sopenharmony_ci			reg = <0x2200 0x100>;
1188c2ecf20Sopenharmony_ci			interrupts = <2 2 0>;
1198c2ecf20Sopenharmony_ci		};
1208c2ecf20Sopenharmony_ci
1218c2ecf20Sopenharmony_ci		serial@2400 {		// PSC3
1228c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-psc-uart";
1238c2ecf20Sopenharmony_ci			reg = <0x2400 0x100>;
1248c2ecf20Sopenharmony_ci			interrupts = <2 3 0>;
1258c2ecf20Sopenharmony_ci		};
1268c2ecf20Sopenharmony_ci
1278c2ecf20Sopenharmony_ci		ethernet@3000 {
1288c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-fec";
1298c2ecf20Sopenharmony_ci			reg = <0x3000 0x400>;
1308c2ecf20Sopenharmony_ci			local-mac-address = [ 00 00 00 00 00 00 ];
1318c2ecf20Sopenharmony_ci			interrupts = <2 5 0>;
1328c2ecf20Sopenharmony_ci			phy-handle = <&phy0>;
1338c2ecf20Sopenharmony_ci		};
1348c2ecf20Sopenharmony_ci
1358c2ecf20Sopenharmony_ci		mdio@3000 {
1368c2ecf20Sopenharmony_ci			#address-cells = <1>;
1378c2ecf20Sopenharmony_ci			#size-cells = <0>;
1388c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-mdio";
1398c2ecf20Sopenharmony_ci			reg = <0x3000 0x400>;       // fec range, since we need to setup fec interrupts
1408c2ecf20Sopenharmony_ci			interrupts = <2 5 0>;   // these are for "mii command finished", not link changes & co.
1418c2ecf20Sopenharmony_ci
1428c2ecf20Sopenharmony_ci			phy0: ethernet-phy@0 {
1438c2ecf20Sopenharmony_ci				reg = <0>;
1448c2ecf20Sopenharmony_ci			};
1458c2ecf20Sopenharmony_ci		};
1468c2ecf20Sopenharmony_ci
1478c2ecf20Sopenharmony_ci		ata@3a00 {
1488c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-ata";
1498c2ecf20Sopenharmony_ci			reg = <0x3a00 0x100>;
1508c2ecf20Sopenharmony_ci			interrupts = <2 7 0>;
1518c2ecf20Sopenharmony_ci		};
1528c2ecf20Sopenharmony_ci
1538c2ecf20Sopenharmony_ci		i2c@3d40 {
1548c2ecf20Sopenharmony_ci			#address-cells = <1>;
1558c2ecf20Sopenharmony_ci			#size-cells = <0>;
1568c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-i2c","fsl-i2c";
1578c2ecf20Sopenharmony_ci			reg = <0x3d40 0x40>;
1588c2ecf20Sopenharmony_ci			interrupts = <2 16 0>;
1598c2ecf20Sopenharmony_ci
1608c2ecf20Sopenharmony_ci			 rtc@68 {
1618c2ecf20Sopenharmony_ci				compatible = "dallas,ds1307";
1628c2ecf20Sopenharmony_ci				reg = <0x68>;
1638c2ecf20Sopenharmony_ci			};
1648c2ecf20Sopenharmony_ci		};
1658c2ecf20Sopenharmony_ci
1668c2ecf20Sopenharmony_ci		sram@8000 {
1678c2ecf20Sopenharmony_ci			compatible = "fsl,mpc5200-sram";
1688c2ecf20Sopenharmony_ci			reg = <0x8000 0x4000>;
1698c2ecf20Sopenharmony_ci		};
1708c2ecf20Sopenharmony_ci	};
1718c2ecf20Sopenharmony_ci
1728c2ecf20Sopenharmony_ci	localbus {
1738c2ecf20Sopenharmony_ci		compatible = "fsl,mpc5200-lpb","simple-bus";
1748c2ecf20Sopenharmony_ci		#address-cells = <2>;
1758c2ecf20Sopenharmony_ci		#size-cells = <1>;
1768c2ecf20Sopenharmony_ci		ranges = <0 0 0xfc000000 0x02000000>;
1778c2ecf20Sopenharmony_ci
1788c2ecf20Sopenharmony_ci		flash@0,0 {
1798c2ecf20Sopenharmony_ci			compatible = "cfi-flash";
1808c2ecf20Sopenharmony_ci			reg = <0 0 0x02000000>;
1818c2ecf20Sopenharmony_ci			bank-width = <4>;
1828c2ecf20Sopenharmony_ci			device-width = <2>;
1838c2ecf20Sopenharmony_ci			#size-cells = <1>;
1848c2ecf20Sopenharmony_ci			#address-cells = <1>;
1858c2ecf20Sopenharmony_ci		};
1868c2ecf20Sopenharmony_ci	};
1878c2ecf20Sopenharmony_ci
1888c2ecf20Sopenharmony_ci	pci@f0000d00 {
1898c2ecf20Sopenharmony_ci		#interrupt-cells = <1>;
1908c2ecf20Sopenharmony_ci		#size-cells = <2>;
1918c2ecf20Sopenharmony_ci		#address-cells = <3>;
1928c2ecf20Sopenharmony_ci		device_type = "pci";
1938c2ecf20Sopenharmony_ci		compatible = "fsl,mpc5200-pci";
1948c2ecf20Sopenharmony_ci		reg = <0xf0000d00 0x100>;
1958c2ecf20Sopenharmony_ci		interrupt-map-mask = <0xf800 0 0 7>;
1968c2ecf20Sopenharmony_ci		interrupt-map = <0xc000 0 0 1 &mpc5200_pic 0 0 3
1978c2ecf20Sopenharmony_ci				 0xc000 0 0 2 &mpc5200_pic 0 0 3
1988c2ecf20Sopenharmony_ci				 0xc000 0 0 3 &mpc5200_pic 0 0 3
1998c2ecf20Sopenharmony_ci				 0xc000 0 0 4 &mpc5200_pic 0 0 3>;
2008c2ecf20Sopenharmony_ci		clock-frequency = <0>; // From boot loader
2018c2ecf20Sopenharmony_ci		interrupts = <2 8 0 2 9 0 2 10 0>;
2028c2ecf20Sopenharmony_ci		bus-range = <0 0>;
2038c2ecf20Sopenharmony_ci		ranges = <0x42000000 0 0x80000000 0x80000000 0 0x10000000
2048c2ecf20Sopenharmony_ci			  0x02000000 0 0x90000000 0x90000000 0 0x10000000
2058c2ecf20Sopenharmony_ci			  0x01000000 0 0x00000000 0xa0000000 0 0x01000000>;
2068c2ecf20Sopenharmony_ci	};
2078c2ecf20Sopenharmony_ci};
208