操作系统-核心级线程实现
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. ThreadCreate
tss是寄存器,TCB(线程控制块)
创建一个线程就是做出能切换的样子,核心就是上面切换时用到的tss
首先要有TCB,然后是内核栈,把tss做好就行了
copy_process函数在进程创建的fork函数中调用,主要完成进程数据结构,各种资源的初始化。初始化方式可以重新分配,也可以共享父进程资源,主要根据传入CLONE参数来确定。
- 申请内存空间,注意这是在内核中,用get_free_page(),而不是malloc
4. 如何执行我们想要的代码?
从exec这个系统调用开始
exec函数提供了一个在进程中启动另一个程序执行的方法
5. 总结
作者:山丘!
-------------------------------------------
你闻讯而来,我大喜过望,我在这等你,你又在哪呢?喜欢的话加一个“关注”呗!
如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!