正文
1. 从某个中断开始INT 0X80中断,进入内核 ,调用函数就是system_call,接下来就是执行system_call
2. 五段论中的中断入口和中断出口以及schedule- 首先又压栈一些用户态的信息,
- 接下来就是具体去处理sys_fork,也就是中断要产生的效果,但是在执行sys_fork的时候可能引起切换,
- 接下来就是看当前PCB中的state是否等于0,如果不是那么就要进行调度,就是靠schedule,完成五端论中的中间三步
- 看它的时间片是否等于0,时间片用光了也要进行调度
- 最后就是执行中断返回的函数ret_from_sys_call,iret也就是从内核栈到用户栈的切换
- 下图,在ret_from_sys_call中,首先popl一些信息,就是和压栈的信息对应,然后就是iret
关于schedule - 调度的话首先要找下一个线程,这个在后面讲调度的时候详细说
- switch_to里面完成切换
- 把当前cpu中的所有指令放在当前TR指向的段中,也就是把当前执行的信息拍下来放到原tss中,
- 开始执行长跳转指令,
- 把TSS(n)指给TR,也就是把新tss里的信息扣到cpu上
关键三步骤: - INT中断 进入内核
- schedule的里的switch_to里的ljmp完成切换
- ret_from_sys_call里的iret中断出口
3. ThreadCreatetss是寄存器,TCB(线程控制块) 创建一个线程就是做出能切换的样子,核心就是上面切换时用到的tss 首先要有TCB,然后是内核栈,把tss做好就行了 copy_process函数在进程创建的fork函数中调用,主要完成进程数据结构,各种资源的初始化。初始化方式可以重新分配,也可以共享父进程资源,主要根据传入CLONE参数来确定。 - 申请内存空间,注意这是在内核中,用get_free_page(),而不是malloc
4. 如何执行我们想要的代码?从exec这个系统调用开始
exec函数提供了一个在进程中启动另一个程序执行的方法
5. 总结以上文章转载自网络
|