操作系统-核心级线程实现

操作系统-核心级线程实现_第1张图片

1. 从某个中断开始

操作系统-核心级线程实现_第2张图片

INT 0X80中断,进入内核 ,调用函数就是system_call,接下来就是执行system_call

2. 五段论中的中断入口和中断出口以及schedule

  1. 首先又压栈一些用户态的信息,
  2. 接下来就是具体去处理sys_fork,也就是中断要产生的效果,但是在执行sys_fork的时候可能引起切换,
  3. 接下来就是看当前PCB中的state是否等于0,如果不是那么就要进行调度,就是靠schedule,完成五端论中的中间三步
  4. 看它的时间片是否等于0,时间片用光了也要进行调度
  5. 最后就是执行中断返回的函数ret_from_sys_call,iret也就是从内核栈到用户栈的切换
  6. 下图,在ret_from_sys_call中,首先popl一些信息,就是和压栈的信息对应,然后就是iret

操作系统-核心级线程实现_第3张图片
操作系统-核心级线程实现_第4张图片

关于schedule

  1. 调度的话首先要找下一个线程,这个在后面讲调度的时候详细说
  2. switch_to里面完成切换
  3. 把当前cpu中的所有指令放在当前TR指向的段中,也就是把当前执行的信息拍下来放到原tss中,
  4. 开始执行长跳转指令,
  5. 把TSS(n)指给TR,也就是把新tss里的信息扣到cpu上

操作系统-核心级线程实现_第5张图片

关键三步骤:

  1. INT中断 进入内核
  2. schedule的里的switch_to里的ljmp完成切换
  3. ret_from_sys_call里的iret中断出口

3. ThreadCreate

tss是寄存器,TCB(线程控制块)

创建一个线程就是做出能切换的样子,核心就是上面切换时用到的tss

首先要有TCB,然后是内核栈,把tss做好就行了

copy_process函数在进程创建的fork函数中调用,主要完成进程数据结构,各种资源的初始化。初始化方式可以重新分配,也可以共享父进程资源,主要根据传入CLONE参数来确定。

操作系统-核心级线程实现_第6张图片

  1. 申请内存空间,注意这是在内核中,用get_free_page(),而不是malloc

操作系统-核心级线程实现_第7张图片
操作系统-核心级线程实现_第8张图片

4. 如何执行我们想要的代码?

从exec这个系统调用开始
exec函数提供了一个在进程中启动另一个程序执行的方法
操作系统-核心级线程实现_第9张图片
操作系统-核心级线程实现_第10张图片
操作系统-核心级线程实现_第11张图片

5. 总结

操作系统-核心级线程实现_第12张图片

你可能感兴趣的:(操作系统-核心级线程实现)