使用Assembly和c联合写kernel的时候,新的理解

来源:互联网 发布:亿乐社区系统v2.0源码 编辑:程序博客网 时间:2024/06/02 18:09

对unsigned char gdt_ptr[6]数组的操作

汇编中:sgdt  [gdt_ptr]--------[]符号使得汇编的时候将其汇编成  sgdt   ds:gdt_ptr。这样在保护模式下才能访问到正确的内存地址。

C中:想取出gdt_ptr[0-1]两个字节的数字并组合成16位的short整数。*(u16 *)(&gdt_ptr[0])同样的地址,只要改变下指针类型,再*p就可以了,这样是在告诉编译器一下子取出2个数据。


在写kernel的过程中,我在c中调用了disp_str, mem_cpy
这些函数都是自己用汇编写的,并适用于保护模式下。
虽然这些函数是用汇编写的,可是这丝毫不影响在C中的调用,首先汇编的函数写出来之后,会用global导出,然后会在概念上形成一个C的声明的形式。比如上面的disp_str的声明是void disp_str(char* str);但其实汇编代码中并没有这种c的声明,但它会认为当你调用我的时候,确实已经将参数push到栈中了。

原创粉丝点击