2016-12-09 4 views
1

私はLinuxのメモリ管理について学んでいます。linux kernel - pte_xxx()APIがモジュールプログラミングで動作していません

私はmmapに似たモジュールを作ろうとします。

しかし、pte_xxx() APIを使用すると、カーネルパニックが発生しました。

私のアーキテクチャは、x86-64であると、Linuxカーネルのバージョンは4.4

だから、私は4レベルのページングを考えています。

pgd_xxx()API、pud_xxx()API、およびpmd_xxx()APIは問題ありません。

しかし、pte_xxx API()を呼び出すと、カーネルパニックが発生しました。

特に、pgd_val(* pgd)、pud_val(* pud)、およびpmd_val(* pmd)はカーネルパニックを引き起こしません。

pte_val(* pte)はカーネルパニックを引き起こします。

私はpte_offset_map(pmd、アドレス)がパニックを引き起こさないことを確認しました。

pte_val()に問題があるようです。

何が起こっているのか分かりません。

私は不適切にコーディングしたようです。

コメントをお願いします。ありがとうございました。

void callback_fn(struct mm_struct *mm) 
{ 
    unsigned long address = mm->mmap->vm_start; 
    pgd_t * pgd = pgd_offset(mm, address); 

    printk("follow_pte() for %lx\n", address); 

    entry->pte = 0; 
    if (!pgd_none(*pgd) && !pgd_bad(*pgd)) { 
     pud_t * pud = pud_offset(pgd, address); 
     struct vm_area_struct * vma = find_vma(mm, address); 

     printk(" pgd = %lx\n", pgd_val(*pgd)); 

     if (pud_none(*pud)) { 
      printk(" pud = empty\n"); 
      return; 
     } 
     if (pud_huge(*pud) && vma->vm_flags & VM_HUGETLB) { 
      entry->pte = pud_val(*pud); 
      printk(" pud = huge\n"); 
      return; 
     } 

     if (!pud_bad(*pud)) { 
      pmd_t * pmd = pmd_offset(pud, address); 

      printk(" pud = %lx\n", pud_val(*pud)); 

      if (pmd_none(*pmd)) { 
       printk(" pmd = empty\n"); 
       return; 
      } 
      if (pmd_huge(*pmd) && vma->vm_flags & VM_HUGETLB) { 
       entry->pte = pmd_val(*pmd); 
       printk(" pmd = huge\n"); 
       return; 
      } 
      if (pmd_trans_huge(*pmd)) { 
       entry->pte = pmd_val(*pmd); 
       printk(" pmd = trans_huge\n"); 
       return; 
      } 
      if (!pmd_bad(*pmd)) { 
       pte_t * pte = pte_offset_map(pmd, address); 

       printk(" pmd = %lx\n", pmd_val(*pmd)); 

       if (!pte_none(*pte)) { 

        // I think pte_val() cause panic. 
        entry->pte = pte_val(*pte); 
        printk(" pte = %lx\n", pte_val(*pte)); 
       } else { 
        printk(" pte = empty\n"); 
       } 
       pte_unmap(pte); 
      } 
     } 
    } 
} 

答えて

0

申し訳ありません、私のソースコードは、別の部分(手順)がカーネルパニックを起こしました。

上記のコードはうまく機能します。ごめんなさい。

関連する問題