This source file includes following definitions.
- u300_map_io
- u300_init_check_chip
- u300_restart
- u300_init_irq_dt
- u300_init_machine_dt
1
2
3
4
5
6
7
8
9
10 #include <linux/kernel.h>
11 #include <linux/pinctrl/machine.h>
12 #include <linux/pinctrl/pinconf-generic.h>
13 #include <linux/platform_data/clk-u300.h>
14 #include <linux/irqchip.h>
15 #include <linux/of_address.h>
16 #include <linux/of_platform.h>
17 #include <linux/clocksource.h>
18 #include <linux/clk.h>
19
20 #include <asm/mach/map.h>
21 #include <asm/mach/arch.h>
22
23
24
25
26
27
28
29 #define U300_NAND_CS0_PHYS_BASE 0x80000000
30
31 #define U300_NAND_IF_PHYS_BASE 0x9f800000
32
33 #define PLAT_NAND_CLE (1 << 16)
34 #define PLAT_NAND_ALE (1 << 17)
35
36 #define U300_AHB_PER_PHYS_BASE 0xa0000000
37 #define U300_AHB_PER_VIRT_BASE 0xff010000
38
39 #define U300_FAST_PER_PHYS_BASE 0xc0000000
40 #define U300_FAST_PER_VIRT_BASE 0xff020000
41
42 #define U300_SLOW_PER_PHYS_BASE 0xc0010000
43 #define U300_SLOW_PER_VIRT_BASE 0xff000000
44
45 #define U300_BOOTROM_PHYS_BASE 0xffff0000
46 #define U300_BOOTROM_VIRT_BASE 0xffff0000
47
48 #define U300_SEMI_CONFIG_BASE 0x2FFE0000
49
50
51
52
53
54
55 #define U300_AHB_BRIDGE_BASE (U300_AHB_PER_PHYS_BASE+0x0000)
56
57 #define U300_INTCON0_BASE (U300_AHB_PER_PHYS_BASE+0x1000)
58 #define U300_INTCON0_VBASE IOMEM(U300_AHB_PER_VIRT_BASE+0x1000)
59
60 #define U300_INTCON1_BASE (U300_AHB_PER_PHYS_BASE+0x2000)
61 #define U300_INTCON1_VBASE IOMEM(U300_AHB_PER_VIRT_BASE+0x2000)
62
63 #define U300_MSPRO_BASE (U300_AHB_PER_PHYS_BASE+0x3000)
64
65 #define U300_EMIF_CFG_BASE (U300_AHB_PER_PHYS_BASE+0x4000)
66
67
68
69
70
71
72 #define U300_FAST_BRIDGE_BASE (U300_FAST_PER_PHYS_BASE+0x0000)
73
74 #define U300_MMCSD_BASE (U300_FAST_PER_PHYS_BASE+0x1000)
75
76 #define U300_PCM_I2S0_BASE (U300_FAST_PER_PHYS_BASE+0x2000)
77
78 #define U300_PCM_I2S1_BASE (U300_FAST_PER_PHYS_BASE+0x3000)
79
80 #define U300_I2C0_BASE (U300_FAST_PER_PHYS_BASE+0x4000)
81
82 #define U300_I2C1_BASE (U300_FAST_PER_PHYS_BASE+0x5000)
83
84 #define U300_SPI_BASE (U300_FAST_PER_PHYS_BASE+0x6000)
85
86 #define U300_UART1_BASE (U300_FAST_PER_PHYS_BASE+0x7000)
87
88
89
90
91
92
93 #define U300_SLOW_BRIDGE_BASE (U300_SLOW_PER_PHYS_BASE)
94
95 #define U300_SYSCON_BASE (U300_SLOW_PER_PHYS_BASE+0x1000)
96 #define U300_SYSCON_VBASE IOMEM(U300_SLOW_PER_VIRT_BASE+0x1000)
97
98 #define U300_WDOG_BASE (U300_SLOW_PER_PHYS_BASE+0x2000)
99
100 #define U300_UART0_BASE (U300_SLOW_PER_PHYS_BASE+0x3000)
101
102 #define U300_TIMER_APP_BASE (U300_SLOW_PER_PHYS_BASE+0x4000)
103 #define U300_TIMER_APP_VBASE IOMEM(U300_SLOW_PER_VIRT_BASE+0x4000)
104
105 #define U300_KEYPAD_BASE (U300_SLOW_PER_PHYS_BASE+0x5000)
106
107 #define U300_GPIO_BASE (U300_SLOW_PER_PHYS_BASE+0x6000)
108
109 #define U300_RTC_BASE (U300_SLOW_PER_PHYS_BASE+0x7000)
110
111 #define U300_BUSTR_BASE (U300_SLOW_PER_PHYS_BASE+0x8000)
112
113 #define U300_EVHIST_BASE (U300_SLOW_PER_PHYS_BASE+0x9000)
114
115 #define U300_TIMER_BASE (U300_SLOW_PER_PHYS_BASE+0xa000)
116
117 #define U300_PPM_BASE (U300_SLOW_PER_PHYS_BASE+0xb000)
118
119
120
121
122
123
124 #define U300_ISP_BASE (0xA0008000)
125
126 #define U300_DMAC_BASE (0xC0020000)
127
128 #define U300_MSL_BASE (0xc0022000)
129
130 #define U300_APEX_BASE (0xc0030000)
131
132 #define U300_VIDEOENC_BASE (0xc0080000)
133
134 #define U300_XGAM_BASE (0xd0000000)
135
136
137
138
139
140
141 #define U300_SYSCON_CIDR (0x400)
142
143 #define U300_SYSCON_SMCR (0x4d0)
144 #define U300_SYSCON_SMCR_FIELD_MASK (0x000e)
145 #define U300_SYSCON_SMCR_SEMI_SREFACK_IND (0x0008)
146 #define U300_SYSCON_SMCR_SEMI_SREFREQ_ENABLE (0x0004)
147 #define U300_SYSCON_SMCR_SEMI_EXT_BOOT_MODE_ENABLE (0x0002)
148
149 #define U300_SYSCON_CSDR (0x4f0)
150 #define U300_SYSCON_CSDR_SW_DEBUG_ENABLE (0x0001)
151
152 #define U300_SYSCON_PCR (0x4f8)
153 #define U300_SYSCON_PCR_SERV_IND (0x0001)
154
155 #define U300_SYSCON_BCR (0x4fc)
156 #define U300_SYSCON_BCR_ACC_CPU_SUBSYS_VINITHI_IND (0x0400)
157 #define U300_SYSCON_BCR_APP_CPU_SUBSYS_VINITHI_IND (0x0200)
158 #define U300_SYSCON_BCR_EXTRA_BOOT_OPTION_MASK (0x01FC)
159 #define U300_SYSCON_BCR_APP_BOOT_SERV_MASK (0x0003)
160
161 static void __iomem *syscon_base;
162
163
164
165
166
167
168
169 static struct map_desc u300_io_desc[] __initdata = {
170 {
171 .virtual = U300_SLOW_PER_VIRT_BASE,
172 .pfn = __phys_to_pfn(U300_SLOW_PER_PHYS_BASE),
173 .length = SZ_64K,
174 .type = MT_DEVICE,
175 },
176 {
177 .virtual = U300_AHB_PER_VIRT_BASE,
178 .pfn = __phys_to_pfn(U300_AHB_PER_PHYS_BASE),
179 .length = SZ_32K,
180 .type = MT_DEVICE,
181 },
182 {
183 .virtual = U300_FAST_PER_VIRT_BASE,
184 .pfn = __phys_to_pfn(U300_FAST_PER_PHYS_BASE),
185 .length = SZ_32K,
186 .type = MT_DEVICE,
187 },
188 };
189
190 static void __init u300_map_io(void)
191 {
192 iotable_init(u300_io_desc, ARRAY_SIZE(u300_io_desc));
193 }
194
195 static unsigned long pin_pullup_conf[] = {
196 PIN_CONF_PACKED(PIN_CONFIG_BIAS_PULL_UP, 1),
197 };
198
199 static unsigned long pin_highz_conf[] = {
200 PIN_CONF_PACKED(PIN_CONFIG_BIAS_HIGH_IMPEDANCE, 0),
201 };
202
203
204 static struct pinctrl_map __initdata u300_pinmux_map[] = {
205
206 PIN_MAP_MUX_GROUP_HOG_DEFAULT("pinctrl-u300", NULL, "power"),
207 PIN_MAP_MUX_GROUP_HOG_DEFAULT("pinctrl-u300", NULL, "emif0"),
208 PIN_MAP_MUX_GROUP_HOG_DEFAULT("pinctrl-u300", NULL, "emif1"),
209
210 PIN_MAP_MUX_GROUP_DEFAULT("mmci", "pinctrl-u300", NULL, "mmc0"),
211 PIN_MAP_MUX_GROUP_DEFAULT("pl022", "pinctrl-u300", NULL, "spi0"),
212 PIN_MAP_MUX_GROUP_DEFAULT("uart0", "pinctrl-u300", NULL, "uart0"),
213
214 PIN_MAP_CONFIGS_PIN_DEFAULT("mmci", "pinctrl-u300", "PIO APP GPIO 11",
215 pin_pullup_conf),
216
217 PIN_MAP_CONFIGS_PIN_DEFAULT("mmci", "pinctrl-u300", "PIO MS INS",
218 pin_highz_conf),
219 };
220
221 struct db_chip {
222 u16 chipid;
223 const char *name;
224 };
225
226
227
228
229 static struct db_chip db_chips[] __initdata = {
230 {
231 .chipid = 0xb800,
232 .name = "DB3000",
233 },
234 {
235 .chipid = 0xc000,
236 .name = "DB3100",
237 },
238 {
239 .chipid = 0xc800,
240 .name = "DB3150",
241 },
242 {
243 .chipid = 0xd800,
244 .name = "DB3200",
245 },
246 {
247 .chipid = 0xe000,
248 .name = "DB3250",
249 },
250 {
251 .chipid = 0xe800,
252 .name = "DB3210",
253 },
254 {
255 .chipid = 0xf000,
256 .name = "DB3350 P1x",
257 },
258 {
259 .chipid = 0xf100,
260 .name = "DB3350 P2x",
261 },
262 {
263 .chipid = 0x0000,
264 .name = NULL,
265 }
266 };
267
268 static void __init u300_init_check_chip(void)
269 {
270
271 u16 val;
272 struct db_chip *chip;
273 const char *chipname;
274 const char unknown[] = "UNKNOWN";
275
276
277 val = readw(syscon_base + U300_SYSCON_CIDR);
278
279 val = (val & 0xFFU) << 8 | (val >> 8);
280 chip = db_chips;
281 chipname = unknown;
282
283 for ( ; chip->chipid; chip++) {
284 if (chip->chipid == (val & 0xFF00U)) {
285 chipname = chip->name;
286 break;
287 }
288 }
289 printk(KERN_INFO "Initializing U300 system on %s baseband chip " \
290 "(chip ID 0x%04x)\n", chipname, val);
291
292 if ((val & 0xFF00U) != 0xf000 && (val & 0xFF00U) != 0xf100) {
293 printk(KERN_ERR "Platform configured for BS335 " \
294 " with DB3350 but %s detected, expect problems!",
295 chipname);
296 }
297 }
298
299
300 void coh901327_watchdog_reset(void);
301
302 static void u300_restart(enum reboot_mode mode, const char *cmd)
303 {
304 switch (mode) {
305 case REBOOT_SOFT:
306 case REBOOT_HARD:
307 #ifdef CONFIG_COH901327_WATCHDOG
308 coh901327_watchdog_reset();
309 #endif
310 break;
311 default:
312
313 break;
314 }
315
316 while (1);
317 }
318
319
320 static struct of_dev_auxdata u300_auxdata_lookup[] __initdata = {
321 OF_DEV_AUXDATA("stericsson,pinctrl-u300", U300_SYSCON_BASE,
322 "pinctrl-u300", NULL),
323 OF_DEV_AUXDATA("stericsson,gpio-coh901", U300_GPIO_BASE,
324 "u300-gpio", NULL),
325 OF_DEV_AUXDATA("stericsson,coh901327", U300_WDOG_BASE,
326 "coh901327_wdog", NULL),
327 OF_DEV_AUXDATA("stericsson,coh901331", U300_RTC_BASE,
328 "rtc-coh901331", NULL),
329 OF_DEV_AUXDATA("stericsson,coh901318", U300_DMAC_BASE,
330 "coh901318", NULL),
331 OF_DEV_AUXDATA("stericsson,fsmc-nand", U300_NAND_IF_PHYS_BASE,
332 "fsmc-nand", NULL),
333 OF_DEV_AUXDATA("arm,primecell", U300_UART0_BASE,
334 "uart0", NULL),
335 OF_DEV_AUXDATA("arm,primecell", U300_UART1_BASE,
336 "uart1", NULL),
337 OF_DEV_AUXDATA("arm,primecell", U300_SPI_BASE,
338 "pl022", NULL),
339 OF_DEV_AUXDATA("st,ddci2c", U300_I2C0_BASE,
340 "stu300.0", NULL),
341 OF_DEV_AUXDATA("st,ddci2c", U300_I2C1_BASE,
342 "stu300.1", NULL),
343 OF_DEV_AUXDATA("arm,primecell", U300_MMCSD_BASE,
344 "mmci", NULL),
345 { },
346 };
347
348 static void __init u300_init_irq_dt(void)
349 {
350 struct device_node *syscon;
351 struct clk *clk;
352
353 syscon = of_find_node_by_path("/syscon@c0011000");
354 if (!syscon) {
355 pr_crit("could not find syscon node\n");
356 return;
357 }
358 syscon_base = of_iomap(syscon, 0);
359 if (!syscon_base) {
360 pr_crit("could not remap syscon\n");
361 return;
362 }
363
364 u300_clk_init(syscon_base);
365
366
367 clk = clk_get_sys("pl172", NULL);
368 BUG_ON(IS_ERR(clk));
369 clk_prepare_enable(clk);
370 clk = clk_get_sys("semi", NULL);
371 BUG_ON(IS_ERR(clk));
372 clk_prepare_enable(clk);
373
374
375 clk = clk_get_sys("intcon", NULL);
376 BUG_ON(IS_ERR(clk));
377 clk_prepare_enable(clk);
378
379 irqchip_init();
380 }
381
382 static void __init u300_init_machine_dt(void)
383 {
384 u16 val;
385
386
387 u300_init_check_chip();
388
389
390 pinctrl_register_mappings(u300_pinmux_map,
391 ARRAY_SIZE(u300_pinmux_map));
392
393 of_platform_default_populate(NULL, u300_auxdata_lookup, NULL);
394
395
396 val = readw(syscon_base + U300_SYSCON_SMCR) |
397 U300_SYSCON_SMCR_SEMI_SREFREQ_ENABLE;
398 writew(val, syscon_base + U300_SYSCON_SMCR);
399 }
400
401 static const char * u300_board_compat[] = {
402 "stericsson,u300",
403 NULL,
404 };
405
406 DT_MACHINE_START(U300_DT, "U300 S335/B335 (Device Tree)")
407 .map_io = u300_map_io,
408 .init_irq = u300_init_irq_dt,
409 .init_time = timer_probe,
410 .init_machine = u300_init_machine_dt,
411 .restart = u300_restart,
412 .dt_compat = u300_board_compat,
413 MACHINE_END