lyl19 发表于 2010-09-24 23:33

[mips] 疑惑mip-uclibc-gcc对一段汇编的编译

这个程序应该是一个小型的bootload, 我是用buildroot生成的mips交叉编译链,gcc-4.3.2binutils-2.19,编译的文件在一个mips虚拟机上跑
setup.S
.........
      la gp, _gp
........
它完成的功能是把rom的一块数据搬到ram去,gp是rom的初始地址, _gp是在linker script中指定的

ld_script
SECTIONS {
   .text : { *(.text) ; _etext = . ; }   
   .= 0xa0000000 + ( 0x100000 * 3 / 4 ) ; /* must match setup.S DATA_START */
   _gp = .;
    ......................
}

未link的setup.o的反汇编为
lw      gp,0(gp)
link后的setup.o反汇编为
lw      gp,64(gp)
而使用readelf -s setup.o可以看出_gp的值为a00c0000, 因为gp寄存器最初清0,所以这样导致gp寄存器的值不等于_gp,导致后面搬数据也失败了。

我很不理解为什么gcc要这样来编译,并且感觉还不能随便修改或去掉_gp这个变量。有没有哪位大侠赐教一下,谢谢

lyl19 发表于 2010-09-25 01:46

回复 1# lyl19


    加了一个.cpload $25就可以了,
   但我现在还不懂,什么时候需要用到gp来做重定位,假设汇编中某个变量我不想使用gp做重定位,该如何设置呢

EricFisher 发表于 2010-09-25 10:06

这个,也算作是约定吧。
页: [1]
查看完整版本: [mips] 疑惑mip-uclibc-gcc对一段汇编的编译