搁置了几天,继续我们的操作系统,今天我们的主题是引入C语言,毕竟有了C语言这个工具,开发就便捷了很多,我们C语言依然使用GCC编译器,现在我们有几个事情没有完成,中断没有打开,段选择子没有设置,先把中断搁置一下,把段选择子分配了。
一、段选择子segment selector的分配
在start_protect这个函数中,暂时分配给ds段二号全局描述符,给ss分配三号全局描述符,这里赘述一下寄存器操作方面的知识,可能有些知识是8086的,用在386上不太正确,恳请改正。
寄存器寻址的方式,因为汇编用的不多,寄存器寻址每次都是最不熟练的,这里给我自己总结一下:
1. 立即寻址:立即数寻址
2.寄存器寻址:用寄存器寻址
3.直接寻址:直接从内存中取数据,前三个都很简单,后边的还能hold住么?
4.寄存器间接寻址:80386以上cpu可以使用esp之外其他所有通用寄存器,其中ebp的默认段是ss,其他所有的默认段都是ds
5.寄存器相对寻址:80386以上cpu可以使用esp之外其他所有通用寄存器,其中ebp的默认段是ss,其他所有的默认段都是ds
6.基址变址寻址:基址寄存器ebx ebp,变址寄存器除了esp都可以用,带有ebp时缺省段是ss,其他情况都是ds
7.基址变址寻址相对寻址:基址寄存器ebx ebp,变址寄存器除了esp都可以用,带有ebp时缺省段是ss,其他情况都是ds(6.7.的知识还是基于8086的,不知道80386有没有改进)
另外在 AT&T 汇编格式中,内存操作数的寻址方式是section:disp(base, index, scale)
32位线性地址下物理地址的计算方式是disp + base + index * scale
干货就这些,够用了,看代码
start_protect:
.code32
movw $0x0010, %ax
movw %ax, %ds
movw $0x0018, %ax
movw %ax, %s