日期:2014-05-16  浏览次数:20730 次

Linux内核探讨-- 第七章

文是个人分析《Linux内核设计与实现》而写的总结,欢迎转载,请注明出处:

                                                                              http://blog.csdn.net/dlutbrucezhang/article/details/13621133


      第七章--进程地址空间
      内核运行在内核地址空间中,相应的,用户程序需要运行,肯定也需要地址空间,这其实是属于资源的。进程运行在自己的地址空间中,进程描述符中有指向这一地址的指针。线程没有自己独立的地址空间,所以,它和进程共享地址空间,也就是说线程的地址空间字段也是指向它所在进程的地址空间。

      1.地址空间
      内存区域也称为虚拟内存区域,它包含多个不同的内存对象。
      代码段:可执行文件的内存映射
      数据段:可执行文件已初始化的全局变量的内存映射
      bss 段:可执行文件未初始化的全局变量的内存映射
      进程的用户空间栈的零页内存映射
      共享库的代码段,数据段和bss段也会包含在进程的地址空间中
      。。。。。。

      2.内存描述符
      为了更好的理解进程的地址空间,首先贴出它的数据结构,之后再简单的介绍其中的字段。
struct mm_struct
{
    struct vm_area_struct *mmap;     //list of VMA
    rb_root_t mm_rb;                     //指向vma段红黑树的指针
    struct vm_area_struct *mmap_cache;   //last find_vma result  存储上一次查询的操作的结果
    pgd_t *pgd;                            //进程页目录的起始地址
    atomic_t mm_users;                    //how many users with user space
    atomic_t mm_count;                    //how many reference to "struct mm_struct"
    int map_count;                        //Number of VMA
    struct rw_semaphore mmap_sem;        //对mmap操作的互赤信号量
    spinlock_t page_table_lock;            //Protects task page tables and mm->rss
    struct list_head mmlist;            //list of all active mm's. These are globally together off init_mm.mmlist,and are protected by mmlist_lock
    unsigned long start_code,end_code,start_data,end_data;
    unsigned long start_brk,brk,start_stack;
    unsigned long arg_start,arg_end,env_start,env_end;
    unsigned long rss,total_vm,locked_vm;     //rss进程内容驻留在物理内存的页面地址
    unsigned long def_flags;
    unsigned long cpu_vm_mask;
    unsigned long swap_address;     //页面换出过程用到交换空间地址

    un