`
mqzhuang
  • 浏览: 187728 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

在Ubuntu10.10上升级内核到2.6.36使用systemtap

阅读更多

     一直在 linux 平台上做开发工作已经几年了,但对 linux 内核都没有认真研究过,个人对 linux 的了解都停留在系统 api 的使用层面,对 linux 的底层设计了解甚少。在身边的同事,不凡有熟悉 linux 内核的高手,在他们的耳濡目染下,也激发了自己研究 linux 内核的激情,所以在自己的小黑上装上了 vmware Ubuntu10.10 下面我将分享一下个人在搭建环境和学习 linux 内核的一些初步准备工作。

 

        我学习 linux 内核分成两个方面,理论学习和实践。理论学习主要偏重理论书籍的阅读,短时间内,我囫囵吞枣的扫描了如下的介绍 linux 内核的书籍,《 linux 内核完全注释》,《 linux 内核修炼之道》,《 linux 内核设计与实现》第二版,《深入理解 linux 内核》第三版,《 独辟蹊径品内核 -- LINUX内核源代码导读 》,还有一本与内核关系不是太大,《 程序员的自我修养— 链接、装载与库》,这些书真的挺理论的,看完了,脑子居然没有留下多少东西,唯一留下的就是感觉 liunx 内核好深奥,真 NB 。这肯定不是我想要的学习效果,我需要的是在学习理论的同时,不断地实践,尽量多的理解自己感兴趣的一些技术设计细节。虽然看这些理论书籍比较枯燥,但通过读这些书籍,我宏观上了解了 linux 内核的架构,知道了内核的学习方法,避免在实践时走弯路。个人对文件系统和网络系统比较感兴趣,但经历有限,只会深入研究其中一个系统,兼顾整个内核系统其它模块的学习。我的案头摆着几本以后要重点学习的书籍,《深入理解 linux 内核》第三版, 《深入理解 linux 架构》,《内核网络栈源代码情景分析》,希望这些理论书籍能提升自己对 linux 内核的了解。

 

        下面谈谈我在内核学习中的一些初期实践工作,碰到不少问题,但还是耐心的一个个解决了。首先去 http://www.kernel.org/ 下载了最新的 linux 内核 2.6.36 让后就开始风风火火的准备看代码了,真的是初生牛犊不怕虎,啃了两天代码,也没有看明白一个小模块,看来盲目的学习不起作用,还是得补习点理论知识,于是借来几本理论书籍开始啃,在理论学习过程中,了解了 x86 的架构,汇编相关知识,内存管理,进程调度,文件系统等初步知识,似乎理解得更多一点了,前期学习的理论知识应该准备得差不多了,应该开始详细分析一些感兴趣的代码了。万事开头难,还得从搭建学习环境开始。

 

        一番准备后,在小黑上装上了 vmware ,并装上了 Ubuntu10.10 Ubuntu10.10 自带的内核是 2.6.35.22 ,我的学习目标是 2.6.36 所以首先是要升级内核。编译内核前对编译选项做了一些简单裁剪配置,主要打开了一些用于调试的开关。然后就是一番漫长的等待编译过程,最后 make install 。重启,选择 2.6.36 内核启动, oops ,启动不成功,哪里出问题了?重新进入原来的 2.6.35 内核启动系统,查看 /boot/ 目录,有 initrd.img-2.6.35-22-generic 这个 image ,但却没有 initrd.img-2.6. 36 这个 image ,难道 vmware 需要内核支持 ramdisk 才能启动?我查看了编译内核的配置,“

Initial RAM filesystem and RAM disk (initramfs/initrd) support ”这个选项也选上了,那为什么编译的时候没有生成 initrd.img-2.6. 36 这个 image 呢?经过一番研究,没找到原因,但发现用 make-kpkg 可以编译出这个 image ,于是安装 make-kpkg

sudo apt-get install make-kpkg 。

     然后进入 linux 源代码的文件夹运行:

make -kpkg --initrd binary-arch

 

经过一段时间后,在源代码的上层目录生成了三个 deb 的安装文件。

linux-headers-2.6.36_2.6.36-10.00.Custom_i386.deb
linux-image-2.6.36_2.6.36-10.00.Custom_i386.deb
linux-image-2.6.36-dbg_2.6.36-10.00.Custom_i386.deb

 

分别安装这个三个包:

 

sudo dpkg -i l inux-headers-2.6.36_2.6.36-10.00.Custom_i386.deb
sudo dpkg -i l inux-image-2.6.36_2.6.36-10.00.Custom_i386.deb
sudo dpkg -i linux-image-2.6.36-dbg_2.6.36-10.00.Custom_i386.deb 
 

        安装完成后重启系统,选择 2.6.36 内核进入系统,啊,成功启动,兴奋一把。尝试运行系统一些命令,似乎也正常。升级内核该告一个段落了吧,好戏还在后头。

 

       Systemtap 是学习内核一个必不可少的工具,它不仅可以侦测内核空间的相关信息,还可以侦测用户空间的信息,是研究内核源代码,调试系统性能的一个必备工具。在 Ubuntu 下如何安装 Systemtap 请参考:

http://sourceware.org/systemtap/wiki/SystemtapOnUbuntu

       

        运行 sudo apt-get install systemta p 安装 Systemtap 。由于在升级内核的时候已经安装了相应的 debug 信息,

至此内核追踪已经可以执行,但module的信息还需要多做些工作

sudo apt-get install elfutils

for file in `find /usr/lib/debug -name '*.ko' -print`
do
      buildid=`eu-readelf -n $file| grep Build.ID: | awk '{print $3}'`
      dir=`echo $buildid | cut -c1-2`
      fn=`echo $buildid | cut -c3-`
      mkdir -p /usr/lib/debug/.build-id/$dir
      ln -s $file /usr/lib/debug/.build-id/$dir/$fn
      ln -s $file /usr/lib/debug/.build-id/$dir/${fn}.debug
Done

 

到这里应该能运行 stap 执行 hello Word 的程序了吧,先试运行一个简单的

sudo stap -ve 'probe begin { log("hello world") exit() }'

 

运行出错了, error:‘param_ops_int64_t’ undeclared here (not in a function)

这是什么情况,先不管,再试运行一个脚本

sudo stap -c df -e 'probe syscall.* { if (target()==pid()) log(name." ".argstr) }'

 

          任然遇到上面的错误,在网上搜了一番,原来这是 Systemtap 2.6.36 内核支持不好,有这个 bug Systemtap 官方网站说这个 bug 已经修复,使用最新的 Systemtap 就好了。于是下面的网站下载最新的 Systemtap 的源代码,编译安装。

http://sources.redhat.com/systemtap/ftp/snapshots/

 

然后运行 hello Word 脚本,

 

Pass 1: parsed user script and 75 library script(s) using 16300virt/12368res/1628shr kb, in 920usr/3670sys/4627real ms.

Pass 2: analyzed script: 1 probe(s), 2 function(s), 0 embed(s), 0 global(s) using 16564virt/12892res/1688shr kb, in 170usr/260sys/526real ms.

Pass 3: translated to C into "/tmp/stapa7GBqo/stap_5d4a1f5ec0c40981d6d84405569c6127_669.c" using 16564virt/13116res/1896shr kb, in 150usr/130sys/277real ms.

Pass 4: compiled C into "stap_5d4a1f5ec0c40981d6d84405569c6127_669.ko" in 8880usr/18060sys/27864real ms.

Pass 5: starting run.

hello world

Pass 5: run completed in 60usr/2650sys/2871real ms.

 

 

试运行一下能否侦测系统函数的调用堆栈,这个功能在看源代码的时候用得着,脚本如下:

 

#!/usr/bin/stap

probe kernel.function("do_timer").return {
    print_backtrace();
    printf("\n");
    exit();
}
 

运行输出如下:

 

Returning from:  0xc0155e60 : do_timer+0x0/0x30 [kernel]
Returning to  :  0xc017574d : tick_do_update_jiffies64+0xed/0x170 [kernel]
0xc017597c : tick_sched_timer+0xbc/0xd0 [kernel]
0xc0169a0a : __run_hrtimer+0x7a/0x1c0 [kernel]
0xc0169df0 : hrtimer_interrupt+0x130/0x2a0 [kernel]
0xc05d08e6 : smp_apic_timer_interrupt+0x56/0x8a [kernel]
0xc05ca5d9 : apic_timer_interrupt+0x31/0x38 [kernel]
0xc012ab4a : native_safe_halt+0xa/0x10 [kernel] (inexact)
0xc0109e93 : default_idle+0x53/0xb0 [kernel] (inexact)
0xc0101e4a : cpu_idle+0x8a/0xf0 [kernel] (inexact)
0xc05c4242 : start_secondary+0x1ec/0x1f2 [kernel] (inexact)
 

           不错, Systemtap 对内核的侦测功能应该运行正常了,下面我们来尝试一下 Systemtap 对用户空间的侦测功能,在开发过程中,我们也不时用 Systemtap 来侦测函数的调用堆栈,调用频率,性能如何等等。先写个简单的程序 test.c 试试看。

#include <stdlib.h>
#include <stdio.h>

void func()
{
    int i = 0;
    int count = 0;

    for (i = 0; i < 1000000; ++i)
    {
        ++count;
    }
}


int main(int argc, char** argv)
{
    func();
    return 0;
}
 

          编译 gcc -g  test.c -o test ,用户程序要使用 Systemtap 需要在编译时加 -g 选项。写个简单的脚本 calltime.stp 来测试“ func ”的执行时间。

 

#!/usr/bin/stap

global tm
global call_time

probe begin {
    printf(":\)\n");
}

probe process("./test").function("func") {
    tm = gettimeofday_ns();
}

probe process("./test").function("func").return {
    call_time <<< (gettimeofday_ns() - tm);
    printf("func call_time: %d\n", @avg(call_time));
}

probe end {
    if (@count(call_time) > 0) {
        printf("func call_time: %d\n", @avg(call_time));
    }
}
 

          运行 sudo ./calltime.stp 运行出错了, SystemTap不支持process(" ./test ")的用户 空间 的调试的方法 ,在网上搜罗一番,原来是 Systemtap 对用户空间的调试需要 utrace 支持, utrace 只是在 redhat 系统做了支持, Ubuntu 系统中默认不支持,内核也是默认不支持 utrace 。问题找到了,先给内核打上 utrace 的补丁,到如下网站下载 utrace 2.6.36 内核的补丁。

http://people.redhat.com/roland/utrace/

补丁的顺序如下:

  >cd /src/linux2 .6.36
  >patch – p1 <tracehook.patch
  >patch – p1 <utrace.patch
  >patch – p1 <utrace-ptrace.patch 
 

 

           打好补丁之后,重新编译内核,注意需要选中 utrace 选项 General setup --> Infrastructure for tracing and debugging user processes 然后就是按照上面的步骤重新升级内核,内核升级完成后,先运行

sudo ./calltime.stp
 

等待出现“ :) ”,然后运行 ./test

结果是这样的

 

:)
func call_time: 10291909
 

至此,终于配置好了,可以在系统中作更多的测试学习了。

分享到:
评论

相关推荐

    ubuntu-10.10镜像文件下载链接

    - **软件兼容性问题**:部分较新的软件可能无法在Ubuntu 10.10上正常运行,可以考虑升级到更高版本的Ubuntu。 #### 五、总结 Ubuntu 10.10 作为一款经典的Ubuntu版本,在当时提供了许多先进的特性和改进,至今仍...

    ubuntu10.10编译内核3.0.8实验报告

    本实验报告旨在指导用户在 Ubuntu 10.10 操作系统环境下编译 Linux 3.0.8 内核版本。实验的主要步骤包括安装 Ubuntu 10.10 操作系统、下载和解压 Linux 3.0.8 内核文件、配置编译环境、编译内核、配置内核文件和修改...

    新手XP下硬盘安装ubuntu10.10图文教程

    Ubuntu 10.10在2010年10月正式发布,让众多Ubuntu用户都对这款全新的系统充满期望。毕竟,Ubuntu 10.10是Canonical公司推出的最为...而在Ubuntu 10.10系统中,Light主题得到继续采用,同时在细节上的改善使其更新美观。

    Ubuntu10.10下tftp服务器配置笔记

    本文档介绍了在 Ubuntu 10.10 操作系统下如何配置 TFTP 服务器,从虚拟机网络配置到 TFTP 服务器的搭建,旨在帮助读者快速搭建 TFTP 服务器。 一、虚拟机网络配置 在 Ubuntu 10.10 操作系统下,虚拟机网络配置是必...

    用Ubuntu10.10 dvd版本作为本地源,Ubuntu 10.10 DVD ISO挂载的方式来更新软件

    在本文中,我们将详细介绍如何使用Ubuntu 10.10 DVD ISO文件作为本地软件仓库来更新系统中的软件包。这种方法对于网络不稳定或者带宽有限的环境非常有用,可以有效避免因下载外部资源而造成的延迟或中断问题。 ####...

    在U盘中安装Ubuntu 10.10的方法

    用户可以在不同的计算机上使用同一套系统环境,但需要注意不同计算机硬件配置的差异可能会影响系统兼容性。 - **维护与更新**:与硬盘安装的Ubuntu相同,安装在U盘上的Ubuntu同样需要定期更新系统补丁和安全修复...

    ubuntu10.10安装配置全过程图文详解

    - 可以通过 Linux QQ、Web 版本或使用 Wine 安装 Windows 版本的 QQ 来实现在 Ubuntu 上使用 QQ。 - 对于其他软件,用户可以根据个人需求通过软件中心或命令行进行安装。 通过以上步骤,用户可以从零开始安装并...

    Ubuntu10.10安装指南

    本文将基于提供的文件信息,深入解析Ubuntu 10.10的安装流程及关键步骤,旨在为初次接触或升级至该版本的用户提供详尽指导。 #### 准备工作 在开始安装前,确保你拥有以下资源: - Ubuntu 10.10的ISO镜像文件或Live...

    Ubuntu10.10

    ### Ubuntu 10.10 在 Windows XP 下的安装指南及关键知识点 #### 安装环境与准备 - **操作系统**: Windows XP - **硬盘需求**: 至少 40GB 的空闲空间,用于安装 Ubuntu 10.10 和相关文件。 - **所需文件**: - **...

    Ubuntu10.10下kgdb环境搭建

    **第一步:在主机上安装Ubuntu 10.10** 此步骤相对简单,按照官方指南或社区文档即可完成。 **第二步:安装虚拟机VMware软件** 1. 下载并安装VMware Workstation Full 7.1.4-385536.i386.bundle。 2. 在安装过程...

    Ubuntu 10.10的安装图解过程

    - **对比测试:** 与Windows 7的“微软雅黑”字体进行了对比,结果显示Ubuntu 10.10在16号字体大小上表现更佳,特别是在文字对齐方面。 综上所述,Ubuntu 10.10在安装流程、界面设计以及字体优化等方面进行了大量...

    ubuntu 10.10网络配置10步曲

    ubuntu 10.10网络配置10步曲

    U盘安装ubuntu10.10图文教程

    U盘安装ubuntu10.10图文教程

    ubuntu10.10编译内核步骤

    经过个人实践,包括内核下载和安装gcc,make等工具的介绍,以及从内核的下载到编译到安装过程,不错的教程哦

    Ubuntu 10.10安装配置tftp服务.doc

    TFTP服务在Ubuntu 10.10上的配置并不复杂,但需关注细节,尤其是共享目录的权限设置和服务的启动配置。通过遵循上述步骤,可以有效建立和维护TFTP服务,满足文件传输的基本需求。同时,遇到问题时,应当细致排查,...

    g++4.4 for ubuntu10.10 64bit

    在本文中,我们将深入探讨g++4.4在Ubuntu 10.10 64位环境下的安装、使用以及与其相关的GCC版本和libc-bin的关系。 首先,g++4.4是针对C++编程语言的一个特定版本,它包含了对C++标准库的支持和优化。在这个版本中,...

    ubuntu10.10华为E261的3G上网卡上的移植文档

    4. **USB驱动程序**:为了在Ubuntu 10.10上使用E261,需要识别并安装正确的USB驱动,使得系统能识别并通信于该设备。 5. **ModemManager**:Ubuntu可能已经包含了ModemManager,这是一个处理调制解调器(包括3G数据...

    Ubuntu10.10下嵌入式开发环境的配置.doc

    在Ubuntu10.10环境下,GCC通常已预装,但G++则需要手动安装。此外,还需要安装交叉编译器和其他辅助工具。 **安装G++**: - 打开终端,使用命令`sudo apt-get install g++`进行安装。 **安装交叉编译器**: 1. ...

    一步一步教你在win7下硬盘安装Ubuntu10.10或者ylmf_os3.0

    在安装 Ubuntu10.10 或者 ylmf os3.0 之前,需要在 Win7 下对最后一个盘的大小进行调整,留出 15 到 20G 的空间供 Linux 系统安装使用。同时,需要在 PE 系统下用 PM 或者 PQ 分区工具调整分区大小。 二、安装前的...

Global site tag (gtag.js) - Google Analytics