cachepc-linux

Fork of AMDESE/linux with modifications for CachePC side-channel attack
git clone https://git.sinitax.com/sinitax/cachepc-linux
Log | Files | Refs | README | LICENSE | sfeed.txt

hugetlbpage.rst (1450B)


      1.. SPDX-License-Identifier: GPL-2.0
      2
      3.. include:: ../disclaimer-zh_TW.rst
      4
      5:Original: :ref:`Documentation/arm64/hugetlbpage.rst <hugetlbpage_index>`
      6
      7Translator: Bailu Lin <bailu.lin@vivo.com>
      8            Hu Haowen <src.res@email.cn>
      9
     10=====================
     11ARM64中的 HugeTLBpage
     12=====================
     13
     14大頁依靠有效利用 TLBs 來提高地址翻譯的性能。這取決於以下
     15兩點 -
     16
     17  - 大頁的大小
     18  - TLBs 支持的條目大小
     19
     20ARM64 接口支持2種大頁方式。
     21
     221) pud/pmd 級別的塊映射
     23-----------------------
     24
     25這是常規大頁,他們的 pmd 或 pud 頁面表條目指向一個內存塊。
     26不管 TLB 中支持的條目大小如何,塊映射可以減少翻譯大頁地址
     27所需遍歷的頁表深度。
     28
     292) 使用連續位
     30-------------
     31
     32架構中轉換頁表條目(D4.5.3, ARM DDI 0487C.a)中提供一個連續
     33位告訴 MMU 這個條目是一個連續條目集的一員,它可以被緩存在單
     34個 TLB 條目中。
     35
     36在 Linux 中連續位用來增加 pmd 和 pte(最後一級)級別映射的大
     37小。受支持的連續頁表條目數量因頁面大小和頁表級別而異。
     38
     39
     40支持以下大頁尺寸配置 -
     41
     42  ====== ========   ====    ========    ===
     43  -      CONT PTE    PMD    CONT PMD    PUD
     44  ====== ========   ====    ========    ===
     45  4K:         64K     2M         32M     1G
     46  16K:         2M    32M          1G
     47  64K:         2M   512M         16G
     48  ====== ========   ====    ========    ===
     49