Arnd Bergmann | 2d33429 | 2012-03-07 15:04:07 +0000 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2011 ST-Ericsson AB |
| 3 | * |
| 4 | * The code contained herein is licensed under the GNU General Public |
| 5 | * License. You may obtain a copy of the GNU General Public License |
| 6 | * Version 2 or later at the following locations: |
| 7 | * |
| 8 | * http://www.opensource.org/licenses/gpl-license.html |
| 9 | * http://www.gnu.org/copyleft/gpl.html |
| 10 | */ |
| 11 | |
| 12 | /dts-v1/; |
Linus Walleij | 2ce05a1 | 2013-08-07 15:37:52 +0200 | [diff] [blame] | 13 | #include "ste-dbx5x0.dtsi" |
Linus Walleij | 8320062 | 2014-02-03 14:32:20 +0100 | [diff] [blame] | 14 | #include "ste-href-ab8500.dtsi" |
Linus Walleij | 3bfdebb | 2013-11-13 10:32:20 +0100 | [diff] [blame] | 15 | #include "ste-href-family-pinctrl.dtsi" |
Arnd Bergmann | 2d33429 | 2012-03-07 15:04:07 +0000 | [diff] [blame] | 16 | |
| 17 | / { |
| 18 | model = "Calao Systems Snowball platform with device tree"; |
Lee Jones | 79b4075 | 2012-10-15 10:07:55 +0100 | [diff] [blame] | 19 | compatible = "calaosystems,snowball-a9500", "st-ericsson,u9500"; |
Arnd Bergmann | 2d33429 | 2012-03-07 15:04:07 +0000 | [diff] [blame] | 20 | |
Linus Walleij | 109978d | 2015-07-10 11:32:15 +0200 | [diff] [blame] | 21 | /* This stablilizes the serial port enumeration */ |
| 22 | aliases { |
| 23 | serial0 = &ux500_serial0; |
| 24 | serial1 = &ux500_serial1; |
| 25 | serial2 = &ux500_serial2; |
| 26 | }; |
| 27 | |
Arnd Bergmann | 2d33429 | 2012-03-07 15:04:07 +0000 | [diff] [blame] | 28 | memory { |
| 29 | reg = <0x00000000 0x20000000>; |
| 30 | }; |
| 31 | |
Lee Jones | bc36748 | 2012-05-03 11:23:47 +0100 | [diff] [blame] | 32 | en_3v3_reg: en_3v3 { |
| 33 | compatible = "regulator-fixed"; |
Lee Jones | b099576 | 2013-06-18 09:51:58 +0100 | [diff] [blame] | 34 | regulator-name = "en-3v3-fixed-supply"; |
| 35 | regulator-min-microvolt = <3300000>; |
| 36 | regulator-max-microvolt = <3300000>; |
| 37 | /* AB8500 GPIOs start from 1 - offset 25 is GPIO26. */ |
| 38 | gpio = <&ab8500_gpio 25 0x4>; |
| 39 | startup-delay-us = <5000>; |
| 40 | enable-active-high; |
Lee Jones | bc36748 | 2012-05-03 11:23:47 +0100 | [diff] [blame] | 41 | }; |
| 42 | |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 43 | gpio_keys { |
| 44 | compatible = "gpio-keys"; |
| 45 | #address-cells = <1>; |
| 46 | #size-cells = <0>; |
| 47 | |
| 48 | button@1 { |
| 49 | debounce_interval = <50>; |
Sudeep Holla | 4db7062 | 2015-10-16 17:01:36 +0100 | [diff] [blame] | 50 | wakeup-source; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 51 | linux,code = <2>; |
| 52 | label = "userpb"; |
Lee Jones | 93b5698 | 2012-05-29 14:17:36 +0800 | [diff] [blame] | 53 | gpios = <&gpio1 0 0x4>; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 54 | }; |
| 55 | button@2 { |
| 56 | debounce_interval = <50>; |
Sudeep Holla | 4db7062 | 2015-10-16 17:01:36 +0100 | [diff] [blame] | 57 | wakeup-source; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 58 | linux,code = <3>; |
Lee Jones | 3f3ed40 | 2012-04-13 15:05:07 +0100 | [diff] [blame] | 59 | label = "extkb1"; |
Lee Jones | 93b5698 | 2012-05-29 14:17:36 +0800 | [diff] [blame] | 60 | gpios = <&gpio4 23 0x4>; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 61 | }; |
| 62 | button@3 { |
| 63 | debounce_interval = <50>; |
Sudeep Holla | 4db7062 | 2015-10-16 17:01:36 +0100 | [diff] [blame] | 64 | wakeup-source; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 65 | linux,code = <4>; |
Lee Jones | 3f3ed40 | 2012-04-13 15:05:07 +0100 | [diff] [blame] | 66 | label = "extkb2"; |
Lee Jones | 93b5698 | 2012-05-29 14:17:36 +0800 | [diff] [blame] | 67 | gpios = <&gpio4 24 0x4>; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 68 | }; |
| 69 | button@4 { |
| 70 | debounce_interval = <50>; |
Sudeep Holla | 4db7062 | 2015-10-16 17:01:36 +0100 | [diff] [blame] | 71 | wakeup-source; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 72 | linux,code = <5>; |
Lee Jones | 3f3ed40 | 2012-04-13 15:05:07 +0100 | [diff] [blame] | 73 | label = "extkb3"; |
Lee Jones | 93b5698 | 2012-05-29 14:17:36 +0800 | [diff] [blame] | 74 | gpios = <&gpio5 1 0x4>; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 75 | }; |
| 76 | button@5 { |
| 77 | debounce_interval = <50>; |
Sudeep Holla | 4db7062 | 2015-10-16 17:01:36 +0100 | [diff] [blame] | 78 | wakeup-source; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 79 | linux,code = <6>; |
Lee Jones | 3f3ed40 | 2012-04-13 15:05:07 +0100 | [diff] [blame] | 80 | label = "extkb4"; |
Lee Jones | 93b5698 | 2012-05-29 14:17:36 +0800 | [diff] [blame] | 81 | gpios = <&gpio5 2 0x4>; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 82 | }; |
| 83 | }; |
| 84 | |
| 85 | leds { |
| 86 | compatible = "gpio-leds"; |
Linus Walleij | 2f4b84f | 2013-11-17 11:33:19 +0100 | [diff] [blame] | 87 | pinctrl-names = "default"; |
| 88 | pinctrl-0 = <&gpioled_snowball_mode>; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 89 | used-led { |
| 90 | label = "user_led"; |
Lee Jones | 93b5698 | 2012-05-29 14:17:36 +0800 | [diff] [blame] | 91 | gpios = <&gpio4 14 0x4>; |
Lee Jones | 7fd975f | 2012-06-15 09:30:30 +0100 | [diff] [blame] | 92 | default-state = "on"; |
Lee Jones | fd53d04 | 2012-05-02 09:48:38 +0100 | [diff] [blame] | 93 | linux,default-trigger = "heartbeat"; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 94 | }; |
| 95 | }; |
| 96 | |
Gabriel Fernandez | b1ba143 | 2013-03-01 14:38:07 +0100 | [diff] [blame] | 97 | soc { |
Linus Walleij | a12f703 | 2013-11-13 15:59:40 +0100 | [diff] [blame] | 98 | usb_per5@a03e0000 { |
| 99 | pinctrl-names = "default", "sleep"; |
| 100 | pinctrl-0 = <&musb_default_mode>; |
| 101 | pinctrl-1 = <&musb_sleep_mode>; |
| 102 | }; |
Lee Jones | e648806 | 2012-07-31 13:31:50 +0100 | [diff] [blame] | 103 | |
| 104 | sound { |
| 105 | compatible = "stericsson,snd-soc-mop500"; |
| 106 | |
| 107 | stericsson,cpu-dai = <&msp1 &msp3>; |
| 108 | stericsson,audio-codec = <&codec>; |
| 109 | }; |
| 110 | |
Linus Walleij | 70b41ab | 2013-11-13 14:45:06 +0100 | [diff] [blame] | 111 | msp0: msp@80123000 { |
| 112 | pinctrl-names = "default"; |
| 113 | pinctrl-0 = <&msp0_default_mode>; |
| 114 | status = "okay"; |
| 115 | }; |
| 116 | |
Lee Jones | fe16452 | 2012-07-31 12:37:16 +0100 | [diff] [blame] | 117 | msp1: msp@80124000 { |
Linus Walleij | 70b41ab | 2013-11-13 14:45:06 +0100 | [diff] [blame] | 118 | pinctrl-names = "default"; |
| 119 | pinctrl-0 = <&msp1_default_mode>; |
| 120 | status = "okay"; |
| 121 | }; |
| 122 | |
| 123 | msp2: msp@80117000 { |
| 124 | pinctrl-names = "default"; |
| 125 | pinctrl-0 = <&msp2_default_mode>; |
Lee Jones | fe16452 | 2012-07-31 12:37:16 +0100 | [diff] [blame] | 126 | }; |
| 127 | |
| 128 | msp3: msp@80125000 { |
| 129 | status = "okay"; |
| 130 | }; |
| 131 | |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 132 | external-bus@50000000 { |
Lee Jones | bf76e06 | 2012-04-24 10:53:18 +0100 | [diff] [blame] | 133 | status = "okay"; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 134 | |
Lee Jones | bf76e06 | 2012-04-24 10:53:18 +0100 | [diff] [blame] | 135 | ethernet@0 { |
| 136 | compatible = "smsc,lan9115"; |
| 137 | reg = <0 0x10000>; |
Linus Walleij | 90c4025 | 2013-05-29 19:15:39 +0200 | [diff] [blame] | 138 | interrupts = <12 IRQ_TYPE_EDGE_RISING>; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 139 | interrupt-parent = <&gpio4>; |
Lee Jones | bc36748 | 2012-05-03 11:23:47 +0100 | [diff] [blame] | 140 | vdd33a-supply = <&en_3v3_reg>; |
| 141 | vddvario-supply = <&db8500_vape_reg>; |
Linus Walleij | a48bf4b | 2013-11-17 10:02:22 +0100 | [diff] [blame] | 142 | pinctrl-names = "default"; |
| 143 | pinctrl-0 = <ð_snowball_mode>; |
Lee Jones | bc36748 | 2012-05-03 11:23:47 +0100 | [diff] [blame] | 144 | |
Lee Jones | bf76e06 | 2012-04-24 10:53:18 +0100 | [diff] [blame] | 145 | reg-shift = <1>; |
| 146 | reg-io-width = <2>; |
| 147 | smsc,force-internal-phy; |
| 148 | smsc,irq-active-high; |
| 149 | smsc,irq-push-pull; |
Lee Jones | 7fb2afc | 2013-06-03 13:06:13 +0100 | [diff] [blame] | 150 | |
| 151 | clocks = <&prcc_pclk 3 0>; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 152 | }; |
| 153 | }; |
| 154 | |
Lee Jones | 383307c | 2013-04-02 14:21:54 +0100 | [diff] [blame] | 155 | vmmci: regulator-gpio { |
Ulf Hansson | 53d2669 | 2015-04-20 16:02:31 +0200 | [diff] [blame] | 156 | compatible = "regulator-gpio"; |
| 157 | |
Ulf Hansson | a1ab5e4 | 2013-12-12 14:31:37 +0100 | [diff] [blame] | 158 | gpios = <&gpio7 4 0x4>; |
| 159 | enable-gpio = <&gpio6 25 0x4>; |
Ulf Hansson | 53d2669 | 2015-04-20 16:02:31 +0200 | [diff] [blame] | 160 | |
| 161 | regulator-min-microvolt = <1800000>; |
| 162 | regulator-max-microvolt = <2900000>; |
| 163 | regulator-name = "mmci-reg"; |
| 164 | regulator-type = "voltage"; |
| 165 | |
| 166 | startup-delay-us = <100>; |
| 167 | enable-active-high; |
| 168 | |
| 169 | states = <1800000 0x1 |
| 170 | 2900000 0x0>; |
Lee Jones | 383307c | 2013-04-02 14:21:54 +0100 | [diff] [blame] | 171 | }; |
| 172 | |
Lee Jones | 5e1ac7d | 2012-05-29 14:40:04 +0800 | [diff] [blame] | 173 | // External Micro SD slot |
Lee Jones | 81bf8c2 | 2012-09-26 12:55:56 +0100 | [diff] [blame] | 174 | sdi0_per1@80126000 { |
Lee Jones | 5e1ac7d | 2012-05-29 14:40:04 +0800 | [diff] [blame] | 175 | arm,primecell-periphid = <0x10480180>; |
Linus Walleij | 90ccde4 | 2013-05-27 13:15:05 +0200 | [diff] [blame] | 176 | max-frequency = <100000000>; |
Lee Jones | 92a0f48 | 2012-09-26 11:12:48 +0100 | [diff] [blame] | 177 | bus-width = <4>; |
Ulf Hansson | 30cdd66 | 2014-03-18 20:34:04 +0100 | [diff] [blame] | 178 | cap-mmc-highspeed; |
Lee Jones | 4a85c7f | 2012-05-29 14:29:53 +0800 | [diff] [blame] | 179 | vmmc-supply = <&ab8500_ldo_aux3_reg>; |
Lee Jones | 383307c | 2013-04-02 14:21:54 +0100 | [diff] [blame] | 180 | vqmmc-supply = <&vmmci>; |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 181 | pinctrl-names = "default", "sleep"; |
| 182 | pinctrl-0 = <&sdi0_default_mode>; |
| 183 | pinctrl-1 = <&sdi0_sleep_mode>; |
Lee Jones | 5e1ac7d | 2012-05-29 14:40:04 +0800 | [diff] [blame] | 184 | |
Lee Jones | 93b5698 | 2012-05-29 14:17:36 +0800 | [diff] [blame] | 185 | cd-gpios = <&gpio6 26 0x4>; // 218 |
Lee Jones | 5e1ac7d | 2012-05-29 14:40:04 +0800 | [diff] [blame] | 186 | cd-inverted; |
| 187 | |
| 188 | status = "okay"; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 189 | }; |
| 190 | |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 191 | // WLAN SDIO channel |
| 192 | sdi1_per2@80118000 { |
| 193 | arm,primecell-periphid = <0x10480180>; |
| 194 | max-frequency = <100000000>; |
| 195 | bus-width = <4>; |
| 196 | pinctrl-names = "default", "sleep"; |
| 197 | pinctrl-0 = <&sdi1_default_mode>; |
| 198 | pinctrl-1 = <&sdi1_sleep_mode>; |
| 199 | |
| 200 | status = "okay"; |
| 201 | }; |
| 202 | |
| 203 | // Unused PoP eMMC - register and put it to sleep by default */ |
| 204 | sdi2_per3@80005000 { |
| 205 | arm,primecell-periphid = <0x10480180>; |
| 206 | pinctrl-names = "default"; |
| 207 | pinctrl-0 = <&sdi2_sleep_mode>; |
| 208 | |
| 209 | status = "okay"; |
| 210 | }; |
| 211 | |
Lee Jones | 5e1ac7d | 2012-05-29 14:40:04 +0800 | [diff] [blame] | 212 | // On-board eMMC |
Lee Jones | 81bf8c2 | 2012-09-26 12:55:56 +0100 | [diff] [blame] | 213 | sdi4_per2@80114000 { |
Lee Jones | 5e1ac7d | 2012-05-29 14:40:04 +0800 | [diff] [blame] | 214 | arm,primecell-periphid = <0x10480180>; |
Linus Walleij | 90ccde4 | 2013-05-27 13:15:05 +0200 | [diff] [blame] | 215 | max-frequency = <100000000>; |
Lee Jones | 5e1ac7d | 2012-05-29 14:40:04 +0800 | [diff] [blame] | 216 | bus-width = <8>; |
Ulf Hansson | 30cdd66 | 2014-03-18 20:34:04 +0100 | [diff] [blame] | 217 | cap-mmc-highspeed; |
Lee Jones | 4a85c7f | 2012-05-29 14:29:53 +0800 | [diff] [blame] | 218 | vmmc-supply = <&ab8500_ldo_aux2_reg>; |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 219 | pinctrl-names = "default", "sleep"; |
| 220 | pinctrl-0 = <&sdi4_default_mode>; |
| 221 | pinctrl-1 = <&sdi4_sleep_mode>; |
Lee Jones | 5e1ac7d | 2012-05-29 14:40:04 +0800 | [diff] [blame] | 222 | |
| 223 | status = "okay"; |
Lee Jones | 7e0ce27 | 2012-03-15 16:46:17 +0000 | [diff] [blame] | 224 | }; |
| 225 | |
Lee Jones | 4905af0 | 2012-03-07 17:35:04 +0000 | [diff] [blame] | 226 | uart@80120000 { |
Linus Walleij | 3bfdebb | 2013-11-13 10:32:20 +0100 | [diff] [blame] | 227 | pinctrl-names = "default", "sleep"; |
| 228 | pinctrl-0 = <&uart0_default_mode>; |
| 229 | pinctrl-1 = <&uart0_sleep_mode>; |
Lee Jones | 4905af0 | 2012-03-07 17:35:04 +0000 | [diff] [blame] | 230 | status = "okay"; |
| 231 | }; |
| 232 | |
Linus Walleij | 1d8aca9 | 2015-07-08 15:15:22 +0200 | [diff] [blame] | 233 | /* This UART is unused and thus left disabled */ |
Lee Jones | 4905af0 | 2012-03-07 17:35:04 +0000 | [diff] [blame] | 234 | uart@80121000 { |
Linus Walleij | 3bfdebb | 2013-11-13 10:32:20 +0100 | [diff] [blame] | 235 | pinctrl-names = "default", "sleep"; |
| 236 | pinctrl-0 = <&uart1_default_mode>; |
| 237 | pinctrl-1 = <&uart1_sleep_mode>; |
Lee Jones | 4905af0 | 2012-03-07 17:35:04 +0000 | [diff] [blame] | 238 | }; |
| 239 | |
| 240 | uart@80007000 { |
Linus Walleij | 3bfdebb | 2013-11-13 10:32:20 +0100 | [diff] [blame] | 241 | pinctrl-names = "default", "sleep"; |
| 242 | pinctrl-0 = <&uart2_default_mode>; |
| 243 | pinctrl-1 = <&uart2_sleep_mode>; |
Lee Jones | 4905af0 | 2012-03-07 17:35:04 +0000 | [diff] [blame] | 244 | status = "okay"; |
| 245 | }; |
| 246 | |
Linus Walleij | 96fee13 | 2013-11-13 11:10:07 +0100 | [diff] [blame] | 247 | i2c@80004000 { |
| 248 | pinctrl-names = "default","sleep"; |
| 249 | pinctrl-0 = <&i2c0_default_mode>; |
| 250 | pinctrl-1 = <&i2c0_sleep_mode>; |
| 251 | }; |
| 252 | |
| 253 | i2c@80122000 { |
| 254 | pinctrl-names = "default","sleep"; |
| 255 | pinctrl-0 = <&i2c1_default_mode>; |
| 256 | pinctrl-1 = <&i2c1_sleep_mode>; |
| 257 | }; |
| 258 | |
| 259 | i2c@80128000 { |
| 260 | pinctrl-names = "default","sleep"; |
| 261 | pinctrl-0 = <&i2c2_default_mode>; |
| 262 | pinctrl-1 = <&i2c2_sleep_mode>; |
Linus Walleij | d0e3bc8 | 2014-04-12 17:13:23 +0200 | [diff] [blame] | 263 | lsm303dlh@18 { |
| 264 | /* Accelerometer */ |
| 265 | compatible = "st,lsm303dlh-accel"; |
| 266 | st,drdy-int-pin = <1>; |
| 267 | reg = <0x18>; |
| 268 | vdd-supply = <&ab8500_ldo_aux1_reg>; |
| 269 | vddio-supply = <&db8500_vsmps2_reg>; |
| 270 | pinctrl-names = "default"; |
| 271 | pinctrl-0 = <&accel_snowball_mode>; |
Linus Walleij | 22a9316 | 2015-04-27 11:28:33 +0200 | [diff] [blame] | 272 | interrupt-parent = <&gpio5>; |
| 273 | interrupts = <3 IRQ_TYPE_EDGE_RISING>, /* INT1 */ |
| 274 | <4 IRQ_TYPE_EDGE_RISING>; /* INT2 */ |
Linus Walleij | d0e3bc8 | 2014-04-12 17:13:23 +0200 | [diff] [blame] | 275 | }; |
Linus Walleij | 93deea9 | 2015-04-29 14:08:38 +0200 | [diff] [blame] | 276 | lsm303dlh@1e { |
Linus Walleij | d0e3bc8 | 2014-04-12 17:13:23 +0200 | [diff] [blame] | 277 | /* Magnetometer */ |
Linus Walleij | 93deea9 | 2015-04-29 14:08:38 +0200 | [diff] [blame] | 278 | compatible = "st,lsm303dlh-magn"; |
Linus Walleij | d0e3bc8 | 2014-04-12 17:13:23 +0200 | [diff] [blame] | 279 | reg = <0x1e>; |
| 280 | vdd-supply = <&ab8500_ldo_aux1_reg>; |
| 281 | vddio-supply = <&db8500_vsmps2_reg>; |
| 282 | pinctrl-names = "default"; |
| 283 | pinctrl-0 = <&magneto_snowball_mode>; |
Linus Walleij | c80b401 | 2015-11-05 10:18:14 +0100 | [diff] [blame] | 284 | interrupt-parent = <&gpio5>; |
| 285 | interrupts = <5 IRQ_TYPE_EDGE_RISING>; /* DRDY line */ |
Linus Walleij | d0e3bc8 | 2014-04-12 17:13:23 +0200 | [diff] [blame] | 286 | }; |
| 287 | l3g4200d@68 { |
| 288 | /* Gyroscope */ |
| 289 | compatible = "st,l3g4200d-gyro"; |
| 290 | st,drdy-int-pin = <2>; |
| 291 | reg = <0x68>; |
| 292 | vdd-supply = <&ab8500_ldo_aux1_reg>; |
| 293 | vddio-supply = <&db8500_vsmps2_reg>; |
Linus Walleij | 22a9316 | 2015-04-27 11:28:33 +0200 | [diff] [blame] | 294 | pinctrl-names = "default"; |
| 295 | pinctrl-0 = <&gyro_snowball_mode>; |
Linus Walleij | 22a9316 | 2015-04-27 11:28:33 +0200 | [diff] [blame] | 296 | interrupt-parent = <&gpio5>; |
Linus Walleij | c80b401 | 2015-11-05 10:18:14 +0100 | [diff] [blame] | 297 | interrupts = <6 IRQ_TYPE_EDGE_RISING>, /* DRDY line */ |
| 298 | <9 IRQ_TYPE_EDGE_RISING>; /* INT1 */ |
Linus Walleij | d0e3bc8 | 2014-04-12 17:13:23 +0200 | [diff] [blame] | 299 | }; |
| 300 | lsp001wm@5c { |
| 301 | /* Barometer/pressure sensor */ |
| 302 | compatible = "st,lps001wp-press"; |
| 303 | reg = <0x5c>; |
| 304 | vdd-supply = <&ab8500_ldo_aux1_reg>; |
| 305 | vddio-supply = <&db8500_vsmps2_reg>; |
| 306 | }; |
Linus Walleij | 96fee13 | 2013-11-13 11:10:07 +0100 | [diff] [blame] | 307 | }; |
| 308 | |
| 309 | i2c@80110000 { |
| 310 | pinctrl-names = "default","sleep"; |
| 311 | pinctrl-0 = <&i2c3_default_mode>; |
| 312 | pinctrl-1 = <&i2c3_sleep_mode>; |
| 313 | }; |
| 314 | |
Linus Walleij | fd8f9ea | 2013-11-17 11:13:21 +0100 | [diff] [blame] | 315 | ssp@80002000 { |
| 316 | pinctrl-names = "default"; |
| 317 | pinctrl-0 = <&ssp0_snowball_mode>; |
| 318 | }; |
| 319 | |
hongbo.zhang | dc1956b | 2012-11-15 18:56:43 +0800 | [diff] [blame] | 320 | cpufreq-cooling { |
| 321 | status = "okay"; |
| 322 | }; |
Linus Torvalds | db5b0ae | 2012-12-13 10:39:26 -0800 | [diff] [blame] | 323 | |
Lee Jones | 809efa5 | 2012-09-25 12:04:51 +0100 | [diff] [blame] | 324 | prcmu@80157000 { |
Lee Jones | 6cb7ea9 | 2013-09-18 16:03:07 +0100 | [diff] [blame] | 325 | cpufreq { |
| 326 | status = "okay"; |
| 327 | }; |
| 328 | |
Lee Jones | 6c1d25b | 2013-04-02 14:21:51 +0100 | [diff] [blame] | 329 | thermal@801573c0 { |
| 330 | num-trips = <4>; |
| 331 | |
| 332 | trip0-temp = <70000>; |
| 333 | trip0-type = "active"; |
| 334 | trip0-cdev-num = <1>; |
| 335 | trip0-cdev-name0 = "thermal-cpufreq-0"; |
| 336 | |
| 337 | trip1-temp = <75000>; |
| 338 | trip1-type = "active"; |
| 339 | trip1-cdev-num = <1>; |
| 340 | trip1-cdev-name0 = "thermal-cpufreq-0"; |
| 341 | |
| 342 | trip2-temp = <80000>; |
| 343 | trip2-type = "active"; |
| 344 | trip2-cdev-num = <1>; |
| 345 | trip2-cdev-name0 = "thermal-cpufreq-0"; |
| 346 | |
| 347 | trip3-temp = <85000>; |
| 348 | trip3-type = "critical"; |
| 349 | trip3-cdev-num = <0>; |
| 350 | |
| 351 | status = "okay"; |
| 352 | }; |
| 353 | |
Arnd Bergmann | d52701d3 | 2013-03-12 09:39:01 +0100 | [diff] [blame] | 354 | ab8500 { |
Lee Jones | 924e82d | 2013-01-16 14:28:03 +0000 | [diff] [blame] | 355 | ab8500-gpio { |
| 356 | compatible = "stericsson,ab8500-gpio"; |
| 357 | }; |
| 358 | |
Lee Jones | b0c8fad | 2013-06-07 17:11:21 +0100 | [diff] [blame] | 359 | ext_regulators: ab8500-ext-regulators { |
| 360 | ab8500_ext1_reg: ab8500_ext1 { |
| 361 | regulator-name = "ab8500-ext-supply1"; |
| 362 | }; |
| 363 | |
| 364 | ab8500_ext2_reg_reg: ab8500_ext2 { |
| 365 | regulator-name = "ab8500-ext-supply2"; |
| 366 | }; |
| 367 | |
| 368 | ab8500_ext3_reg_reg: ab8500_ext3 { |
| 369 | regulator-name = "ab8500-ext-supply3"; |
| 370 | }; |
| 371 | }; |
| 372 | |
Lee Jones | 809efa5 | 2012-09-25 12:04:51 +0100 | [diff] [blame] | 373 | ab8500-regulators { |
| 374 | ab8500_ldo_aux1_reg: ab8500_ldo_aux1 { |
| 375 | regulator-name = "V-DISPLAY"; |
| 376 | }; |
| 377 | |
| 378 | ab8500_ldo_aux2_reg: ab8500_ldo_aux2 { |
| 379 | regulator-name = "V-eMMC1"; |
| 380 | }; |
| 381 | |
| 382 | ab8500_ldo_aux3_reg: ab8500_ldo_aux3 { |
| 383 | regulator-name = "V-MMC-SD"; |
| 384 | }; |
| 385 | |
Fabio Baltieri | 99b38ee | 2013-04-09 11:16:56 +0200 | [diff] [blame] | 386 | ab8500_ldo_intcore_reg: ab8500_ldo_intcore { |
Lee Jones | 809efa5 | 2012-09-25 12:04:51 +0100 | [diff] [blame] | 387 | regulator-name = "V-INTCORE"; |
| 388 | }; |
| 389 | |
| 390 | ab8500_ldo_tvout_reg: ab8500_ldo_tvout { |
| 391 | regulator-name = "V-TVOUT"; |
| 392 | }; |
| 393 | |
| 394 | ab8500_ldo_usb_reg: ab8500_ldo_usb { |
| 395 | regulator-name = "dummy"; |
| 396 | }; |
| 397 | |
| 398 | ab8500_ldo_audio_reg: ab8500_ldo_audio { |
| 399 | regulator-name = "V-AUD"; |
| 400 | }; |
| 401 | |
| 402 | ab8500_ldo_anamic1_reg: ab8500_ldo_anamic1 { |
| 403 | regulator-name = "V-AMIC1"; |
| 404 | }; |
| 405 | |
Fabio Baltieri | 5510ed9 | 2013-05-30 15:27:42 +0200 | [diff] [blame] | 406 | ab8500_ldo_anamic2_reg: ab8500_ldo_anamic2 { |
Lee Jones | 809efa5 | 2012-09-25 12:04:51 +0100 | [diff] [blame] | 407 | regulator-name = "V-AMIC2"; |
| 408 | }; |
| 409 | |
| 410 | ab8500_ldo_dmic_reg: ab8500_ldo_dmic { |
| 411 | regulator-name = "V-DMIC"; |
| 412 | }; |
| 413 | |
| 414 | ab8500_ldo_ana_reg: ab8500_ldo_ana { |
| 415 | regulator-name = "V-CSI/DSI"; |
| 416 | }; |
| 417 | }; |
| 418 | }; |
| 419 | }; |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 420 | |
| 421 | pinctrl { |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 422 | /* |
| 423 | * Set this up using hogs, as time goes by and as seems fit, these |
| 424 | * can be moved over to being controlled by respective device. |
| 425 | */ |
| 426 | pinctrl-names = "default"; |
Linus Walleij | d0e3bc8 | 2014-04-12 17:13:23 +0200 | [diff] [blame] | 427 | pinctrl-0 = <&gbf_snowball_mode>, |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 428 | <&wlan_snowball_mode>; |
| 429 | |
Linus Walleij | a48bf4b | 2013-11-17 10:02:22 +0100 | [diff] [blame] | 430 | ethernet { |
| 431 | /* |
| 432 | * Mux in "SM" which is used for the |
| 433 | * SMSC911x Ethernet adapter |
| 434 | */ |
| 435 | eth_snowball_mode: eth_snowball { |
| 436 | snowball_mux { |
Linus Walleij | 68d41f2 | 2014-09-29 17:21:56 +0200 | [diff] [blame] | 437 | function = "sm"; |
| 438 | groups = "sm_b_1"; |
Linus Walleij | a48bf4b | 2013-11-17 10:02:22 +0100 | [diff] [blame] | 439 | }; |
| 440 | /* LAN IRQ pin */ |
| 441 | snowball_cfg1 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 442 | pins = "GPIO140_B11"; |
Linus Walleij | a48bf4b | 2013-11-17 10:02:22 +0100 | [diff] [blame] | 443 | ste,config = <&in_nopull>; |
| 444 | }; |
| 445 | /* LAN reset pin */ |
| 446 | snowball_cfg2 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 447 | pins = "GPIO141_C12"; |
Linus Walleij | a48bf4b | 2013-11-17 10:02:22 +0100 | [diff] [blame] | 448 | ste,config = <&gpio_out_hi>; |
| 449 | }; |
| 450 | |
| 451 | }; |
| 452 | }; |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 453 | sdi0 { |
| 454 | sdi0_default_mode: sdi0_default { |
| 455 | snowball_mux { |
Linus Walleij | 68d41f2 | 2014-09-29 17:21:56 +0200 | [diff] [blame] | 456 | function = "mc0"; |
| 457 | groups = "mc0dat31dir_a_1"; |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 458 | }; |
| 459 | snowball_cfg1 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 460 | pins = "GPIO21_AB3"; /* DAT31DIR */ |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 461 | ste,config = <&out_hi>; |
| 462 | }; |
Linus Walleij | 1d8aca9 | 2015-07-08 15:15:22 +0200 | [diff] [blame] | 463 | /* SD card detect GPIO pin, extend default state */ |
| 464 | snowball_cfg2 { |
| 465 | pins = "GPIO218_AH11"; |
| 466 | ste,config = <&gpio_in_pu>; |
| 467 | }; |
| 468 | /* VMMCI level-shifter enable */ |
| 469 | snowball_cfg3 { |
| 470 | pins = "GPIO217_AH12"; |
| 471 | ste,config = <&gpio_out_lo>; |
| 472 | }; |
| 473 | /* VMMCI level-shifter voltage select */ |
| 474 | snowball_cfg4 { |
| 475 | pins = "GPIO228_AJ6"; |
| 476 | ste,config = <&gpio_out_hi>; |
| 477 | }; |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 478 | }; |
| 479 | }; |
Linus Walleij | fd8f9ea | 2013-11-17 11:13:21 +0100 | [diff] [blame] | 480 | ssp0 { |
| 481 | ssp0_snowball_mode: ssp0_snowball_default { |
| 482 | snowball_mux { |
Linus Walleij | 68d41f2 | 2014-09-29 17:21:56 +0200 | [diff] [blame] | 483 | function = "ssp0"; |
| 484 | groups = "ssp0_a_1"; |
Linus Walleij | fd8f9ea | 2013-11-17 11:13:21 +0100 | [diff] [blame] | 485 | }; |
| 486 | snowball_cfg1 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 487 | pins = "GPIO144_B13"; /* FRM */ |
Linus Walleij | fd8f9ea | 2013-11-17 11:13:21 +0100 | [diff] [blame] | 488 | ste,config = <&gpio_out_hi>; |
| 489 | }; |
| 490 | snowball_cfg2 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 491 | pins = "GPIO145_C13"; /* RXD */ |
Linus Walleij | fd8f9ea | 2013-11-17 11:13:21 +0100 | [diff] [blame] | 492 | ste,config = <&in_pd>; |
| 493 | }; |
| 494 | snowball_cfg3 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 495 | pins = |
Linus Walleij | fd8f9ea | 2013-11-17 11:13:21 +0100 | [diff] [blame] | 496 | "GPIO146_D13", /* TXD */ |
| 497 | "GPIO143_D12"; /* CLK */ |
| 498 | ste,config = <&out_lo>; |
| 499 | }; |
| 500 | |
| 501 | }; |
| 502 | }; |
Linus Walleij | 2f4b84f | 2013-11-17 11:33:19 +0100 | [diff] [blame] | 503 | gpio_led { |
| 504 | gpioled_snowball_mode: gpioled_default { |
| 505 | snowball_cfg1 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 506 | pins = "GPIO142_C11"; |
Linus Walleij | 2f4b84f | 2013-11-17 11:33:19 +0100 | [diff] [blame] | 507 | ste,config = <&gpio_out_hi>; |
| 508 | }; |
| 509 | |
| 510 | }; |
| 511 | }; |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 512 | accelerometer { |
| 513 | accel_snowball_mode: accel_snowball { |
| 514 | /* Accelerometer lines */ |
| 515 | snowball_cfg1 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 516 | pins = |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 517 | "GPIO163_C20", /* ACCEL_IRQ1 */ |
| 518 | "GPIO164_B21"; /* ACCEL_IRQ2 */ |
| 519 | ste,config = <&gpio_in_pu>; |
| 520 | }; |
| 521 | }; |
| 522 | }; |
Linus Walleij | 22a9316 | 2015-04-27 11:28:33 +0200 | [diff] [blame] | 523 | gyro { |
| 524 | gyro_snowball_mode: gyro_snowball { |
| 525 | snowball_cfg1 { |
| 526 | pins = |
| 527 | "GPIO166_A22", /* DRDY */ |
| 528 | "GPIO169_D22"; /* INT */ |
| 529 | ste,config = <&gpio_in_pu>; |
| 530 | }; |
| 531 | }; |
| 532 | }; |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 533 | magnetometer { |
| 534 | magneto_snowball_mode: magneto_snowball { |
| 535 | snowball_cfg1 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 536 | pins = "GPIO165_C21"; /* MAG_DRDY */ |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 537 | ste,config = <&gpio_in_pu>; |
| 538 | }; |
| 539 | }; |
| 540 | }; |
| 541 | gbf { |
| 542 | gbf_snowball_mode: gbf_snowball { |
| 543 | /* |
| 544 | * GBF (GPS, Bluetooth, FM-radio) interface, |
| 545 | * pull low to reset state |
| 546 | */ |
| 547 | snowball_cfg1 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 548 | pins = "GPIO171_D23"; /* GBF_ENA_RESET */ |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 549 | ste,config = <&gpio_out_lo>; |
| 550 | }; |
| 551 | }; |
| 552 | }; |
| 553 | wlan { |
| 554 | wlan_snowball_mode: wlan_snowball { |
| 555 | /* |
| 556 | * Activate this mode with the WLAN chip. |
| 557 | * These are plain GPIO pins used by WLAN |
| 558 | */ |
| 559 | snowball_cfg1 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 560 | pins = |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 561 | "GPIO161_D21", /* WLAN_PMU_EN */ |
| 562 | "GPIO215_AH13"; /* WLAN_ENA */ |
| 563 | ste,config = <&gpio_out_lo>; |
| 564 | }; |
| 565 | snowball_cfg2 { |
Linus Walleij | 1637d48 | 2014-09-30 12:16:25 +0200 | [diff] [blame] | 566 | pins = "GPIO216_AG12"; /* WLAN_IRQ */ |
Linus Walleij | 4d4629f | 2013-11-17 11:52:32 +0100 | [diff] [blame] | 567 | ste,config = <&gpio_in_pu>; |
| 568 | }; |
| 569 | }; |
| 570 | }; |
Linus Walleij | 1e66235 | 2013-11-13 13:46:57 +0100 | [diff] [blame] | 571 | }; |
Linus Walleij | 817a5b9 | 2013-11-14 15:23:20 +0100 | [diff] [blame] | 572 | |
| 573 | mcde@a0350000 { |
| 574 | pinctrl-names = "default", "sleep"; |
| 575 | pinctrl-0 = <&lcd_default_mode>; |
| 576 | pinctrl-1 = <&lcd_sleep_mode>; |
| 577 | }; |
Arnd Bergmann | 2d33429 | 2012-03-07 15:04:07 +0000 | [diff] [blame] | 578 | }; |
| 579 | }; |