Linux内核——进程调度以及进程切换过程

进程调度的时机


明确一点:一般来说,进程调度都是发生在进程外的(即进程运行的时候会持续执行代码),当执行代码中断跳到其他代码段(系统调用函数,中断处理函数等)时会触发进程调度函数(schedule)使得进程(此时在内核态)得以切换,切换的实际是两个进程的内核堆栈的切换。

一般有四个进程调度的时机
1. 用户调用特点系统调用主动让出CPU
2. 中断处理函数返回用户态时固定时机点
3. 内核线程主动调用schedule
4. 中断处理函数主动调用schedule

中断类型


  1. 硬中断(Interrupt)
    CPU两个引脚(可屏蔽中断,不可屏蔽中断),高电平表示有中断。类似时钟,键盘等会使用硬中断方式。
  2. 软中断(Exception)
    • 故障(Fault)
    • 退出(Abort)
    • 陷阱(Trap)
      系统调用属于该类软中断

进程上下文切换


进程上下文包括

  • 用户地址空间:程序代码段,数据段,用户堆栈等内存信息
  • 控制信息:进程描述符、内核堆栈
  • 硬件上下文:寄存器

关键寄存器切换

  • CR3 地址空间寄存器
  • ESP
  • EIP

thread_struct thread

每个进程描述符都有一个类型thread_stuct的thread字段,该字段在进程被切出去的时候保存了当时硬件上下文信息

切换步骤

  1. 切换CR3,切换后两个进程相同的虚拟地址对应了不物理地址
  2. 切换内核堆栈和硬件上下文信息

代码分析

schedele函数调用context_switch进行上下文切换

context_switch(struct rq *rq, struct task_struct *prev, struct task_struct *next)
{
  switch_mm(oldmm,mm,next) //内存CR3寄存器切换
  switch_to(prev, next, prev) //内核堆栈和硬件上下文切换
}
switch_mm(struct mm_struct *prev, struct mm_struct *next, struct task_struct *tsk)
{
  load_cr3(newxt->pgd);
}
//简化代码
switch_to(prev,next last)
{
  pushfl
  pushl %ebp //0

  prev->thread.sp = %esp //1
  %esp = next->thread.sp //2
  prev->thread.ip = $1f //3
  
  push next->thread.ip //4
  jmp _switch_to //5

  1f:
  popl %ebp //6
  popfl
    
  
}

重点讲解switch_to函数

0

将当前进程(prev)的硬件上下文和内核堆栈地址保存在当前进程(prev)内核堆栈中,当当前进程(prev)再次被调度的时候进行恢复

1

保存内核堆栈地址到当前进程(prev)的thread结构体中,上面有提到

2

将当前CPU的ESP寄存器(堆栈寄存器)切换为下一个进程(next)的内核堆栈地址。由于进程的内核堆栈和进程控制块(PCB,即进程描述符)保存在连续的8K内存空间,因此当CPU的ESP寄存器切换到下一个进程(next)的内核堆栈地址时,可以理解为当前已经切换到了next进程。

3

将上一个进程(prev)的thread.ip设置为1f的地址,这是当该进程再次被调度时开始执行的代码行。

4&5

在next进程的内核堆栈中压入thread.ip的代码段地址(即该进程在上次被调度出去在第三步保存的地址),然后使用jmp _switch_to来控制CPU的EIP寄存器跳转到1f的代码段地址。可以将这两步(4、5)理解为将地址装载然后控制EIP跳转的功能。

6

此时进入进程恢复阶段,对应第0步。恢复进程的堆栈,硬件上下文信息。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 227,882评论 6 531
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 98,208评论 3 414
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 175,746评论 0 373
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 62,666评论 1 309
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 71,477评论 6 407
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 54,960评论 1 321
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 43,047评论 3 440
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 42,200评论 0 288
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 48,726评论 1 333
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 40,617评论 3 354
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 42,807评论 1 369
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 38,327评论 5 358
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 44,049评论 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 34,425评论 0 26
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 35,674评论 1 281
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 51,432评论 3 390
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 47,769评论 2 372

推荐阅读更多精彩内容