测量编号页面错误发生在Linux上的程序

时间:2012-05-01 01:42:01

标签: linux-kernel posix system-calls page-fault

我正在Linux调度程序上做一个项目,试图最小化页面错误的数量。

我已完成算法实现,我需要测量效果。我想知道Linux是否提供了在整个执行过程中发生的记录页数错误的工具?

基本上,我想要像

这样的东西
$ pfstat ./a.out
page faults: 3
Execution Time: 1003 ms

有这样的工具吗?我想在决定自己写一个之前确定一下,这将是很多工作......

2 个答案:

答案 0 :(得分:3)

我建议perf-stat

$ perf stat make

 Performance counter stats for 'make':

          4.142908 task-clock                #    0.781 CPUs utilized          
                 0 context-switches          #    0.000 K/sec                  
                 0 CPU-migrations            #    0.000 K/sec                  
               318 page-faults               #    0.077 M/sec                  
         3,111,777 cycles                    #    0.751 GHz                    
         1,956,914 stalled-cycles-frontend   #   62.89% frontend cycles idle   
         2,275,123 stalled-cycles-backend    #   73.11% backend  cycles idle   
        11,244,599 instructions              #    3.61  insns per cycle        
                                             #    0.20  stalled cycles per insn [65.87%]
     <not counted> branches                
     <not counted> branch-misses           

       0.005305316 seconds time elapsed

它会计算页面错误以及许多其他性能计数器。

但它要求您安装包perf

答案 1 :(得分:1)

在大多数系统/usr/bin/time上都会报告页面错误,例如:

$ /usr/bin/time /bin/true
0.00user 0.00system 0:00.00elapsed 0%CPU (0avgtext+0avgdata 1632maxresident)k
40inputs+0outputs (1major+141minor)pagefaults 0swaps