d382cc6c5a
If (edata-address & 3) != (end-address & 3), my own code cause infinity loop. Fixed it.
156 lines
3.7 KiB
ArmAsm
156 lines
3.7 KiB
ArmAsm
/* $NetBSD: srt0.s,v 1.2 2004/01/05 15:31:03 nonaka Exp $ */
|
|
|
|
/*
|
|
* Copyright (C) 1996-1999 Cort Dougan (cort@fsmlasb.com).
|
|
* Copyright (C) 1996-1999 Gary Thomas (gdt@osf.org).
|
|
* Copyright (C) 1996-1999 Paul Mackeras (paulus@linuxcare.com).
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions and the following disclaimer.
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
* documentation and/or other materials provided with the distribution.
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
* must display the following acknowledgement:
|
|
* This product includes software developed by TooLs GmbH.
|
|
* 4. The name of TooLs GmbH may not be used to endorse or promote products
|
|
* derived from this software without specific prior written permission.
|
|
*
|
|
* THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
|
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
|
* IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
|
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
|
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
|
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
*/
|
|
|
|
#define MSR_IP (1<<6)
|
|
|
|
#define HID0_DCI (1<<10)
|
|
#define HID0_ICFI (1<<11)
|
|
#define HID0_DCE (1<<14)
|
|
#define HID0_ICE (1<<15)
|
|
|
|
.text
|
|
|
|
.globl _start
|
|
_start:
|
|
bl start
|
|
start:
|
|
mr 11,3 /* Save pointer to residual/board data */
|
|
li 3,MSR_IP /* Establish default MSR value */
|
|
mtmsr 3
|
|
isync
|
|
|
|
mflr 7
|
|
bl flush_icache
|
|
mfspr 3,1008
|
|
lis 4,~(HID0_ICE|HID0_DCE)@h
|
|
ori 4,4,~(HID0_ICE|HID0_DCE)@l
|
|
andc 3,3,4
|
|
mtspr 1008,3
|
|
mtlr 7
|
|
|
|
/*
|
|
* check if we need to relocate ourselves to the link addr or were we
|
|
* loaded there to begin with -- Cort
|
|
*/
|
|
lis 4,_start@h
|
|
ori 4,4,_start@l
|
|
mflr 3
|
|
subi 3,3,4 /* we get the nip, not the ip of the branch */
|
|
mr 8,3
|
|
cmpw 3,4
|
|
bne relocate
|
|
b start_ldr
|
|
|
|
/*
|
|
* no matter where we're loaded, move ourselves to -Ttext address
|
|
*/
|
|
relocate:
|
|
lis 4,_start@h
|
|
ori 4,4,_start@l
|
|
lis 5,end@h
|
|
ori 5,5,end@l
|
|
addi 5,5,3 /* Round up - just in case */
|
|
sub 5,5,4 /* Compute # longwords to move */
|
|
srwi 5,5,2
|
|
mtctr 5
|
|
subi 3,3,4 /* Set up for loop */
|
|
subi 4,4,4
|
|
2:
|
|
lwzu 5,4(3)
|
|
stwu 5,4(4)
|
|
bdnz 2b
|
|
lis 3,start_ldr@h
|
|
ori 3,3,start_ldr@l
|
|
mtlr 3 /* Easiest way to do an absolute jump */
|
|
blr
|
|
start_ldr:
|
|
mr 9,1 /* Save old stack pointer */
|
|
lis 1,.stack@h
|
|
ori 1,1,.stack@l
|
|
addi 1,1,4096
|
|
li 2,0x000F
|
|
andc 1,1,2
|
|
mr 3,11 /* arg1: residual/board data */
|
|
mr 4,8 /* arg2: loadaddr */
|
|
bl boot
|
|
hang:
|
|
b hang
|
|
|
|
/*
|
|
* Execute
|
|
* run(startsym, endsym, args, bootinfo, entry)
|
|
*/
|
|
.globl run
|
|
run:
|
|
mtctr 7 /* Entry point */
|
|
bctr
|
|
|
|
/*
|
|
* Flush instruction cache
|
|
*/
|
|
.globl flush_icache
|
|
flush_icache:
|
|
mflr 5
|
|
bl flush_dcache
|
|
mfspr 4,1008
|
|
li 4,0
|
|
ori 4,4,HID0_ICE|HID0_ICFI
|
|
or 3,3,4
|
|
mtspr 1008,3
|
|
andc 3,3,4
|
|
ori 3,3,HID0_ICE
|
|
mtspr 1008,3
|
|
mtlr 5
|
|
blr
|
|
|
|
/*
|
|
* Flush data cache
|
|
*/
|
|
.globl flush_dcache
|
|
flush_dcache:
|
|
lis 3,0x1000@h
|
|
ori 3,3,0x1000@l
|
|
li 4,1024
|
|
mtctr 4
|
|
1:
|
|
lwz 4,0(3)
|
|
addi 3,3,32
|
|
bdnz 1b
|
|
blr
|
|
|
|
/*
|
|
* local stack
|
|
*/
|
|
.comm .stack,8192,4
|