最近在写一个x86下的boot loader,由于是基于legacy bios的,所以要使用real mode编程,编写汇编文件,用as编译生成目标文件,再用ld链接器手动链接,把代码段和数据段指定到合适的位置。
而这个“合适的位置”,引发了我的思考。
代码如下供参考。
这份代码如果编译的时候,把代码段和数据段指定到了0x1234,结果,用objdump来看一下,效果如下。
第一行没有显示出来是因为ljmp这个指令在ia32下是不支持的,所以解析错误,我们看下机器码即可,实际上这个指令的机器码是 ea 39 12 c0 07,为什么是39,是因为第一条指令正好占用4个字节,所以next的标号就是1234+5=1239,这就是指定代码段基址的结果。
原文链接:https://blog.csdn.net/ross1206/article/details/97130226