- 论坛徽章:
- 0
|
- vmalloc_fault:
- {
-
- int index = pgd_index(address);
- unsigned long pgd_paddr;
- pgd_t *pgd, *pgd_k;
- pud_t *pud, *pud_k;
- pmd_t *pmd, *pmd_k;
- pte_t *pte_k;
- asm("movl %%cr3,%0":"=r" (pgd_paddr));
- pgd = index + (pgd_t *)__va(pgd_paddr);
- pgd_k = init_mm.pgd + index;
- if (!pgd_present(*pgd_k))
- goto no_context;
- pud = pud_offset(pgd, address);
- pud_k = pud_offset(pgd_k, address);
- if (!pud_present(*pud_k))
- goto no_context;
-
- pmd = pmd_offset(pud, address);
- pmd_k = pmd_offset(pud_k, address);
- if (!pmd_present(*pmd_k))
- goto no_context;
- set_pmd(pmd, *pmd_k);
- pte_k = pte_offset_kernel(pmd_k, address);
- if (!pte_present(*pte_k))
- goto no_context;
- return;
- }
复制代码 用户态的程序通过中断进入内核态后会执行中断处理函数,那么中断处理函数的线性地址如何转换成物理地址呢?
我在缺页异常中找到如上程序,看程序似乎是把主内核表中pmd项拷贝到用户程序的pmd中。假设这里使用了4级映射,代码pud = pud_offset(pgd, address);是查找线性地址address对应的pud项的线性地址,那么会不会出现pud表根本没有建立的情况呢?与此类似的还有pmd表。如果pud表与pmd表没有建立,这段代码就无法执行了。 |
|