123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241 |
- // SPDX-License-Identifier: GPL-2.0-or-later
- /*
- * wm8650.dtsi - Device tree file for Wondermedia WM8650 SoC
- *
- * Copyright (C) 2012 Tony Prisk <[email protected]>
- */
- / {
- #address-cells = <1>;
- #size-cells = <1>;
- compatible = "wm,wm8650";
- cpus {
- #address-cells = <0>;
- #size-cells = <0>;
- cpu {
- device_type = "cpu";
- compatible = "arm,arm926ej-s";
- };
- };
- memory {
- device_type = "memory";
- reg = <0x0 0x0>;
- };
- aliases {
- serial0 = &uart0;
- serial1 = &uart1;
- };
- soc {
- #address-cells = <1>;
- #size-cells = <1>;
- compatible = "simple-bus";
- ranges;
- interrupt-parent = <&intc0>;
- intc0: interrupt-controller@d8140000 {
- compatible = "via,vt8500-intc";
- interrupt-controller;
- reg = <0xd8140000 0x10000>;
- #interrupt-cells = <1>;
- };
- /* Secondary IC cascaded to intc0 */
- intc1: interrupt-controller@d8150000 {
- compatible = "via,vt8500-intc";
- interrupt-controller;
- #interrupt-cells = <1>;
- reg = <0xD8150000 0x10000>;
- interrupts = <56 57 58 59 60 61 62 63>;
- };
- pinctrl: pinctrl@d8110000 {
- compatible = "wm,wm8650-pinctrl";
- reg = <0xd8110000 0x10000>;
- interrupt-controller;
- #interrupt-cells = <2>;
- gpio-controller;
- #gpio-cells = <2>;
- };
- pmc@d8130000 {
- compatible = "via,vt8500-pmc";
- reg = <0xd8130000 0x1000>;
- clocks {
- #address-cells = <1>;
- #size-cells = <0>;
- ref25: ref25M {
- #clock-cells = <0>;
- compatible = "fixed-clock";
- clock-frequency = <25000000>;
- };
- ref24: ref24M {
- #clock-cells = <0>;
- compatible = "fixed-clock";
- clock-frequency = <24000000>;
- };
- plla: plla {
- #clock-cells = <0>;
- compatible = "wm,wm8650-pll-clock";
- clocks = <&ref25>;
- reg = <0x200>;
- };
- pllb: pllb {
- #clock-cells = <0>;
- compatible = "wm,wm8650-pll-clock";
- clocks = <&ref25>;
- reg = <0x204>;
- };
- pllc: pllc {
- #clock-cells = <0>;
- compatible = "wm,wm8650-pll-clock";
- clocks = <&ref25>;
- reg = <0x208>;
- };
- plld: plld {
- #clock-cells = <0>;
- compatible = "wm,wm8650-pll-clock";
- clocks = <&ref25>;
- reg = <0x20c>;
- };
- plle: plle {
- #clock-cells = <0>;
- compatible = "wm,wm8650-pll-clock";
- clocks = <&ref25>;
- reg = <0x210>;
- };
- clkarm: arm {
- #clock-cells = <0>;
- compatible = "via,vt8500-device-clock";
- clocks = <&plla>;
- divisor-reg = <0x300>;
- };
- clkahb: ahb {
- #clock-cells = <0>;
- compatible = "via,vt8500-device-clock";
- clocks = <&pllb>;
- divisor-reg = <0x304>;
- };
- clkapb: apb {
- #clock-cells = <0>;
- compatible = "via,vt8500-device-clock";
- clocks = <&pllb>;
- divisor-reg = <0x320>;
- };
- clkddr: ddr {
- #clock-cells = <0>;
- compatible = "via,vt8500-device-clock";
- clocks = <&plld>;
- divisor-reg = <0x310>;
- };
- clkuart0: uart0 {
- #clock-cells = <0>;
- compatible = "via,vt8500-device-clock";
- clocks = <&ref24>;
- enable-reg = <0x250>;
- enable-bit = <1>;
- };
- clkuart1: uart1 {
- #clock-cells = <0>;
- compatible = "via,vt8500-device-clock";
- clocks = <&ref24>;
- enable-reg = <0x250>;
- enable-bit = <2>;
- };
- clksdhc: sdhc {
- #clock-cells = <0>;
- compatible = "via,vt8500-device-clock";
- clocks = <&pllb>;
- divisor-reg = <0x328>;
- divisor-mask = <0x3f>;
- enable-reg = <0x254>;
- enable-bit = <18>;
- };
- };
- };
- timer@d8130100 {
- compatible = "via,vt8500-timer";
- reg = <0xd8130100 0x28>;
- interrupts = <36>;
- };
- ehci@d8007900 {
- compatible = "via,vt8500-ehci";
- reg = <0xd8007900 0x200>;
- interrupts = <43>;
- };
- uhci@d8007b00 {
- compatible = "platform-uhci";
- reg = <0xd8007b00 0x200>;
- interrupts = <43>;
- };
- sdhc@d800a000 {
- compatible = "wm,wm8505-sdhc";
- reg = <0xd800a000 0x400>;
- interrupts = <20>, <21>;
- clocks = <&clksdhc>;
- bus-width = <4>;
- sdon-inverted;
- };
- fb: fb@d8050800 {
- compatible = "wm,wm8505-fb";
- reg = <0xd8050800 0x200>;
- };
- ge_rops@d8050400 {
- compatible = "wm,prizm-ge-rops";
- reg = <0xd8050400 0x100>;
- };
- uart0: serial@d8200000 {
- compatible = "via,vt8500-uart";
- reg = <0xd8200000 0x1040>;
- interrupts = <32>;
- clocks = <&clkuart0>;
- status = "disabled";
- };
- uart1: serial@d82b0000 {
- compatible = "via,vt8500-uart";
- reg = <0xd82b0000 0x1040>;
- interrupts = <33>;
- clocks = <&clkuart1>;
- status = "disabled";
- };
- rtc@d8100000 {
- compatible = "via,vt8500-rtc";
- reg = <0xd8100000 0x10000>;
- interrupts = <48>;
- };
- ethernet@d8004000 {
- compatible = "via,vt8500-rhine";
- reg = <0xd8004000 0x100>;
- interrupts = <10>;
- };
- };
- };
|