Linux oprofile 使用

为了找到我们Android 2.3@众志小本上的性能瓶颈,我们使用功能强大的linux性能分析工具oprofile

 

首先,我们需要内核的支持。所以,要求北大编译了一个支持Oprofile的内核版本。

 

其次,如何使用?

 

opcontrol --setup

opcontrol --start

opcontrol --stop

 

然后,查看分析报告

opreport

 

[c-sharp] view plain copy print ?
  1. CPU: CPU with timer interrupt, speed 0 MHz (estimated)  
  2. Profiling through timer interrupt  
  3.           TIMER:0|  
  4.   samples|      %|  
  5. ------------------  
  6.      3447 15.3452 Xunigfx  
  7.      3358 14.9490 libvcllu.so  
  8.      3062 13.6313 libswlu.so  
  9.      2139  9.5223 no-vmlinux  
  10.      1571  6.9937 libuno_sal.so.3  
  11.      1512  6.7311 libcairo.so.2.10800.4  
  12.      1417  6.3082 libpthread-2.9.so  
  13.       801  3.5659 libgcc_s.so.1  
  14.       791  3.5213 libc-2.9.so  
  15.       743  3.3077 libfreetype.so.6.3.20  
  16.       740  3.2943 libsvxlu.so  
  17.       415  1.8475 libsvllu.so  
  18.       367  1.6338 soffice.bin  
  19.       267  1.1886 libtllu.so  
CPU: CPU with timer interrupt, speed 0 MHz (estimated) Profiling through timer interrupt TIMER:0| samples| %| ------------------ 3447 15.3452 Xunigfx 3358 14.9490 libvcllu.so 3062 13.6313 libswlu.so 2139 9.5223 no-vmlinux 1571 6.9937 libuno_sal.so.3 1512 6.7311 libcairo.so.2.10800.4 1417 6.3082 libpthread-2.9.so 801 3.5659 libgcc_s.so.1 791 3.5213 libc-2.9.so 743 3.3077 libfreetype.so.6.3.20 740 3.2943 libsvxlu.so 415 1.8475 libsvllu.so 367 1.6338 soffice.bin 267 1.1886 libtllu.so 

也可以使用opreport -d 查看所有的细节,包括函数链接符号的地址。

然后通过objdump结合虚拟地址来查看函数名。

 

另外我们可以发现,在android 2.3/externl/目录下也有个oprofile。对于这个层的oprofile,我们有同学有研究:

http://hi.baidu.com/snownight/blog/item/6d81c3ce305fc11193457e56.html

 

具体的Oprofile详细介绍参见:

http://www.ibm.com/developerworks/cn/linux/l-oprof/

 

 

补充:

出现的问题:

 opcontrol --init

 

cat: can't open '/dev/oprofile/cpu_type': No such file or directory

Unable to open cpu_type file for reading

Make sure you have done opcontrol --init

cpu_type 'unset' is not valid

you should upgrade oprofile or force the use of timer mode

解决:

mount -t oprofilefs nodev /dev/oprofile

 

 

http://blog.csdn.net/Kasmile/archive/2009/07/30/4393482.aspx

 

http://blog.csdn.net/louieuser/archive/2011/01/19/6152175.aspx

Arm平台Oprofile移植

 

 

来自:http://blog.csdn.net/fengkehuan/article/details/6309674

你可能感兴趣的:(android,linux,timer,File,工具,profiling)