解析Linux内核获取当前进程指针的方法(1)

文章作者 100test 发表时间 2007:03:14 16:43:07
来源 100Test.Com百考试题网


一、内存数据表示:

我们在教材或阅读中,经常需要直观的用图示来展示数据在内存中的分布,那么数据是如何在内存中组织的呢?不同的机器有不同的表示法,我们以最常见的Intel X86系列计算机为例来说明这个问题。

如上图示内存示意图:内存低址在上。内存高址在下,内存单位为16bit。对于基于intel i386架构的计算机,系统采用小端字节序来存放数据,所谓小端字节序是指低序字节低地址,高序字节高地址(内存地址增大方向),大端字节序反之,给定系统所用的字节序称为主机字节序;CPU也以小端字节序形式读取数据,如上图所示,如果变量num是16位的short短整类型,则CPU从内存中读出的num=0x1234;如果num是32位的int类型,则CPU从内存中读出的是num=0x56781234,其中num地址是0x12345678,即&.num=0x12345678。

二、linux内核获取进程任务结构的指针

明白了系统内存数据表示,我们现在来看看linux内核是如何获取当前进程的任务结构指针的,以下代码均参照linux内核2.4.0的源码。

在include\asm-i386\ current.h中

#ifndef _I386_CURRENT_H



#define _I386_CURRENT_H



struct task_struct.



static inline struct task_struct * get_current(void)



{



struct task_struct *current.



__asm__("andl %%esp,%0. ":"=r" (current) : "0" (~8191UL)).



return current.



}



#define current get_current()



#endif /* !(_I386_CURRENT_H) */


相关文章


解析Linux内核获取当前进程指针的方法(2)
推荐:手机Linux系统还需奋力一搏
解析Linux内核获取当前进程指针的方法(1)
Linux程序开发:QT中的多线程编程(4)
用Linux操作系统防火墙防止DOS攻击
澳大利亚华人论坛
考好网
日本华人论坛
华人移民留学论坛
英国华人论坛