【发布时间】:2011-08-11 14:12:26
【问题描述】:
我在一个程序中多次调用getpid()(测试系统调用的效率),但是当我使用strace获取trace时,只有一个getpid( ) 调用被捕获。
代码很简单:
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
void print_usage(){
printf("Usage: program count\n");
exit(-1);
}
int main(int argc, char** argv){
if(argc != 2)
print_usage();
int cnt = atoi(argv[1]);
int i = 0;
while(i++<cnt)
getpid();
return 0;
}
我用gdb 得到了这个:
(gdb) disasse
Dump of assembler code for function getpid:
0xb76faac0 <getpid+0>: mov %gs:0x4c,%edx
0xb76faac7 <getpid+7>: cmp $0x0,%edx
0xb76faaca <getpid+10>: mov %edx,%eax
0xb76faacc <getpid+12>: jle 0xb76faad0 <getpid+16>
0xb76faace <getpid+14>: repz ret
0xb76faad0 <getpid+16>: jne 0xb76faadc <getpid+28>
0xb76faad2 <getpid+18>: mov %gs:0x48,%eax
0xb76faad8 <getpid+24>: test %eax,%eax
0xb76faada <getpid+26>: jne 0xb76faace <getpid+14>
0xb76faadc <getpid+28>: mov $0x14,%eax
0xb76faae1 <getpid+33>: call *%gs:0x10
0xb76faae8 <getpid+40>: test %edx,%edx
0xb76faaea <getpid+42>: mov %eax,%ecx
0xb76faaec <getpid+44>: jne 0xb76faace <getpid+14>
0xb76faaee <getpid+46>: mov %ecx,%gs:0x48
0xb76faaf5 <getpid+53>: ret
我不太了解汇编代码。如果有人可以对此进行详细解释,那也会很有帮助。根据我的观察,除了第一个 getpid() 调用外,没有执行"call *%gs:0x10" (, 它跳转到 vdso),这可能是后续 的原因getpid() 调用未被捕获。但我不知道为什么。
linux内核:2.6.24-29 海合会 (GCC) 4.2.4 libc 2.7,
谢谢!
【问题讨论】:
标签: linux-kernel system-calls libc strace