概要 ページアッパーディレクトリが物理メモリ上に存在するか確認する 詳細 CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる 2以下 1を返す それ以外 pud_flags()で取得したページアッパーディレクトリのフラグと_PAGE_PRESENTの論理積の結果を…
概要 ページアッパーディレクトリに設定されているフラグを取得する 詳細 native_pud_val()で取得したページアッパーディレクトリのアドレスとpud_flags_mask()で取得したページアッパーディレクトリのフラグマスクの論理積を返す
概要 ページアッパーディレクトリのフラグマスクを取得する 詳細 pud_pfn_mask()で取得したページアッパーディレクトリのアドレスマスクを反転した値を返すため、アドレス以外のbit値をフラグとして利用できるものとする
概要 ページアッパーディレクトリのページサイズ拡張(PSE)の状態を確認する 詳細 CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる 2以下 0を返す それ以外 pud_val()でページアッパーディレクトリの値を取得し、取得した値の_PAGE_PSEと_PAGE_PR…
概要 ページアッパーディレクトリのエントリに該当するアドレスを取得する 詳細 CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる CONFIG_PGTABLE_LEVELSの値が3を超える場合 pgd_page_vaddr()で取得したページグローバルディレクトリの仮想アド…
概要 仮想アドレスからページグローバルディレクトリのインデックスを取得する 詳細 unsigned long型で表されるaddressをPUD_SHIFT分右にシフトた値とPUDのエントリ数であるPTRS_PER_PUDから1を引いた値の論理積を取ることで、ページグローバルディレクトリ…
概要 ページグローバルディレクトリの仮想アドレスを取得する 詳細 CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる CONFIG_PGTABLE_LEVELSが3を超える場合 pgd_val()でページグローバルディレクトリの値を取得し、その値とPTE_PFN_MASKの論理積…
概要 ページアッパーディレクトリの仮想アドレスを取得する 詳細 CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる CONFIG_PGTABLE_LEVELSが2を超える場合 pud_val()でページアッパーディレクトリの値を取得し、その値とpud_pfn_mask()で取得した…
概要 ページミドルディレクトリの値を返す 詳細 pmd_t型の値valを引数として受け取り、CONFIG_PARAVIRTと__PAGETABLE_PMD_FOLDED、CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる CONFIG_PARAVIRTが有効でCONFIG_PGTABLE_LEVELSが3以上 PVOP_CA…
概要 ページミドルディレクトリの仮想アドレスを取得する 詳細 pmd_val()でページミドルディレクトリの値を取得し、その値とpmd_pfn_mask()で取得したページミドルディレクトリのマスク値との論理積を求めることでページミドルディレクトリの物理アドレスを…
概要 ページミドルディレクトリのアドレスマスクを取得する 詳細 native_pmd_val()でページミドルディレクトリの値を取得し、_PAGE_PSEフラグが立っていた場合はPATが有効なためPHYSICAL_PMD_PAGE_MASKを、それ以外の場合はPTE_PFN_MASKを返す
概要 ページアッパーディレクトリのアドレスマスクを取得する 詳細 native_pud_val()でページアッパーディレクトリの値を取得し、_PAGE_PSEフラグが立っていた場合はPATが有効なためPHYSICAL_PUD_PAGE_MASKを、それ以外の場合はPTE_PFN_MASKを返す
概要 ページテーブルエントリ(PTE)のフラグを示すマクロ 詳細 bit番号 マクロ フラグ 0 _PAGE_PRESENT 0: 物理メモリに存在しない1: 存在する 1 _PAGE_RW 0: R ONLY1: R/W 2 _PAGE_USER 0: カーネルモード1: ユーザーモード 3 _PAGE_PWT 0: キャッシュのライ…
概要 ページグローバルディレクトリが無効なアドレスか確認する 詳細 PTRS_PER_PUDとCONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる PTRS_PER_PUDの値が1以上の場合 pgd_val()でページグローバルディレクトリのアドレスを取得し、取得したアド…
概要 ページアッパーディレクトリのアドレスが無効なアドレスか確認する 詳細 PTRS_PER_PMDとCONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる PTRS_PER_PMDの値が1以下の場合 pud_val()でページアッパーディレクトリのアドレスを取得し、取得し…
概要 ページミドルディレクトリのアドレスが無効なアドレスか確認する 詳細 native_pmd_val()で取得したページミドルディレクトリの値が0なら1、それ以外の場合は0を返す
概要 ページミドルディレクトリのアドレスを返す 詳細 CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる CONFIG_PGTABLE_LEVELSが2を超える場合 pmd_t型の値をpmdval_t型に変換して返す それ以外 native_pgd_val()でページグローバルディレクトリ…
概要 pmdval_t型の値をpmd_t型に変換する 詳細 _ CONFIG_PARAVIRTとCONFIG_PGTABLE_LEVELS、__PAGETABLE_PMD_FOLDED_の値によって以下のように処理が異なる CONFIG_PARAVIRTが定義されていてCONFIG_PGTABLE_LEVELSの値が3以上の場合 PVOP_CALLEEx()にvalが32…
概要 pmdval_t型の値をpmd_t_型に変換する 詳細 pmdval_t型の値valを引数として受け取り、valを値とするpmd_t_型の値を返す
概要 ページアッパーディレクトリの値を返す 詳細 pud_t型の値valを引数として受け取り、CONFIG_PARAVIRTと__PAGETABLE_PUD_FOLDED、CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる CONFIG_PARAVIRTが有効でCONFIG_PGTABLE_LEVELSの値が4 PVOP_…
概要 ページアッパーディレクトリのアドレスを返す 詳細 CONFIG_PGTABLE_LEVELSの値によって以下のように処理が異なる CONFIG_PGTABLE_LEVELSが3を超える場合 pud_t型の値をpudval_t型に変換して返す それ以外 native_pgd_val()でページグローバルディレクト…
概要 pudval_t型の値をpud_t型に変換する 詳細 pudval_t型の値を引数として受け取り、CONFIG_PARAVIRTとCONFIG_PGTABLE_LEVELS、__PAGETABLE_PUD_FOLDEDの値によって以下のように処理が異なる CONFIG_PARAVIRTが定義されていてCONFIG_PGTABLE_LEVELSの値が4…
概要 pmdval_t型の値をpud_t_型に変換する 詳細 pmdval_t型の値valを引数として受け取り、valを値とするpud_t_型の値を返す
概要 pgdval_t型の値をpgd_t型に変換する 詳細 pgdval_t型の値を引数として受け取り、CONFIG_PARAVIRTの値によって以下のように処理が異なる 有効 PVOP_CALLEEx()にvalが32bitの場合は引数を1つ、64bitモードの場合は第1引数valの下位32bitを、第2引数に上位…
概要 pgdval_t型の値をpgd_t型に変換する 詳細 pgdval_t型の値valを引数として受け取り、valを値とするpgd_t型の値を返す
概要 ページグローバルディレクトリの値を返す 詳細 pgd_t型の値valを引数として受け取り、CONFIG_PARAVIRTの値によって以下のように処理が異なる 有効 PVOP_CALLEEx()にvalが32bitの場合は引数を1つ、64bitモードの場合は第1引数valの下位32bitを、第2引数…
概要 ページグローバルディレクトリのアドレス返す 詳細 pgd_t型の引数からページグローバルディレクトリのアドレスの値を返す
概要 受け取った値をそのまま帰す 詳細 __PV_IS_CALLEE_SAVE()に関数名を渡すが、CONFIG_X86_32とCONFIG_X86_PAEの値によって引数として渡す関数が変わる CONFIG_X86_32が有効でCONFIG_X86_PAEが無効な場合(PAEが有効でないただの32bitモードの場合) _paravi…
概要 受け取った値をそのまま返す 詳細 32bitモードの場合はu32型、それ以外の場合はu64型の引数の値を受け取り、値をそのまま返す関数 struct pv_mmu_ops構造体のメソッドとして使用されるため関数として定義されているものと思われる
概要 任意の関数でstruct paravirt_callee_save型の変数を初期化する 詳細 関数名を引数として受け取り、struct paravirt_callee_save型のfuncメンバに関数のポインタを代入して初期化する