2017-2018-1 20179219《Linux内核原理与分析》第九周作业

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2017-2018-1 20179219《Linux内核原理与分析》第九周作业相关的知识,希望对你有一定的参考价值。

一、学习笔记:

1.中断处理过程:包括时钟中断、I/O中断、系统调用和异常。直接调用schedule()函数,在队列中找到进程并分配CPU或返回用户态时根据need_resched标记调用schedule()。

2. 内核线程只有内核态没有用户态,可以直接调用schedule()进行进程之间的切换,也可以在中断处理过程中进行调度。用户态进程无法实现主动调度只能在中断处理过程中调度。

3.内核级别:ring0~3

4.进程上下文包含了进程执行所需要的信息

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

5.schedule()函数选择一个新进程运行并调用context_switch进行上下文的切换。

6.挂起CPU上执行的进程和中断时保存现场的操作并不相同,中断前后是在同一个进程上下文中,只是由用户态转向内核态执行。

7关键代码:

  context_switch(rq, prev, next); //进程上下文切换

  switch_to(pre,next,prev) //切换堆栈和寄存器  

8.内存映射

技术分享图片

9.深入理解ls命令执行过程

技术分享图片

二、代码分析

switch_to函数:

#define switch_to(prev, next, last) //prev指向当前进程,next指向被调度的进程                                   
do {                                                                              
      /*                              
  * Context-switching clobbers all registers, so we clobber  
   * them explicitly, via unused output variables.     
   * (EAX and EBP is not listed because EBP is saved/restored  
   * explicitly for wchan access and EAX is the return value of   
   * __switch_to())                     
  */ unsigned long ebx, ecx, edx, esi, edi; asm volatile("pushfl\\n\\t" //把prev进程的flag保存到prev进程的内核堆栈中 "pushl %%ebp\\n\\t" //把prev进程的基址ebp保存到prev进程的内核堆栈中 "movl %%esp,%[prev_sp]\\n\\t"//把prev进程的内核栈esp保存到prev->thread.sp中 "movl %[next_sp],%%esp\\n\\t"//esp指向next进程的内核堆栈栈顶(next->thread.sp) "movl $1f,%[prev_ip]\\n\\t"//把"1:\\t"地址赋给prev->thread.ip,当prev进程下次被switch_to切回来时,从"1:\\t"处执行,即往后执行"popl %%ebp\\n\\t"和"popfl\\n" "pushl %[next_ip]\\n\\t"//把next->thread.ip压入next进程的内核堆栈栈顶 __switch_canary "jmp __switch_to\\n"//执行__switch_to()函数,完成硬件上下文切换 "1:\\t" "popl %%ebp\\n\\t" "popfl\\n" /* output parameters */ : [prev_sp] "=m"(prev->thread.sp), [prev_ip] "=m"(prev->thread.ip), "=a" (last), /* clobbered output registers: */ "=b" (ebx), "=c"(ecx), "=d" (edx), "=S" (esi), "=D"(edi) __switch_canary_oparam /* input parameters: */ : [next_sp] "m" (next->thread.sp), [next_ip] "m" (next->thread.ip), /* regparm parameters for __switch_to():*/ [prev] "a" (prev), [next] "d" (next) __switch_canary_iparam : /* reloaded segment registers */ "memory"); } while (0)

 三、课本学习思考

复习了操作系统中的cache的概念,以及多线程、操作系统内核处理的方式等。三级页表转换是地址转换的核心

技术分享图片







以上是关于2017-2018-1 20179219《Linux内核原理与分析》第九周作业的主要内容,如果未能解决你的问题,请参考以下文章

2017-2018-1 20179219 《Linux内核原理与分析》第三周作业

2017-2018-1 20179219《Linux内核原理与分析》第五周作业

2017-2018-1 20179219《Linux内核原理与分析》第二周作业

20179219 《Linux内核原理与分析》第一周学习笔记

Linu计划书

linu运算