tcl: replace the deprecated commands with "adapter ..."
[openocd.git] / tcl / board / icnova_sam9g45_sodimm.cfg
1 #################################################################################################
2 # #
3 # Author: Lars Poeschel (larsi@wh2.tu-dresden.de) #
4 # Generated for In-Circuit ICnova SAM9G45 SODIMM #
5 # http://www.ic-board.de/product_info.php?info=p214_ICnova-SAM9G45-SODIMM.html|ICnova #
6 # #
7 #################################################################################################
8
9 # FIXME use some standard target config, maybe create one from this
10 #
11 # source [find target/...cfg]
12
13 source [find target/at91sam9g45.cfg]
14
15 # Set reset type.
16 # reset_config trst_and_srst
17
18 # adapter srst delay 200
19 # jtag_ntrst_delay 200
20
21
22 # If you don't want to execute built-in boot rom code (and there are good reasons at times not to do that) in the
23 # AT91SAM9 family, the microcontroller is a lump on a log without initialization. Because this family has
24 # some powerful features, we want to have a special function that handles "reset init". To do this we declare
25 # an event handler where these special activities can take place.
26
27 scan_chain
28 $_TARGETNAME configure -event reset-init {at91sam9g45_init}
29
30 # Set fallback clock to 1/6 of worst-case clock speed (which would be the 32.768 kHz slow clock).
31 # Slow-speed oscillator enabled at reset, so run jtag speed slow.
32 $_TARGETNAME configure -event reset-start {at91sam9g45_start}
33
34
35 # NandFlash configuration and definition
36 # Future TBD
37 # Flash configuration
38 # flash bank cfi <base> <size> <chip width> <bus width> <target#>
39 set _FLASHNAME $_CHIPNAME.flash
40 # set _NANDNAME $_CHIPNAME.nand
41 flash bank $_FLASHNAME cfi 0x10000000 0x00800000 2 2 $_TARGETNAME
42 # nand device $_NANDNAME at91sam9 $_TARGETNAME 0x40000000 0xFFFFE800
43
44
45 proc read_register {register} {
46 set result ""
47 mem2array result 32 $register 1
48 return $result(0)
49 }
50
51 proc at91sam9g45_start { } {
52
53 # Make sure that the the jtag is running slow, since there are a number of different ways the board
54 # can be configured coming into this state that can cause communication problems with the jtag
55 # adapter. Also since this call can be made following a "reset init" where fast memory accesses
56 # are enabled, need to temporarily shut this down so that the RSTC_MR register can be written at slower
57 # jtag speed without causing GDB keep alive problem.
58
59 arm7_9 fast_memory_access disable
60 # Slow-speed oscillator enabled at reset, so run jtag speed slow.
61 adapter speed 4
62 # Make sure processor is halted, or error will result in following steps.
63 halt
64 wait_halt 10000
65 # RSTC_MR : enable user reset.
66 mww 0xfffffd08 0xa5000501
67 }
68
69
70 proc at91sam9g45_init { } {
71
72 # At reset AT91SAM9G45 chip runs on slow clock (32.768 kHz). To shift over to a normal clock requires
73 # a number of steps that must be carefully performed. The process outline below follows the
74 # recommended procedure outlined in the AT91SAM9G45 technical manual.
75 #
76 # Several key and very important things to keep in mind:
77 # The SDRAM parts used currently on the board are -75 grade parts. This
78 # means the master clock (MCLK) must be at or below 133 MHz or timing errors will occur. The processor
79 # core can operate up to 400 MHz and therefore PCLK must be at or below this to function properly.
80
81 # Make sure processor is halted, or error will result in following steps.
82 halt
83 # RSTC_MR : enable user reset.
84 mww 0xfffffd08 0xa5000501
85 # WDT_MR : disable watchdog.
86 mww 0xfffffd44 0x00008000
87
88 # Enable the main 15.000 MHz oscillator in CKGR_MOR register.
89 # Wait for MOSCS in PMC_SR to assert indicating oscillator is again stable after change to CKGR_MOR.
90
91 mww 0xfffffc20 0x00004001
92 while { [expr [read_register 0xfffffc68] & 0x01] != 1 } { sleep 1 }
93
94 # Set PLLA Register for 792.576 MHz (divider: bypass, multiplier: 43).
95 # Wait for LOCKA signal in PMC_SR to assert indicating PLLA is stable.
96
97 #mww 0xfffffc28 0x202a3f01
98 mww 0xfffffc28 0x20c73f03
99 while { [expr [read_register 0xfffffc68] & 0x02] != 2 } { sleep 1 }
100
101 # Set master system clock prescaler divide by 6 and processor clock divide by 2 in PMC_MCKR.
102 # Wait for MCKRDY signal from PMC_SR to assert.
103
104 #mww 0xfffffc30 0x00000101
105 mww 0xfffffc30 0x00001301
106 while { [expr [read_register 0xfffffc68] & 0x08] != 8 } { sleep 1 }
107
108 # Now change PMC_MCKR register to select PLLA.
109 # Wait for MCKRDY signal from PMC_SR to assert.
110
111 mww 0xfffffc30 0x00001302
112 while { [expr [read_register 0xfffffc68] & 0x08] != 8 } { sleep 1 }
113
114 # Processor and master clocks are now operating and stable at maximum frequency possible:
115 # -> MCLK = 132.096 MHz
116 # -> PCLK = 396.288 MHz
117
118 # Switch over to adaptive clocking.
119
120 adapter speed 6000
121
122 # Enable faster DCC downloads.
123
124 arm7_9 dcc_downloads enable
125
126 # To be able to use external SDRAM, several peripheral configuration registers must
127 # be modified. The first change is made to PIO_ASR to select peripheral functions
128 # for D15 through D31. The second change is made to the PIO_PDR register to disable
129 # this for D15 through D31.
130
131 # mww 0xfffff870 0xffff0000
132 # mww 0xfffff804 0xffff0000
133
134 # The EBI chip select register EBI_CS must be specifically configured to enable the internal SDRAM controller
135 # using CS1. Additionally we want CS3 assigned to NandFlash. Also VDDIO is connected physically on
136 # the board to the 3.3 VDC power supply so set the appropriate register bit to notify the micrcontroller.
137
138 # mww 0xffffef1c 0x000100a
139
140 # The ICnova SAM9G45 SODIMM has built-in NandFlash. The exact physical timing characteristics
141 # for the memory type used on the current board (MT29F2G08AACWP) can be established by setting
142 # four registers in order: SMC_SETUP3, SMC_PULSE3, SMC_CYCLE3, and SMC_MODE3.
143
144 # mww 0xffffec30 0x00020002
145 # mww 0xffffec34 0x04040404
146 # mww 0xffffec38 0x00070007
147 # mww 0xffffec3c 0x00030003
148
149 # Identify NandFlash bank 0. Disabled at the moment because a memory driver is not yet complete.
150
151 # nand probe 0
152
153 # SMC_SETUP0 : Setup SMC for NOR Flash
154 mww 0xffffe800 0x0012000a
155 # SMC_PULSE0
156 mww 0xffffe804 0x3b38343b
157 # SMC_CYCLE0
158 mww 0xffffe808 0x003f003f
159 # SMC_MODE0
160 mww 0xffffe80c 0x00001000
161 # Identify flash bank 0
162 flash probe 0
163
164 # Now setup SDRAM. This is tricky and configuration is very important for reliability! The current calculations
165 # are based on 2 x Samsung K4T51083QG memory.
166
167 # 0. Enable DDR2 Clock
168 mww 0xfffffc00 0x4
169 # 1. Program memory device type
170 # 1.1 configure the DDR controller
171 mww 0xffffe620 0x16
172 # 1.2 program the DDR controller
173 mww 0xffffe608 0x3d
174
175 # 2. program memory device features
176 # 2.1 assume timings for 7.5ns min clock period
177 mww 0xffffe60c 0x21128226
178 # 2.2 pSDDRC->HDDRSDRC2_T1PR
179 mww 0xffffe610 0x02c8100e
180 # 2.3 pSDDRC->HDDRSDRC2_T2PR
181 mww 0xffffe614 0x01000702
182 # 3. NOP
183 mww 0xffffe600 0x1
184 mww 0x70000000 0x1
185 # 3.1 delay 200us
186 sleep 1
187 # jim tcl alternative: after ms
188 # after 0.2
189
190 # 4. NOP
191 mww 0xffffe600 0x1
192 mww 0x70000000 0x1
193 # 4.1 delay 400ns
194
195 # 5. set all bank precharge
196 mww 0xffffe600 0x2
197 mww 0x70000000 0x1
198 # 5.1 delay 400ns
199
200 # 6. set EMR operation (EMRS2)
201 mww 0xffffe600 0x5
202 mww 0x74000000 0x1
203 # 6.1 delay 2 cycles
204
205 # 7. set EMR operation (EMRS3)
206 mww 0xffffe600 0x5
207 mww 0x76000000 0x1
208 # 7.1 delay 2 cycles
209
210 # 8. set EMR operation (EMRS1)
211 mww 0xffffe600 0x5
212 mww 0x72000000 0x1
213 # 8.1 delay 200 cycles (400Mhz -> 5 * 10^-7s)
214 sleep 1
215
216 # 9. Enable DLL Reset (set DLL bit)
217 set CR [expr [read_register 0xffffe608] | 0x80]
218 mww 0xffffe608 $CR
219
220 # 10. mode register cycle to reset the DLL
221 mww 0xffffe600 0x5
222 mww 0x70000000 0x1
223 # 10.1 delay 2 cycles
224
225 # 11. set all bank precharge
226 mww 0xffffe600 0x2
227 mww 0x70000000 0x1
228 # 11.1 delay 400 ns
229
230 # 12. two auto-refresh (CBR) cycles are provided.
231 mww 0xffffe600 0x4
232 mww 0x70000000 0x1
233 # 12.1 delay 10 cycles
234 # 12.2 2nd cycle (schreiben des Mode Register sparen wir uns)
235 mww 0x70000000 0x1
236 # 12.3 delay 10 cycles
237
238 # 13. disable DLL reset (clear DLL bit)
239 set CR [expr [read_register 0xffffe608] & 0xffffff7f]
240 mww 0xffffe608 $CR
241
242 # 14. mode register set cycle
243 mww 0xffffe600 0x3
244 mww 0x70000000 0x1
245
246 # 15. program OCD field (set OCD bits)
247 set CR [expr [read_register 0xffffe608] | 0x7000]
248 mww 0xffffe608 $CR
249
250 # 16. (EMRS1)
251 mww 0xffffe600 0x5
252 mww 0x72000000 0x1
253 # 16.1 delay 2 cycles
254
255 # 17. disable OCD field (clear OCD bits)
256 set CR [expr [read_register 0xffffe608] & 0xffff8fff]
257 mww 0xffffe608 $CR
258
259 # 18. (EMRS1)
260 mww 0xffffe600 0x5
261 mww 0x76000000 0x1
262 # 18.1 delay 2 cycles
263
264 # 19. normal mode command
265 mww 0xffffe600 0x0
266 mww 0x70000000 0x1
267
268 # 20. perform write to any address
269 #mww 0x70000000 0x1
270
271 # 21. write refresh rate into the count field of the refresh rate register
272 mww 0xffffe604 0x24b
273 # 21.1 delay (500 * 6 cycles)
274
275 arm7_9 fast_memory_access enable
276 }
277
278

Linking to existing account procedure

If you already have an account and want to add another login method you MUST first sign in with your existing account and then change URL to read https://review.openocd.org/login/?link to get to this page again but this time it'll work for linking. Thank you.

SSH host keys fingerprints

1024 SHA256:YKx8b7u5ZWdcbp7/4AeXNaqElP49m6QrwfXaqQGJAOk gerrit-code-review@openocd.zylin.com (DSA)
384 SHA256:jHIbSQa4REvwCFG4cq5LBlBLxmxSqelQPem/EXIrxjk gerrit-code-review@openocd.org (ECDSA)
521 SHA256:UAOPYkU9Fjtcao0Ul/Rrlnj/OsQvt+pgdYSZ4jOYdgs gerrit-code-review@openocd.org (ECDSA)
256 SHA256:A13M5QlnozFOvTllybRZH6vm7iSt0XLxbA48yfc2yfY gerrit-code-review@openocd.org (ECDSA)
256 SHA256:spYMBqEYoAOtK7yZBrcwE8ZpYt6b68Cfh9yEVetvbXg gerrit-code-review@openocd.org (ED25519)
+--[ED25519 256]--+
|=..              |
|+o..   .         |
|*.o   . .        |
|+B . . .         |
|Bo. = o S        |
|Oo.+ + =         |
|oB=.* = . o      |
| =+=.+   + E     |
|. .=o   . o      |
+----[SHA256]-----+
2048 SHA256:0Onrb7/PHjpo6iVZ7xQX2riKN83FJ3KGU0TvI0TaFG4 gerrit-code-review@openocd.zylin.com (RSA)