summaryrefslogtreecommitdiff
path: root/cpu/mips
diff options
context:
space:
mode:
authorVlad Lungu <vlad.lungu@windriver.com>2008-05-05 14:04:00 +0300
committerWolfgang Denk <wd@denx.de>2008-05-05 13:24:12 +0200
commit0f8c62a14b523c56874ebcb67c1a16c99aad48b3 (patch)
treee09f3f2b8fa1cb239e5422584f9ab2c4100e4564 /cpu/mips
parent7c0773fde6100b61be2558cb5d8c442a3194aecb (diff)
Allow building mips versions with ELDK 3.1.1
.gpword works only with local symbols on certain binutils versions Signed-off-by: Vlad Lungu <vlad.lungu@windrvier.com>
Diffstat (limited to 'cpu/mips')
-rw-r--r--cpu/mips/start.S9
1 files changed, 6 insertions, 3 deletions
diff --git a/cpu/mips/start.S b/cpu/mips/start.S
index 6e1a78ceac4..947128dd813 100644
--- a/cpu/mips/start.S
+++ b/cpu/mips/start.S
@@ -345,7 +345,8 @@ relocate_code:
jr t0
nop
- .gpword _GLOBAL_OFFSET_TABLE_ /* _GLOBAL_OFFSET_TABLE_ - _gp */
+ .word _gp
+ .word _GLOBAL_OFFSET_TABLE_
.word uboot_end_data
.word uboot_end
.word num_got_entries
@@ -358,8 +359,10 @@ in_ram:
* generated by GNU ld. Skip these reserved entries from relocation.
*/
lw t3, -4(t0) /* t3 <-- num_got_entries */
- lw t4, -16(t0) /* t4 <-- (_GLOBAL_OFFSET_TABLE_ - _gp) */
- add t4, t4, gp /* t4 now holds _GLOBAL_OFFSET_TABLE_ */
+ lw t4, -16(t0) /* t4 <-- _GLOBAL_OFFSET_TABLE_ */
+ lw t5, -20(t0) /* t5 <-- _gp */
+ sub t4, t5 /* compute offset*/
+ add t4, t4, gp /* t4 now holds relocated _GLOBAL_OFFSET_TABLE_ */
addi t4, t4, 8 /* Skipping first two entries. */
li t2, 2
1: