Linux2.6对新型CPU的支持(2)

http://tech.ddvip.com   2006年03月31日    社区交流

本文详细介绍Linux2.6对新型CPU的支持(2)

  由用户态经库函数进入内核态

  为了配合内核使用新的系统调用方式,glibc中要做一定的修改。新的glibc-2.3.2(及其以后版本中)中已经包含了这个改动,在glibc源代码的sysdeps/unix/sysv/linux/i386/sysdep.h文件中,处理系统调用的宏INTERNAL_SYSCALL在不同的编译选项下有不同的结果。在打开支持sysenter/sysexit指令的选项I386_USE_SYSENTER下,系统调用会有两种方式,在静态链接(编译时加上-static选项)情况下,采用"call *_dl_sysinfo"指令;在动态链接情况下,采用"call *%gs:0x10"指令。这两种情况由glibc库采用哪种方法链接,实际上最终都相当于调用某个固定地址的代码。下面我们通过一个小小的程序,配合gdb来验证。

  首先是一个静态编译的程序,代码很简单:

  main()
{
  getuid();
}

  将代码加上static选项用gcc静态编译,然后用gdb装载并反编译main函数。

[root@test opt]# gcc test.c -o ./static -static
[root@test opt]# gdb ./static
(gdb) disassemble main
0x08048204 <main+0>:  push  %ebp
0x08048205 <main+1>:  mov  %esp,%ebp
0x08048207 <main+3>:  sub  $0x8,%esp
0x0804820a <main+6>:  and  $0xfffffff0,%esp
0x0804820d <main+9>:  mov  $0x0,%eax
0x08048212 <main+14>:  sub  %eax,%esp
0x08048214 <main+16>:  call  0x804cb20 <__getuid>
0x08048219 <main+21>:  leave
0x0804821a <main+22>:  ret

  可以看出,main函数中调用了__getuid函数,接着反编译__getuid函数。

来源:Linux 爱好者    作者:刘子锐    责编:豆豆技术应用

正在加载评论...