Chinaunix首页 | 论坛 | 博客
  • 博客访问: 699007
  • 博文数量: 193
  • 博客积分: 1875
  • 博客等级: 上尉
  • 技术积分: 2187
  • 用 户 组: 普通用户
  • 注册时间: 2010-10-23 23:21
个人简介

有时候,就是想窥视一下不知道的东东,因为好奇!

文章分类

全部博文(193)

文章存档

2024年(9)

2023年(3)

2020年(1)

2019年(1)

2018年(1)

2017年(2)

2016年(69)

2015年(53)

2014年(14)

2013年(1)

2012年(5)

2011年(25)

2010年(9)

分类: LINUX

2016-03-05 22:47:30

  1. ftrace是什么
   ftrace是内核的跟踪器。可追踪插件追踪内核事件。
   ftrace的用户界面是在debugfs文件系统上生成的。多数情况下挂载到/sys/kernel/debug目录下
    对应挂载命令“mount -t debugfs debugfs /sys/kernel/debug”。 ftrace目录为/sys/kernel/debug/tracing,下面有ftrace控制相关的文件。
   
 2. 使用ftrace
   使用举例如下:
   a. 追踪函数调用
     
   上面看出,进程调用程序是从几个不同的函数调用的。
   b. 使用通配符追踪多个函数 
    
    上面结果记录了以irq开头的函数。
   c. 追踪指定模块中的函数
     
   d. 获取函数的调用关系
     
   上图中使用缩进和大括号清晰的显示调用关系。
   e. 函数回溯
     
    上图中对象函数的追踪入口后面出现了,它的后面显示的是回溯的结果。
   f. 进行函数概要分析
     
   上图中,Time表示累计值,Avg表示平均值,S^2表示平均方差。其中值包含函数内休眠时间,和函数内调用其它函数的处理时间。
   这此时间可以分别用options/sleep-time和options/graph-time来修正。
     修正睡眠时间
     
     修正调用其它函数的时间
     
   g. 查找占用内核栈最大的位置
     
   上图Depth表示该函数内最大的栈消耗量, Size表示仅该函数内的栈消耗量
   h. 测量中断延迟
     echo irqsoff > current_tracer
     echo 1 > tracing_on
      echo 0 > tracing_on
     cat trace 
     当前环境不支持
   i. 记录内核事件
    
   上图看出,不同任务处理时发生中断
j. 查看特定中断
      
     
      删除过滤如下
     
k. 查看可追踪事件
   /sys/kernel/debug/tracing/available_events文件中的内容为可追踪事件
   /sys/kernel/debug/tracing/events目录下为各追踪事件组名和事件名。如下:
   
  
阅读(1581) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~