hc
2024-03-26 e9199a72d842cbda78ac614eee5db7cdaa6f2530
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
/*
 * Low-level board setup code for TI DaVinci SoC based boards.
 *
 * Copyright (C) 2007 Sergey Kubushyn <ksi@koi8.net>
 *
 * Partially based on TI sources, original copyrights follow:
 */
 
/*
 * Board specific setup info
 *
 * (C) Copyright 2003
 * Texas Instruments, <www.ti.com>
 * Kshitij Gupta <Kshitij@ti.com>
 *
 * Modified for OMAP 1610 H2 board by Nishant Kamat, Jan 2004
 *
 * Modified for OMAP 5912 OSK board by Rishi Bhattacharya, Apr 2004
 *
 * Modified for DV-EVM board by Rishi Bhattacharya, Apr 2005
 *
 * Modified for DV-EVM board by Swaminathan S, Nov 2005
 *
 * SPDX-License-Identifier:    GPL-2.0+
 */
 
#include <config.h>
 
#define MDSTAT_STATE    0x3f
 
.globl    lowlevel_init
lowlevel_init:
#ifdef CONFIG_SOC_DM644X
 
   /*-------------------------------------------------------*
    * Mask all IRQs by setting all bits in the EINT default *
    *-------------------------------------------------------*/
   mov    r1, $0
   ldr    r0, =EINT_ENABLE0
   str    r1, [r0]
   ldr    r0, =EINT_ENABLE1
   str    r1, [r0]
 
   /*------------------------------------------------------*
    * Put the GEM in reset                    *
    *------------------------------------------------------*/
 
   /* Put the GEM in reset */
   ldr    r8, PSC_GEM_FLAG_CLEAR
   ldr    r6, MDCTL_GEM
   ldr    r7, [r6]
   and    r7, r7, r8
   str    r7, [r6]
 
   /* Enable the Power Domain Transition Command */
   ldr    r6, PTCMD
   ldr    r7, [r6]
   orr    r7, r7, $0x02
   str    r7, [r6]
 
   /* Check for Transition Complete(PTSTAT) */
checkStatClkStopGem:
   ldr    r6, PTSTAT
   ldr    r7, [r6]
   ands    r7, r7, $0x02
   bne    checkStatClkStopGem
 
   /* Check for GEM Reset Completion */
checkGemStatClkStop:
   ldr    r6, MDSTAT_GEM
   ldr    r7, [r6]
   ands    r7, r7, $0x100
   bne    checkGemStatClkStop
 
   /* Do this for enabling a WDT initiated reset this is a workaround
      for a chip bug.  Not required under normal situations */
   ldr    r6, P1394
   mov    r10, $0
   str    r10, [r6]
 
   /*------------------------------------------------------*
    * Enable L1 & L2 Memories in Fast mode                 *
    *------------------------------------------------------*/
   ldr    r6, DFT_ENABLE
   mov    r10, $0x01
   str    r10, [r6]
 
   ldr    r6, MMARG_BRF0
   ldr    r10, MMARG_BRF0_VAL
   str    r10, [r6]
 
   ldr    r6, DFT_ENABLE
   mov    r10, $0
   str    r10, [r6]
 
   /*------------------------------------------------------*
    * DDR2 PLL Initialization                *
    *------------------------------------------------------*/
 
   /* Select the Clock Mode Depending on the Value written in the Boot Table by the run script */
   mov    r10, $0
   ldr    r6, PLL2_CTL
   ldr    r7, PLL_CLKSRC_MASK
   ldr    r8, [r6]
   and    r8, r8, r7
   mov    r9, r10, lsl $8
   orr    r8, r8, r9
   str    r8, [r6]
 
   /* Select the PLLEN source */
   ldr    r7, PLL_ENSRC_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Bypass the PLL */
   ldr    r7, PLL_BYPASS_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Wait for few cycles to allow PLLEN Mux switch properly to bypass Clock */
   mov    r10, $0x20
WaitPPL2Loop:
   subs    r10, r10, $1
   bne    WaitPPL2Loop
 
   /* Reset the PLL */
   ldr    r7, PLL_RESET_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Power up the PLL */
   ldr    r7, PLL_PWRUP_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Enable the PLL from Disable Mode */
   ldr    r7, PLL_DISABLE_ENABLE_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Program the PLL Multiplier */
   ldr    r6, PLL2_PLLM
   mov    r2, $0x17    /* 162 MHz */
   str    r2, [r6]
 
   /* Program the PLL2 Divisor Value */
   ldr    r6, PLL2_DIV2
   mov    r3, $0x01
   str    r3, [r6]
 
   /* Program the PLL2 Divisor Value */
   ldr    r6, PLL2_DIV1
   mov    r4, $0x0b    /* 54 MHz */
   str    r4, [r6]
 
   /* PLL2 DIV2 MMR */
   ldr    r8, PLL2_DIV_MASK
   ldr    r6, PLL2_DIV2
   ldr    r9, [r6]
   and    r8, r8, r9
   mov    r9, $0x01
   mov    r9, r9, lsl $15
   orr    r8, r8, r9
   str    r8, [r6]
 
   /* Program the GOSET bit to take new divider values */
   ldr    r6, PLL2_PLLCMD
   ldr    r7, [r6]
   orr    r7, r7, $0x01
   str    r7, [r6]
 
   /* Wait for Done */
   ldr    r6, PLL2_PLLSTAT
doneLoop_0:
   ldr    r7, [r6]
   ands    r7, r7, $0x01
   bne    doneLoop_0
 
   /* PLL2 DIV1 MMR */
   ldr    r8, PLL2_DIV_MASK
   ldr    r6, PLL2_DIV1
   ldr    r9, [r6]
   and    r8, r8, r9
   mov    r9, $0x01
   mov    r9, r9, lsl $15
   orr    r8, r8, r9
   str    r8, [r6]
 
   /* Program the GOSET bit to take new divider values */
   ldr    r6, PLL2_PLLCMD
   ldr    r7, [r6]
   orr    r7, r7, $0x01
   str    r7, [r6]
 
   /* Wait for Done */
   ldr    r6, PLL2_PLLSTAT
doneLoop:
   ldr    r7, [r6]
   ands    r7, r7, $0x01
   bne    doneLoop
 
   /* Wait for PLL to Reset Properly */
   mov    r10, $0x218
ResetPPL2Loop:
   subs    r10, r10, $1
   bne    ResetPPL2Loop
 
   /* Bring PLL out of Reset */
   ldr    r6, PLL2_CTL
   ldr    r8, [r6]
   orr    r8, r8, $0x08
   str    r8, [r6]
 
   /* Wait for PLL to Lock */
   ldr    r10, PLL_LOCK_COUNT
PLL2Lock:
   subs    r10, r10, $1
   bne    PLL2Lock
 
   /* Enable the PLL */
   ldr    r6, PLL2_CTL
   ldr    r8, [r6]
   orr    r8, r8, $0x01
   str    r8, [r6]
 
   /*------------------------------------------------------*
    * Issue Soft Reset to DDR Module            *
    *------------------------------------------------------*/
 
   /* Shut down the DDR2 LPSC Module */
   ldr    r8, PSC_FLAG_CLEAR
   ldr    r6, MDCTL_DDR2
   ldr    r7, [r6]
   and    r7, r7, r8
   orr    r7, r7, $0x03
   str    r7, [r6]
 
   /* Enable the Power Domain Transition Command */
   ldr    r6, PTCMD
   ldr    r7, [r6]
   orr    r7, r7, $0x01
   str    r7, [r6]
 
   /* Check for Transition Complete(PTSTAT) */
checkStatClkStop:
   ldr    r6, PTSTAT
   ldr    r7, [r6]
   ands    r7, r7, $0x01
   bne    checkStatClkStop
 
   /* Check for DDR2 Controller Enable Completion */
checkDDRStatClkStop:
   ldr    r6, MDSTAT_DDR2
   ldr    r7, [r6]
   and    r7, r7, $MDSTAT_STATE
   cmp    r7, $0x03
   bne    checkDDRStatClkStop
 
   /*------------------------------------------------------*
    * Program DDR2 MMRs for 162MHz Setting            *
    *------------------------------------------------------*/
 
   /* Program PHY Control Register */
   ldr    r6, DDRCTL
   ldr    r7, DDRCTL_VAL
   str    r7, [r6]
 
   /* Program SDRAM Bank Config Register */
   ldr    r6, SDCFG
   ldr    r7, SDCFG_VAL
   str    r7, [r6]
 
   /* Program SDRAM TIM-0 Config Register */
   ldr    r6, SDTIM0
   ldr    r7, SDTIM0_VAL_162MHz
   str    r7, [r6]
 
   /* Program SDRAM TIM-1 Config Register */
   ldr    r6, SDTIM1
   ldr    r7, SDTIM1_VAL_162MHz
   str    r7, [r6]
 
   /* Program the SDRAM Bank Config Control Register */
   ldr    r10, MASK_VAL
   ldr    r8, SDCFG
   ldr    r9, SDCFG_VAL
   and    r9, r9, r10
   str    r9, [r8]
 
   /* Program SDRAM SDREF Config Register */
   ldr    r6, SDREF
   ldr    r7, SDREF_VAL
   str    r7, [r6]
 
   /*------------------------------------------------------*
    * Issue Soft Reset to DDR Module            *
    *------------------------------------------------------*/
 
   /* Issue a Dummy DDR2 read/write */
   ldr    r8, DDR2_START_ADDR
   ldr    r7, DUMMY_VAL
   str    r7, [r8]
   ldr    r7, [r8]
 
   /* Shut down the DDR2 LPSC Module */
   ldr    r8, PSC_FLAG_CLEAR
   ldr    r6, MDCTL_DDR2
   ldr    r7, [r6]
   and    r7, r7, r8
   orr    r7, r7, $0x01
   str    r7, [r6]
 
   /* Enable the Power Domain Transition Command */
   ldr    r6, PTCMD
   ldr    r7, [r6]
   orr    r7, r7, $0x01
   str    r7, [r6]
 
   /* Check for Transition Complete(PTSTAT) */
checkStatClkStop2:
   ldr    r6, PTSTAT
   ldr    r7, [r6]
   ands    r7, r7, $0x01
   bne    checkStatClkStop2
 
   /* Check for DDR2 Controller Enable Completion */
checkDDRStatClkStop2:
   ldr    r6, MDSTAT_DDR2
   ldr    r7, [r6]
   and    r7, r7, $MDSTAT_STATE
   cmp    r7, $0x01
   bne    checkDDRStatClkStop2
 
   /*------------------------------------------------------*
    * Turn DDR2 Controller Clocks On            *
    *------------------------------------------------------*/
 
   /* Enable the DDR2 LPSC Module */
   ldr    r6, MDCTL_DDR2
   ldr    r7, [r6]
   orr    r7, r7, $0x03
   str    r7, [r6]
 
   /* Enable the Power Domain Transition Command */
   ldr    r6, PTCMD
   ldr    r7, [r6]
   orr    r7, r7, $0x01
   str    r7, [r6]
 
   /* Check for Transition Complete(PTSTAT) */
checkStatClkEn2:
   ldr    r6, PTSTAT
   ldr    r7, [r6]
   ands    r7, r7, $0x01
   bne    checkStatClkEn2
 
   /* Check for DDR2 Controller Enable Completion */
checkDDRStatClkEn2:
   ldr    r6, MDSTAT_DDR2
   ldr    r7, [r6]
   and    r7, r7, $MDSTAT_STATE
   cmp    r7, $0x03
   bne    checkDDRStatClkEn2
 
   /*  DDR Writes and Reads */
   ldr    r6, CFGTEST
   mov    r3, $0x01
   str    r3, [r6]
 
   /*------------------------------------------------------*
    * System PLL Initialization                *
    *------------------------------------------------------*/
 
   /* Select the Clock Mode Depending on the Value written in the Boot Table by the run script */
   mov    r2, $0
   ldr    r6, PLL1_CTL
   ldr    r7, PLL_CLKSRC_MASK
   ldr    r8, [r6]
   and    r8, r8, r7
   mov    r9, r2, lsl $8
   orr    r8, r8, r9
   str    r8, [r6]
 
   /* Select the PLLEN source */
   ldr    r7, PLL_ENSRC_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Bypass the PLL */
   ldr    r7, PLL_BYPASS_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Wait for few cycles to allow PLLEN Mux switch properly to bypass Clock */
   mov    r10, $0x20
 
WaitLoop:
   subs    r10, r10, $1
   bne    WaitLoop
 
   /* Reset the PLL */
   ldr    r7, PLL_RESET_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Disable the PLL */
   orr    r8, r8, $0x10
   str    r8, [r6]
 
   /* Power up the PLL */
   ldr    r7, PLL_PWRUP_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Enable the PLL from Disable Mode */
   ldr    r7, PLL_DISABLE_ENABLE_MASK
   and    r8, r8, r7
   str    r8, [r6]
 
   /* Program the PLL Multiplier */
   ldr    r6, PLL1_PLLM
   mov    r3, $0x15    /* For 594MHz */
   str    r3, [r6]
 
   /* Wait for PLL to Reset Properly */
   mov    r10, $0xff
 
ResetLoop:
   subs    r10, r10, $1
   bne    ResetLoop
 
   /* Bring PLL out of Reset */
   ldr    r6, PLL1_CTL
   orr    r8, r8, $0x08
   str    r8, [r6]
 
   /* Wait for PLL to Lock */
   ldr    r10, PLL_LOCK_COUNT
 
PLL1Lock:
   subs    r10, r10, $1
   bne    PLL1Lock
 
   /* Enable the PLL */
   orr    r8, r8, $0x01
   str    r8, [r6]
 
   nop
   nop
   nop
   nop
 
   /*------------------------------------------------------*
    * AEMIF configuration for NOR Flash (double check)     *
    *------------------------------------------------------*/
   ldr    r0, _PINMUX0
   ldr    r1, _DEV_SETTING
   str    r1, [r0]
 
   ldr    r0, WAITCFG
   ldr    r1, WAITCFG_VAL
   ldr    r2, [r0]
   orr    r2, r2, r1
   str    r2, [r0]
 
   ldr    r0, ACFG3
   ldr    r1, ACFG3_VAL
   ldr    r2, [r0]
   and    r1, r2, r1
   str    r1, [r0]
 
   ldr    r0, ACFG4
   ldr    r1, ACFG4_VAL
   ldr    r2, [r0]
   and    r1, r2, r1
   str    r1, [r0]
 
   ldr    r0, ACFG5
   ldr    r1, ACFG5_VAL
   ldr    r2, [r0]
   and    r1, r2, r1
   str    r1, [r0]
 
   /*--------------------------------------*
    * VTP manual Calibration               *
    *--------------------------------------*/
   ldr    r0, VTPIOCR
   ldr    r1, VTP_MMR0
   str    r1, [r0]
 
   ldr    r0, VTPIOCR
   ldr    r1, VTP_MMR1
   str    r1, [r0]
 
   /* Wait for 33 VTP CLK cycles.  VRP operates at 27 MHz */
   ldr    r10, VTP_LOCK_COUNT
VTPLock:
   subs    r10, r10, $1
   bne    VTPLock
 
   ldr    r6, DFT_ENABLE
   mov    r10, $0x01
   str    r10, [r6]
 
   ldr    r6, DDRVTPR
   ldr    r7, [r6]
   mov    r8, r7, LSL #32-10
   mov    r8, r8, LSR #32-10        /* grab low 10 bits  */
   ldr    r7, VTP_RECAL
   orr    r8, r7, r8
   ldr    r7, VTP_EN
   orr    r8, r7, r8
   str    r8, [r0]
 
 
   /* Wait for 33 VTP CLK cycles.  VRP operates at 27 MHz */
   ldr    r10, VTP_LOCK_COUNT
VTP1Lock:
   subs    r10, r10, $1
   bne    VTP1Lock
 
   ldr    r1, [r0]
   ldr    r2, VTP_MASK
   and    r2, r1, r2
   str    r2, [r0]
 
   ldr    r6, DFT_ENABLE
   mov    r10, $0
   str    r10, [r6]
 
   /*
    * Call board-specific lowlevel init.
    * That MUST be present and THAT returns
    * back to arch calling code with "mov pc, lr."
    */
   b    dv_board_init
 
.ltorg
 
_PINMUX0:
   .word    0x01c40000        /* Device Configuration Registers */
_PINMUX1:
   .word    0x01c40004        /* Device Configuration Registers */
 
_DEV_SETTING:
   .word    0x00000c1f
 
WAITCFG:
   .word    0x01e00004
WAITCFG_VAL:
   .word    0
ACFG3:
   .word    0x01e00014
ACFG3_VAL:
   .word    0x3ffffffd
ACFG4:
   .word    0x01e00018
ACFG4_VAL:
   .word    0x3ffffffd
ACFG5:
   .word    0x01e0001c
ACFG5_VAL:
   .word    0x3ffffffd
 
MDCTL_DDR2:
   .word    0x01c41a34
MDSTAT_DDR2:
   .word    0x01c41834
 
PTCMD:
   .word    0x01c41120
PTSTAT:
   .word    0x01c41128
 
EINT_ENABLE0:
   .word    0x01c48018
EINT_ENABLE1:
   .word    0x01c4801c
 
PSC_FLAG_CLEAR:
   .word    0xffffffe0
PSC_GEM_FLAG_CLEAR:
   .word    0xfffffeff
 
/* DDR2 MMR & CONFIGURATION VALUES, 162 MHZ clock */
DDRCTL:
   .word    0x200000e4
DDRCTL_VAL:
   .word    0x50006405
SDREF:
   .word    0x2000000c
SDREF_VAL:
   .word    0x000005c3
SDCFG:
   .word    0x20000008
SDCFG_VAL:
#ifdef    DDR_4BANKS
   .word    0x00178622
#elif defined DDR_8BANKS
   .word    0x00178632
#else
#error "Unknown DDR configuration!!!"
#endif
SDTIM0:
   .word    0x20000010
SDTIM0_VAL_162MHz:
   .word    0x28923211
SDTIM1:
   .word    0x20000014
SDTIM1_VAL_162MHz:
   .word    0x0016c722
VTPIOCR:
   .word    0x200000f0    /* VTP IO Control register */
DDRVTPR:
   .word    0x01c42030    /* DDR VPTR MMR */
VTP_MMR0:
   .word    0x201f
VTP_MMR1:
   .word    0xa01f
DFT_ENABLE:
   .word    0x01c4004c
VTP_LOCK_COUNT:
   .word    0x5b0
VTP_MASK:
   .word    0xffffdfff
VTP_RECAL:
   .word    0x08000
VTP_EN:
   .word    0x02000
CFGTEST:
   .word    0x80010000
MASK_VAL:
   .word    0x00000fff
 
/* GEM Power Up & LPSC Control Register */
MDCTL_GEM:
   .word    0x01c41a9c
MDSTAT_GEM:
   .word    0x01c4189c
 
/* For WDT reset chip bug */
P1394:
   .word    0x01c41a20
 
PLL_CLKSRC_MASK:
   .word    0xfffffeff    /* Mask the Clock Mode bit */
PLL_ENSRC_MASK:
   .word    0xffffffdf    /* Select the PLLEN source */
PLL_BYPASS_MASK:
   .word    0xfffffffe    /* Put the PLL in BYPASS */
PLL_RESET_MASK:
   .word    0xfffffff7    /* Put the PLL in Reset Mode */
PLL_PWRUP_MASK:
   .word    0xfffffffd    /* PLL Power up Mask Bit  */
PLL_DISABLE_ENABLE_MASK:
   .word    0xffffffef    /* Enable the PLL from Disable */
PLL_LOCK_COUNT:
   .word    0x2000
 
/* PLL1-SYSTEM PLL MMRs */
PLL1_CTL:
   .word    0x01c40900
PLL1_PLLM:
   .word    0x01c40910
 
/* PLL2-SYSTEM PLL MMRs */
PLL2_CTL:
   .word    0x01c40d00
PLL2_PLLM:
   .word    0x01c40d10
PLL2_DIV1:
   .word    0x01c40d18
PLL2_DIV2:
   .word    0x01c40d1c
PLL2_PLLCMD:
   .word    0x01c40d38
PLL2_PLLSTAT:
   .word    0x01c40d3c
PLL2_DIV_MASK:
   .word    0xffff7fff
 
MMARG_BRF0:
   .word    0x01c42010    /* BRF margin mode 0 (R/W)*/
MMARG_BRF0_VAL:
   .word    0x00444400
 
DDR2_START_ADDR:
   .word    0x80000000
DUMMY_VAL:
   .word    0xa55aa55a
#else /* CONFIG_SOC_DM644X */
   mov pc, lr
#endif