A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

正文

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. 总结
以上文章转载自网络

1 个回复

倒序浏览
有问题联系小优:DKA-2018
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马