]> git.kernelconcepts.de Git - karo-tx-uboot.git/blob - board/samsung/smdkc100/lowlevel_init.S
4df0974af5896e0258654d5cd5e92d752ae15867
[karo-tx-uboot.git] / board / samsung / smdkc100 / lowlevel_init.S
1 /*
2  * Copyright (C) 2009 Samsung Electronics
3  * Kyungmin Park <kyungmin.park@samsung.com>
4  * Minkyu Kang <mk7.kang@samsung.com>
5  *
6  * SPDX-License-Identifier:     GPL-2.0+
7  */
8
9 #include <config.h>
10 #include <version.h>
11 #include <asm/arch/cpu.h>
12 #include <asm/arch/power.h>
13
14 /*
15  * Register usages:
16  *
17  * r5 has zero always
18  */
19
20 _TEXT_BASE:
21         .word   CONFIG_SYS_TEXT_BASE
22
23         .globl lowlevel_init
24 lowlevel_init:
25         mov     r9, lr
26
27         /* r5 has always zero */
28         mov     r5, #0
29
30         ldr     r8, =S5PC100_GPIO_BASE
31
32         /* Disable Watchdog */
33         ldr     r0, =S5PC100_WATCHDOG_BASE              @0xEA200000
34         orr     r0, r0, #0x0
35         str     r5, [r0]
36
37         /* setting SRAM */
38         ldr     r0, =S5PC100_SROMC_BASE
39         ldr     r1, =0x9
40         str     r1, [r0]
41
42         /* S5PC100 has 3 groups of interrupt sources */
43         ldr     r0, =S5PC100_VIC0_BASE                  @0xE4000000
44         ldr     r1, =S5PC100_VIC1_BASE                  @0xE4000000
45         ldr     r2, =S5PC100_VIC2_BASE                  @0xE4000000
46
47         /* Disable all interrupts (VIC0, VIC1 and VIC2) */
48         mvn     r3, #0x0
49         str     r3, [r0, #0x14]                         @INTENCLEAR
50         str     r3, [r1, #0x14]                         @INTENCLEAR
51         str     r3, [r2, #0x14]                         @INTENCLEAR
52
53         /* Set all interrupts as IRQ */
54         str     r5, [r0, #0xc]                          @INTSELECT
55         str     r5, [r1, #0xc]                          @INTSELECT
56         str     r5, [r2, #0xc]                          @INTSELECT
57
58         /* Pending Interrupt Clear */
59         str     r5, [r0, #0xf00]                        @INTADDRESS
60         str     r5, [r1, #0xf00]                        @INTADDRESS
61         str     r5, [r2, #0xf00]                        @INTADDRESS
62
63         /* for UART */
64         bl uart_asm_init
65
66         /* for TZPC */
67         bl tzpc_asm_init
68
69 1:
70         mov     lr, r9
71         mov     pc, lr
72
73 /*
74  * system_clock_init: Initialize core clock and bus clock.
75  * void system_clock_init(void)
76  */
77 system_clock_init:
78         ldr     r8, =S5PC100_CLOCK_BASE         @ 0xE0100000
79
80         /* Set Clock divider */
81         ldr     r1, =0x00011110
82         str     r1, [r8, #0x304]
83         ldr     r1, =0x1
84         str     r1, [r8, #0x308]
85         ldr     r1, =0x00011301
86         str     r1, [r8, #0x300]
87
88         /* Set Lock Time */
89         ldr     r1, =0xe10                      @ Locktime : 0xe10 = 3600
90         str     r1, [r8, #0x000]                @ APLL_LOCK
91         str     r1, [r8, #0x004]                @ MPLL_LOCK
92         str     r1, [r8, #0x008]                @ EPLL_LOCK
93         str     r1, [r8, #0x00C]                @ HPLL_LOCK
94
95         /* APLL_CON */
96         ldr     r1, =0x81bc0400         @ SDIV 0, PDIV 4, MDIV 444 (1332MHz)
97         str     r1, [r8, #0x100]
98         /* MPLL_CON */
99         ldr     r1, =0x80590201         @ SDIV 1, PDIV 2, MDIV 89 (267MHz)
100         str     r1, [r8, #0x104]
101         /* EPLL_CON */
102         ldr     r1, =0x80870303         @ SDIV 3, PDIV 3, MDIV 135 (67.5MHz)
103         str     r1, [r8, #0x108]
104         /* HPLL_CON */
105         ldr     r1, =0x80600603
106         str     r1, [r8, #0x10C]
107
108         /* Set Source Clock */
109         ldr     r1, =0x1111                     @ A, M, E, HPLL Muxing
110         str     r1, [r8, #0x200]                @ CLK_SRC0
111
112         ldr     r1, =0x1000001                  @ Uart Clock & CLK48M Muxing
113         str     r1, [r8, #0x204]                @ CLK_SRC1
114
115         ldr     r1, =0x9000                     @ ARMCLK/4
116         str     r1, [r8, #0x400]                @ CLK_OUT
117
118         /* wait at least 200us to stablize all clock */
119         mov     r2, #0x10000
120 1:      subs    r2, r2, #1
121         bne     1b
122
123         mov     pc, lr
124
125 /*
126  * uart_asm_init: Initialize UART's pins
127  */
128 uart_asm_init:
129         mov     r0, r8
130         ldr     r1, =0x22222222
131         str     r1, [r0, #0x0]                  @ GPA0_CON
132         ldr     r1, =0x00022222
133         str     r1, [r0, #0x20]                 @ GPA1_CON
134
135         mov     pc, lr
136
137 /*
138  * tzpc_asm_init: Initialize TZPC
139  */
140 tzpc_asm_init:
141         ldr     r0, =0xE3800000
142         mov     r1, #0x0
143         str     r1, [r0]
144         mov     r1, #0xff
145         str     r1, [r0, #0x804]
146         str     r1, [r0, #0x810]
147
148         ldr     r0, =0xE2800000
149         str     r1, [r0, #0x804]
150         str     r1, [r0, #0x810]
151         str     r1, [r0, #0x81C]
152
153         ldr     r0, =0xE2900000
154         str     r1, [r0, #0x804]
155         str     r1, [r0, #0x810]
156
157         mov     pc, lr