今天终于跑起来了自己OS的mbr,还是很激动人心的。学习了16位实模式下jmp和call的各种用法,来总结一下:
call (near) 0xabcd 相对近调用 后面的地址是相对的 -32768~32767
call [addr] 间接绝对近调用 地址为绝对,但是是在某个寄存器或内存中
call (far) 段基址:偏移 直接绝对远调用 跨段
call far [addr] 间接绝对远调用 跨段 地址在内存中 前2个字节是段基址 后2个字节是偏移(addr dw start,0)
jmp (short) addr 相对短转移 -128-127
jmp (near) addr 相对近转移 -32768-32767
jmp (near) ax 间接绝对近转移 地址在寄存器或内存中
jmp (far) 段基址:偏移 直接绝对远转移 跨段
jmp far [addr] 间接绝对远转移 地址在内存中
感觉call和jmp其实没什么区别,就是有没有ret的关系 自己对于大端字节序 小端字节序的理解还不够到位,要好好看看
这些内容是从《操作系统真象还原》这本书上总结下来的,今天是我第一天写总结,希望能够坚持下去!
标签:addr,far,jmp,绝对,2024,call,字节 From: https://www.cnblogs.com/jiehuan/p/18119848