如果从进程本身的角度来看,它只不过是一段执行中的代码,这样看起来它跟我们已经实现的代码没有本质的区别。可是,如果从操作系统角度来看,进程必须是可控制的,所以这就涉及到进程和操作系统之间执行的转换。因为CPU只有一个,同一时刻要么是客户进程在运行,要么是操作系统在运行。这个问题我们在后面的章节中还有更加详细的论述。不过我们现在应该清楚,如果实现进程,需要一种控制权转换机制,这种机制便是中断。
进程的控制权转换机制是通过中断实现的,更精确的来说,应该是时钟中断。而且添加中断处理,以后方便出现错误时进行调试。
几个程序之间的调用关系如下:
kernel.asm调用start.c的cstart()函数,移动GDT,设置IDT。
sgdt [gdt_ptr] ; cstart() 中将会用到 gdt_ptr
call cstart ; 在此函数中改变了gdt_ptr,让它指向新的GDT
lgdt [gdt_ptr] ; 使用新的GDT
lidt [idt_ptr]
start.c调用protect.c的init_prot()函数设置8259和处理器约定异常处理。
其实程序很简单,就是设置全局变量数据idt的值,然后通过kernel.asm的指令 lidt [idt_ptr]工作。