手把手教你做北邮操作系统小学期实验一——Linux启动过程优化2

接上一章 手把手教你做北邮操作系统小学期实验一——Linux启动过程优化1

5.实验步骤:

内核态启动优化

一、多个init函数比较
  1. 在/usr/src/linux-2.4目录下,能得到Linux源代码(内核开发包)。
    这里写图片描述

  2. 修改linux/init/main.c,在所有的需要检测的代码段添加条件编译TIME_TEST常量。测试的代码段包括console_init(),vfs_caches_init,和pci_init()等等。
    源代码(原代码)
    这里写图片描述

添加#define TIME_TEST
这里写图片描述

添加

#ifdef  TIME_TEST  #include <linux/time.h> 
struct timeval gettime_before, gettime_after; #endif
//gettime_before函数调用前时间和gettime_after调用后时间

这里写图片描述

在380多行添加
do_gettimeofday(&gettime_before);
do_gettimeofday(&gettime_after);和一个打印时间的函数
//添加在console_init();函数的前后
这里写图片描述

在420多行添加
do_gettimeofday(&gettime_before);
do_gettimeofday(&gettime_after);和一个打印时间的函数
//添加在vfs_caches_init();函数的前后
这里写图片描述

在510多行添加
do_gettimeofday(&gettime_before);
do_gettimeofday(&gettime_after);和一个打印时间的函数
//添加在pci_init();函数的前后
这里写图片描述

添加do_initcalls()函数里的,注意do_initcalls()函数前后不添加,而是在代码里添加,在460多行左右
这里写图片描述

在rest_init()函数里
do_gettimeofday(&gettime_before);
do_gettimeofday(&gettime_after);和一个打印时间的函数这和之前的样。
同理可得。

  1. 修改完以后,编译内核。make mrproper清除源码树
    这里写图片描述

  2. make oldconfig生成现有.config文件
    这里写图片描述

  3. make menuconfig配置内核(需要安装ncurses-devel,安装ncurses-devel又需要安装yum,有的电脑需要安装,有的不需要安装)可以在网上找一个ncurses的tar.gz的包
    我找的是ncurses-5.7.tar.gz
    首先

tar -zxvf ncurses-5.7.tar.gz//解压
cd ncurses-5.7
./configure
make
make install //对它进行编译

然后 make menuconfig
这里写图片描述

  1. make dep//生成依赖关系
    这里写图片描述

  2. make bzImage //编译内核

这里写图片描述

  1. make modules//编译模块
    这里写图片描述

  2. make modules_install//安装模块
    这里写图片描述

  3. make install//安装内核
    这里写图片描述

离胜利不远了。

  1. init 6//重启 选那个2.4.20-8custom
    这里写图片描述
    这里写图片描述
    这里写图片描述

由上图可以知道console_init()函数花费:156 mircosecond
这里写图片描述

vfs_caches_init()函数花费:156 mircosecond
这里写图片描述

pci_init()函数花费:79878 mircosecond
这里写图片描述

do_initcalls()函数花费:4 second -550203 mircosecond//记得do_initcalls()用到函数的地址费时最多的那一个,但是开机画面显示的是一部分,可以等一下用代码查看。
rest_init()函数花费:71 mircosecond
这里写图片描述

dmesg | grep “second”
这里写图片描述
这里写图片描述
这里写图片描述

这里写图片描述

综上所述,c036e138花费4 second -550203 mircosecond,用System.map查看c036e138是initcall_ide_init

下一章 手把手教你做北邮操作系统小学期实验一——Linux启动过程优化3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值