2005-04-16 15:20:36 -07:00
|
|
|
/*
|
|
|
|
* Copyright (C) Paul Mackerras 1997.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version
|
|
|
|
* 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* NOTE: this code runs in 32 bit mode and is packaged as ELF32.
|
|
|
|
*/
|
|
|
|
|
2005-08-07 20:24:38 -07:00
|
|
|
#include "ppc_asm.h"
|
2005-04-16 15:20:36 -07:00
|
|
|
|
|
|
|
.text
|
2006-01-13 21:04:06 -07:00
|
|
|
/* a procedure descriptor used when booting this as a COFF file */
|
|
|
|
_zimage_start_opd:
|
|
|
|
.long _zimage_start, 0, 0, 0
|
|
|
|
|
2005-10-28 17:46:49 -07:00
|
|
|
.globl _zimage_start
|
|
|
|
_zimage_start:
|
2006-01-13 21:04:06 -07:00
|
|
|
/* Work out the offset between the address we were linked at
|
|
|
|
and the address where we're running. */
|
2005-11-17 14:09:02 -07:00
|
|
|
bl 1f
|
2006-01-13 21:04:06 -07:00
|
|
|
1: mflr r0
|
2005-11-17 14:09:02 -07:00
|
|
|
lis r9,1b@ha
|
|
|
|
addi r9,r9,1b@l
|
2005-10-28 17:46:48 -07:00
|
|
|
subf. r0,r9,r0
|
2006-01-13 21:04:06 -07:00
|
|
|
beq 3f /* if running at same address as linked */
|
2005-10-28 17:46:48 -07:00
|
|
|
|
2006-01-13 21:04:06 -07:00
|
|
|
/* The .got2 section contains a list of addresses, so add
|
|
|
|
the address offset onto each entry. */
|
2005-10-28 17:46:48 -07:00
|
|
|
lis r9,__got2_start@ha
|
|
|
|
addi r9,r9,__got2_start@l
|
|
|
|
lis r8,__got2_end@ha
|
|
|
|
addi r8,r8,__got2_end@l
|
|
|
|
subf. r8,r9,r8
|
2005-11-17 14:09:02 -07:00
|
|
|
beq 3f
|
2005-10-28 17:46:48 -07:00
|
|
|
srwi. r8,r8,2
|
|
|
|
mtctr r8
|
|
|
|
add r9,r0,r9
|
2006-01-13 21:04:06 -07:00
|
|
|
2: lwz r8,0(r9)
|
2005-10-28 17:46:48 -07:00
|
|
|
add r8,r8,r0
|
|
|
|
stw r8,0(r9)
|
|
|
|
addi r9,r9,4
|
2005-11-17 14:09:02 -07:00
|
|
|
bdnz 2b
|
2005-10-28 17:46:48 -07:00
|
|
|
|
2006-01-13 21:04:06 -07:00
|
|
|
/* Do a cache flush for our text, in case OF didn't */
|
|
|
|
3: lis r9,_start@h
|
2005-10-28 17:46:48 -07:00
|
|
|
add r9,r0,r9
|
2005-04-16 15:20:36 -07:00
|
|
|
lis r8,_etext@ha
|
|
|
|
addi r8,r8,_etext@l
|
2005-10-28 17:46:48 -07:00
|
|
|
add r8,r0,r8
|
2005-11-17 14:09:02 -07:00
|
|
|
4: dcbf r0,r9
|
2005-04-16 15:20:36 -07:00
|
|
|
icbi r0,r9
|
|
|
|
addi r9,r9,0x20
|
|
|
|
cmplwi 0,r9,8
|
2005-11-17 14:09:02 -07:00
|
|
|
blt 4b
|
2005-04-16 15:20:36 -07:00
|
|
|
sync
|
|
|
|
isync
|
|
|
|
|
2005-10-28 17:46:50 -07:00
|
|
|
mr r6,r1
|
2005-04-16 15:20:36 -07:00
|
|
|
b start
|
|
|
|
|