最近在学习一个risc-v相关的项目,在开始实验时发现了一个比较怪异的事情,
在两个汇编文件中都有一个同样的语句
la t0,var
运行以后,发现第一个汇编文件中得到的是var的物理地址0x80008000,
而第二个运行后t0的值为var的虚拟地址0xffffffe000008000.
开始百思不得其解,后来查看反汇编代码发现,第一个文件的la语句被翻译为
ffffffe000000008: 00008297 auipc t0,0x8
ffffffe00000000c: ff828293 addi t0,t0,-8 # ffffffe000008000 <var>
而第2条语句被翻译为
ffffffe000000014: 00003297 auipc t0,0x3
ffffffe000000018: 04c2b283 ld t0,76(t0) # ffffffe000003060 <_GLOBAL_OFFSET_TABLE_+0x30>.
第一种翻译方式正是我所需要的.而第二种翻译方式则是先建立一个符号表,然后在这个表中的某一项存储了
var的虚拟地址.
再经仔细检查发现,第二个文件的编译时,多了一个选项-fPIE,导致所有的符号都被翻译为绝对地址.
去掉这个选项重新编译,问题解决.