zynq-7000.dtsi 8.0 KB
Newer Older
1
/*
2
 *  Copyright (C) 2011 - 2014 Xilinx
3 4 5 6 7 8 9 10 11 12
 *
 * This software is licensed under the terms of the GNU General Public
 * License version 2, as published by the Free Software Foundation, and
 * may be copied, distributed, and modified under those terms.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 */
13
/include/ "skeleton.dtsi"
14 15

/ {
16
	compatible = "xlnx,zynq-7000";
17

S
Soren Brinkmann 已提交
18 19 20 21 22 23 24 25 26
	cpus {
		#address-cells = <1>;
		#size-cells = <0>;

		cpu@0 {
			compatible = "arm,cortex-a9";
			device_type = "cpu";
			reg = <0>;
			clocks = <&clkc 3>;
27
			clock-latency = <1000>;
28
			cpu0-supply = <&regulator_vccpint>;
29 30 31 32 33
			operating-points = <
				/* kHz    uV */
				666667  1000000
				333334  1000000
			>;
S
Soren Brinkmann 已提交
34 35 36 37 38 39 40 41 42 43
		};

		cpu@1 {
			compatible = "arm,cortex-a9";
			device_type = "cpu";
			reg = <1>;
			clocks = <&clkc 3>;
		};
	};

M
Michal Simek 已提交
44 45 46 47 48 49 50
	pmu {
		compatible = "arm,cortex-a9-pmu";
		interrupts = <0 5 4>, <0 6 4>;
		interrupt-parent = <&intc>;
		reg = < 0xf8891000 0x1000 0xf8893000 0x1000 >;
	};

51 52 53 54 55 56 57 58 59
	regulator_vccpint: fixedregulator@0 {
		compatible = "regulator-fixed";
		regulator-name = "VCCPINT";
		regulator-min-microvolt = <1000000>;
		regulator-max-microvolt = <1000000>;
		regulator-boot-on;
		regulator-always-on;
	};

60 61 62 63
	amba {
		compatible = "simple-bus";
		#address-cells = <1>;
		#size-cells = <1>;
64
		interrupt-parent = <&intc>;
65 66
		ranges;

67
		adc: adc@f8007100 {
S
Soren Brinkmann 已提交
68 69 70 71 72
			compatible = "xlnx,zynq-xadc-1.00.a";
			reg = <0xf8007100 0x20>;
			interrupts = <0 7 4>;
			interrupt-parent = <&intc>;
			clocks = <&clkc 12>;
M
Michal Simek 已提交
73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
		};

		can0: can@e0008000 {
			compatible = "xlnx,zynq-can-1.0";
			status = "disabled";
			clocks = <&clkc 19>, <&clkc 36>;
			clock-names = "can_clk", "pclk";
			reg = <0xe0008000 0x1000>;
			interrupts = <0 28 4>;
			interrupt-parent = <&intc>;
			tx-fifo-depth = <0x40>;
			rx-fifo-depth = <0x40>;
		};

		can1: can@e0009000 {
			compatible = "xlnx,zynq-can-1.0";
			status = "disabled";
			clocks = <&clkc 20>, <&clkc 37>;
			clock-names = "can_clk", "pclk";
			reg = <0xe0009000 0x1000>;
			interrupts = <0 51 4>;
			interrupt-parent = <&intc>;
			tx-fifo-depth = <0x40>;
			rx-fifo-depth = <0x40>;
		};
S
Soren Brinkmann 已提交
98 99 100 101 102 103 104 105 106

		gpio0: gpio@e000a000 {
			compatible = "xlnx,zynq-gpio-1.0";
			#gpio-cells = <2>;
			clocks = <&clkc 42>;
			gpio-controller;
			interrupt-parent = <&intc>;
			interrupts = <0 20 4>;
			reg = <0xe000a000 0x1000>;
S
Soren Brinkmann 已提交
107 108
		};

109
		i2c0: i2c@e0004000 {
110 111 112 113 114 115 116 117 118 119
			compatible = "cdns,i2c-r1p10";
			status = "disabled";
			clocks = <&clkc 38>;
			interrupt-parent = <&intc>;
			interrupts = <0 25 4>;
			reg = <0xe0004000 0x1000>;
			#address-cells = <1>;
			#size-cells = <0>;
		};

120
		i2c1: i2c@e0005000 {
121 122 123 124 125 126 127 128 129 130
			compatible = "cdns,i2c-r1p10";
			status = "disabled";
			clocks = <&clkc 39>;
			interrupt-parent = <&intc>;
			interrupts = <0 48 4>;
			reg = <0xe0005000 0x1000>;
			#address-cells = <1>;
			#size-cells = <0>;
		};

131
		intc: interrupt-controller@f8f01000 {
132 133
			compatible = "arm,cortex-a9-gic";
			#interrupt-cells = <3>;
134
			interrupt-controller;
135 136
			reg = <0xF8F01000 0x1000>,
			      <0xF8F00100 0x100>;
137 138
		};

139
		L2: cache-controller@f8f02000 {
140 141
			compatible = "arm,pl310-cache";
			reg = <0xF8F02000 0x1000>;
142 143
			arm,data-latency = <3 2 2>;
			arm,tag-latency = <2 2 2>;
144 145 146 147
			cache-unified;
			cache-level = <2>;
		};

148
		mc: memory-controller@f8006000 {
S
Soren Brinkmann 已提交
149 150
			compatible = "xlnx,zynq-ddrc-a05";
			reg = <0xf8006000 0x1000>;
M
Michal Simek 已提交
151
		};
S
Soren Brinkmann 已提交
152

153
		uart0: serial@e0000000 {
154
			compatible = "xlnx,xuartps", "cdns,uart-r1p8";
155
			status = "disabled";
156
			clocks = <&clkc 23>, <&clkc 40>;
157
			clock-names = "uart_clk", "pclk";
158
			reg = <0xE0000000 0x1000>;
159
			interrupts = <0 27 4>;
160
		};
161

162
		uart1: serial@e0001000 {
163
			compatible = "xlnx,xuartps", "cdns,uart-r1p8";
164
			status = "disabled";
165
			clocks = <&clkc 24>, <&clkc 41>;
166
			clock-names = "uart_clk", "pclk";
167 168 169
			reg = <0xE0001000 0x1000>;
			interrupts = <0 50 4>;
		};
J
Josh Cartwright 已提交
170

A
Andreas Färber 已提交
171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194
		spi0: spi@e0006000 {
			compatible = "xlnx,zynq-spi-r1p6";
			reg = <0xe0006000 0x1000>;
			status = "disabled";
			interrupt-parent = <&intc>;
			interrupts = <0 26 4>;
			clocks = <&clkc 25>, <&clkc 34>;
			clock-names = "ref_clk", "pclk";
			#address-cells = <1>;
			#size-cells = <0>;
		};

		spi1: spi@e0007000 {
			compatible = "xlnx,zynq-spi-r1p6";
			reg = <0xe0007000 0x1000>;
			status = "disabled";
			interrupt-parent = <&intc>;
			interrupts = <0 49 4>;
			clocks = <&clkc 26>, <&clkc 35>;
			clock-names = "ref_clk", "pclk";
			#address-cells = <1>;
			#size-cells = <0>;
		};

S
Steffen Trumtrar 已提交
195 196
		gem0: ethernet@e000b000 {
			compatible = "cdns,gem";
197
			reg = <0xe000b000 0x1000>;
S
Steffen Trumtrar 已提交
198 199 200 201
			status = "disabled";
			interrupts = <0 22 4>;
			clocks = <&clkc 30>, <&clkc 30>, <&clkc 13>;
			clock-names = "pclk", "hclk", "tx_clk";
202 203
			#address-cells = <1>;
			#size-cells = <0>;
S
Steffen Trumtrar 已提交
204 205 206 207
		};

		gem1: ethernet@e000c000 {
			compatible = "cdns,gem";
208
			reg = <0xe000c000 0x1000>;
S
Steffen Trumtrar 已提交
209 210 211 212
			status = "disabled";
			interrupts = <0 45 4>;
			clocks = <&clkc 31>, <&clkc 31>, <&clkc 14>;
			clock-names = "pclk", "hclk", "tx_clk";
213 214
			#address-cells = <1>;
			#size-cells = <0>;
S
Steffen Trumtrar 已提交
215 216
		};

217
		sdhci0: sdhci@e0100000 {
218 219 220 221 222 223 224
			compatible = "arasan,sdhci-8.9a";
			status = "disabled";
			clock-names = "clk_xin", "clk_ahb";
			clocks = <&clkc 21>, <&clkc 32>;
			interrupt-parent = <&intc>;
			interrupts = <0 24 4>;
			reg = <0xe0100000 0x1000>;
225
		};
226

227
		sdhci1: sdhci@e0101000 {
228 229 230 231 232 233 234
			compatible = "arasan,sdhci-8.9a";
			status = "disabled";
			clock-names = "clk_xin", "clk_ahb";
			clocks = <&clkc 22>, <&clkc 33>;
			interrupt-parent = <&intc>;
			interrupts = <0 47 4>;
			reg = <0xe0101000 0x1000>;
235
		};
236

J
Josh Cartwright 已提交
237
		slcr: slcr@f8000000 {
238 239
			#address-cells = <1>;
			#size-cells = <1>;
240
			compatible = "xlnx,zynq-slcr", "syscon";
J
Josh Cartwright 已提交
241
			reg = <0xF8000000 0x1000>;
242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259
			ranges;
			clkc: clkc@100 {
				#clock-cells = <1>;
				compatible = "xlnx,ps7-clkc";
				ps-clk-frequency = <33333333>;
				fclk-enable = <0>;
				clock-output-names = "armpll", "ddrpll", "iopll", "cpu_6or4x",
						"cpu_3or2x", "cpu_2x", "cpu_1x", "ddr2x", "ddr3x",
						"dci", "lqspi", "smc", "pcap", "gem0", "gem1",
						"fclk0", "fclk1", "fclk2", "fclk3", "can0", "can1",
						"sdio0", "sdio1", "uart0", "uart1", "spi0", "spi1",
						"dma", "usb0_aper", "usb1_aper", "gem0_aper",
						"gem1_aper", "sdio0_aper", "sdio1_aper",
						"spi0_aper", "spi1_aper", "can0_aper", "can1_aper",
						"i2c0_aper", "i2c1_aper", "uart0_aper", "uart1_aper",
						"gpio_aper", "lqspi_aper", "smc_aper", "swdt",
						"dbg_trc", "dbg_apb";
				reg = <0x100 0x100>;
J
Josh Cartwright 已提交
260 261
			};
		};
262

263 264 265 266
		dmac_s: dmac@f8003000 {
			compatible = "arm,pl330", "arm,primecell";
			reg = <0xf8003000 0x1000>;
			interrupt-parent = <&intc>;
267 268
			interrupt-names = "abort", "dma0", "dma1", "dma2", "dma3",
				"dma4", "dma5", "dma6", "dma7";
269 270 271 272 273 274 275 276 277 278 279 280
			interrupts = <0 13 4>,
			             <0 14 4>, <0 15 4>,
			             <0 16 4>, <0 17 4>,
			             <0 40 4>, <0 41 4>,
			             <0 42 4>, <0 43 4>;
			#dma-cells = <1>;
			#dma-channels = <8>;
			#dma-requests = <4>;
			clocks = <&clkc 27>;
			clock-names = "apb_pclk";
		};

281 282 283
		devcfg: devcfg@f8007000 {
			compatible = "xlnx,zynq-devcfg-1.0";
			reg = <0xf8007000 0x100>;
284
		};
285

286 287 288 289 290 291 292 293
		global_timer: timer@f8f00200 {
			compatible = "arm,cortex-a9-global-timer";
			reg = <0xf8f00200 0x20>;
			interrupts = <1 11 0x301>;
			interrupt-parent = <&intc>;
			clocks = <&clkc 4>;
		};

294
		ttc0: timer@f8001000 {
295
			interrupt-parent = <&intc>;
296
			interrupts = <0 10 4>, <0 11 4>, <0 12 4>;
297
			compatible = "cdns,ttc";
298
			clocks = <&clkc 6>;
299 300 301
			reg = <0xF8001000 0x1000>;
		};

302
		ttc1: timer@f8002000 {
303
			interrupt-parent = <&intc>;
304
			interrupts = <0 37 4>, <0 38 4>, <0 39 4>;
305
			compatible = "cdns,ttc";
306
			clocks = <&clkc 6>;
307 308
			reg = <0xF8002000 0x1000>;
		};
309 310

		scutimer: timer@f8f00600 {
M
Michal Simek 已提交
311
			interrupt-parent = <&intc>;
312
			interrupts = <1 13 0x301>;
M
Michal Simek 已提交
313
			compatible = "arm,cortex-a9-twd-timer";
314
			reg = <0xf8f00600 0x20>;
315
			clocks = <&clkc 4>;
316
		};
317 318 319 320 321 322 323 324 325 326 327

		watchdog0: watchdog@f8005000 {
			clocks = <&clkc 45>;
			compatible = "xlnx,zynq-wdt-r1p2";
			device_type = "watchdog";
			interrupt-parent = <&intc>;
			interrupts = <0 9 1>;
			reg = <0xf8005000 0x1000>;
			reset = <0>;
			timeout-sec = <10>;
		};
328 329
	};
};