linux内核分析第二周

网易云课堂linux内核分析第二周

20135103                王海宁

《Linux内核分析》MOOC课程http://mooc.study.163.com/course/USTC-1000029000

操作系统的核心功能就是:进程调度和中断机制,通过与硬件的配合实现多任务处理,再加上上层应用软件的支持,最终变成可以使用户可以很容易操作的计算机系统,

my_timer_handler 函数会被内核周期性的调用,每调用1000次,就去将全局变量my_need_sched的值修改为1,通知正在执行的进程执行调度程序my_schedule。在my_schedule函数中,完成进程的切换。进程的切换分两种情况,一种情况是下一个进程没有被调度过,另外一种情况是下一个进程被调度过,可以通过下一个进程的state知道其状态。进程切换依然是通过内联汇编代码实现,无非是保存旧进程的eip和堆栈,将新进程的eip和堆栈的值存入对应的寄存器中。原来那个mypcb.h定义了 Thread 结构体,用于存储当前进程中正在执行的线程的ip和sp,PCB结构体中的各个字段含义如下

pid:进程号

state:进程状态,在模拟系统中,所有进程控制块信息都会被创建出来,其初始化值就是-1,如果被调度运行起来,其值就会变成0

stack:进程使用的堆栈

thread:当前正在执行的线程信息

task_entry:进程入口函数

next:指向下一个PCB,模拟系统中所有的PCB是以链表的形式组织起来的。

mypcb.h

linux内核分析第二周

mymain.c

linux内核分析第二周

linux内核分析第二周

linux内核分析第二周

myinterrupt.c

linux内核分析第二周

linux内核分析第二周

linux内核分析第二周

linux内核分析第二周

my_timer_handler 函数会被内核周期性的调用,每调用1000次,就去将全局变量my_need_sched的值修改为1,通知正在执行的进程执行调度程序my_schedule。在my_schedule函数中,完成进程的切换。进程的切换分两种情况,一种情况是下一个进程没有被调度过,另外一种情况是下一个进程被调度过,可以通过下一个进程的state知道其状态。进程切换依然是通过内联汇编代码实现,无非是保存旧进程的eip和堆栈,将新进程的eip和堆栈的值存入对应的寄存器中。原来那个mypcb.h定义了 Thread 结构体,用于存储当前进程中正在执行的线程的ip和sp,PCB结构体中的各个字段含义如下

pid:进程号

state:进程状态,在模拟系统中,所有进程控制块信息都会被创建出来,其初始化值就是-1,如果被调度运行起来,其值就会变成0

stack:进程使用的堆栈

thread:当前正在执行的线程信息

task_entry:进程入口函数

next:指向下一个PCB,模拟系统中所有的PCB是以链表的形式组织起来的。

主要的数一下核心代码

首先,解读一下程序的核心代码

void __init my_start_kernel(void)
{
int i = 0;
while(1)
{
i++;
if(i%100000 == 0)
printk(KERN_NOTICE "my_start_kernel here %d ",i);

}
}

这是内核代码的启动函数,C语言编写,循环部分是每执行100000次,输出一条语句。

void my_timer_handler(void)
{
printk(KERN_NOTICE " >>>>>>>>6666>>>>>>>>>my_timer_handler here<<<<<<<<<<<<<<<<<< ");
}

这段代码是被时间中断时调用,每次被调用的时候输出一条语句。

然后对编写的代码进行整合,然后整合到Linux Kernel-3.9.4中。

下载mykernel_for_linux3.9.4sc.patch,再下载linux kernel-3.9.4,make 最后安装QEMU,运行kernel。

linux内核分析第二周
上一篇:初涉JavaScript模式 (3) : 字面量


下一篇:Javascript - ExtJs - Ext.form.Panel组件