OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [rtos/] [rtems/] [c/] [src/] [lib/] [libbsp/] [powerpc/] [helas403/] [flashentry/] [flashentry.S] - Blame information for rev 30

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 30 unneback
/*  flashentry.s
2
 *
3
 *  This file contains the entry code for RTEMS programs starting
4
 *  directly from Flash.
5
 *
6
 *  Author:     Thomas Doerfler 
7
 *              IMD Ingenieurbuero fuer Microcomputertechnik
8
 *
9
 *  COPYRIGHT (c) 1998 by IMD
10
 *
11
 *  Changes from IMD are covered by the original distributions terms.
12
 *  This file has been derived from the papyrus BSP:
13
 *
14
 *  This file contains the entry veneer for RTEMS programs
15
 *  stored in Papyrus' flash ROM.
16
 *
17
 *  Author:     Andrew Bray 
18
 *
19
 *  COPYRIGHT (c) 1995 by i-cubed ltd.
20
 *
21
 *  To anyone who acknowledges that this file is provided "AS IS"
22
 *  without any express or implied warranty:
23
 *      permission to use, copy, modify, and distribute this file
24
 *      for any purpose is hereby granted without fee, provided that
25
 *      the above copyright notice and this notice appears in all
26
 *      copies, and that the name of i-cubed limited not be used in
27
 *      advertising or publicity pertaining to distribution of the
28
 *      software without specific, written prior permission.
29
 *      i-cubed limited makes no representations about the suitability
30
 *      of this software for any purpose.
31
 *
32
 *  $Id: flashentry.S,v 1.2 2001-09-27 12:00:36 chris Exp $
33
 */
34
 
35
#include "asm.h"
36
#include 
37
 
38
/*----------------------------------------------------------------------------
39
 * Reset_entry.
40
 *---------------------------------------------------------------------------*/
41
#if PPC_ASM == PPC_ASM_ELF
42
        .section .reset,"ax",@progbits
43
        /* this section MUST be located at absolute address 0xFFFFFFFC
44
           or last word of EPROM */
45
#else
46
        .csect .text[PR]
47
#endif
48
 
49
        ba      flash_entry /* this is the first instruction after reset */
50
 
51
        .previous
52
 
53
/*----------------------------------------------------------------------------
54
 * ROM Vector area.
55
 *---------------------------------------------------------------------------*/
56
#if PPC_ASM == PPC_ASM_ELF
57
        .section .entry,"ax",@progbits
58
#else
59
        .csect .text[PR]
60
#endif
61
        PUBLIC_VAR (flash_entry)
62
SYM (flash_entry):
63
        bl      .startup /* call startup, link reg points to base_addr */
64
base_addr:
65
/*----------------------------------------------------------------------------
66
 * Parameters from linker
67
 *---------------------------------------------------------------------------*/
68
toc_pointer:
69
#if PPC_ASM == PPC_ASM_ELF
70
        .long   s.got
71
#else
72
        .long   TOC[tc0]
73
#endif
74
text_length:
75
        .long   text.size
76
text_addr:
77
        .long   text.start
78
copy_src:
79
        .long   copy.src
80
copy_length:
81
        .long   copy.size
82
copy_dest:
83
        .long   copy.dest
84
bss_length:
85
        .long   bss.size
86
bss_addr:
87
        .long   bss.start
88
stack_top:
89
        .long   stack.end
90
 
91
/*----------------------------------------------------------------------------
92
 * from Reset_entry.
93
 *---------------------------------------------------------------------------*/
94
.startup:
95
        /* Get start address, r1 points to label base_addr */
96
        mflr    r1
97
 
98
        /* Set up Bank regs, cache etc. */
99
        /* set up bank register BR0 for Flash-EPROM:
100
         * NOTE: bank size should stay 1MByte, this is standard size
101
         *       after RESET
102
         * base addr = Fffxxxxx -> 0b11111111........................
103
         * bank size = 1 MByte  -> 0b........000..................... (std)
104
         * bank use  = readonly -> 0b...........01...................
105
         * seq. fill = targ frst-> 0b.............0..................
106
         * burst mode= enable   -> 0b..............1.................
107
         * bus width = 8 bit    -> 0b...............00...............
108
         * ready pin = disable  -> 0b.................0..............
109
         * first wait= 2 clocks -> 0b..................0010..........
110
         * burst wait= 2 clocks -> 0b......................10........
111
         * CSon time = 0 clocks -> 0b........................0.......
112
         * OEon time = 0 clocks -> 0b.........................0......
113
         * WBon time = 1 clocks -> 0b..........................1.....
114
         * WBoff time= 0 clocks -> 0b...........................0....
115
         * Hold time = 1 clocks -> 0b............................001.
116
         * ram type  = SRAM(ign)-> 0b...............................1
117
         * value                   0b11111111000010100000101000100011
118
         *                         0x   F   F   0   A   0   A   2   3
119
         */
120
        lis     r2,0xFF0A
121
        ori     r2,r2,0x0A23
122
 
123
        mtdcr   br0,r2 /* write to DCR BR0 */
124
 
125
 
126
        /*--------------------------------------------------------------------
127
         * test various RAM configurations (from big to small per bank)
128
         *------------------------------------------------------------------*/
129
        /*--------------------------------------------------------------------
130
         * test RAM config 16 MByte (1x4Mx32Bit)
131
         *------------------------------------------------------------------*/
132
        /* set up bank register BR7 for DRAM:
133
         * base addr = 000xxxxx -> 0b00000000........................
134
         * bank size = 16MByte  -> 0b........100.....................
135
         * bank use  = readwrite-> 0b...........11...................
136
         * seq. fill = targ.frst-> 0b.............0..................
137
         * early RAS = disabled -> 0b..............0.................
138
         * bus width = 32bit    -> 0b...............10...............
139
         * adr mux   = internal -> 0b.................0..............
140
         * RAS to CAS= 2 clocks -> 0b..................1.............
141
         * Alt. Rfrsh= normal   -> 0b...................0............
142
         * page mode = enabled  -> 0b....................1...........
143
         * first wait= 1 clocks -> 0b.....................01.........
144
         * burst wait= 1 clocks -> 0b.......................01.......
145
         * precharge = 1 clocks -> 0b.........................0......
146
         * RAS Rfrsh = 2 clocks -> 0b..........................1.....
147
         * Rfrsh Itvl= 512 clks -> 0b...........................1000.
148
         * ram type  = DRAM     -> 0b...............................0
149
         * value                   0b00000000100110010010101010110000
150
         *                         0x   0   0   9   9   2   A   B   0
151
         */
152
        lis     r2,0x0099
153
        ori     r2,r2,0x2AB0
154
        mtdcr   br7,r2 /* write to DCR BR7*/
155
 
156
        lis     r2,0x0000       /* start address = 0x00000000 */
157
        lis     r3,0x0100       /* size  16 MB   = 0x01000000 */
158
        bl      ramacc          /* test memory accessibility  */
159
        cmpi    0,0,r4,0        /* memory ok? else test smaller size */
160
        bne     ramcfgt18
161
 
162
        /*--------------------------------------------------------------------
163
         * test RAM config 32 MByte (2x4Mx32Bit)
164
         *------------------------------------------------------------------*/
165
        /* set up bank register BR7 like above
166
         * set up bank register BR6 for DRAM:
167
         * base addr = 010xxxxx -> 0b00010000........................
168
         * bank size = 16MByte  -> 0b........100..................... (for now)
169
         * bank use  = readwrite-> 0b...........11...................
170
         * seq. fill = targ.frst-> 0b.............0..................
171
         * early RAS = disabled -> 0b..............0.................
172
         * bus width = 32bit    -> 0b...............10...............
173
         * adr mux   = internal -> 0b.................0..............
174
         * RAS to CAS= 2 clocks -> 0b..................1.............
175
         * Alt. Rfrsh= normal   -> 0b...................0............
176
         * page mode = enabled  -> 0b....................1...........
177
         * first wait= 1 clocks -> 0b.....................01.........
178
         * burst wait= 1 clocks -> 0b.......................01.......
179
         * precharge = 1 clocks -> 0b.........................0......
180
         * RAS Rfrsh = 2 clocks -> 0b..........................1.....
181
         * Rfrsh Itvl= 512 clks -> 0b...........................1000.
182
         * ram type  = DRAM     -> 0b...............................0
183
         * value                   0b00010000100110010010101010110000
184
         *                         0x   1   0   9   9   2   A   B   0
185
         */
186
        lis     r2,0x1099
187
        ori     r2,r2,0x2AB0
188
        mtdcr   br6,r2          /* write to DCR BR6*/
189
 
190
        lis     r2,0x0100       /* start address = 0x01000000 */
191
        lis     r3,0x0100       /* size  16 MB   = 0x01000000 */
192
        bl      ramacc          /* test memory accessibility  */
193
        cmpi    0,0,r4,0        /* memory ok? else test smaller size */
194
        beq     ramcfgok        /* ok, we found configuration... +/
195
 
196
        lis     r2,0x0000       /* disable BR6, config not ok */
197
        mtdcr   br6,r2          /* write to DCR BR6*/
198
        b       ramcfgok        /* and finish configuration */
199
 
200
ramcfgt18:
201
        /*--------------------------------------------------------------------
202
         * test RAM config 8 MByte (1x2Mx32Bit)
203
         *------------------------------------------------------------------*/
204
        /* set up bank register BR7 for DRAM:
205
         * base addr = 000xxxxx -> 0b00000000........................
206
         * bank size =  8MByte  -> 0b........011.....................
207
         * bank use  = readwrite-> 0b...........11...................
208
         * seq. fill = targ.frst-> 0b.............0..................
209
         * early RAS = disabled -> 0b..............0.................
210
         * bus width = 32bit    -> 0b...............10...............
211
         * adr mux   = internal -> 0b.................0..............
212
         * RAS to CAS= 2 clocks -> 0b..................1.............
213
         * Alt. Rfrsh= normal   -> 0b...................0............
214
         * page mode = enabled  -> 0b....................1...........
215
         * first wait= 1 clocks -> 0b.....................01.........
216
         * burst wait= 1 clocks -> 0b.......................01.......
217
         * precharge = 1 clocks -> 0b.........................0......
218
         * RAS Rfrsh = 2 clocks -> 0b..........................1.....
219
         * Rfrsh Itvl= 512 clks -> 0b...........................1000.
220
         * ram type  = DRAM     -> 0b...............................0
221
         * value                   0b00000000011110010010101010110000
222
         *                         0x   0   0   7   9   2   A   B   0
223
         */
224
        lis     r2,0x0079
225
        ori     r2,r2,0x2AB0
226
        mtdcr   br7,r2         /* write to DCR BR7           */
227
 
228
        lis     r2,0x0000       /* start address = 0x00000000 */
229
        lis     r3,0x0080       /* size   8 MB   = 0x00800000 */
230
        bl      ramacc          /* test memory accessibility  */
231
        cmpi    0,0,r4,0        /* memory ok? else test smaller size */
232
        bne     ramcfgt14
233
 
234
        /*--------------------------------------------------------------------
235
         * test RAM config 16 MByte (2x2Mx32Bit)
236
         *------------------------------------------------------------------*/
237
        /* set up bank register BR7 like above
238
         * set up bank register BR6 for DRAM:
239
         * base addr = 008xxxxx -> 0b00001000........................
240
         * bank size = 08MByte  -> 0b........011..................... (for now)
241
         * bank use  = readwrite-> 0b...........11...................
242
         * seq. fill = targ.frst-> 0b.............0..................
243
         * early RAS = disabled -> 0b..............0.................
244
         * bus width = 32bit    -> 0b...............10...............
245
         * adr mux   = internal -> 0b.................0..............
246
         * RAS to CAS= 2 clocks -> 0b..................1.............
247
         * Alt. Rfrsh= normal   -> 0b...................0............
248
         * page mode = enabled  -> 0b....................1...........
249
         * first wait= 1 clocks -> 0b.....................01.........
250
         * burst wait= 1 clocks -> 0b.......................01.......
251
         * precharge = 1 clocks -> 0b.........................0......
252
         * RAS Rfrsh = 2 clocks -> 0b..........................1.....
253
         * Rfrsh Itvl= 512 clks -> 0b...........................1000.
254
         * ram type  = DRAM     -> 0b...............................0
255
         * value                   0b00001000011110010010101010110000
256
         *                         0x   0   8   7   9   2   A   B   0
257
         */
258
        lis     r2,0x0879
259
        ori     r2,r2,0x2AB0
260
        mtdcr   br6,r2          /* write to DCR BR6*/
261
 
262
        lis     r2,0x0080       /* start address = 0x00800000 */
263
        lis     r3,0x0080       /* size   8 MB   = 0x00800000 */
264
        bl      ramacc          /* test memory accessibility  */
265
        cmpi    0,0,r4,0        /* memory ok? else test smaller size */
266
        beq     ramcfgok        /* ok, we found configuration... +/
267
 
268
        lis     r2,0x0000       /* disable BR6, config not ok */
269
        mtdcr   br6,r2          /* write to DCR BR6*/
270
        b       ramcfgok        /* and finish configuration */
271
 
272
ramcfgt14:
273
        /*--------------------------------------------------------------------
274
         * test RAM config 4 MByte (1x1Mx32Bit)
275
         *------------------------------------------------------------------*/
276
        /* set up bank register BR7 for DRAM:
277
         * base addr = 000xxxxx -> 0b00000000........................
278
         * bank size =  4MByte  -> 0b........010.....................
279
         * bank use  = readwrite-> 0b...........11...................
280
         * seq. fill = targ.frst-> 0b.............0..................
281
         * early RAS = disabled -> 0b..............0.................
282
         * bus width = 32bit    -> 0b...............10...............
283
         * adr mux   = internal -> 0b.................0..............
284
         * RAS to CAS= 2 clocks -> 0b..................1.............
285
         * Alt. Rfrsh= normal   -> 0b...................0............
286
         * page mode = enabled  -> 0b....................1...........
287
         * first wait= 1 clocks -> 0b.....................01.........
288
         * burst wait= 1 clocks -> 0b.......................01.......
289
         * precharge = 1 clocks -> 0b.........................0......
290
         * RAS Rfrsh = 2 clocks -> 0b..........................1.....
291
         * Rfrsh Itvl= 512 clks -> 0b...........................1000.
292
         * ram type  = DRAM     -> 0b...............................0
293
         * value                   0b00000000010110010010101010110000
294
         *                         0x   0   0   5   9   2   A   B   0
295
         */
296
        /*
297
         * FIXME: this is the minimum size supported, should test and
298
         * report error, when failed
299
         */
300
        lis     r2,0x0059
301
        ori     r2,r2,0x2AB0
302
        mtdcr   br7,r2 /* write to DCR BR7*/
303
 
304
        /*--------------------------------------------------------------------
305
         * test RAM config  8 MByte (2x1Mx32Bit)
306
         *------------------------------------------------------------------*/
307
        /* set up bank register BR7 like above
308
         * set up bank register BR6 for DRAM:
309
         * base addr = 004xxxxx -> 0b00000100........................
310
         * bank size =  4MByte  -> 0b........010..................... (for now)
311
         * bank use  = readwrite-> 0b...........11...................
312
         * seq. fill = targ.frst-> 0b.............0..................
313
         * early RAS = disabled -> 0b..............0.................
314
         * bus width = 32bit    -> 0b...............10...............
315
         * adr mux   = internal -> 0b.................0..............
316
         * RAS to CAS= 2 clocks -> 0b..................1.............
317
         * Alt. Rfrsh= normal   -> 0b...................0............
318
         * page mode = enabled  -> 0b....................1...........
319
         * first wait= 1 clocks -> 0b.....................01.........
320
         * burst wait= 1 clocks -> 0b.......................01.......
321
         * precharge = 1 clocks -> 0b.........................0......
322
         * RAS Rfrsh = 2 clocks -> 0b..........................1.....
323
         * Rfrsh Itvl= 512 clks -> 0b...........................1000.
324
         * ram type  = DRAM     -> 0b...............................0
325
         * value                   0b00000100010110010010101010110000
326
         *                         0x   0   4   5   9   2   A   B   0
327
         */
328
        lis     r2,0x0459
329
        ori     r2,r2,0x2AB0
330
        mtdcr   br6,r2          /* write to DCR BR6*/
331
 
332
        lis     r2,0x0040       /* start address = 0x00400000 */
333
        lis     r3,0x0040       /* size   4 MB   = 0x00400000 */
334
        bl      ramacc          /* test memory accessibility  */
335
        cmpi    0,0,r4,0        /* memory ok? else test smaller size */
336
        beq     ramcfgok        /* ok, we found configuration... +/
337
 
338
        lis     r2,0x0000       /* disable BR6, config not ok */
339
        mtdcr   br6,r2          /* write to DCR BR6*/
340
        b       ramcfgok        /* and finish configuration */
341
 
342
ramcfgok:
343
        /*--------------------------------------------------------------------
344
         * init the DRAM where STACK+ DATA+ BBS will be placed.  If this is OK
345
         * we will return here.
346
         *-------------------------------------------------------------------*/
347
        bl      rom2ram
348
 
349
        /* clear caches */
350
        addi    r2,0,PPC_I_CACHE/PPC_CACHE_ALIGNMENT
351
        mtctr   r2              /* count the loops needed... */
352
        xor     r2,r2,r2        /* start at adr zero */
353
icinvlp:
354
        iccci   0,r2
355
        addi    r2,r2,PPC_CACHE_ALIGNMENT
356
        bdnz    icinvlp
357
 
358
        addi    r2,r0,PPC_D_CACHE/PPC_CACHE_ALIGNMENT
359
        mtctr   r2              /* count the loops needed... */
360
        xor     r2,r2,r2        /* start at adr 0 */
361
dcinvlp:
362
        dccci   0,r2
363
        addi    r2,r2,PPC_CACHE_ALIGNMENT
364
        bdnz    dcinvlp
365
        /*--------------------------------------------------------------------
366
         * Enable two 128MB cachable regions.
367
         * FEPROM is cachable    at 0xFFF00000..0xFFFFFFFF
368
         * DRAM   is cachable    at 0x00000000..0x00FFFFFF
369
         * FEPROM is noncachable at 0x7FF00000..0x7FFFFFFF
370
         * DRAM   is noncachable at 0x80000000..0x80FFFFFF
371
         *-------------------------------------------------------------------*/
372
        addis   r2,r0,0x8000
373
        addi    r2,r2,0x0001
374
 
375
        mtspr   iccr, r2               /* ICCR */
376
        mtspr   dccr, r2               /* DCCR */
377
 
378
        .extern SYM(__vectors)
379
 
380
        lis     r2,__vectors@h          /* set EVPR exc. vector prefix */
381
        mtspr   evpr,r2
382
 
383
        lis     r2,0x0000
384
        ori     r2,r2,0x0000
385
        mtmsr   r2                      /* set default msr           */
386
        lis     r2,0x0000               /* do not allow critical IRQ */
387
        ori     r2,r2,0x0000
388
        mtdcr   exier, r2               /* disable all external IRQs */
389
 
390
        addi    r2,r0,-1                /* r2 = 0xffffffff               */
391
        mtdcr   exisr, r2               /* clear all pendingdisable IRQs */
392
 
393
        /*--------------------------------------------------------------------
394
         * C_setup.
395
         *-------------------------------------------------------------------*/
396
 
397
        lwz     r2,toc_pointer-base_addr(r1)       /* set r2 to toc */
398
        lwz     r1,stack_top-base_addr(r1)         /* set r1 to stack_top */
399
 
400
        addi    r1,r1,-56                /* start stack at data_addr - 56 */
401
        addi    r3,r0,0x0                /* clear r3 */
402
        stw     r3, 0(r1)                /* Clear stack chain */
403
        stw     r3, 4(r1)
404
        stw     r3, 8(r1)
405
        stw     r3, 12(r1)
406
        .extern SYM (boot_card)
407
        b       SYM (boot_card)          /* call the first C routine */
408
 
409
/*----------------------------------------------------------------------------
410
 * Rom2ram.
411
 *---------------------------------------------------------------------------*/
412
rom2ram:
413
        lwz     r2,copy_dest-base_addr(r1)    /* start of data set by loader */
414
        lwz     r3,copy_length-base_addr(r1)  /* data length                 */
415
        rlwinm  r3,r3,30,0x3FFFFFFF           /* form length/4               */
416
        mtctr   r3                            /* set ctr reg                 */
417
        /*--------------------------------------------------------------------
418
         * Calculate offset of data in image.
419
         *-------------------------------------------------------------------*/
420
        lwz     r4,copy_src-base_addr(r1)      /* get start of copy area */
421
move_data:
422
        lswi    r6,r4,0x4               /* load r6 */
423
        stswi   r6,r2,0x4               /* store r6 */
424
        addi    r4,r4,0x4               /* update r4 */
425
        addi    r2,r2,0x4               /* update r2 */
426
        bdnz    move_data               /* decrement counter and loop */
427
        /*--------------------------------------------------------------------
428
         * Data move finished, zero out bss.
429
         *-------------------------------------------------------------------*/
430
        lwz     r2,bss_addr-base_addr(r1) /* start of bss set by loader */
431
        lwz     r3,bss_length-base_addr(r1)       /* bss length */
432
        rlwinm. r3,r3,30,0x3FFFFFFF     /* form length/4 */
433
        beqlr                           /* no bss */
434
        mtctr   r3                      /* set ctr reg */
435
        xor     r6,r6,r6                /* r6 = 0 */
436
clear_bss:
437
        stswi   r6,r2,0x4               /* store r6 */
438
        addi    r2,r2,0x4               /* update r2 */
439
        bdnz    clear_bss               /* decrement counter and loop */
440
        blr                             /* return */
441
 
442
/*----------------------------------------------------------------------------
443
 * ramacc test accessibility of RAM
444
 * input:       r2 = start address, r3 = length (in byte)
445
 * output:      r4 = 0 -> ok, !=0 -> fail
446
 *---------------------------------------------------------------------------*/
447
ramacc:
448
        xor     r4,r4,r4                /* r4 = 0                    */
449
        stw     r4,0(r2)                /* init ram at start address */
450
        addi    r4,r0,0x04              /* set start shift           */
451
ramaccf1:
452
        cmp     0,0,r4,r3               /* compare with length       */
453
        bge     ramaccfx                /* r4 >= r3? then finished   */
454
        add     r5,r4,r2                /* get next address to fill  */
455
        stw     r4,0(r5)                /* store new pattern         */
456
        add     r4,r4,r4                /* r4 = r4*2                 */
457
        b       ramaccf1                /* and then next loop        */
458
 
459
ramaccfx:
460
        lwz     r4,0(r2)                /* get memory at start adr  */
461
        blr
462
 
463
 
464
#if PPC_ABI == PPC_ABI_POWEROPEN
465
        DESCRIPTOR (startup)
466
#endif
467
 
468
 
469
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.