Chinaunix首页 | 论坛 | 博客
  • 博客访问: 173553
  • 博文数量: 108
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 1065
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-29 08:56
文章分类

全部博文(108)

文章存档

2011年(11)

2010年(46)

2009年(29)

2008年(22)

我的朋友

分类: LINUX

2011-01-20 11:30:14

do_execve->bprm_mm_init->mm_alloc->mm_init->mm_alloc_pgd->pgd_alloc->pgd_ctor

   i386下,pgtable_cache_init设置pgd分配的构造函数pgd_ctor,
   每次调用pgd_alloc时,pgd_cto人自动被调用,复制内核页表。
  
   powerpc下,内核页表用bats寄存器或tlb1中的项直接映射低端物理内存,不使用pte,
   高端物理内存和io内存使用pte。在 tlbmiss时,判断异常访问地址是在内核还是用户空间,
   在内核空间时使用swapper_pg_dir页表,在用户空间时使用SPRG3中保存的进程页表基地址,
   在页表中找到pte,转换成tlb后加载到tlb0中。
   内核访问低端物理内存(0xc0000000-0xc0000000+768M)永远不会出现tlbmiss,
   因为它们由bat或tlb1永久映射,在系统运行期间不会改变
   mapin_ram()函数
阅读(538) | 评论(0) | 转发(0) |
0

上一篇:quagga 各部分通讯备忘

下一篇:好习惯

给主人留下些什么吧!~~