`
longxj
  • 浏览: 101827 次
  • 性别: Icon_minigender_1
  • 来自: 南京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

memory region and red-black tree

阅读更多

当一个进程要增加线性空间时,kernel首先检查看是不是现有的memory region是不是可以被增大,如果不可以的话,就创建一个新的memory region。一个进程可以包含多个memory region,他们用
list结构进行存储,考虑到如果一个进程包含太多的memory region时,查找一个特定的线性地址在哪个memory region时,开销太大。所以每个进程的mm_struct(也就是跟内存分配有关的数据结构)
还有一个结构,保存了所有memory region的指针,这个结构是一个红黑树,所以可以方便地查找特定的线性地址所在的memory region.一般的访问是通过list还进行的,只有少数像查找一个特定的线性
地址时才会用到红黑树的结构。
2009/02/06 五

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics