linux内核初始化

1.系统的引导和初始化:

Linux 系统的引导有好几种方式:常见的有 Lilo, Loadin引导和Linux的自举引导 (bootsect-loader),而后者所对应源程序为arch/i386/boot/bootsect.S,它为实模式的汇编程序,无论是哪种引导方式,最后都要跳转到 arch/i386/Kernel/setup.S, 


setup.S主要是  进行时模式下的初始化,为系统进入保护模式做准备;


此后,系统执行 arch/i386/kernel/head.S (对经压缩后存放的内核要先执行 arch/i386/boot/compressed/head.S); 


head.S 中定义的一段汇编程序setup_idt ,它负责建立一张256项的 idt 表(Interrupt Descriptor Table),此表保存着所有自陷和中断的入口地址;其中  

包括系统调用总控程序 system_call 的入口地址;当然,除此之外,head.S还要做一些其他的初始化工作; 





2.

系统初始化后运行的第一个内核程序asmlinkage void __init start_kernel(void) 定义在 /usr/src/linux/init/main.c中


它通过调用usr/src/linux/arch/i386/kernel/traps.c 中的一个函数  void __init trap_init(void) 把各自陷和中断服务程序的入口地址设置到 idt 表中,其中系统调用总控程序  system_cal就是中断服务程序之一;


void __init trap_init(void) 函数则通过调用一个宏  set_system_gate(SYSCALL_VECTOR,&system_call); 把系统调用总控程序的入口挂在中断0x80上;  


其中SYSCALL_VECTOR是定义在 /usr/src/linux/arch/i386/kernel/irq.h中的一个常量0x80; 而 system_call 即为中断总控程序的入口地址;


中断总控程序用汇编语言定义在/usr/src/linux/arch/i386/kernel/entry.S中;  




3.

中断总控程序主要负责保存处理机执行系统调用前的状态,检验当前调用是否合法, 并根据系统调用向量,使处理机跳转到保存在 sys_call_table 表中的相应系统服务例程的入口; 从系统服务例程返回后恢复处理机状态退回用户程序;  


而系统调用向量则定义在/usr/src/linux/include/asm-386/unistd.h 中;

sys_call_table 表定义在 /usr/src/linux/arch/i386/kernel/entry.S 中; 

同时在 /usr/src/linux/include/asm-386/unistd.h  中也定义了系统调用的用户编程接口;  





4.

由此可见 , linux 的系统调用也象 dos 系统的 int 21h 中断服务, 

它把0x80 中断作为总的入口, 然后 转到保存在 sys_call_table 表中的各种中断服务例程的入口地址 , 形成各种不同的中断服务;  



由以上源代码分析可知, 要增加一个系统调用就必须在 sys_call_table 表中增加一项 , 并在其中保存好自己 的系统服务例程的入口地址,然后重新编译内核,当然,系统服务例程是必不可少的。


结语:当然对于庞大复杂的 linux 内核而言,一篇文章远远不够,而且与系统调用相关的代码也只是内核中极其 微小的一部分;但重要的是方法、掌握好的分析方法;所以上的分析只是起个引导的作用,而正真的分析还有待于我们自己的努力。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值