4.4.2 当前进程(current宏)

      当一个进程在某个CPU上正在执行时,内核如何获得指向它的task_struct的指针?上面所提到的存储方式为达到这一目的提供了方便。在linux/include/ i386current.h 中定义了current宏,这是一段与体系结构相关的代码:

 

static inline struct task_struct * get_current(void)

{

struct task_struct *current;

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

return current;

}

 

   实际上,这段代码相当于如下一组汇编指令(设p是指向当前进程task_struc结构的指针):

   

movl $0xffffe000, %ecx

andl %esp, %ecx

movl %ecx, p

 

换句话说,仅仅只需检查栈指针的值,而根本无需存取内存,内核就可以导出task_struct结构的地址。

   

在本书的描述中,会经常出现current宏,在内核代码中也随处可见,可以把它看作全局变量来用,例如,current->pid返回在CPU上正在执行的进程的标识符。

 

    另外,在include/ i386/processor.h中定义了两个函数free_task_struct(  ) alloc_task_struct(  ),前一个函数释放8KBtask_union内存区,而后一个函数分配8KBtask_union内存区。