Linux-2.6.12-rc2
[safe/jmp/linux-2.6] / arch / cris / arch-v10 / lib / dram_init.S
1 /* $Id: dram_init.S,v 1.4 2003/09/22 09:21:59 starvik Exp $
2  * 
3  * DRAM/SDRAM initialization - alter with care
4  * This file is intended to be included from other assembler files
5  *
6  * Note: This file may not modify r9 because r9 is used to carry
7  *       information from the decompresser to the kernel
8  *
9  * Copyright (C) 2000, 2001 Axis Communications AB
10  *
11  * Authors:  Mikael Starvik (starvik@axis.com)  
12  * 
13  * $Log: dram_init.S,v $
14  * Revision 1.4  2003/09/22 09:21:59  starvik
15  * Decompresser is linked to 0x407xxxxx and sdram commands are at 0x000xxxxx
16  * so we need to mask off 12 bits.
17  *
18  * Revision 1.3  2003/03/31 09:38:37  starvik
19  * Corrected calculation of end of sdram init commands
20  *
21  * Revision 1.2  2002/11/19 13:33:29  starvik
22  * Changes from Linux 2.4
23  *
24  * Revision 1.13  2002/10/30 07:42:28  starvik
25  * Always read SDRAM command sequence from flash
26  *
27  * Revision 1.12  2002/08/09 11:37:37  orjanf
28  * Added double initialization work-around for Samsung SDRAMs.
29  *
30  * Revision 1.11  2002/06/04 11:43:21  starvik
31  * Check if mrs_data is specified in kernelconfig (necessary for MCM)
32  *
33  * Revision 1.10  2001/10/04 12:00:21  martinnn
34  * Added missing underscores.
35  *
36  * Revision 1.9  2001/10/01 14:47:35  bjornw
37  * Added register prefixes and removed underscores
38  *
39  * Revision 1.8  2001/05/15 07:12:45  hp
40  * Copy warning from head.S about r8 and r9
41  *
42  * Revision 1.7  2001/04/18 12:05:39  bjornw
43  * Fixed comments, and explicitely include config.h to be sure its there
44  *
45  * Revision 1.6  2001/04/10 06:20:16  starvik
46  * Delay should be 200us, not 200ns
47  *
48  * Revision 1.5  2001/04/09 06:01:13  starvik
49  * Added support for 100 MHz SDRAMs
50  *
51  * Revision 1.4  2001/03/26 14:24:01  bjornw
52  * Namechange of some config options
53  *
54  * Revision 1.3  2001/03/23 08:29:41  starvik
55  * Corrected calculation of mrs_data
56  *
57  * Revision 1.2  2001/02/08 15:20:00  starvik
58  * Corrected SDRAM initialization
59  * Should now be included as inline
60  *
61  * Revision 1.1  2001/01/29 13:08:02  starvik
62  * Initial version
63  * This file should be included from all assembler files that needs to
64  * initialize DRAM/SDRAM.
65  *
66  */
67
68 /* Just to be certain the config file is included, we include it here
69  * explicitely instead of depending on it being included in the file that
70  * uses this code.
71  */
72
73 #include <linux/config.h>
74
75         ;; WARNING! The registers r8 and r9 are used as parameters carrying
76         ;; information from the decompressor (if the kernel was compressed). 
77         ;; They should not be used in the code below.
78
79 #ifndef CONFIG_SVINTO_SIM       
80         move.d   CONFIG_ETRAX_DEF_R_WAITSTATES, $r0
81         move.d   $r0, [R_WAITSTATES]
82
83         move.d   CONFIG_ETRAX_DEF_R_BUS_CONFIG, $r0
84         move.d   $r0, [R_BUS_CONFIG]
85         
86 #ifndef CONFIG_ETRAX_SDRAM
87         move.d   CONFIG_ETRAX_DEF_R_DRAM_CONFIG, $r0
88         move.d   $r0, [R_DRAM_CONFIG]
89
90         move.d   CONFIG_ETRAX_DEF_R_DRAM_TIMING, $r0
91         move.d   $r0, [R_DRAM_TIMING]
92 #else
93         ;; Samsung SDRAMs seem to require to be initialized twice to work properly.
94         moveq    2, $r6 
95 _sdram_init:
96         
97         ; Refer to ETRAX 100LX Designers Reference for a description of SDRAM initialization
98         
99         ; Bank configuration
100         move.d   CONFIG_ETRAX_DEF_R_SDRAM_CONFIG, $r0
101         move.d   $r0, [R_SDRAM_CONFIG]
102
103         ; Calculate value of mrs_data 
104         ; CAS latency = 2 && bus_width = 32 => 0x40
105         ; CAS latency = 3 && bus_width = 32 => 0x60
106         ; CAS latency = 2 && bus_width = 16 => 0x20
107         ; CAS latency = 3 && bus_width = 16 => 0x30
108
109         ; Check if value is already supplied in kernel config
110         move.d   CONFIG_ETRAX_DEF_R_SDRAM_TIMING, $r2
111         and.d    0x00ff0000, $r2
112         bne      _set_timing
113         lsrq     16, $r2
114         
115         move.d   0x40, $r2       ; Assume 32 bits and CAS latency = 2
116         move.d   CONFIG_ETRAX_DEF_R_SDRAM_TIMING, $r1
117         move.d   $r1, $r3
118         and.d    0x03, $r1       ; Get CAS latency
119         and.d    0x1000, $r3     ; 50 or 100 MHz?
120         beq      _speed_50
121         nop
122 _speed_100:             
123         cmp.d    0x00, $r1      ; CAS latency = 2?
124         beq      _bw_check
125         nop
126         or.d     0x20, $r2      ; CAS latency = 3 
127         ba       _bw_check
128         nop
129 _speed_50:                      
130         cmp.d    0x01, $r1      ; CAS latency = 2?
131         beq      _bw_check
132         nop
133         or.d     0x20, $r2       ; CAS latency = 3
134 _bw_check:
135         move.d   CONFIG_ETRAX_DEF_R_SDRAM_CONFIG, $r1
136         and.d    0x800000, $r1  ; DRAM width is bit 23
137         bne      _set_timing
138         nop
139         lsrq     1, $r2         ;  16 bits. Shift down value.
140
141         ; Set timing parameters. Starts master clock
142 _set_timing:
143         move.d   CONFIG_ETRAX_DEF_R_SDRAM_TIMING, $r1
144         and.d    0x8000f9ff, $r1 ; Make sure mrs data and command is 0 
145         or.d     0x80000000, $r1        ; Make sure sdram enable bit is set
146         move.d   $r1, $r5
147         or.d     0x0000c000, $r1 ; ref = disable
148         lslq     16, $r2                ; mrs data starts at bit 16
149         or.d     $r2, $r1 
150         move.d   $r1, [R_SDRAM_TIMING]  
151                 
152         ; Wait 200us
153         move.d   10000, $r2
154 1:      bne      1b
155         subq     1, $r2
156         
157         ; Issue initialization command sequence
158         move.d   _sdram_commands_start, $r2
159         and.d    0x000fffff, $r2 ; Make sure commands are read from flash
160         move.d   _sdram_commands_end,  $r3
161         and.d    0x000fffff, $r3
162 1:      clear.d  $r4
163         move.b   [$r2+], $r4
164         lslq     9, $r4 ; Command starts at bit 9
165         or.d     $r1, $r4
166         move.d   $r4, [R_SDRAM_TIMING]
167         nop             ; Wait five nop cycles between each command
168         nop
169         nop
170         nop
171         nop
172         cmp.d    $r2, $r3
173         bne      1b
174         nop
175         move.d   $r5, [R_SDRAM_TIMING]
176         subq     1, $r6
177         bne      _sdram_init
178         nop
179         ba       _sdram_commands_end
180         nop
181
182 _sdram_commands_start:
183         .byte   3       ; Precharge
184         .byte   0       ; nop
185         .byte   2       ; refresh
186         .byte   0       ; nop
187         .byte   2       ; refresh
188         .byte   0       ; nop
189         .byte   2       ; refresh
190         .byte   0       ; nop
191         .byte   2       ; refresh
192         .byte   0       ; nop
193         .byte   2       ; refresh
194         .byte   0       ; nop
195         .byte   2       ; refresh
196         .byte   0       ; nop
197         .byte   2       ; refresh
198         .byte   0       ; nop
199         .byte   2       ; refresh
200         .byte   0       ; nop
201         .byte   1       ; mrs
202         .byte   0       ; nop 
203 _sdram_commands_end:            
204 #endif
205 #endif