1// SPDX-License-Identifier: GPL-2.0-only 2/* 3 * linux/arch/arm/boot/nspire.dtsi 4 * 5 * Copyright (C) 2013 Daniel Tang <tangrs@tangrs.id.au> 6 */ 7 8/ { 9 #address-cells = <1>; 10 #size-cells = <1>; 11 interrupt-parent = <&intc>; 12 13 cpus { 14 cpu@0 { 15 compatible = "arm,arm926ej-s"; 16 }; 17 }; 18 19 bootrom: bootrom@0 { 20 reg = <0x00000000 0x80000>; 21 }; 22 23 sram: sram@a4000000 { 24 device = "memory"; 25 reg = <0xa4000000 0x20000>; 26 }; 27 28 timer_clk: timer_clk { 29 #clock-cells = <0>; 30 compatible = "fixed-clock"; 31 clock-frequency = <32768>; 32 }; 33 34 base_clk: base_clk { 35 #clock-cells = <0>; 36 reg = <0x900b0024 0x4>; 37 }; 38 39 ahb_clk: ahb_clk { 40 #clock-cells = <0>; 41 reg = <0x900b0024 0x4>; 42 clocks = <&base_clk>; 43 }; 44 45 apb_pclk: apb_pclk { 46 #clock-cells = <0>; 47 compatible = "fixed-factor-clock"; 48 clock-div = <2>; 49 clock-mult = <1>; 50 clocks = <&ahb_clk>; 51 }; 52 53 usb_phy: usb_phy { 54 compatible = "usb-nop-xceiv"; 55 #phy-cells = <0>; 56 }; 57 58 vbus_reg: vbus_reg { 59 compatible = "regulator-fixed"; 60 61 regulator-name = "USB VBUS output"; 62 regulator-type = "voltage"; 63 64 regulator-min-microvolt = <5000000>; 65 regulator-max-microvolt = <5000000>; 66 }; 67 68 ahb { 69 compatible = "simple-bus"; 70 #address-cells = <1>; 71 #size-cells = <1>; 72 ranges; 73 74 spi: spi@a9000000 { 75 reg = <0xa9000000 0x1000>; 76 }; 77 78 usb0: usb@b0000000 { 79 compatible = "lsi,zevio-usb"; 80 reg = <0xb0000000 0x1000>; 81 interrupts = <8>; 82 83 usb-phy = <&usb_phy>; 84 vbus-supply = <&vbus_reg>; 85 }; 86 87 usb1: usb@b4000000 { 88 reg = <0xb4000000 0x1000>; 89 interrupts = <9>; 90 status = "disabled"; 91 }; 92 93 lcd: lcd@c0000000 { 94 compatible = "arm,pl111", "arm,primecell"; 95 reg = <0xc0000000 0x1000>; 96 interrupts = <21>; 97 98 /* 99 * We assume the same clock is fed to APB and CLCDCLK. 100 * There is some code to scale the clock down by a factor 101 * 48 for the display so likely the frequency to the 102 * display is 1MHz and the CLCDCLK is 48 MHz. 103 */ 104 clocks = <&apb_pclk>, <&apb_pclk>; 105 clock-names = "clcdclk", "apb_pclk"; 106 }; 107 108 adc: adc@c4000000 { 109 reg = <0xc4000000 0x1000>; 110 interrupts = <11>; 111 }; 112 113 tdes: crypto@c8010000 { 114 reg = <0xc8010000 0x1000>; 115 }; 116 117 sha256: crypto@cc000000 { 118 reg = <0xcc000000 0x1000>; 119 }; 120 121 apb@90000000 { 122 compatible = "simple-bus"; 123 #address-cells = <1>; 124 #size-cells = <1>; 125 clock-ranges; 126 ranges; 127 128 gpio: gpio@90000000 { 129 compatible = "lsi,zevio-gpio"; 130 reg = <0x90000000 0x1000>; 131 interrupts = <7>; 132 gpio-controller; 133 #gpio-cells = <2>; 134 }; 135 136 fast_timer: timer@90010000 { 137 reg = <0x90010000 0x1000>; 138 interrupts = <17>; 139 }; 140 141 uart: serial@90020000 { 142 reg = <0x90020000 0x1000>; 143 interrupts = <1>; 144 }; 145 146 timer0: timer@900c0000 { 147 reg = <0x900c0000 0x1000>; 148 clocks = <&timer_clk>, <&timer_clk>, 149 <&timer_clk>; 150 clock-names = "timer0clk", "timer1clk", 151 "apb_pclk"; 152 }; 153 154 timer1: timer@900d0000 { 155 reg = <0x900d0000 0x1000>; 156 interrupts = <19>; 157 clocks = <&timer_clk>, <&timer_clk>, 158 <&timer_clk>; 159 clock-names = "timer0clk", "timer1clk", 160 "apb_pclk"; 161 }; 162 163 watchdog: watchdog@90060000 { 164 compatible = "arm,primecell"; 165 reg = <0x90060000 0x1000>; 166 interrupts = <3>; 167 }; 168 169 rtc: rtc@90090000 { 170 reg = <0x90090000 0x1000>; 171 interrupts = <4>; 172 }; 173 174 misc: misc@900a0000 { 175 reg = <0x900a0000 0x1000>; 176 }; 177 178 pwr: pwr@900b0000 { 179 reg = <0x900b0000 0x1000>; 180 interrupts = <15>; 181 }; 182 183 keypad: input@900e0000 { 184 compatible = "ti,nspire-keypad"; 185 reg = <0x900e0000 0x1000>; 186 interrupts = <16>; 187 188 scan-interval = <1000>; 189 row-delay = <200>; 190 191 clocks = <&apb_pclk>; 192 }; 193 194 contrast: contrast@900f0000 { 195 reg = <0x900f0000 0x1000>; 196 }; 197 198 led: led@90110000 { 199 reg = <0x90110000 0x1000>; 200 }; 201 }; 202 }; 203}; 204