]> git.ipfire.org Git - people/ms/u-boot.git/blame - board/dnp1110/memsetup.S
* Code cleanup:
[people/ms/u-boot.git] / board / dnp1110 / memsetup.S
CommitLineData
fe8c2806
WD
1/*
2 * Memory Setup stuff - taken from blob memsetup.S
3 *
4 * Copyright (C) 1999 2000 2001 Erik Mouw (J.A.K.Mouw@its.tudelft.nl) and
5 * Jan-Derk Bakker (J.D.Bakker@its.tudelft.nl)
6 *
7 * See file CREDITS for list of people who contributed to this
8 * project.
9 *
10 * This program is free software; you can redistribute it and/or
11 * modify it under the terms of the GNU General Public License as
12 * published by the Free Software Foundation; either version 2 of
13 * the License, or (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
22 * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
23 * MA 02111-1307 USA
24 */
25
26
dc7c9a1a
WD
27#include "config.h"
28#include "version.h"
fe8c2806
WD
29
30
31/* some parameters for the board */
32
33MEM_BASE: .long 0xa0000000
34MEM_START: .long 0xc0000000
35
dc7c9a1a
WD
36#define MDCNFG 0x00
37#define MDCAS00 0x04 /* CAS waveform rotate reg 0 */
38#define MDCAS01 0x08 /* CAS waveform rotate reg 1 bank */
39#define MDCAS02 0x0C /* CAS waveform rotate reg 2 bank */
40#define MDREFR 0x1C /* DRAM refresh control reg */
8bde7f77 41#define MDCAS20 0x20 /* CAS waveform rotate reg 0 bank */
dc7c9a1a
WD
42#define MDCAS21 0x24 /* CAS waveform rotate reg 1 bank */
43#define MDCAS22 0x28 /* CAS waveform rotate reg 2 bank */
44#define MECR 0x18 /* Expansion memory (PCMCIA) bus configuration register */
45#define MSC0 0x10 /* static memory control reg 0 */
46#define MSC1 0x14 /* static memory control reg 1 */
47#define MSC2 0x2C /* static memory control reg 2 */
48#define SMCNFG 0x30 /* SMROM configuration reg */
49
50mdcas00: .long 0x5555557F
51mdcas01: .long 0x55555555
52mdcas02: .long 0x55555555
53mdcas20: .long 0x5555557F
54mdcas21: .long 0x55555555
55mdcas22: .long 0x55555555
56mdcnfg: .long 0x0000B25C
57mdrefr: .long 0x007000C1
58mecr: .long 0x10841084
59msc0: .long 0x00004774
60msc1: .long 0x00000000
61msc2: .long 0x00000000
62smcnfg: .long 0x00000000
fe8c2806
WD
63
64/* setting up the memory */
65
66.globl memsetup
67memsetup:
fe8c2806 68
dc7c9a1a 69 ldr r0, MEM_BASE
fe8c2806
WD
70
71 /* Set up the DRAM */
72
dc7c9a1a
WD
73 /* MDCAS00 */
74 ldr r1, mdcas00
75 str r1, [r0, #MDCAS00]
fe8c2806 76
dc7c9a1a
WD
77 /* MDCAS01 */
78 ldr r1, mdcas01
79 str r1, [r0, #MDCAS01]
fe8c2806 80
dc7c9a1a
WD
81 /* MDCAS02 */
82 ldr r1, mdcas02
83 str r1, [r0, #MDCAS02]
fe8c2806 84
dc7c9a1a
WD
85 /* MDCAS20 */
86 ldr r1, mdcas20
87 str r1, [r0, #MDCAS20]
88
89 /* MDCAS21 */
90 ldr r1, mdcas21
91 str r1, [r0, #MDCAS21]
92
93 /* MDCAS22 */
94 ldr r1, mdcas22
95 str r1, [r0, #MDCAS22]
96
97 /* MDREFR */
98 ldr r1, mdrefr
99 str r1, [r0, #MDREFR]
fe8c2806
WD
100
101 /* Set up PCMCIA space */
102 ldr r1, mecr
103 str r1, [r0, #MECR]
104
dc7c9a1a
WD
105 /* Setup the flash memory and other */
106 ldr r1, msc0
107 str r1, [r0, #MSC0]
fe8c2806 108
dc7c9a1a
WD
109 ldr r1, msc1
110 str r1, [r0, #MSC1]
111
112 ldr r1, msc2
113 str r1, [r0, #MSC2]
114
115 ldr r1, smcnfg
116 str r1, [r0, #SMCNFG]
117
118 /* MDCNFG */
119 ldr r1, mdcnfg
120 bic r1, r1, #0x00000001
121 str r1, [r0, #MDCNFG]
122
123 /* Load something to activate bank */
124 ldr r2, MEM_START
fe8c2806 125.rept 8
dc7c9a1a 126 ldr r1, [r2]
fe8c2806
WD
127.endr
128
dc7c9a1a
WD
129 /* MDCNFG */
130 ldr r1, mdcnfg
131 orr r1, r1, #0x00000001
132 str r1, [r0, #MDCNFG]
133
fe8c2806
WD
134 /* everything is fine now */
135 mov pc, lr